/* ============================================================
   HOME SHOWS — Ticketing UI (buy flow, customer portal,
   confirmation, mobile-first agent/scanner app)
   Sits on top of css/styles.css on public pages; the agent app
   carries its own fallback tokens so it can stand alone.
   ============================================================ */

/* shared fallback tokens (public pages already define these) */
.tk, .tk-shop, .tk-portal, .tk-confirm, .ag-app {
  --tk-gold:#e8b84e; --tk-gold-deep:#a87c1a;
  --tk-ok:#46c46e; --tk-bad:#e2554e; --tk-info:#5aa9e6; --tk-vip:#a98bd6;
}

/* the standalone agent/scanner app loads only this stylesheet, so it needs its own
   box-sizing reset (public ticketing pages inherit it from styles.css) */
.ag-login, .ag-login *, .ag-app, .ag-app *{box-sizing:border-box;}
/* ...and its brand fonts (styles.css defines --font-* for public pages; the agent app must too, or it falls back to serif) */
.ag-login, .ag-app{--font-display:'Poppins',system-ui,-apple-system,'Segoe UI',sans-serif;
  --font-body:'Mulish',system-ui,-apple-system,'Segoe UI',sans-serif;font-family:var(--font-body);}
.ag-login h1, .ag-app h1, .ag-login h2, .ag-app h2, .ag-login h3, .ag-app h3{font-family:var(--font-display);}

/* ====================== BUY FLOW (tickets.html) ====================== */
.tk-hero{position:relative;overflow:hidden;background:var(--black);color:#efe9dd;padding:clamp(2.4rem,5vw,4rem) 0 clamp(2rem,4vw,3rem)}
.tk-hero .container{position:relative;z-index:2}
.tk-hero .crumbs{color:rgba(255,255,255,.6);font-size:.8rem;margin-bottom:1rem;display:flex;gap:.5rem;flex-wrap:wrap}
.tk-hero .crumbs a{color:rgba(255,255,255,.75)}
.tk-hero h1{font-size:clamp(2.1rem,5vw,3.4rem);margin:.2rem 0 .4rem}
.tk-hero .sub{color:#cfc9bd;max-width:42rem;font-size:1.02rem}
.tk-hero .meta{display:flex;flex-wrap:wrap;gap:.5rem .9rem;margin-top:1.2rem}
.tk-hero .meta .chip{display:inline-flex;align-items:center;gap:.4rem;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:999px;padding:.35rem .8rem;font-size:.82rem}
.tk-hero .glow{position:absolute;inset:auto -10% -60% auto;width:60vw;height:60vw;max-width:560px;max-height:560px;background:radial-gradient(circle,rgba(232,184,78,.28),transparent 65%);filter:blur(8px);z-index:1}

.tk-shop{display:grid;grid-template-columns:1.7fr 1fr;gap:1.6rem;align-items:start}
@media(max-width:920px){.tk-shop{grid-template-columns:1fr}}
.tk-col{min-width:0}

.tk-step-h{display:flex;align-items:center;gap:.7rem;margin:0 0 1rem}
.tk-step-h .n{flex:0 0 auto;width:1.9rem;height:1.9rem;border-radius:999px;background:var(--gold);color:#1a1407;font-family:var(--font-display);font-weight:700;display:grid;place-items:center;font-size:.95rem}
.tk-step-h h2{font-size:1.25rem}

/* ticket type cards */
.tk-types{display:flex;flex-direction:column;gap:.9rem}
.tk-type{display:grid;grid-template-columns:1fr auto;gap:.4rem 1rem;align-items:center;border:1.5px solid var(--line);border-radius:16px;padding:1.1rem 1.2rem;background:var(--paper);transition:.18s ease;position:relative}
.tk-type.has{border-color:var(--gold);box-shadow:0 0 0 3px rgba(232,184,78,.14)}
.tk-type .tt-name{font-family:var(--font-display);font-weight:700;font-size:1.06rem;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.tk-type .tt-blurb{grid-column:1/2;color:var(--muted);font-size:.88rem;line-height:1.45;margin-top:.1rem}
.tk-type .tt-price{text-align:right;font-family:var(--font-display);font-weight:700;font-size:1.5rem;color:var(--gold-dark);white-space:nowrap}
.tk-type .tt-price small{display:block;font-size:.7rem;font-weight:600;color:var(--muted);letter-spacing:.02em}
.tk-type .tt-controls{grid-column:1/-1;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-top:.4rem}
.tk-badge{display:inline-block;font-family:var(--font-display);font-size:.62rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:.22rem .55rem;border-radius:999px;background:rgba(232,184,78,.18);color:var(--gold-dark)}
.tk-badge.vip{background:rgba(169,139,214,.2);color:#7b59c0}
.tk-badge.best{background:var(--gold);color:#1a1407}

.tk-perks{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.2rem}
.tk-perks span{font-size:.74rem;color:var(--ink-soft);background:var(--cream);border:1px solid var(--line);border-radius:999px;padding:.18rem .55rem}

/* qty stepper */
.tk-stepper{display:inline-flex;align-items:center;border:1.5px solid var(--line);border-radius:999px;overflow:hidden;background:var(--surface)}
.tk-stepper button{width:2.4rem;height:2.4rem;border:0;background:transparent;font-size:1.3rem;line-height:1;cursor:pointer;color:var(--ink);transition:.15s}
.tk-stepper button:hover:not(:disabled){background:var(--cream)}
.tk-stepper button:disabled{opacity:.3;cursor:not-allowed}
.tk-stepper .q{min-width:2.2rem;text-align:center;font-family:var(--font-display);font-weight:700;font-size:1.05rem}

/* day picker */
.tk-days{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:.3rem}
.tk-day{border:1.5px solid var(--line);background:var(--surface);border-radius:10px;padding:.5rem .8rem;cursor:pointer;font-size:.82rem;font-weight:600;text-align:center;transition:.15s;line-height:1.2}
.tk-day small{display:block;font-weight:500;color:var(--muted);font-size:.68rem}
.tk-day.on{border-color:var(--gold);background:rgba(232,184,78,.12);color:var(--ink)}
.tk-day-note{font-size:.78rem;color:var(--muted);margin-top:.4rem}

/* ====================== ORDER SUMMARY ====================== */
.tk-summary{position:sticky;top:calc(var(--hs-header-h,76px) + 14px);border:1.5px solid var(--line);border-radius:18px;background:var(--paper);box-shadow:var(--shadow-card);overflow:hidden}
.tk-summary .sum-head{background:var(--charcoal);color:#efe9dd;padding:1rem 1.2rem}
.tk-summary .sum-head h3{font-size:1.05rem;margin:0;color:#fff}
.tk-summary .sum-head .sub{color:#cfc9bd;font-size:.8rem;margin-top:.1rem}
.tk-summary .sum-body{padding:1.1rem 1.2rem}
.tk-line{display:flex;justify-content:space-between;gap:1rem;font-size:.92rem;padding:.35rem 0}
.tk-line .l{color:var(--ink-soft)}
.tk-line.disc .l,.tk-line.disc .r{color:var(--gold-dark);font-weight:700}
.tk-line.total{border-top:1.5px solid var(--line);margin-top:.5rem;padding-top:.7rem;font-family:var(--font-display);font-weight:700;font-size:1.25rem}
.tk-empty{color:var(--muted);font-size:.9rem;text-align:center;padding:1.4rem 0}

/* savings meter / gamification */
.tk-savings{margin:.4rem 0 1rem;background:linear-gradient(100deg,rgba(70,196,110,.12),rgba(70,196,110,.03));border:1px solid rgba(70,196,110,.3);border-radius:12px;padding:.8rem .9rem}
.tk-savings .sv-top{display:flex;justify-content:space-between;align-items:baseline;font-size:.84rem;color:var(--ink-soft)}
.tk-savings .sv-amt{font-family:var(--font-display);font-weight:800;color:#2e9c52;font-size:1.05rem}
.tk-meter{height:9px;border-radius:999px;background:rgba(70,196,110,.18);overflow:hidden;margin-top:.45rem}
.tk-meter i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#6dd48a,#2e9c52);transition:width .5s cubic-bezier(.2,.9,.2,1)}
.tk-badges{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.7rem}
.tk-ach{display:inline-flex;align-items:center;gap:.35rem;font-size:.74rem;font-weight:700;padding:.25rem .6rem;border-radius:999px;background:var(--cream);border:1px solid var(--line);color:var(--muted);opacity:.55;transition:.3s}
.tk-ach.on{opacity:1;background:rgba(232,184,78,.16);border-color:var(--gold);color:var(--gold-dark)}

/* promo */
.tk-promo{margin:.4rem 0 1rem}
.tk-promo .pf{display:flex;gap:.5rem}
.tk-promo input{flex:1;min-width:0;text-transform:uppercase;letter-spacing:.08em}
.tk-promo .msg{font-size:.8rem;margin-top:.45rem;min-height:1.1rem}
.tk-promo .msg.ok{color:#2e9c52;font-weight:700}
.tk-promo .msg.err{color:var(--tk-bad)}
.tk-promo .hint{font-size:.74rem;color:var(--muted);margin-top:.3rem}
.tk-promo .hint code{background:var(--cream);padding:.05rem .3rem;border-radius:5px;cursor:pointer}

/* checkout / payment */
.tk-pay{border:1.5px dashed var(--line);border-radius:14px;padding:1rem 1.1rem;background:var(--cream);margin-top:.3rem}
.tk-pay .demo-note{display:flex;align-items:center;gap:.45rem;font-size:.78rem;color:var(--muted);margin-bottom:.7rem}
.tk-field{margin-bottom:.7rem}
.tk-field label{display:block;font-size:.78rem;font-weight:700;color:var(--ink-soft);margin-bottom:.25rem}
.tk-field input,.tk-field select{width:100%;padding:.7rem .8rem;border:1.5px solid var(--line);border-radius:10px;background:var(--surface);font-family:inherit;font-size:.95rem;color:var(--ink)}
.tk-field input:focus,.tk-field select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(232,184,78,.16)}
.tk-field input.invalid{border-color:var(--tk-bad);box-shadow:0 0 0 3px rgba(226,85,78,.12)}
.tk-field .err{color:var(--tk-bad);font-size:.74rem;margin-top:.2rem;display:none}
.tk-field.show-err .err{display:block}
.tk-row2{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
@media(max-width:420px){.tk-row2{grid-template-columns:1fr}}

.tk-cta{width:100%;margin-top:.4rem}
.tk-cta:disabled{opacity:.55;cursor:not-allowed}
.tk-secure{display:flex;align-items:center;justify-content:center;gap:.4rem;font-size:.76rem;color:var(--muted);margin-top:.7rem}

/* ====================== SUCCESS / CONFIRMATION ====================== */
.tk-success{max-width:760px;margin:0 auto}
.tk-success .done-hero{text-align:center;padding:2rem 0 1rem}
.tk-success .done-hero .ring{width:74px;height:74px;border-radius:999px;background:rgba(70,196,110,.16);color:#2e9c52;display:grid;place-items:center;margin:0 auto 1rem;font-size:2.1rem;animation:tkpop .5s cubic-bezier(.2,1.4,.4,1)}
@keyframes tkpop{0%{transform:scale(.4);opacity:0}100%{transform:scale(1);opacity:1}}
.tk-actions{display:flex;flex-wrap:wrap;gap:.7rem;justify-content:center;margin:1.2rem 0}

.tk-ticketcard{display:grid;grid-template-columns:auto 1fr;gap:1.1rem;border:1.5px solid var(--line);border-radius:16px;overflow:hidden;background:var(--paper);margin-bottom:1rem}
.tk-ticketcard .qr{background:#fff;padding:.9rem;display:grid;place-items:center;border-right:1.5px dashed var(--line);position:relative}
.tk-ticketcard .qr img{width:128px;height:128px;display:block}
.tk-ticketcard .qr.scanned{filter:grayscale(1) opacity(.5)}
.tk-ticketcard .body{padding:1rem 1.1rem 1rem 0;min-width:0}
.tk-ticketcard .body h4{font-size:1.05rem;margin:0 0 .2rem;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.tk-ticketcard .body .row{font-size:.86rem;color:var(--ink-soft);margin:.1rem 0}
.tk-ticketcard .body .muted{color:var(--muted)}
.tk-stat{display:inline-block;font-size:.66rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:.2rem .55rem;border-radius:999px}
.tk-stat.valid{background:rgba(70,196,110,.16);color:#2e9c52}
.tk-stat.admitted{background:rgba(90,169,230,.16);color:#3580bf}
.tk-stat.refunded,.tk-stat.cancelled,.tk-stat.void{background:rgba(226,85,78,.14);color:var(--tk-bad)}
.tk-stat.paid{background:rgba(70,196,110,.16);color:#2e9c52}
.tk-stat.partially_refunded{background:rgba(232,184,78,.18);color:var(--gold-dark)}

/* confetti */
.tk-confetti{position:fixed;inset:0;pointer-events:none;z-index:60;overflow:hidden}
.tk-confetti i{position:absolute;top:-12px;width:9px;height:14px;opacity:.9;animation:tkfall linear forwards}
@keyframes tkfall{to{transform:translateY(108vh) rotate(640deg);opacity:.8}}

/* ====================== CUSTOMER PORTAL (my-tickets.html) ====================== */
.tk-portal{max-width:920px;margin:0 auto}
.tk-login{max-width:420px;margin:0 auto;border:1.5px solid var(--line);border-radius:18px;background:var(--paper);padding:1.6rem;box-shadow:var(--shadow-card)}
.tk-order{border:1.5px solid var(--line);border-radius:16px;background:var(--paper);margin-bottom:1.1rem;overflow:hidden}
.tk-order .oh{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;padding:.9rem 1.1rem;background:var(--cream);border-bottom:1px solid var(--line)}
.tk-order .oh b{font-family:var(--font-display)}
.tk-order .ob{padding:1rem 1.1rem}

/* ====================== AGENT APP (agent.html / agent-login.html) ====================== */
.ag-app{--ag-bg:#0e0d0b;--ag-panel:#1b1813;--ag-panel-2:#231f18;--ag-line:rgba(255,255,255,.1);--ag-ink:#ece7dd;--ag-mute:#9a9488;
  min-height:100dvh;background:var(--ag-bg);color:var(--ag-ink);font-family:var(--font-body);display:flex;flex-direction:column}
.ag-topbar{position:sticky;top:0;z-index:5;display:flex;align-items:center;justify-content:space-between;gap:.6rem;padding:.7rem 1rem;background:rgba(14,13,11,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--ag-line)}
.ag-topbar .brand{display:flex;align-items:center;gap:.55rem;font-family:var(--font-display);font-weight:700}
.ag-topbar .brand .logo{width:1.9rem;height:1.9rem;border-radius:8px;background:var(--tk-gold);color:#1a1407;display:grid;place-items:center;font-size:.8rem;font-weight:800}
.ag-topbar .who{font-size:.74rem;color:var(--ag-mute);text-align:right;line-height:1.2}
.ag-iconbtn{background:transparent;border:1px solid var(--ag-line);color:var(--ag-ink);border-radius:9px;padding:.4rem .6rem;cursor:pointer;font-size:.85rem}
.ag-main{flex:1;width:100%;max-width:640px;margin:0 auto;padding:1rem;min-width:0}

.ag-tabs{display:flex;gap:.5rem;background:var(--ag-panel);border:1px solid var(--ag-line);border-radius:12px;padding:.35rem;margin-bottom:1rem}
.ag-tabs button{flex:1;border:0;background:transparent;color:var(--ag-mute);font-family:var(--font-display);font-weight:600;font-size:.85rem;padding:.6rem;border-radius:9px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.4rem}
.ag-tabs button.on{background:var(--tk-gold);color:#1a1407}

.ag-card{background:var(--ag-panel);border:1px solid var(--ag-line);border-radius:14px;padding:1.1rem}
.ag-card+.ag-card{margin-top:1rem}

/* scanner */
.ag-scanwrap{position:relative;border-radius:16px;overflow:hidden;background:#000;aspect-ratio:1/1;max-height:62vh;margin:0 auto;display:grid;place-items:center}
.ag-scanwrap video{width:100%;height:100%;object-fit:cover}
.ag-reticle{position:absolute;inset:14%;border:3px solid rgba(232,184,78,.9);border-radius:18px;box-shadow:0 0 0 100vmax rgba(0,0,0,.35)}
.ag-reticle:before{content:"";position:absolute;left:0;right:0;top:50%;height:2px;background:var(--tk-gold);box-shadow:0 0 12px var(--tk-gold);animation:agscan 2.2s ease-in-out infinite}
@keyframes agscan{0%,100%{top:14%}50%{top:86%}}
.ag-cam-off{color:var(--ag-mute);text-align:center;padding:2rem 1rem}
.ag-daysel{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.8rem}
.ag-daysel button{flex:1;min-width:64px;border:1px solid var(--ag-line);background:var(--ag-panel-2);color:var(--ag-ink);border-radius:9px;padding:.5rem;font-size:.78rem;cursor:pointer}
.ag-daysel button.on{background:var(--tk-gold);color:#1a1407;border-color:var(--tk-gold);font-weight:700}

/* big result */
.ag-result{position:fixed;inset:0;z-index:30;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem;color:#fff;animation:tkpop .25s ease}
.ag-result.admitted{background:linear-gradient(160deg,#1f9d52,#0f6b36)}
.ag-result.already{background:linear-gradient(160deg,#c98b1f,#8a5e12)}
.ag-result.invalid,.ag-result.void{background:linear-gradient(160deg,#c33,#7a1d1d)}
.ag-result .big{font-size:4rem;line-height:1}
.ag-result h2{font-size:2rem;margin:.6rem 0 .2rem;color:#fff}
.ag-result .det{opacity:.92;font-size:1rem}
.ag-result .tap{margin-top:1.6rem;font-size:.85rem;opacity:.8}

.ag-history{margin-top:1rem}
.ag-scanrow{display:flex;align-items:center;justify-content:space-between;gap:.7rem;padding:.55rem 0;border-bottom:1px solid var(--ag-line);font-size:.85rem}
.ag-scanrow .dot{width:9px;height:9px;border-radius:999px;flex:0 0 auto}
.ag-dot-admitted{background:#46c46e}.ag-dot-already{background:#e8b84e}.ag-dot-invalid,.ag-dot-void{background:#e2554e}

/* service console */
.ag-search{display:flex;gap:.5rem;margin-bottom:1rem}
.ag-search input{flex:1;min-width:0}
.ag-input,.ag-card input,.ag-card select,.ag-card textarea{width:100%;padding:.7rem .8rem;border:1px solid var(--ag-line);border-radius:10px;background:var(--ag-panel-2);color:var(--ag-ink);font-family:inherit;font-size:.95rem}
.ag-input::placeholder{color:var(--ag-mute)}
.ag-btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;border:0;border-radius:10px;padding:.7rem 1.1rem;font-family:var(--font-display);font-weight:700;font-size:.82rem;letter-spacing:.04em;cursor:pointer;background:var(--tk-gold);color:#1a1407}
.ag-btn.ghost{background:transparent;border:1px solid var(--ag-line);color:var(--ag-ink)}
.ag-btn.danger{background:#7a1d1d;color:#fff}
.ag-btn:disabled{opacity:.5;cursor:not-allowed}
.ag-orow{display:flex;justify-content:space-between;gap:.8rem;padding:.7rem .2rem;border-bottom:1px solid var(--ag-line);cursor:pointer}
.ag-orow:hover{background:var(--ag-panel-2)}
.ag-kv{display:flex;justify-content:space-between;gap:1rem;font-size:.88rem;padding:.3rem 0}
.ag-kv .k{color:var(--ag-mute)}

.ag-login{min-height:100dvh;display:grid;place-items:center;background:var(--ag-bg);color:var(--ag-ink);padding:1.2rem}
.ag-login .box{width:100%;max-width:400px;background:var(--ag-panel);border:1px solid var(--ag-line);border-radius:18px;padding:1.8rem}
.ag-login h1{font-size:1.5rem;margin:.4rem 0 .2rem}
.ag-login .demo{margin-top:1rem;font-size:.78rem;color:var(--ag-mute);background:var(--ag-panel-2);border:1px solid var(--ag-line);border-radius:10px;padding:.7rem .8rem}
.ag-login .demo code{color:var(--tk-gold);cursor:pointer}
.ag-msg{font-size:.84rem;margin:.6rem 0;min-height:1rem}
.ag-msg.err{color:#ff8d86}

/* generic helpers for ticketing pages */
.tk-note{background:rgba(232,184,78,.1);border:1px solid var(--tk-gold);border-radius:12px;padding:.8rem 1rem;font-size:.86rem;color:var(--ink-soft);display:flex;gap:.6rem;align-items:flex-start}
.tk-spin{width:1.1em;height:1.1em;border:2px solid currentColor;border-right-color:transparent;border-radius:999px;display:inline-block;animation:tkspin .7s linear infinite;vertical-align:-2px}
@keyframes tkspin{to{transform:rotate(360deg)}}
