/* ==========================================================================
   ZURE SARE INFORMATIKA — Hoja de estilos
   Paleta de marca: verde bosque + tinta negra sobre crema
   Motif: la malla de la "sare" (red) como firma visual
   ========================================================================== */

/* ---------- Tokens ---------- */
:root{
  /* Paleta de marca: verde (la "sare") sobre crema cálido, con acento ámbar
     para dar viveza. Los tokens --forest* son el color de marca. */
  --ink:#15211b;
  --ink-soft:#33433a;
  --forest:#14532d;
  --forest-deep:#0d3b20;
  --forest-bright:#1f7a48;
  --forest-glow:#2f9e63;
  --accent:#f59e0b;
  --accent-deep:#d97706;
  --cream:#f7f4ec;
  --cream-soft:#fbf9f2;
  --paper:#ffffff;
  --muted:#5e6b62;
  --line:rgba(21,33,27,.12);
  --line-strong:rgba(21,33,27,.24);

  --sans:"Inter","Segoe UI",system-ui,-apple-system,sans-serif;
  --serif:"Inter","Segoe UI",system-ui,-apple-system,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;

  --maxw:1240px;
  --radius:18px;
  --radius-sm:12px;
  --shadow-sm:0 2px 10px rgba(0,0,0,.06);
  --shadow:0 18px 50px -22px rgba(0,0,0,.30);
  --shadow-lg:0 40px 90px -40px rgba(0,0,0,.45);
  --ease:cubic-bezier(.16,1,.3,1);

  /* malla de red en SVG, sutil, como textura de fondo */
  --mesh:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 22 22'%3E%3Ccircle cx='1' cy='1' r='1' fill='%2315803d' fill-opacity='0.22'/%3E%3C/svg%3E");
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none}
::selection{background:var(--forest);color:#f7f4ec}

/* ---------- Layout helpers ---------- */
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(20px,5vw,48px)}
.section{padding-block:clamp(72px,10vw,140px);position:relative}
.eyebrow{
  font-family:var(--sans);
  font-weight:700;
  font-size:.78rem;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--forest);
  display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:34px;height:2.5px;background:var(--accent);border-radius:2px}
h1,h2,h3,h4{font-family:var(--sans);line-height:1.02;font-weight:800;letter-spacing:-.035em;color:var(--ink)}
h1{font-size:clamp(3rem,8.4vw,6.4rem);font-weight:900;line-height:.96;letter-spacing:-.045em}
h2{font-size:clamp(2rem,4.8vw,3.6rem);font-weight:800}
h3{font-size:clamp(1.3rem,2.4vw,1.6rem);font-weight:700;letter-spacing:-.02em}
.lead{font-size:clamp(1.05rem,1.6vw,1.28rem);color:var(--ink-soft);max-width:62ch}

/* ---------- Lang switching ---------- */
[data-lang]{display:none}
html[lang="eu"] [data-lang="eu"]{display:revert}
html[lang="es"] [data-lang="es"]{display:revert}
/* inline variants keep flow */
span[data-lang],em[data-lang],strong[data-lang]{display:none}
html[lang="eu"] span[data-lang="eu"],
html[lang="eu"] em[data-lang="eu"],
html[lang="eu"] strong[data-lang="eu"]{display:inline}
html[lang="es"] span[data-lang="es"],
html[lang="es"] em[data-lang="es"],
html[lang="es"] strong[data-lang="es"]{display:inline}

/* ==========================================================================
   HEADER
   ========================================================================== */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:100;
  transition:all .45s var(--ease);
  background:transparent;
}
.site-header.scrolled{
  background:rgba(247,244,236,.92);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  box-shadow:0 1px 0 var(--line),0 12px 30px -24px rgba(0,0,0,.4);
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px;padding-block:18px;transition:padding .4s var(--ease)}
.site-header.scrolled .nav{padding-block:12px}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:46px;width:auto;transition:height .4s var(--ease)}
.site-header.scrolled .brand img{height:40px}

.nav-links{display:flex;align-items:center;gap:6px}
.nav-links>.btn{display:none} /* CTA solo para el panel móvil; en escritorio se usa .nav-cta */
.nav-links a{
  position:relative;font-weight:700;font-size:.78rem;padding:10px 14px;border-radius:999px;
  color:var(--ink-soft);transition:color .25s,background .25s;
  text-transform:uppercase!important;letter-spacing:.12em;
}
.nav-links a::after{
  content:"";position:absolute;left:16px;right:16px;bottom:6px;height:2px;
  background:var(--forest);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease);
}
.nav-links a:hover{color:var(--forest)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-links a.active{color:var(--forest)}

.nav-tools{display:flex;align-items:center;gap:14px}

.lang-toggle{
  display:inline-flex;align-items:center;border:1.5px solid var(--line-strong);
  border-radius:999px;overflow:hidden;font-weight:700;font-size:.8rem;letter-spacing:.04em;
}
.lang-toggle button{padding:7px 13px;color:var(--muted);transition:all .25s}
.lang-toggle button.on{background:var(--forest);color:#f7f4ec}

.btn{
  display:inline-flex;align-items:center;gap:.6em;font-weight:700;font-size:.95rem;
  padding:13px 24px;border-radius:999px;transition:all .3s var(--ease);white-space:nowrap;
  letter-spacing:.01em;position:relative;overflow:hidden;
}
.btn-primary{background:var(--forest);color:#f7f4ec;box-shadow:0 0 0 1px var(--forest-bright),0 14px 32px -8px rgba(21,128,61,.45),inset 0 1px 0 rgba(255,255,255,.1)}
.btn-primary::before{
  content:"";position:absolute;top:0;bottom:0;left:-60%;width:50%;
  background:linear-gradient(110deg,transparent 0%,rgba(255,255,255,.4) 50%,transparent 100%);
  transform:skewX(-22deg);transition:left .55s var(--ease);pointer-events:none;
}
.btn-primary:hover::before{left:120%}
.btn-primary:hover{box-shadow:0 0 0 1px var(--forest-glow),0 20px 40px -8px rgba(31,154,77,.6),inset 0 1px 0 rgba(255,255,255,.18);transform:translateY(-2px);background:var(--forest-deep)}
.btn-ghost{border:1.5px solid var(--line-strong);color:var(--ink)}
.btn-ghost:hover{border-color:var(--forest);color:var(--forest);background:rgba(21,128,61,.05)}
.btn-light{background:var(--cream);color:var(--forest)}
.btn-light:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.btn .arrow{transition:transform .3s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}

.burger{display:none;width:44px;height:44px;border-radius:12px;border:1.5px solid var(--line-strong);position:relative}
.burger span{position:absolute;left:11px;right:11px;height:2px;background:var(--ink);transition:.35s var(--ease)}
.burger span:nth-child(1){top:15px}
.burger span:nth-child(2){top:21px}
.burger span:nth-child(3){top:27px}
.burger.open span:nth-child(1){top:21px;transform:rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){top:21px;transform:rotate(-45deg)}

/* ==========================================================================
   HERO
   ========================================================================== */
.hero{
  position:relative;padding-top:clamp(140px,18vh,200px);padding-bottom:clamp(70px,9vw,120px);
  overflow:hidden;
  background:
    radial-gradient(120% 90% at 100% -10%,rgba(0,0,0,.10),transparent 55%),
    radial-gradient(80% 70% at -10% 110%,rgba(0,0,0,.08),transparent 50%),
    var(--cream);
}
.hero::before{
  content:"";position:absolute;inset:0;background-image:var(--mesh);background-size:44px 44px;
  opacity:.9;mask-image:linear-gradient(180deg,transparent,#000 25%,#000 70%,transparent);
  pointer-events:none;
}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(30px,5vw,70px);align-items:center;position:relative;z-index:2}
.hero h1{margin:.35em 0 .5em}
.hero h1 .accent{color:var(--forest);font-weight:900;position:relative;white-space:nowrap;font-style:normal}
.hero h1 .accent::after{content:"";position:absolute;left:0;right:0;bottom:.04em;height:.12em;background:var(--forest);border-radius:2px}
.hero .lead{margin-bottom:34px}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:40px}
.hero-meta{display:flex;flex-wrap:wrap;gap:28px;padding-top:26px;border-top:1px solid var(--line)}
.hero-meta div span{display:block;font-family:var(--serif);font-size:1.9rem;color:var(--forest);line-height:1}
.hero-meta div small{font-size:.82rem;color:var(--muted);letter-spacing:.02em}

.hero-visual{position:relative;display:grid;place-items:center}
.hero-visual{position:relative;display:flex;flex-direction:column;align-items:stretch;gap:8px}
.hero-art{position:relative;width:100%;display:grid;place-items:center;padding:clamp(10px,2.5vw,28px);margin-top:-30px}
.hero-art::before{content:"";position:absolute;width:80%;aspect-ratio:1;border-radius:50%;z-index:0;
  background:radial-gradient(circle,rgba(21,128,61,.16),rgba(21,128,61,.04) 55%,transparent 70%);
  animation:halo 6s ease-in-out infinite}
.hero-art img{position:relative;z-index:2;width:100%;max-width:210px;height:auto;
  filter:drop-shadow(0 18px 30px rgba(21,33,27,.16))}
.hero-badge{
  position:absolute;z-index:3;background:var(--forest);color:#f7f4ec;
  border-radius:16px;padding:13px 17px;box-shadow:var(--shadow);display:flex;gap:11px;align-items:center;
  font-weight:600;font-size:.86rem;line-height:1.25;
}
.hero-badge svg{flex:0 0 auto;width:24px;height:24px}
.hero-badge.b1{top:8%;right:4%;animation:floaty-soft 5s var(--ease) infinite}
.hero-badge.b2{bottom:10%;left:2%;background:var(--paper);color:var(--ink);border:1px solid var(--line);animation:floaty-soft 6s var(--ease) infinite .7s}

/* ----- Mockup tipo terminal flotante ----- */
.hero-term{
  position:relative;align-self:flex-end;margin-right:4%;margin-top:-10px;
  width:min(280px,90%);
  background:#0d1f15;color:#a7f3c5;border-radius:14px;padding:0;
  font-family:var(--mono);font-size:.78rem;line-height:1.55;
  box-shadow:0 22px 50px -12px rgba(13,31,21,.55),0 0 0 1px rgba(74,222,128,.18),inset 0 1px 0 rgba(255,255,255,.04);
  overflow:hidden;
  animation:term-float 7s ease-in-out infinite;
}
.term-bar{
  display:flex;align-items:center;gap:6px;padding:9px 12px;background:#08160e;
  border-bottom:1px solid rgba(74,222,128,.10);
}
.term-bar .dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto}
.term-bar .dot.r{background:#ef4444}.term-bar .dot.y{background:#f59e0b}.term-bar .dot.g{background:#22c55e}
.term-title{margin-left:8px;color:#5a8c70;font-size:.7rem;letter-spacing:.04em}
.term-body{padding:14px 14px 16px;position:relative}
.term-line{white-space:pre;overflow:hidden;width:0;display:block;color:#d1fae5;animation:term-type 1s steps(30,end) forwards}
.term-line.ok{color:#4ade80}
.term-line::before{content:attr(data-text)}
.term-line:nth-child(1){animation-delay:.4s}
.term-line:nth-child(2){animation-delay:1.4s}
.term-line:nth-child(3){animation-delay:2.0s}
.term-line:nth-child(4){animation-delay:2.6s}
.term-line:nth-child(5){animation-delay:3.4s}
.term-cursor{display:inline-block;width:.6em;color:#22c55e;animation:blink 1s steps(2,start) infinite;font-weight:700}

@keyframes term-type{to{width:100%}}
@keyframes blink{50%{opacity:0}}
@keyframes term-float{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-10px) rotate(-1deg)}}

@media (max-width:980px){.hero-term{display:none}}
@media (prefers-reduced-motion:reduce){.hero-term,.term-line,.term-cursor{animation:none}.term-line{width:100%}}

@keyframes halo{0%,100%{transform:scale(1);opacity:.85}50%{transform:scale(1.07);opacity:1}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes floaty-soft{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.hero-badge.b2 svg{color:var(--forest)}

/* ==========================================================================
   MARQUEE
   ========================================================================== */
.marquee{background:var(--forest);color:#f7f4ec;overflow:hidden;padding-block:20px;border-block:1px solid var(--forest-deep)}
.marquee-track{display:flex;gap:0;white-space:nowrap;width:max-content;animation:scroll 32s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track span{font-family:var(--serif);font-size:clamp(1.1rem,2vw,1.6rem);font-style:italic;padding-inline:30px;display:inline-flex;align-items:center;gap:30px;opacity:.92}
.marquee-track span::after{content:"✦";font-style:normal;font-size:.7em;color:var(--forest-glow)}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ==========================================================================
   SERVICES
   ========================================================================== */
.section-head{max-width:760px;margin-bottom:clamp(40px,6vw,68px)}
.section-head h2{margin:.3em 0 .4em}

#servicios{background:var(--forest-deep);color:#f7f4ec;position:relative}
#servicios::before{content:"";position:absolute;inset:0;background-image:var(--mesh);background-size:34px 34px;opacity:.18;pointer-events:none;mask-image:radial-gradient(70% 70% at 80% 20%,#000,transparent)}
#servicios>.wrap{position:relative;z-index:2}
#servicios .section-head h2,#servicios .service-card h3{color:#f7f4ec}
#servicios .section-head p{color:rgba(255,255,255,.78)}
#servicios .eyebrow{color:#4ade80}
#servicios .btn-ghost{color:#f7f4ec;border-color:rgba(255,255,255,.35)}
#servicios .btn-ghost:hover{background:#f7f4ec;color:var(--forest);border-color:#f7f4ec}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;perspective:1000px}

/* ---------- STACK TECH (sistemas y marcas) ---------- */
.stack-band{background:var(--cream);position:relative;overflow:hidden}
.stack-band::before{content:"";position:absolute;inset:0;background-image:var(--mesh);background-size:22px 22px;opacity:.7;pointer-events:none;mask-image:radial-gradient(70% 80% at 20% 30%,#000,transparent 70%)}
.stack-band>.wrap{position:relative;z-index:2}
.stack-head{max-width:780px;margin-bottom:42px}
.stack-head h2{margin:8px 0 8px}
.stack-head p.muted{color:var(--muted);font-size:1.08rem}
.stack-label{display:inline-block;font-size:.78rem;color:var(--forest);font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin-bottom:14px}
.stack-group{margin-bottom:30px}
.stack-group:last-child{margin-bottom:0}
.pills{display:flex;flex-wrap:wrap;gap:10px}
.pill{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:999px;
  background:var(--paper);border:1px solid var(--line);color:var(--ink);
  font-size:.92rem;font-weight:600;font-family:var(--sans);letter-spacing:-.01em;
  box-shadow:0 1px 0 rgba(21,33,27,.05),0 8px 22px -10px rgba(21,33,27,.18);
  transition:transform .25s var(--ease),box-shadow .25s,border-color .25s;
  animation:pop-in .55s cubic-bezier(.34,1.56,.64,1) var(--d,0ms) both;
}
@keyframes pop-in{
  0%{opacity:0;transform:scale(.7) translateY(10px)}
  60%{opacity:1;transform:scale(1.06) translateY(-2px)}
  100%{opacity:1;transform:scale(1) translateY(0)}
}
.pill:hover{transform:translateY(-2px);border-color:var(--forest);box-shadow:0 4px 0 rgba(21,128,61,.06),0 14px 28px -10px rgba(21,128,61,.35)}
.pill .dot{width:6px;height:6px;border-radius:50%;background:var(--forest-bright);box-shadow:0 0 0 3px rgba(31,154,77,.18);animation:pulse 2.4s ease-in-out infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 3px rgba(31,154,77,.18)}50%{box-shadow:0 0 0 5px rgba(31,154,77,.06)}}
@media (prefers-reduced-motion:reduce){.pill .dot{animation:none}.pill{opacity:1;transform:none;animation:none!important}}

/* ---------- FRANJA LEMA (cita grande editorial) ---------- */
.quote-band{padding:clamp(70px,10vw,140px) 0;background:var(--cream);position:relative;overflow:hidden}
.quote-band::before{content:"\201C";position:absolute;top:-30px;left:50%;transform:translateX(-50%);font-family:var(--serif);font-size:clamp(8rem,16vw,18rem);color:var(--forest);opacity:.08;line-height:1;font-style:italic}
.quote-text{font-family:var(--serif);font-size:clamp(2rem,5.2vw,4.4rem);font-weight:500;line-height:1.04;color:var(--ink);max-width:1000px;margin:0 auto;text-align:center;letter-spacing:-.025em;position:relative;z-index:2}
.quote-text em{font-style:italic;color:var(--forest);font-weight:600}

/* ---------- Callout A DOMICILIO ---------- */
.callout-home{
  background:var(--forest);color:#f7f4ec;border-radius:clamp(18px,3vw,28px);
  padding:clamp(24px,3vw,38px) clamp(28px,3.5vw,44px);
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:clamp(20px,2.6vw,32px);
  box-shadow:var(--shadow-lg);position:relative;overflow:hidden;
}
.callout-home::after{
  content:"";position:absolute;inset:0;background-image:var(--mesh);background-size:34px 34px;
  opacity:.18;pointer-events:none;mask-image:radial-gradient(80% 60% at 80% 50%,#000,transparent);
}
.callout-ico{
  width:64px;height:64px;border-radius:18px;background:rgba(255,255,255,.12);
  color:#f7f4ec;display:grid;place-items:center;flex:0 0 auto;
}
.callout-ico svg{width:34px;height:34px}
.callout-text h3{color:#f7f4ec;margin-bottom:6px;font-weight:700}
.callout-text p{color:rgba(255,255,255,.82);margin:0}
.callout-home .btn{flex:0 0 auto;position:relative;z-index:2;background:var(--cream);color:var(--forest);border-color:#f7f4ec}
.callout-home .btn:hover{background:#fff;color:var(--forest-deep)}
.service-card{
  --mx:50%;--my:50%;
  position:relative;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:clamp(26px,3vw,38px);overflow:hidden;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s;
  transform-style:preserve-3d;
  will-change:transform;
}
.service-card::after{
  content:"";position:absolute;inset:0;pointer-events:none;border-radius:inherit;opacity:0;
  background:radial-gradient(380px circle at var(--mx) var(--my),rgba(31,154,77,.22),transparent 55%);
  transition:opacity .35s;
}
.service-card:hover::after{opacity:1}

.service-card:hover{transform:translateY(-6px) rotateX(var(--ry,0deg)) rotateY(var(--rx,0deg));box-shadow:var(--shadow);border-color:transparent;background:var(--forest)}

.service-card:hover h3{color:#f7f4ec}
.service-card:hover p{color:rgba(255,255,255,.72)}
.service-num{position:absolute;top:24px;right:28px;font-family:var(--serif);font-size:3.2rem;color:#f7f4ec;
  -webkit-text-stroke:1.4px var(--line-strong);line-height:1;transition:color .4s,-webkit-text-stroke .4s}
.service-card:hover .service-num{color:rgba(255,255,255,.10);-webkit-text-stroke:1.4px rgba(255,255,255,.32)}
.service-ico{
  width:78px;height:78px;border-radius:22px;display:grid;place-items:center;
  background:var(--forest);color:#f7f4ec;margin-bottom:22px;position:relative;z-index:2;
  box-shadow:0 14px 26px -10px rgba(20,83,45,.55);
  transition:background .4s,color .4s,transform .5s var(--ease),box-shadow .4s;
}
.service-card:hover .service-ico{background:var(--accent);color:#3a2400;transform:rotate(-6deg) scale(1.05);box-shadow:0 16px 30px -10px rgba(245,158,11,.55)}
.service-card:hover .tags span{color:var(--forest);background:rgba(255,255,255,.92)}
.service-ico svg{width:38px;height:38px;stroke-width:2}
.service-card h3{position:relative;z-index:2;margin-bottom:10px}
.service-card p{position:relative;z-index:2;color:var(--muted);font-size:.98rem}
.service-card .tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px;position:relative;z-index:2}
.service-card .tags span{font-size:.78rem;font-weight:600;color:var(--forest);background:rgba(21,128,61,.09);padding:5px 11px;border-radius:999px}

/* ==========================================================================
   FEATURE / WHY
   ========================================================================== */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,6vw,80px);align-items:center}
.split.flip .split-media{order:-1}
.feature-list{display:grid;gap:22px;margin-top:34px}
.feature-item{display:flex;gap:18px;align-items:flex-start}
.feature-item .fi-ico{flex:0 0 auto;width:48px;height:48px;border-radius:14px;background:rgba(0,0,0,.08);
  color:var(--forest);display:grid;place-items:center}
.feature-item .fi-ico svg{width:24px;height:24px}
.feature-item h4{font-family:var(--serif);font-size:1.18rem;margin-bottom:3px}
.feature-item p{color:var(--muted);font-size:.96rem}

.media-frame{
  position:relative;border-radius:24px;background:linear-gradient(160deg,var(--forest),var(--forest-deep));
  padding:clamp(34px,5vw,56px);overflow:hidden;color:#f7f4ec;box-shadow:var(--shadow-lg);
}
.media-frame::before{content:"";position:absolute;inset:0;background-image:var(--mesh);background-size:40px 40px;
  opacity:.5;filter:invert(1) brightness(2);mask-image:linear-gradient(135deg,#000,transparent 80%)}
.media-frame .mf-inner{position:relative;z-index:2}
.media-frame .stat-big{font-family:var(--serif);font-size:clamp(3rem,7vw,5rem);line-height:1;margin-bottom:6px}
.media-frame .stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:30px;padding-top:30px;
  border-top:1px solid rgba(255,255,255,.2)}
.media-frame .stat-grid span{display:block;font-family:var(--serif);font-size:2rem;color:var(--forest-glow)}
.media-frame .stat-grid small{opacity:.78;font-size:.84rem}

/* ==========================================================================
   PROCESS / STEPS
   ========================================================================== */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:50px;counter-reset:step}
.step{position:relative;padding:0 26px 0 0}
.step:not(:last-child)::after{content:"";position:absolute;top:26px;left:54px;right:0;height:1.5px;
  background:repeating-linear-gradient(90deg,var(--line-strong) 0 7px,transparent 7px 14px)}
.step .dot{width:54px;height:54px;border-radius:50%;background:var(--cream);border:1.5px solid var(--forest);
  color:var(--forest);display:grid;place-items:center;font-family:var(--serif);font-size:1.3rem;font-weight:600;
  position:relative;z-index:2;margin-bottom:20px}
.step h4{font-family:var(--serif);font-size:1.2rem;margin-bottom:6px}
.step p{color:var(--muted);font-size:.94rem;padding-right:18px}

/* ==========================================================================
   CTA BAND
   ========================================================================== */
.cta-band{position:relative;background:var(--forest-deep);color:#f7f4ec;border-radius:clamp(20px,4vw,34px);
  padding:clamp(44px,7vw,90px);overflow:hidden;text-align:center}
.cta-band::before{content:"";position:absolute;inset:0;background-image:var(--mesh);background-size:46px 46px;
  opacity:.4;filter:invert(1) brightness(1.6) sepia(.4) hue-rotate(80deg);
  mask-image:radial-gradient(80% 100% at 50% 0,#000,transparent)}
.cta-band > *{position:relative;z-index:2}
.cta-band h2{color:#f7f4ec;margin-bottom:14px}
.cta-band p{color:rgba(255,255,255,.8);max-width:54ch;margin:0 auto 32px}
.cta-band .hero-cta{justify-content:center}

/* ==========================================================================
   FOOTER
   ========================================================================== */
.site-footer{background:var(--forest-deep);color:rgba(255,255,255,.8);padding-block:clamp(56px,7vw,84px) 30px;position:relative;overflow:hidden}
.site-footer::before{content:"";position:absolute;inset:0;background-image:var(--mesh);background-size:48px 48px;
  opacity:.4;filter:invert(1) brightness(2);mask-image:linear-gradient(180deg,#000,transparent 60%)}
.footer-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:40px}
.footer-brand img{height:54px;width:auto;filter:brightness(0) invert(1);margin-bottom:18px}
.footer-brand p{font-size:.95rem;max-width:34ch}
.footer-col h5{font-family:var(--sans);font-weight:700;letter-spacing:.18em;text-transform:uppercase;font-size:.78rem;
  color:#f7f4ec;margin-bottom:18px}
.footer-col a{display:block;padding:6px 0;font-size:.96rem;transition:color .25s,transform .25s}
.footer-col a:hover{color:var(--forest-glow);transform:translateX(4px)}
.footer-contact a{display:flex;gap:10px;align-items:flex-start}
.footer-contact svg{width:18px;height:18px;color:var(--forest-glow);flex:0 0 auto;margin-top:4px}
.footer-bottom{position:relative;z-index:2;margin-top:48px;padding-top:24px;border-top:1px solid rgba(255,255,255,.16);
  display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center;font-size:.86rem}
.footer-bottom .socials{display:flex;gap:12px}
.footer-bottom .socials a{width:38px;height:38px;border-radius:10px;border:1px solid rgba(255,255,255,.2);
  display:grid;place-items:center;transition:all .3s var(--ease)}
.footer-bottom .socials a:hover{background:var(--forest-glow);border-color:var(--forest-glow);color:var(--forest-deep);transform:translateY(-3px)}
.footer-bottom .socials svg{width:18px;height:18px}

/* ==========================================================================
   PAGE HEADER (subpáginas)
   ========================================================================== */
.page-hero{position:relative;padding-top:clamp(150px,18vh,210px);padding-bottom:clamp(50px,7vw,90px);
  background:radial-gradient(110% 80% at 90% -20%,rgba(0,0,0,.10),transparent 55%),var(--cream);overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;background-image:var(--mesh);background-size:44px 44px;
  opacity:.8;mask-image:linear-gradient(180deg,transparent,#000 35%,transparent)}
.page-hero .wrap{position:relative;z-index:2}
.breadcrumb{font-size:.85rem;color:var(--muted);margin-bottom:18px;display:flex;gap:8px;align-items:center}
.breadcrumb a:hover{color:var(--forest)}
.page-hero h1{max-width:16ch}
.page-hero .lead{margin-top:18px}

/* ==========================================================================
   SERVICE DETAIL ROWS
   ========================================================================== */
.svc-row{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(30px,5vw,64px);align-items:center;
  padding-block:clamp(46px,6vw,80px);border-bottom:1px solid var(--line)}
.svc-row:last-child{border-bottom:none}
.svc-row.flip .svc-visual{order:-1}
.svc-row .svc-tag{color:var(--forest);font-weight:700;letter-spacing:.2em;text-transform:uppercase;font-size:.76rem}
.svc-row h2{font-size:clamp(1.7rem,3.4vw,2.7rem);margin:10px 0 16px}
.svc-row p{color:var(--ink-soft)}
.svc-checks{display:grid;gap:12px;margin-top:24px}
.svc-checks li{display:flex;gap:12px;align-items:flex-start;color:var(--ink-soft);font-size:.98rem}
.svc-checks svg{width:22px;height:22px;color:var(--forest);flex:0 0 auto;margin-top:2px}
.svc-visual{position:relative;border-radius:22px;aspect-ratio:5/4;overflow:hidden;
  background:linear-gradient(150deg,var(--forest),var(--forest-deep));display:grid;place-items:center;box-shadow:var(--shadow)}
.svc-visual::before{content:"";position:absolute;inset:0;background-image:var(--mesh);background-size:38px 38px;
  opacity:.55;filter:invert(1) brightness(2);mask-image:radial-gradient(80% 80% at 30% 30%,#000,transparent)}
.svc-visual .big-ico{position:relative;z-index:2;color:#f7f4ec}
.svc-visual .big-ico svg{width:clamp(80px,14vw,140px);height:auto;opacity:.95}
.svc-visual .svc-illu{position:relative;z-index:2;width:100%;height:100%;display:block}

/* ==========================================================================
   ABOUT / VALUES
   ========================================================================== */
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px}
.value-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:32px;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.value-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.value-card .v-ico{width:50px;height:50px;border-radius:14px;background:rgba(21,128,61,.10);color:var(--forest);
  display:grid;place-items:center;margin-bottom:18px}
.value-card .v-ico svg{width:26px;height:26px}
.value-card h3{font-size:1.3rem;margin-bottom:8px}
.value-card p{color:var(--muted);font-size:.96rem}

.about-photo{position:relative;border-radius:24px;padding:30px;display:grid;place-items:center;min-height:420px}
.about-photo::before{content:"";position:absolute;width:78%;aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle,rgba(21,128,61,.20),rgba(21,128,61,.05) 55%,transparent 70%);
  animation:halo 6s ease-in-out infinite}
.about-photo img{position:relative;z-index:2;max-width:78%;filter:drop-shadow(0 20px 34px rgba(21,33,27,.18))}

/* ==========================================================================
   CONTACT
   ========================================================================== */
.contact-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:clamp(34px,5vw,64px);align-items:start}
.contact-info .info-item{display:flex;gap:16px;align-items:flex-start;padding:20px 0;border-bottom:1px solid var(--line)}
.contact-info .info-item:last-child{border-bottom:none}
.contact-info .ci-ico{flex:0 0 auto;width:50px;height:50px;border-radius:14px;background:var(--forest);color:#f7f4ec;
  display:grid;place-items:center}
.contact-info .ci-ico svg{width:24px;height:24px}
.contact-info h4{font-family:var(--serif);font-size:1.15rem;margin-bottom:3px}
.contact-info a,.contact-info p{color:var(--muted);font-size:.98rem}
.contact-info a:hover{color:var(--forest)}

.form-card{background:var(--paper);border:1px solid var(--line);border-radius:24px;padding:clamp(28px,4vw,44px);box-shadow:var(--shadow)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{margin-bottom:18px}
.field label{display:block;font-weight:600;font-size:.88rem;margin-bottom:8px;color:var(--ink-soft)}
.field input,.field select,.field textarea{
  width:100%;padding:14px 16px;border:1.5px solid var(--line);border-radius:12px;background:var(--cream-soft);
  font-family:inherit;font-size:1rem;color:var(--ink);transition:border-color .25s,box-shadow .25s;
}
.field textarea{resize:vertical;min-height:130px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--forest);
  box-shadow:0 0 0 4px rgba(0,0,0,.10)}
.form-card .btn-primary{width:100%;justify-content:center;margin-top:6px}
.form-note{font-size:.82rem;color:var(--muted);margin-top:14px;text-align:center}
.form-success{display:none;text-align:center;padding:20px;background:rgba(21,128,61,.09);border-radius:14px;
  color:var(--forest);font-weight:600;margin-top:16px}
.form-success.show{display:block}

.faq{margin-top:30px}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;text-align:left;display:flex;justify-content:space-between;align-items:center;gap:16px;
  padding:22px 0;font-family:var(--serif);font-size:1.15rem;color:var(--ink)}
.faq-q .pm{flex:0 0 auto;width:28px;height:28px;border-radius:50%;border:1.5px solid var(--forest);color:var(--forest);
  display:grid;place-items:center;font-size:1.2rem;transition:transform .35s var(--ease),background .3s,color .3s}
.faq-item.open .faq-q .pm{background:var(--forest);color:#f7f4ec;transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .45s var(--ease);color:var(--muted)}
.faq-a div{padding-bottom:22px;font-size:.98rem}

/* ==========================================================================
   WHATSAPP FLOAT
   ========================================================================== */
.wa-float{position:fixed;bottom:24px;right:24px;z-index:90;width:60px;height:60px;border-radius:50%;
  background:#25D366;display:grid;place-items:center;box-shadow:0 14px 30px -8px rgba(0,0,0,.45);
  transition:transform .3s var(--ease);animation:wa-pop .6s var(--ease) .8s both}
.wa-float:hover{transform:scale(1.08) rotate(6deg)}
.wa-float svg{width:32px;height:32px;color:#fff}
@keyframes wa-pop{from{transform:scale(0)}to{transform:scale(1)}}

/* ==========================================================================
   COMPROMISOS (lista del panel), ANIMACIONES Y PRECIOS
   ========================================================================== */
/* Lista de compromisos dentro del panel oscuro */
.promise-list{margin-top:28px;display:grid;gap:14px}
.promise-list li{display:flex;align-items:flex-start;gap:12px;font-weight:500;font-size:1rem;line-height:1.4}
.promise-list li span{opacity:.92}
.promise-list svg{flex:0 0 auto;width:22px;height:22px;margin-top:1px;padding:3px;border-radius:50%;
  background:rgba(255,255,255,.12);color:#f7f4ec}

/* Flotación retirada para un aire más sobrio/corporativo */

/* Brillo de barrido en botones primarios */
.btn-primary{position:relative;overflow:hidden}
.btn-primary::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;
  background:linear-gradient(120deg,transparent,rgba(255,255,255,.35),transparent);
  transform:skewX(-18deg);transition:left .6s var(--ease)}
.btn-primary:hover::after{left:140%}

/* Hover de los pasos del proceso y de los feature-item */
.step .dot{transition:transform .4s var(--ease),background .4s,color .4s}
.step:hover .dot{transform:scale(1.12) rotate(-6deg)}
.feature-item{transition:transform .4s var(--ease)}
.feature-item:hover{transform:translateX(6px)}

/* ---------- PRECIOS ---------- */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:14px}
.price-card{position:relative;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:clamp(28px,3vw,40px);display:flex;flex-direction:column;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .4s}
.price-card:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:transparent}
.price-card.featured{background:var(--forest);color:#f7f4ec;border-color:transparent;transform:scale(1.03)}
.price-card.featured h3,.price-card.featured .price-amount{color:#f7f4ec}
.price-card.featured .price-desc{color:rgba(255,255,255,.75)}
.price-card.featured .price-feats li{color:#f7f4ec}
.price-card.featured:hover{transform:scale(1.03) translateY(-8px)}
.price-card.featured .price-desc,.price-card.featured .price-per{opacity:.8}
.price-tag-top{font-family:var(--sans);font-weight:700;font-size:.74rem;letter-spacing:.26em;text-transform:uppercase;
  color:var(--forest);margin-bottom:8px}
.price-card.featured .price-tag-top{color:#f7f4ec;opacity:.7}
.price-card h3{margin-bottom:6px}
.price-desc{color:var(--muted);font-size:.96rem;min-height:42px}
.price-amount{font-family:var(--serif);font-size:clamp(2.4rem,5vw,3.4rem);line-height:1;margin:18px 0 4px;display:flex;align-items:baseline;gap:6px}
.price-amount .cur{font-size:.5em}
.price-per{font-size:.85rem;color:var(--muted);margin-bottom:22px}
.price-feats{display:grid;gap:11px;margin-bottom:28px}
.price-feats li{display:flex;gap:10px;align-items:flex-start;font-size:.95rem}
.price-feats svg{flex:0 0 auto;width:19px;height:19px;margin-top:2px;color:var(--forest)}
.price-card.featured .price-feats svg{color:#f7f4ec}
.price-card .btn{margin-top:auto;justify-content:center;width:100%}
.price-note{text-align:center;color:var(--muted);font-size:.86rem;margin-top:26px;font-style:italic}
.price-badge{position:absolute;top:18px;right:20px;background:var(--accent);color:#3a2400;
  font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:5px 12px;border-radius:999px}


/* El contenido es visible por defecto. Solo se oculta para animar si el JS
   está activo y añade .is-hidden — así nada queda invisible si el JS falla. */
.reveal{transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.is-hidden{opacity:0;transform:translateY(30px)}
.reveal[data-delay="1"]{transition-delay:.08s}
.reveal[data-delay="2"]{transition-delay:.16s}
.reveal[data-delay="3"]{transition-delay:.24s}
.reveal[data-delay="4"]{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){
  .reveal,.reveal.is-hidden{opacity:1;transform:none;transition:none}
  .marquee-track{animation:none}
  .hero-art img,.hero-art::before,.hero-art::after,.hero-badge.b1,.hero-badge.b2{animation:none}
  *{scroll-behavior:auto!important}
}

/* ==========================================================================
   MOBILE
   ========================================================================== */
@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:50px}
  .hero-visual{max-width:460px;margin-inline:auto;width:100%}
  .split,.contact-grid,.svc-row,.svc-row.flip{grid-template-columns:1fr;gap:36px}
  .split.flip .split-media,.svc-row.flip .svc-visual{order:0}
  .footer-grid{grid-template-columns:1fr 1fr;gap:34px}
  .values-grid,.services-grid{grid-template-columns:1fr 1fr}
  .callout-home{grid-template-columns:auto 1fr;text-align:left}
  .callout-home .btn{grid-column:1/-1;justify-self:start;margin-top:6px}
  .steps{grid-template-columns:1fr 1fr;gap:36px 0}
  .step:not(:last-child)::after{display:none}
  .pricing-grid{grid-template-columns:1fr;gap:18px;max-width:520px;margin-inline:auto}
  .price-card.featured{transform:none}
  .price-card.featured:hover{transform:translateY(-8px)}
}
@media (max-width:720px){
  .nav-links{
    position:fixed;inset:0 0 0 auto;width:min(82vw,340px);flex-direction:column;align-items:stretch;
    background:var(--cream-soft);padding:100px 26px 40px;gap:6px;transform:translateX(100%);
    transition:transform .5s var(--ease);box-shadow:-20px 0 60px -20px rgba(0,0,0,.4);z-index:80;
  }
  .nav-links.open{transform:none}
  .nav-links>.btn{display:inline-flex} /* CTA visible dentro del panel móvil */
  .nav-links a{font-size:1.15rem;padding:14px 16px}
  .nav-links a::after{display:none}
  .burger{display:block;z-index:101}
  .nav-cta{display:none}
  .services-grid,.values-grid,.footer-grid,.steps{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .hero-meta{gap:20px}
  .nav-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);backdrop-filter:blur(3px);
    opacity:0;pointer-events:none;transition:opacity .4s;z-index:70}
  .nav-overlay.open{opacity:1;pointer-events:auto}
}
@media (min-width:721px){.nav-overlay{display:none}}

/* ==========================================================================
   EFECTOS VISUALES (canvas red, cursor glow, scroll bar, dark mode, theme btn)
   ========================================================================== */

/* Canvas de partículas dentro del hero, detrás del contenido */
.hero{position:relative;overflow:hidden}
.hero-net{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:0;opacity:.85}
.hero>.wrap,.hero>.section{position:relative;z-index:1}
.hero .wrap{position:relative;z-index:2}

/* Cursor glow: bola verde que sigue al cursor */
.cursor-glow{
  position:fixed;top:0;left:0;width:360px;height:360px;border-radius:50%;
  pointer-events:none;z-index:9998;
  background:radial-gradient(circle,rgba(31,154,77,.18) 0%,rgba(31,154,77,.06) 35%,transparent 65%);
  mix-blend-mode:multiply;will-change:transform;
}
html.dark .cursor-glow{mix-blend-mode:screen;background:radial-gradient(circle,rgba(74,222,128,.22) 0%,rgba(74,222,128,.06) 40%,transparent 65%)}

/* Barra de progreso del scroll */
.scroll-progress{
  position:fixed;top:0;left:0;height:3px;width:0;
  background:linear-gradient(90deg,var(--forest),var(--forest-glow));
  z-index:9999;box-shadow:0 0 12px rgba(31,154,77,.55);
  transition:width .12s linear;
}

/* Toggle de tema (sol/luna) */
.theme-toggle{
  width:38px;height:38px;border-radius:50%;background:var(--paper);border:1px solid var(--line);
  display:grid;place-items:center;cursor:pointer;transition:all .25s var(--ease);
  color:var(--ink-soft);position:relative;overflow:hidden;
}
.theme-toggle:hover{transform:rotate(15deg) scale(1.05);border-color:var(--forest);color:var(--forest)}
.theme-toggle svg{width:18px;height:18px;transition:transform .35s var(--ease)}
.theme-toggle .t-moon{display:none}
html.dark .theme-toggle .t-sun{display:none}
html.dark .theme-toggle .t-moon{display:block}

/* ===== MODO OSCURO ===== */
html.dark{
  --ink:#f1efe8;
  --ink-soft:#cfd3cd;
  --cream:#0d1612;
  --cream-soft:#121e18;
  --paper:#172420;
  --muted:#9da9a2;
  --line:rgba(241,239,232,.10);
  --line-strong:rgba(241,239,232,.22);
  --forest:#22c55e;
  --forest-deep:#0d3b20;
  --forest-bright:#4ade80;
  --forest-glow:#86efac;
  color-scheme:dark;
}
html.dark body{background:var(--cream)}
html.dark .site-header.scrolled{background:rgba(13,22,18,.88);backdrop-filter:saturate(160%) blur(14px);-webkit-backdrop-filter:saturate(160%) blur(14px);box-shadow:0 1px 0 var(--line),0 12px 30px -16px rgba(0,0,0,.6)}
html.dark .nav-links a{color:#dfe3dd}
html.dark .nav-links a:hover,html.dark .nav-links a.active{color:var(--forest-bright)}
html.dark .nav-links a.active::after,html.dark .nav-links a:hover::after{background:var(--forest-bright)}
html.dark .brand{color:var(--ink)}
html.dark .brand img{filter:brightness(0) invert(1);opacity:.95}
html.dark .lang-toggle{background:rgba(255,255,255,.06);border:1px solid var(--line-strong)}
html.dark .lang-toggle button{color:var(--ink-soft)}
html.dark .lang-toggle button.active{background:var(--forest);color:#0d1612}
html.dark .theme-toggle{background:rgba(255,255,255,.06);border-color:var(--line-strong);color:var(--ink-soft)}
html.dark .theme-toggle:hover{color:var(--forest-bright);border-color:var(--forest-bright)}
html.dark .hero-net{opacity:1}
html.dark #servicios{background:#0a1410}
html.dark #servicios .service-card{background:#1c2922;border-color:rgba(255,255,255,.08)}
html.dark #servicios .service-card h3{color:#f1efe8}
html.dark #servicios .service-card p{color:#a0aaa3}
html.dark #servicios .service-num{color:rgba(255,255,255,.18)}
html.dark #servicios .tags span{background:rgba(74,222,128,.15);color:#86efac}
html.dark .price-card{background:var(--paper)}
html.dark .price-card.featured{background:var(--forest-deep)}
html.dark .quote-band{background:var(--cream-soft)}
html.dark .quote-text em{color:var(--forest-bright)}
html.dark .stack-band{background:var(--cream)}
html.dark .pill{background:var(--paper);color:var(--ink);border-color:var(--line-strong)}
html.dark .pill:hover{border-color:var(--forest-bright);box-shadow:0 14px 28px -10px rgba(74,222,128,.45)}
html.dark .form-card{background:var(--paper)}
html.dark .form-card input,html.dark .form-card select,html.dark .form-card textarea{background:var(--cream-soft);color:var(--ink);border-color:var(--line-strong)}
html.dark .callout-home{background:linear-gradient(135deg,#15803d,#0d3b20);border:1px solid rgba(134,239,172,.3);box-shadow:0 24px 60px -20px rgba(74,222,128,.25),0 0 0 1px rgba(74,222,128,.2)}
html.dark .cta-band{background:linear-gradient(135deg,#15803d,#0d4d24);border:1px solid rgba(134,239,172,.3);box-shadow:0 30px 80px -20px rgba(74,222,128,.3)}
html.dark .service-card{background:var(--paper);border-color:var(--line-strong)}
html.dark .service-card h3{color:var(--ink)}
html.dark .service-card:hover{background:var(--forest-deep)}
html.dark .hero-art img,html.dark .about-photo img{filter:brightness(0) invert(1) drop-shadow(0 18px 30px rgba(74,222,128,.18))}
html.dark .footer-band{background:#080f0b}

@media (prefers-reduced-motion:reduce){
  .scroll-progress{transition:none}
  .cursor-glow{display:none}
}

/* ==========================================================================
   LEGAL: aviso legal, privacidad, cookies + banner
   ========================================================================== */

/* TOC de la página legal */
.legal-toc{display:flex;flex-wrap:wrap;gap:10px;padding:18px 22px;background:var(--paper);border:1px solid var(--line);border-radius:14px}
.legal-toc a{padding:8px 14px;border-radius:999px;background:var(--cream-soft);color:var(--ink);font-weight:600;font-size:.88rem;transition:all .25s var(--ease)}
.legal-toc a:hover{background:var(--forest);color:#f7f4ec}

/* Secciones legales */
.legal-section{padding-block:clamp(40px,5vw,72px);scroll-margin-top:90px}
.legal-section-alt{background:var(--cream-soft)}
.legal-content{max-width:840px}
.legal-content h2{font-size:clamp(1.8rem,4vw,2.6rem);margin-bottom:14px;letter-spacing:-.03em}
.legal-content h3{font-size:1.15rem;font-weight:700;margin:28px 0 10px;color:var(--forest)}
.legal-content p{margin-bottom:14px;color:var(--ink-soft);line-height:1.65;font-size:.98rem}
.legal-content .legal-intro{font-size:1.05rem;color:var(--ink);font-weight:500;padding:14px 18px;border-left:3px solid var(--forest);background:var(--paper);border-radius:0 10px 10px 0;margin:8px 0 22px}
.legal-list{list-style:none;padding:0;margin:0 0 14px}
.legal-list li{position:relative;padding-left:22px;margin-bottom:8px;color:var(--ink-soft);line-height:1.6;font-size:.98rem}
.legal-list li::before{content:"›";position:absolute;left:6px;color:var(--forest);font-weight:700}
.legal-list li code{font-family:var(--mono);background:var(--cream-soft);padding:2px 6px;border-radius:4px;font-size:.85em;color:var(--forest)}
.legal-content a{color:var(--forest);text-decoration:underline;text-underline-offset:3px}
.legal-content a:hover{color:var(--forest-deep)}
.legal-note{margin-top:24px;padding:12px 16px;background:var(--cream-soft);border-radius:10px;font-size:.9rem!important;color:var(--muted)!important}

/* Dark mode legal */
html.dark .legal-toc{background:var(--paper);border-color:var(--line-strong)}
html.dark .legal-toc a{background:rgba(255,255,255,.05);color:var(--ink)}
html.dark .legal-toc a:hover{background:var(--forest);color:#0d1612}
html.dark .legal-section-alt{background:var(--cream-soft)}
html.dark .legal-content .legal-intro{background:var(--paper);border-left-color:var(--forest-bright)}
html.dark .legal-content h3{color:var(--forest-bright)}
html.dark .legal-content a{color:var(--forest-bright)}
html.dark .legal-list li code{background:rgba(255,255,255,.06);color:var(--forest-bright)}
html.dark .legal-note{background:rgba(255,255,255,.04);color:var(--muted)!important}

/* Footer: enlaces legales */
.footer-bottom,.footer-bot{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding-top:24px;border-top:1px solid rgba(255,255,255,.10)}
.footer-legal{display:flex;flex-wrap:wrap;gap:10px}
.footer-legal a{color:rgba(255,255,255,.65);font-size:.84rem;transition:color .25s}
.footer-legal a:hover{color:#f7f4ec}
.footer-legal a + a::before{content:"·";color:rgba(255,255,255,.30);margin-right:10px;margin-left:0}

/* Checkbox GDPR del formulario */
.gdpr-check{display:flex;gap:10px;align-items:flex-start;padding:12px 0 6px;font-size:.86rem;line-height:1.5;color:var(--muted);cursor:pointer}
.gdpr-check input[type="checkbox"]{flex:0 0 auto;width:18px;height:18px;margin-top:1px;accent-color:var(--forest);cursor:pointer}
.gdpr-check a{color:var(--forest);text-decoration:underline;text-underline-offset:3px}
.gdpr-check a:hover{color:var(--forest-deep)}
html.dark .gdpr-check{color:var(--muted)}
html.dark .gdpr-check a{color:var(--forest-bright)}

/* Banner de cookies */
.cookie-banner{
  position:fixed;bottom:20px;left:20px;right:20px;max-width:560px;margin:0 auto;
  background:var(--paper);border:1px solid var(--line);border-radius:18px;
  padding:18px 20px;display:flex;align-items:center;gap:18px;
  box-shadow:0 24px 60px -16px rgba(0,0,0,.25),0 0 0 1px rgba(21,128,61,.08);
  z-index:9990;opacity:0;transform:translateY(20px);transition:all .4s var(--ease);
}
.cookie-banner.show{opacity:1;transform:translateY(0)}
.cookie-text{flex:1;min-width:0}
.cookie-text strong{display:block;font-size:.92rem;margin-bottom:4px;color:var(--ink)}
.cookie-text p{margin:0;font-size:.83rem;color:var(--muted);line-height:1.5}
.cookie-text a{color:var(--forest);text-decoration:underline;text-underline-offset:2px}
.cookie-banner .cookie-ok{flex:0 0 auto;padding:10px 18px;font-size:.85rem}
html.dark .cookie-banner{background:var(--paper);border-color:var(--line-strong);box-shadow:0 24px 60px -16px rgba(0,0,0,.6),0 0 0 1px rgba(74,222,128,.18)}
html.dark .cookie-text a{color:var(--forest-bright)}

@media (max-width:640px){
  .cookie-banner{flex-direction:column;align-items:stretch;text-align:left;left:12px;right:12px;bottom:12px;padding:16px}
  .cookie-banner .cookie-ok{width:100%;justify-content:center}
  .footer-bottom,.footer-bot{flex-direction:column;align-items:flex-start;gap:14px}
}

/* Callout Aurrekont (variante con eyebrow) */
.callout-eyebrow{display:inline-block;font-size:.74rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.85);margin-bottom:6px;padding:3px 10px;border-radius:999px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.18)}
.callout-aurrekont .callout-text h3{font-size:clamp(1.5rem,2.4vw,2rem);color:#f7f4ec;margin-bottom:6px;font-weight:800;letter-spacing:-.02em}

/* Footer "otro proyecto" */
.footer-cr{display:flex;flex-direction:column;gap:4px}
.footer-sister{font-size:.82rem;color:rgba(255,255,255,.55)}
.footer-sister a{color:var(--forest-bright);font-weight:600;text-decoration:underline;text-underline-offset:3px;transition:color .25s}
.footer-sister a:hover{color:#f7f4ec}
@media (max-width:640px){.footer-cr{gap:2px}}
