/* ============================================================
   BRAVO IBIZA — brand stylesheet
   Marigold #efb604 + ink black. Three directions via [data-variant].
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,500;12..96,600;12..96,700;12..96,800&family=Schibsted+Grotesk:wght@400;500;600;700&display=swap');

:root{
  --marigold:#efb604;
  --marigold-deep:#d39e00;
  --marigold-soft:#fff3cc;

  --ink:#0d0d0d;
  --ink-1:#141413;
  --ink-2:#1b1a18;
  --ink-3:#242220;
  --line:rgba(255,255,255,.10);
  --line-2:rgba(255,255,255,.16);

  --paper:#f4eee1;
  --paper-card:#fbf8f0;
  --paper-line:rgba(20,16,8,.12);

  --warm-white:#f5f1e8;
  --muted:#9b968a;
  --ink-text:#17140e;
  --ink-muted:#6c665a;

  --display:'Bricolage Grotesque',sans-serif;
  --sans:'Schibsted Grotesk',sans-serif;

  --maxw:1280px;
  --gutter:40px;
  --radius:18px;
  --radius-s:12px;

  /* themed (overridden per variant) */
  --bg:var(--ink);
  --surface:var(--ink-1);
  --surface-2:var(--ink-2);
  --text:var(--warm-white);
  --text-dim:var(--muted);
  --border:var(--line);
  --header-bg:var(--marigold);
  --header-text:#0d0d0d;
  --accent:var(--marigold);
  --on-accent:#0d0d0d;
}

/* ---------- DIRECTION A · MARIGOLD (yellow header, dark body) ---------- */
[data-variant="a"]{
  --bg:var(--ink); --surface:var(--ink-1); --surface-2:var(--ink-2);
  --text:var(--warm-white); --text-dim:var(--muted); --border:var(--line);
  --header-bg:var(--marigold); --header-text:#0d0d0d;
  --accent:var(--marigold); --on-accent:#0d0d0d;
}
/* ---------- DIRECTION B · MIDNIGHT (all dark, thin yellow accent) ---------- */
[data-variant="b"]{
  --bg:#070707; --surface:#0f0f0f; --surface-2:#151514;
  --text:#ece9e1; --text-dim:#7e7a70; --border:rgba(255,255,255,.08);
  --header-bg:rgba(7,7,7,.72); --header-text:#ece9e1;
  --accent:var(--marigold); --on-accent:#0d0d0d;
}
/* ---------- DIRECTION C · SOL (warm light, editorial) ---------- */
[data-variant="c"]{
  --bg:var(--paper); --surface:var(--paper-card); --surface-2:#fffdf7;
  --text:var(--ink-text); --text-dim:var(--ink-muted); --border:var(--paper-line);
  --header-bg:#0d0d0d; --header-text:var(--marigold);
  --accent:var(--marigold); --on-accent:#0d0d0d;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}
.eyebrow{
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;
  color:var(--accent);
}
[data-variant="a"] .eyebrow, [data-variant="b"] .eyebrow{color:var(--marigold)}

/* ===================== HEADER ===================== */
.site-header{
  position:sticky;top:0;z-index:40;
  background:var(--header-bg);
  color:var(--header-text);
  border-bottom:1px solid transparent;
  backdrop-filter:blur(12px);
  transition:background .3s;
}
[data-variant="b"] .site-header{border-bottom:1px solid var(--border)}
[data-variant="c"] .site-header{border-bottom:1px solid #0d0d0d}
.header-inner{
  max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter);
  height:76px;display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.brand{display:flex;align-items:center;height:100%}
.brand img{height:44px;width:auto}
.nav{display:none}
.nav a{
  font-size:14.5px;font-weight:600;letter-spacing:.01em;opacity:.85;
  position:relative;padding:4px 0;white-space:nowrap;
}
.nav a:hover{opacity:1}
.nav a::after{
  content:'';position:absolute;left:0;right:100%;bottom:-2px;height:2px;
  background:currentColor;transition:right .25s;
}
.nav a:hover::after{right:0}
.header-cta{display:flex;align-items:center;gap:16px}
.lang-dd{position:relative}
.lang-toggle{
  display:flex;align-items:center;gap:6px;font-size:13.5px;font-weight:700;letter-spacing:.04em;
  padding:8px 12px;border-radius:999px;border:1.5px solid currentColor;line-height:1;
  opacity:.85;transition:opacity .15s,background .15s;
}
.lang-toggle:hover{opacity:1}
.lang-caret{font-size:10px;transition:transform .2s}
.lang-dd.open .lang-caret{transform:rotate(180deg)}
.lang-menu{
  position:absolute;top:calc(100% + 10px);right:0;min-width:160px;
  background:var(--ink-1);border:1px solid var(--line-2);border-radius:14px;
  padding:6px;display:none;flex-direction:column;gap:2px;z-index:60;
  box-shadow:0 18px 40px rgba(0,0,0,.4);
}
[data-variant="c"] .lang-menu{background:#fffdf7;border-color:var(--paper-line)}
.lang-dd.open .lang-menu{display:flex}
.lang-opt{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  font-size:14px;font-weight:600;color:var(--warm-white);text-align:left;
  padding:10px 12px;border-radius:9px;transition:background .15s;white-space:nowrap;
}
[data-variant="c"] .lang-opt{color:var(--ink-text)}
.lang-opt:hover{background:color-mix(in srgb, currentColor 10%, transparent)}
.lang-opt.active{color:var(--marigold)}
.lang-opt.active::after{content:'✓';font-size:13px}
.btn-ghost-head{
  font-size:14px;font-weight:600;padding:10px 18px;border-radius:999px;
  border:1.5px solid currentColor;
}
.btn-ghost-head:hover{background:currentColor}
[data-variant="a"] .btn-ghost-head:hover{color:var(--marigold)}
[data-variant="b"] .btn-ghost-head:hover{color:#070707}
[data-variant="c"] .btn-ghost-head:hover{color:#0d0d0d}
.menu-toggle{display:block;font-size:24px;line-height:1;cursor:pointer}

/* ---------- slide-in drawer menu ---------- */
.drawer-root{position:fixed;inset:0;z-index:90;pointer-events:none}
.drawer-backdrop{position:absolute;inset:0;background:rgba(5,5,5,.6);backdrop-filter:blur(3px);opacity:0;transition:opacity .25s}
.drawer{
  position:absolute;top:0;right:0;bottom:0;width:min(340px,86vw);
  background:var(--ink-1);border-left:1px solid var(--line-2);
  padding:84px 30px 30px;display:flex;flex-direction:column;gap:4px;
  transform:translateX(100%);transition:transform .3s cubic-bezier(.25,.9,.3,1);
}
[data-variant="c"] .drawer{background:#fffdf7;border-color:var(--paper-line)}
.drawer-root.open{pointer-events:auto}
.drawer-root.open .drawer-backdrop{opacity:1}
.drawer-root.open .drawer{transform:translateX(0)}
.drawer-close{position:absolute;top:20px;right:22px;width:40px;height:40px;border-radius:50%;display:grid;place-items:center;font-size:17px;background:rgba(255,255,255,.07);color:var(--warm-white)}
.drawer-close:hover{background:rgba(255,255,255,.16)}
[data-variant="c"] .drawer-close{background:rgba(20,16,8,.07);color:var(--ink-text)}
.drawer-link{
  font-family:var(--display);font-size:21px;font-weight:700;letter-spacing:-.01em;
  color:var(--warm-white);padding:13px 2px;line-height:1.1;display:flex;align-items:baseline;gap:10px;
  border-bottom:1px solid var(--line);transition:color .15s,padding-left .2s;
}
[data-variant="c"] .drawer-link{color:var(--ink-text);border-color:var(--paper-line)}
.drawer-link:hover{color:var(--marigold);padding-left:8px}
.drawer-feature{color:var(--marigold)}
.drawer-soon{cursor:default;color:var(--text-dim)}
.drawer-soon:hover{color:var(--text-dim);padding-left:2px}
.drawer-soon small{font-family:var(--sans);font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:600}
.drawer-sep{flex:1}
.drawer-link.drawer-minor{font-family:var(--sans);font-size:15px;font-weight:600;border-bottom:none;padding:8px 2px}

/* ===================== HERO ===================== */
.hero{position:relative;isolation:isolate;overflow:hidden}
.hero-media{position:absolute;inset:0;z-index:-2;background:#0d0d0d url(assets/hero.jpg) center 62%/cover no-repeat}
.hero-media image-slot{width:100%;height:100%}
.svc-media{position:absolute;inset:0;z-index:-2}
.hero-scrim{
  position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(8,8,8,.35) 0%,rgba(8,8,8,.55) 45%,rgba(8,8,8,.9) 100%);
}
[data-variant="c"] .hero-scrim{
  background:linear-gradient(180deg,rgba(244,238,225,.1) 0%,rgba(244,238,225,.55) 60%,var(--paper) 100%);
}
.hero-inner{
  max-width:var(--maxw);margin:0 auto;padding:140px var(--gutter) 96px;
  min-height:78vh;display:flex;flex-direction:column;justify-content:flex-end;
}
.hero h1{
  font-family:var(--display);font-weight:700;
  font-size:clamp(54px,8.5vw,116px);line-height:.95;letter-spacing:-.02em;
  text-wrap:balance;max-width:14ch;
  color:#fff;
}
[data-variant="c"] .hero h1{color:var(--ink-text)}
.hero h1 em{font-style:normal;color:var(--marigold)}
.hero-sub{
  margin-top:26px;max-width:46ch;font-size:clamp(16px,1.5vw,20px);
  color:rgba(255,255,255,.82);font-weight:400;
}
[data-variant="c"] .hero-sub{color:var(--ink-muted)}
.hero-sign{color:var(--marigold);font-weight:700}
.hero-actions{margin-top:38px;display:flex;flex-wrap:wrap;gap:14px}

/* hero date-entry panel (Spotlight-style quick date select) */
.hero-datepanel{
  margin-top:38px;max-width:620px;padding:24px;border-radius:20px;
  background:rgba(10,10,12,.5);border:1px solid rgba(255,255,255,.16);
  backdrop-filter:blur(12px);
}
[data-variant="c"] .hero-datepanel{background:rgba(255,253,247,.62);border-color:rgba(20,16,8,.14)}
.hdp-quick{display:flex;flex-wrap:wrap;gap:12px}
.hdp-quick .btn{flex:1;min-width:200px;justify-content:center}
.hdp-div{display:flex;align-items:center;gap:14px;margin:18px 0;white-space:nowrap;
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;color:rgba(255,255,255,.6)}
[data-variant="c"] .hdp-div{color:var(--ink-muted)}
.hdp-div::before,.hdp-div::after{content:'';height:1px;flex:1;background:rgba(255,255,255,.18)}
[data-variant="c"] .hdp-div::before,[data-variant="c"] .hdp-div::after{background:rgba(20,16,8,.14)}
.hdp-weeks{display:flex;flex-wrap:wrap;gap:9px}
.hdp-week{
  font-size:13.5px;font-weight:600;padding:10px 16px;border-radius:999px;white-space:nowrap;
  border:1.5px solid rgba(255,255,255,.3);color:#fff;background:transparent;transition:all .18s;
}
.hdp-week:hover{background:#fff;color:#0d0d0d;border-color:#fff;transform:translateY(-1px)}
[data-variant="c"] .hdp-week{border-color:var(--ink-text);color:var(--ink-text)}
[data-variant="c"] .hdp-week:hover{background:var(--ink-text);color:var(--paper)}
.hdp-services{display:inline-block;margin-top:18px;font-size:14.5px;font-weight:600;
  color:#fff;opacity:.82;border-bottom:1px solid currentColor;padding-bottom:1px}
.hdp-services:hover{opacity:1}
[data-variant="c"] .hdp-services{color:var(--ink-text)}
.hero-tags{
  margin-top:46px;display:flex;flex-wrap:wrap;gap:10px;
}
.tag{
  font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;font-weight:600;
  padding:8px 16px;border-radius:999px;border:1px solid rgba(255,255,255,.28);
  color:rgba(255,255,255,.9);white-space:nowrap;
}
[data-variant="c"] .tag{border-color:var(--paper-line);color:var(--ink-text)}

/* buttons */
.btn{
  display:inline-flex;align-items:center;gap:10px;white-space:nowrap;
  font-size:15px;font-weight:600;letter-spacing:.01em;
  padding:15px 26px;border-radius:999px;transition:transform .15s,background .2s,color .2s;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--marigold);color:#0d0d0d}
.btn-primary:hover{background:#ffce2e}
.btn-outline{border:1.5px solid rgba(255,255,255,.5);color:#fff}
.btn-outline:hover{border-color:#fff;background:rgba(255,255,255,.08)}
[data-variant="c"] .btn-outline{border-color:var(--ink-text);color:var(--ink-text)}
[data-variant="c"] .btn-outline:hover{background:rgba(20,16,8,.06)}

/* ===================== SECTION HEADINGS ===================== */
.section{padding:110px 0}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;margin-bottom:54px}
.section-head h2{
  font-family:var(--display);font-weight:700;
  font-size:clamp(34px,4.4vw,60px);line-height:1;letter-spacing:-.02em;
  text-wrap:balance;
}
.section-head .lead{max-width:40ch;color:var(--text-dim);font-size:17px;margin-top:14px}

/* ===================== SERVICES ===================== */
.services-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:22px;
}
.svc{
  position:relative;border-radius:var(--radius);overflow:hidden;
  background:var(--surface);border:1px solid var(--border);
  min-height:300px;display:flex;flex-direction:column;justify-content:flex-end;
  isolation:isolate;text-decoration:none;
  transition:transform .3s ease, border-color .3s;
}
.svc:hover{transform:translateY(-4px);border-color:var(--accent)}
.svc-media{position:absolute;inset:0;z-index:-2}
.svc-media image-slot{width:100%;height:100%}

/* feature card: guestlist leads, 5-card layout */
.svc[data-service="guestlist"]{grid-column:1 / -1;grid-row:auto;min-height:440px}
.svc[data-service="guestlist"] h3{font-size:38px}
.svc[data-service="guestlist"] p{font-size:16.5px;max-width:40ch}
@media(max-width:980px){
  .svc[data-service="guestlist"]{grid-column:1 / -1;grid-row:auto;min-height:380px}
}
@media(max-width:680px){
  .svc[data-service="guestlist"]{grid-column:span 1;min-height:340px}
}

/* placeholder labels (hidden once user drops an image) */
.hero-ph-label,.svc-ph-label{
  position:absolute;z-index:1;font-family:ui-monospace,'SF Mono',Menlo,monospace;
  font-size:11px;letter-spacing:.02em;line-height:1.3;color:rgba(255,255,255,.85);
  background:rgba(8,8,8,.42);border:1px solid rgba(255,255,255,.2);
  padding:6px 10px;border-radius:8px;pointer-events:none;backdrop-filter:blur(3px);max-width:80%;
}
.hero-ph-label{bottom:26px;right:26px}
.svc-ph-label{top:14px;left:14px}
image-slot[data-filled] ~ .hero-ph-label,
image-slot[data-filled] ~ .svc-ph-label{display:none}

/* placeholder scene imagery as media background — shows even before a user drop;
   a dropped image in the slot covers it. */
.svc[data-service="guestlist"] .svc-media{background:#150b10 url(assets/guestlist.jpg) center/cover no-repeat}
.svc[data-service="tickets"] .svc-media{background:#0a0a10 url(assets/tickets.jpg) center/cover no-repeat}
.svc[data-service="yacht"] .svc-media{background:#1d4651 url(assets/yacht.jpg) center/cover no-repeat}
.svc[data-service="table"] .svc-media{background:#15110a url(assets/vip-tables.jpg) center/cover no-repeat}
.svc[data-service="transport"] .svc-media{background:#0a0a0a url(assets/transport.jpg) center/cover no-repeat}
.svc[data-service="villa"] .svc-media{background:#5a3f31 url(assets/villa.jpg) center/cover no-repeat}
.svc-scrim{position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(8,8,8,0) 12%,rgba(8,8,8,.5) 48%,rgba(8,8,8,.92) 100%);}
.svc-body{padding:26px;color:#fff;text-shadow:0 1px 16px rgba(0,0,0,.45)}
.svc-num{font-size:12px;letter-spacing:.2em;font-weight:600;color:var(--marigold);text-transform:uppercase}
.svc h3{font-family:var(--display);font-size:27px;font-weight:700;margin-top:8px;line-height:1.05}
.svc p{font-size:14.5px;color:rgba(255,255,255,.78);margin-top:8px;max-width:30ch}
.svc-cta{margin-top:16px;display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:14px;color:var(--marigold);white-space:nowrap}
.svc-arrow{transition:transform .25s}
.svc:hover .svc-arrow{transform:translateX(5px)}
.svc-soon{cursor:default}
.svc-soon:hover{transform:none;border-color:var(--border)}
.svc-cta-soon{color:var(--text-dim);font-weight:600;font-size:14px;display:inline-flex;align-items:center;gap:8px}
.svc-cta-soon::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--text-dim)}

/* ===================== CALENDAR ===================== */
.cal-filters{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}
.cal-filter-row{display:flex;gap:16px;align-items:flex-start}
.cal-filter-label{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-dim);font-weight:700;padding-top:11px;width:54px;flex:none}
.chip-row{display:flex;flex-wrap:wrap;gap:9px;flex:1;min-width:0}
.cal-count{font-size:13px;letter-spacing:.04em;color:var(--text-dim);font-weight:600;margin-bottom:24px}
.filter-chip{
  display:inline-flex;align-items:center;gap:8px;
  font-size:14px;font-weight:600;padding:10px 16px;border-radius:999px;
  border:1px solid var(--border);color:var(--text-dim);background:transparent;
  transition:all .2s;white-space:nowrap;
}
.filter-chip:hover{color:var(--text);border-color:var(--text-dim)}
.filter-chip.active{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}
.chip-count{
  font-size:11px;font-weight:700;min-width:19px;height:19px;padding:0 5px;border-radius:999px;
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--border);color:var(--text-dim);
}
.filter-chip.active .chip-count{background:rgba(13,13,13,.18);color:rgba(13,13,13,.8)}

.cal-list{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px;
}
.cal-empty{color:var(--text-dim);padding:30px 0;font-size:16px}
.evt-card{
  display:flex;flex-direction:column;
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:22px 22px 20px;transition:transform .25s,border-color .25s,box-shadow .25s;
}
.evt-card:hover{transform:translateY(-3px);border-color:var(--accent)}
.ec-head{display:flex;align-items:center;justify-content:space-between;gap:12px}
.ec-date{font-size:13px;font-weight:600;color:var(--text);letter-spacing:.02em;text-transform:uppercase;white-space:nowrap}
.ec-date b{color:var(--accent);font-weight:700}
[data-variant="c"] .ec-date b{color:var(--marigold-deep)}
.ec-genre{
  font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:600;color:var(--text-dim);
  padding:5px 10px;border-radius:999px;border:1px solid var(--border);white-space:nowrap;
}
.ec-club{
  font-family:var(--display);font-size:28px;font-weight:700;line-height:1;letter-spacing:-.01em;
  margin-top:16px;display:flex;align-items:center;gap:10px;
}
.ec-club .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex:none}
.ec-night{font-size:15.5px;font-weight:600;color:var(--text);margin-top:11px}
.ec-area{font-size:13.5px;color:var(--text-dim);margin-top:5px;line-height:1.45;text-wrap:pretty}
.ec-actions{display:flex;gap:9px;margin-top:auto;padding-top:20px}
.ec-actions .act{flex:1;text-align:center}
.act{
  font-size:13.5px;font-weight:600;padding:11px 14px;border-radius:999px;
  border:1.5px solid var(--border);color:var(--text);transition:all .18s;white-space:nowrap;
}
.act:hover{border-color:var(--text);transform:translateY(-1px)}
.act.act-primary{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}
.act.act-primary:hover{background:#ffce2e;border-color:#ffce2e}
.act.soldout{opacity:.4;pointer-events:none;text-decoration:line-through}

/* ===================== STRIP / CTA BAND ===================== */
.band{background:var(--marigold);color:#0d0d0d}
.band .wrap{padding:84px var(--gutter);display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap}
.band h2{font-family:var(--display);font-size:clamp(32px,4vw,54px);font-weight:700;letter-spacing:-.02em;line-height:1;max-width:18ch}
.band p{margin-top:14px;font-size:17px;max-width:44ch;color:rgba(13,13,13,.78)}
.btn-dark{background:#0d0d0d;color:var(--marigold);padding:16px 30px;border-radius:999px;font-weight:600;font-size:15px;display:inline-flex;gap:10px;align-items:center}
.btn-dark:hover{background:#000}

/* ===================== FOOTER ===================== */
.site-footer{background:var(--ink);color:var(--warm-white);padding:80px 0 40px;border-top:1px solid var(--line)}
[data-variant="c"] .site-footer{background:#0d0d0d}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-bottom:54px;border-bottom:1px solid var(--line)}
.footer-brand img{height:34px;margin-bottom:20px}
.footer-brand p{color:var(--muted);font-size:14.5px;max-width:32ch}
.footer-socials{display:flex;gap:12px;margin-top:22px}
.social-ig{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;border:1px solid var(--line);color:var(--warm-white);transition:border-color .2s,color .2s,transform .2s}
.social-ig:hover{border-color:var(--marigold);color:var(--marigold);transform:translateY(-2px)}
.foot-col h4{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--marigold);font-weight:700;margin-bottom:18px}
.foot-col a,.foot-col p{display:block;color:var(--muted);font-size:14.5px;margin-bottom:11px}
.foot-col a:hover{color:var(--warm-white)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;padding-top:28px;flex-wrap:wrap}
.footer-bottom p{color:var(--muted);font-size:13px}
.footer-bottom .legal{display:flex;gap:24px}
.footer-bottom a{color:var(--muted);font-size:13px}
.footer-bottom a:hover{color:var(--marigold)}

/* ===================== MODALS ===================== */
.modal-root{position:fixed;inset:0;z-index:100;display:none}
.modal-root.open{display:block}
.modal-backdrop{position:absolute;inset:0;background:rgba(5,5,5,.72);backdrop-filter:blur(4px);opacity:1;animation:fade .25s ease both}
.modal-card{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:min(560px,calc(100vw - 36px));max-height:calc(100vh - 48px);overflow-y:auto;
  background:var(--ink-1);color:var(--warm-white);
  border:1px solid var(--line-2);border-radius:22px;
  padding:34px;opacity:1;animation:pop .28s cubic-bezier(.2,.9,.3,1.2) both;
}
[data-variant="c"] .modal-card{background:#fffdf7;color:var(--ink-text);border-color:var(--paper-line)}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes pop{from{transform:translate(-50%,-46%) scale(.96)}to{transform:translate(-50%,-50%) scale(1)}}
.modal-close{position:absolute;top:18px;right:18px;width:38px;height:38px;border-radius:50%;display:grid;place-items:center;font-size:18px;background:rgba(255,255,255,.08);transition:background .2s}
.modal-close:hover{background:rgba(255,255,255,.18)}
[data-variant="c"] .modal-close{background:rgba(20,16,8,.07)}
[data-variant="c"] .modal-close:hover{background:rgba(20,16,8,.14)}
.modal-eyebrow{font-size:12px;letter-spacing:.2em;text-transform:uppercase;font-weight:700;color:var(--marigold)}
.modal-card h3{font-family:var(--display);font-size:30px;font-weight:700;line-height:1.05;margin-top:10px;letter-spacing:-.01em}
.modal-context{display:flex;gap:14px;align-items:center;margin-top:16px;padding:14px 16px;border-radius:14px;background:rgba(239,182,4,.10);border:1px solid rgba(239,182,4,.28)}
.modal-context .mc-date{font-family:var(--display);font-weight:700;font-size:22px;color:var(--marigold);line-height:1;text-align:center}
.modal-context .mc-date small{display:block;font-size:11px;letter-spacing:.12em;font-family:var(--sans);font-weight:600;color:var(--text-dim);margin-top:4px}
.modal-context .mc-info b{font-size:16px}
.modal-context .mc-info span{display:block;color:var(--text-dim);font-size:13.5px;margin-top:2px}

.field{margin-top:18px}
.field label{display:block;font-size:13px;font-weight:600;margin-bottom:8px;letter-spacing:.01em}
.field label .opt{color:var(--text-dim);font-weight:400}
.field input,.field select,.field textarea{
  width:100%;padding:13px 15px;border-radius:12px;font-family:inherit;font-size:15px;
  background:rgba(255,255,255,.05);border:1px solid var(--line-2);color:inherit;transition:border .2s;
}
[data-variant="c"] .field input,[data-variant="c"] .field select,[data-variant="c"] .field textarea{background:#fff;border-color:var(--paper-line)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--marigold)}
.field input[type="date"]{cursor:pointer}
.field input[type="date"]::-webkit-calendar-picker-indicator{
  cursor:pointer;opacity:.95;transform:scale(1.25);
  filter:invert(76%) sepia(61%) saturate(1300%) hue-rotate(2deg) brightness(1.05);
}
[data-variant="c"] .field input[type="date"]::-webkit-calendar-picker-indicator{filter:none}
.field textarea{resize:vertical;min-height:80px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field input::placeholder,.field textarea::placeholder{color:var(--text-dim)}
.check-field{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:600;cursor:pointer}
.check-field input{width:18px;height:18px;accent-color:var(--marigold);cursor:pointer}
.club-chips{display:flex;flex-wrap:wrap;gap:9px}
.club-chip{display:inline-flex;align-items:center;font-size:14px;font-weight:600;padding:10px 16px;border-radius:999px;border:1.5px solid var(--line-2);cursor:pointer;transition:all .15s;user-select:none}
[data-variant="c"] .club-chip{border-color:var(--paper-line)}
.club-chip input{position:absolute;opacity:0;pointer-events:none}
.club-chip:has(input:checked){background:var(--marigold);color:#0d0d0d;border-color:var(--marigold)}
.club-chip:has(input:disabled){opacity:.35;cursor:not-allowed}
.club-chip:hover{border-color:var(--marigold)}
.modal-card .btn{width:100%;justify-content:center;margin-top:26px}

/* ticket tiers */
.tier{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 18px;border-radius:14px;border:1.5px solid var(--line-2);margin-top:12px;cursor:pointer;transition:border .2s,background .2s}
[data-variant="c"] .tier{border-color:var(--paper-line)}
.tier:hover{border-color:var(--marigold)}
.tier.sel{border-color:var(--marigold);background:rgba(239,182,4,.08)}
.tier-name b{font-size:16px}
.tier-name span{display:block;color:var(--text-dim);font-size:13px;margin-top:3px}
.tier-price{font-family:var(--display);font-weight:700;font-size:22px;white-space:nowrap}
.qty{display:flex;align-items:center;gap:0;margin-top:6px;border:1.5px solid var(--line-2);border-radius:999px;overflow:hidden;width:max-content}
.qty button{width:42px;height:42px;font-size:20px;font-weight:600;background:rgba(255,255,255,.04)}
.qty button:hover{background:var(--marigold);color:#0d0d0d}
.qty span{min-width:46px;text-align:center;font-weight:700;font-size:17px}
.modal-total{display:flex;justify-content:space-between;align-items:baseline;margin-top:24px;padding-top:20px;border-top:1px solid var(--line)}
.modal-total .lbl{color:var(--text-dim);font-size:14px}
.modal-total .amt{font-family:var(--display);font-weight:700;font-size:32px}

/* success state */
.modal-success{text-align:center;padding:18px 6px}
.success-ring{width:74px;height:74px;border-radius:50%;background:var(--marigold);color:#0d0d0d;display:grid;place-items:center;margin:0 auto 22px;font-size:38px;animation:pop .4s cubic-bezier(.2,.9,.3,1.2)}
.modal-success h3{font-family:var(--display);font-size:28px;font-weight:700}
.modal-success p{color:var(--text-dim);margin-top:12px;font-size:15.5px;max-width:36ch;margin-inline:auto}

.hint{font-size:12.5px;color:var(--text-dim);margin-top:14px;text-align:center}

/* ===================== RESPONSIVE ===================== */
@media(max-width:980px){
  :root{--gutter:24px}
  .services-grid{grid-template-columns:1fr 1fr}
  .svc.tall{grid-row:auto;min-height:300px}
  .footer-top{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .cal-list{grid-template-columns:1fr}
  .section{padding:74px 0}
  .hero-inner{min-height:74vh;padding-top:120px}
  .services-grid{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .section-head{flex-direction:column;align-items:flex-start}
}
