/* ============================================================
   HOME SHOW — Exhibitor signup, booth picker & portal
   Phase 1 demo. Builds on css/styles.css tokens (gold/black,
   Poppins/Mulish). Loaded only on exhibitor-* pages.
   ============================================================ */

/* ---- tier palette (map only; legend explains them) ---- */
:root{
  --t-standard:#7e98b0;
  --t-corner:#4f9e83;
  --t-island:#e8b84e;
  --t-vignette:#b1567f;
  --t-sold:#b9b3a7;
  --t-hold:#dca73c;
  --hsx-board:#f3ede0;
  --hsx-board-line:rgba(20,18,14,.10);
  --ok:#3f9d63;
  --due:#d99a2b;
  --overdue:#d2603f;
}
html[data-theme="dark"]{
  --hsx-board:#1b1813;
  --hsx-board-line:rgba(255,255,255,.08);
  --t-sold:#5b564d;
  --ok:#4fb978;
}

/* ---- demo note ---- */
.hsx-demo-note{
  display:flex;align-items:center;justify-content:center;gap:.5rem;
  background:repeating-linear-gradient(45deg,rgba(232,184,78,.16),rgba(232,184,78,.16) 14px,rgba(232,184,78,.07) 14px,rgba(232,184,78,.07) 28px);
  border-bottom:1px solid var(--line);
  color:var(--ink-soft);font-size:.76rem;letter-spacing:.04em;
  font-family:var(--font-display);font-weight:600;padding:.5rem 1rem;text-align:center;
}
.hsx-demo-note b{color:var(--gold-dark);}

/* ---- pricing tier cards (exhibitors.html) ---- */
.hsx-tier-cards{align-items:stretch;}
.hsx-tier-card{position:relative;display:flex;flex-direction:column;min-width:0;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:1.4rem 1.4rem 1.5rem;box-shadow:var(--shadow-card);transition:.2s;}
.hsx-tier-card:hover{transform:translateY(-3px);}
.hsx-tier-feat{box-shadow:0 24px 50px -24px rgba(232,184,78,.55);border-color:rgba(232,184,78,.5);}
.hsx-tier-flag{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:var(--gold);color:#1a160d;font-family:var(--font-display);font-weight:700;font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;padding:.3rem .8rem;border-radius:999px;white-space:nowrap;}
.hsx-tier-h{display:flex;flex-direction:column;gap:.15rem;}
.hsx-tier-name{font-family:var(--font-display);font-weight:700;font-size:1.15rem;}
.hsx-tier-size{font-size:.78rem;color:var(--muted);letter-spacing:.02em;}
.hsx-tier-price{font-family:var(--font-display);font-weight:800;font-size:2rem;color:var(--gold-dark);margin:.7rem 0 .2rem;line-height:1;}
.hsx-tier-blurb{font-size:.9rem;color:var(--ink-soft);margin:.6rem 0 .9rem;}
.hsx-tier-perks{font-size:.86rem;margin-bottom:1.2rem;flex:1;}
.hsx-tier-card .btn{margin-top:auto;}
@media (max-width:1120px){ .hsx-tier-cards{grid-template-columns:repeat(2,1fr);} }
@media (max-width:560px){ .hsx-tier-cards{grid-template-columns:1fr;} }

/* ============================================================
   WIZARD
   ============================================================ */
.hsx-wizard{max-width:1240px;margin:0 auto;padding-inline:var(--pad);width:100%;}
.hsx-wizard-head{text-align:center;max-width:720px;margin:clamp(28px,4vw,48px) auto clamp(20px,3vw,30px);}

/* stepper */
.hsx-stepper{display:flex;align-items:flex-start;justify-content:center;gap:0;max-width:760px;margin:0 auto clamp(28px,4vw,46px);}
.hsx-step{display:flex;flex-direction:column;align-items:center;gap:.55rem;flex:1;position:relative;text-align:center;}
.hsx-step::before{content:"";position:absolute;top:18px;left:-50%;width:100%;height:2px;background:var(--line);z-index:0;}
.hsx-step:first-child::before{display:none;}
.hsx-step .dot{
  position:relative;z-index:1;width:38px;height:38px;border-radius:50%;
  display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:.9rem;
  background:var(--surface);border:2px solid var(--line);color:var(--muted);transition:.25s;
}
.hsx-step .lbl{font-family:var(--font-display);font-weight:600;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);transition:.25s;}
.hsx-step.active .dot{border-color:var(--gold);color:var(--gold-dark);box-shadow:0 0 0 5px rgba(232,184,78,.16);}
.hsx-step.active .lbl{color:var(--ink);}
.hsx-step.done .dot{background:var(--gold);border-color:var(--gold);color:#1a160d;}
.hsx-step.done::before{background:var(--gold);}
.hsx-step.done .lbl{color:var(--ink-soft);}

.hsx-panel{display:none;animation:hsx-fade .3s ease;}
.hsx-panel.active{display:block;}
@keyframes hsx-fade{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}

/* ============================================================
   BOOTH PICKER
   ============================================================ */
.hsx-picker{display:grid;grid-template-columns:1fr 340px;gap:clamp(18px,2.4vw,32px);align-items:start;}
/* min-width:0 lets the grid tracks shrink below their content (prevents the
   classic CSS-grid min-content overflow on narrow screens). */
.hsx-picker>*{min-width:0;}

/* show selector + view toggle */
.hsx-pick-bar{display:flex;flex-wrap:wrap;gap:.8rem 1rem;align-items:center;margin-bottom:1rem;}
.hsx-pick-bar .field{margin:0;}
.hsx-showsel{display:flex;gap:.5rem;flex-wrap:wrap;}
.hsx-showsel button{
  font-family:var(--font-display);font-weight:600;font-size:.78rem;cursor:pointer;
  padding:.55rem 1rem;border:1.5px solid var(--line);background:var(--surface);color:var(--ink-soft);
  border-radius:999px;transition:.2s;
}
.hsx-showsel button:hover{border-color:var(--gold);color:var(--ink);}
.hsx-showsel button.active{background:var(--gold);border-color:var(--gold);color:#1a160d;}

.hsx-toggle{margin-left:auto;display:inline-flex;border:1.5px solid var(--line);border-radius:999px;overflow:hidden;}
.hsx-toggle button{font-family:var(--font-display);font-weight:600;font-size:.74rem;padding:.5rem .95rem;background:transparent;border:none;cursor:pointer;color:var(--muted);}
.hsx-toggle button.active{background:var(--ink);color:#fff;}

/* legend + scarcity */
.hsx-legend{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.8rem;}
.hsx-legend .chip{
  display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;user-select:none;
  font-family:var(--font-display);font-weight:600;font-size:.76rem;
  padding:.45rem .8rem;border:1.5px solid var(--line);border-radius:999px;background:var(--surface);transition:.18s;
}
.hsx-legend .chip .sw{width:13px;height:13px;border-radius:3px;flex:none;}
.hsx-legend .chip small{color:var(--muted);font-weight:600;}
.hsx-legend .chip:hover{border-color:var(--gold);}
.hsx-legend .chip.off{opacity:.4;}
.hsx-legend .chip.off .sw{filter:grayscale(1);}

/* map board */
.hsx-mapwrap{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--surface);box-shadow:var(--shadow-card);min-width:0;}
.hsx-map-toolbar{display:flex;align-items:center;gap:.6rem;padding:.7rem .9rem;border-bottom:1px solid var(--line);background:var(--cream);min-width:0;}
.hsx-map-toolbar .ttl{font-family:var(--font-display);font-weight:700;font-size:.84rem;letter-spacing:.04em;flex:0 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.hsx-map-toolbar .sp{margin-left:auto;flex:1 0 0;}
.hsx-zoom{flex:none;}
.hsx-zoom{display:inline-flex;gap:.3rem;}
.hsx-zoom button{width:34px;height:34px;border-radius:9px;border:1.5px solid var(--line);background:var(--surface);color:var(--ink);font-size:1.1rem;line-height:1;cursor:pointer;display:grid;place-items:center;transition:.18s;}
.hsx-zoom button:hover{border-color:var(--gold);color:var(--gold-dark);}
.hsx-map-stage{position:relative;overflow:auto;background:var(--hsx-board);max-height:62vh;cursor:grab;-webkit-overflow-scrolling:touch;}
.hsx-map-stage.grabbing{cursor:grabbing;}
.hsx-map-stage svg{display:block;}

/* svg primitives */
.hsx-floor{fill:var(--hsx-board);}
.hsx-aisle{fill:rgba(20,18,14,.03);}
.hsx-walltext,.hsx-zonelabel{font-family:'Poppins',sans-serif;fill:var(--muted);font-weight:600;}
.hsx-zonelabel{font-size:13px;letter-spacing:.12em;text-transform:uppercase;}
.hsx-walltext{font-size:11px;letter-spacing:.18em;text-transform:uppercase;}
.hsx-feature{fill:rgba(20,18,14,.05);stroke:var(--hsx-board-line);stroke-dasharray:4 4;}

.hsx-booth{cursor:pointer;}
.hsx-booth .bx{stroke:rgba(0,0,0,.18);stroke-width:1;transition:transform .12s ease,filter .12s ease;rx:3px;}
.hsx-booth .blab{font-family:'Poppins',sans-serif;font-size:9px;font-weight:600;fill:rgba(20,16,10,.7);pointer-events:none;text-anchor:middle;dominant-baseline:central;}
.hsx-booth[data-tier="standard"] .bx{fill:var(--t-standard);}
.hsx-booth[data-tier="corner"]   .bx{fill:var(--t-corner);}
.hsx-booth[data-tier="island"]   .bx{fill:var(--t-island);}
.hsx-booth[data-tier="vignette"] .bx{fill:var(--t-vignette);}
.hsx-booth[data-tier="vignette"] .blab,
.hsx-booth[data-tier="island"] .blab{fill:rgba(20,16,10,.82);}

.hsx-booth:hover .bx{filter:brightness(1.08) drop-shadow(0 2px 5px rgba(0,0,0,.3));}
.hsx-booth.is-selected .bx{fill:var(--gold)!important;stroke:#7a5a12;stroke-width:2.5;filter:drop-shadow(0 0 0 3px rgba(232,184,78,.45));animation:hsx-pop .28s ease;}
.hsx-booth.is-selected .blab{fill:#1a160d;font-weight:700;}
@keyframes hsx-pop{0%{transform:scale(.7);}60%{transform:scale(1.12);}100%{transform:scale(1);}}

.hsx-booth[data-status="sold"]{cursor:not-allowed;}
.hsx-booth[data-status="sold"] .bx{fill:var(--t-sold);opacity:.55;stroke-dasharray:none;}
.hsx-booth[data-status="sold"] .blab{fill:rgba(20,16,10,.45);}
.hsx-booth[data-status="hold"]{cursor:not-allowed;}
.hsx-booth[data-status="hold"] .bx{fill:none;stroke:var(--t-hold);stroke-width:2;stroke-dasharray:5 3;}
.hsx-booth[data-status="hold"] .blab{fill:var(--t-hold);}
/* dimmed by tier filter */
.hsx-booth.dim{opacity:.16;pointer-events:none;}

/* tooltip */
.hsx-tip{
  position:fixed;z-index:60;pointer-events:none;opacity:0;transform:translateY(4px);transition:opacity .12s;
  background:#15130f;color:#f4efe4;border:1px solid rgba(232,184,78,.4);border-radius:10px;
  padding:.6rem .75rem;font-size:.78rem;line-height:1.45;max-width:220px;box-shadow:0 12px 30px rgba(0,0,0,.4);
}
.hsx-tip.show{opacity:1;transform:none;}
.hsx-tip b{font-family:var(--font-display);display:block;font-size:.86rem;margin-bottom:.1rem;}
.hsx-tip .tprice{color:var(--gold);font-weight:700;}
.hsx-tip .ttag{display:inline-block;margin-top:.25rem;font-size:.68rem;letter-spacing:.06em;text-transform:uppercase;opacity:.8;}

/* list view */
.hsx-list{display:none;}
.hsx-list.active{display:block;}
.hsx-mapwrap.hide{display:none;}
.hsx-list-group{margin-bottom:1.2rem;}
.hsx-list-group h4{font-family:var(--font-display);font-size:.86rem;letter-spacing:.04em;display:flex;align-items:center;gap:.5rem;margin-bottom:.6rem;}
.hsx-list-group h4 .sw{width:12px;height:12px;border-radius:3px;}
.hsx-list-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(116px,1fr));gap:.55rem;}
.hsx-lbooth{
  text-align:left;cursor:pointer;border:1.5px solid var(--line);border-radius:10px;background:var(--surface);
  padding:.6rem .7rem;font-family:var(--font-body);transition:.16s;
}
.hsx-lbooth .bid{font-family:var(--font-display);font-weight:700;font-size:.92rem;}
.hsx-lbooth .bpr{font-size:.8rem;color:var(--gold-dark);font-weight:700;}
.hsx-lbooth:hover{border-color:var(--gold);transform:translateY(-1px);}
.hsx-lbooth.is-selected{border-color:var(--gold);background:rgba(232,184,78,.12);box-shadow:0 0 0 2px rgba(232,184,78,.3) inset;}
.hsx-lbooth:disabled{opacity:.45;cursor:not-allowed;text-decoration:line-through;}

/* ---- cart / order summary ---- */
.hsx-cart{position:sticky;top:90px;border:1px solid var(--line);border-radius:14px;background:var(--surface);box-shadow:var(--shadow-card);overflow:hidden;}
.hsx-cart-head{padding:1rem 1.2rem;border-bottom:1px solid var(--line);background:var(--cream);}
.hsx-cart-head h3{font-family:var(--font-display);font-size:1.05rem;}
.hsx-cart-head p{font-size:.8rem;color:var(--muted);margin:.2rem 0 0;}
.hsx-cart-body{padding:1rem 1.2rem;}
.hsx-cart-empty{color:var(--muted);font-size:.9rem;text-align:center;padding:1.4rem 0;}
.hsx-line{display:flex;align-items:center;gap:.6rem;padding:.6rem 0;border-bottom:1px dashed var(--line);}
.hsx-line:last-of-type{border-bottom:none;}
.hsx-line .lsw{width:10px;height:10px;border-radius:3px;flex:none;}
.hsx-line .lmain{flex:1;min-width:0;}
.hsx-line .lmain b{font-family:var(--font-display);font-size:.92rem;display:block;}
.hsx-line .lmain small{color:var(--muted);font-size:.74rem;}
.hsx-line .lpr{font-family:var(--font-display);font-weight:700;font-size:.9rem;white-space:nowrap;}
.hsx-line .lrm{background:none;border:none;cursor:pointer;color:var(--muted);font-size:1.1rem;line-height:1;padding:0 0 0 .2rem;transition:.15s;}
.hsx-line .lrm:hover{color:var(--overdue);}
.hsx-cart-total{display:flex;justify-content:space-between;align-items:baseline;margin:.9rem 0 .2rem;padding-top:.8rem;border-top:2px solid var(--line);}
.hsx-cart-total .tk{font-family:var(--font-display);font-weight:600;letter-spacing:.06em;text-transform:uppercase;font-size:.78rem;color:var(--ink-soft);}
.hsx-cart-total .tv{font-family:var(--font-display);font-weight:700;font-size:1.5rem;color:var(--gold-dark);}
.hsx-cart .btn{margin-top:.9rem;}
.hsx-cart-note{font-size:.74rem;color:var(--muted);text-align:center;margin-top:.7rem;}

/* ============================================================
   DETAILS + PAYMENT
   ============================================================ */
.hsx-2col{display:grid;grid-template-columns:1fr 360px;gap:clamp(20px,3vw,40px);align-items:start;}
.hsx-2col>*{min-width:0;}
.hsx-pay-card{margin-top:1.4rem;border-top:1px solid var(--line);padding-top:1.4rem;}
.hsx-pay-options{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;margin-bottom:1.2rem;}
.hsx-payopt{cursor:pointer;border:1.5px solid var(--line);border-radius:12px;padding:.9rem 1rem;transition:.18s;display:block;}
.hsx-payopt:hover{border-color:var(--gold);}
.hsx-payopt.sel{border-color:var(--gold);background:rgba(232,184,78,.1);box-shadow:0 0 0 2px rgba(232,184,78,.25) inset;}
.hsx-payopt input{position:absolute;opacity:0;}
.hsx-payopt b{font-family:var(--font-display);font-size:.96rem;display:block;}
.hsx-payopt small{color:var(--muted);font-size:.78rem;}
.hsx-card-row{display:grid;grid-template-columns:1fr 110px 90px;gap:.8rem;}

/* order summary card */
.hsx-order .hsx-order-li{display:flex;justify-content:space-between;gap:1rem;padding:.5rem 0;border-bottom:1px dashed var(--line);font-size:.92rem;}
.hsx-order .hsx-order-li small{color:var(--muted);}
.hsx-order-total{display:flex;justify-content:space-between;margin-top:.8rem;padding-top:.7rem;border-top:2px solid var(--line);font-family:var(--font-display);font-weight:700;}
.hsx-order-due{display:flex;justify-content:space-between;margin-top:.5rem;color:var(--gold-dark);font-family:var(--font-display);font-weight:700;font-size:1.1rem;}

/* confirmation */
.hsx-done{max-width:640px;margin:0 auto;text-align:center;padding:clamp(20px,4vw,40px) 0;}
.hsx-done .tick{width:84px;height:84px;border-radius:50%;background:var(--gold);display:grid;place-items:center;margin:0 auto 1.4rem;animation:hsx-pop .4s ease;}
.hsx-done .tick svg{width:42px;height:42px;stroke:#1a160d;stroke-width:3;fill:none;}
.hsx-done .ref{display:inline-block;margin-top:.6rem;font-family:var(--font-display);font-weight:700;letter-spacing:.1em;background:var(--cream);border:1px dashed var(--line);border-radius:8px;padding:.5rem 1rem;}
.hsx-done .hsx-order{max-width:420px;margin:1.6rem auto;text-align:left;border:1px solid var(--line);border-radius:12px;padding:1.2rem 1.4rem;background:var(--surface);}

/* ============================================================
   EXHIBITOR PORTAL  (dedicated app shell)
   ============================================================ */
.hsx-app{min-height:100vh;display:grid;grid-template-columns:264px 1fr;background:var(--cream);}
.hsx-app>div{min-width:0;}
.hsx-side{background:var(--black);color:#e9e3d6;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;}
.hsx-brand{display:flex;align-items:center;gap:.6rem;padding:1.2rem 1.3rem;border-bottom:1px solid rgba(255,255,255,.08);}
.hsx-brand .mk{width:30px;height:30px;border-radius:7px;background:var(--gold);display:grid;place-items:center;color:#1a160d;font-family:var(--font-display);font-weight:800;font-size:1.05rem;flex:none;}
.hsx-brand .bt{font-family:var(--font-display);font-weight:700;font-size:.92rem;line-height:1.2;}
.hsx-brand .bt small{display:block;font-weight:500;font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);}
.hsx-nav{padding:.8rem .7rem;flex:1;overflow:auto;}
.hsx-nav a{display:flex;align-items:center;gap:.7rem;padding:.7rem .85rem;border-radius:10px;color:#cfc9bd;font-family:var(--font-display);font-weight:600;font-size:.86rem;cursor:pointer;transition:.16s;margin-bottom:.15rem;}
.hsx-nav a svg{width:18px;height:18px;flex:none;opacity:.85;}
.hsx-nav a:hover{background:rgba(255,255,255,.06);color:#fff;}
.hsx-nav a.active{background:var(--gold);color:#1a160d;}
.hsx-nav a .badge{margin-left:auto;background:var(--overdue);color:#fff;font-size:.66rem;font-weight:700;padding:.05rem .4rem;border-radius:999px;}
.hsx-side-foot{padding:.9rem 1rem;border-top:1px solid rgba(255,255,255,.08);font-size:.72rem;color:#8c867b;}
.hsx-side-foot a{color:#cfc9bd;text-decoration:underline;}

.hsx-top{display:flex;align-items:center;gap:1rem;padding:1rem clamp(18px,3vw,38px);background:var(--surface);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20;min-width:0;}
.hsx-top .h{font-family:var(--font-display);font-weight:700;font-size:1.15rem;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.hsx-top .h small{display:block;font-weight:500;font-size:.78rem;color:var(--muted);letter-spacing:0;text-transform:none;}
.hsx-top .sp{margin-left:auto;}
.hsx-top .ava{display:flex;align-items:center;gap:.6rem;}
.hsx-top .ava .av{width:38px;height:38px;border-radius:50%;background:var(--gold);color:#1a160d;display:grid;place-items:center;font-family:var(--font-display);font-weight:700;}
.hsx-top .ava .nm{font-family:var(--font-display);font-weight:600;font-size:.86rem;line-height:1.2;}
.hsx-top .ava .nm small{display:block;font-weight:500;color:var(--muted);font-size:.72rem;}
.hsx-portal-main{padding:clamp(18px,3vw,38px);max-width:1100px;min-width:0;}
.hsx-hamb{display:none;background:none;border:1.5px solid var(--line);border-radius:8px;width:40px;height:40px;cursor:pointer;}
.hsx-hamb span{display:block;width:18px;height:2px;background:var(--ink);margin:4px auto;}

/* portal cards & widgets */
.hsx-card{background:var(--surface);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-card);}
.hsx-card-p{padding:1.3rem 1.4rem;}
.hsx-grid{display:grid;gap:clamp(14px,1.8vw,22px);}
.hsx-g3{grid-template-columns:repeat(3,1fr);}
.hsx-g2{grid-template-columns:1.5fr 1fr;}
.hsx-section-t{font-family:var(--font-display);font-weight:700;font-size:1.05rem;margin-bottom:.9rem;display:flex;align-items:center;gap:.5rem;}

.hsx-stat{padding:1.2rem 1.3rem;}
.hsx-stat .k{font-family:var(--font-display);font-weight:600;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);}
.hsx-stat .v{font-family:var(--font-display);font-weight:700;font-size:1.8rem;color:var(--gold-dark);margin-top:.2rem;line-height:1;}
.hsx-stat .d{font-size:.8rem;color:var(--ink-soft);margin-top:.35rem;}

/* welcome banner */
.hsx-welcome{background:linear-gradient(120deg,var(--black),var(--charcoal));color:#f1ece2;border-radius:14px;padding:clamp(1.3rem,3vw,2rem);display:flex;flex-wrap:wrap;align-items:center;gap:1.2rem;box-shadow:var(--shadow-card);}
.hsx-welcome .wc{flex:1;min-width:240px;}
.hsx-welcome h2{font-family:var(--font-display);font-size:clamp(1.4rem,3vw,2rem);}
.hsx-welcome p{color:#cfc9bd;margin:.4rem 0 0;}
.hsx-welcome .gold-text{color:var(--gold);}
.hsx-countdown{display:flex;gap:.8rem;}
.hsx-countdown .u{text-align:center;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:.6rem .8rem;min-width:62px;}
.hsx-countdown .u b{font-family:var(--font-display);font-size:1.5rem;display:block;color:#fff;}
.hsx-countdown .u span{font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-soft);}

/* setup checklist + ring */
.hsx-check{display:flex;align-items:center;gap:1.4rem;flex-wrap:wrap;}
.hsx-ring{--p:0;position:relative;width:96px;height:96px;border-radius:50%;flex:none;
  background:conic-gradient(var(--gold) calc(var(--p)*1%),var(--line) 0);display:grid;place-items:center;}
.hsx-ring::before{content:"";position:absolute;inset:10px;border-radius:50%;background:var(--surface);}
.hsx-ring b{position:relative;font-family:var(--font-display);font-weight:700;font-size:1.3rem;color:var(--gold-dark);}
.hsx-tasks{flex:1;min-width:220px;display:flex;flex-direction:column;gap:.5rem;}
.hsx-task{display:flex;align-items:center;gap:.65rem;font-size:.92rem;}
.hsx-task .ck{width:22px;height:22px;border-radius:50%;border:2px solid var(--line);display:grid;place-items:center;flex:none;}
.hsx-task.done .ck{background:var(--ok);border-color:var(--ok);}
.hsx-task.done .ck svg{width:12px;height:12px;stroke:#fff;stroke-width:3;fill:none;}
.hsx-task.done span{color:var(--muted);text-decoration:line-through;}
.hsx-task a{margin-left:auto;font-size:.78rem;color:var(--gold-dark);font-weight:700;cursor:pointer;}

/* quick actions */
.hsx-qa{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.7rem;}
.hsx-qa button{text-align:left;cursor:pointer;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:.9rem 1rem;transition:.18s;font-family:var(--font-body);}
.hsx-qa button:hover{border-color:var(--gold);transform:translateY(-1px);box-shadow:var(--shadow-card);}
.hsx-qa button b{font-family:var(--font-display);display:block;font-size:.92rem;}
.hsx-qa button small{color:var(--muted);font-size:.78rem;}

/* my booth */
.hsx-booth-hero{display:flex;gap:1.4rem;flex-wrap:wrap;align-items:center;}
.hsx-booth-badge{flex:none;width:150px;height:150px;border-radius:14px;background:var(--gold);color:#1a160d;display:grid;place-content:center;text-align:center;box-shadow:var(--shadow-card);}
.hsx-booth-badge .bn{font-family:var(--font-display);font-weight:800;font-size:2.2rem;line-height:1;}
.hsx-booth-badge .bt{font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;margin-top:.3rem;font-weight:700;}
.hsx-minimap{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--hsx-board);}
.hsx-minimap svg{display:block;width:100%;}

/* tables */
.hsx-table{width:100%;border-collapse:collapse;font-size:.9rem;}
.hsx-table th{text-align:left;font-family:var(--font-display);font-weight:600;font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);padding:.7rem .9rem;border-bottom:1px solid var(--line);}
.hsx-table td{padding:.8rem .9rem;border-bottom:1px solid var(--line);vertical-align:middle;}
.hsx-table tr:last-child td{border-bottom:none;}
.hsx-table .num{font-family:var(--font-display);font-weight:700;}
.pill{display:inline-flex;align-items:center;gap:.35rem;font-family:var(--font-display);font-weight:700;font-size:.7rem;letter-spacing:.04em;text-transform:uppercase;padding:.22rem .6rem;border-radius:999px;}
.pill::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor;}
.pill.paid{color:var(--ok);background:rgba(63,157,99,.12);}
.pill.due{color:var(--due);background:rgba(217,154,43,.14);}
.pill.overdue{color:var(--overdue);background:rgba(210,96,63,.14);}
.hsx-balance-row{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;margin-top:1.1rem;padding-top:1rem;border-top:2px solid var(--line);}
.hsx-balance-row .bk{font-family:var(--font-display);font-weight:600;letter-spacing:.05em;text-transform:uppercase;font-size:.8rem;color:var(--ink-soft);}
.hsx-balance-row .bv{font-family:var(--font-display);font-weight:700;font-size:1.6rem;color:var(--gold-dark);}

/* documents */
.hsx-doc{display:flex;align-items:center;gap:.9rem;padding:.9rem 0;border-bottom:1px solid var(--line);}
.hsx-doc:last-child{border-bottom:none;}
.hsx-doc .dico{width:42px;height:42px;border-radius:10px;background:var(--cream);display:grid;place-items:center;flex:none;color:var(--gold-dark);}
.hsx-doc .dico svg{width:20px;height:20px;}
.hsx-doc .dmain{flex:1;min-width:0;}
.hsx-doc .dmain b{font-family:var(--font-display);font-size:.94rem;display:block;}
.hsx-doc .dmain small{color:var(--muted);font-size:.8rem;}

/* profile logo */
.hsx-logo-up{display:flex;align-items:center;gap:1rem;margin-bottom:1.2rem;}
.hsx-logo-up .lg{width:80px;height:80px;border-radius:12px;border:1px dashed var(--line);background:var(--cream);display:grid;place-items:center;overflow:hidden;flex:none;font-family:var(--font-display);font-weight:800;font-size:1.6rem;color:var(--gold-dark);}
.hsx-logo-up .lg img{width:100%;height:100%;object-fit:cover;}

/* toast */
.hsx-toasts{position:fixed;right:18px;bottom:18px;z-index:200;display:flex;flex-direction:column;gap:.5rem;}
.hsx-toast{background:#15130f;color:#f4efe4;border:1px solid rgba(232,184,78,.4);border-left:3px solid var(--gold);border-radius:8px;padding:.7rem 1rem;font-size:.86rem;box-shadow:0 12px 30px rgba(0,0,0,.4);animation:hsx-fade .25s ease;}

/* ============================================================
   LOGIN
   ============================================================ */
.hsx-login-wrap{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;}
.hsx-login-aside{background:linear-gradient(150deg,var(--black),var(--charcoal));color:#f1ece2;padding:clamp(2rem,5vw,4rem);display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden;}
.hsx-login-aside .eyebrow{color:var(--gold);}
.hsx-login-aside h1{font-family:var(--font-display);font-size:clamp(1.8rem,3.4vw,2.8rem);line-height:1.1;}
.hsx-login-aside p{color:#cfc9bd;margin-top:1rem;max-width:420px;}
.hsx-login-aside .stats{display:flex;gap:1.6rem;margin-top:2rem;}
.hsx-login-aside .stats b{font-family:var(--font-display);font-size:1.6rem;color:var(--gold);display:block;}
.hsx-login-aside .stats span{font-size:.78rem;color:#cfc9bd;}
.hsx-login-main{display:flex;align-items:center;justify-content:center;padding:clamp(1.5rem,5vw,3rem);background:var(--page);}
.hsx-login-card{width:100%;max-width:400px;}
.hsx-login-card .mk{width:42px;height:42px;border-radius:10px;background:var(--gold);display:grid;place-items:center;color:#1a160d;font-family:var(--font-display);font-weight:800;font-size:1.3rem;margin-bottom:1.2rem;}
.hsx-demo-creds{background:var(--cream);border:1px dashed var(--line);border-radius:10px;padding:.8rem 1rem;font-size:.82rem;color:var(--ink-soft);margin-top:1.2rem;}
.hsx-demo-creds b{color:var(--gold-dark);font-family:var(--font-display);}
.hsx-mini-toggle{position:absolute;top:1rem;right:1rem;}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:980px){
  .hsx-picker{grid-template-columns:1fr;}
  .hsx-cart{position:static;}
  .hsx-2col{grid-template-columns:1fr;}
  .hsx-g2{grid-template-columns:1fr;}
  .hsx-login-wrap{grid-template-columns:1fr;}
  .hsx-login-aside{display:none;}
}
@media (max-width:860px){
  .hsx-g3{grid-template-columns:1fr;}
  .hsx-app{grid-template-columns:1fr;}
  .hsx-side{position:fixed;left:0;top:0;width:264px;z-index:120;transform:translateX(-100%);transition:transform .25s ease;box-shadow:0 0 60px rgba(0,0,0,.5);}
  .hsx-app.nav-open .hsx-side{transform:none;}
  .hsx-app.nav-open::after{content:"";position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:110;}
  .hsx-hamb{display:block;}
  .hsx-portal-main{padding-inline:18px;}
}
@media (max-width:600px){
  .hsx-top{gap:.55rem;padding-inline:14px;}
  .hsx-top .h{flex:1 1 auto;font-size:1.02rem;}
  .hsx-top .h small{display:none;}
  .hsx-top .sp{display:none;}
  .hsx-top .ava .nm{display:none;}
  .hsx-top #hsxOut{padding:.5em .8em;font-size:.66rem;}
}
@media (max-width:560px){
  .hsx-stepper .lbl{display:none;}
  .hsx-card-row{grid-template-columns:1fr;}
  .hsx-pay-options{grid-template-columns:1fr;}
  .hsx-step::before{top:18px;}
}
