/* ============================================================
   SoulGate — tarot & light
   Paleta celestial: azul noche + dorado
   ============================================================ */

:root{
  --bg:        #05060f;
  --bg-2:      #090d20;
  --bg-3:      #0c1330;
  --blue:      #13245e;
  --blue-soft: #1c336f;
  --blue-glow: #2c53c9;
  --gold:      #d9b45a;
  --gold-2:    #c99f45;
  --gold-bright:#f4dd9a;
  --text:      #efeadb;
  --muted:     #a6adcf;
  --muted-2:   #949bc0;
  --line:      rgba(217,180,90,.22);
  --line-soft: rgba(255,255,255,.08);

  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans:  'Jost', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;

  --wrap: 1120px;
  --radius: 16px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{ box-sizing:border-box; }

html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--sans);
  font-weight:300;
  line-height:1.65;
  letter-spacing:.01em;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* Ambient starfield behind everything */
body::before{
  content:"";
  position:fixed; inset:0;
  z-index:-2;
  background:
    radial-gradient(1200px 700px at 50% -10%, rgba(44,83,201,.18), transparent 60%),
    radial-gradient(900px 600px at 85% 110%, rgba(217,180,90,.06), transparent 60%),
    linear-gradient(180deg, var(--bg) 0%, var(--bg-2) 55%, var(--bg) 100%);
}
body::after{
  content:"";
  position:fixed; inset:0;
  z-index:-1;
  background-image:
    radial-gradient(1px 1px at 20% 30%, rgba(255,255,255,.55), transparent),
    radial-gradient(1px 1px at 70% 20%, rgba(255,255,255,.4), transparent),
    radial-gradient(1px 1px at 40% 70%, rgba(255,255,255,.35), transparent),
    radial-gradient(1.4px 1.4px at 85% 55%, rgba(255,255,255,.5), transparent),
    radial-gradient(1px 1px at 12% 80%, rgba(255,255,255,.3), transparent),
    radial-gradient(1.2px 1.2px at 60% 85%, rgba(255,255,255,.4), transparent);
  opacity:.5;
  animation:twinkle 7s ease-in-out infinite alternate;
}
@keyframes twinkle{ from{opacity:.32} to{opacity:.6} }
@media (prefers-reduced-motion: reduce){ body::after{ animation:none; } }

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

/* Foco visible para navegación por teclado (accesibilidad) */
:focus-visible{ outline:2px solid var(--gold-bright); outline-offset:3px; border-radius:6px; }
.btn:focus-visible{ outline:2px solid var(--gold-bright); outline-offset:4px; }

.wrap{ width:100%; max-width:var(--wrap); margin:0 auto; padding:0 22px; }
.wrap-narrow{ max-width:780px; }

.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;
}

/* ---------- Typography helpers ---------- */
.eyebrow{
  font-family:var(--sans);
  text-transform:lowercase;
  letter-spacing:.42em;
  font-size:.8rem;
  color:var(--gold-bright);
  margin:0 0 1.1rem;
  padding-left:.42em;
  text-shadow:0 1px 18px rgba(5,6,15,.8);
}
.kicker{
  display:flex; align-items:center; gap:.6rem;
  font-family:var(--sans);
  text-transform:uppercase;
  letter-spacing:.26em;
  font-size:.72rem;
  color:var(--gold);
  margin:0 0 1rem;
}
.kicker.center{ justify-content:center; text-align:center; }
.kicker.light{ color:var(--gold-bright); }
.kicker-num{
  font-family:var(--serif);
  font-size:.95rem;
  letter-spacing:0;
  color:var(--muted-2);
  border:1px solid var(--line);
  border-radius:50%;
  width:1.9em; height:1.9em;
  display:inline-flex; align-items:center; justify-content:center;
}
.h2{
  font-family:var(--serif);
  font-weight:500;
  font-size:clamp(1.9rem, 6vw, 3rem);
  line-height:1.1;
  letter-spacing:.005em;
  margin:0;
  color:var(--text);
}
.h2.light{ color:#fff; }
.lede{
  font-family:var(--serif);
  font-size:clamp(1.15rem, 3.4vw, 1.4rem);
  line-height:1.55;
  color:var(--muted);
  margin:1.3rem 0 0;
}

.section{ padding:clamp(72px, 12vw, 130px) 0; position:relative; }
.section-alt{ background:linear-gradient(180deg, transparent, rgba(12,19,48,.55), transparent); }
.section-head{ margin-bottom:clamp(38px, 6vw, 60px); }
.section-head.center{ text-align:center; }
.section-head.center .h2{ max-width:16ch; margin-inline:auto; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:.5rem;
  font-family:var(--sans); font-weight:400;
  letter-spacing:.06em;
  font-size:.95rem;
  padding:.95rem 1.9rem;
  border-radius:999px;
  border:1px solid transparent;
  cursor:pointer;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease), background .3s, color .3s;
  white-space:nowrap;
}
.btn-sm{ padding:.6rem 1.2rem; font-size:.82rem; }
.btn-gold{
  background:linear-gradient(135deg, var(--gold-bright), var(--gold) 55%, var(--gold-2));
  color:#1a1405;
  box-shadow:0 8px 30px -8px rgba(217,180,90,.5);
}
.btn-gold:hover{ transform:translateY(-2px); box-shadow:0 14px 40px -10px rgba(217,180,90,.65); }
.btn-ghost{
  background:rgba(255,255,255,.03);
  border-color:var(--line);
  color:var(--text);
}
.btn-ghost:hover{ border-color:var(--gold); color:var(--gold-bright); transform:translateY(-2px); }

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:50;
  transition:background .4s var(--ease), backdrop-filter .4s, border-color .4s;
  border-bottom:1px solid transparent;
}
.site-header:not(.scrolled){
  background:linear-gradient(180deg, rgba(5,6,15,.55), rgba(5,6,15,0));
}
.site-header.scrolled{
  background:rgba(5,6,15,.82);
  backdrop-filter:blur(14px);
  border-bottom-color:var(--line-soft);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  height:68px;
}
.brand{ display:inline-flex; align-items:baseline; gap:.5rem; transition:opacity .4s var(--ease); }
/* El hero ya muestra el wordmark grande; ocultamos el del header hasta hacer scroll */
.site-header:not(.scrolled) .brand{ opacity:0; pointer-events:none; }
.brand-star{ color:var(--gold); font-size:.9rem; transform:translateY(-1px); }
.brand-word{
  font-family:var(--serif);
  font-weight:600;
  letter-spacing:.24em;
  font-size:1.15rem;
  color:var(--gold-bright);
  background:linear-gradient(180deg,#fbeeb8,#d9b45a);
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent;
  padding-left:.12em;
}
.nav{ display:flex; gap:2rem; }
.nav a{
  font-size:.82rem; letter-spacing:.08em; color:var(--muted);
  position:relative; padding:.2rem 0; transition:color .3s;
  text-shadow:0 1px 12px rgba(5,6,15,.7);
}
.nav a::after{
  content:""; position:absolute; left:0; bottom:-2px; height:1px; width:0;
  background:var(--gold); transition:width .3s var(--ease);
}
.nav a:hover{ color:var(--text); }
.nav a:hover::after{ width:100%; }

.header-actions{ display:flex; align-items:center; gap:.9rem; }
.lang-toggle{
  background:none; border:1px solid var(--line); border-radius:999px;
  color:var(--muted); font-family:var(--sans); font-size:.72rem;
  letter-spacing:.12em; padding:.4rem .8rem; cursor:pointer; min-height:40px;
  display:inline-flex; gap:.35rem; align-items:center; transition:border-color .3s;
}
.lang-toggle:hover{ border-color:var(--gold); }
.lang-opt{ transition:color .3s; }
.lang-opt.is-active{ color:var(--gold-bright); }
.lang-sep{ color:var(--muted-2); }

.menu-btn{
  display:none; width:44px; height:44px; border:none; background:none; cursor:pointer;
  flex-direction:column; justify-content:center; gap:5px; padding:0;
}
.menu-btn span{ display:block; height:1.5px; width:22px; background:var(--gold-bright); margin:0 auto; transition:transform .3s var(--ease), opacity .3s; }
.menu-btn.open span:nth-child(1){ transform:translateY(6.5px) rotate(45deg); }
.menu-btn.open span:nth-child(2){ opacity:0; }
.menu-btn.open span:nth-child(3){ transform:translateY(-6.5px) rotate(-45deg); }

/* Mobile menu */
.mobile-menu{
  position:fixed; inset:0; z-index:45;
  background:rgba(5,6,15,.97); backdrop-filter:blur(10px);
  display:flex; align-items:center; justify-content:center;
  opacity:0; transition:opacity .35s var(--ease);
}
.mobile-menu.show{ opacity:1; }
.mobile-menu nav{ display:flex; flex-direction:column; gap:1.4rem; text-align:center; }
.mobile-menu nav a{ font-family:var(--serif); font-size:1.6rem; color:var(--text); letter-spacing:.02em; padding:.4rem 1.2rem; min-height:44px; display:flex; align-items:center; justify-content:center; }
.mobile-menu nav a.btn{ font-family:var(--sans); font-size:1rem; margin-top:.8rem; }

/* ============================================================
   1. HERO
   ============================================================ */
.hero{
  position:relative;
  min-height:100svh;
  display:flex; flex-direction:column; justify-content:flex-end;
  padding-bottom:clamp(70px, 14vh, 130px);
  overflow:hidden;
}
.hero-bg{
  position:absolute; inset:0;
  background:url("img/hero-gate.jpg") center 34% / cover no-repeat;
  transform:scale(1.05);
  animation:heroDrift 26s ease-in-out infinite alternate;
}
@keyframes heroDrift{ from{ transform:scale(1.05) translateY(0); } to{ transform:scale(1.12) translateY(-14px); } }
@media (prefers-reduced-motion: reduce){ .hero-bg{ animation:none; transform:none; } }
.hero-veil{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(5,6,15,.5) 0%, rgba(5,6,15,.22) 22%, rgba(5,6,15,.5) 52%, rgba(5,6,15,.9) 82%, var(--bg) 100%),
    radial-gradient(115% 80% at 50% 118%, rgba(5,6,15,.9), transparent 66%);
}
.hero-content{ position:relative; z-index:2; max-width:760px; }
.hero-title{
  font-family:var(--serif);
  font-weight:500;
  font-size:clamp(2.5rem, 9vw, 4.6rem);
  line-height:1.05;
  letter-spacing:.01em;
  margin:0;
  color:#fff;
  text-shadow:0 2px 40px rgba(0,0,0,.5);
}
.hero-sub{
  font-size:clamp(1rem, 2.6vw, 1.18rem);
  color:#cfd4ee;
  max-width:52ch;
  margin:1.5rem 0 0;
  font-weight:300;
  text-shadow:0 1px 24px rgba(5,6,15,.9);
}
.hero-cta{ display:flex; flex-wrap:wrap; gap:.9rem; margin-top:2.2rem; }

.scroll-cue{
  position:absolute; bottom:26px; left:50%; transform:translateX(-50%);
  width:26px; height:42px; border:1px solid var(--line); border-radius:999px; z-index:2;
  display:flex; justify-content:center; padding-top:8px;
}
.scroll-cue-dot{ width:3px; height:8px; border-radius:2px; background:var(--gold); animation:cue 1.8s ease-in-out infinite; }
@keyframes cue{ 0%,100%{ transform:translateY(0); opacity:1 } 50%{ transform:translateY(10px); opacity:.2 } }
@media (prefers-reduced-motion: reduce){ .scroll-cue-dot{ animation:none; } }

/* ============================================================
   2. GRID (¿Qué es?)
   ============================================================ */
.grid-2{
  display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(32px, 6vw, 72px);
  align-items:center;
}
.media-frame{
  margin:0; border-radius:var(--radius); overflow:hidden; position:relative;
  border:1px solid var(--line);
  box-shadow:0 30px 80px -30px rgba(0,0,0,.8), 0 0 60px -20px rgba(44,83,201,.4);
}
.media-frame img{ width:100%; height:100%; object-fit:cover; aspect-ratio:4/5; }
.media-frame::after{
  content:""; position:absolute; inset:0;
  box-shadow:inset 0 0 60px rgba(5,6,15,.5); pointer-events:none;
}

/* ============================================================
   3. STEPS (¿Cómo funciona?)
   ============================================================ */
.steps{
  list-style:none; margin:0; padding:0;
  display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,3vw,34px);
  counter-reset:none;
}
.step{
  position:relative; text-align:center;
  padding:2.6rem 1.6rem 2.2rem;
  border:1px solid var(--line-soft); border-radius:var(--radius);
  background:linear-gradient(180deg, rgba(28,51,111,.16), rgba(12,19,48,.28));
  transition:transform .4s var(--ease), border-color .4s;
}
.step:hover{ transform:translateY(-6px); border-color:var(--line); }
.step-num{
  position:absolute; top:-18px; left:50%; transform:translateX(-50%);
  width:36px; height:36px; border-radius:50%;
  background:var(--bg); border:1px solid var(--gold);
  color:var(--gold-bright); font-family:var(--serif); font-size:1.15rem;
  display:flex; align-items:center; justify-content:center;
}
.step-icon{ display:inline-flex; color:var(--gold); margin:.4rem 0 1.1rem; }
.step-icon svg{ width:52px; height:52px; }
.step-title{ font-family:var(--serif); font-weight:500; font-size:1.5rem; margin:0 0 .6rem; color:var(--text); }
.step-text{ margin:0; font-size:.95rem; color:var(--muted); }

/* ============================================================
   4. CATEGORIES (¿Para qué?)
   ============================================================ */
.cats{
  display:grid; grid-template-columns:repeat(3,1fr); gap:16px;
}
.cat{
  display:flex; flex-direction:column; align-items:center; gap:1rem;
  text-align:center;
  padding:2.2rem 1.2rem;
  border:1px solid var(--line-soft); border-radius:var(--radius);
  background:rgba(255,255,255,.015);
  transition:transform .4s var(--ease), border-color .4s, background .4s;
}
.cat:hover{ transform:translateY(-5px); border-color:var(--line); background:rgba(28,51,111,.18); }
.cat-ic{
  color:var(--gold);
  width:58px; height:58px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  border:1px solid var(--line);
  background:radial-gradient(circle at 50% 30%, rgba(217,180,90,.14), transparent 70%);
}
.cat-ic svg{ width:26px; height:26px; }
.cat-name{ font-family:var(--serif); font-size:1.2rem; color:var(--text); line-height:1.25; }

/* ============================================================
   5. PHILOSOPHY
   ============================================================ */
.philosophy{ position:relative; padding:clamp(90px,16vw,170px) 0; overflow:hidden; text-align:center; }
.philosophy-bg{
  position:absolute; inset:0;
  background:url("img/cumbre.jpg") center 32% / cover no-repeat;
}
.philosophy-veil{
  position:absolute; inset:0;
  background:linear-gradient(180deg, var(--bg) 0%, rgba(5,6,15,.72) 40%, rgba(5,6,15,.72) 60%, var(--bg) 100%);
}
.philosophy-content{ position:relative; z-index:2; max-width:800px; }
.quote{ margin:0; }
.quote-hl{
  display:block;
  font-family:var(--serif); font-style:italic; font-weight:500;
  font-size:clamp(1.7rem, 5.5vw, 2.8rem);
  line-height:1.22;
  color:#fff;
  text-shadow:0 2px 30px rgba(0,0,0,.5);
}
.quote-rest{
  display:block; margin-top:1.4rem;
  font-size:clamp(1rem, 2.6vw, 1.15rem);
  color:var(--muted); max-width:60ch; margin-inline:auto; font-weight:300;
}

/* ============================================================
   6. FEATURES (¿Qué hace diferente?)
   ============================================================ */
.features{
  display:grid; grid-template-columns:repeat(3,1fr); gap:16px;
}
.feature{
  display:flex; align-items:center; gap:1.1rem;
  padding:1.6rem 1.5rem;
  border:1px solid var(--line-soft); border-radius:var(--radius);
  background:linear-gradient(180deg, rgba(28,51,111,.12), rgba(12,19,48,.2));
  transition:transform .4s var(--ease), border-color .4s;
}
.feature:hover{ transform:translateY(-4px); border-color:var(--line); }
.feat-ic{
  flex:none; color:var(--gold);
  width:46px; height:46px; border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  border:1px solid var(--line);
  background:radial-gradient(circle at 50% 30%, rgba(217,180,90,.12), transparent 70%);
}
.feat-ic svg{ width:24px; height:24px; }
.feat-title{ font-family:var(--serif); font-weight:500; font-size:1.22rem; margin:0; line-height:1.25; color:var(--text); }

/* ============================================================
   7. PHONES (Capturas de la App)
   ============================================================ */
.phones{
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:clamp(20px,4vw,48px);
  justify-items:center; align-items:start;
}
.phone{ margin:0; text-align:center; max-width:280px; }
.phone-frame{
  position:relative; border-radius:34px; overflow:hidden;
  border:8px solid #0c1024;
  box-shadow:0 40px 90px -30px rgba(0,0,0,.85), 0 0 70px -24px rgba(44,83,201,.5);
  outline:1px solid rgba(217,180,90,.2); outline-offset:-9px;
}
.phone-frame::before{
  content:""; position:absolute; top:0; left:50%; transform:translateX(-50%);
  width:38%; height:20px; background:#0c1024; border-radius:0 0 12px 12px; z-index:2;
}
.phone-frame img{ width:100%; aspect-ratio:9/19.5; object-fit:cover; }
.phone figcaption{
  margin-top:1.2rem; font-family:var(--serif); font-style:italic;
  font-size:1.15rem; color:var(--gold-bright);
}
.phone:nth-child(2){ transform:translateY(-24px); }

/* ============================================================
   8. WAITLIST (Próximamente)
   ============================================================ */
.waitlist{ position:relative; padding:clamp(90px,16vw,160px) 0; overflow:hidden; text-align:center; }
.waitlist-bg{ position:absolute; inset:0; background:url("img/starfield.jpg") center 30% / cover no-repeat; }
.waitlist-veil{
  position:absolute; inset:0;
  background:
    radial-gradient(90% 60% at 50% 42%, rgba(5,6,15,.68), transparent 78%),
    linear-gradient(180deg, var(--bg) 0%, rgba(5,6,15,.55) 34%, rgba(5,6,15,.45) 62%, rgba(5,6,15,.85) 100%);
}
.waitlist-content{ position:relative; z-index:2; max-width:640px; }
.waitlist-content .h2{ max-width:18ch; margin-inline:auto; }
.waitlist-text{ color:var(--muted); font-size:clamp(1rem,2.6vw,1.12rem); margin:1.3rem auto 0; max-width:48ch; }
.waitlist-form{
  display:flex; flex-wrap:wrap; gap:.8rem; justify-content:center;
  margin:2.4rem auto 0; max-width:520px;
}
.field{ flex:1 1 180px; min-width:0; }
.waitlist-form input{
  width:100%;
  background:rgba(5,6,15,.5); border:1px solid var(--line);
  border-radius:999px; padding:.95rem 1.3rem;
  color:var(--text); font-family:var(--sans); font-size:.95rem;
  transition:border-color .3s, background .3s;
}
.waitlist-form input::placeholder{ color:var(--muted-2); }
.waitlist-form input:focus{ border-color:var(--gold); background:rgba(5,6,15,.7); }
.waitlist-form .btn{ flex:1 1 100%; }
.form-msg{ margin:1.2rem 0 0; min-height:1.4em; font-size:.95rem; color:var(--gold-bright); }
.form-msg.error{ color:#f0a3a3; }

/* ============================================================
   9. FAQ
   ============================================================ */
.faq{ border-top:1px solid var(--line-soft); }
.faq-item{ border-bottom:1px solid var(--line-soft); }
.faq-q{
  width:100%; background:none; border:none; cursor:pointer;
  display:flex; align-items:center; justify-content:space-between; gap:1.5rem;
  padding:1.5rem 0; text-align:left;
  font-family:var(--serif); font-size:clamp(1.15rem,3.4vw,1.4rem); color:var(--text);
  transition:color .3s;
}
.faq-q:hover{ color:var(--gold-bright); }
.faq-plus{ position:relative; flex:none; width:18px; height:18px; }
.faq-plus::before, .faq-plus::after{
  content:""; position:absolute; background:var(--gold);
  transition:transform .35s var(--ease), opacity .35s;
}
.faq-plus::before{ top:50%; left:0; width:100%; height:1.5px; transform:translateY(-50%); }
.faq-plus::after{ left:50%; top:0; width:1.5px; height:100%; transform:translateX(-50%); }
.faq-item.open .faq-plus::after{ transform:translateX(-50%) scaleY(0); opacity:0; }
/* visibility:hidden saca el contenido colapsado del árbol de accesibilidad */
.faq-a{ overflow:hidden; max-height:0; visibility:hidden; transition:max-height .4s var(--ease), visibility 0s .4s; }
.faq-item.open .faq-a{ visibility:visible; transition:max-height .4s var(--ease), visibility 0s 0s; }
.faq-a p{ margin:0 0 1.5rem; color:var(--muted); font-size:1.02rem; max-width:60ch; }

/* ============================================================
   10. FOOTER
   ============================================================ */
.site-footer{
  border-top:1px solid var(--line-soft);
  background:linear-gradient(180deg, transparent, rgba(9,13,32,.6));
  padding-top:clamp(60px,9vw,90px);
}
.footer-inner{
  display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:40px;
  padding-bottom:52px;
}
.footer-brand .brand-star{ font-size:1rem; }
.footer-word{ font-size:1.35rem; }
.footer-tag{ display:block; font-family:var(--serif); font-style:italic; color:var(--gold); margin-top:.2rem; letter-spacing:.04em; }
.footer-desc{ color:var(--muted); margin:1rem 0 0; max-width:34ch; font-size:.95rem; }
.footer-col{ display:flex; flex-direction:column; gap:.7rem; }
.footer-h{ font-size:.72rem; text-transform:uppercase; letter-spacing:.2em; color:var(--gold); margin-bottom:.3rem; }
.footer-col a{ color:var(--muted); font-size:.95rem; transition:color .3s; width:fit-content; }
.footer-col a:hover{ color:var(--text); }
.socials{ display:flex; gap:.8rem; }
.socials a{
  width:44px; height:44px; border-radius:50%; border:1px solid var(--line);
  display:flex; align-items:center; justify-content:center; color:var(--gold);
  transition:border-color .3s, color .3s, transform .3s;
}
.socials a svg{ width:20px; height:20px; }
.socials a:hover{ border-color:var(--gold); color:var(--gold-bright); transform:translateY(-2px); }
.footer-bilingual{ color:var(--muted-2); font-size:.82rem; margin:1rem 0 0; }
.footer-bottom{ border-top:1px solid var(--line-soft); padding:22px; text-align:center; }
.footer-bottom p{ margin:0; color:var(--muted-2); font-size:.82rem; }

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; transition:none; } }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 900px){
  .nav{ display:none; }
  .menu-btn{ display:flex; }
  .nav-cta{ display:none; }
  .grid-2{ grid-template-columns:1fr; }
  .col-media{ order:-1; }
  .media-frame img{ aspect-ratio:16/11; }
  .steps{ grid-template-columns:1fr; gap:34px; max-width:440px; margin-inline:auto; }
  .cats{ grid-template-columns:repeat(2,1fr); }
  .features{ grid-template-columns:1fr; max-width:520px; margin-inline:auto; }
  .footer-inner{ grid-template-columns:1fr 1fr; gap:34px 24px; }
  .footer-brand{ grid-column:1 / -1; }
}

@media (max-width: 900px){
  .lang-toggle{ min-height:44px; }
}

@media (max-width: 640px){
  .phones{ grid-template-columns:1fr; }
  .phone{ max-width:250px; }
  .phone:nth-child(2){ transform:none; }
  .cats{ grid-template-columns:1fr 1fr; }
  .cat-name{ font-size:1.05rem; }
  .hero{ min-height:92svh; }
  .waitlist-form .field{ flex:1 1 100%; }
  .footer-inner{ grid-template-columns:1fr; }
  .footer-col{ gap:.2rem; }
  .footer-col a{ min-height:44px; display:inline-flex; align-items:center; }
}

@media (max-width: 380px){
  .cats{ grid-template-columns:1fr; }
  .eyebrow{ letter-spacing:.28em; }
}

/* ============================================================
   LEGAL PAGES
   ============================================================ */
.legal-header{ border-bottom:1px solid var(--line-soft); background:rgba(5,6,15,.6); }
.legal-header-inner{ display:flex; align-items:center; justify-content:space-between; height:68px; }
.legal{ padding:64px 0 90px; }
.legal .back{
  display:inline-flex; align-items:center; gap:.5rem;
  color:var(--gold); font-size:.85rem; letter-spacing:.06em; margin-bottom:2.5rem;
  transition:color .3s;
}
.legal .back:hover{ color:var(--gold-bright); }
.legal h1{
  font-family:var(--serif); font-weight:500;
  font-size:clamp(2rem,7vw,3rem); margin:0 0 .4rem; color:#fff;
}
.legal .updated{ color:var(--muted-2); font-size:.85rem; margin:0 0 2.6rem; letter-spacing:.04em; }
.legal .note{
  border:1px solid var(--line); border-radius:12px;
  background:rgba(217,180,90,.06); color:var(--muted);
  padding:1rem 1.2rem; font-size:.9rem; margin-bottom:2.6rem;
}
.legal h2{
  font-family:var(--serif); font-weight:500; color:var(--gold-bright);
  font-size:clamp(1.3rem,4vw,1.7rem); margin:2.4rem 0 .8rem;
}
.legal p, .legal li{ color:var(--muted); font-size:1rem; line-height:1.75; }
.legal ul{ padding-left:1.2rem; }
.legal li{ margin:.4rem 0; }
.legal a.inline{ color:var(--gold); }
