/* ============================================================
   EventPass — light editorial theme
   Layout inspiration: District (horizontal scroll rows, location nav)
   Palette & type deliberately our own:
     paper   #fbf7f0  warm cream background
     surface #ffffff  cards
     ink     #1a1614  warm near-black text
     teal    #1d6d5f  primary accent (links, brand)
     coral   #f0683a  CTA / action
     gold    #c79a3e  detail / ratings
     mute    #7a7068  secondary text
     line    #ece4d8  hairlines
   Display: Fraunces (serif)   Body: Outfit (sans)
   ============================================================ */

:root{
  --paper:#fbf7f0; --surface:#ffffff; --surface2:#f5efe5;
  --ink:#1a1614; --teal:#1d6d5f; --teal-d:#155249;
  --coral:#f0683a; --coral-d:#d8542a; --gold:#c79a3e;
  --mute:#7a7068; --line:#ece4d8; --line2:#ddd2c2;
  --ok:#1d8a5f; --warn:#c98a1a; --bad:#cc4733;
  --r:16px; --shadow:0 12px 30px -16px rgba(60,40,20,.28);
}

*{box-sizing:border-box}
html,body{margin:0}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:'Outfit',system-ui,sans-serif;
  line-height:1.55;
  min-height:100vh;
  display:flex;flex-direction:column;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
h1,h2,h3,.brand-text{font-family:'Fraunces','Georgia',serif;letter-spacing:-.01em;font-weight:600}

/* ---------- Nav ---------- */
.nav{position:sticky;top:0;z-index:50;background:rgba(251,247,240,.9);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav-inner{max-width:1220px;margin:0 auto;padding:14px 24px;display:flex;align-items:center;gap:22px}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:21px}
.brand-mark{color:var(--coral);font-size:24px}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-text em{font-style:normal;font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--mute);margin-top:3px;font-family:'Outfit'}
.nav-links{display:flex;gap:4px;margin-left:8px;flex-wrap:wrap}
.nav-links a{padding:8px 13px;border-radius:10px;color:var(--ink);font-size:15px;font-weight:500;transition:.15s}
.nav-links a:hover{color:var(--teal);background:var(--surface2)}
.nav-actions{margin-left:auto;display:flex;gap:8px;align-items:center}
.btn-ghost,.btn-solid{padding:9px 15px;border-radius:11px;font-size:14px;font-weight:600;cursor:pointer;border:1px solid transparent;transition:.15s}
.btn-ghost{color:var(--ink);border-color:var(--line2)}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal)}
.btn-solid{background:var(--coral);color:#fff}
.btn-solid:hover{background:var(--coral-d)}

/* ---------- Layout ---------- */
.container{max-width:1220px;margin:0 auto;padding:30px 24px;width:100%;flex:1}
.muted{color:var(--mute)}
.flash{max-width:1220px;margin:14px auto 0;padding:12px 18px;border-radius:12px;font-weight:500}
.flash-info{background:#e7f1ef;color:var(--teal-d);border:1px solid #bfe0d8}
.flash-error{background:#fae7e2;color:var(--bad);border:1px solid #f1c4b8}
.flash-success{background:#e4f3ea;color:var(--ok);border:1px solid #bde6cd}

/* ---------- Hero ---------- */
.hero{position:relative;border-radius:24px;overflow:hidden;padding:60px 48px;margin-bottom:14px;
  background:linear-gradient(120deg,#1d6d5f,#155249 60%,#123f38);color:#fdfaf4}
.hero h1{font-size:clamp(36px,5.5vw,62px);font-weight:600;margin:0 0 14px;line-height:1.02;color:#fff}
.hero h1 .foil{font-style:italic;color:#f4c97a}
.hero p{font-size:18px;color:#e4efe9;max-width:560px;margin:0 0 26px}
.hero .pillrow{display:flex;gap:10px;flex-wrap:wrap}
.pill{padding:9px 16px;border-radius:999px;border:1px solid rgba(255,255,255,.3);
  background:rgba(255,255,255,.1);font-size:14px;font-weight:600;color:#fff;transition:.15s}
.pill:hover{background:#fff;color:var(--teal-d)}

/* ---------- Section headers ---------- */
.sec-head{display:flex;align-items:baseline;gap:14px;margin:34px 0 18px}
.sec-head h2{font-size:27px;margin:0}
.sec-head .eyebrow{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--coral);font-weight:700}

/* ---------- Horizontal scroll rows (District-style) ---------- */
.row-head{display:flex;align-items:center;justify-content:space-between;margin:36px 0 16px}
.row-head h2{font-size:25px;margin:0}
.row-head a{font-size:14px;color:var(--teal);font-weight:600}
.hscroll{display:flex;gap:18px;overflow-x:auto;padding:4px 4px 16px;scroll-snap-type:x proximity;
  scrollbar-width:thin;scrollbar-color:var(--line2) transparent}
.hscroll::-webkit-scrollbar{height:8px}
.hscroll::-webkit-scrollbar-thumb{background:var(--line2);border-radius:99px}
.hscroll > *{scroll-snap-align:start;flex:0 0 auto}
.hcard{width:210px}

/* ---------- Grid ---------- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px}

/* ---------- Poster card ---------- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  overflow:hidden;display:flex;flex-direction:column;transition:.18s;box-shadow:0 1px 2px rgba(60,40,20,.04)}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--line2)}
.card-top{height:240px;display:flex;align-items:center;justify-content:center;font-size:76px;position:relative}
.hcard .card-top{height:270px}
.card-cat{position:absolute;top:12px;left:12px;font-size:11px;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;padding:5px 10px;border-radius:999px;background:rgba(255,255,255,.92);color:var(--ink)}
.rating-badge{position:absolute;top:12px;right:12px;display:flex;align-items:center;gap:4px;
  background:rgba(26,22,20,.85);color:#fff;font-size:12px;font-weight:700;padding:5px 9px;border-radius:999px}
.rating-badge .star{color:var(--gold)}
.card-body{padding:14px 15px 16px;display:flex;flex-direction:column;gap:6px;flex:1}
.card-body h3{margin:0;font-size:17px;line-height:1.22;font-weight:600}
.card-meta{font-size:13px;color:var(--mute);display:flex;flex-direction:column;gap:2px}
.card-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;padding-top:12px}
.price{font-family:'Fraunces';font-weight:600;font-size:18px;color:var(--teal)}
.seats-left{font-size:12px;color:var(--mute)}
.seats-low{color:var(--coral);font-weight:600}
.sold-out{color:var(--bad);font-weight:700}

/* ---------- Buttons ---------- */
.btn{display:inline-block;padding:11px 18px;border-radius:11px;font-weight:600;cursor:pointer;
  border:none;font-size:15px;transition:.15s;font-family:inherit;text-align:center}
.btn-primary{background:var(--coral);color:#fff}
.btn-primary:hover{background:var(--coral-d)}
.btn-gold{background:var(--teal);color:#fff}
.btn-gold:hover{background:var(--teal-d)}
.btn-block{display:block;width:100%}
.btn[disabled]{opacity:.4;cursor:not-allowed}

/* ---------- Detail pages ---------- */
.detail{display:grid;grid-template-columns:1.5fr 1fr;gap:32px;align-items:start}
.detail-hero{border-radius:20px;padding:36px;min-height:300px;display:flex;flex-direction:column;
  justify-content:flex-end;font-size:90px;color:#fff;position:relative;overflow:hidden}
.detail-hero .emoji{font-size:104px}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:26px;box-shadow:0 1px 2px rgba(60,40,20,.04)}
.panel h3{margin:0 0 16px;font-size:21px}
.kv{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--line);font-size:14px;gap:16px}
.kv:last-child{border-bottom:none}
.kv span:first-child{color:var(--mute)}
.kv span:last-child{text-align:right;font-weight:500}

/* movie info banner */
.movie-banner{display:flex;gap:26px;flex-wrap:wrap;align-items:flex-end;border-radius:22px;
  padding:38px;color:#fff;margin-bottom:24px;position:relative;overflow:hidden}
.movie-poster{width:150px;height:200px;border-radius:14px;background:rgba(255,255,255,.15);
  display:flex;align-items:center;justify-content:center;font-size:84px;flex:0 0 auto;border:1px solid rgba(255,255,255,.25)}
.movie-banner-info{flex:1;min-width:240px}
.movie-banner-info h1{margin:0 0 10px;font-size:clamp(28px,4vw,42px);color:#fff}
.tag-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.tag{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.28);color:#fff;
  font-size:13px;font-weight:600;padding:5px 12px;border-radius:999px}
.score-big{display:inline-flex;align-items:center;gap:8px;background:rgba(0,0,0,.28);
  padding:8px 16px;border-radius:12px;font-weight:700;font-size:17px}
.score-big .star{color:var(--gold);font-size:20px}
.score-big small{font-weight:500;opacity:.85;font-size:12px}

/* cast row */
.cast-row{display:flex;gap:18px;overflow-x:auto;padding:6px 2px 14px;scrollbar-width:thin}
.cast-card{width:130px;flex:0 0 auto;text-align:center}
.cast-avatar{width:96px;height:96px;border-radius:50%;margin:0 auto 10px;display:flex;align-items:center;
  justify-content:center;font-size:40px;background:linear-gradient(135deg,var(--surface2),#eaddc9);
  border:1px solid var(--line2);color:var(--teal-d);font-family:'Fraunces';font-weight:600}
.cast-card .actor{font-weight:600;font-size:14px;line-height:1.25}
.cast-card .role{font-size:13px;color:var(--mute);margin-top:2px}

/* ---------- Forms ---------- */
.form{max-width:440px;margin:0 auto}
.form.wide{max-width:560px}
label{display:block;font-size:13px;font-weight:600;color:var(--ink);margin:14px 0 6px}
input,select,textarea{width:100%;padding:12px 14px;border-radius:11px;border:1px solid var(--line2);
  background:var(--surface);color:var(--ink);font-size:15px;font-family:inherit}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(29,109,95,.12)}
.field-row{display:flex;gap:14px}
.field-row>div{flex:1}
.auth-card{max-width:420px;margin:30px auto;background:var(--surface);border:1px solid var(--line);
  border-radius:20px;padding:36px;box-shadow:var(--shadow)}
.auth-card h1{font-size:28px;margin:0 0 6px}
.auth-card .sub{color:var(--mute);margin:0 0 20px;font-size:14px}
.center-note{text-align:center;margin-top:16px;font-size:14px;color:var(--mute)}
.center-note a{color:var(--teal);font-weight:600}

/* ---------- Verify page ---------- */
.verify-result{max-width:520px;margin:20px auto;border-radius:20px;padding:36px;text-align:center;border:2px solid;background:var(--surface)}
.verify-ok{border-color:var(--ok);background:#eef8f1}
.verify-bad{border-color:var(--bad);background:#fcefec}
.verify-warn{border-color:var(--warn);background:#fbf3e2}
.verify-result .big{font-size:56px;margin-bottom:8px}
.verify-result h2{margin:0 0 6px}

/* ---------- Tables ---------- */
table{width:100%;border-collapse:collapse;font-size:14px}
th,td{text-align:left;padding:11px 12px;border-bottom:1px solid var(--line)}
th{color:var(--mute);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.04em}
tr:hover td{background:var(--surface2)}
.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:700}
.badge-ok{background:#e4f3ea;color:var(--ok)}
.badge-used{background:#fcefec;color:var(--bad)}
.badge-wait{background:#fbf3e2;color:var(--warn)}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:26px}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:22px;box-shadow:0 1px 2px rgba(60,40,20,.04)}
.stat .num{font-family:'Fraunces';font-weight:600;font-size:30px;color:var(--teal)}
.stat .lbl{color:var(--mute);font-size:13px;margin-top:2px}

/* ---------- Ticket (kept light-on-paper) ---------- */
.ticket{--notch:var(--paper);background:var(--surface);color:var(--ink);border-radius:18px;max-width:520px;
  margin:0 auto;position:relative;box-shadow:var(--shadow);overflow:hidden;border:1px solid var(--line)}
.ticket-head{padding:24px 28px;border-bottom:2px dashed var(--line2);position:relative}
.ticket-head .cat{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--coral);font-weight:700}
.ticket-head h2{margin:6px 0 2px;font-size:25px}
.ticket-head .venue{color:var(--mute);font-size:14px}
.ticket::before,.ticket::after{content:"";position:absolute;width:28px;height:28px;background:var(--paper);
  border:1px solid var(--line);border-radius:50%;left:50%;transform:translateX(-50%)}
.ticket-body{padding:26px 28px;display:grid;grid-template-columns:1fr auto;gap:22px;align-items:center}
.ticket-info dl{margin:0;display:grid;grid-template-columns:auto 1fr;gap:7px 16px;font-size:14px}
.ticket-info dt{color:var(--mute);font-weight:600}
.ticket-info dd{margin:0;font-weight:600}
.ticket-qr{text-align:center}
.ticket-qr img{width:150px;height:150px;border:6px solid #fff;border-radius:10px;box-shadow:0 2px 10px rgba(0,0,0,.1)}
.ticket-qr .ref{font-family:'Fraunces';font-weight:600;letter-spacing:.04em;margin-top:8px;font-size:14px}
.ticket-foot{padding:14px 28px;background:var(--surface2);font-size:12px;color:var(--mute);
  display:flex;justify-content:space-between;align-items:center;border-top:2px dashed var(--line2)}
.ticket-stamp{display:inline-block;padding:5px 12px;border:2px solid var(--ok);color:var(--ok);
  border-radius:8px;font-weight:700;text-transform:uppercase;font-size:12px;transform:rotate(-3deg)}
.ticket-stamp.used{border-color:var(--bad);color:var(--bad)}

/* ---------- Footer ---------- */
.footer{border-top:1px solid var(--line);margin-top:50px;background:var(--surface2)}
.footer-inner{max-width:1220px;margin:0 auto;padding:36px 24px;display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap}
.footer-cols{display:flex;flex-direction:column;gap:8px}
.footer-cols a{color:var(--mute);font-size:14px}
.footer-cols a:hover{color:var(--teal)}
.footer-bottom{text-align:center;padding:16px;font-size:13px;border-top:1px solid var(--line);color:var(--mute)}

/* ---------- Toolbar ---------- */
.toolbar{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-bottom:22px}
.toolbar form{display:flex;gap:10px;flex:1;min-width:260px}
.toolbar input{flex:1}
.chips{display:flex;gap:8px;flex-wrap:wrap}
.chip{padding:8px 15px;border-radius:999px;border:1px solid var(--line2);font-size:14px;font-weight:600;
  color:var(--mute);background:var(--surface);transition:.15s;cursor:pointer}
.chip.active,.chip:hover{border-color:var(--teal);color:var(--teal);background:#fff}

/* ---------- Geolocation banner ---------- */
.geo-banner{position:fixed;left:50%;bottom:22px;transform:translateX(-50%);z-index:200;display:flex;
  align-items:center;gap:18px;flex-wrap:wrap;background:var(--surface);border:1px solid var(--teal);
  border-radius:16px;padding:14px 20px;box-shadow:var(--shadow);max-width:92vw;animation:geoUp .35s ease}
.geo-banner strong{color:var(--teal)}
.geo-actions{display:flex;gap:8px}
.geo-yes,.geo-no{border:none;cursor:pointer;font-family:inherit;font-weight:600;font-size:14px;padding:8px 14px;border-radius:10px}
.geo-yes{background:var(--coral);color:#fff}
.geo-no{background:transparent;color:var(--mute);border:1px solid var(--line2)}
.geo-no:hover{color:var(--ink)}
@keyframes geoUp{from{opacity:0;transform:translate(-50%,12px)}to{opacity:1;transform:translate(-50%,0)}}

@media (max-width:820px){
  .detail{grid-template-columns:1fr}
  .nav-links{display:none}
  .hero{padding:40px 28px}
  .movie-banner{padding:26px}
}
@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}
:focus-visible{outline:2px solid var(--teal);outline-offset:2px}
