:root{
  --bg:#0b0f1a; --bg2:#0e1425;
  --card:#141b30; --card2:#1a2240;
  --ink:#eef1f8; --ink2:#9aa4c7;
  --brand:#ffb84d; --brand2:#ff7a2e;
  --ok:#22d39d; --warn:#ffc84d; --danger:#ff5c72;
  --line:#263253; --shadow:0 10px 30px rgba(0,0,0,.4);
  --radius:18px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:'Pretendard','Apple SD Gothic Neo','Noto Sans KR',system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased}
button{font-family:inherit}
[hidden]{display:none !important}
.bg-grid{
  position:fixed;inset:0;z-index:-1;opacity:.25;
  background:
    radial-gradient(1000px 600px at 10% 0%,#1a2460 0,transparent 60%),
    radial-gradient(800px 500px at 100% 20%,#32124a 0,transparent 55%),
    linear-gradient(180deg,#0b0f1a,#0b0f1a 40%,#0a0d16);
}
.wrap{max-width:720px;margin:0 auto;padding:28px 18px 80px}

/* HERO */
.hero{text-align:center;padding:18px 4px 10px;animation:drop .55s ease-out both}
.ribbon{display:inline-block;font-size:13px;letter-spacing:.02em;background:linear-gradient(90deg,#2a3b78,#3a2d6e);padding:8px 14px;border-radius:999px;color:#bcd0ff;box-shadow:inset 0 0 0 1px #3c4c8a}
.hero h1{font-size:26px;line-height:1.3;margin:14px 0 8px;font-weight:800;letter-spacing:-.02em;background:linear-gradient(90deg,#fff,#ffd9a8);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero .sub{color:var(--ink2);margin:0 0 10px;font-size:15px}
.hero .urgency{color:#ffd38a;background:rgba(255,184,77,.09);border:1px solid rgba(255,184,77,.25);padding:10px 14px;border-radius:12px;display:inline-block;font-weight:600;font-size:14px;margin:8px 0 4px}
.hero .deadline{color:#ffb0b8;font-weight:600;margin:8px 0 0;font-size:14px}

/* Narrative panels */
.panel{margin:22px 0 0;background:linear-gradient(160deg,#141b30,#1a2240);border:1px solid var(--line);border-radius:var(--radius);padding:18px 18px 16px;box-shadow:var(--shadow);animation:rise .55s ease-out both}
.panel h3{font-size:15px;letter-spacing:.04em;color:#ffd38a;margin:0 0 10px;display:flex;align-items:center;gap:8px;font-weight:800}
.panel .body{color:#cdd6f0;line-height:1.7;font-size:14.5px;white-space:pre-wrap}
.panel.host{background:linear-gradient(160deg,#231a3e,#2c1e4a);border-color:#4a3c78}
.panel.host h3{color:#bcd0ff}
.panel.host .body{color:#e3e6ff;font-style:italic}
.panel.pay{background:linear-gradient(160deg,#3a1d24,#2a1620);border-color:#7d2a3c}
.panel.pay h3{color:#ffb0b8}
.section-divider{display:flex;align-items:center;gap:10px;margin:26px 4px 6px;color:#6f7aa2;font-size:12px;letter-spacing:.1em;text-transform:uppercase;font-weight:800}
.section-divider:before,.section-divider:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,#2a345a,transparent)}

/* Cards */
.events{display:grid;gap:16px;margin-top:22px}
@media(min-width:720px){.events{grid-template-columns:1fr 1fr}}
.card{
  background:linear-gradient(160deg,var(--card),var(--card2));
  border:1px solid var(--line);
  border-radius:var(--radius);padding:18px 18px 16px;
  box-shadow:var(--shadow);position:relative;overflow:hidden;
  animation:rise .6s .1s ease-out both;
}
.card.full{opacity:.55;filter:grayscale(.2)}
.card::before{content:"";position:absolute;inset:-1px;background:linear-gradient(120deg,transparent,rgba(255,184,77,.12),transparent);transform:translateX(-120%);transition:transform .8s}
.card:hover::before{transform:translateX(120%)}
.card-head{display:flex;align-items:center;gap:8px}
.card-head .time{font-weight:800;font-size:15px;color:#ffd38a}
.card-head .badge{font-size:11px;letter-spacing:.08em;background:linear-gradient(90deg,#ff5c72,#ff8a5b);color:#fff;padding:3px 8px;border-radius:999px;font-weight:800}
.card h2{font-size:20px;margin:6px 0 4px;font-weight:800}
.card .desc{margin:0 0 14px;color:var(--ink2);font-size:14px;line-height:1.5}
.meter{height:9px;background:rgba(255,255,255,.06);border-radius:999px;overflow:hidden;margin:6px 0}
.meter .bar{height:100%;background:linear-gradient(90deg,#22d39d,#6bf0c2);border-radius:999px;transition:width .9s cubic-bezier(.2,.7,.2,1)}
.meter-warn .bar{background:linear-gradient(90deg,#ffb84d,#ffd38a)}
.meter-danger .bar{background:linear-gradient(90deg,#ff5c72,#ff8a5b)}
.counts{display:flex;align-items:baseline;gap:6px;font-size:14px;color:var(--ink2);margin-top:8px}
.counts .cur{font-size:26px;font-weight:900;color:#fff;letter-spacing:-.02em}
.counts .sep{opacity:.5}
.counts .cap{font-weight:700;color:var(--ink)}
.pill{margin-left:auto;padding:4px 10px;border-radius:999px;font-weight:800;font-size:12px;letter-spacing:.03em}
.pill-ok{background:rgba(34,211,157,.12);color:#22d39d;border:1px solid rgba(34,211,157,.35)}
.pill-warn{background:rgba(255,200,77,.12);color:#ffc84d;border:1px solid rgba(255,200,77,.4)}
.pill-danger{background:rgba(255,92,114,.12);color:#ff5c72;border:1px solid rgba(255,92,114,.4);animation:pulse 1.2s infinite}
.full-pill{background:rgba(100,100,100,.2);color:#aaa;border:1px solid #333}
.btn-apply{
  display:block;width:100%;margin-top:14px;padding:14px;
  background:linear-gradient(90deg,var(--brand2),var(--brand));
  color:#1a0f00;border:0;border-radius:12px;font-size:16px;font-weight:900;cursor:pointer;
  box-shadow:0 8px 22px rgba(255,122,46,.3);transition:transform .15s,filter .15s;
  letter-spacing:-.01em;
}
.btn-apply:hover{filter:brightness(1.05)}
.btn-apply:active{transform:translateY(1px)}
.btn-apply[disabled]{background:#2a3250;color:#6c7394;box-shadow:none;cursor:not-allowed}

/* INFO */
.info{margin:26px 0 0;background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:14px;padding:14px 16px}
.info-row{display:flex;gap:10px;padding:7px 0;font-size:14px;align-items:flex-start}
.info-row + .info-row{border-top:1px dashed rgba(255,255,255,.08)}
.info-row b{flex:0 0 80px;color:#ffd38a;font-weight:700}
.info-row span{color:var(--ink2);line-height:1.6;white-space:pre-wrap}
.info-row a.tel{color:#ffd38a;font-weight:800;text-decoration:none;border-bottom:1px dashed rgba(255,211,138,.4);margin-left:4px}
.foot{text-align:center;margin-top:26px;color:var(--ink2);font-size:13px;line-height:1.6;padding:0 10px}

/* Modal */
.modal{position:fixed;inset:0;background:rgba(5,8,18,.72);display:flex;align-items:center;justify-content:center;z-index:100;padding:16px;animation:fade .2s ease-out both;backdrop-filter:blur(3px)}
.modal-card{width:100%;max-width:420px;background:linear-gradient(160deg,#161f3a,#0f162d);border:1px solid #2c3a68;border-radius:20px;padding:22px;position:relative;box-shadow:var(--shadow);animation:rise .3s ease-out both}
.modal-close{position:absolute;top:10px;right:12px;background:transparent;color:#8b97bf;border:0;font-size:28px;cursor:pointer}
.modal-title{margin:0 0 4px;font-size:22px;font-weight:800}
.modal-sub{color:#ffd38a;margin:0 0 16px;font-weight:700;font-size:14px}
.modal-card label{display:block;margin:10px 0}
.modal-card label > span{display:block;color:#9aa4c7;font-size:13px;margin-bottom:6px}
.modal-card label em{color:#ff8a8a;font-style:normal}
.modal-card small{display:block;color:#6f7aa2;font-size:12px;margin-top:4px}
.modal-card input,.modal-card textarea{
  width:100%;background:#0c1326;border:1px solid #2a345a;color:#eef1f8;
  border-radius:12px;padding:12px 14px;font-size:15px;font-family:inherit;outline:none;transition:border-color .15s,box-shadow .15s;
}
.modal-card input:focus,.modal-card textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(255,184,77,.15)}
.btn-submit{
  margin-top:18px;width:100%;padding:14px;border-radius:12px;border:0;
  background:linear-gradient(90deg,#22d39d,#6bf0c2);color:#063626;font-weight:900;font-size:16px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;
  box-shadow:0 8px 22px rgba(34,211,157,.3)
}
.btn-submit:disabled{opacity:.7;cursor:wait}
.spin{width:16px;height:16px;border:2px solid rgba(0,0,0,.25);border-top-color:#063626;border-radius:50%;animation:rot .8s linear infinite}

/* SUCCESS OVERLAY */
.success{position:fixed;inset:0;background:rgba(5,8,18,.9);display:flex;align-items:center;justify-content:center;padding:16px;z-index:120;animation:fade .25s ease-out both;backdrop-filter:blur(6px)}
.success-card{width:100%;max-width:440px;background:linear-gradient(160deg,#0f1e3d,#0b1628);border:1px solid #1e4a8a;border-radius:22px;padding:28px 22px;text-align:center;animation:rise .4s ease-out both;box-shadow:0 20px 50px rgba(0,0,0,.6)}
.success-card h3{margin:14px 0 6px;font-size:22px;font-weight:900}
.success-card .typer{color:#a8e9ff;font-weight:600;min-height:24px;font-size:15px;margin:0 0 18px}
.success-card .bullets{list-style:none;padding:0;margin:6px 0 22px;text-align:left}
.success-card .bullets li{background:rgba(255,255,255,.04);border:1px solid #1e2c55;padding:10px 12px;margin:8px 0;border-radius:12px;font-size:14px;color:#cdd6f0;animation:slide .5s ease-out both}
.success-card .bullets li:nth-child(1){animation-delay:.2s}
.success-card .bullets li:nth-child(2){animation-delay:.5s}
.success-card .bullets li:nth-child(3){animation-delay:.8s}
.success-card .bullets b{color:#ffd38a}
.btn-done{background:linear-gradient(90deg,#ff7a2e,#ffb84d);color:#1a0f00;border:0;border-radius:12px;padding:12px 30px;font-weight:900;cursor:pointer;font-size:15px}

/* Check animation */
.check svg{width:70px;height:70px;display:block;margin:0 auto}
.check svg circle{stroke:#22d39d;stroke-width:3;stroke-dasharray:166;stroke-dashoffset:166;animation:dash 1s .1s ease-out forwards}
.check svg path{stroke:#22d39d;stroke-width:4;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:48;stroke-dashoffset:48;animation:dash .6s .7s ease-out forwards}

/* TOAST */
.toast{position:fixed;left:50%;bottom:28px;transform:translate(-50%,40px);background:#1c2344;color:#ffe8c8;padding:12px 18px;border-radius:999px;font-weight:700;font-size:14px;z-index:200;box-shadow:var(--shadow);opacity:0;transition:all .25s;border:1px solid #3b4788}
.toast.show{opacity:1;transform:translate(-50%,0)}
.toast.error{color:#ffc8c8;border-color:#802c3a;background:#311523}

@keyframes drop{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@keyframes slide{from{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:none}}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes rot{to{transform:rotate(360deg)}}
@keyframes dash{to{stroke-dashoffset:0}}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
