@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@500;600;700&family=Mulish:wght@300;400;500;600;700&display=swap');
:root{
  --teal:#0077a2; --teal-d:#005f82; --coral:#e14d4d; --coral-d:#cc3f3f;
  --gold:#d99a2b; --purple:#8e63c4; --ink:#23303a; --gray:#6b7a85;
  --line:#e7edf0; --soft:#f6f9fb; --green:#1f9d6b;
  --serif:'Playfair Display',Georgia,serif; --sans:'Mulish',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--sans);color:var(--ink);background:#fff;line-height:1.6;font-weight:400}
.accent-line{height:3px;border-radius:3px;background:linear-gradient(90deg,var(--teal),var(--coral) 45%,var(--gold) 72%,var(--purple))}
a{color:var(--teal)}

nav{border-bottom:1px solid var(--line);background:#fff;position:sticky;top:0;z-index:20}
.nav-in{max-width:1080px;margin:0 auto;padding:16px 26px;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.nav-in img{height:34px;display:block}
.nav-right{display:flex;gap:14px;align-items:center}
.nav-right a{font-weight:600;font-size:14px;color:var(--gray);text-decoration:none}
.nav-right a:hover{color:var(--ink)}
.nav-right .phone{font-size:13px;color:var(--gray);font-weight:600}

.stage{max-width:1080px;margin:0 auto;padding:54px 26px 70px}
.center{min-height:60vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.eyebrow{font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--teal);margin-bottom:14px}
h1.disp{font-family:var(--serif);font-weight:700;font-size:40px;line-height:1.12;color:var(--ink)}
h1.disp .lt{color:var(--coral)}
.lede{font-size:16px;color:var(--gray);max-width:520px;margin:16px auto 0}

.codecard{margin-top:38px;background:#fff;border:1px solid var(--line);border-radius:20px;padding:34px 36px;
  box-shadow:0 24px 60px -28px rgba(0,90,125,.35);max-width:460px;width:100%}
.codecard .lbl{font-family:var(--serif);font-size:19px;font-weight:600;margin-bottom:18px}
.code-row{display:flex;gap:12px;align-items:center}
.code-row input{flex:1;font-family:var(--sans);font-weight:600;font-size:17px;letter-spacing:.12em;text-transform:uppercase;
  text-align:center;padding:15px 16px;border:1.5px solid var(--line);border-radius:13px;background:var(--soft);color:var(--ink)}
.code-row input:focus{outline:none;border-color:var(--teal);background:#fff;box-shadow:0 0 0 4px rgba(0,119,162,.12)}
.arrow{flex-shrink:0;width:54px;height:54px;border-radius:50%;border:0;background:var(--coral);color:#fff;font-size:24px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.18s;box-shadow:0 8px 18px -6px rgba(225,77,77,.6)}
.arrow:hover{background:var(--coral-d);transform:translateX(3px)}
.hint{font-size:12.5px;color:var(--gray);margin-top:16px}
.hint b{color:var(--teal);font-weight:700;letter-spacing:.05em}
.err{color:var(--coral);font-size:13.5px;font-weight:600;margin-top:14px}

.crumb{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--gray);font-weight:600;margin-bottom:8px}
.crumb a{color:var(--teal);font-weight:700;text-decoration:none}
.org-head{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap;margin-bottom:6px}
.org-head h2{font-family:var(--serif);font-weight:700;font-size:30px;line-height:1.15}
.org-head .meta{font-size:13.5px;color:var(--gray);margin-top:4px}
.cur-badge{display:inline-flex;align-items:center;gap:8px;background:#eafaf3;border:1px solid #bfe7d4;color:#157a51;
  font-weight:700;font-size:13px;padding:9px 16px;border-radius:999px;white-space:nowrap}
.cur-badge .dot{width:8px;height:8px;border-radius:50%;background:var(--green)}

.layout{display:grid;grid-template-columns:1.2fr .8fr;gap:34px;margin-top:30px;align-items:start}
@media(max-width:780px){.layout{grid-template-columns:1fr}}
.poster-frame{background:var(--soft);border:1px solid var(--line);border-radius:16px;padding:10px}
.poster-frame iframe{width:100%;height:760px;border:0;border-radius:8px;background:#fff}
.poster-cap{text-align:center;font-size:12px;color:var(--gray);margin-top:12px;font-weight:600;letter-spacing:.04em}
.poster-open{display:inline-block;margin-top:8px;font-size:13px;font-weight:700;text-decoration:none}

.side h3{font-family:var(--serif);font-size:21px;font-weight:600;margin-bottom:6px}
.side .note{font-size:13.5px;color:var(--gray);line-height:1.65}
.side .note b{color:var(--ink)}
.divider{margin:22px 0}

.ack{background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px;box-shadow:0 14px 40px -26px rgba(0,90,125,.4)}
.ack label.fl{display:block;font-size:12px;font-weight:700;color:var(--gray);letter-spacing:.04em;text-transform:uppercase;margin-bottom:7px}
.ack input.nm{width:100%;font-family:var(--sans);font-size:15px;font-weight:500;padding:12px 14px;border:1.5px solid var(--line);
  border-radius:11px;background:var(--soft);color:var(--ink)}
.ack input.nm:focus{outline:none;border-color:var(--teal);background:#fff;box-shadow:0 0 0 4px rgba(0,119,162,.1)}
.ack .chk{display:flex;gap:10px;align-items:flex-start;margin:16px 0 18px;font-size:13px;color:var(--ink);line-height:1.5}
.ack .chk input{margin-top:3px;width:17px;height:17px;accent-color:var(--teal);flex-shrink:0}
.btn-coral{width:100%;font-family:var(--sans);font-weight:700;font-size:15px;border:0;border-radius:12px;padding:14px;cursor:pointer;
  background:var(--coral);color:#fff;transition:.18s;box-shadow:0 10px 22px -10px rgba(225,77,77,.6)}
.btn-coral:hover{background:var(--coral-d)}
.btn-teal{width:100%;font-family:var(--sans);font-weight:700;font-size:15px;border:0;border-radius:12px;padding:13px;cursor:pointer;
  background:var(--teal);color:#fff;transition:.18s}
.btn-teal:hover{background:var(--teal-d)}

.accepted{text-align:center;padding:6px 4px}
.accepted .ring{width:62px;height:62px;border-radius:50%;background:#eafaf3;border:2px solid var(--green);color:var(--green);
  font-size:30px;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;font-weight:800}
.accepted h4{font-family:var(--serif);font-size:20px;margin-bottom:6px}
.accepted p{font-size:13px;color:var(--gray)}
.accepted .stamp{margin-top:14px;font-size:12px;color:var(--teal);font-weight:700;background:var(--soft);border-radius:10px;padding:10px}

.admin-card{margin-top:30px;background:#fff;border:1px solid var(--line);border-radius:20px;padding:36px;
  box-shadow:0 24px 60px -30px rgba(0,90,125,.4);max-width:400px;width:100%;text-align:left}
.admin-card .lock{width:48px;height:48px;border-radius:13px;background:var(--soft);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:18px}
.admin-card h3{font-family:var(--serif);font-size:23px;font-weight:700;margin-bottom:4px}
.admin-card p{font-size:13.5px;color:var(--gray);margin-bottom:20px}
.admin-card input{width:100%;font-family:var(--sans);font-size:15px;padding:13px 15px;border:1.5px solid var(--line);
  border-radius:12px;background:var(--soft);margin-bottom:14px}
.admin-card input:focus{outline:none;border-color:var(--teal);background:#fff;box-shadow:0 0 0 4px rgba(0,119,162,.1)}

.dash-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:16px;margin-bottom:6px}
.dash-head h2{font-family:var(--serif);font-weight:700;font-size:30px}
.dash-head p{font-size:13.5px;color:var(--gray);margin-top:3px}
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-top:26px}
.stat{background:#fff;border:1px solid var(--line);border-radius:15px;padding:20px 22px;position:relative;overflow:hidden}
.stat:after{content:"";position:absolute;left:0;bottom:0;height:3px;width:100%}
.stat.a:after{background:var(--teal)} .stat.b:after{background:var(--coral)} .stat.c:after{background:var(--gold)}
.stat .n{font-family:var(--serif);font-weight:700;font-size:32px;line-height:1}
.stat .l{font-size:12.5px;color:var(--gray);margin-top:8px;font-weight:600}

.table{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;margin-top:26px}
.trow{display:grid;gap:14px;padding:14px 22px;border-bottom:1px solid var(--line);font-size:13.5px;align-items:center}
.trow:last-child{border-bottom:0}
.t-ack{grid-template-columns:1.4fr 1.4fr .9fr}
.t-reg{grid-template-columns:1fr 1.6fr 2fr auto}
.thead{background:var(--soft);font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--gray)}
.trow .nm{font-weight:700}
.trow .cd{font-weight:700;color:var(--teal);letter-spacing:.04em}
.trow .rl{font-size:12px;color:var(--gray)}
.st{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--green)}
.st .d{width:7px;height:7px;border-radius:50%;background:var(--green)}
.empty{padding:46px 20px;text-align:center;color:var(--gray);font-size:14px}
.ghost{background:none;border:1px solid var(--line);color:var(--gray);font-weight:600;font-size:12.5px;padding:8px 15px;
  border-radius:999px;cursor:pointer;font-family:var(--sans);text-decoration:none;display:inline-block}
.ghost:hover{border-color:var(--gray);color:var(--ink)}
.btnlink{text-decoration:none}

.panel{background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px;margin-top:18px}
.panel h4{font-family:var(--serif);font-size:17px;margin-bottom:14px}
.grid-form{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
@media(max-width:680px){.grid-form{grid-template-columns:1fr}}
.grid-form .full{grid-column:1 / -1}
.grid-form label{display:block;font-size:11px;font-weight:700;color:var(--gray);letter-spacing:.04em;text-transform:uppercase;margin-bottom:6px}
.grid-form input,.grid-form select{width:100%;font-family:var(--sans);font-size:14px;padding:11px 12px;border:1.5px solid var(--line);
  border-radius:10px;background:var(--soft)}
.grid-form input:focus{outline:none;border-color:var(--teal);background:#fff}
.copy{background:var(--soft);border:1px solid var(--line);border-radius:8px;font-size:12px;font-weight:700;color:var(--ink);
  padding:7px 12px;cursor:pointer;font-family:var(--sans)}
.copy:hover{background:#eef3f6}
.flash{background:#eafaf3;border:1px solid #bfe7d4;border-radius:10px;padding:12px 14px;font-size:13.5px;color:#157a51;margin-top:6px}
.flash.bad{background:#fbecec;border-color:#f3cfcf;color:#9a2d2d}

.foot{text-align:center;margin-top:40px;font-size:12px;color:var(--gray);line-height:1.8}
.foot b{color:var(--teal)}
