/* ============================================================
   Estonian Juniors & Masters Open 2026
   Design system + styles
   Palette: squash-court charcoal, warm wood, YOLO orange,
   squash-ball yellow accents.
   ============================================================ */

:root {
  /* Type scale */
  --text-xs: clamp(0.75rem, 0.7rem + 0.25vw, 0.875rem);
  --text-sm: clamp(0.875rem, 0.8rem + 0.35vw, 1rem);
  --text-base: clamp(1rem, 0.95rem + 0.25vw, 1.125rem);
  --text-lg: clamp(1.125rem, 1rem + 0.75vw, 1.5rem);
  --text-xl: clamp(1.5rem, 1.2rem + 1.25vw, 2.25rem);
  --text-2xl: clamp(2rem, 1.2rem + 2.5vw, 3.5rem);
  --text-3xl: clamp(2.5rem, 1rem + 4vw, 5rem);
  --text-hero: clamp(3rem, 0.5rem + 7vw, 7rem);

  /* Spacing */
  --space-1: 0.25rem; --space-2: 0.5rem; --space-3: 0.75rem;
  --space-4: 1rem; --space-5: 1.25rem; --space-6: 1.5rem;
  --space-7: 1.75rem; --space-8: 2rem; --space-10: 2.5rem; --space-12: 3rem;
  --space-16: 4rem; --space-20: 5rem; --space-24: 6rem; --space-32: 8rem;

  --radius-sm: 0.375rem; --radius-md: 0.5rem; --radius-lg: 0.75rem;
  --radius-xl: 1rem; --radius-full: 9999px;
  --transition-interactive: 200ms cubic-bezier(0.16, 1, 0.3, 1);

  --content-narrow: 680px;
  --content-default: 1000px;
  --content-wide: 1040px;
  --gutter: clamp(2.5rem, 9vw, 9rem);

  --font-display: 'Clash Display', 'Arial Narrow', sans-serif;
  --font-body: 'General Sans', 'Helvetica Neue', sans-serif;
}

/* LIGHT MODE */
:root, [data-theme="light"] {
  --color-bg: #f6f5f2;
  --color-surface: #ffffff;
  --color-surface-2: #fbfaf8;
  --color-surface-offset: #efece6;
  --color-divider: #e2ded7;
  --color-border: #d6d1c8;

  --color-text: #1c1a17;
  --color-text-muted: #6c6760;
  --color-text-faint: #a7a299;
  --color-text-inverse: #fafafa;

  /* YOLO orange primary */
  --color-primary: #ee5a14;
  --color-primary-hover: #d24a0c;
  --color-primary-active: #b03c08;
  --color-primary-soft: #fce4d8;

  /* squash-ball yellow accent */
  --color-accent: #e3b505;
  --color-accent-soft: #f7ecc2;

  --color-ink: #18171a;        /* deep court charcoal */
  --color-ball-ring: transparent; /* squash-ball edge ring (light mode: none) */
  --color-wood: #6b4226;       /* warm wood */

  --shadow-sm: 0 1px 2px rgba(20,18,16,0.06);
  --shadow-md: 0 6px 18px rgba(20,18,16,0.10);
  --shadow-lg: 0 18px 44px rgba(20,18,16,0.16);
}

/* DARK MODE */
[data-theme="dark"] {
  --color-bg: #131214;
  --color-surface: #1b1a1d;
  --color-surface-2: #201f22;
  --color-surface-offset: #232225;
  --color-divider: #2c2b2e;
  --color-border: #38363a;

  --color-text: #ece9e4;
  --color-text-muted: #9a958d;
  --color-text-faint: #6a655e;
  --color-text-inverse: #18171a;

  --color-primary: #ff6a24;
  --color-primary-hover: #ff8347;
  --color-primary-active: #ff9b6b;
  --color-primary-soft: #3a2317;

  --color-accent: #f4c727;
  --color-accent-soft: #3b3413;

  --color-ink: #0e0d0f;
  --color-ball-ring: rgba(255,255,255,.28); /* squash-ball edge ring (dark mode) */
  --color-wood: #b07a4e;

  --shadow-sm: 0 1px 2px rgba(0,0,0,0.4);
  --shadow-md: 0 6px 18px rgba(0,0,0,0.5);
  --shadow-lg: 0 18px 44px rgba(0,0,0,0.6);
}

/* ---------- base ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;scroll-behavior:smooth;
  scroll-padding-top:5rem;
}
body{
  min-height:100dvh;line-height:1.6;font-family:var(--font-body);
  font-size:var(--text-base);color:var(--color-text);
  background:var(--color-bg);overflow-x:hidden;
}
img,picture,svg{display:block;max-width:100%;height:auto}
ul[role=list]{list-style:none}
a{color:inherit;text-decoration:none}
button{cursor:pointer;background:none;border:none;font:inherit;color:inherit}
h1,h2,h3,h4{text-wrap:balance;line-height:1.08;font-family:var(--font-display);font-weight:600}
p{text-wrap:pretty}
:focus-visible{outline:2px solid var(--color-primary);outline-offset:3px;border-radius:var(--radius-sm)}
::selection{background:var(--color-primary);color:#fff}
a,button,input,select,textarea{transition:color var(--transition-interactive),background var(--transition-interactive),border-color var(--transition-interactive),box-shadow var(--transition-interactive),transform var(--transition-interactive)}
@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ---------- layout helpers ---------- */
.wrap{width:min(var(--content-wide), 100% - var(--gutter) * 2);margin-inline:auto;padding-inline:0}
.section{padding-block:clamp(var(--space-16),9vw,var(--space-32))}
section[id]{scroll-margin-top:5.8rem}
.eyebrow{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--color-primary)}
.eyebrow::before{content:"";width:1.6rem;height:2px;background:var(--color-primary);border-radius:2px}
.section-title{font-size:var(--text-2xl);margin-block:var(--space-3) var(--space-5);max-width:18ch}
.lead{font-size:var(--text-lg);color:var(--color-text-muted);max-width:62ch}
.tag-tbd{display:inline-block;font-family:var(--font-body);font-size:.7em;font-weight:600;letter-spacing:.04em;color:var(--color-primary);background:var(--color-primary-soft);padding:.15em .5em;border-radius:var(--radius-full);vertical-align:middle}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:600;padding:.8rem 1.4rem;border-radius:var(--radius-full);white-space:nowrap}
.btn-primary{background:var(--color-primary);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--color-primary-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-disabled,.btn-disabled:hover{background:var(--color-surface-offset);color:var(--color-text-muted);box-shadow:none;transform:none;cursor:not-allowed}
.btn-ghost{border:1.5px solid var(--color-border);color:var(--color-text)}
.btn-ghost:hover{border-color:var(--color-primary);color:var(--color-primary)}
.btn-light{background:#fff;color:#18171a}
.btn-light:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}

/* ---------- header ---------- */
.header{position:sticky;top:0;z-index:60;background:color-mix(in srgb,var(--color-bg) 86%,transparent);backdrop-filter:blur(14px);border-bottom:1px solid transparent;transition:border-color .3s,box-shadow .3s}
.header.scrolled{border-color:var(--color-divider);box-shadow:var(--shadow-sm)}
.nav{display:flex;align-items:center;justify-content:space-between;height:4.6rem;gap:var(--space-6)}
.brand{display:flex;align-items:center;gap:var(--space-3);font-family:var(--font-display);font-weight:600;font-size:var(--text-base)}
.brand span{white-space:nowrap}
.brand svg{flex:none}
.brand b{color:var(--color-primary)}
.nav-links{display:flex;align-items:center;gap:var(--space-4)}
.nav-links a{font-size:var(--text-sm);font-weight:500;color:var(--color-text-muted);white-space:nowrap}
.nav-links a:hover,.nav-links a.active{color:var(--color-text)}
.nav-links a.active{font-weight:700}
.nav-right{display:flex;align-items:center;gap:var(--space-3)}
.theme-toggle{width:2.4rem;height:2.4rem;display:grid;place-items:center;border-radius:var(--radius-full);color:var(--color-text-muted)}
.theme-toggle:hover{background:var(--color-surface-offset);color:var(--color-text)}
.theme-toggle-label{display:none}
.burger{display:none;width:2.4rem;height:2.4rem;place-items:center;border-radius:var(--radius-md);color:var(--color-text)}
.nav-more{position:relative}
.nav-more summary{list-style:none;cursor:pointer;font-size:var(--text-sm);font-weight:500;color:var(--color-text-muted);white-space:nowrap}
.nav-more summary::after{content:"";display:inline-block;width:.42rem;height:.42rem;margin-left:.45rem;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:translateY(-.14rem) rotate(45deg)}
.nav-more[open] summary::after{transform:translateY(.08rem) rotate(225deg)}
.nav-more summary::-webkit-details-marker{display:none}
.nav-more summary:hover,.nav-more[open] summary,.nav-more:has(a.active) summary{color:var(--color-text)}
.nav-more-menu{position:absolute;right:0;top:calc(100% + .8rem);min-width:10rem;padding:var(--space-2);background:var(--color-surface);border:1px solid var(--color-divider);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:grid;gap:.1rem}
.nav-more-menu a{display:block;padding:.55rem .8rem;border-radius:var(--radius-sm)}
.nav-more-menu a:hover,.nav-more-menu a.active{background:var(--color-surface-offset);color:var(--color-text)}

/* mobile nav */
@media(max-width:920px){
  .nav-links{position:fixed;inset:4.6rem 0 auto 0;flex-direction:column;align-items:flex-start;gap:0;background:var(--color-surface);border-bottom:1px solid var(--color-divider);padding:var(--space-3) var(--space-6) var(--space-6);transform:translateY(-130%);transition:transform .35s cubic-bezier(.16,1,.3,1);box-shadow:var(--shadow-lg)}
  .nav-links.open{transform:translateY(0)}
  .nav-links a{width:100%;padding:var(--space-3) 0;font-size:var(--text-base);border-bottom:1px solid var(--color-divider)}
  .nav-links a.active{color:var(--color-primary)}
  .nav-more{width:100%;border-bottom:1px solid var(--color-divider)}
  .nav-more summary{padding:var(--space-3) 0;font-size:var(--text-base)}
  .nav-more-menu{position:static;box-shadow:none;border:0;background:transparent;padding:0 0 var(--space-2)}
  .nav-more-menu a{padding:var(--space-2) 0 var(--space-2) var(--space-4);border-bottom:0}
  .burger{display:grid}
  /* On mobile, Register + theme toggle move into the menu so the burger fits */
  .nav-right .btn-primary,
  .nav-right .theme-toggle{display:none}
  .nav-links .mobile-actions{display:flex;flex-direction:column;gap:var(--space-3);width:100%;padding-top:var(--space-4)}
  .nav-links .mobile-actions .btn-primary{display:inline-flex;justify-content:center;width:100%;color:#fff;border-bottom:0;padding:.85rem 1.4rem}
  .nav-links .mobile-actions .theme-toggle{display:inline-flex;align-items:center;justify-content:flex-start;gap:var(--space-2);width:100%;height:auto;padding:.75rem 0;border-radius:0}
  .nav-links .mobile-actions .theme-toggle-label{display:inline;font-size:var(--text-sm);font-weight:600}
}
.mobile-actions{display:none}

/* ---------- hero ---------- */
.hero{position:relative;min-height:92vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:-2}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 30%}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(12,11,13,.55) 0%,rgba(12,11,13,.35) 35%,rgba(12,11,13,.92) 100%)}
.hero-inner{width:min(var(--content-wide), 100% - var(--gutter) * 2);margin-inline:auto;padding:var(--space-6) 0 clamp(var(--space-12),7vw,var(--space-24))}
.hero-badge{display:inline-flex;align-items:center;gap:var(--space-2);background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);backdrop-filter:blur(6px);padding:.45rem .9rem;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;letter-spacing:.08em;text-transform:uppercase}
.hero h1{font-size:var(--text-hero);font-weight:600;letter-spacing:-.01em;margin-block:var(--space-5) var(--space-4);max-width:16ch}
.hero h1 .accent{color:var(--color-primary)}
.hero-meta{display:flex;flex-wrap:wrap;gap:var(--space-5);margin-bottom:var(--space-8);font-size:var(--text-base)}
.hero-meta .m{display:flex;align-items:center;gap:var(--space-2);font-weight:500}
.hero-meta svg{color:var(--color-primary)}
.hero-cta{display:flex;flex-wrap:wrap;gap:var(--space-3)}
.hero-proof{margin-top:var(--space-4);font-size:var(--text-sm);font-weight:600;color:rgba(255,255,255,.78)}
.scroll-hint{position:absolute;left:50%;bottom:var(--space-6);transform:translateX(-50%);font-size:var(--text-xs);letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.7);display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}
.scroll-hint span{width:1px;height:2.2rem;background:linear-gradient(rgba(255,255,255,.7),transparent)}
@media(max-width:560px){
  .hero{min-height:calc(100svh - 4.6rem);align-items:flex-end}
  .hero-inner{padding-bottom:var(--space-10)}
  .hero h1{max-width:9ch}
  .hero-badge{border-radius:var(--radius-xl);white-space:normal}
  .hero-meta{display:grid;gap:var(--space-4);margin-bottom:var(--space-6)}
  .hero-cta{flex-direction:column;align-items:flex-start}
  .hero-cta .btn{width:max-content;max-width:100%}
  .hero-proof{max-width:36ch}
  .scroll-hint{display:none}
}

/* ---------- countdown ---------- */
.countdown{display:flex;gap:var(--space-4);margin-bottom:var(--space-8)}
.cd-unit{text-align:center;min-width:3.6rem}
.cd-num{font-family:var(--font-display);font-size:var(--text-xl);font-weight:600;line-height:1;color:#fff}
.cd-lab{font-size:var(--text-xs);letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.65);margin-top:var(--space-1)}

/* ---------- facts strip ---------- */
.facts{background:var(--color-ink);color:#fff}
.facts .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-6);padding-block:var(--space-12)}
.fact h3{font-size:var(--text-xl);color:var(--color-primary);margin-bottom:var(--space-1)}
.fact p{font-size:var(--text-sm);color:rgba(255,255,255,.7)}
@media(max-width:760px){.facts .grid{grid-template-columns:repeat(2,1fr);gap:var(--space-8)}}

/* ---------- invitation ---------- */
.two-col{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(var(--space-8),5vw,var(--space-20));align-items:center}
@media(max-width:880px){.two-col{grid-template-columns:1fr;gap:var(--space-10)}}
.invite-card{background:var(--color-surface);border:1px solid var(--color-divider);border-radius:var(--radius-xl);padding:var(--space-8);box-shadow:var(--shadow-md)}
.invite-card h3{font-size:var(--text-lg);margin-bottom:var(--space-5)}
.kv{display:flex;justify-content:space-between;gap:var(--space-4);padding:var(--space-3) 0;border-bottom:1px solid var(--color-divider);font-size:var(--text-sm)}
.kv:last-child{border-bottom:0}
.kv .k{color:var(--color-text-muted)}
.kv .v{font-weight:600;text-align:right}
.prose p{margin-bottom:var(--space-4);color:var(--color-text-muted)}
.prose p.first{font-size:var(--text-lg);color:var(--color-text)}

/* ---------- why tallinn ---------- */
.why-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--space-5)}
.why-grid.compact{grid-template-columns:repeat(3,minmax(0,1fr))}
.why-card{background:var(--color-surface);border:1px solid var(--color-divider);border-radius:var(--radius-xl);padding:var(--space-7);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--space-3);transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}
.why-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--color-primary)}
.why-card .why-ic{font-size:1.9rem;line-height:1}
.why-card h3{font-family:var(--font-display);font-size:var(--text-lg);font-weight:600;color:var(--color-text)}
.why-card p{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.6}
.why-card.feature{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-active));border-color:transparent}
.why-card.feature h3,.why-card.feature p{color:#fff}
.why-card.feature p{color:rgba(255,255,255,.92)}
@media(max-width:1040px){.why-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:1040px){.why-grid.compact{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:560px){.why-grid{grid-template-columns:1fr}}
@media(max-width:560px){.why-grid.compact{grid-template-columns:1fr}}

/* ---------- categories ---------- */
.cat-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6)}
@media(max-width:760px){.cat-grid{grid-template-columns:1fr}}
.cat-card{position:relative;border-radius:var(--radius-xl);padding:var(--space-8);overflow:hidden;border:1px solid var(--color-divider);background:var(--color-surface)}
.cat-card.juniors{background:linear-gradient(160deg,var(--color-primary),var(--color-primary-active));color:#fff;border:none}
.cat-card.masters{background:linear-gradient(160deg,var(--color-ink),#2a282d);color:#fff;border:none}
.cat-card h3{font-size:var(--text-xl);margin-bottom:var(--space-2)}
.cat-card .cat-sub{font-size:var(--text-sm);opacity:.85;margin-bottom:var(--space-6)}
.chips{display:flex;flex-wrap:wrap;gap:var(--space-2)}
.chip{font-size:var(--text-sm);font-weight:600;padding:.45rem .8rem;border-radius:var(--radius-full);background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.22)}
.cat-note{margin-top:var(--space-6);font-size:var(--text-xs);opacity:.8;line-height:1.5}

/* ---------- schedule ---------- */
.days{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6)}
@media(max-width:760px){.days{grid-template-columns:1fr}}
.day{background:var(--color-surface);border:1px solid var(--color-divider);border-radius:var(--radius-xl);padding:var(--space-8);box-shadow:var(--shadow-sm)}
.day .dnum{font-family:var(--font-display);font-size:var(--text-2xl);color:var(--color-primary);line-height:1}
.day .ddate{font-size:var(--text-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-faint);margin-bottom:var(--space-5)}
.day h3{font-size:var(--text-lg);margin-bottom:var(--space-4)}
.day ul{list-style:none;display:flex;flex-direction:column;gap:var(--space-3)}
.day li{display:flex;gap:var(--space-3);font-size:var(--text-sm);color:var(--color-text-muted)}
.day li::before{content:"";flex:none;width:.5rem;height:.5rem;margin-top:.5rem;border-radius:50%;background:var(--color-accent)}
.note-bar{margin-top:var(--space-8);background:var(--color-accent-soft);border:1px solid color-mix(in srgb,var(--color-accent) 40%,transparent);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);font-size:var(--text-sm);display:flex;gap:var(--space-3);align-items:flex-start}
.note-bar svg{flex:none;color:var(--color-accent);margin-top:2px}

/* ---------- entry / register ---------- */
.entry{background:var(--color-ink);color:#fff}
.entry .lead{color:rgba(255,255,255,.72)}
.entry .section-title{color:#fff}
.entry .sub-h{font-size:var(--text-lg);font-family:var(--font-display);font-weight:600;margin-bottom:var(--space-5);color:#fff}

/* configurator layout */
.config{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,340px);gap:clamp(var(--space-6),3vw,var(--space-10));align-items:start;width:100%;max-width:100%;overflow:hidden}
.config>*{min-width:0;max-width:100%}
@media(max-width:980px){.config{grid-template-columns:minmax(0,1fr)}}
.cfg-group{margin-top:var(--space-8)}
.config-options>.cfg-group:first-child{margin-top:0}
.cfg-hint{font-size:var(--text-xs);color:rgba(255,255,255,.55);margin-top:var(--space-4);line-height:1.5}

/* package cards (selectable) */
.pkg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-5);align-items:stretch}
@media(max-width:760px){.pkg-grid{grid-template-columns:1fr}}
.pkg-card.selectable{position:relative;display:flex;flex-direction:column;text-align:left;background:rgba(255,255,255,.05);color:#fff;border:1.5px solid rgba(255,255,255,.14);border-radius:var(--radius-xl);padding:var(--space-6);cursor:pointer;transition:border-color .2s,background .2s,transform .2s;overflow:visible}
.pkg-card.selectable:hover{border-color:rgba(255,255,255,.4);transform:translateY(-2px)}
.pkg-card.selectable.selected{border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 14%,transparent)}
.pkg-card.featured{padding-top:var(--space-8)}
.pkg-flag{position:absolute;top:-0.7rem;left:var(--space-6);background:var(--color-primary);color:#fff;font-size:.62rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:.28rem .7rem;border-radius:var(--radius-full)}
.pkg-check{position:absolute;top:var(--space-5);right:var(--space-5);width:1.3rem;height:1.3rem;border-radius:50%;border:2px solid rgba(255,255,255,.35);transition:all .2s}
.pkg-card.selected .pkg-check{border-color:var(--color-primary);background:var(--color-primary)}
.pkg-card.selected .pkg-check::after{content:"";position:absolute;left:.34rem;top:.14rem;width:.32rem;height:.6rem;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}
.pkg-card.selectable h4{font-size:var(--text-lg);margin:0 0 var(--space-1);padding-right:2rem}
.pkg-card .pkg-sub{font-size:var(--text-sm);color:rgba(255,255,255,.65);margin-bottom:var(--space-5)}
.pkg-base{display:flex;flex-direction:column;padding-bottom:var(--space-5);margin-bottom:var(--space-5);border-bottom:1px solid rgba(255,255,255,.14)}
.pkg-base .amt{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:600;color:var(--color-accent);line-height:1.05}
.pkg-base .per{font-size:var(--text-xs);color:rgba(255,255,255,.6);font-weight:500}
.pkg-list{list-style:none;display:flex;flex-direction:column;gap:var(--space-2);margin:0}
.pkg-list li{position:relative;padding-left:1.4rem;font-size:var(--text-sm);line-height:1.45}
.pkg-list li::before{content:"";position:absolute;left:0;top:.45em;width:.5rem;height:.5rem;border-radius:50%;background:var(--color-accent)}
.pkg-list li.muted{color:rgba(255,255,255,.5)}
.pkg-list li.muted::before{background:rgba(255,255,255,.4)}
.mobile-selection-bar{display:none}
@media(max-width:980px){
  .mobile-selection-bar{position:sticky;top:5rem;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);margin-top:var(--space-5);padding:var(--space-4);background:color-mix(in srgb,var(--color-surface) 94%,transparent);color:var(--color-text);border:1px solid var(--color-divider);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}
  .mobile-selection-bar div{display:flex;flex-direction:column;gap:.1rem;min-width:0}
  .mobile-selection-bar span{font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .mobile-selection-bar small{font-size:var(--text-xs);color:var(--color-text-muted)}
  .mobile-selection-bar strong{font-family:var(--font-display);font-size:var(--text-xl);color:var(--color-primary);white-space:nowrap}
}

/* segmented control (nights) */
.seg{display:inline-flex;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);border-radius:var(--radius-full);padding:.3rem;gap:.3rem}
.seg-btn{display:flex;flex-direction:column;align-items:center;gap:.1rem;padding:.6rem 1.4rem;border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:600;color:rgba(255,255,255,.7);transition:all .2s}
.seg-btn small{font-size:.62rem;font-weight:500;opacity:.7}
.seg-btn.active{background:var(--color-primary);color:#fff}
.seg-btn:disabled{opacity:.35;cursor:not-allowed}

/* extras */
.extras{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}
@media(max-width:560px){.extras{grid-template-columns:1fr}}
.extra.toggle{display:flex;gap:var(--space-3);align-items:flex-start;background:rgba(255,255,255,.05);border:1.5px solid rgba(255,255,255,.14);border-radius:var(--radius-lg);padding:var(--space-4);cursor:pointer;transition:border-color .2s,background .2s}
.extra.toggle:hover{border-color:rgba(255,255,255,.35)}
.extra.toggle:has(input:checked){border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 12%,transparent)}
.extra.toggle input{margin-top:.2rem;width:1.1rem;height:1.1rem;accent-color:var(--color-primary);flex:none}
.extra .ex-name{display:block;font-weight:600;font-size:var(--text-sm)}
.extra .ex-price{display:block;font-family:var(--font-display);color:var(--color-accent);font-size:var(--text-base);font-weight:600;margin:.15rem 0}
.extra .ex-note{display:block;font-size:var(--text-xs);color:rgba(255,255,255,.6);line-height:1.45}
.extra.is-included{cursor:default;border-color:rgba(255,255,255,.10);background:rgba(255,255,255,.03)}
.extra.is-included:hover{border-color:rgba(255,255,255,.10)}
.extra.is-included .ex-price{color:rgba(255,255,255,.55);font-family:var(--font-body);font-size:var(--text-xs);font-weight:500}
.inc-badge{flex:none;display:inline-flex;align-items:center;height:1.3rem;padding:0 .55rem;border-radius:var(--radius-full);background:color-mix(in srgb,var(--color-primary) 22%,transparent);color:var(--color-accent);font-size:.66rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;margin-top:.15rem}

/* stepper */
.stepper-row{margin-top:var(--space-4)}
.stepper{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);background:rgba(255,255,255,.05);border:1.5px solid rgba(255,255,255,.14);border-radius:var(--radius-lg);padding:var(--space-4)}
.st-label{font-size:var(--text-sm);font-weight:600;display:flex;flex-direction:column;gap:.15rem}
.st-label small{font-size:var(--text-xs);font-weight:500;color:rgba(255,255,255,.6)}
.st-ctrl{display:flex;align-items:center;gap:var(--space-3);flex:none}
.st-ctrl button{width:2.1rem;height:2.1rem;border-radius:50%;background:rgba(255,255,255,.1);color:#fff;font-size:1.2rem;line-height:1;display:grid;place-items:center;transition:background .2s}
.st-ctrl button:hover{background:var(--color-primary)}
.st-ctrl span{min-width:1.4rem;text-align:center;font-weight:600;font-family:var(--font-display)}

/* summary panel */
.config-summary{position:sticky;top:5.6rem;width:100%;max-width:100%;min-width:0;box-sizing:border-box}
@media(max-width:980px){.config-summary{position:static}}
.cs-inner{background:var(--color-surface);color:var(--color-text);border-radius:var(--radius-xl);padding:var(--space-7);box-shadow:var(--shadow-lg);width:100%;max-width:100%;box-sizing:border-box;overflow:hidden}
.cs-inner .sub-h{color:var(--color-text);margin-bottom:var(--space-4)}
.cs-lines{list-style:none;display:flex;flex-direction:column;gap:var(--space-3);margin:0}
.cs-lines li{display:flex;justify-content:space-between;gap:var(--space-4);font-size:var(--text-sm)}
.cs-lines li .l{color:var(--color-text-muted);min-width:0}
.cs-lines li .v{font-weight:600;flex:none;white-space:nowrap;overflow-wrap:anywhere}
.cs-inner .btn-primary{white-space:normal}
.cs-inner .tag-tbd{flex:none}
.cs-total{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-1);padding-top:var(--space-4);border-top:1px solid var(--color-divider);margin-top:var(--space-4);margin-bottom:var(--space-5)}
.cs-total span:first-child{font-size:var(--text-sm);color:var(--color-text-muted)}
.cs-amt{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:700;color:var(--color-primary);line-height:1}
.cs-inner .btn-primary{width:100%}
.cs-note{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:var(--space-4);line-height:1.5}

/* payment */
.pay-wrap{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:var(--space-6);align-items:start;width:100%;max-width:100%;overflow:hidden}
.pay-wrap>*{min-width:0;max-width:100%}
@media(max-width:880px){.pay-wrap{grid-template-columns:1fr}}
.pay-card{background:var(--color-surface);color:var(--color-text);border-radius:var(--radius-xl);padding:var(--space-7);box-shadow:var(--shadow-md);width:100%;max-width:100%;box-sizing:border-box;overflow:hidden}
.pay-intro{font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-5);line-height:1.55}
.pay-rows{display:flex;flex-direction:column;gap:var(--space-3)}
.pr{display:flex;justify-content:space-between;gap:var(--space-4);font-size:var(--text-sm);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-divider)}
.pr:last-child{border-bottom:none}
.pr .pk{color:var(--color-text-muted);flex:none}
.pr .pv{font-weight:600;text-align:right;word-break:break-word;overflow-wrap:anywhere;min-width:0}
.entry .note-bar{color:var(--color-text)}

/* ---------- venue ---------- */
.venue-media{border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-lg);position:relative}
.venue-media img{width:100%;height:100%;object-fit:cover;aspect-ratio:3/2}
.venue-list{display:flex;flex-direction:column;gap:var(--space-4);margin-top:var(--space-6)}
.venue-list .row{display:flex;gap:var(--space-3);align-items:flex-start;font-size:var(--text-sm)}
.venue-list svg{flex:none;color:var(--color-primary);margin-top:2px}
.venue-list .row b{display:block}
.venue-links{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-top:var(--space-6)}
.vlink{display:inline-flex;align-items:center;gap:var(--space-2);padding:.55rem 1rem;border:1px solid var(--color-divider);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:600;color:var(--color-text);background:var(--color-surface);transition:border-color .2s ease,color .2s ease,transform .2s ease}
.vlink svg{color:var(--color-primary)}
.vlink:hover{border-color:var(--color-primary);color:var(--color-primary);transform:translateY(-2px)}
.venue-links-note{margin-top:var(--space-3);font-size:var(--text-xs);color:var(--color-text-muted)}
.map-embed{margin-top:var(--space-6);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--color-divider)}
.map-embed iframe{display:block;width:100%;height:300px;border:0;filter:grayscale(.2)}

/* ---------- travel ---------- */
.travel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6)}
@media(max-width:880px){.travel-grid{grid-template-columns:1fr}}
.travel-card{background:var(--color-surface);border:1px solid var(--color-divider);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-sm)}
.travel-card .ph{aspect-ratio:16/10;overflow:hidden}
.travel-card .ph img{width:100%;height:100%;object-fit:cover}
.travel-card .pad{padding:var(--space-6)}
.travel-card h3{font-size:var(--text-lg);margin-bottom:var(--space-2)}
.travel-card p{font-size:var(--text-sm);color:var(--color-text-muted)}
.hotel-list{display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-4)}
.hotel-list .h{display:flex;justify-content:space-between;gap:var(--space-3);font-size:var(--text-sm);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-divider)}
.hotel-list .h:last-child{border-bottom:0;padding-bottom:0}
.hotel-list .h .dist{color:var(--color-text-faint);font-size:var(--text-xs);white-space:nowrap}

/* ---------- info ---------- */
.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-6)}
@media(max-width:760px){.info-grid{grid-template-columns:1fr}}
.info-card{display:flex;gap:var(--space-4);background:var(--color-surface);border:1px solid var(--color-divider);border-radius:var(--radius-lg);padding:var(--space-6)}
.info-card .ic{flex:none;width:2.8rem;height:2.8rem;display:grid;place-items:center;border-radius:var(--radius-md);background:var(--color-primary-soft);color:var(--color-primary)}
.info-card h3{font-size:var(--text-base);font-family:var(--font-body);font-weight:600;margin-bottom:var(--space-1)}
.info-card p{font-size:var(--text-sm);color:var(--color-text-muted)}
.info-card a{color:var(--color-primary);font-weight:600}
.updated{margin-top:var(--space-8);font-size:var(--text-sm);color:var(--color-text-muted)}

/* ---------- faq ---------- */
.faq-list{display:flex;flex-direction:column;gap:var(--space-3);max-width:var(--content-narrow)}
.faq-item{background:var(--color-surface);border:1px solid var(--color-divider);border-radius:var(--radius-lg);padding:var(--space-5) var(--space-6)}
.faq-item summary{font-weight:600;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:var(--space-4)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";flex:none;font-size:1.4em;font-weight:400;color:var(--color-primary);line-height:1;transition:transform .2s ease}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item p{margin-top:var(--space-4);font-size:var(--text-sm);color:var(--color-text-muted)}
.faq-item a{color:var(--color-primary);font-weight:600}

/* ---------- players placeholder ---------- */
.players{text-align:center}
.players-box{max-width:var(--content-narrow);margin-inline:auto;background:var(--color-surface);border:1.5px dashed var(--color-border);border-radius:var(--radius-xl);padding:clamp(var(--space-10),6vw,var(--space-20)) var(--space-8)}
.players-box .ic{width:3.4rem;height:3.4rem;margin:0 auto var(--space-5);display:grid;place-items:center;border-radius:var(--radius-full);background:var(--color-primary-soft);color:var(--color-primary)}
.players-box h3{font-size:var(--text-xl);margin-bottom:var(--space-3)}
.players-box p{color:var(--color-text-muted);max-width:46ch;margin-inline:auto}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6)}
@media(max-width:880px){.contact-grid{grid-template-columns:1fr}}
.person{background:var(--color-surface);border:1px solid var(--color-divider);border-radius:var(--radius-xl);padding:var(--space-8);text-align:center;box-shadow:var(--shadow-sm)}
.person .avatar{width:7rem;height:7rem;border-radius:50%;margin:0 auto var(--space-5);object-fit:cover;border:3px solid var(--color-primary);background:var(--color-surface-offset)}
.person .avatar-fallback{width:7rem;height:7rem;border-radius:50%;margin:0 auto var(--space-5);display:grid;place-items:center;background:var(--color-primary-soft);color:var(--color-primary);font-family:var(--font-display);font-size:var(--text-xl);border:3px solid var(--color-primary)}
.person h3{font-size:var(--text-lg);margin-bottom:var(--space-1)}
.person .role{font-size:var(--text-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-faint);margin-bottom:var(--space-4)}
.person a{color:var(--color-primary);font-weight:600;font-size:var(--text-sm);word-break:break-word}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6);align-items:stretch;max-width:980px}
.team-grid .person{display:flex;flex-direction:column}
.team-grid .person h3{margin-top:var(--space-1)}
.person .person-bio{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.5;margin-bottom:var(--space-4);flex:1 1 auto}
.person .avatar-ref{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-soft));color:#fff;border-color:var(--color-primary)}
@media(max-width:1100px){.team-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:760px){.team-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-4)}}
@media(max-width:460px){.team-grid{grid-template-columns:1fr}}

/* ---------- partners ---------- */
.partners{text-align:center}
.logo-row{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:clamp(var(--space-8),6vw,var(--space-20));margin-top:var(--space-10)}
.logo-row .logo{height:5.2rem;display:grid;place-items:center;padding:0 var(--space-6);background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s}
.logo-row a.logo:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.logo-row img{max-height:3.2rem;width:auto;object-fit:contain;transition:opacity .2s}
.logo-placeholder{height:3.2rem;min-width:9rem;border:1.5px dashed var(--color-border);border-radius:var(--radius-md);display:grid;place-items:center;font-size:var(--text-xs);color:var(--color-text-faint);padding:0 var(--space-4)}
.partner-cta{margin-top:var(--space-10);font-size:var(--text-sm);color:var(--color-text-muted)}

/* ---------- footer ---------- */
.footer{background:var(--color-ink);color:rgba(255,255,255,.7);padding-block:var(--space-16) var(--space-8)}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:var(--space-10);padding-bottom:var(--space-10);border-bottom:1px solid rgba(255,255,255,.12)}
@media(max-width:760px){.footer-top{grid-template-columns:1fr;gap:var(--space-8)}}
.footer h4{color:#fff;font-family:var(--font-body);font-size:var(--text-sm);letter-spacing:.08em;text-transform:uppercase;margin-bottom:var(--space-4)}
.footer .brand{color:#fff;margin-bottom:var(--space-4)}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:var(--space-2)}
.footer a{font-size:var(--text-sm)}
.footer a:hover{color:var(--color-primary)}
.footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:var(--space-3);padding-top:var(--space-6);font-size:var(--text-xs);color:rgba(255,255,255,.5)}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s cubic-bezier(.16,1,.3,1),transform .6s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
/* summary panel must never animate via transform (breaks position:sticky and clips card) */
.config-summary.reveal{opacity:1;transform:none;transition:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---------- gallery ---------- */
.gallery-grid{
  margin-top:var(--space-12);
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:200px;
  gap:var(--space-4);
}
.gallery-grid figure{
  margin:0;position:relative;overflow:hidden;
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-md);
  background:var(--color-surface-offset);
}
.gallery-grid img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .6s cubic-bezier(.16,1,.3,1),filter .4s ease;
}
.gallery-grid figure:hover img{transform:scale(1.05)}
.gallery-grid figcaption{
  position:absolute;inset:auto 0 0 0;
  padding:var(--space-6) var(--space-4) var(--space-3);
  font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;
  color:#fff;
  background:linear-gradient(to top,rgba(15,14,12,.78),rgba(15,14,12,0));
  opacity:0;transform:translateY(8px);
  transition:opacity .4s ease,transform .4s ease;
  pointer-events:none;
}
.gallery-grid figure:hover figcaption{opacity:1;transform:none}
/* span helpers */
.g-tall{grid-row:span 2}
.g-wide{grid-column:span 2}
.g-big{grid-column:span 2;grid-row:span 2}
@media(max-width:900px){
  .gallery-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}
  .g-wide,.g-big{grid-column:span 2}
  .g-big{grid-row:span 2}
}
@media(max-width:520px){
  .gallery-grid{grid-template-columns:1fr;grid-auto-rows:220px}
  .g-wide,.g-big,.g-tall{grid-column:span 1;grid-row:span 1}
}
