/* ============================================================
   TIMEOUT — High-Performance Identity
   ============================================================ */

:root{
  /* Surface */
  --surface:#121414;
  --surface-bright:#383939;
  --surface-container-lowest:#0d0e0f;
  --surface-container-low:#1b1c1c;
  --surface-container:#1f2020;
  --surface-container-high:#292a2a;
  --surface-container-highest:#343535;

  /* Text */
  --on-surface:#e3e2e2;
  --on-surface-variant:#d2c4b8;
  --outline:#9b8f84;
  --outline-variant:#4e453c;

  /* Brand */
  --primary:#e6c098;
  --primary-dim:#b18f6a;
  --primary-deep:#765938;
  --on-primary:#432c0f;
  --gold-accent:#d4af37;

  /* Radius */
  --r-sm:.25rem;
  --r:.5rem;
  --r-md:.75rem;
  --r-lg:1rem;
  --r-xl:1.5rem;
  --r-full:9999px;

  /* Spacing */
  --gutter:32px;
  --margin:80px;

  /* Type */
  --f-display:'Sora',sans-serif;
  --f-body:'Lexend',sans-serif;
}

/* =================== PRELOADER =================== */
.preloader{
  position:fixed; inset:0; z-index:9999;
  background:#000;
  display:flex; align-items:center; justify-content:center;
  transition: opacity .8s ease, visibility .8s ease;
  overflow:hidden;
}
.preloader::before{
  content:"";
  position:absolute; inset:0;
  background-image: radial-gradient(rgba(177,143,106,.18) 1px, transparent 1.4px);
  background-size: 14px 14px;
  opacity:.4;
  mask-image: radial-gradient(circle at center, #000, transparent 75%);
  -webkit-mask-image: radial-gradient(circle at center, #000, transparent 75%);
  pointer-events:none;
}
.preloader.hidden{ opacity:0; visibility:hidden; }
.preloader-inner{
  text-align:center;
  position:relative; z-index:1;
  padding:0 24px;
  max-width:520px;
}
.preloader-logo{
  height:96px; width:auto;
  margin:0 auto 32px;
  display:block;
  animation: preloaderPulse 2.4s ease-in-out infinite;
}
@keyframes preloaderPulse{
  0%,100%{ opacity:.85; transform:scale(1); }
  50%{ opacity:1; transform:scale(1.04); }
}
.preloader-warning{
  display:inline-flex; align-items:center; gap:14px;
  padding:10px 22px;
  border:1px solid var(--primary-dim);
  border-radius:var(--r-full);
  margin-bottom:20px;
}
.preloader-text{
  font-family:'Sora',sans-serif;
  font-size:13px;
  font-weight:600;
  letter-spacing:.28em;
  color:var(--primary);
  text-transform:uppercase;
}
.preloader-dot{
  width:6px; height:6px;
  border-radius:50%;
  background:var(--primary);
  animation: preloaderBlink 1.4s ease-in-out infinite;
}
.preloader-dot:last-child{ animation-delay:.7s; }
@keyframes preloaderBlink{
  0%,100%{ opacity:.25; transform:scale(1); }
  50%{ opacity:1; transform:scale(1.3); }
}
.preloader-sub{
  font-family:'Lexend',sans-serif;
  font-size:13px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#9b8f84;
  margin-bottom:28px;
}
.preloader-bar{
  width:240px; max-width:80%;
  height:2px;
  background:rgba(155,143,132,.2);
  margin:0 auto;
  overflow:hidden;
  border-radius:var(--r-full);
}
.preloader-bar-fill{
  width:30%; height:100%;
  background: linear-gradient(90deg, transparent, #e6c098, transparent);
  animation: preloaderSlide 1.6s ease-in-out infinite;
}
@keyframes preloaderSlide{
  0%{ transform: translateX(-120%); }
  100%{ transform: translateX(420%); }
}
/* Prevent body scroll while preloader is up */
body.loading{ overflow:hidden; }

/* =================== RESET =================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--f-body);
  font-size:16px;
  line-height:1.6;
  color:var(--on-surface);
  background:#000;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none;transition:color .2s ease,opacity .2s ease}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,textarea,select{font:inherit;color:inherit}
::selection{background:var(--primary);color:var(--on-primary)}

/* =================== LAYOUT =================== */
.container{
  width:100%;
  max-width:1280px;
  margin:0 auto;
  padding:0 var(--margin);
}
@media (max-width:900px){
  :root{ --margin:24px; --gutter:16px; }
}

.section{
  padding: clamp(72px,9vw,140px) 0;
  position:relative;
  isolation:isolate;
  background:
    radial-gradient(ellipse 80% 60% at 50% 0%, rgba(177,143,106,.06) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 50% 100%, rgba(118,89,56,.05) 0%, transparent 60%),
    linear-gradient(180deg, #0a0b0b 0%, #101212 50%, #0a0b0b 100%);
}
.section-alt{
  background:
    radial-gradient(ellipse 70% 60% at 0% 50%, rgba(177,143,106,.05) 0%, transparent 60%),
    radial-gradient(ellipse 70% 60% at 100% 50%, rgba(212,175,55,.04) 0%, transparent 60%),
    linear-gradient(180deg, #0d0e0f 0%, #131516 50%, #0d0e0f 100%);
}

/* Dotted grid base — visible on every section, faint by default */
.section::before{
  content:"";
  position:absolute; inset:0;
  background-image: radial-gradient(rgba(177,143,106,.10) 1px, transparent 1.2px);
  background-size: 22px 22px;
  background-position: 0 0;
  opacity:.45;
  pointer-events:none;
  z-index:0;
  mask-image: linear-gradient(180deg, transparent, #000 18%, #000 82%, transparent);
  -webkit-mask-image: linear-gradient(180deg, transparent, #000 18%, #000 82%, transparent);
}

/* Cursor spotlight layer — brighter dots within a radius of the pointer */
.section::after{
  content:"";
  position:absolute; inset:0;
  background-image: radial-gradient(rgba(230,192,152,.55) 1.2px, transparent 1.6px);
  background-size: 22px 22px;
  pointer-events:none;
  z-index:0;
  opacity:0;
  transition: opacity .35s ease;
  mask-image: radial-gradient(circle 180px at var(--mx, 50%) var(--my, 50%), #000 0%, rgba(0,0,0,.6) 35%, transparent 70%);
  -webkit-mask-image: radial-gradient(circle 180px at var(--mx, 50%) var(--my, 50%), #000 0%, rgba(0,0,0,.6) 35%, transparent 70%);
}
.section:hover::after{ opacity:1; }

/* Make sure section content sits above the dot layers */
.section > .container{ position:relative; z-index:1; }

/* The alt section gets a slightly different background-position so the dots don't visually align with the previous section */
.section-alt::before{ background-position: 11px 11px; }

/* =================== TYPOGRAPHY =================== */
.eyebrow{
  display:inline-block;
  font-family:var(--f-body);
  font-size:12px;
  font-weight:500;
  letter-spacing:.25em;
  color:var(--primary);
  text-transform:uppercase;
  margin-bottom:1rem;
  padding-bottom:.5rem;
  position:relative;
}
.eyebrow::after{
  content:"";
  position:absolute; left:0; bottom:0;
  width:32px; height:1px;
  background:var(--primary);
}

.headline{
  font-family:var(--f-display);
  font-size:clamp(28px, 4vw, 48px);
  font-weight:600;
  line-height:1.1;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--on-surface);
}
.headline .accent{ color:var(--primary); }

.prose p{
  font-size:18px;
  color:var(--on-surface-variant);
  margin-bottom:1rem;
  max-width:54ch;
}
.prose p:last-child{ margin-bottom:0; }

/* =================== BUTTONS =================== */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:.5rem;
  padding:14px 28px;
  border-radius:var(--r-full);
  font-family:var(--f-body);
  font-weight:500;
  font-size:14px;
  letter-spacing:.15em;
  text-transform:uppercase;
  transition:transform .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
  border:1.5px solid transparent;
  white-space:nowrap;
  cursor:pointer;
}
.btn-sm{ padding:10px 20px; font-size:12px; }
.btn-primary{
  background:var(--primary-dim);
  color:#0a0a0a;
}
.btn-primary:hover{ background:var(--primary); transform:translateY(-2px); }
.btn-ghost{
  border-color:var(--primary-dim);
  color:var(--on-surface);
  background:transparent;
}
.btn-ghost:hover{ background:rgba(177,143,106,.1); border-color:var(--primary); color:var(--primary); }
.btn.full{ width:100%; }

/* =================== HEADER =================== */
.site-header{
  position:fixed; top:0; left:0; right:0;
  z-index:100;
  padding:18px 0;
  background:rgba(13,14,15,.65);
  backdrop-filter: blur(16px) saturate(140%);
  -webkit-backdrop-filter: blur(16px) saturate(140%);
  border-bottom:1px solid transparent;
  transition: background .3s, border-color .3s, padding .3s;
}
.site-header.scrolled{
  background:rgba(13,14,15,.9);
  border-bottom-color:rgba(155,143,132,.12);
  padding:12px 0;
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  gap:24px;
}
.brand img{ height:38px; width:auto; }
.brand-logo-mobile{ display:none; }
@media (max-width:900px){
  .brand-logo-desktop{ display:none; }
  .brand-logo-mobile{ display:block; height:42px; }
}

.nav-desktop{ display:flex; gap:32px; }
.nav-desktop a{
  font-size:13px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--on-surface-variant);
  position:relative;
  padding:6px 0;
}
.nav-desktop a:hover{ color:var(--primary); }
.nav-desktop a::after{
  content:""; position:absolute; left:0; bottom:0;
  width:0; height:1px; background:var(--primary);
  transition:width .25s ease;
}
.nav-desktop a:hover::after{ width:100%; }

.header-actions{ display:flex; align-items:center; gap:12px; }

.menu-toggle{
  display:none;
  width:40px; height:40px;
  flex-direction:column; align-items:center; justify-content:center;
  gap:5px;
}
.menu-toggle span{
  display:block; width:22px; height:1.5px;
  background:var(--on-surface);
  transition:transform .25s ease, opacity .2s ease;
}
.menu-toggle.open span:nth-child(1){ transform:translateY(6.5px) rotate(45deg); }
.menu-toggle.open span:nth-child(2){ opacity:0; }
.menu-toggle.open span:nth-child(3){ transform:translateY(-6.5px) rotate(-45deg); }

@media (max-width:900px){
  .nav-desktop{ display:none; }
  .menu-toggle{ display:flex; }
  .header-actions .btn{ display:none; }
}

.nav-mobile{
  position:fixed; top:0; right:0;
  width:min(86vw,360px); height:100vh;
  background:var(--surface-container-lowest);
  border-left:1px solid var(--outline-variant);
  padding:100px 32px 32px;
  display:flex; flex-direction:column; gap:20px;
  transform:translateX(100%);
  transition: transform .35s cubic-bezier(.6,.05,.3,1);
  z-index:99;
}
.nav-mobile.open{ transform:translateX(0); }
.nav-mobile a{
  font-size:16px; letter-spacing:.15em;
  text-transform:uppercase;
  padding:12px 0;
  border-bottom:1px solid var(--outline-variant);
}
.nav-mobile a.btn{ border-bottom:none; margin-top:16px; }

/* =================== HERO =================== */
.hero{
  position:relative;
  min-height:100vh;
  display:flex; align-items:center;
  padding:140px 0 80px;
  overflow:hidden;
  isolation:isolate;
}
.hero-bg{
  position:absolute; inset:0;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  background-color: #000;
  z-index:-2;
  animation: slowFade 14s ease-in-out infinite alternate;
}
@keyframes slowFade{
  0%{ opacity:.9; }
  100%{ opacity:1; }
}
/* On very wide / very narrow screens, cover-fit so we don't get huge black bars */
@media (min-aspect-ratio: 21/9){
  .hero-bg{ background-size: cover; }
}
@media (max-width: 700px){
  .hero-bg{ background-size: cover; background-position: center 30%; }
}

.hero-overlay{
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse at center, rgba(0,0,0,.15) 0%, rgba(0,0,0,.55) 70%, rgba(0,0,0,.85) 100%),
    linear-gradient(180deg, rgba(0,0,0,.25) 0%, rgba(0,0,0,.15) 40%, rgba(0,0,0,.95) 100%);
  z-index:-1;
}

.hero-content{ position:relative; z-index:2; max-width:900px; }
.hero-title{
  font-family:var(--f-display);
  font-size: clamp(40px, 7vw, 88px);
  line-height:1;
  letter-spacing:.06em;
  font-weight:600;
  text-transform:uppercase;
  margin: 1rem 0 1.5rem;
}
.hero-sub{
  font-size: clamp(16px, 1.5vw, 19px);
  color:var(--on-surface-variant);
  max-width:560px;
  margin-bottom:2.5rem;
}
.hero-cta{ display:flex; gap:12px; flex-wrap:wrap; margin-bottom:4rem; }
.hero-meta{
  display:flex; flex-wrap:wrap; gap: clamp(24px, 5vw, 60px);
  padding-top:2rem;
  border-top:1px solid var(--outline-variant);
}
.hero-meta > div{ display:flex; flex-direction:column; }
.hero-meta strong{
  font-family:var(--f-display);
  font-size:28px;
  font-weight:600;
  color:var(--primary);
  letter-spacing:.05em;
}
.hero-meta span{
  font-size:11px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--on-surface-variant);
  margin-top:4px;
}

.scroll-cue{
  position:absolute; bottom:24px; left:50%;
  transform:translateX(-50%);
  width:24px; height:38px;
  border:1px solid var(--outline);
  border-radius:var(--r-full);
  display:flex; justify-content:center;
  padding-top:8px;
}
.scroll-cue span{
  display:block; width:2px; height:8px;
  background:var(--primary);
  border-radius:var(--r-full);
  animation: cue 1.6s ease-in-out infinite;
}
@keyframes cue{
  0%{ transform:translateY(0); opacity:1;}
  100%{ transform:translateY(12px); opacity:0;}
}

/* =================== GRID HELPERS =================== */
.grid-2{
  display:grid;
  grid-template-columns: minmax(0,1fr) minmax(0,1fr);
  gap: clamp(32px, 5vw, 80px);
  align-items:start;
  margin-bottom: clamp(48px, 8vw, 96px);
}
@media (max-width:800px){
  .grid-2{ grid-template-columns:1fr; gap:24px; }
}

.section-head{ margin-bottom: clamp(40px, 6vw, 80px); }
.section-head.center{ text-align:center; }
.section-head.center .eyebrow{ padding-bottom:.5rem; }
.section-head.center .eyebrow::after{ left:50%; transform:translateX(-50%); }

/* =================== FEATURE CARDS =================== */
.feature-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:24px;
}
@media (max-width:900px){ .feature-grid{ grid-template-columns:1fr; } }

.feature-card{
  position:relative;
  background: linear-gradient(135deg, rgba(255,255,255,.04) 0%, rgba(255,255,255,.015) 100%);
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--r-lg);
  padding:40px 32px;
  overflow:hidden;
  transition: transform .3s ease, border-color .3s ease, background .3s ease, box-shadow .3s ease;
  box-shadow:
    inset 0 1px 0 0 rgba(255,255,255,.06),
    0 8px 32px -12px rgba(0,0,0,.6);
}
.feature-card::before{
  content:"";
  position:absolute; inset:0;
  background-image: radial-gradient(rgba(177,143,106,.18) 1px, transparent 1.4px);
  background-size: 12px 12px;
  opacity:.4;
  mask-image: radial-gradient(circle at top right, #000, transparent 70%);
  -webkit-mask-image: radial-gradient(circle at top right, #000, transparent 70%);
  pointer-events:none;
}
.feature-card:hover{
  transform:translateY(-4px);
  border-color: rgba(230,192,152,.4);
  background: linear-gradient(135deg, rgba(230,192,152,.07) 0%, rgba(255,255,255,.02) 100%);
  box-shadow:
    inset 0 1px 0 0 rgba(255,255,255,.1),
    0 16px 40px -12px rgba(0,0,0,.7),
    0 0 40px -10px rgba(230,192,152,.25);
}
.feature-num{
  font-family:var(--f-display);
  font-size:48px;
  font-weight:600;
  color:var(--primary);
  letter-spacing:.05em;
  margin-bottom:16px;
  opacity:.6;
}
.feature-card h3{
  font-family:var(--f-display);
  font-size:18px;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  margin-bottom:12px;
}
.feature-card p{ color:var(--on-surface-variant); font-size:15px; }

/* =================== TRAINING ZONES =================== */
.zones-section{
  background:
    radial-gradient(ellipse 60% 50% at 50% 0%, rgba(230,192,152,.05) 0%, transparent 60%),
    radial-gradient(ellipse 50% 40% at 50% 100%, rgba(118,89,56,.04) 0%, transparent 60%),
    linear-gradient(180deg, #0a0a0a 0%, #0e1010 50%, #0a0a0a 100%);
}
.zones-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:24px;
}
@media (max-width:900px){ .zones-grid{ grid-template-columns:1fr; } }

.zone-card{
  position:relative;
  aspect-ratio: 3 / 4;
  border-radius:var(--r-lg);
  overflow:hidden;
  border:1px solid rgba(255,255,255,.08);
  cursor:pointer;
  isolation:isolate;
  transition:
    transform .6s cubic-bezier(.2,.7,.2,1),
    box-shadow .6s cubic-bezier(.2,.7,.2,1),
    border-color .6s ease;
  background:#0a0a0a;
  box-shadow:
    inset 0 1px 0 0 rgba(255,255,255,.05),
    0 12px 36px -16px rgba(0,0,0,.7);
}
.zone-card-bg{
  position:absolute; inset:0;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  transition: transform .8s cubic-bezier(.2,.7,.2,1), filter .6s ease, opacity .6s ease;
  filter: brightness(1) contrast(1.05) saturate(1.05);
  opacity:1;
  z-index:0;
}
.zone-card-overlay{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 45%, rgba(0,0,0,.55) 75%, rgba(0,0,0,.9) 100%);
  z-index:1;
  transition: opacity .6s ease, background .6s ease;
}
.zone-card-content{
  position:absolute; left:0; right:0; bottom:0;
  padding:32px 28px;
  z-index:2;
  display:flex; flex-direction:column;
  gap:14px;
  transform: translateY(0);
  transition: transform .6s cubic-bezier(.2,.7,.2,1);
}
.zone-mark{
  font-family:var(--f-display);
  font-size:10px;
  letter-spacing:.35em;
  color:var(--primary);
  text-transform:uppercase;
  opacity:.85;
  text-shadow: 0 1px 8px rgba(0,0,0,.7);
}
.zone-card h3{
  font-family:var(--f-display);
  font-size: clamp(28px, 3.2vw, 40px);
  font-weight:600;
  letter-spacing:.12em;
  line-height:.95;
  text-transform:uppercase;
  color:#fff;
  text-shadow: 0 2px 16px rgba(0,0,0,.85), 0 1px 2px rgba(0,0,0,.9);
}
.zone-card p{
  font-size:14px;
  color: rgba(255,255,255,.9);
  text-shadow: 0 1px 8px rgba(0,0,0,.9);
  max-width:42ch;
  opacity:0;
  max-height:0;
  overflow:hidden;
  transform: translateY(8px);
  transition: opacity .5s ease, transform .5s ease, max-height .5s ease;
}

/* Glow + rise on hover */
.zone-card:hover{
  transform: translateY(-12px);
  border-color: var(--primary);
  box-shadow:
    0 24px 48px -16px rgba(0,0,0,.7),
    0 0 0 1px rgba(230,192,152,.35),
    0 0 64px -8px rgba(230,192,152,.45),
    0 0 120px -20px rgba(212,175,55,.35);
}
.zone-card:hover .zone-card-bg{
  transform: scale(1.06);
  filter: brightness(1.25) contrast(1.1) saturate(1.15);
}
.zone-card:hover .zone-card-overlay{
  background:
    linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 55%, rgba(0,0,0,.4) 80%, rgba(0,0,0,.85) 100%);
}
.zone-card:hover .zone-card-content{ transform: translateY(-4px); }
.zone-card:hover p{
  opacity:1;
  max-height:120px;
  transform: translateY(0);
}

@media (hover:none){
  .zone-card p{ opacity:1; max-height:120px; transform:none; }
}

/* =================== PROGRAM CARDS =================== */
.program-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:24px;
}
@media (max-width:700px){ .program-grid{ grid-template-columns:1fr; } }
.program-card{
  position:relative;
  padding:48px 40px;
  background: linear-gradient(135deg, rgba(255,255,255,.035) 0%, rgba(255,255,255,.01) 100%);
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  border-radius:var(--r-lg);
  border:1px solid rgba(255,255,255,.07);
  box-shadow:
    inset 0 1px 0 0 rgba(255,255,255,.05),
    0 8px 32px -12px rgba(0,0,0,.5);
  transition: background .3s, border-color .3s, transform .3s, box-shadow .3s;
}
.program-card:hover{
  background: linear-gradient(135deg, rgba(230,192,152,.08) 0%, rgba(255,255,255,.02) 100%);
  border-color: rgba(230,192,152,.4);
  transform:translateY(-4px);
  box-shadow:
    inset 0 1px 0 0 rgba(255,255,255,.1),
    0 16px 40px -12px rgba(0,0,0,.7),
    0 0 40px -10px rgba(230,192,152,.25);
}
.program-tag{
  display:inline-block;
  padding:4px 12px;
  border:1px solid var(--primary-dim);
  border-radius:var(--r-full);
  font-size:10px;
  letter-spacing:.2em;
  color:var(--primary);
  text-transform:uppercase;
  margin-bottom:24px;
}
.program-card h3{
  font-family:var(--f-display);
  font-size:24px;
  letter-spacing:.08em;
  margin-bottom:12px;
}
.program-card p{ color:var(--on-surface-variant); margin-bottom:24px; }
.link-arrow{
  color:var(--primary);
  font-size:13px;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:500;
}
.link-arrow:hover{ color:var(--on-surface); }

/* =================== STATS =================== */
.stats-row{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
  text-align:center;
}
@media (max-width:700px){ .stats-row{ grid-template-columns:repeat(2,1fr); } }
.stat{
  padding:32px 16px;
  background: linear-gradient(135deg, rgba(255,255,255,.035) 0%, rgba(255,255,255,.01) 100%);
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  border:1px solid rgba(255,255,255,.07);
  border-radius:var(--r-lg);
  box-shadow:
    inset 0 1px 0 0 rgba(255,255,255,.05),
    0 8px 24px -12px rgba(0,0,0,.5);
  transition: transform .3s ease, border-color .3s ease;
}
.stat:hover{
  transform: translateY(-2px);
  border-color: rgba(230,192,152,.3);
}
.stat-num{
  font-family:var(--f-display);
  font-size: clamp(36px, 5vw, 56px);
  font-weight:600;
  color:var(--primary);
  letter-spacing:.05em;
  line-height:1;
}
.stat-label{
  margin-top:8px;
  font-size:11px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--on-surface-variant);
}

/* =================== PRICING =================== */
.price-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  align-items:stretch;
}
@media (max-width:900px){ .price-grid{ grid-template-columns:1fr; } }
.price-card{
  position:relative;
  background: linear-gradient(135deg, rgba(255,255,255,.04) 0%, rgba(255,255,255,.015) 100%);
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--r-lg);
  padding:40px 32px;
  display:flex; flex-direction:column;
  box-shadow:
    inset 0 1px 0 0 rgba(255,255,255,.06),
    0 8px 32px -12px rgba(0,0,0,.6);
  transition: transform .3s, border-color .3s, background .3s, box-shadow .3s;
}
.price-card:hover{
  transform:translateY(-4px);
  border-color: rgba(230,192,152,.35);
  box-shadow:
    inset 0 1px 0 0 rgba(255,255,255,.1),
    0 16px 40px -12px rgba(0,0,0,.7),
    0 0 40px -10px rgba(230,192,152,.2);
}
.price-card.featured{
  border-color: rgba(230,192,152,.45);
  background: linear-gradient(135deg, rgba(230,192,152,.1) 0%, rgba(255,255,255,.025) 100%);
  transform:scale(1.02);
  box-shadow:
    inset 0 1px 0 0 rgba(255,255,255,.1),
    0 16px 48px -16px rgba(0,0,0,.7),
    0 0 60px -12px rgba(230,192,152,.25);
}
.price-card.featured:hover{ transform: scale(1.02) translateY(-4px); }
.ribbon{
  position:absolute; top:-12px; left:50%;
  transform:translateX(-50%);
  background:var(--primary);
  color:var(--on-primary);
  font-size:10px;
  font-weight:600;
  letter-spacing:.2em;
  padding:6px 14px;
  border-radius:var(--r-full);
  text-transform:uppercase;
}
.price-card header{ margin-bottom:24px; padding-bottom:24px; border-bottom:1px solid var(--outline-variant); }
.price-card h3{
  font-family:var(--f-display);
  font-size:18px;
  letter-spacing:.18em;
  margin-bottom:16px;
}
.price-card .price{
  font-family:var(--f-display);
  font-size:48px;
  font-weight:600;
  color:var(--primary);
  letter-spacing:.02em;
}
.price-card .price span{ font-size:24px; vertical-align:top; margin-right:4px; }
.price-card .price small{ font-size:14px; color:var(--on-surface-variant); font-weight:400; margin-left:4px; }
.price-card .price-na{
  font-size:40px;
  letter-spacing:.12em;
  color:var(--on-surface-variant);
  opacity:.85;
}
.price-card ul{
  list-style:none;
  flex:1;
  margin-bottom:24px;
}
.price-card li{
  padding:10px 0 10px 24px;
  position:relative;
  color:var(--on-surface-variant);
  font-size:15px;
  border-bottom:1px solid rgba(155,143,132,.1);
}
.price-card li::before{
  content:"";
  position:absolute; left:0; top:18px;
  width:10px; height:1.5px;
  background:var(--primary);
}

/* =================== CTA / CONTACT =================== */
.cta-section{ background:var(--surface-container-lowest); position:relative; }
.cta-inner{ max-width:760px; margin:0 auto; text-align:center; }
.cta-inner .prose{ margin: 16px auto 40px; }
.cta-inner .prose p{ margin:0 auto; }

.contact-form{
  text-align:left;
  display:flex; flex-direction:column;
  gap:20px;
  margin-top:32px;
  padding:40px;
  background: linear-gradient(135deg, rgba(255,255,255,.04) 0%, rgba(255,255,255,.015) 100%);
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--r-lg);
  box-shadow:
    inset 0 1px 0 0 rgba(255,255,255,.06),
    0 8px 32px -12px rgba(0,0,0,.6);
}
@media (max-width:600px){ .contact-form{ padding:24px; } }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media (max-width:600px){ .form-row{ grid-template-columns:1fr; } }
.contact-form label{ display:flex; flex-direction:column; gap:8px; }
.contact-form label.full-width{ grid-column:1/-1; }
.contact-form span{
  font-size:11px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--on-surface-variant);
}
.contact-form input,
.contact-form select,
.contact-form textarea{
  background: rgba(0,0,0,.35);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--r);
  padding:14px 16px;
  color:var(--on-surface);
  font-size:15px;
  transition:border-color .2s, box-shadow .2s, background .2s;
  resize:vertical;
  width:100%;
}
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus{
  outline:none;
  border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(230,192,152,.15);
}
.contact-form button{ align-self:flex-start; margin-top:8px; }
.form-success{
  margin-top:8px;
  color:var(--primary);
  font-size:14px;
  letter-spacing:.05em;
}

/* =================== FOOTER =================== */
.site-footer{
  background:#000;
  padding:80px 0 24px;
  border-top:1px solid var(--outline-variant);
}
.footer-inner{
  display:grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap:48px;
  margin-bottom:48px;
}
@media (max-width:900px){
  .footer-inner{ grid-template-columns: 1fr 1fr; }
}
@media (max-width:520px){
  .footer-inner{ grid-template-columns: 1fr; gap:32px; }
}
.footer-brand img{ height:32px; margin-bottom:16px; width:auto; }
.footer-brand p{ color:var(--on-surface-variant); font-size:14px; }
.footer-col h4{
  font-family:var(--f-display);
  font-size:12px;
  letter-spacing:.25em;
  color:var(--primary);
  text-transform:uppercase;
  margin-bottom:20px;
  font-weight:600;
}
.footer-col a,
.footer-col span{
  display:block;
  color:var(--on-surface-variant);
  font-size:14px;
  padding:6px 0;
  transition:color .2s;
}
.footer-col a:hover{ color:var(--primary); }
.social-disabled{
  display:block;
  color:var(--outline);
  font-size:14px;
  padding:6px 0;
  cursor:not-allowed;
  opacity:.55;
}
.social-disabled em{
  font-style:normal;
  font-size:10px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--primary);
  margin-left:6px;
  opacity:.8;
}
.footer-bottom{
  display:flex; justify-content:space-between;
  padding-top:24px;
  border-top:1px solid var(--outline-variant);
  color:var(--on-surface-variant);
  font-size:12px;
  letter-spacing:.1em;
}
.footer-bottom{ justify-content:center; }
@media (max-width:520px){
  .footer-bottom{ flex-direction:column; gap:12px; text-align:center; }
}

/* =================== REVEAL ANIMATIONS =================== */
.reveal{
  opacity:0;
  transform:translateY(24px);
  transition: opacity .8s ease, transform .8s ease;
}
.reveal.visible{ opacity:1; transform:none; }

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{ animation-duration:0.001ms !important; transition-duration:0.001ms !important; }
  .hero-bg{ animation:none; }
}
