/* ═══════════════════════════════════════════════════════════════
   BIG GUARD RECOVERY — style.css (Phase A.5: Brand Alignment)
   Real Gotham font, brand colors (#253D80 blue, true black bg),
   tactical bordered labels, atmospheric smoke effects.
   ═══════════════════════════════════════════════════════════════ */

/* ─────────────────── 0. GOTHAM FONT FACE ─────────────────── */
@font-face{font-family:'Gotham';src:url('../fonts/gotham/Gotham-Book.otf') format('opentype');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Gotham';src:url('../fonts/gotham/Gotham-Medium.otf') format('opentype');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Gotham';src:url('../fonts/gotham/Gotham-Bold.otf') format('opentype');font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:'Gotham';src:url('../fonts/gotham/Gotham-Black.otf') format('opentype');font-weight:900;font-style:normal;font-display:swap}
@font-face{font-family:'Gotham';src:url('../fonts/gotham/Gotham-BlackItalic.otf') format('opentype');font-weight:900;font-style:italic;font-display:swap}

/* ─────────────────── 1. RESET + TOKENS (BRAND ALIGNED) ─────────────────── */
:root{
  /* Brand colors (from Figma) */
  --bg:#000000;            /* true black */
  --bg2:#0A0A0A;           /* near-black for layering */
  --bg3:#111;              /* card surfaces */
  --blue:#253D80;          /* brand royal blue */
  --blue-bright:#2E4FA8;   /* slightly brighter for hovers */
  --glow:#3B5FCF;          /* lighter highlight */
  --white:#fff;
  --mute:#A0A8B8;          /* muted text */
  --line:rgba(255,255,255,.12); /* divider lines */
  /* Fonts: real Gotham first, fallback to Inter (system) then sans-serif */
  --display:'Gotham','Inter','Helvetica Neue',sans-serif;
  --body:'Gotham','Inter','Helvetica Neue',sans-serif;
  --serif:'Gotham','Inter',sans-serif; /* legacy var, points to Gotham now */
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{overflow-x:hidden;max-width:100vw}
body{background:var(--bg);color:var(--white);font-family:var(--body);line-height:1.6}
a{color:inherit;text-decoration:none}
img,video{display:block;max-width:100%;height:auto}
button{font-family:inherit}

/* Grain texture */
body::before{content:'';position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ─────────────────── 2. BUTTONS ─────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:16px 36px;border-radius:999px;font-weight:700;font-size:12px;letter-spacing:1.5px;text-transform:uppercase;transition:.4s;border:1px solid transparent;cursor:pointer;font-family:var(--body)}
.btn--white{background:#fff;color:#000}
.btn--white:hover{transform:translateY(-3px);box-shadow:0 20px 40px rgba(59,95,207,.5)}
.btn--ghost{border-color:rgba(255,255,255,.3);color:#fff;background:transparent}
.btn--ghost:hover{border-color:var(--blue);background:rgba(37,61,128,.15)}

/* ─────────────────── 3. NAVIGATION (desktop) ─────────────────── */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(10,14,26,.85);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-bottom:1px solid rgba(255,255,255,.05)}
.nav__inner{max-width:1480px;margin:0 auto;padding:20px 48px;display:flex;align-items:center;justify-content:space-between;gap:40px}
.nav__logo{display:flex;align-items:center;gap:12px}
.nav__logo span{width:46px;height:46px;border:2px solid var(--blue);border-radius:50%;display:grid;place-items:center;font-family:var(--display);color:var(--blue);font-size:20px;background:rgba(37,61,128,.1)}
.nav__logo strong{display:block;font-family:var(--display);font-size:15px;letter-spacing:1px;line-height:1;font-weight:800}
.nav__logo em{font-style:italic;font-size:11px;color:var(--glow);letter-spacing:2px}

.nav__links{display:flex;gap:38px;align-items:center}
.nav__links>a{font-size:12px;font-weight:700;letter-spacing:2px;padding:8px 0;color:rgba(255,255,255,.7);transition:.3s;position:relative;font-family:var(--body)}
.nav__links>a:hover,.nav__links>a.is-active{color:#fff}
.nav__links>a.is-active::after{content:'';position:absolute;left:0;right:0;bottom:0;height:2px;background:var(--blue)}

/* Desktop dropdown */
.nav__drop{position:relative}
.nav__drop>a{display:flex;align-items:center;gap:4px;font-size:12px;font-weight:700;letter-spacing:2px;color:rgba(255,255,255,.7);transition:.3s;padding:8px 0;cursor:pointer}
.nav__drop:hover>a{color:#fff}
.nav__drop::after{content:'';position:absolute;top:100%;left:0;right:0;height:20px}
.nav__menu{position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%) translateY(-10px);min-width:320px;background:rgba(10,14,26,.97);backdrop-filter:blur(24px);border:1px solid rgba(59,95,207,.2);border-radius:20px;padding:16px;opacity:0;pointer-events:none;transition:.3s;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.nav__drop:hover .nav__menu{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.nav__menu>a{display:block;padding:14px 16px;border-radius:12px;transition:.2s;letter-spacing:0;font-weight:500;text-transform:none}
.nav__menu>a:hover{background:rgba(37,61,128,.15)}
.nav__menu>a strong{display:block;font-family:var(--display);font-size:15px;text-transform:uppercase;letter-spacing:.5px;color:#fff;margin-bottom:4px;font-weight:800}
.nav__menu>a span{font-size:11px;color:var(--mute);letter-spacing:1px;text-transform:uppercase}
.nav__menu-foot{border-top:1px solid rgba(255,255,255,.08);margin-top:8px;padding-top:8px}
.nav__menu-foot a{display:block;text-align:center;font-size:11px;letter-spacing:2px;color:var(--blue);padding:10px;font-weight:700}

.nav__cta{background:var(--blue);color:#fff;padding:12px 22px;border-radius:999px;font-size:11px;letter-spacing:1.5px;font-weight:700;transition:.3s}
.nav__cta:hover{background:#fff;color:#000}

/* Hamburger + drawer — hidden on desktop */
.nav__burger{display:none}
.nav__backdrop{display:none}
.nav__cta-mobile{display:none}

/* ─────────────────── 4. HERO ─────────────────── */
.hero{min-height:100vh;padding:160px 48px 80px;position:relative;overflow:hidden;display:flex;align-items:center}
.hero::before{content:'';position:absolute;top:20%;right:-10%;width:60%;height:60%;background:radial-gradient(circle,rgba(37,61,128,.4),transparent 70%);filter:blur(80px)}
.hero__inner{max-width:1480px;margin:0 auto;width:100%;position:relative;z-index:2}
.hero__grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}

.eyebrow{display:inline-flex;align-items:center;gap:14px;font-size:11px;letter-spacing:3px;color:var(--glow);text-transform:uppercase;font-weight:600;margin-bottom:28px}
.eyebrow::before{content:'';width:48px;height:1px;background:var(--glow)}
.eyebrow--center{justify-content:center;display:flex}
.eyebrow--center::after{content:'';width:48px;height:1px;background:var(--glow)}

.hero h1{font-family:var(--display);font-size:clamp(64px,10vw,160px);line-height:.85;letter-spacing:-3px;margin-bottom:32px;text-transform:uppercase;font-weight:800}
.hero h1 .line2{display:block;font-family:var(--serif);font-style:italic;color:var(--blue);font-weight:400;letter-spacing:-1px;text-transform:none;margin-top:8px;text-shadow:0 0 60px rgba(37,61,128,.6)}
.hero p{font-size:18px;color:var(--mute);max-width:480px;margin-bottom:40px;line-height:1.7}
.hero__ctas{display:flex;gap:16px;flex-wrap:wrap}

.hero__visual{position:relative;aspect-ratio:4/5;border-radius:28px;overflow:hidden;box-shadow:0 40px 80px rgba(0,0,0,.5)}
.hero__visual img{width:100%;height:100%;object-fit:cover;transition:8s}
.hero__visual:hover img{transform:scale(1.08)}
.hero__visual::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(10,14,26,.7));pointer-events:none}
.hero__badge{position:absolute;left:24px;bottom:24px;background:rgba(10,14,26,.85);backdrop-filter:blur(20px);padding:14px 20px;border-radius:12px;border:1px solid rgba(59,95,207,.3);z-index:2}
.hero__badge strong{display:block;font-family:var(--display);font-size:24px;color:var(--blue);line-height:1;font-weight:800}
.hero__badge span{font-size:10px;letter-spacing:2px;color:var(--mute);text-transform:uppercase}

/* ─────────────────── 5. MARQUEE ─────────────────── */
.marquee{padding:24px 0;background:var(--blue);overflow:hidden;transform:rotate(-2deg);margin:-20px -20px;position:relative;z-index:5}
.marquee__track{display:flex;gap:60px;animation:scroll 30s linear infinite;white-space:nowrap;font-family:var(--display);font-size:32px;letter-spacing:3px;font-weight:800}
.marquee__track span{display:flex;align-items:center;gap:60px}
.marquee__track span::after{content:'★';color:rgba(255,255,255,.5)}
@keyframes scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ─────────────────── 6. SECTIONS + WRAP ─────────────────── */
section{padding:140px 48px;position:relative}
.wrap{max-width:1480px;margin:0 auto}
.section-title{font-family:var(--display);font-size:clamp(56px,7vw,120px);text-align:center;line-height:.9;margin-bottom:90px;letter-spacing:-3px;text-transform:uppercase;font-weight:800}
.section-title em{font-family:var(--serif);font-style:italic;color:var(--blue);font-weight:400;letter-spacing:-1px;text-transform:none}

/* ─────────────────── 7. MANIFESTO ─────────────────── */
.manifesto{padding:160px 48px;position:relative}
.manifesto__grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 2fr;gap:80px;align-items:start}
.manifesto .eyebrow{grid-column:1/-1;margin-bottom:32px}
.manifesto h2{font-family:var(--display);font-size:clamp(36px,4.5vw,72px);line-height:.95;text-transform:uppercase;letter-spacing:-2px;grid-column:1/-1;margin-bottom:40px;font-weight:800}
.manifesto h2 em{font-family:var(--serif);font-style:italic;color:var(--blue);font-weight:400;text-transform:none;letter-spacing:-1px}
.manifesto p{font-size:18px;color:var(--mute);line-height:1.8;max-width:640px;grid-column:2}

/* ─────────────────── 8. SERVICES (home cards) ─────────────────── */
.services{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.service{position:relative;aspect-ratio:3/4;border-radius:24px;overflow:hidden;cursor:pointer;transition:.6s cubic-bezier(.16,1,.3,1);display:block}
.service img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:1s}
.service::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,14,26,.2),rgba(10,14,26,.5) 50%,rgba(10,14,26,.95));z-index:1;transition:.5s}
.service:hover{transform:translateY(-16px)}
.service:hover img{transform:scale(1.1)}
.service__num{position:absolute;top:24px;left:24px;font-family:var(--display);font-size:14px;color:#fff;letter-spacing:3px;z-index:2;background:rgba(37,61,128,.9);padding:6px 12px;border-radius:6px;font-weight:800}
.service__body{position:absolute;left:0;right:0;bottom:0;padding:32px 28px;z-index:2}
.service__body h3{font-family:var(--display);font-size:28px;letter-spacing:-.5px;margin-bottom:10px;line-height:1;font-weight:800;text-transform:uppercase}
.service__body p{font-size:13px;color:rgba(255,255,255,.7);margin-bottom:18px}
.service__more{font-size:11px;letter-spacing:2px;color:var(--blue);font-weight:800;display:inline-flex;gap:8px;transition:.3s}
.service:hover .service__more{gap:14px;color:#fff}

/* ─────────────────── 9. CODE OF RECOVERY ─────────────────── */
.code{background:linear-gradient(180deg,var(--bg),#000,var(--bg))}
.code__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;background:rgba(59,95,207,.15);border:1px solid rgba(59,95,207,.15);border-radius:24px;overflow:hidden;max-width:1200px;margin:0 auto}
.code__item{background:var(--bg);padding:60px 48px;transition:.4s;position:relative;min-height:280px;display:flex;flex-direction:column;justify-content:space-between}
.code__item:hover{background:linear-gradient(135deg,rgba(37,61,128,.12),transparent)}
.code__num{font-family:var(--display);font-size:96px;color:var(--blue);line-height:.8;opacity:.35;letter-spacing:-4px;font-weight:800}
.code__item h4{font-family:var(--display);font-size:32px;letter-spacing:-.5px;margin:24px 0 16px;text-transform:uppercase;line-height:1;font-weight:800}
.code__item p{font-size:15px;color:var(--mute);line-height:1.6}

/* ─────────────────── 10. PRE-FOOTER CTA ─────────────────── */
.prefooter{padding:100px 48px;text-align:center;position:relative;overflow:hidden}
.prefooter::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(37,61,128,.2),transparent 60%)}
.prefooter__box{max-width:760px;margin:0 auto;padding:70px 48px;border:2px solid rgba(59,95,207,.4);border-radius:28px;background:rgba(10,14,26,.6);backdrop-filter:blur(20px);position:relative;z-index:2}
.prefooter h2{font-family:var(--display);font-size:clamp(40px,5.5vw,72px);margin-bottom:36px;line-height:.95;text-transform:uppercase;letter-spacing:-2px;font-weight:800}
.prefooter h2 em{font-family:var(--serif);font-style:italic;color:var(--blue);font-weight:400;text-transform:none;letter-spacing:-1px}

/* ─────────────────── 11. FOOTER ─────────────────── */
.footer{padding:100px 48px 0;border-top:1px solid rgba(255,255,255,.05)}
.footer__inner{max-width:1480px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:60px}
.logo-circle{width:68px;height:68px;border:2px solid var(--blue);border-radius:50%;display:grid;place-items:center;font-family:var(--display);color:var(--blue);font-size:24px;background:rgba(37,61,128,.1);font-weight:800}
.footer__cols{display:grid;grid-template-columns:repeat(3,1fr);gap:80px;width:100%;max-width:960px}
.footer__cols h4{font-family:var(--display);font-size:14px;letter-spacing:2px;margin-bottom:24px;color:var(--blue);font-weight:800}
.footer__cols ul{list-style:none}
.footer__cols li{margin-bottom:12px}
.footer__cols a,.footer__cols p,.footer__cols li{font-size:13px;color:var(--mute)}
.footer__cols p{margin-bottom:16px}
.footer__cols strong{color:#fff;font-weight:600;display:block;margin-top:4px}
.footer__bar{margin-top:80px;padding:24px;background:var(--blue);text-align:center;font-size:11px;letter-spacing:2px;font-weight:700;text-transform:uppercase}

/* ─────────────────── 12. PAGE HERO (shared) ─────────────────── */
.page-hero{padding:200px 48px 100px;text-align:center;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;top:30%;left:50%;transform:translateX(-50%);width:80%;height:60%;background:radial-gradient(circle,rgba(37,61,128,.25),transparent 60%);filter:blur(100px)}
.page-hero .eyebrow{justify-content:center;display:inline-flex;margin-bottom:24px}
.page-hero .eyebrow::after{content:'';width:48px;height:1px;background:var(--glow)}
.page-hero__title{font-family:var(--display);font-size:clamp(64px,9vw,140px);line-height:.9;text-transform:uppercase;letter-spacing:-3px;font-weight:800;margin-bottom:32px;position:relative;z-index:2}
.page-hero__title em{font-family:var(--serif);font-style:italic;color:var(--blue);font-weight:400;text-transform:none;letter-spacing:-1px;display:block}
.page-hero__sub{font-size:18px;color:var(--mute);max-width:620px;margin:0 auto;position:relative;z-index:2}

/* ─────────────────── 13. ARSENAL ─────────────────── */
.arsenal{padding:80px 48px 140px}
.arsenal__row{display:grid;grid-template-columns:1.1fr 1fr;gap:80px;align-items:center;margin-bottom:140px}
.arsenal__row--alt{grid-template-columns:1fr 1.1fr}
.arsenal__row--alt .arsenal__media{order:2}
.arsenal__media{position:relative;aspect-ratio:4/5;border-radius:24px;overflow:hidden}
.arsenal__media img{width:100%;height:100%;object-fit:cover;transition:8s}
.arsenal__row:hover .arsenal__media img{transform:scale(1.06)}
.arsenal__num{position:absolute;top:-30px;left:-20px;font-family:var(--display);font-size:200px;color:var(--blue);font-weight:800;letter-spacing:-8px;line-height:.8;opacity:.9;text-shadow:0 0 40px rgba(37,61,128,.5)}
.arsenal__text h2{font-family:var(--display);font-size:clamp(56px,7vw,110px);line-height:.85;text-transform:uppercase;letter-spacing:-3px;font-weight:800;margin:16px 0 20px}
.arsenal__tag{font-family:var(--serif);font-style:italic;color:var(--blue);font-size:26px;margin-bottom:24px;line-height:1.2}
.arsenal__text p{color:var(--mute);font-size:16px;line-height:1.8;margin-bottom:32px;max-width:520px}

/* ─────────────────── 14. EVENTS LIST + DETAIL ─────────────────── */
.events__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:32px}
.evt{display:block;border:1px solid rgba(255,255,255,.08);border-radius:24px;overflow:hidden;background:rgba(255,255,255,.02);transition:.5s cubic-bezier(.16,1,.3,1)}
.evt:hover{transform:translateY(-12px);border-color:var(--blue);box-shadow:0 30px 60px rgba(37,61,128,.2)}
.evt__img{aspect-ratio:16/10;overflow:hidden;background:#000}
.evt__img img{width:100%;height:100%;object-fit:cover;object-position:center;transition:1s}
.evt:hover .evt__img img{transform:scale(1.08)}
.evt__body{padding:32px}
.evt__meta{display:flex;justify-content:space-between;font-size:11px;letter-spacing:2px;color:var(--mute);margin-bottom:16px}
.evt__star{color:var(--blue);font-weight:700}
.evt h3{font-family:var(--display);font-size:32px;text-transform:uppercase;letter-spacing:-1px;margin-bottom:8px;line-height:1;font-weight:800}
.evt__loc{font-family:var(--serif);font-style:italic;color:var(--blue);font-size:18px;margin-bottom:16px}
.evt__desc{color:var(--mute);font-size:14px;line-height:1.7;margin-bottom:24px}
.evt__cta{font-size:11px;letter-spacing:2px;color:var(--blue);font-weight:700;display:inline-flex;gap:8px;transition:.3s}
.evt:hover .evt__cta{gap:16px;color:#fff}

.evt-hero{min-height:70vh;padding:200px 48px 100px;background-size:cover;background-position:center;display:flex;align-items:flex-end;position:relative}
.evt-hero__title{font-family:var(--display);font-size:clamp(56px,8vw,140px);line-height:.9;text-transform:uppercase;letter-spacing:-3px;font-weight:800;margin:24px 0 40px;max-width:1000px}
.evt-hero__meta{display:grid;grid-template-columns:repeat(4,1fr);gap:40px;margin-bottom:40px;max-width:900px}
.evt-hero__meta span{display:block;font-size:10px;letter-spacing:2px;color:var(--mute);margin-bottom:8px}
.evt-hero__meta strong{font-family:var(--display);font-size:18px;line-height:1.2;text-transform:uppercase;font-weight:800}
.evt-desc{font-size:18px;color:var(--mute);line-height:1.8;max-width:800px;margin:40px auto 24px;text-align:center}
.evt-addr{text-align:center;font-size:13px;letter-spacing:2px;color:var(--blue);margin-bottom:40px}

/* ─────────────────── 15. SESSION PICKER (stunning cards) ─────────────────── */
.sess-pick{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:28px;margin:48px 0}
.sess-pick__card{position:relative;background:linear-gradient(165deg,rgba(20,24,40,.95),rgba(10,14,26,.98));border:1px solid rgba(255,255,255,.08);border-radius:24px;padding:40px 32px;cursor:pointer;transition:all .5s cubic-bezier(.16,1,.3,1);overflow:hidden;opacity:0;transform:translateY(24px);animation:sessIn .7s cubic-bezier(.16,1,.3,1) forwards;display:block}
@keyframes sessIn{to{opacity:1;transform:translateY(0)}}
.sess-pick__card::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 0%,rgba(37,61,128,.12),transparent 60%);opacity:0;transition:opacity .5s}
.sess-pick__card:hover{transform:translateY(-8px);border-color:rgba(37,61,128,.5);box-shadow:0 40px 100px -30px rgba(37,61,128,.4),0 20px 60px -20px rgba(0,0,0,.6)}
.sess-pick__card:hover::before{opacity:1}
.sess-pick__card--featured{background:linear-gradient(165deg,rgba(37,61,128,.12),rgba(15,20,40,.98));border-color:rgba(37,61,128,.4)}
.sess-pick__ribbon{position:absolute;top:20px;right:-6px;background:linear-gradient(135deg,#253D80,#3B5FCF);color:#fff;font-size:10px;letter-spacing:2px;padding:8px 18px;font-weight:800;font-family:var(--display);box-shadow:0 10px 30px -5px rgba(37,61,128,.6);z-index:2}
.sess-pick__duration{position:absolute;top:24px;left:24px;font-family:var(--display);font-weight:800;font-size:11px;letter-spacing:2px;color:var(--blue);padding:8px 14px;background:rgba(37,61,128,.1);border:1px solid rgba(37,61,128,.3);border-radius:100px}
.sess-pick__type{margin-top:56px;font-size:10px;letter-spacing:2.5px;color:var(--mute);font-family:var(--display);font-weight:700;margin-bottom:12px}
.sess-pick__name{font-family:var(--display);font-weight:800;font-size:34px;line-height:1.05;margin:0 0 14px;color:#fff;letter-spacing:-1px;text-transform:uppercase}
.sess-pick__tagline{font-family:var(--serif);font-style:italic;font-size:18px;color:var(--blue);margin:0 0 24px;line-height:1.3;text-transform:none}
.sess-pick__icons{display:flex;gap:8px;margin-bottom:24px;flex-wrap:wrap}
.sess-pick__icon{font-family:var(--display);font-weight:800;font-size:10px;letter-spacing:1px;padding:8px 12px;border-radius:8px;background:rgba(255,255,255,.03);color:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.05);transition:all .3s}
.sess-pick__icon.on{background:rgba(37,61,128,.15);color:var(--blue);border-color:rgba(37,61,128,.4);box-shadow:0 0 20px -5px rgba(37,61,128,.4)}
.sess-pick__desc{font-size:14px;line-height:1.6;color:rgba(255,255,255,.6);margin:0 0 28px;min-height:66px}
.sess-pick__price{display:flex;align-items:baseline;gap:8px;padding-top:24px;border-top:1px solid rgba(255,255,255,.08);margin-bottom:8px}
.sess-pick__price strong{font-family:var(--display);font-weight:800;font-size:56px;color:var(--blue);line-height:1;letter-spacing:-2px}
.sess-pick__price small{font-size:13px;color:var(--mute);font-weight:500}
.sess-pick__club{font-size:10px;letter-spacing:1.5px;color:var(--blue);text-transform:uppercase;font-weight:700;margin-bottom:20px}
.sess-pick__btn{width:100%;margin-top:16px;padding:18px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.15);border-radius:100px;color:#fff;font-family:var(--display);font-weight:700;font-size:13px;letter-spacing:2px;cursor:pointer;transition:all .3s;display:block;text-align:center}
.sess-pick__card:hover .sess-pick__btn{background:var(--blue);border-color:var(--blue);box-shadow:0 20px 40px -10px rgba(37,61,128,.5)}

/* ─────────────────── 16. BOOKING WIZARD ─────────────────── */
.booking{padding:40px 48px 140px}
.bk__steps{display:flex;gap:8px;justify-content:center;margin-bottom:60px;flex-wrap:wrap}
.bk__step{padding:12px 20px;border:1px solid rgba(255,255,255,.1);border-radius:999px;font-size:11px;letter-spacing:1.5px;font-weight:700;color:var(--mute);font-family:var(--display)}
.bk__step.active{border-color:var(--blue);color:#fff;background:rgba(37,61,128,.1)}
.bk__step.done{border-color:var(--blue);opacity:.7}
.bk__panel{max-width:1100px;margin:0 auto;padding:60px 48px;border:1px solid rgba(255,255,255,.08);border-radius:28px;background:rgba(255,255,255,.02);backdrop-filter:blur(20px)}
.bk__h{font-family:var(--display);font-size:36px;margin-bottom:12px;text-transform:uppercase;letter-spacing:-1px;text-align:center;font-weight:800}
.bk__h em{font-family:var(--serif);font-style:italic;color:var(--blue);font-weight:400;text-transform:none;letter-spacing:-1px}
.bk__sub{text-align:center;color:var(--mute);font-size:13px;margin-bottom:36px;letter-spacing:1px;text-transform:uppercase}
.bk__loading{text-align:center;color:var(--mute);padding:40px}
.bk__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin-bottom:28px}
.bk__grid--events{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.bk__grid--type{grid-template-columns:1fr 1fr;max-width:780px;margin:0 auto 28px}

.bk__card{border:1px solid rgba(255,255,255,.08);border-radius:16px;overflow:hidden;cursor:pointer;transition:.3s;background:rgba(0,0,0,.2)}
.bk__card:hover{border-color:var(--blue);transform:translateY(-4px)}
.bk__card img{width:100%;height:160px;object-fit:cover}
.bk__cbody{padding:20px}
.bk__cbody h4{font-family:var(--display);font-size:22px;margin-bottom:6px;text-transform:uppercase;font-weight:800;letter-spacing:-.5px}
.bk__cbody p{color:var(--mute);font-size:13px;margin-bottom:8px}
.bk__cat{font-size:10px;letter-spacing:2px;color:var(--blue);margin-bottom:8px;text-transform:uppercase;font-weight:700}
.bk__dates{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:28px}
.bk__times{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:28px}
.bk__date,.bk__time{padding:18px;border:1px solid rgba(255,255,255,.1);border-radius:12px;background:transparent;color:#fff;cursor:pointer;font-family:var(--body);transition:.3s;text-align:center}
.bk__date span{display:block;font-size:11px;color:var(--mute);margin-bottom:4px}
.bk__date strong{font-family:var(--display);font-size:18px;font-weight:800}
.bk__date em{display:block;font-size:9px;color:var(--mute);letter-spacing:1.5px;margin-top:4px;font-style:normal}
.bk__date:hover,.bk__time:not(:disabled):hover{border-color:var(--blue);background:rgba(37,61,128,.1)}
.bk__time{display:flex;flex-direction:column;gap:4px;padding:16px 12px}
.bk__time strong{font-family:var(--display);font-size:14px;font-weight:800}
.bk__time span{font-size:9px;letter-spacing:1px;color:var(--blue);text-transform:uppercase}
.bk__time.full{opacity:.35;cursor:not-allowed}
.bk__time.full span{color:rgba(255,100,100,.7)}

.bk__form{display:grid;grid-template-columns:1fr 1fr;gap:16px;max-width:640px;margin:0 auto}
.bk__form input,.bk__form textarea{padding:16px 20px;background:rgba(0,0,0,.3);border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;font-family:var(--body);font-size:14px}
.bk__form textarea{grid-column:1/-1;min-height:100px;resize:vertical}
.bk__form input:focus,.bk__form textarea:focus{outline:none;border-color:var(--blue)}
.bk__chk{display:flex;align-items:center;gap:12px;padding:14px 18px;background:rgba(0,0,0,.3);border:1px solid rgba(255,255,255,.1);border-radius:12px;font-size:13px;color:var(--mute);cursor:pointer;grid-column:1/-1}
.bk__chk input{width:auto;accent-color:var(--blue)}
.bk__actions{grid-column:1/-1;display:flex;justify-content:space-between;gap:16px;margin-top:20px}

.bk__review{max-width:560px;margin:0 auto 32px;border:1px solid rgba(255,255,255,.1);border-radius:16px;overflow:hidden}
.bk__review>div{display:flex;justify-content:space-between;padding:18px 24px;border-bottom:1px solid rgba(255,255,255,.06);gap:20px}
.bk__review span{font-size:11px;letter-spacing:2px;color:var(--mute)}
.bk__review strong{font-family:var(--display);font-size:16px;font-weight:800}
.bk__total{background:rgba(37,61,128,.1)}
.bk__total strong{font-size:24px!important;color:var(--blue)}
.disc{color:var(--blue)!important}
.bk__pay{display:flex;gap:16px;justify-content:center;margin-bottom:24px}
.bk__pay label{padding:16px 24px;border:1px solid rgba(255,255,255,.1);border-radius:12px;cursor:pointer;font-size:13px;transition:.3s}
.bk__pay label.on{border-color:var(--blue);background:rgba(37,61,128,.15)}
.bk__done{text-align:center;padding:40px}
.bk__check{width:80px;height:80px;border-radius:50%;background:var(--blue);display:grid;place-items:center;font-size:40px;margin:0 auto 24px}
.bk__done h2{font-family:var(--display);font-size:48px;margin-bottom:12px;letter-spacing:-2px;font-weight:800}
.bk__ref{font-family:var(--display);font-size:20px;color:var(--blue);margin:20px 0;letter-spacing:2px;font-weight:800}
.bk__note{color:var(--mute);margin-bottom:32px}

/* ─────────────────── 17. CONTACT ─────────────────── */
.contact{padding:40px 48px 140px}
.contact__grid{display:grid;grid-template-columns:1fr 1.3fr;gap:80px;max-width:1200px;margin:0 auto}
.contact__info h2{font-family:var(--display);font-size:clamp(48px,6vw,80px);text-transform:uppercase;letter-spacing:-2px;line-height:.9;margin-bottom:40px;font-weight:800}
.contact__info h2 em{font-family:var(--serif);font-style:italic;color:var(--blue);font-weight:400;text-transform:none;letter-spacing:-1px}
.contact__block{padding:20px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.contact__block span{font-size:10px;letter-spacing:2px;color:var(--mute);display:block;margin-bottom:6px}
.contact__block strong{font-family:var(--display);font-size:22px;letter-spacing:-.5px;font-weight:800}
.contact__note{margin-top:28px;color:var(--mute);font-size:14px}
.contact__note a{color:var(--blue);font-weight:600}
.contact__form{display:flex;flex-direction:column;gap:16px;padding:48px;border:1px solid rgba(255,255,255,.08);border-radius:24px;background:rgba(255,255,255,.02)}
.contact__form input,.contact__form textarea{padding:18px 22px;background:rgba(0,0,0,.3);border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;font-family:var(--body);font-size:14px}
.contact__form textarea{min-height:140px;resize:vertical}
.contact__form input:focus,.contact__form textarea:focus{outline:none;border-color:var(--blue)}
.contact__success{padding:20px;background:rgba(37,61,128,.15);border:1px solid var(--blue);border-radius:12px;text-align:center}
.contact__success strong{display:block;font-family:var(--display);font-size:18px;letter-spacing:1px;color:var(--blue);margin-bottom:4px;font-weight:800}
.contact__err{padding:16px;background:rgba(255,80,80,.1);border:1px solid rgba(255,80,80,.3);border-radius:12px;color:#ff8080;font-size:13px}

/* ─────────────────── 18. GALLERY ─────────────────── */
.gallery{padding:40px 48px 140px}
.masonry{columns:3;column-gap:20px}
.masonry__item{break-inside:avoid;margin-bottom:20px;border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.06);transition:.4s}
.masonry__item:hover{transform:scale(1.02);border-color:var(--blue)}
.masonry__item img{width:100%;display:block}

/* ─────────────────── 19. PILLS (used around) ─────────────────── */
.pill{display:inline-block;padding:4px 10px;border-radius:999px;font-size:10px;letter-spacing:1.5px;font-weight:700;text-transform:uppercase}
.pill--active{background:rgba(50,220,120,.12);color:#4ade80;border:1px solid rgba(74,222,128,.3)}
.pill--featured{background:rgba(37,61,128,.15);color:var(--blue);border:1px solid rgba(37,61,128,.4)}
.pill--paused{background:rgba(255,180,50,.12);color:#fbbf24;border:1px solid rgba(251,191,36,.3)}

/* ═══════════════════════════════════════════════════════════════
   20. MOBILE — everything below 900px
   ═══════════════════════════════════════════════════════════════ */
@media(max-width:900px){
  
  /* Nav: hamburger visible, desktop links hidden → drawer */
  .nav__inner{padding:16px 20px;gap:12px}
  .nav__logo span{width:40px;height:40px;font-size:14px}
  .nav__logo strong{font-size:13px}
  .nav__logo em{font-size:9px}
  .nav__cta{display:none}
  
  /* Hamburger button — now visible */
  .nav__burger{
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:center;
    width:48px;
    height:48px;
    background:rgba(37,61,128,.1);
    border:1px solid rgba(37,61,128,.4);
    border-radius:10px;
    cursor:pointer;
    padding:12px;
    margin-left:auto;
    position:relative;
    z-index:102;
    flex-shrink:0;
  }
  .nav__burger span{
    display:block;
    width:22px;
    height:2px;
    background:#fff;
    margin:3px 0;
    border-radius:2px;
    transition:all .3s ease;
  }
  .nav__burger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
  .nav__burger.open span:nth-child(2){opacity:0}
  .nav__burger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
  
  /* Drawer — free-floating, isolated stacking context, no blur leak */
  .nav__links{
    position:fixed;
    top:0;
    right:0;
    bottom:0;
    left:auto;
    width:min(360px,85vw);
    height:100vh;
    height:100dvh;
    padding:100px 32px 60px;
    box-sizing:border-box;
    background:#000;
    backdrop-filter:none;
    -webkit-backdrop-filter:none;
    filter:none;
    isolation:isolate;
    border-left:1px solid rgba(37,61,128,.2);
    box-shadow:-20px 0 60px rgba(0,0,0,.9);
    z-index:200;
    overflow-y:auto;
    overflow-x:hidden;
    -webkit-overflow-scrolling:touch;
    display:flex;
    flex-direction:column;
    align-items:stretch;
    gap:0;
    transform:translateX(100%);
    transition:transform .4s cubic-bezier(.16,1,.3,1);
  }
  .nav__links.open{transform:translateX(0)}
  
  .nav__links>a,
  .nav__links .nav__drop>a,
  .nav__links .nav__cta-mobile{
    display:block;
    padding:20px 0;
    font-family:var(--display);
    font-weight:800;
    font-size:22px;
    letter-spacing:-.5px;
    color:#fff;
    text-decoration:none;
    border-bottom:1px solid rgba(255,255,255,.1);
    text-transform:uppercase;
    width:100%;
    background:transparent;
    pointer-events:auto;
    cursor:pointer;
    position:relative;
    z-index:2;
  }
  .nav__links>a:hover,.nav__links>a.is-active{color:var(--blue)}
  .nav__links>a.is-active::after{display:none}
  
  .nav__drop{width:100%;position:static}
  .nav__drop::after{display:none}
  .nav__menu{
    position:static;
    transform:none;
    opacity:1;
    pointer-events:auto;
    background:none;
    box-shadow:none;
    border:0;
    padding:0 0 12px 16px;
    min-width:0;
    display:none;
  }
  .nav__drop.is-active .nav__menu,
  .nav__drop:hover .nav__menu{display:block}
  .nav__menu>a{padding:12px 0;font-size:13px;border-bottom:1px solid rgba(255,255,255,.04)}
  .nav__menu>a strong{font-size:13px}
  .nav__menu>a span{font-size:10px}
  
  .nav__cta-mobile{
    display:block;
    margin-top:auto;
    margin-bottom:20px;
    padding:18px 28px;
    background:var(--blue);
    color:#fff;
    text-align:center;
    border-radius:100px;
    font-size:12px;
    letter-spacing:2px;
    text-transform:uppercase;
    font-weight:800;
    border:0;
    width:100%;
    font-family:var(--display);
  }
  
  /* Backdrop */
  .nav__backdrop{
    display:none;
    position:fixed;
    inset:0;
    background:rgba(0,0,0,.75);
    z-index:150;
    opacity:0;
    transition:opacity .35s;
  }
  .nav__backdrop.open{display:block;opacity:1}
  body.nav-open{overflow:hidden}
  
  /* Remove backdrop blur from nav on mobile (was causing drawer issues) */
  .nav{backdrop-filter:none;-webkit-backdrop-filter:none;background:#000}
  
  /* HERO */
  .hero{padding:100px 0 40px;min-height:auto}
  .hero__inner{padding:20px}
  .hero__grid{grid-template-columns:1fr;gap:32px}
  .hero h1{font-size:clamp(44px,12vw,72px);line-height:.95;margin-bottom:20px;letter-spacing:-2px}
  .hero h1 .line2{font-size:.75em}
  .hero p{font-size:15px;line-height:1.55;margin-bottom:28px;max-width:100%}
  .hero__ctas{flex-direction:column;gap:12px;align-items:stretch}
  .hero__ctas .btn{width:100%;padding:18px 24px}
  .hero__visual{aspect-ratio:4/3;border-radius:20px}
  .hero__badge{bottom:16px;left:16px;padding:16px 20px}
  .hero__badge strong{font-size:32px}
  
  /* Marquee */
  .marquee__track{font-size:24px;gap:40px}
  .marquee__track span{gap:40px}
  
  /* Manifesto */
  .manifesto{padding:60px 20px}
  .manifesto__grid{grid-template-columns:1fr;gap:16px}
  .manifesto h2{font-size:clamp(28px,7vw,42px);line-height:1.1;letter-spacing:-1px}
  .manifesto p{font-size:14px;line-height:1.6;grid-column:1}
  
  /* Sections + titles */
  section{padding:60px 20px}
  .wrap{padding:0 0}
  .section-title{font-size:clamp(36px,9vw,56px);line-height:1;letter-spacing:-2px;margin-bottom:48px}
  .eyebrow{font-size:10px;letter-spacing:2px}
  
  /* Services cards — preserve absolute layout, adjust sizes */
  .services{grid-template-columns:1fr;gap:20px}
  .service{aspect-ratio:3/4;min-height:360px;max-width:100%}
  .service__body{padding:28px 24px}
  .service__body h3{font-size:26px;margin-bottom:10px}
  .service__body p{font-size:14px;margin-bottom:18px}
  .service__num{font-size:12px;top:20px;left:20px}
  
  /* Code of Recovery */
  .code__grid{grid-template-columns:1fr 1fr;gap:16px}
  .code__item{padding:32px 24px;min-height:auto}
  .code__num{font-size:48px;margin-bottom:8px}
  .code__item h4{font-size:18px;margin:16px 0 8px}
  .code__item p{font-size:13px}
  
  /* Pre-footer */
  .prefooter{padding:60px 20px}
  .prefooter__box{padding:48px 24px}
  .prefooter h2{font-size:clamp(32px,8vw,48px);line-height:1;letter-spacing:-1.5px}
  .prefooter .btn{width:100%}
  
  /* Footer */
  .footer{padding:60px 20px 0}
  .footer__cols{grid-template-columns:1fr;gap:40px}
  .footer__bar{font-size:10px;padding:20px}
  
  /* Page hero */
  .page-hero{padding:120px 20px 60px}
  .page-hero__title{font-size:clamp(40px,11vw,68px);line-height:.95;letter-spacing:-2px}
  .page-hero__sub{font-size:14px;line-height:1.5}
  
  /* Arsenal */
  .arsenal{padding:40px 20px 80px}
  .arsenal__row,.arsenal__row--alt{grid-template-columns:1fr;gap:24px;margin-bottom:60px}
  .arsenal__row--alt .arsenal__media{order:-1}
  .arsenal__num{font-size:100px;top:-10px;left:-5px}
  .arsenal__text h2{font-size:44px;letter-spacing:-2px}
  .arsenal__tag{font-size:18px}
  .arsenal__text p{font-size:14px;line-height:1.6}
  
  /* Events list */
  .events__grid{grid-template-columns:1fr;gap:20px}
  .evt__img{aspect-ratio:16/10}
  .evt__body{padding:24px}
  .evt h3{font-size:22px}
  
  /* Event detail hero */
  .evt-hero{padding:120px 20px 60px;min-height:auto}
  .evt-hero__title{font-size:clamp(36px,10vw,64px);line-height:.95;letter-spacing:-2px;margin-bottom:28px}
  .evt-hero__meta{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:32px}
  .evt-hero__meta span{font-size:9px}
  .evt-hero__meta strong{font-size:13px}
  .evt-hero .btn{width:100%}
  .evt-desc{font-size:14px;line-height:1.6}
  
  /* Session picker */
  .sess-pick{grid-template-columns:1fr;gap:18px;margin:32px 0}
  .sess-pick__card{padding:32px 24px}
  .sess-pick__name{font-size:26px}
  .sess-pick__tagline{font-size:15px}
  .sess-pick__desc{font-size:13px;min-height:0}
  .sess-pick__price strong{font-size:44px}
  .sess-pick__duration{top:20px;left:20px;font-size:10px;padding:6px 12px}
  .sess-pick__type{margin-top:44px}
  .sess-pick__ribbon{font-size:9px;padding:6px 14px}
  
  /* Booking wizard */
  .booking{padding:20px 20px 80px}
  .bk__panel{padding:32px 20px}
  .bk__h{font-size:28px;letter-spacing:-1px}
  .bk__steps{gap:6px;margin-bottom:24px}
  .bk__step{font-size:10px;padding:8px 12px}
  .bk__grid,.bk__grid--events,.bk__grid--type{grid-template-columns:1fr;gap:16px}
  .bk__dates{grid-template-columns:repeat(3,1fr);gap:10px}
  .bk__date{padding:16px 10px}
  .bk__date strong{font-size:22px}
  .bk__times{grid-template-columns:1fr 1fr;gap:10px}
  .bk__time{padding:14px 10px}
  .bk__form{grid-template-columns:1fr}
  .bk__review>div{flex-direction:column;align-items:flex-start;gap:4px;padding:12px 16px}
  .bk__total strong{font-size:32px!important}
  .bk__pay{flex-direction:column;gap:10px}
  .bk__actions{flex-direction:column-reverse;gap:12px}
  .bk__actions .btn{width:100%}
  
  /* Contact */
  .contact{padding:20px 20px 80px}
  .contact__grid{grid-template-columns:1fr;gap:40px}
  .contact__form{padding:28px 20px}
  
  /* Gallery */
  .gallery{padding:20px 20px 80px}
  .masonry{columns:2}
  
  /* Buttons — min touch target */
  .btn{font-size:12px;padding:16px 24px;min-height:52px;letter-spacing:1.5px}
}

/* ── Small phone ── */
@media(max-width:480px){
  .hero h1{font-size:clamp(38px,13vw,56px)}
  .section-title{font-size:clamp(30px,10vw,44px)}
  .marquee__track{font-size:20px}
  .code__grid{grid-template-columns:1fr;gap:12px}
  .bk__dates{grid-template-columns:repeat(2,1fr)}
  .evt-hero__meta{grid-template-columns:1fr}
  .masonry{columns:1}
  .nav__links{width:min(320px,90vw);padding:80px 24px 32px}
  .nav__links>a,.nav__links .nav__drop>a{font-size:20px;padding:18px 0}
  .hero__badge strong{font-size:28px}
}

/* ═══════════════════════════════════════════════════════════════
   POLISH FIXES V2 — Apr 13
   3 targeted fixes: desktop nav, mobile dropdown overflow, event card
   All additions — nothing modified from existing rules above
   ═══════════════════════════════════════════════════════════════ */

/* ─── FIX 1: Desktop nav (links gayab the) ─── */
@media(min-width:901px){
  .nav__links{
    position:fixed !important;
    top:0;
    left:50%;
    right:auto;
    transform:translateX(-50%);
    z-index:101;
    display:flex !important;
    flex-direction:row;
    justify-content:center;
    align-items:center;
    gap:38px;
    padding:28px 48px;
    background:transparent;
    height:auto;
    width:auto;
    max-width:none;
    box-shadow:none;
    border:0;
    isolation:auto;
    overflow:visible;
  }
  .nav__links > a,
  .nav__links .nav__drop,
  .nav__links .nav__drop > a{
    pointer-events:auto;
    position:relative;
  }
  .nav__cta-mobile{display:none !important}
  .nav__burger{display:none !important}
  .nav__backdrop{display:none !important}
}

/* ─── FIX 2: Mobile drawer — events dropdown content stays inside ─── */
@media(max-width:900px){
  .nav__drop{
    width:100% !important;
    max-width:100% !important;
 
    box-sizing:border-box !important;
  }
  .nav__menu{
    width:100% !important;
    max-width:100% !important;
    box-sizing:border-box !important;
    padding:0 0 12px 16px !important;
    margin:0 !important;
    left:auto !important;
    right:auto !important;
    transform:none !important;
  }
  .nav__menu > a{
    width:100% !important;
    max-width:100% !important;
    box-sizing:border-box !important;
    padding:12px 8px !important;
    word-wrap:break-word !important;
    overflow-wrap:break-word !important;
    white-space:normal !important;
  }
  .nav__menu > a strong{
    display:block !important;
    word-wrap:break-word !important;
    overflow-wrap:break-word !important;
    white-space:normal !important;
  }
  .nav__menu > a span{
    display:block !important;
    word-wrap:break-word !important;
    overflow-wrap:break-word !important;
    white-space:normal !important;
    font-size:10px !important;
  }
  .nav__menu-foot{
    width:100% !important;
    max-width:100% !important;
    box-sizing:border-box !important;
    margin-top:8px !important;
    padding:8px 0 0 0 !important;
  }
  .nav__menu-foot a{
    width:100% !important;
    max-width:100% !important;
    box-sizing:border-box !important;
    padding:10px 8px !important;
    text-align:left !important;
  }
}

/* ─── FIX 3: Events page — card image proportional, not huge ─── */
.evt__img{
  aspect-ratio:auto !important;
  height:260px !important;
  background:#000 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
}
.evt__img img{
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  object-position:center !important;
}
@media(max-width:900px){
  .evt__img{
    height:200px !important;
  }
}
/* ════════════════════════════════════════════════════════════════
   PHASE A — UPCOMING EVENTS (homepage), URGENCY BADGES, SOCIAL PROOF
   ════════════════════════════════════════════════════════════════ */

/* ─────────── 15. UPCOMING EVENTS (homepage section) ─────────── */
.upcoming{padding:120px 48px 60px;position:relative}
.upcoming::before{content:'';position:absolute;top:10%;left:-10%;width:50%;height:60%;background:radial-gradient(circle,rgba(37,61,128,.18),transparent 70%);filter:blur(100px);pointer-events:none}
.upcoming__head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:48px;gap:24px;flex-wrap:wrap;position:relative;z-index:2}
.upcoming__title{font-family:var(--display);font-size:clamp(40px,6vw,88px);line-height:.9;letter-spacing:-2px;text-transform:uppercase;font-weight:800}
.upcoming__title em{font-family:var(--serif);font-style:italic;color:var(--blue);font-weight:400;text-transform:none;letter-spacing:-1px}
.upcoming__all{font-size:11px;letter-spacing:2px;color:var(--blue);font-weight:700;padding:14px 22px;border:1px solid rgba(59,95,207,.4);border-radius:999px;transition:.3s;white-space:nowrap}
.upcoming__all:hover{background:var(--blue);color:#fff;border-color:var(--blue);transform:translateY(-2px)}

.upcoming__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;position:relative;z-index:2}

.up-evt{display:flex;flex-direction:column;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.08);border-radius:20px;overflow:hidden;transition:.5s cubic-bezier(.16,1,.3,1);position:relative}
.up-evt:hover{transform:translateY(-10px);border-color:var(--blue);box-shadow:0 30px 60px rgba(37,61,128,.25)}
.up-evt__img{aspect-ratio:16/10;overflow:hidden;background:#000;position:relative}
.up-evt__img img{width:100%;height:100%;object-fit:cover;transition:1s}
.up-evt:hover .up-evt__img img{transform:scale(1.08)}
.up-evt__body{padding:24px 24px 28px;display:flex;flex-direction:column;flex:1;gap:8px}
.up-evt__date{font-size:11px;letter-spacing:2.5px;color:var(--glow);text-transform:uppercase;font-weight:700}
.up-evt__name{font-family:var(--display);font-size:24px;letter-spacing:-.5px;line-height:1;text-transform:uppercase;font-weight:800;margin-top:4px}
.up-evt__loc{font-family:var(--serif);font-style:italic;color:var(--blue);font-size:17px;margin-top:2px}
.up-evt__spots{font-size:11px;letter-spacing:1.5px;color:#FBBF24;text-transform:uppercase;font-weight:700;margin-top:4px;display:inline-flex;align-items:center;gap:6px}
.up-evt__spots::before{content:'●';color:#FBBF24;font-size:8px;animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.up-evt__cta{margin-top:auto;padding-top:16px;font-size:11px;letter-spacing:2px;color:var(--blue);font-weight:800;display:inline-flex;gap:8px;transition:.3s}
.up-evt:hover .up-evt__cta{gap:14px;color:#fff}

/* ─────────── 16. URGENCY BADGE (on event card image) ─────────── */
.urg-badge{position:absolute;top:14px;left:14px;padding:7px 14px;border-radius:999px;font-size:10px;letter-spacing:1.5px;font-weight:800;text-transform:uppercase;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:2;border:1px solid rgba(255,255,255,.15)}
.urg-badge--amber{background:rgba(251,191,36,.95);color:#1a0f00}
.urg-badge--red{background:rgba(239,68,68,.95);color:#fff}
.urg-badge--blue{background:rgba(37,61,128,.95);color:#fff}

/* ─────────── 17. SOCIAL PROOF STRIP ─────────── */
.proof-strip{padding:32px 48px;background:linear-gradient(90deg,#000,var(--bg2),#000);border-top:1px solid rgba(59,95,207,.12);border-bottom:1px solid rgba(59,95,207,.12);position:relative;z-index:6}
.proof-strip__inner{display:flex;align-items:center;justify-content:center;gap:60px;flex-wrap:wrap}
.proof-stat{text-align:center}
.proof-stat strong{display:block;font-family:var(--display);font-size:36px;color:var(--blue);line-height:1;font-weight:800;letter-spacing:-1px;text-shadow:0 0 30px rgba(37,61,128,.5)}
.proof-stat span{display:block;font-size:11px;letter-spacing:2px;color:var(--mute);text-transform:uppercase;margin-top:6px;font-weight:600}
.proof-divider{width:1px;height:40px;background:linear-gradient(180deg,transparent,rgba(59,95,207,.4),transparent)}

/* ─────────── 18. RESPONSIVE: UPCOMING ─────────── */
@media (max-width:1100px){
  .upcoming__grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:720px){
  .upcoming{padding:80px 20px 40px}
  .upcoming__head{margin-bottom:32px}
  .upcoming__grid{grid-template-columns:1fr;gap:18px}
  .up-evt__body{padding:20px 20px 24px}
  .up-evt__name{font-size:22px}
  .proof-strip{padding:24px 20px}
  .proof-strip__inner{gap:28px}
  .proof-stat strong{font-size:28px}
  .proof-divider{display:none}
}

/* ════════════════════════════════════════════════════════════════
   PHASE A.5 — BRAND ALIGNMENT UTILITIES
   ════════════════════════════════════════════════════════════════ */

/* ─────────── 19. TACTICAL LABEL BOX ─────────── */
/* Replaces editorial "eyebrow" treatment for sections like "WHAT WE DO",
   "SERVICES WE OFFER", "RECOVERY TOUR" — bordered uppercase pill */
.label-box{display:inline-flex;align-items:center;justify-content:center;padding:14px 32px;border:2px solid #fff;border-radius:8px;font-family:var(--display);font-weight:900;font-style:italic;font-size:clamp(18px,2.4vw,28px);letter-spacing:1.5px;text-transform:uppercase;color:#fff;background:transparent;line-height:1;white-space:nowrap}
.label-box--center{margin:0 auto;display:flex;width:fit-content}
.label-box--sm{padding:10px 20px;font-size:13px;letter-spacing:1px;border-width:1.5px;border-radius:6px}

/* ─────────── 20. SMOKE / ATMOSPHERE BACKGROUND ─────────── */
.smoke-bg{position:relative;background:#000;overflow:hidden}
.smoke-bg::before{content:'';position:absolute;inset:0;background:
  radial-gradient(ellipse at 20% 0%,rgba(37,61,128,.35),transparent 50%),
  radial-gradient(ellipse at 80% 100%,rgba(37,61,128,.2),transparent 50%);
  pointer-events:none;z-index:0}
.smoke-bg::after{content:'';position:absolute;left:0;right:0;bottom:0;height:50%;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 400'%3E%3Cfilter id='f'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.012' numOctaves='3' seed='5'/%3E%3CfeColorMatrix values='0 0 0 0 0.6 0 0 0 0 0.7 0 0 0 0 1 0 0 0 0.4 0'/%3E%3C/filter%3E%3Crect width='1200' height='400' filter='url(%23f)' opacity='0.25'/%3E%3C/svg%3E") center bottom/cover no-repeat;
  pointer-events:none;mix-blend-mode:screen;opacity:.6;z-index:1}
.smoke-bg > *{position:relative;z-index:2}

/* ─────────── 21. GLOW EFFECTS ─────────── */
.glow-blue{text-shadow:0 0 30px rgba(37,61,128,.7),0 0 60px rgba(37,61,128,.4)}
.glow-edge{display:inline-block;font-style:italic;color:var(--blue);text-shadow:0 0 30px rgba(37,61,128,.8),0 2px 0 rgba(255,255,255,.15);position:relative}
/* Outline-style "EDGE" treatment: blue fill + white stroke effect */
.edge-text{font-family:var(--display);font-weight:900;font-style:italic;color:var(--blue);
  -webkit-text-stroke:1.5px rgba(255,255,255,.4);
  text-shadow:0 0 24px rgba(37,61,128,.6),0 0 50px rgba(37,61,128,.3)}

/* ─────────── 22. LOGO (nav + footer) ─────────── */
.brand-logo{display:flex;align-items:center;gap:14px;height:46px}
.brand-logo__mark{height:46px;width:46px;flex-shrink:0}
.brand-logo__mark img,.brand-logo__mark svg{width:100%;height:100%;display:block}
.brand-logo__text{display:flex;flex-direction:column;line-height:1;gap:2px}
.brand-logo__text strong{font-family:var(--display);font-weight:900;font-size:15px;letter-spacing:1px;color:#fff;text-transform:uppercase}
.brand-logo__text em{font-family:var(--display);font-weight:900;font-style:italic;font-size:12px;letter-spacing:2.5px;color:#fff;text-transform:uppercase;opacity:.85}

.footer-logo{width:80px;height:80px;display:block;margin:0 auto}
.footer-logo img,.footer-logo svg{width:100%;height:100%;display:block}

/* ─────────── 23. NAV REFINEMENTS (premium feel) ─────────── */
.nav__links>a{transition:.3s;position:relative}
.nav__links>a::after{content:'';position:absolute;left:50%;right:50%;bottom:-2px;height:2px;background:var(--blue);transition:.3s}
.nav__links>a:hover::after,.nav__links>a.is-active::after{left:0;right:0}

/* ─────────── 24. BUTTON REFINEMENTS (brand pill) ─────────── */
.btn--white{background:#fff;color:#000;font-weight:700}
.btn--white:hover{background:var(--blue);color:#fff;transform:translateY(-2px);box-shadow:0 16px 40px rgba(37,61,128,.5)}
.btn--ghost{border:1.5px solid #fff;color:#fff;background:transparent}
.btn--ghost:hover{background:#fff;color:#000;border-color:#fff}
.btn--blue{background:var(--blue);color:#fff;border-color:var(--blue)}
.btn--blue:hover{background:var(--blue-bright);transform:translateY(-2px);box-shadow:0 16px 40px rgba(37,61,128,.5)}

/* ─────────── 25. RESPONSIVE: BRAND ELEMENTS ─────────── */
@media (max-width:720px){
  .label-box{padding:11px 22px;font-size:15px;letter-spacing:1px;border-width:1.5px}
  .brand-logo__mark{height:40px;width:40px}
  .brand-logo__text strong{font-size:14px}
  .brand-logo__text em{font-size:10px}
}

/* Force display font weight defaults across legacy headings */
h1,h2,h3,h4{font-family:var(--display);font-weight:900}
