/* ===== promou.com — sistema de marca en web ===== */
@font-face{font-family:"Italiana";src:url("assets/fonts/Italiana-Regular.ttf") format("truetype");font-display:swap}
@font-face{font-family:"DM Mono";src:url("assets/fonts/DMMono-Regular.ttf") format("truetype");font-display:swap}
@font-face{font-family:"Jura";src:url("assets/fonts/Jura-Light.ttf") format("truetype");font-weight:300;font-display:swap}
@font-face{font-family:"Outfit";src:url("assets/fonts/Outfit-Regular.ttf") format("truetype");font-weight:400;font-display:swap}
@font-face{font-family:"Outfit";src:url("assets/fonts/Outfit-Bold.ttf") format("truetype");font-weight:700;font-display:swap}
@font-face{font-family:"Kaushan Script";src:url("assets/fonts/KaushanScript-Regular.ttf") format("truetype");font-display:swap}

:root{
  --gold:#FBBF24; --gold-hi:#FFD66E; --indigo:#5145E5; --purple:#7C3AED; --cream:#FDF6E6;
  --maxw:1180px; --r:18px; --ease:cubic-bezier(.2,.7,.2,1);
}
/* DARK (default) */
:root[data-theme="dark"]{
  --bg:#0d0b1e; --bg2:#08070f;
  --ink:#ECEEF8; --ink-soft:#CBCEEA; --muted:#9A9CC0;
  --panel:rgba(255,255,255,.035); --panel-2:rgba(255,255,255,.05);
  --border:rgba(206,210,235,.12); --border-2:rgba(206,210,235,.20);
  --ring:rgba(206,210,235,.11); --gold-text:var(--gold-hi); --star:230,234,250;
  --bg-layers:
    radial-gradient(1200px 820px at 72% -12%, rgba(124,58,237,.20), transparent 58%),
    radial-gradient(960px 720px at 16% 112%, rgba(81,69,229,.18), transparent 60%),
    radial-gradient(680px 520px at 50% 40%, rgba(251,191,36,.05), transparent 60%),
    linear-gradient(180deg,var(--bg),var(--bg2));
  --nav-bg:rgba(13,11,30,.62); --shadow:0 30px 80px -40px rgba(0,0,0,.8);
}
/* LIGHT */
:root[data-theme="light"]{
  --bg:#F7F4EC; --bg2:#ECE7DA;
  --ink:#1E1B4B; --ink-soft:#3a3668; --muted:#6E6C8C;
  --panel:#ffffff; --panel-2:#fffdf8;
  --border:rgba(30,27,75,.10); --border-2:rgba(30,27,75,.18);
  --ring:rgba(30,27,75,.10); --gold-text:#A9781A; --star:30,27,75;
  --bg-layers:
    radial-gradient(1100px 760px at 78% -12%, rgba(124,58,237,.08), transparent 58%),
    radial-gradient(900px 680px at 12% 112%, rgba(81,69,229,.07), transparent 60%),
    linear-gradient(180deg,var(--bg),var(--bg2));
  --nav-bg:rgba(247,244,236,.72); --shadow:0 26px 70px -44px rgba(30,27,75,.35);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; font-family:"Outfit",system-ui,sans-serif; color:var(--ink);
  background:var(--bg-layers) fixed; background-color:var(--bg);
  -webkit-font-smoothing:antialiased; line-height:1.55; overflow-x:hidden;
  transition:background-color .5s var(--ease), color .4s var(--ease);
}
#stars{position:fixed; inset:0; z-index:0; pointer-events:none; transition:opacity .6s ease}
:root[data-theme="light"] #stars{opacity:0}
main,.nav,.footer{position:relative; z-index:1}
a{color:inherit; text-decoration:none}
img{display:block; max-width:100%}
.eyebrow{font-family:"DM Mono",monospace; font-size:.72rem; letter-spacing:.28em;
  color:var(--gold-text); margin:0 0 1.1rem; text-transform:uppercase}
em{font-style:normal; color:var(--gold-text)}

/* ---- buttons ---- */
.btn{display:inline-flex; align-items:center; gap:.5rem; font-weight:700; font-size:.95rem;
  padding:.78rem 1.35rem; border-radius:999px; border:1px solid transparent; cursor:pointer;
  transition:transform .25s var(--ease), background .25s, border-color .25s, box-shadow .25s}
.btn:hover{transform:translateY(-2px)}
.btn--gold{background:linear-gradient(180deg,var(--gold-hi),var(--gold)); color:#241a05;
  box-shadow:0 12px 30px -12px rgba(251,191,36,.6)}
.btn--ghost{background:var(--panel); color:var(--ink); border-color:var(--border-2)}
.btn--ghost:hover{border-color:var(--gold)}

/* ---- nav ---- */
.nav{position:sticky; top:0; z-index:100; display:flex; align-items:center; gap:1.5rem;
  max-width:var(--maxw); margin:0 auto; padding:1rem 1.5rem;
  backdrop-filter:blur(14px); background:var(--nav-bg);
  border-bottom:1px solid var(--border); border-radius:0 0 16px 16px}
.brand{display:flex; align-items:center; gap:.6rem}
.brand__mark{width:30px; height:30px; filter:drop-shadow(0 0 10px rgba(251,191,36,.35))}
.brand__word{font-family:"Italiana",serif; font-size:1.5rem; letter-spacing:.02em; line-height:1}
.brand__dot{color:var(--gold-text)}
.nav__links{display:flex; gap:1.6rem; margin-left:1rem; font-size:.95rem; color:var(--ink-soft)}
.nav__links a{position:relative; padding:.2rem 0; color:var(--ink-soft); transition:color .2s}
.nav__links a:hover{color:var(--ink)}
.nav__links a::after{content:""; position:absolute; left:0; bottom:-3px; width:0; height:2px;
  background:var(--gold); transition:width .25s var(--ease)}
.nav__links a:hover::after{width:100%}
.nav__actions{margin-left:auto; display:flex; align-items:center; gap:.7rem}
.theme-toggle{display:grid; place-items:center; width:40px; height:40px; border-radius:999px;
  background:var(--panel); border:1px solid var(--border-2); color:var(--ink); cursor:pointer;
  transition:border-color .2s, transform .2s}
.theme-toggle:hover{border-color:var(--gold); transform:rotate(12deg)}
.theme-toggle .i-moon{display:none}
:root[data-theme="light"] .theme-toggle .i-sun{display:none}
:root[data-theme="light"] .theme-toggle .i-moon{display:block}

/* ---- hero ---- */
.hero{max-width:var(--maxw); margin:0 auto; padding:5.5rem 1.5rem 4rem;
  display:grid; grid-template-columns:1.05fr .95fr; gap:2.5rem; align-items:center}
.hero__h1{font-family:"Italiana",serif; font-weight:400; font-size:clamp(2.8rem,6vw,4.7rem);
  line-height:1.04; margin:.2rem 0 1.3rem; letter-spacing:.005em}
.hero__sub{font-family:"Jura",sans-serif; font-weight:300; font-size:1.18rem;
  color:var(--ink-soft); max-width:33ch; margin:0 0 2rem}
.hero__cta{display:flex; gap:.8rem; flex-wrap:wrap}
.hero__meta{margin-top:1.6rem; font-family:"DM Mono",monospace; font-size:.78rem;
  letter-spacing:.16em; color:var(--muted)}

/* orrery art */
.hero__art{display:grid; place-items:center}
.orrery{position:relative; width:min(440px,86vw); aspect-ratio:1}
.orrery .ring{position:absolute; inset:0; margin:auto; border-radius:50%; border:1px solid var(--ring)}
.ring--1{width:34%; height:34%}
.ring--2{width:58%; height:58%}
.ring--3{width:80%; height:80%}
.ring--4{width:100%; height:100%; border-color:var(--border-2)}
.orrery__core{position:absolute; inset:0; margin:auto; width:21%;
  filter:drop-shadow(0 0 26px rgba(251,191,36,.55)); animation:spin 60s linear infinite}
.orrery__beluna{position:absolute; width:23%; top:11%; left:13%;
  filter:drop-shadow(0 0 16px rgba(230,194,102,.5)); animation:float 7s var(--ease) infinite}
.orrery__rondea{position:absolute; width:13%; bottom:12%; right:16%;
  filter:drop-shadow(0 0 16px rgba(124,58,237,.6)); animation:float 8s var(--ease) infinite reverse}
.orrery__scout{position:absolute; width:12.5%; bottom:18%; left:12%;
  filter:drop-shadow(0 0 16px rgba(81,69,229,.65)); animation:float 7.5s var(--ease) infinite}
.orrery__labs{position:absolute; width:11%; top:22%; right:9%;
  filter:drop-shadow(0 0 15px rgba(34,211,238,.6)); animation:float 8.5s var(--ease) infinite reverse}
.orrery .dot{position:absolute; width:7px; height:7px; border-radius:50%;
  background:rgba(var(--star),.85)}
.dot--a{top:30%; right:8%} .dot--b{bottom:26%; left:9%}
@keyframes float{0%,100%{transform:translateY(-5px)}50%{transform:translateY(7px)}}
@keyframes spin{to{transform:rotate(360deg)}}
@media(prefers-reduced-motion:reduce){.orrery__core,.orrery__beluna,.orrery__rondea{animation:none}}

/* ---- sections ---- */
.section{max-width:var(--maxw); margin:0 auto; padding:5rem 1.5rem}
.section--alt{border-top:1px solid var(--border); border-bottom:1px solid var(--border)}
.section__head{margin-bottom:2.6rem; max-width:42rem}
.section__title{font-family:"Italiana",serif; font-weight:400; font-size:clamp(1.9rem,3.6vw,2.9rem);
  line-height:1.12; margin:0}

/* ---- product cards ---- */
.cards{display:grid; grid-template-columns:repeat(auto-fit,minmax(248px,1fr)); gap:1.4rem}
.card{position:relative; padding:2rem 1.7rem 1.7rem; border-radius:var(--r);
  background:var(--panel); border:1px solid var(--border); box-shadow:var(--shadow);
  transition:transform .35s var(--ease), border-color .35s, background .35s}
.card:hover{transform:translateY(-6px); border-color:var(--border-2)}
.card__mark{height:84px; display:flex; align-items:center}
.card__mark img{height:74px; width:auto}
.card--rondea .card__mark img{height:80px}
.card__mark--dots{gap:10px}
.card__mark--dots span{width:12px; height:12px; border-radius:50%; background:var(--muted); display:inline-block}
.card__name{margin:1rem 0 .2rem; font-size:2rem; line-height:1}
.word-beluna{font-family:"Kaushan Script",cursive; color:var(--gold-text); font-weight:400}
.word-rondea,.word-scout{font-family:"Outfit",sans-serif; font-weight:700; letter-spacing:-.01em; color:var(--ink)}
.word-next{font-family:"Outfit",sans-serif; font-weight:700; color:var(--ink)}
.card__tag{font-family:"DM Mono",monospace; font-size:.66rem; letter-spacing:.18em;
  color:var(--muted); margin:.2rem 0 1rem}
.card__desc{color:var(--ink-soft); font-size:.98rem; margin:0 0 1.4rem}
.card__link{font-weight:700; color:var(--gold-text); font-size:.95rem}
.card__link:hover{text-decoration:underline; text-underline-offset:4px}
.card--beluna{background:
  radial-gradient(120% 80% at 0% 0%, rgba(230,194,102,.10), transparent 55%), var(--panel)}
.card--rondea{background:
  radial-gradient(120% 80% at 0% 0%, rgba(124,58,237,.12), transparent 55%), var(--panel)}
.card--scout{background:
  radial-gradient(120% 80% at 0% 0%, rgba(81,69,229,.13), transparent 55%), var(--panel)}

/* ---- features ---- */
.features{display:grid; grid-template-columns:repeat(4,1fr); gap:1.4rem}
.feature{padding:1.6rem 1.4rem; border-radius:var(--r); border:1px solid var(--border); background:var(--panel)}
.feature__no{font-family:"DM Mono",monospace; font-size:.8rem; color:var(--gold-text); letter-spacing:.1em}
.feature h3{font-family:"Italiana",serif; font-weight:400; font-size:1.35rem; margin:.7rem 0 .5rem}
.feature p{margin:0; color:var(--ink-soft); font-size:.94rem}

/* ---- la casa ---- */
.house{display:grid; grid-template-columns:1fr 1fr; gap:2.5rem; align-items:center}
.house__quote{font-family:"Italiana",serif; font-weight:400; font-size:clamp(2.2rem,4.6vw,3.4rem);
  line-height:1.06; margin:0 0 1.4rem}
.house__p{color:var(--ink-soft); font-size:1.05rem; max-width:40ch; margin:0 0 1rem}
.house__p strong{color:var(--ink)}
.house__p.muted{font-family:"DM Mono",monospace; font-size:.85rem; letter-spacing:.06em; color:var(--muted)}
.house__diagram{display:grid; place-items:center; padding:2rem; border-radius:var(--r);
  background:var(--panel); border:1px solid var(--border)}
.orbit-row{display:flex; align-items:center; gap:1.2rem; width:100%}
.om--core{width:84px; filter:drop-shadow(0 0 20px rgba(251,191,36,.45))}
.om__line{flex:0 0 38px; height:1px; background:var(--border-2)}
.om__kids{display:flex; flex-direction:column; gap:1.05rem; flex:1}
.kid{display:flex; align-items:center; gap:.8rem; font-size:1.25rem}
.kid img{width:34px; height:34px; object-fit:contain}
.kid__dots{display:inline-flex; gap:5px; width:34px; justify-content:center}
.kid__dots span{width:7px;height:7px;border-radius:50%;background:var(--muted)}

/* ---- reseñas / reviews ---- */
.reviews__grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(290px,1fr)); gap:1.4rem}
.review{display:flex; flex-direction:column; padding:1.8rem 1.6rem; border-radius:var(--r);
  background:var(--panel); border:1px solid var(--border); box-shadow:var(--shadow);
  transition:transform .35s var(--ease), border-color .35s}
.review:hover{transform:translateY(-5px); border-color:var(--border-2)}
.review__top{display:flex; align-items:center; justify-content:space-between; margin-bottom:1rem}
.review__pill{font-family:"DM Mono",monospace; font-size:.6rem; letter-spacing:.16em;
  padding:.3rem .6rem; border-radius:999px; border:1px solid var(--border-2); color:var(--muted)}
.review__stars{display:inline-flex; gap:2px}
.review__stars svg{width:16px; height:16px; fill:var(--gold); display:block}
.review__quote{font-family:"Jura",sans-serif; font-weight:300; color:var(--ink-soft);
  font-size:1.05rem; line-height:1.5; margin:0 0 1.5rem; flex:1}
.review__quote::before{content:"\201C"; font-family:"Italiana",serif; color:var(--gold-text);
  font-size:1.4rem; line-height:0; margin-right:.12em; vertical-align:-.15em}
.review__who{display:flex; align-items:center; gap:.85rem; margin-top:auto}
.review__avatar{width:42px; height:42px; border-radius:50%; flex:0 0 auto; display:grid; place-items:center;
  font-family:"DM Mono",monospace; font-size:.82rem; font-weight:700; color:#241a05;
  background:linear-gradient(180deg,var(--gold-hi),var(--gold)); box-shadow:0 6px 16px -8px rgba(251,191,36,.7)}
.review__id{display:flex; flex-direction:column; gap:1px; min-width:0}
.review__name{font-weight:700; color:var(--ink); font-size:.97rem}
.review__role{font-family:"DM Mono",monospace; font-size:.67rem; letter-spacing:.05em; color:var(--muted)}
.review--beluna{background:radial-gradient(120% 80% at 0% 0%, rgba(230,194,102,.09), transparent 55%), var(--panel)}
.review--beluna .review__pill{color:var(--gold-text); border-color:rgba(230,194,102,.42)}
.review--rondea{background:radial-gradient(120% 80% at 0% 0%, rgba(124,58,237,.11), transparent 55%), var(--panel)}
.review--rondea .review__pill{color:#a78bfa; border-color:rgba(124,58,237,.42)}
.review--rondea .review__avatar{background:linear-gradient(180deg,#8b5cf6,#7c3aed); color:#fff; box-shadow:0 6px 16px -8px rgba(124,58,237,.8)}
.review--scout{background:radial-gradient(120% 80% at 0% 0%, rgba(81,69,229,.12), transparent 55%), var(--panel)}
.review--scout .review__pill{color:#8b9bff; border-color:rgba(81,69,229,.42)}
.review--scout .review__avatar{background:linear-gradient(180deg,#6366f1,#5145e5); color:#fff; box-shadow:0 6px 16px -8px rgba(81,69,229,.8)}
.review__quote strong{font-weight:700; font-family:"Outfit",sans-serif}
.review--beluna .review__quote strong{color:var(--gold-text)}
.review--rondea .review__quote strong{color:#a78bfa}
.review--scout .review__quote strong{color:#8b9bff}

/* ---- cta ---- */
.cta{max-width:760px; margin:2rem auto 5rem; padding:3.4rem 2rem; text-align:center;
  border-radius:26px; background:var(--panel-2); border:1px solid var(--border-2); box-shadow:var(--shadow)}
.cta__h{font-family:"Italiana",serif; font-weight:400; font-size:clamp(1.8rem,4vw,2.7rem); margin:0 0 .6rem}
.cta__sub{color:var(--ink-soft); margin:0 0 1.8rem}
.cta__actions{display:flex; gap:.8rem; justify-content:center; flex-wrap:wrap}

/* ---- footer ---- */
.footer{max-width:var(--maxw); margin:0 auto; padding:3rem 1.5rem 3.5rem;
  border-top:1px solid var(--border); display:grid; grid-template-columns:1.4fr 2fr; gap:2rem; align-items:start}
.footer__tag{color:var(--muted); font-family:"Jura",sans-serif; font-weight:300; margin:1rem 0 0; max-width:30ch}
.footer__cols{display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem}
.footer__cols h4{font-family:"DM Mono",monospace; font-size:.7rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--muted); margin:0 0 .9rem}
.footer__cols a{display:block; color:var(--ink-soft); font-size:.95rem; padding:.22rem 0; transition:color .2s}
.footer__cols a:hover{color:var(--gold-text)}
.footer__legal{grid-column:1/-1; display:flex; align-items:center; justify-content:space-between;
  border-top:1px solid var(--border); margin-top:1rem; padding-top:1.3rem;
  font-family:"DM Mono",monospace; font-size:.74rem; color:var(--muted); flex-wrap:wrap; gap:1rem}
.pal{display:inline-flex; gap:7px}
.pal i{width:16px; height:16px; border-radius:5px; background:var(--s); border:1px solid var(--border-2)}

/* ---- responsive ---- */
@media(max-width:920px){
  .hero{grid-template-columns:1fr; padding-top:3.5rem}
  .hero__art{order:-1}
  .cards{grid-template-columns:repeat(2,1fr)}
  .features{grid-template-columns:repeat(2,1fr)}
  .house{grid-template-columns:1fr}
  .footer{grid-template-columns:1fr}
  .nav__links{display:none}
}
@media(max-width:560px){
  .features{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr}
  .footer__cols{grid-template-columns:1fr 1fr}
}

/* ===================== reveal on scroll ===================== */
.reveal{opacity:0; transform:translateY(20px); transition:opacity .7s var(--ease), transform .7s var(--ease)}
.reveal.in{opacity:1; transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important;transition:none}}

/* ===================== mobile nav ===================== */
.nav__burger{display:none; width:40px; height:40px; place-items:center; border-radius:999px;
  background:var(--panel); border:1px solid var(--border-2); color:var(--ink); cursor:pointer}
.nav__burger svg{width:20px;height:20px}
@media(max-width:920px){
  .nav__burger{display:grid; order:3}
  .nav__actions{margin-left:auto}
  .nav__links{position:fixed; inset:64px 12px auto 12px; flex-direction:column; gap:.3rem;
    background:var(--nav-bg); backdrop-filter:blur(16px); border:1px solid var(--border-2);
    border-radius:16px; padding:.7rem; box-shadow:var(--shadow); display:none; z-index:50; margin-left:0}
  body.menu-open .nav__links{display:flex}
  .nav__links a{padding:.7rem .8rem; border-radius:10px}
  .nav__links a:hover{background:var(--panel)}
  .nav__links a::after{display:none}
}

/* ===================== subpage hero ===================== */
.subnav-cta{font-size:.9rem}
.housetag{display:inline-flex; align-items:center; gap:.5rem; font-family:"DM Mono",monospace;
  font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted);
  border:1px solid var(--border-2); border-radius:999px; padding:.4rem .85rem; margin-bottom:1.4rem}
.housetag img{width:16px; height:16px}
.housetag b{color:var(--ink)}
.subhero{max-width:var(--maxw); margin:0 auto; padding:4rem 1.5rem 3rem;
  display:grid; grid-template-columns:1.1fr .9fr; gap:2.5rem; align-items:center}
.subhero__mark{height:120px; margin-bottom:1.2rem}
.subhero__mark img{height:100%}
.subhero h1{font-size:clamp(3rem,7vw,5rem); line-height:.95; margin:.2rem 0 1rem}
.subhero .tagline{font-family:"DM Mono",monospace; letter-spacing:.16em; text-transform:uppercase;
  color:var(--accent-text); font-size:.82rem; margin:0 0 1.2rem}
.subhero p.lead{font-family:"Jura",sans-serif; font-weight:300; font-size:1.2rem; color:var(--ink-soft); max-width:36ch; margin:0 0 1.8rem}
.subhero__art{display:grid; place-items:center}
.bigmark{width:min(380px,80vw); aspect-ratio:1; display:grid; place-items:center; position:relative}
.bigmark::before{content:""; position:absolute; inset:8%; border-radius:50%;
  background:radial-gradient(circle, var(--accent-soft), transparent 65%)}
.bigmark img{width:74%; position:relative; filter:drop-shadow(0 20px 50px rgba(0,0,0,.4))}
.h1-beluna{font-family:"Kaushan Script",cursive; color:var(--gold-text); font-weight:400}
.h1-rondea,.h1-scout{font-family:"Outfit",sans-serif; font-weight:700; letter-spacing:-.02em}

/* ===================== steps (cómo funciona) ===================== */
.steps{display:grid; grid-template-columns:repeat(5,1fr); gap:1rem; counter-reset:s}
.step{position:relative; padding:1.5rem 1.2rem; border-radius:var(--r); background:var(--panel); border:1px solid var(--border)}
.step::before{counter-increment:s; content:"0" counter(s); font-family:"DM Mono",monospace;
  color:var(--accent-text); font-size:.9rem; letter-spacing:.1em}
.step h3{font-family:"Italiana",serif; font-weight:400; font-size:1.2rem; margin:.6rem 0 .4rem}
.step p{margin:0; font-size:.9rem; color:var(--ink-soft)}
@media(max-width:920px){.steps{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.steps{grid-template-columns:1fr}}

/* ===================== stats band ===================== */
.stats{display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem; text-align:center;
  padding:2.4rem 1.5rem; border-radius:var(--r); background:var(--panel); border:1px solid var(--border)}
.stat b{display:block; font-family:"Italiana",serif; font-size:2.3rem; color:var(--accent-text); line-height:1}
.stat span{font-size:.85rem; color:var(--muted)}
@media(max-width:560px){.stats{grid-template-columns:1fr 1fr}}

/* ===================== case ===================== */
.case{display:grid; grid-template-columns:1.2fr 1fr; gap:2rem; align-items:center;
  padding:2.4rem; border-radius:var(--r); background:
   radial-gradient(120% 90% at 100% 0%, var(--accent-soft), transparent 55%), var(--panel);
  border:1px solid var(--border)}
.case__quote{font-family:"Italiana",serif; font-size:1.6rem; line-height:1.3; margin:0 0 1rem}
.case ul{margin:0; padding:0; list-style:none; display:grid; gap:.7rem}
.case li{display:flex; gap:.7rem; font-size:.95rem; color:var(--ink-soft)}
.case li b{color:var(--accent-text); font-family:"DM Mono",monospace; min-width:74px}
@media(max-width:760px){.case{grid-template-columns:1fr}}

/* ===================== pricing ===================== */
.pricing{display:grid; grid-template-columns:repeat(3,1fr); gap:1.3rem; align-items:start}
.plan{padding:2rem 1.7rem; border-radius:var(--r); background:var(--panel); border:1px solid var(--border); position:relative}
.plan--pro{border-color:var(--gold); box-shadow:0 0 0 1px var(--gold), var(--shadow)}
.plan__badge{position:absolute; top:-12px; left:1.7rem; background:linear-gradient(180deg,var(--gold-hi),var(--gold));
  color:#241a05; font-size:.68rem; font-weight:700; letter-spacing:.1em; padding:.25rem .7rem; border-radius:999px}
.plan__name{font-family:"DM Mono",monospace; letter-spacing:.18em; text-transform:uppercase; font-size:.78rem; color:var(--muted)}
.plan__price{font-family:"Italiana",serif; font-size:2.6rem; margin:.5rem 0 .1rem; line-height:1}
.plan__price small{font-size:1rem; color:var(--muted); font-family:"Outfit"}
.plan__note{color:var(--muted); font-size:.85rem; margin:0 0 1.2rem}
.plan ul{list-style:none; margin:0 0 1.5rem; padding:0; display:grid; gap:.6rem}
.plan li{font-size:.93rem; color:var(--ink-soft); display:flex; gap:.55rem}
.plan li::before{content:"◉"; color:var(--accent-text); font-size:.7rem; line-height:1.5}
.pricing__note{text-align:center; color:var(--muted); font-family:"DM Mono",monospace; font-size:.82rem; margin-top:1.4rem}
@media(max-width:880px){.pricing{grid-template-columns:1fr}}

/* ===================== FAQ ===================== */
.faq{max-width:760px; margin:0 auto; display:grid; gap:.7rem}
.faq details{border:1px solid var(--border); border-radius:14px; background:var(--panel); overflow:hidden}
.faq summary{cursor:pointer; padding:1.1rem 1.3rem; font-weight:700; list-style:none; display:flex; justify-content:space-between; gap:1rem; align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+"; color:var(--accent-text); font-size:1.4rem; transition:transform .25s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq p{margin:0; padding:0 1.3rem 1.2rem; color:var(--ink-soft)}

/* ===================== product accents ===================== */
body[data-product="beluna"]{--accent:var(--gold); --accent-text:var(--gold-text); --accent-soft:rgba(230,194,102,.14)}
body[data-product="rondea"]{--accent:var(--purple); --accent-soft:rgba(124,58,237,.16)}
:root[data-theme="dark"] body[data-product="rondea"]{--accent-text:#b3a6ff}
:root[data-theme="light"] body[data-product="rondea"]{--accent-text:#6b3fd0}
body[data-product="scout"]{--accent:var(--indigo); --accent-soft:rgba(81,69,229,.16)}
:root[data-theme="dark"] body[data-product="scout"]{--accent-text:#9a90ff}
:root[data-theme="light"] body[data-product="scout"]{--accent-text:#4036c9}
.btn--accent{background:var(--accent); color:#fff; box-shadow:0 12px 30px -14px var(--accent)}
body[data-product="beluna"] .btn--accent{color:#241a05; background:linear-gradient(180deg,var(--gold-hi),var(--gold))}

@media(max-width:920px){
  .subhero{grid-template-columns:1fr} .subhero__art{order:-1}
}

/* ===================== labs ===================== */
.labs{max-width:var(--maxw); margin:0 auto; padding:4.5rem 1.5rem; --lab:#34d0e6}
:root[data-theme="light"] .labs{--lab:#0e8398}
.labs .eyebrow{color:var(--lab)}
.labs__panel{border:1px dashed var(--border-2); border-radius:var(--r); padding:2.4rem 2.2rem;
  background:radial-gradient(130% 120% at 100% 0%, rgba(34,211,238,.07), transparent 55%), var(--panel)}
.labs__head{max-width:46rem; margin-bottom:1.4rem}
.labs__logo{width:42px; height:42px; display:block; margin-bottom:.8rem; filter:drop-shadow(0 0 12px rgba(34,211,238,.5))}
.labs__head h2{font-family:"Italiana",serif; font-weight:400; font-size:clamp(1.6rem,3vw,2.2rem); margin:.2rem 0 .6rem}
.labs__head p{color:var(--ink-soft); margin:0}
.lab{display:flex; gap:1.3rem; align-items:flex-start; padding:1.4rem 0; border-top:1px solid var(--border)}
.lab__mark{flex:0 0 54px; width:54px; filter:drop-shadow(0 0 14px rgba(34,211,238,.4))}
.lab__body{flex:1}
.lab__top{display:flex; align-items:center; gap:.8rem; flex-wrap:wrap}
.lab__name{font-family:"Outfit",sans-serif; font-weight:700; font-size:1.5rem; color:var(--ink); line-height:1}
.lab__chip{font-family:"DM Mono",monospace; font-size:.62rem; letter-spacing:.14em; color:var(--lab);
  border:1px solid var(--lab); border-radius:999px; padding:.22rem .6rem}
.lab__tag{font-family:"DM Mono",monospace; font-size:.66rem; letter-spacing:.16em; color:var(--muted); margin:.4rem 0 .5rem}
.lab__desc{color:var(--ink-soft); margin:0 0 .4rem; max-width:60ch}
.lab__note{font-family:"DM Mono",monospace; font-size:.74rem; color:var(--muted)}
@media(max-width:560px){ .lab{flex-direction:column; gap:.8rem} }

/* ===================== language switcher ===================== */
.lang{position:static}
.lang__btn{display:flex; align-items:center; gap:.4rem; height:40px; padding:0 .6rem;
  border-radius:999px; background:var(--panel); border:1px solid var(--border-2); color:var(--ink);
  cursor:pointer; transition:border-color .2s}
.lang__btn:hover{border-color:var(--gold)}
.lang__btn[aria-expanded="true"]{border-color:var(--gold)}
.lang__flag{width:22px; height:16px; border-radius:3px; object-fit:cover; box-shadow:0 0 0 1px rgba(0,0,0,.18); display:block}
.lang__chev{opacity:.55; transition:transform .2s var(--ease)}
.lang__btn[aria-expanded="true"] .lang__chev{transform:rotate(180deg)}
/* horizontal strip, centered under the nav line */
.lang__menu{position:absolute; left:50%; top:calc(100% + .55rem); transform:translateX(-50%);
  z-index:200; margin:0; padding:.5rem .55rem; list-style:none;
  display:flex; flex-wrap:wrap; justify-content:center; gap:.35rem;
  width:max-content; max-width:min(720px, calc(100vw - 1.5rem));
  background:var(--nav-bg); backdrop-filter:blur(16px); border:1px solid var(--border-2);
  border-radius:16px; box-shadow:var(--shadow)}
.lang__menu[hidden]{display:none}
.lang__opt{display:flex; align-items:center; gap:.45rem; padding:.4rem .7rem; border-radius:999px;
  cursor:pointer; font-size:.9rem; color:var(--ink-soft); white-space:nowrap;
  border:1px solid transparent; transition:background .15s, color .15s, border-color .15s}
.lang__opt:hover{background:var(--panel); color:var(--ink)}
.lang__opt img{width:22px; height:16px; border-radius:3px; object-fit:cover; box-shadow:0 0 0 1px rgba(0,0,0,.18); flex:0 0 auto}
.lang__opt[aria-selected="true"]{background:var(--panel); color:var(--ink); border-color:var(--gold)}
@media(max-width:380px){ .nav__actions .btn--ghost{ display:none } }

/* ===================== contact form ===================== */
.form{max-width:540px; margin:2rem auto 0; text-align:left; display:grid; gap:1rem}
.form__row{display:grid; grid-template-columns:1fr 1fr; gap:1rem}
.field{display:grid; gap:.4rem}
.field__label{font-family:"DM Mono",monospace; font-size:.7rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted)}
.form input,.form select,.form textarea{
  width:100%; font:inherit; font-size:.95rem; color:var(--ink);
  background:var(--panel); border:1px solid var(--border-2); border-radius:12px; padding:.7rem .85rem;
  transition:border-color .2s;
}
.form input:focus,.form select:focus,.form textarea:focus{outline:none; border-color:var(--gold)}
.form select{appearance:none; -webkit-appearance:none; cursor:pointer;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' stroke='%239a9cc0' stroke-width='1.6' fill='none' stroke-linecap='round'/></svg>");
  background-repeat:no-repeat; background-position:right .9rem center; background-size:10px;}
.form select option{color:#1e1b4b; background:#fff}
.form textarea{resize:vertical; min-height:96px}
.form .btn{justify-self:start; margin-top:.2rem}
.form__note{font-family:"DM Mono",monospace; font-size:.74rem; color:var(--muted); margin:.2rem 0 0; line-height:1.5}
.form__hp{position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden}
@media(max-width:520px){ .form__row{grid-template-columns:1fr} }
