/* ============================================================
   VECTA — Web corporativa · Dirección 02 "Lima"
   ink #161814 + bone #F3F1EA + verde 624C #688D7E + lima #C7F032
   Tokens en css/tokens.css
   ============================================================ */

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bone);color:var(--fg);font-family:var(--font-body);
  font-size:var(--t-body);line-height:var(--lh-body);-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{margin:0}
p{margin:0}
ul{margin:0;padding:0;list-style:none}
::selection{background:var(--acid-500);color:var(--accent-ink)}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px}
.measure{max-width:64ch}

/* ---- eyebrow (numbered, architectural) ---- */
.eyebrow{font-family:var(--font-body);font-weight:700;font-size:var(--t-eyebrow);
  letter-spacing:var(--tracking-eyebrow);text-transform:uppercase;color:var(--sage-700);
  display:inline-flex;align-items:center;gap:12px}
.eyebrow .ix{font-variant-numeric:tabular-nums;color:var(--ink-800)}
.eyebrow::before{content:"";width:28px;height:1.5px;background:var(--sage-500);display:inline-block}
.eyebrow.on-ink{color:var(--acid-500)}
.eyebrow.on-ink .ix{color:var(--fg-invert)}
.eyebrow.on-ink::before{background:var(--acid-500)}

/* ---- buttons ---- */
.btn{font-family:var(--font-body);font-weight:700;font-size:15px;border:1.5px solid transparent;
  border-radius:var(--r-sm);padding:15px 26px;cursor:pointer;display:inline-flex;align-items:center;
  gap:9px;line-height:1;transition:transform var(--dur) var(--ease),background var(--dur) var(--ease),
  color var(--dur) var(--ease),border-color var(--dur) var(--ease)}
.btn:active{transform:scale(.975)}
.btn-primary{background:var(--sage-500);color:#fff}
.btn-primary:hover{background:var(--sage-600)}
.btn-acid{background:var(--acid-500);color:var(--accent-ink)}
.btn-acid:hover{background:var(--acid-600)}
.btn-ink{background:var(--ink-800);color:var(--fg-invert)}
.btn-ink:hover{background:var(--ink-700)}
.btn-ghost{background:transparent;color:var(--fg);border-color:var(--line-strong)}
.btn-ghost:hover{border-color:var(--ink-800)}
.btn-ghost.on-ink{color:var(--fg-invert);border-color:rgba(255,255,255,.28)}
.btn-ghost.on-ink:hover{border-color:rgba(255,255,255,.65)}

/* ============================================================
   HEADER
   ============================================================ */
.hdr{position:fixed;top:0;left:0;right:0;z-index:60;transition:background var(--dur) var(--ease),
  box-shadow var(--dur) var(--ease)}
.hdr-inner{display:flex;align-items:center;justify-content:space-between;height:100px;gap:40px}
.hdr.scrolled{background:rgba(22,24,20,.86);backdrop-filter:blur(14px);
  box-shadow:0 1px 0 rgba(255,255,255,.08)}
.hdr .logo{height:54px;width:auto;flex:none}
.nav{display:flex;align-items:center;gap:36px}
.nav a{font-size:14.5px;font-weight:600;color:var(--fg-invert);opacity:.82;
  transition:opacity var(--dur),color var(--dur);position:relative}
.nav a:hover,.nav a.active{opacity:1;color:var(--acid-500)}
.nav a.active::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:1.5px;
  background:var(--acid-500)}
.hdr-cta{display:flex;align-items:center;gap:20px}
.lang{display:flex;align-items:center;gap:5px;font-size:13px;font-weight:700}
.lang button{background:none;border:0;color:var(--fg-invert);opacity:.5;cursor:pointer;
  font-weight:700;font-size:13px;padding:2px;font-family:var(--font-body);transition:.2s}
.lang button.active{opacity:1;color:var(--acid-500)}
.lang .sep{color:var(--fg-invert);opacity:.3}
.burger{display:none;background:none;border:0;cursor:pointer;flex-direction:column;gap:5px;
  padding:8px;z-index:70}
.burger span{width:26px;height:2px;background:var(--fg-invert);display:block;transition:.3s var(--ease)}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:55;background:var(--ink-900);
  display:flex;flex-direction:column;justify-content:center;padding:0 40px;gap:8px;
  transform:translateY(-100%);transition:transform .4s var(--ease);visibility:hidden}
.drawer.open{transform:translateY(0);visibility:visible}
.drawer a{font-family:var(--font-display);font-weight:600;font-size:2rem;color:var(--fg-invert);
  padding:14px 0;border-bottom:1px solid rgba(255,255,255,.1)}
.drawer a:hover{color:var(--acid-500)}
.drawer .drawer-cta{margin-top:32px}

/* ============================================================
   PAGE HERO (ink band — opens every page for parallelism)
   ============================================================ */
.phero{background:var(--ink-800);color:var(--fg-invert);padding:184px 0 96px;position:relative;
  overflow:hidden}
.phero .inner{position:relative;z-index:1;max-width:880px}
.phero h1{font-family:var(--font-display);font-weight:700;font-size:var(--t-h1);
  line-height:var(--lh-tight);letter-spacing:var(--tracking-display);color:#fff;margin:24px 0 0}
.phero .lead{font-size:var(--t-lead);color:var(--fg-invert-2);margin:26px 0 0;max-width:56ch}

/* ============================================================
   HOME HERO
   ============================================================ */
.hero{background:var(--ink-800);color:var(--fg-invert);padding:172px 0 104px;position:relative;
  overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.12fr .88fr;gap:72px;align-items:center;
  position:relative;z-index:1}
.hero h1{font-family:var(--font-display);font-weight:700;font-size:var(--t-display);
  line-height:var(--lh-tight);letter-spacing:var(--tracking-display);color:#fff;margin:28px 0 0}
.hero h1 .accent{color:var(--sage-400)}
.hero .lead{font-size:var(--t-lead);color:var(--fg-invert-2);margin:28px 0 38px;max-width:52ch}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}
.hero-stats{display:flex;gap:48px;margin-top:60px;flex-wrap:wrap}
.stat .n{font-family:var(--font-display);font-weight:700;font-size:1.7rem;color:#fff;
  letter-spacing:-.02em;line-height:1}
.stat .l{font-size:13px;color:var(--fg-invert-2);margin-top:8px;letter-spacing:.02em}
.hero-portrait{position:relative}
.hero-portrait image-slot,.hero-portrait img{width:100%;aspect-ratio:4/5;border-radius:var(--r-lg);overflow:hidden;
  display:block;border:1px solid rgba(255,255,255,.12);object-fit:cover}
.hero-portrait .cap{position:absolute;left:0;right:0;bottom:0;padding:22px 24px;font-size:14px;
  color:#fff;background:linear-gradient(transparent,rgba(0,0,0,.62));z-index:2;pointer-events:none;
  border-radius:0 0 var(--r-lg) var(--r-lg)}
.hero-portrait .cap b{font-weight:700;display:block;font-family:var(--font-display);font-size:16px}
.hero-portrait .badge{position:absolute;top:-16px;left:-16px;background:var(--acid-500);
  color:var(--accent-ink);font-weight:700;font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  padding:10px 16px;border-radius:var(--r-pill);z-index:3;white-space:nowrap}

/* ============================================================
   SECTIONS
   ============================================================ */
.sec{padding:128px 0}
.sec.tight{padding:96px 0}
.sec.ink{background:var(--ink-800);color:var(--fg-invert);position:relative;overflow:hidden}
.sec.ink h2{color:#fff}
.sec.ink .wrap{position:relative;z-index:1}
.sec.alt{background:var(--bg-alt)}

/* ---- atmospheric ink backgrounds: line grid + green glow ----
   (recovered from the previous VECTA site) */
.hero::before,.phero::before,.sec.ink::before{content:"";position:absolute;inset:0;
  pointer-events:none;z-index:0;
  background-image:linear-gradient(rgba(143,176,163,.16) 1px,transparent 1px),
    linear-gradient(90deg,rgba(143,176,163,.16) 1px,transparent 1px);
  background-size:78px 78px;
  -webkit-mask-image:radial-gradient(ellipse 90% 80% at 70% 30%,#000 18%,transparent 82%);
  mask-image:radial-gradient(ellipse 90% 80% at 70% 30%,#000 18%,transparent 82%)}
.hero::after,.phero::after,.sec.ink::after{content:"";position:absolute;inset:0;
  pointer-events:none;z-index:0;
  background:radial-gradient(700px 700px at 86% 6%,rgba(104,141,126,.30),transparent 62%),
    radial-gradient(620px 620px at -6% 104%,rgba(104,141,126,.18),transparent 60%)}
.sec-head{max-width:780px;margin-bottom:72px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{font-family:var(--font-display);font-weight:700;font-size:var(--t-h1);
  line-height:var(--lh-tight);letter-spacing:var(--tracking-display);color:inherit;margin:20px 0 0}
.sec-head p{font-size:var(--t-lead);color:var(--fg-2);margin:24px 0 0;max-width:64ch}
.sec.ink .sec-head p{color:var(--fg-invert-2)}
.sec-head.center p{margin-left:auto;margin-right:auto}

/* generic card */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:34px;
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease),border-color var(--dur)}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--line-strong)}
.card h3{font-family:var(--font-display);font-size:var(--t-h3);font-weight:600;margin:0 0 12px;
  color:var(--fg)}
.card p{font-size:var(--t-body);color:var(--fg-2)}

/* ---- challenges grid ---- */
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.chal{position:relative}
.chal .num{font-family:var(--font-display);font-weight:700;font-size:1.1rem;color:var(--sage-500);
  letter-spacing:-.02em;margin-bottom:18px;display:block}
.chal h3{font-size:var(--t-h4);margin-bottom:10px}
.chal p{font-size:var(--t-small);line-height:var(--lh-body)}

/* audience strip */
.aud{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);
  border-radius:var(--r-md);overflow:hidden;background:var(--surface)}
.aud > div{padding:40px}
.aud > div + div{border-left:1px solid var(--line)}
.aud .who{font-family:var(--font-display);font-weight:600;font-size:var(--t-h4);color:var(--fg);
  margin-bottom:14px}
.aud p{font-size:var(--t-small);color:var(--fg-2)}

/* ---- services columns ---- */
.svc{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.svc-col{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:48px;display:flex;flex-direction:column}
.svc-col.feature{background:var(--ink-800);color:var(--fg-invert);border-color:var(--ink-700)}
.svc-col .tag{font-size:var(--t-eyebrow);font-weight:700;letter-spacing:var(--tracking-eyebrow);
  text-transform:uppercase;color:var(--sage-700)}
.svc-col.feature .tag{color:var(--acid-500)}
.svc-col h3{font-family:var(--font-display);font-weight:700;font-size:var(--t-h2);margin:16px 0 16px;
  color:var(--fg)}
.svc-col.feature h3{color:#fff}
.svc-col > p{font-size:var(--t-body);color:var(--fg-2);margin-bottom:30px}
.svc-col.feature > p{color:var(--fg-invert-2)}
.svc-list{display:flex;flex-direction:column;gap:0;margin-top:auto}
.svc-item{padding:22px 0;border-top:1px solid var(--line)}
.svc-col.feature .svc-item{border-top-color:rgba(255,255,255,.12)}
.svc-item .it-h{display:flex;align-items:center;gap:12px;font-family:var(--font-display);
  font-weight:600;font-size:var(--t-h4);color:var(--fg);margin-bottom:8px}
.svc-col.feature .svc-item .it-h{color:#fff}
.svc-item .it-h .ico{width:22px;height:22px;color:var(--sage-500);flex:none;
  display:inline-flex;align-items:center;justify-content:center}
.svc-item .it-h .ico svg{width:100%;height:100%;display:block}
.svc-col.feature .svc-item .it-h .ico{color:var(--acid-500)}
.svc-item p{font-size:var(--t-small);color:var(--fg-2)}
.svc-col.feature .svc-item p{color:var(--fg-invert-2)}

/* tag chips */
.chips{display:flex;flex-wrap:wrap;gap:12px;margin-top:48px}
.chip{font-size:var(--t-small);font-weight:600;color:var(--fg);background:var(--bone);
  border:1px solid var(--line-strong);border-radius:var(--r-pill);padding:9px 18px}
.sec.ink .chip{color:var(--fg-invert);background:transparent;border-color:rgba(255,255,255,.2)}

/* ---- gallery ---- */
.gal{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:240px;gap:18px}
.gal image-slot,.gal img{width:100%;height:100%;border-radius:var(--r-md);overflow:hidden;display:block;
  object-fit:cover}
.gal .g-tall{grid-row:span 2}
.gal .g-item{position:relative;border-radius:var(--r-md);overflow:hidden}
.gal .g-item .cap{position:absolute;left:0;right:0;bottom:0;padding:18px 18px;font-size:13px;
  font-weight:600;color:#fff;background:linear-gradient(transparent,rgba(0,0,0,.6));z-index:2;
  pointer-events:none}

/* ---- method steps ---- */
.steps{display:flex;flex-direction:column}
.step{display:grid;grid-template-columns:120px 1fr;gap:40px;padding:44px 0;
  border-top:1px solid var(--line);align-items:start}
.step:last-child{border-bottom:1px solid var(--line)}
.step .s-num{font-family:var(--font-display);font-weight:800;font-size:3.2rem;line-height:1;
  color:var(--sage-300);letter-spacing:-.04em}
.step .s-body h3{font-family:var(--font-display);font-weight:600;font-size:var(--t-h3);
  margin-bottom:12px;color:var(--fg)}
.step .s-body p{font-size:var(--t-body);color:var(--fg-2);max-width:62ch}
.sec.ink .step{border-color:rgba(255,255,255,.12)}
.sec.ink .step .s-num{color:var(--sage-500)}
.sec.ink .step .s-body h3{color:#fff}
.sec.ink .step .s-body p{color:var(--fg-invert-2)}

/* outcomes list */
.outcomes{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.outcome{display:flex;gap:16px;align-items:flex-start;padding:24px 0;
  border-top:1px solid var(--line)}
.outcome .ico{width:24px;height:24px;color:var(--sage-500);flex:none;margin-top:2px;
  display:inline-flex}
.outcome .ico svg{width:100%;height:100%;display:block}
.outcome span{font-family:var(--font-display);font-weight:500;font-size:var(--t-h4);color:var(--fg)}
.sec.ink .outcome span{color:#fff}
.sec.ink .outcome{border-color:rgba(255,255,255,.12)}

/* ---- about ---- */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.about-portrait{position:relative}
.about-portrait image-slot,.about-portrait img{width:100%;aspect-ratio:4/5;border-radius:var(--r-lg);overflow:hidden;
  display:block;object-fit:cover}
.about-portrait .cap{position:absolute;left:0;right:0;bottom:0;padding:22px 24px;color:#fff;
  background:linear-gradient(transparent,rgba(0,0,0,.6));z-index:2;pointer-events:none;
  border-radius:0 0 var(--r-lg) var(--r-lg)}
.about-portrait .cap b{font-weight:700;font-family:var(--font-display);font-size:16px;display:block}
.about-portrait .cap span{font-size:13px;opacity:.85}
.about-text h2{margin-bottom:24px}
.about-text p{font-size:var(--t-body);color:var(--fg-2);margin-bottom:18px}
.quote{border-left:2px solid var(--acid-500);padding:6px 0 6px 28px;margin:40px 0}
.quote p{font-family:var(--font-display);font-weight:600;font-size:var(--t-h3);color:var(--fg);
  line-height:var(--lh-snug);font-style:italic;margin-bottom:14px}
.quote cite{font-style:normal;font-size:var(--t-small);font-weight:700;color:var(--sage-700);
  letter-spacing:.04em}
.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-top:1px solid var(--line);
  margin-top:48px}
.info-grid > div{padding:24px 0;border-bottom:1px solid var(--line)}
.info-grid > div:nth-child(odd){padding-right:24px}
.info-grid > div:nth-child(even){padding-left:24px;border-left:1px solid var(--line)}
.info-grid .k{font-size:var(--t-eyebrow);font-weight:700;letter-spacing:var(--tracking-eyebrow);
  text-transform:uppercase;color:var(--fg-muted);margin-bottom:8px}
.info-grid .v{font-family:var(--font-display);font-weight:600;font-size:var(--t-h4);color:var(--fg)}

/* ---- CTA band ---- */
.cta-band{background:var(--sage-500);color:#fff;border-radius:var(--r-lg);padding:48px 72px;
  display:grid;grid-template-columns:1.4fr auto;gap:48px;align-items:center}
.cta-band h2{font-family:var(--font-display);font-weight:700;font-size:var(--t-h2);color:#fff;
  line-height:var(--lh-snug);letter-spacing:var(--tracking-tight);max-width:20ch}
.cta-band p{color:rgba(255,255,255,.85);font-size:var(--t-body);margin-top:16px;max-width:48ch}
.cta-band .btn-acid{align-self:center}

/* ---- contact ---- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.contact-single{max-width:680px}
.contact-left h2{margin-bottom:24px}
.contact-left .lead{font-size:var(--t-lead);color:var(--fg-2);margin-bottom:40px}
.contact-detail{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line)}
.contact-detail a,.contact-detail div{display:flex;align-items:center;gap:16px;padding:22px 0;
  border-bottom:1px solid var(--line);font-size:var(--t-h4);font-weight:500;color:var(--fg);
  font-family:var(--font-display);transition:color var(--dur)}
.contact-detail a:hover{color:var(--sage-600)}
.contact-detail .ico{width:22px;height:22px;color:var(--sage-500);flex:none;
  display:inline-flex}
.contact-detail .ico svg{width:100%;height:100%;display:block}
.form{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:44px}
.field{margin-bottom:22px}
.field label{display:block;font-size:var(--t-eyebrow);font-weight:700;
  letter-spacing:var(--tracking-eyebrow);text-transform:uppercase;color:var(--fg-muted);
  margin-bottom:10px}
.field input,.field textarea{width:100%;font-family:var(--font-body);font-size:var(--t-body);
  color:var(--fg);background:var(--bone);border:1px solid var(--line);border-radius:var(--r-sm);
  padding:14px 16px;transition:border-color var(--dur)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--sage-500)}
.field textarea{min-height:130px;resize:vertical}

/* ============================================================
   LEGAL / PROSE PAGES
   ============================================================ */
[data-lang-block="en"]{display:none}
.legal{max-width:800px}
.legal .updated{font-size:var(--t-small);color:var(--fg-muted);margin-bottom:8px}
.legal h2{font-family:var(--font-display);font-weight:600;font-size:var(--t-h3);color:var(--fg);
  margin:52px 0 16px;letter-spacing:var(--tracking-tight)}
.legal h2:first-of-type{margin-top:0}
.legal h3{font-family:var(--font-display);font-weight:600;font-size:var(--t-h4);color:var(--fg);
  margin:28px 0 10px}
.legal p{color:var(--fg-2);font-size:var(--t-body);margin-bottom:16px}
.legal a{color:var(--sage-600);text-decoration:underline;text-underline-offset:2px}
.legal a:hover{color:var(--sage-700)}
.legal ul{list-style:disc;padding-left:22px;margin:0 0 16px;color:var(--fg-2)}
.legal li{margin-bottom:8px;font-size:var(--t-body)}
.legal .data{border-top:1px solid var(--line);margin:8px 0 0}
.legal .data .row{display:grid;grid-template-columns:220px 1fr;gap:24px;padding:16px 0;
  border-bottom:1px solid var(--line)}
.legal .data .k{font-size:var(--t-eyebrow);font-weight:700;letter-spacing:var(--tracking-eyebrow);
  text-transform:uppercase;color:var(--fg-muted)}
.legal .data .v{color:var(--fg);font-size:var(--t-body)}
.legal .ph{color:var(--sage-700);font-weight:600}
@media (max-width:560px){
  .legal .data .row{grid-template-columns:1fr;gap:4px}
}

/* ============================================================
   COOKIE CONSENT
   ============================================================ */
.ck-banner{position:fixed;left:50%;bottom:20px;transform:translateX(-50%) translateY(140%);
  width:calc(100% - 40px);max-width:840px;z-index:300;
  background:var(--ink-900);color:var(--fg-invert);border:1px solid rgba(255,255,255,.12);
  border-radius:var(--r-md);box-shadow:var(--shadow-lg);padding:13px 24px;
  display:flex;align-items:center;gap:22px;
  transition:transform .5s var(--ease),opacity .4s var(--ease);opacity:0}
.ck-banner.show{transform:translateX(-50%) translateY(0);opacity:1}
.ck-banner .ck-txt{flex:1;min-width:0}
.ck-banner h4{font-family:var(--font-display);font-weight:600;font-size:15px;color:#fff;
  margin-bottom:4px}
.ck-banner p{font-size:12.5px;color:var(--fg-invert-2);line-height:1.5}
.ck-banner p a{color:var(--acid-500);text-decoration:underline;text-underline-offset:2px}
.ck-actions{display:flex;gap:9px;flex-wrap:wrap;flex:none}
.ck-actions .btn{padding:10px 16px;font-size:13px}

/* preferences modal */
.ck-modal{position:fixed;inset:0;z-index:400;display:flex;align-items:center;justify-content:center;
  padding:24px;opacity:0;visibility:hidden;transition:opacity .3s var(--ease),visibility .3s}
.ck-modal.show{opacity:1;visibility:visible}
.ck-modal .ck-backdrop{position:absolute;inset:0;background:rgba(11,13,12,.6);backdrop-filter:blur(4px)}
.ck-panel{position:relative;z-index:1;background:var(--surface);color:var(--fg);
  border-radius:var(--r-lg);box-shadow:var(--shadow-lg);width:100%;max-width:580px;
  max-height:88vh;overflow:auto;padding:40px;transform:translateY(16px);
  transition:transform .35s var(--ease)}
.ck-modal.show .ck-panel{transform:none}
.ck-panel h3{font-family:var(--font-display);font-weight:700;font-size:var(--t-h3);margin-bottom:12px}
.ck-panel .ck-intro{font-size:var(--t-small);color:var(--fg-2);margin-bottom:28px}
.ck-cat{border-top:1px solid var(--line);padding:22px 0;display:flex;gap:20px;align-items:flex-start;
  justify-content:space-between}
.ck-cat:last-of-type{border-bottom:1px solid var(--line);margin-bottom:28px}
.ck-cat .ck-cat-txt h5{font-family:var(--font-display);font-weight:600;font-size:var(--t-h4);
  margin-bottom:6px}
.ck-cat .ck-cat-txt p{font-size:var(--t-small);color:var(--fg-2)}
.ck-cat .ck-always{font-size:var(--t-eyebrow);font-weight:700;letter-spacing:var(--tracking-eyebrow);
  text-transform:uppercase;color:var(--sage-600);flex:none;padding-top:4px;white-space:nowrap}
.ck-panel .ck-modal-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:flex-end}
/* switch */
.ck-switch{flex:none;width:46px;height:26px;border-radius:var(--r-pill);background:var(--stone-400);
  border:0;cursor:pointer;position:relative;transition:background .25s var(--ease);padding:0}
.ck-switch::after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;
  background:#fff;transition:transform .25s var(--ease)}
.ck-switch[aria-checked="true"]{background:var(--sage-500)}
.ck-switch[aria-checked="true"]::after{transform:translateX(20px)}
.ck-switch[disabled]{opacity:.55;cursor:not-allowed}
@media (max-width:720px){
  .ck-banner{flex-direction:column;align-items:stretch;gap:18px;padding:24px}
  .ck-actions{justify-content:stretch}
  .ck-actions .btn{flex:1;justify-content:center}
  .ck-panel{padding:30px}
}

/* footer cookie/legal group */
.foot-legal-group{display:flex;gap:24px;flex-wrap:wrap;align-items:center}
.foot-bottom button.foot-legal{background:none;border:0;cursor:pointer;font-family:inherit;padding:0;
  font-size:var(--t-small);color:var(--fg-invert-2);transition:color var(--dur)}
.foot-bottom button.foot-legal:hover{color:var(--acid-500)}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--ink-900);color:var(--fg-invert);padding:96px 0 40px}
.foot-top{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:48px;
  padding-bottom:56px;border-bottom:1px solid rgba(255,255,255,.1)}
.foot-brand .logo{height:34px;margin-bottom:24px}
.foot-brand p{color:var(--fg-invert-2);font-size:var(--t-small);max-width:42ch}
.foot-col h4{font-size:var(--t-eyebrow);font-weight:700;letter-spacing:var(--tracking-eyebrow);
  text-transform:uppercase;color:var(--fg-invert);margin-bottom:22px}
.foot-col a,.foot-col p{display:block;color:var(--fg-invert-2);font-size:var(--t-small);
  padding:7px 0;transition:color var(--dur)}
.foot-col a:hover{color:var(--acid-500)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:32px;
  gap:20px;flex-wrap:wrap}
.foot-bottom p{font-size:var(--t-small);color:var(--fg-muted)}
.foot-bottom .foot-legal{font-size:var(--t-small);color:var(--fg-invert-2);transition:color var(--dur)}
.foot-bottom .foot-legal:hover{color:var(--acid-500)}
.foot-bottom .tagline{font-weight:700;letter-spacing:.14em;text-transform:uppercase;font-size:12px;
  color:var(--acid-500)}

/* ============================================================
   SCROLL REVEAL — only active when html.anim is present
   (set by an inline head script when the tab is visible and
    motion is allowed). Default = content visible, so captures,
    PDF export and background tabs always show content.
   ============================================================ */
html.anim [data-reveal]{opacity:0;transform:translateY(18px);
  transition:opacity .7s var(--ease),transform .7s var(--ease)}
html.anim [data-reveal].in{opacity:1;transform:none}
html.anim [data-reveal][data-delay="1"]{transition-delay:.08s}
html.anim [data-reveal][data-delay="2"]{transition-delay:.16s}
html.anim [data-reveal][data-delay="3"]{transition-delay:.24s}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .hero-grid{grid-template-columns:1fr;gap:48px}
  .hero-portrait{max-width:420px}
  .about-grid{grid-template-columns:1fr;gap:48px}
  .about-portrait{max-width:440px}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .gal{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:860px){
  .nav,.lang .full{display:none}
  .hdr-btn{display:none}
  .burger{display:flex}
  .svc,.grid-2,.contact-grid,.outcomes{grid-template-columns:1fr}
  .aud,.grid-3,.info-grid{grid-template-columns:1fr}
  .aud > div + div{border-left:0;border-top:1px solid var(--line)}
  .info-grid > div:nth-child(even){padding-left:0;border-left:0}
  .info-grid > div:nth-child(odd){padding-right:0}
  .foot-top{grid-template-columns:1fr;gap:36px}
  .cta-band{grid-template-columns:1fr;padding:56px 40px;gap:32px}
  .step{grid-template-columns:1fr;gap:14px}
  .step .s-num{font-size:2.4rem}
}
@media (max-width:560px){
  .wrap{padding:0 24px}
  .sec{padding:88px 0}
  .grid-4{grid-template-columns:1fr}
  .gal{grid-template-columns:1fr;grid-auto-rows:220px}
  .gal .g-tall{grid-row:span 1}
  .svc-col{padding:32px}
  .form{padding:32px}
}
