/* ============================================================
   raulherrero.ai — BRUTALIST · manifiesto + sistema en vivo
   ============================================================ */
:root{
  --bg:#080A0C;
  --bg-2:#0E1216;
  --bone:#EDE8DD;
  --bone-dim:rgba(237,232,221,.55);
  --bone-faint:rgba(237,232,221,.32);
  --gold:#C9A06A;
  --line:rgba(237,232,221,.14);
  --line-soft:rgba(237,232,221,.08);
  --disp:"Syne",system-ui,sans-serif;
  --sans:"Inter",system-ui,sans-serif;
  --serif:"Fraunces",Georgia,serif;
  --pad:clamp(18px,4.5vw,80px);
  --maxw:1400px;
  --ease:cubic-bezier(.19,1,.22,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-font-smoothing:antialiased}
body{font-family:var(--sans);background:var(--bg);color:var(--bone);line-height:1.55;overflow-x:hidden}
img,video,canvas{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
em{font-style:italic}
::selection{background:var(--gold);color:var(--bg)}

/* Intro · carga tipo batería */
.intro{position:fixed;inset:0;z-index:10000;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:30px;overflow:hidden}
.intro.is-done{transform:translateY(-100%);transition:transform .85s var(--ease)}
.intro__brand{font-family:var(--disp);font-weight:800;font-size:clamp(1.8rem,6vw,3.6rem);letter-spacing:-.03em;color:var(--bone)}
.intro__brand span{color:var(--gold)}
.battery{position:relative;width:min(74vw,300px);height:34px;border:2px solid var(--bone);border-radius:8px;padding:4px;display:flex}
.battery__fill{width:0;height:100%;background:var(--gold);border-radius:3px;transition:width .12s linear}
.battery__nub{position:absolute;right:-9px;top:50%;transform:translateY(-50%);width:6px;height:14px;background:var(--bone);border-radius:0 3px 3px 0}
.intro__count{font-family:var(--disp);font-weight:700;font-size:.95rem;color:var(--gold);font-variant-numeric:tabular-nums;letter-spacing:.05em}

/* Cursor */
.cursor{position:fixed;top:0;left:0;width:30px;height:30px;border:1px solid rgba(237,232,221,.5);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .3s var(--ease),height .3s var(--ease),background .3s,border-color .3s;display:none}
.cursor__dot{position:absolute;top:50%;left:50%;width:4px;height:4px;border-radius:50%;background:var(--gold);transform:translate(-50%,-50%)}
.cursor.is-hover{width:80px;height:80px;background:var(--gold);border-color:transparent;mix-blend-mode:difference}
.cursor.is-hover .cursor__dot{opacity:0}
@media(pointer:fine){.cursor{display:block}body{cursor:none}a,button,summary,[data-magnetic],input{cursor:none}}

.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--gold);z-index:9998}

/* Nav */
.nav{position:fixed;top:0;left:0;width:100%;z-index:900;display:flex;align-items:center;justify-content:space-between;padding:22px var(--pad);transition:padding .4s,background .4s,backdrop-filter .4s,border-color .4s;border-bottom:1px solid transparent;mix-blend-mode:difference}
.nav.is-scrolled{mix-blend-mode:normal;padding:13px var(--pad);background:rgba(8,10,12,.7);backdrop-filter:blur(18px);border-bottom:1px solid var(--line-soft)}
.nav__brand{font-family:var(--disp);font-weight:800;font-size:1.5rem;letter-spacing:-.03em}
.nav__brand span{color:var(--gold)}
.nav__links{display:flex;gap:34px}
.nav__links a{font-size:.82rem;letter-spacing:.02em;color:var(--bone-dim);transition:color .3s}
.nav__links a:hover{color:var(--bone)}
@media(max-width:820px){.nav__links{display:none}.nav{mix-blend-mode:normal;background:rgba(8,10,12,.6);backdrop-filter:blur(12px);border-bottom:1px solid var(--line-soft)}}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;font-family:var(--disp);font-weight:700;font-size:.85rem;letter-spacing:.01em;padding:16px 30px;border-radius:0;border:1px solid transparent;transition:transform .4s var(--ease),background .3s,color .3s,border-color .3s;will-change:transform}
.btn--primary{background:var(--gold);color:var(--bg)}
.btn--primary:hover{background:var(--bone)}
.btn--nav{background:var(--bone);color:var(--bg);padding:11px 22px}
.btn--nav:hover{background:var(--gold)}
.btn--xl{padding:24px 54px;font-size:1.05rem}
/* CTA "Pruébame" siempre visible (incl. tablet/móvil); se redimensiona en bloque móvil */
@media(max-width:820px){.btn--nav{padding:11px 20px}}

.eyebrow{font-family:var(--disp);font-weight:700;font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold)}
.section{padding:clamp(80px,13vh,180px) var(--pad);max-width:var(--maxw);margin:0 auto;position:relative}
.section__head{margin-bottom:clamp(44px,6vw,80px);display:flex;flex-direction:column;gap:16px}
.h2{font-family:var(--disp);font-weight:700;font-size:clamp(1.9rem,5vw,3.8rem);line-height:1.02;letter-spacing:-.03em;max-width:18ch}

/* HERO MANIFIESTO */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:center;padding:140px var(--pad) 70px;overflow:hidden}
.hero__media{position:absolute;inset:0;z-index:-1;background:var(--bg)}
.hero__canvas{position:absolute;inset:0;width:100%;height:100%}
.hero__grain{position:absolute;inset:0;opacity:.07;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.hero__veil{position:absolute;inset:0;background:radial-gradient(130% 90% at 10% 20%,rgba(8,10,12,.5),rgba(8,10,12,.85) 70%,var(--bg))}
.hero__eyebrow{margin-bottom:clamp(20px,3vw,36px)}
.manifesto{font-family:var(--disp);font-weight:800;font-size:clamp(2.6rem,9vw,8.4rem);line-height:.92;letter-spacing:-.045em;text-transform:none}
.manifesto .ln{display:block;overflow:hidden}
.manifesto .ln>span{display:block;transform:translateY(105%);animation:lnUp 1s var(--ease) forwards}
.manifesto .ln:nth-child(1)>span{animation-delay:1.15s}
.manifesto .ln:nth-child(2)>span{animation-delay:1.25s}
.manifesto .ln:nth-child(3)>span{animation-delay:1.35s}
.manifesto .ln:nth-child(4)>span{animation-delay:1.45s}
.manifesto .ln--g>span{color:var(--gold)}
@keyframes lnUp{to{transform:translateY(0)}}
.hero__foot{display:flex;align-items:flex-end;justify-content:space-between;gap:40px;margin-top:clamp(34px,5vw,60px);flex-wrap:wrap}
.hero__sub{font-size:clamp(1rem,1.5vw,1.25rem);max-width:46ch;color:var(--bone-dim)}
.hero__sub strong{color:var(--bone);font-weight:500}
.hero__cta{display:inline-flex;align-items:center;gap:14px;font-family:var(--disp);font-weight:700;font-size:1.1rem;padding:18px 30px;border:1px solid var(--bone);transition:background .3s,color .3s,transform .4s var(--ease);will-change:transform}
.hero__cta i{font-style:normal;color:var(--gold)}
.hero__cta:hover{background:var(--bone);color:var(--bg)}
.hero__cta:hover i{color:var(--bg)}
.hero__scroll{position:absolute;bottom:30px;left:var(--pad);display:flex;align-items:center;gap:12px;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--bone-faint)}
.hero__scroll span{width:38px;height:1px;background:var(--bone-faint);position:relative;overflow:hidden}
.hero__scroll span::after{content:"";position:absolute;inset:0;background:var(--gold);transform:translateX(-100%);animation:sl 2.4s var(--ease) infinite}
@keyframes sl{0%{transform:translateX(-100%)}60%,100%{transform:translateX(100%)}}

/* Brutal marquee */
.brutmarquee{border-top:1px solid var(--bone);border-bottom:1px solid var(--bone);overflow:hidden;white-space:nowrap;background:var(--gold)}
.brutmarquee__t{display:inline-flex;gap:0;align-items:center;animation:mq 26s linear infinite}
.brutmarquee__t span{font-family:var(--disp);font-weight:800;font-size:clamp(1.6rem,4vw,3rem);letter-spacing:-.02em;color:var(--bg);padding:14px 30px}
.brutmarquee__t b{color:var(--bg);font-size:1.4rem;opacity:.5}
@keyframes mq{to{transform:translateX(-50%)}}

/* PROBAR */
.probar{display:grid;grid-template-columns:1fr .82fr;gap:clamp(40px,6vw,90px);align-items:center;max-width:var(--maxw);margin:0 auto;padding:clamp(80px,13vh,170px) var(--pad)}
.probar__head{display:flex;flex-direction:column;gap:22px}
.big{font-family:var(--disp);font-weight:800;font-size:clamp(2.4rem,6.5vw,5.5rem);line-height:.96;letter-spacing:-.04em}
.big em{color:var(--gold)}
.probar__lead{font-size:clamp(1rem,1.4vw,1.2rem);color:var(--bone-dim);max-width:44ch}
.probar__hint{font-size:.85rem;color:var(--bone-faint);font-family:var(--disp);font-weight:600}
@media(max-width:860px){.probar{grid-template-columns:1fr}}

/* Phone (demo) */
.phone{background:var(--bone);color:#15171A;border-radius:6px;max-width:380px;margin:0 auto;width:100%;box-shadow:0 50px 120px -30px rgba(0,0,0,.8);overflow:hidden;display:flex;flex-direction:column;height:548px;border:1px solid rgba(237,232,221,.1)}
.phone__bar{display:flex;align-items:center;gap:12px;padding:18px 20px;background:#fff;border-bottom:1px solid rgba(0,0,0,.08)}
.phone__dot{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--gold),#15171A);flex:none}
.phone__bar strong{display:block;font-size:.92rem}.phone__bar em{font-style:normal;font-size:.72rem;color:#2a8a4a}
.phone__chat{flex:1;overflow-y:auto;padding:22px 18px;display:flex;flex-direction:column;gap:12px}
.bubble{max-width:80%;padding:11px 15px;border-radius:14px;font-size:.92rem;line-height:1.45;animation:pop .35s var(--ease)}
.bubble--in{align-self:flex-start;background:#fff;border:1px solid rgba(0,0,0,.08);border-bottom-left-radius:4px}
.bubble--out{align-self:flex-end;background:var(--bg);color:var(--bone);border-bottom-right-radius:4px}
.bubble--typing{align-self:flex-start;background:#fff;border:1px solid rgba(0,0,0,.08);display:flex;gap:5px;padding:14px 16px}
.bubble--typing span{width:7px;height:7px;border-radius:50%;background:rgba(0,0,0,.35);animation:blink 1.2s infinite}
.bubble--typing span:nth-child(2){animation-delay:.2s}.bubble--typing span:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,60%,100%{opacity:.25}30%{opacity:1}}
@keyframes pop{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.phone__input{display:flex;gap:8px;padding:14px;border-top:1px solid rgba(0,0,0,.08);background:#fff}
.phone__input input{flex:1;border:1px solid rgba(0,0,0,.14);border-radius:100px;padding:12px 18px;font-family:var(--sans);font-size:.9rem;outline:none;color:#15171A}
.phone__input button{width:46px;height:46px;border:none;border-radius:50%;background:var(--bg);color:var(--bone);font-size:1.1rem;flex:none;transition:transform .3s}
.phone__input button:hover{transform:scale(1.08)}

/* COST */
.cost{padding:clamp(80px,13vh,170px) var(--pad);max-width:var(--maxw);margin:0 auto;border-top:1px solid var(--line)}
.cost .eyebrow{margin-bottom:26px}
.costline{font-family:var(--disp);font-weight:800;font-size:clamp(2rem,6vw,5rem);line-height:.98;letter-spacing:-.04em;margin-bottom:clamp(44px,6vw,80px)}
.costline em{color:var(--gold)}
.costgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-soft);border:1px solid var(--line-soft)}
.costcard{background:var(--bg);padding:clamp(28px,3vw,46px);min-height:260px;display:flex;flex-direction:column;justify-content:space-between;transition:background .4s}
.costcard span{font-family:var(--disp);font-weight:800;font-size:2.4rem;color:var(--gold)}
.costcard p{font-size:1.12rem;color:var(--bone-dim)}
.costcard:hover{background:var(--bg-2)}
@media(max-width:760px){.costgrid{grid-template-columns:1fr}}

/* SYSTEM cards */
.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line-soft);border:1px solid var(--line-soft)}
.card{background:var(--bg);padding:clamp(32px,3.5vw,54px);min-height:290px;display:flex;flex-direction:column;transition:background .45s}
.card__idx{font-family:var(--disp);font-weight:800;font-size:1rem;color:var(--gold);margin-bottom:auto}
.card h3{font-family:var(--disp);font-weight:700;font-size:clamp(1.3rem,2.2vw,1.9rem);letter-spacing:-.02em;margin:38px 0 14px;line-height:1.1}
.card p{color:var(--bone-dim);font-size:.98rem}
.card:hover{background:var(--bg-2)}
.system__anchor{font-family:var(--disp);font-weight:700;font-size:clamp(1.4rem,3vw,2.4rem);letter-spacing:-.02em;line-height:1.12;margin-top:clamp(44px,6vw,80px);max-width:26ch}
.system__anchor em{color:var(--gold)}
@media(max-width:760px){.cards{grid-template-columns:1fr}}

/* WHO */
.who__grid{display:grid;grid-template-columns:.8fr 1fr;gap:clamp(36px,6vw,88px);align-items:center}
.who__media{border:1px solid var(--line);overflow:hidden;aspect-ratio:4/5}
.who__media img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.05) brightness(.95);transition:filter .6s var(--ease),transform 1s var(--ease)}
.who__media:hover img{filter:grayscale(0) contrast(1) brightness(1);transform:scale(1.04)}
.who__body{display:flex;flex-direction:column;gap:20px}
.who__body p{color:var(--bone-dim);font-size:1.05rem;max-width:50ch}
.pull{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(1.3rem,2.4vw,2rem);line-height:1.3;color:var(--gold);border-left:2px solid var(--gold);padding-left:24px;margin-top:12px}
@media(max-width:820px){.who__grid{grid-template-columns:1fr}.who__media{max-width:420px;aspect-ratio:3/4}}
/* En táctil no hay hover → mostrar la foto en color por defecto */
@media(hover:none){.who__media img{filter:grayscale(0) contrast(1) brightness(1)}}

/* FOLLOW */
.follow{border-top:1px solid var(--line);text-align:center}
.follow__inner{max-width:900px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:26px}
.follow__title{font-family:var(--disp);font-weight:800;font-size:clamp(2rem,5.5vw,4.4rem);line-height:1;letter-spacing:-.04em}
.follow__text{color:var(--bone-dim);font-size:1.1rem;max-width:50ch}
.follow__links{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:10px}
.follow__link{font-family:var(--disp);font-weight:700;padding:16px 26px;border:1px solid var(--line);transition:background .3s,color .3s,transform .4s var(--ease);will-change:transform}
.follow__link span{color:var(--bone-faint);font-weight:400;font-family:var(--sans);margin-left:8px}
.follow__link:hover{background:var(--gold);color:var(--bg)}
.follow__link:hover span{color:rgba(8,10,12,.7)}

/* PRICE JOKE */
.pricejoke{border-top:1px solid var(--line)}
.pricejoke .eyebrow{margin-bottom:26px}
.priceline{font-family:var(--disp);font-weight:800;font-size:clamp(2.2rem,6.5vw,5.6rem);line-height:.98;letter-spacing:-.04em;margin-bottom:34px}
.priceline em{color:var(--gold)}
.pricejoke__text{font-size:clamp(1.05rem,1.5vw,1.3rem);color:var(--bone-dim);max-width:54ch}

/* LANG / SIN FRONTERAS */
.lang{padding:clamp(80px,13vh,170px) var(--pad);max-width:var(--maxw);margin:0 auto;border-top:1px solid var(--line)}
.lang .eyebrow{margin-bottom:26px}
.langline{font-family:var(--disp);font-weight:800;font-size:clamp(2.2rem,7vw,6rem);line-height:.96;letter-spacing:-.04em;margin-bottom:34px}
.lang__text{font-size:clamp(1.05rem,1.6vw,1.35rem);color:var(--bone-dim);max-width:56ch}
.lang__text em{color:var(--gold);font-style:italic}

/* TRAINING / FORMACIÓN */
.training{border-top:1px solid var(--line)}
.training__lead{font-size:clamp(1.05rem,1.5vw,1.3rem);color:var(--bone-dim);max-width:54ch;margin-top:6px}
.train-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-soft);border:1px solid var(--line-soft)}
.train-card{background:var(--bg);padding:clamp(30px,3vw,48px);min-height:280px;display:flex;flex-direction:column;transition:background .4s}
.train-card span{font-family:var(--disp);font-weight:800;font-size:1rem;color:var(--gold);margin-bottom:auto}
.train-card h3{font-family:var(--disp);font-weight:700;font-size:clamp(1.2rem,2vw,1.7rem);letter-spacing:-.02em;margin:36px 0 14px;line-height:1.12}
.train-card p{color:var(--bone-dim);font-size:.98rem}
.train-card p strong{color:var(--gold);font-weight:700}
.train-card:hover{background:var(--bg-2)}
.creds{margin-top:clamp(40px,5vw,64px);display:flex;flex-direction:column;gap:22px;border-top:1px solid var(--line-soft);padding-top:clamp(32px,4vw,52px)}
.creds__label{font-family:var(--disp);font-weight:700;font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--bone-faint)}
.creds__list{list-style:none;display:flex;flex-wrap:wrap;gap:10px}
.creds__list li{font-size:.86rem;color:var(--bone-dim);border:1px solid var(--line);padding:9px 16px;border-radius:100px}
.train-cta{align-self:flex-start;font-family:var(--disp);font-weight:700;font-size:1.05rem;display:inline-flex;gap:10px;align-items:center;padding:15px 26px;background:var(--bone);color:var(--bg);transition:background .3s,transform .4s var(--ease);will-change:transform}
.train-cta i{font-style:normal;color:var(--gold)}
.train-cta:hover{background:var(--gold)}
@media(max-width:760px){.train-grid{grid-template-columns:1fr}}

/* SECTORS */
.sectorgrid{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line-soft);border:1px solid var(--line-soft)}
.sectorgrid li{background:var(--bg);padding:clamp(26px,3vw,42px) clamp(16px,2vw,28px);font-family:var(--disp);font-weight:700;font-size:clamp(1.05rem,1.5vw,1.4rem);letter-spacing:-.02em;min-height:128px;display:flex;align-items:flex-end;transition:background .35s,color .35s}
.sectorgrid li:hover{background:var(--gold);color:var(--bg)}
.sectors__note{margin-top:34px;color:var(--bone-dim);font-size:1.05rem;max-width:48ch}
@media(max-width:860px){.sectorgrid{grid-template-columns:repeat(2,1fr)}}

/* CTA */
.cta{max-width:none;background:var(--gold);color:var(--bg);text-align:center;padding:clamp(90px,15vh,200px) var(--pad)}
.cta__inner{max-width:900px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:30px}
.cta__title{font-family:var(--disp);font-weight:800;font-size:clamp(2.2rem,6vw,5rem);line-height:.98;letter-spacing:-.04em}
.cta .btn--primary{background:var(--bg);color:var(--bone)}
.cta .btn--primary:hover{background:var(--bone);color:var(--bg)}
.cta__note{font-size:.95rem;color:rgba(8,10,12,.7)}

/* Footer */
.footer{padding:clamp(50px,7vw,90px) var(--pad);display:grid;grid-template-columns:1fr 1fr 1fr;gap:30px;align-items:start;border-top:1px solid var(--line)}
.footer__brand{font-family:var(--disp);font-weight:800;font-size:1.5rem}
.footer__brand span{color:var(--gold)}
.footer__meta{font-size:.9rem;color:var(--bone-dim);display:flex;flex-direction:column;gap:6px}
.footer__meta a:hover{color:var(--gold)}
.footer__social{display:flex;gap:22px;font-size:.85rem;color:var(--bone-dim);justify-content:flex-end;flex-wrap:wrap}
.footer__social a:hover{color:var(--gold)}
.footer__line{grid-column:1/-1;font-family:var(--disp);font-weight:800;font-size:clamp(2.2rem,9vw,7rem);color:var(--bg-2);letter-spacing:-.04em;margin-top:40px;line-height:1}
@media(max-width:760px){.footer{grid-template-columns:1fr}.footer__social{justify-content:flex-start}}

/* Reveal */
[data-reveal]{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
[data-reveal].is-in{opacity:1;transform:none}
.reveal{opacity:0;transform:translateY(20px);animation:fadeup 1s var(--ease) forwards}
.hero__eyebrow.reveal{animation-delay:1.05s}
.hero__sub.reveal{animation-delay:1.6s}.hero__cta.reveal{animation-delay:1.7s}
@keyframes fadeup{to{opacity:1;transform:none}}

/* ---------- Móvil ---------- */
@media(max-width:600px){
  .nav{padding:15px var(--pad);mix-blend-mode:normal;background:rgba(8,10,12,.55);backdrop-filter:blur(10px)}
  .nav.is-scrolled{padding:11px var(--pad)}
  .btn--nav{display:inline-flex;padding:10px 18px;font-size:.78rem}
  .nav__brand{font-size:1.3rem}

  .hero{min-height:92svh;padding:118px var(--pad) 56px}
  .manifesto{font-size:clamp(2.1rem,11.5vw,3.4rem);line-height:.98;letter-spacing:-.035em}
  .hero__foot{gap:24px}
  .hero__sub{font-size:1rem}
  .hero__cta{font-size:1rem;padding:16px 24px}
  .hero__scroll{display:none}

  .brutmarquee__t span{font-size:clamp(1.3rem,7vw,2rem);padding:12px 18px}

  .probar{padding:64px var(--pad)}
  .big{font-size:clamp(2.1rem,11vw,3.2rem)}
  .phone{height:480px}

  .section{padding:64px var(--pad)}
  .section__head{margin-bottom:36px}
  .cost,.lang{padding:64px var(--pad)}
  .costline,.langline,.priceline{font-size:clamp(2rem,10vw,3.2rem);line-height:1}
  .h2{font-size:clamp(1.7rem,8vw,2.4rem)}
  .costcard{min-height:auto}
  .card{min-height:auto}
  .train-card{min-height:auto}
  .system__anchor{font-size:clamp(1.3rem,6vw,2rem)}
  .follow__title,.cta__title{font-size:clamp(2rem,10vw,3.2rem)}
  .pull{font-size:1.3rem}
  .creds__list{gap:8px}
  .creds__list li{font-size:.8rem;padding:8px 13px}
  .follow__links,.hero__cta{width:100%}
  .footer__line{font-size:clamp(2.4rem,15vw,4rem)}
}
@media(max-width:380px){
  .manifesto{font-size:2rem}
  .big,.costline,.langline,.priceline,.follow__title,.cta__title{font-size:1.9rem}
}

@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}[data-reveal]{opacity:1;transform:none}.manifesto .ln>span{transform:none!important}.intro{display:none}}

/* ---------- Páginas legales ---------- */
.legal-page{cursor:auto}
.legal-page a,.legal-page button,.legal-page summary{cursor:pointer}
.legal{max-width:820px;margin:0 auto;padding:clamp(120px,18vh,200px) var(--pad) clamp(70px,10vh,120px)}
.legal h1{font-family:var(--disp);font-weight:800;font-size:clamp(2.2rem,6vw,4.2rem);line-height:1;letter-spacing:-.03em;margin-bottom:14px}
.legal__updated{color:var(--bone-faint);font-size:.85rem;margin-bottom:clamp(40px,6vw,64px)}
.legal h2{font-family:var(--disp);font-weight:700;font-size:clamp(1.3rem,2.6vw,1.9rem);letter-spacing:-.02em;margin:clamp(36px,5vw,56px) 0 16px;line-height:1.15}
.legal h2 .n{color:var(--gold);margin-right:.45em}
.legal p,.legal li{color:var(--bone-dim);font-size:1.02rem;line-height:1.7;margin-bottom:16px}
.legal strong{color:var(--bone);font-weight:600}
.legal a{color:var(--gold);text-decoration:underline;text-underline-offset:3px}
.legal a:hover{color:var(--bone)}
.legal ul{list-style:none;padding-left:0;margin-bottom:16px}
.legal li{position:relative;padding-left:22px}
.legal li::before{content:"—";position:absolute;left:0;color:var(--gold)}
.legal .todo{color:var(--gold);font-weight:600;border:1px dashed var(--gold);padding:1px 7px;border-radius:4px;font-size:.92em}
.legal__box{border:1px solid var(--line);padding:clamp(22px,3vw,32px);margin:24px 0;background:var(--bg-2)}
.legal__box p:last-child{margin-bottom:0}
@media(max-width:600px){.legal{padding:104px var(--pad) 64px}}
