:root {
  --brand:#2500b7; --brand-dark:#1a007d; --brand-deep:#0f004d;
  --brand-light:#4a28d4; --brand-pale:#ede9ff; --brand-faint:#f7f5ff;
  --accent:#7c3aed; --accent-lt:#a78bfa;
  --gold:#f59e0b; --gold-lt:#fbbf24;
  --text:#1e0070; --text-muted:#6b5bb8;
  --border:#c4b5fd; --border-lt:#ddd6fe;
  --red:#dc2626; --green:#16a34a;
  --gray50:#f8f7ff; --gray100:#ede9ff;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'DM Sans',sans-serif;background:var(--gray50);color:var(--text);font-size:15px;line-height:1.5}

/* HEADER */
header{background:linear-gradient(135deg,var(--brand-deep) 0%,var(--brand) 60%,var(--accent) 100%);padding:40px 24px 48px;text-align:center;position:relative;overflow:hidden}
header::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23fff' fill-opacity='.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/svg%3E")}
header::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:40px;background:var(--gray50);clip-path:ellipse(55% 100% at 50% 100%)}
.hi{position:relative;z-index:1}
.badge{display:inline-block;border:1px solid rgba(255,255,255,.3);color:var(--accent-lt);font-size:10px;letter-spacing:3px;text-transform:uppercase;padding:5px 18px;border-radius:20px;margin-bottom:16px;background:rgba(255,255,255,.05)}
header h1{font-family:'Playfair Display',serif;font-size:clamp(30px,5vw,52px);color:#fff;line-height:1.1;margin-bottom:4px}
header h1 span{color:var(--gold-lt)}
.hdiv{width:60px;height:2px;background:linear-gradient(90deg,transparent,var(--gold-lt),transparent);margin:16px auto}
.hsub{color:rgba(255,255,255,.6);font-size:13px;margin-top:4px}

/* LAYOUT */
.wrap{max-width:900px;margin:0 auto;padding:36px 18px 80px}

/* CARDS */
.card{background:#fff;border:1px solid var(--border-lt);border-radius:12px;padding:28px;margin-bottom:24px;box-shadow:0 2px 16px rgba(37,0,183,.06)}
.st{font-family:'Playfair Display',serif;font-size:20px;color:var(--brand);margin-bottom:4px}
.ss{font-size:13px;color:var(--text-muted);margin-bottom:22px}

/* FORM */
.fg{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:580px){.fg{grid-template-columns:1fr}}
.ff{grid-column:1/-1}
.fl{display:block;font-size:11px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px}
.fl.req::after{content:' *';color:var(--red)}
input,select,textarea{width:100%;padding:11px 14px;border:1.5px solid var(--border-lt);border-radius:8px;font-family:'DM Sans',sans-serif;font-size:14px;color:var(--text);background:var(--brand-faint);transition:border-color .18s,box-shadow .18s;appearance:none;-webkit-appearance:none}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(37,0,183,.1);background:#fff}
select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%232500b7' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:38px;cursor:pointer}
textarea{resize:vertical;min-height:80px}

/* RADIO PILLS */
.rg{display:flex;flex-wrap:wrap;gap:8px}
.rp input{display:none}
.rp span{display:inline-block;padding:7px 16px;border:1.5px solid var(--border-lt);border-radius:20px;cursor:pointer;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--text-muted);transition:all .18s;user-select:none}
.rp input:checked+span{border-color:var(--brand);background:var(--brand);color:#fff;box-shadow:0 2px 8px rgba(37,0,183,.25)}

/* FILTER */
.frow{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.fbtn{padding:7px 18px;border:1.5px solid var(--border-lt);border-radius:20px;background:none;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--text-muted);transition:all .18s}
.fbtn.active,.fbtn:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-pale)}

/* GROUP HEADING */
.gh{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--accent-lt);margin:22px 0 10px;padding-bottom:8px;border-bottom:1px solid var(--border-lt);display:flex;align-items:center;gap:8px}
.gh::before{content:'';display:inline-block;width:16px;height:2px;background:var(--brand);border-radius:2px;flex-shrink:0}

/* MENU CARDS */
.mc{border:2px solid var(--border-lt);border-radius:10px;cursor:pointer;transition:border-color .18s,box-shadow .18s;overflow:hidden;margin-bottom:10px;background:#fff}
.mc:hover{border-color:var(--brand-light);box-shadow:0 2px 12px rgba(37,0,183,.1)}
.mc.sel{border-color:var(--brand);box-shadow:0 4px 20px rgba(37,0,183,.15)}
.mh{display:flex;align-items:center;gap:14px;padding:14px 18px}
.rd{width:20px;height:20px;border-radius:50%;border:2px solid var(--border);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .18s;background:var(--brand-faint)}
.mc.sel .rd{border-color:var(--brand);background:var(--brand)}
.rd::after{content:'';width:8px;height:8px;border-radius:50%;background:#fff;opacity:0;transition:opacity .18s}
.mc.sel .rd::after{opacity:1}
.mnw{flex:1;min-width:0}
.mn{font-family:'Playfair Display',serif;font-size:16px;font-weight:600;color:var(--text);line-height:1.2}
.mc.sel .mn{color:var(--brand)}
.mmin{font-size:11px;color:var(--text-muted);margin-top:2px}
.mpw{text-align:right;flex-shrink:0}
.mp{font-size:16px;font-weight:700;color:var(--brand);white-space:nowrap}
.mps{font-size:10px;color:var(--text-muted)}

/* PANEL */
.mp2{display:none;border-top:1px solid var(--border-lt);background:var(--brand-faint);padding:16px 18px 18px}
.mc.sel .mp2{display:block}

/* CHOICE BLOCKS */
.cb{margin-bottom:14px}
.cb:last-child{margin-bottom:0}
.chdr{display:flex;align-items:center;gap:8px;font-size:10px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--brand);margin-bottom:6px}
.chdr::after{content:'';flex:1;height:1px;background:var(--border-lt)}
.cbadge{background:var(--brand);color:#fff;font-size:9px;padding:1px 7px;border-radius:10px;letter-spacing:.5px;flex-shrink:0}
.csel{width:100%;background-color:#fff}

/* REMARK TEXTAREA */
.rmk{width:100%;padding:8px 12px;border:1px dashed var(--border);border-radius:6px;font-family:'DM Sans',sans-serif;font-size:13px;color:var(--text);background:rgba(255,255,255,.7);resize:none;height:44px;margin-top:5px;transition:border-color .18s,height .18s;display:block}
.rmk:focus{outline:none;border-color:var(--brand);border-style:solid;background:#fff;height:70px}
.rmk::placeholder{color:#b0a8d8;font-style:italic;font-size:12px}

/* FIXED BOX */
.fb{background:rgba(255,255,255,.6);border:1px dashed var(--border);border-radius:8px;padding:10px 14px;margin-top:12px}
.fbl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--accent);margin-bottom:6px}
.fi{font-size:13px;color:var(--text);padding:3px 0;display:flex;align-items:flex-start;gap:7px;line-height:1.4}
.fi::before{content:'✓';color:var(--brand-light);font-size:11px;flex-shrink:0;margin-top:2px}

/* SUB SECTION HDR */
.ssh{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--accent);background:rgba(37,0,183,.06);padding:6px 10px;border-radius:6px;margin:12px 0 8px;border-left:3px solid var(--brand)}

/* SUMMARY */
#sc{display:none;background:linear-gradient(135deg,var(--brand-deep),var(--brand));border-radius:12px;padding:24px;margin-bottom:24px;box-shadow:0 8px 32px rgba(37,0,183,.25)}
.stit{font-family:'Playfair Display',serif;font-size:18px;color:var(--gold-lt);margin-bottom:16px}
.sr{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px solid rgba(255,255,255,.08);font-size:14px;gap:12px}
.sr:last-child{border:none}
.srl{color:rgba(255,255,255,.55);flex-shrink:0}
.srv{color:#fff;font-weight:500;text-align:right}
.stot{margin-top:14px;padding-top:14px;border-top:1px solid var(--gold);display:flex;justify-content:space-between;align-items:center}
.stotl{color:var(--gold-lt);font-family:'Playfair Display',serif;font-size:16px}
.stotv{color:var(--gold-lt);font-weight:700;font-size:22px;font-family:'Playfair Display',serif}
.snote{font-size:11px;color:rgba(255,255,255,.35);margin-top:10px}

/* NOTICE */
.notice{background:#fffbeb;border:1px solid #fde68a;border-left:4px solid var(--gold);border-radius:8px;padding:12px 16px;font-size:13px;color:#78350f;margin-bottom:20px;line-height:1.5}

/* INFO NOTE */
.inote{font-size:12px;color:var(--text-muted);background:var(--brand-pale);border-radius:6px;padding:8px 12px;margin-top:8px;border-left:3px solid var(--brand-light)}

/* BUTTONS */
.br{display:flex;gap:12px;flex-wrap:wrap}
.btn{flex:1;min-width:160px;padding:15px 22px;border:none;border-radius:8px;font-family:'DM Sans',sans-serif;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:10px}
.bwa{background:#25D366;color:#fff;box-shadow:0 4px 16px rgba(37,211,102,.25)}
.bwa:hover{background:#1fba5a;transform:translateY(-1px);box-shadow:0 6px 20px rgba(37,211,102,.35)}
.bem{background:var(--brand);color:#fff;box-shadow:0 4px 16px rgba(37,0,183,.25)}
.bem:hover{background:var(--brand-light);transform:translateY(-1px)}

/* GROUPS */
.mg{display:none}
.mg.vis{display:block}

/* FOOTER */
footer{background:var(--brand-deep);color:rgba(255,255,255,.5);text-align:center;padding:28px 20px;font-size:13px;line-height:1.8}
footer strong{color:var(--gold-lt)}
