/* ============================================================
   AUTHCODE // PIPELINE  —  scrollable slides + industrial pipe
   ============================================================ */
:root{
  --accent:#FFD400;
  --accent-2:#FFB300;
  --font-display:"Chakra Petch", system-ui, sans-serif;
  --font-body:"Space Grotesk", system-ui, sans-serif;
  --font-mono:"Space Mono", ui-monospace, monospace;

  --bg-0:#0b0b10;
  --bg-1:#0e0e14;
  --ink:#F4F1E6;
  --ink-dim:#9d9a8c;
  --ink-faint:#5c5a52;
  --grid:rgba(255,255,255,.035);
  --panel:rgba(255,255,255,.035);
  --panel-line:rgba(255,255,255,.10);
  --pipe-line:#56565f;
  --pipe-line-2:#34343d;
  --pipe-hi:#9c9caa;
  --pipe-fluid:#ffdf20;

  --rail:560px;
  --rail-gap:56px;
  --pad:120px;
}
.theme-light{
  --bg-0:#ece5d2; --bg-1:#f3eedd; --ink:#1a1712; --ink-dim:#6b6450; --ink-faint:#a59c80;
  --grid:rgba(40,34,18,.05); --panel:rgba(26,23,18,.04); --panel-line:rgba(26,23,18,.14);
  --pipe-line:#b9b09a; --pipe-line-2:#cfc7b2; --pipe-hi:#e4dcc6;
}

*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
html{
  scroll-snap-type:y proximity;
  scroll-padding-top:0;
  background:#0b0b10;
}
body{
  font-family:var(--font-body); color:var(--ink);
  background:#141019;
  -webkit-font-smoothing:antialiased;
}
body::before{ /* fixed grid + scanline texture */
  content:""; position:fixed; inset:0; pointer-events:none; z-index:1;
  background-image:
    linear-gradient(var(--grid) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(130% 110% at 25% 10%, #000 30%, transparent 90%);
}
body::after{ /* subtle scanlines only */
  content:""; position:fixed; inset:0; pointer-events:none; z-index:2;
  background:repeating-linear-gradient(0deg, rgba(0,0,0,.09) 0 1px, transparent 1px 3px);
  opacity:.4;
}

/* ---------- fixed header ---------- */
.topbar{
  position:fixed; top:0; left:0; right:0; z-index:40; height:84px;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 48px 0 var(--pad);
  background:rgba(11,11,16,.82); backdrop-filter:blur(9px); -webkit-backdrop-filter:blur(9px);
  border-bottom:1px solid rgba(255,255,255,.06);
  pointer-events:none;
}
.topbar .brand{ display:flex; align-items:center; gap:14px; pointer-events:auto; }
.topbar .brand img{ height:30px; filter:drop-shadow(0 0 10px color-mix(in srgb,var(--accent) 35%,transparent)); }
.theme-light .logo-w{ display:none; } .theme-dark .logo-d{ display:none; }
.topbar .right{ display:flex; align-items:center; gap:18px; pointer-events:auto; }
.topbar .tag{ font-family:var(--font-mono); font-size:11px; letter-spacing:.26em; color:var(--ink-faint); text-transform:uppercase; }
.lang{ display:flex; border:1px solid var(--panel-line); border-radius:2px; overflow:hidden; font-family:var(--font-mono); font-size:11px; letter-spacing:.16em; }
.lang button{ appearance:none; background:transparent; color:var(--ink-dim); border:0; cursor:pointer; padding:7px 12px; font:inherit; letter-spacing:inherit; transition:.18s; }
.lang button.on{ background:var(--accent); color:#0a0a0a; }
.lang button:not(.on):hover{ color:var(--ink); }
.topnav{ display:flex; gap:28px; pointer-events:auto; }
.topnav a{ font-family:var(--font-mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-dim); text-decoration:none; transition:.2s; }
.topnav a:hover{ color:var(--accent); }
.topbtn{ font-family:var(--font-mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase; background:var(--accent); color:#0a0a0a; padding:10px 16px; border-radius:2px; text-decoration:none; transition:.2s; }
.topbtn:hover{ box-shadow:0 0 22px color-mix(in srgb,var(--accent) 50%,transparent); }
@media (max-width:1100px){ .topnav{ display:none; } }

/* scroll progress hairline under bar */
.progress{ position:fixed; top:84px; left:0; height:2px; width:0%; z-index:41; background:linear-gradient(90deg,var(--accent),var(--accent-2)); box-shadow:0 0 12px var(--accent); }

/* ---------- dot pagination (right edge) ---------- */
.dots{ position:fixed; right:22px; top:50%; transform:translateY(-50%); z-index:43; display:flex; flex-direction:column; gap:15px; }
.dots button{ width:10px; height:10px; border-radius:50%; border:1.5px solid color-mix(in srgb,var(--ink) 45%, transparent); background:transparent; padding:0; cursor:pointer; transition:.25s; position:relative; }
.dots button:hover{ border-color:var(--accent); transform:scale(1.2); }
.dots button.on{ background:var(--accent); border-color:var(--accent); box-shadow:0 0 10px color-mix(in srgb,var(--accent) 70%,transparent); }
.dots button.on::after{ content:""; position:absolute; inset:-5px; border:1px solid color-mix(in srgb,var(--accent) 45%,transparent); border-radius:50%; }
.dots button::before{ content:attr(data-label); position:absolute; right:20px; top:50%; transform:translateY(-50%); font-family:var(--font-mono); font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-dim); white-space:nowrap; opacity:0; pointer-events:none; transition:opacity .2s; }
.dots button:hover::before, .dots button.on::before{ opacity:1; }
@media (max-width:1100px){ .dots{ right:12px; } .dots button::before{ display:none; } }

/* ---------- page + pipe rail ---------- */
.page{ position:relative; }
.pipe-rail{
  position:absolute; top:0; right:0; width:var(--rail); height:100%;
  z-index:6; pointer-events:none;
}
.pipe-rail svg{ display:block; width:100%; height:100%; overflow:visible; }
.pipe-tube{ fill:none; stroke:url(#tubeGrad); stroke-linejoin:round; stroke-linecap:round; }
.tg-a{ stop-color:var(--pipe-line-2); }
.tg-b{ stop-color:var(--pipe-line); }
.tg-hi{ stop-color:var(--pipe-hi); }
.pipe-core{ fill:none; stroke:var(--bg-0); stroke-linejoin:round; stroke-linecap:round; }
.pipe-flow{ fill:none; stroke:var(--pipe-fluid); stroke-linecap:round; stroke-linejoin:round; opacity:.42; }
.pipe-flow-glow{ fill:none; stroke:var(--pipe-fluid); stroke-linecap:round; stroke-linejoin:round; opacity:.12; }
/* animated fluid travelling inside the filled length (clipped by #flowMask) */
.pipe-fluid{ fill:none; stroke:var(--pipe-fluid); stroke-linecap:round; stroke-dasharray:2 26; stroke-dashoffset:0; opacity:.9; }
.pipe-spark{ fill:none; stroke:color-mix(in srgb,var(--pipe-fluid) 80%,#fff 20%); stroke-linecap:round; stroke-dasharray:1 27; stroke-dashoffset:0; opacity:.3; }
.flow-head-pulse{ fill:none; stroke:var(--pipe-fluid); stroke-width:2; opacity:0; }
@media (prefers-reduced-motion: no-preference){
  .pipe-fluid{ animation:pipeFlow 1.15s linear infinite; }
  .pipe-spark{ animation:pipeFlow .72s linear infinite; }
  .flow-head-pulse{ animation:headPulse 2.4s ease-out infinite; }
}
@keyframes pipeFlow{ to{ stroke-dashoffset:-28; } }
@keyframes headPulse{ 0%{ r:7; opacity:.22; } 70%{ opacity:.05; } 100%{ r:16; opacity:0; } }
.gauge{ stroke:var(--pipe-line); fill:none; stroke-width:1.6; stroke-linejoin:round; stroke-linecap:round; transition:stroke .35s; }
.gauge-fill{ fill:var(--bg-1); stroke:var(--pipe-line); stroke-width:1.6; transition:stroke .35s; }
.gauge-tick{ stroke:var(--ink-faint); stroke-width:1.4; }
.needle{ stroke:var(--ink-dim); stroke-width:1.4; stroke-linecap:round; }
.flow-head{ fill:var(--pipe-fluid); }
.flow-head-ring{ fill:none; stroke:var(--pipe-fluid); opacity:.7; }
.gauge.lit{ stroke:var(--pipe-fluid); }
.arc{ stroke:var(--pipe-line); fill:none; stroke-width:1.2; opacity:.16; }
.dot-lit{ fill:var(--pipe-fluid); stroke:var(--pipe-fluid); }

/* ---------- sections ---------- */
/* ---------- sections (light / dark mix) ---------- */
section.s{
  position:relative; z-index:5;
  min-height:100vh; scroll-snap-align:start;
  display:flex; flex-direction:column; justify-content:center;
  padding:88px calc(var(--rail) + var(--rail-gap)) 60px var(--pad);
  --railbg:#0b0b10; --secbg:#15151c;
  background:linear-gradient(90deg, var(--secbg) 0, var(--secbg) calc(100% - var(--rail)), var(--railbg) calc(100% - var(--rail)));
}
section.s.dark{
  --secbg:#15151c; --ink:#F4F1E6; --ink-dim:#9d9a8c; --ink-faint:#5c5a52;
  --panel:rgba(255,255,255,.04); --panel-line:rgba(255,255,255,.10); --grid:rgba(255,255,255,.04);
  color:var(--ink);
  background:
    radial-gradient(70% 46% at 12% 10%, color-mix(in srgb,var(--accent) 8%, transparent), transparent 55%),
    linear-gradient(90deg, var(--secbg) 0, var(--secbg) calc(100% - var(--rail)), var(--railbg) calc(100% - var(--rail)));
}
section.s.light{
  --secbg:#efe9db; --ink:#1a1712; --ink-dim:#5f5848; --ink-faint:#a89e86;
  --accent:#806300; --accent-2:#6b5200;
  --panel:rgba(26,23,18,.05); --panel-line:rgba(26,23,18,.16); --grid:rgba(40,34,18,.06);
  color:var(--ink);
  background:linear-gradient(90deg, var(--secbg) 0, var(--secbg) calc(100% - var(--rail)), var(--railbg) calc(100% - var(--rail)));
}
section.s.light .stars img{ filter:drop-shadow(0 1px 2px rgba(26,23,18,.25)); }
section.s.light .social img{ filter:brightness(0) opacity(.78); }
section.s.light .social a:hover img{ filter:brightness(0) opacity(1); }
section.s.hide{ display:none !important; }
/* Last slide sits above the footer — don't snap back when scrolling past it */
.page > section.s:last-child{ scroll-snap-align:none; }
footer{ scroll-snap-align:end; }
.subkicker{ font-family:var(--font-mono); font-size:12px; letter-spacing:.28em; text-transform:uppercase; color:var(--accent); margin-top:30px; padding-top:18px; border-top:1px solid var(--panel-line); }
.trust{ margin-top:42px; }
.logos{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:18px;
  margin-top:14px;
}
.logo-slot{
  height:clamp(130px, 11vw, 170px);
  min-width:0;
  display:flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--panel-line);
  border-radius:6px;
  padding:10px 14px;
  box-sizing:border-box;
  transition:.2s;
}
.logo-slot img{
  display:block;
  flex:1;
  min-width:0;
  min-height:0;
  width:100%;
  height:100%;
  max-width:100%;
  max-height:100%;
  object-fit:contain;
  object-position:center;
}
.logo-slot:hover{ border-color:var(--accent); }
.gallery{ display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.gallery.cols-2{ grid-template-columns:repeat(2,1fr); }
.gallery.cols-2 image-slot,
.gallery.cols-2 figure image-slot{ height:240px; }
.gallery image-slot{ display:block; width:100%; height:176px; border:1px solid var(--panel-line); }

/* portfolio (tabbed gallery, scrollable) */
.pf{ display:grid; grid-template-columns:252px 1fr; gap:36px; margin-top:24px; align-items:start; }
.pf-side{ display:flex; flex-direction:column; gap:14px; }
.pf-tabs{ display:flex; flex-direction:column; gap:11px; }
.pf-tab{ font-family:var(--font-display); font-weight:600; font-size:15.5px; padding:14px 20px; border-radius:999px; border:1px solid var(--panel-line); background:transparent; color:var(--ink); cursor:pointer; transition:.22s; display:flex; align-items:center; justify-content:space-between; gap:10px; }
.pf-tab > span:first-child{ display:flex; }
.pf-tab .pf-n{ font-family:var(--font-mono); font-size:11px; opacity:.55; transition:.22s; }
.pf-tab.on{ background:var(--accent); color:#0a0a0a; border-color:var(--accent); box-shadow:0 10px 26px rgba(255,212,0,.20); }
.pf-tab.on .pf-n{ opacity:.7; }
.pf-tab:not(.on):hover{ border-color:var(--accent); color:var(--accent); transform:translateX(3px); }
.pf-note{ margin-top:4px; padding:18px 20px; border:1px solid var(--panel-line); border-radius:18px; background:var(--panel); }
.pf-count{ font-family:var(--font-display); font-weight:700; font-size:34px; line-height:1; color:var(--accent); display:flex; align-items:baseline; gap:8px; }
.pf-count small{ font-family:var(--font-body); font-size:13px; color:var(--ink-dim); font-weight:500; }
.pf-note p{ margin:10px 0 0; font-size:12.5px; color:var(--ink-dim); line-height:1.45; }

.pf-main{ min-width:0; }
.pf-head{ display:flex; align-items:baseline; justify-content:space-between; gap:14px; margin-bottom:14px; }
.pf-active{ font-family:var(--font-display); font-weight:700; font-size:18px; letter-spacing:.01em; }
.pf-lock{ font-family:var(--font-mono); font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink); background:transparent; border:1px solid var(--panel-line); border-radius:999px; padding:9px 16px; cursor:pointer; transition:.2s; display:inline-flex; align-items:center; gap:7px; }
.pf-lock:hover{ border-color:var(--accent); color:var(--accent); }
.pf-lock .ic{ font-size:12px; }
.pf-lock .pf-lock-off{ display:none; }
.pf-focused .pf-lock{ background:var(--accent); color:#0a0a0a; border-color:var(--accent); }
.pf-focused .pf-lock .pf-lock-on{ display:none; }
.pf-focused .pf-lock .pf-lock-off{ display:inline; }
.pf-focused .pf-scroll{ outline:none; box-shadow:0 0 0 2px var(--accent), 0 18px 50px rgba(0,0,0,.4); border-radius:14px; }
.pf-scroll{ scroll-behavior:smooth; }
.pf-scroll:focus, .pf-scroll:focus-visible{ outline:none; }

/* CTA overlay — invites the click into focus mode */
.pf-cta{ position:absolute; inset:0; z-index:6; display:flex; align-items:center; justify-content:center; gap:16px; border:0; cursor:pointer; border-radius:14px; color:var(--ink); font-family:inherit; text-align:left;
  background:linear-gradient(180deg, color-mix(in srgb,var(--secbg) 30%,transparent), color-mix(in srgb,var(--secbg) 78%,transparent)); backdrop-filter:blur(2px); transition:opacity .3s, visibility .3s; }
.pf-cta::after{ content:""; position:absolute; inset:0; border-radius:14px; border:1.5px dashed color-mix(in srgb,var(--accent) 55%,transparent); pointer-events:none; }
.pf-cta:hover{ background:linear-gradient(180deg, color-mix(in srgb,var(--secbg) 22%,transparent), color-mix(in srgb,var(--secbg) 70%,transparent)); }
.pf-cta-badge{ position:relative; width:56px; height:56px; flex:none; display:grid; place-items:center; }
.pf-cta-ic{ position:relative; z-index:2; width:56px; height:56px; border-radius:50%; background:var(--accent); color:#0a0a0a; display:grid; place-items:center; font-size:24px; box-shadow:0 12px 34px rgba(255,212,0,.4); transition:transform .25s; }
.pf-cta:hover .pf-cta-ic{ transform:translate(3px,-3px); }
.pf-cta-pulse{ position:absolute; inset:0; border-radius:50%; background:var(--accent); opacity:.5; animation:pfpulse 1.9s ease-out infinite; pointer-events:none; }
@keyframes pfpulse{ 0%{ transform:scale(1); opacity:.45; } 70%,100%{ transform:scale(2.3); opacity:0; } }
.pf-cta-tx{ display:flex; flex-direction:column; gap:4px; }
.pf-cta-tx b{ font-family:var(--font-display); font-weight:700; font-size:19px; letter-spacing:.01em; text-transform:uppercase; line-height:1.12; max-width:15ch; }
.pf-cta-tx small{ font-family:var(--font-mono); font-size:11px; letter-spacing:.04em; color:var(--ink-dim); }

.pf-scrollwrap{ position:relative; }
.pf-scrollwrap::before, .pf-scrollwrap::after{ content:""; position:absolute; left:0; right:13px; height:34px; pointer-events:none; z-index:4; }
.pf-scrollwrap::before{ top:0; background:linear-gradient(var(--secbg), transparent); }
.pf-scrollwrap::after{ bottom:0; background:linear-gradient(transparent, var(--secbg)); }
.pf-scroll{ height:min(56vh,520px); overflow-y:auto; overflow-x:hidden; overscroll-behavior:contain; padding:6px 14px 8px 2px; scroll-behavior:smooth; scrollbar-width:thin; scrollbar-color:var(--accent) var(--panel-line); }
.pf-scroll::-webkit-scrollbar{ width:8px; }
.pf-scroll::-webkit-scrollbar-track{ background:var(--panel-line); border-radius:99px; margin:4px 0; }
.pf-scroll::-webkit-scrollbar-thumb{ background:linear-gradient(var(--accent),var(--accent-2)); border-radius:99px; }
.pf-scroll::-webkit-scrollbar-thumb:hover{ background:var(--accent); }
.pf-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; align-content:start; }

.pf-card{ background:#fff; color:#13131a; border-radius:14px; overflow:hidden; display:flex; flex-direction:column; box-shadow:0 6px 20px rgba(0,0,0,.28); transition:transform .25s, box-shadow .25s; animation:pfin .42s ease both; animation-delay:calc(var(--i,0) * .028s); }
.pf-card:hover{ transform:translateY(-5px); box-shadow:0 18px 46px rgba(0,0,0,.5); }
.pf-shot{ position:relative; background:#eef1f5; }
.pf-bar{ display:flex; align-items:center; gap:5px; padding:7px 10px; border-bottom:1px solid #e2e6ec; }
.pf-bar i{ width:8px; height:8px; border-radius:50%; background:#ccd2da; flex:none; }
.pf-url{ margin-left:7px; font-family:var(--font-mono); font-size:9px; color:#9aa2ad; background:#f4f6f9; border:1px solid #e7ebf0; border-radius:5px; padding:2px 8px; flex:1; min-width:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.pf-card image-slot{ display:block; width:100%; height:104px; }
.pf-card .pf-shot img,
.pf-card .pf-shot-ph{ display:block; width:100%; height:104px; object-fit:cover; }
.pf-shot-ph{ background:linear-gradient(135deg,#e8edf3,#d7dee8); }
.pf-body{ padding:12px 14px 13px; display:flex; flex-direction:column; gap:9px; }
.pf-meta{ display:flex; align-items:center; gap:8px; }
.pf-tag{ font-family:var(--font-mono); font-size:9px; letter-spacing:.08em; text-transform:uppercase; color:#5e6470; background:#f0f2f5; border:1px solid #e4e8ee; border-radius:6px; padding:3px 8px; }
.pf-year{ font-family:var(--font-mono); font-size:10px; color:#9aa2ad; margin-left:auto; }
.pf-row{ display:flex; align-items:center; justify-content:space-between; gap:10px; }
.pf-body h3{ font-family:var(--font-display); font-weight:700; font-size:13.5px; text-transform:uppercase; letter-spacing:.02em; margin:0; line-height:1.14; color:#13131a; }
.pf-acts{ display:flex; align-items:center; gap:7px; flex:none; }
.pf-act{ width:30px; height:30px; border-radius:50%; display:grid; place-items:center; flex:none; text-decoration:none; transition:transform .2s, background .2s, color .2s, border-color .2s; }
.pf-detail{ background:#fff; border:1px solid #dfe3ea; color:#13131a; }
.pf-detail svg{ width:15px; height:15px; }
.pf-detail:hover{ background:#13131a; border-color:#13131a; color:#fff; transform:translateY(-2px); }
.pf-go{ width:30px; height:30px; border-radius:50%; background:var(--accent); color:#0a0a0a; display:grid; place-items:center; flex:none; text-decoration:none; font-size:14px; transition:transform .2s; }
.pf-card:hover .pf-go{ transform:translate(2px,-2px); }
@keyframes pfin{ from{ opacity:0; transform:translateY(14px); } to{ opacity:1; transform:none; } }
@media (max-width:1100px){ .pf{ grid-template-columns:1fr; gap:20px; } .pf-side{ flex-direction:row; flex-wrap:wrap; align-items:flex-start; } .pf-tabs{ flex-direction:row; flex-wrap:wrap; flex:1; } .pf-tab{ flex:1; min-width:150px; } .pf-note{ width:100%; } .pf-grid{ grid-template-columns:repeat(2,1fr); } .pf-scroll{ height:62vh; } }
section.s.light .tile:hover{ box-shadow:0 8px 30px rgba(26,23,18,.10); }

.kicker{ font-family:var(--font-mono); font-size:13px; letter-spacing:.34em; text-transform:uppercase; color:var(--accent); display:flex; align-items:center; gap:14px; margin:0 0 18px; }
.kicker::before{ content:""; width:36px; height:1px; background:var(--accent); box-shadow:0 0 8px var(--accent); }

h1.title{ font-family:var(--font-display); font-weight:700; line-height:1.03; font-size:78px; letter-spacing:-.01em; margin:0; text-wrap:balance; }
h2.title{ font-family:var(--font-display); font-weight:700; line-height:1.02; font-size:52px; letter-spacing:-.005em; margin:0; text-wrap:balance; }
.title .hl{ color:var(--accent); text-shadow:0 0 28px color-mix(in srgb,var(--accent) 45%,transparent); }
.lead{ font-size:20px; line-height:1.45; color:var(--ink-dim); max-width:34ch; margin:20px 0 0; }

/* tiles / cards */
.grid{ display:grid; gap:14px; }
.g4{ grid-template-columns:repeat(auto-fit, minmax(260px, 1fr)); }
.g3{ grid-template-columns:repeat(3, minmax(0, 1fr)); }
.g2{ grid-template-columns:repeat(2,1fr); }
.tile{ position:relative; min-width:0; background:var(--panel); border:1px solid var(--panel-line); border-radius:3px; padding:17px 18px 18px; overflow:hidden; transition:border-color .3s, transform .3s; }
.tile::before{ content:""; position:absolute; left:0; top:0; width:100%; height:2px; background:linear-gradient(90deg,var(--accent),transparent 70%); opacity:0; transition:.3s; }
.tile:hover{ border-color:color-mix(in srgb,var(--accent) 45%,transparent); transform:translateY(-3px); }
.tile:hover::before{ opacity:.9; }
.tile .ico{ width:48px; height:48px; margin-bottom:13px; display:inline-grid; place-items:center; border-radius:12px; background:color-mix(in srgb,var(--accent) 14%,transparent); border:1px solid color-mix(in srgb,var(--accent) 32%,transparent); color:var(--accent); object-fit:contain; padding:10px; box-sizing:border-box; }
.tile .ico svg{ width:26px; height:26px; display:block; }
.svc .ico{ width:54px; height:54px; padding:11px; }
.svc .ico svg{ width:30px; height:30px; }
.tile h3{ font-family:var(--font-display); font-weight:600; font-size:17px; letter-spacing:.01em; margin:0 0 6px; text-transform:uppercase; line-height:1.2; overflow-wrap:break-word; }
.tile p{ font-size:13.5px; line-height:1.45; color:var(--ink-dim); margin:0; }
.tile .tag{ position:absolute; right:14px; top:14px; font-family:var(--font-mono); font-size:10px; letter-spacing:.18em; color:var(--accent); opacity:.75; }
.step .num{ font-family:var(--font-mono); font-size:12px; letter-spacing:.2em; color:var(--accent); margin-bottom:10px; display:block; }

/* buttons */
.row{ display:flex; gap:16px; align-items:center; flex-wrap:wrap; }
.btn{ display:inline-flex; align-items:center; gap:11px; font-family:var(--font-mono); font-size:14px; letter-spacing:.14em; text-transform:uppercase; text-decoration:none; padding:15px 24px; border-radius:2px; cursor:pointer; transition:.2s; }
.btn.primary{ background:var(--accent); color:#0a0a0a; box-shadow:0 0 30px color-mix(in srgb,var(--accent) 32%,transparent); }
.btn.primary:hover{ transform:translateY(-2px); box-shadow:0 0 44px color-mix(in srgb,var(--accent) 52%,transparent); }
.btn.ghost{ color:var(--ink); border:1px solid var(--panel-line); }
.btn.ghost:hover{ border-color:var(--accent); color:var(--accent); }
.mono{ font-family:var(--font-mono); } .dim{ color:var(--ink-dim); }

/* testimonial */
.stars{ display:flex; gap:8px; margin-bottom:26px; } .stars img{ height:24px; filter:drop-shadow(0 0 8px color-mix(in srgb,var(--accent) 50%,transparent)); }
.quote{ font-family:var(--font-display); font-weight:600; font-size:38px; line-height:1.16; letter-spacing:-.01em; max-width:18ch; text-wrap:balance; margin:0; }
.quote .qt{ color:var(--accent); }
.person{ display:flex; align-items:center; gap:18px; margin-top:38px; }
.person img{ width:62px; height:62px; border-radius:50%; object-fit:cover; border:1px solid var(--accent); }
.person .nm{ font-family:var(--font-display); font-weight:600; font-size:20px; }
.person .rl{ font-family:var(--font-mono); font-size:12px; letter-spacing:.16em; color:var(--ink-dim); text-transform:uppercase; }

/* ---------- casos de éxito ---------- */
.cases{ display:flex; flex-direction:column; gap:22px; margin-top:26px; }
.case-stage{ display:grid; grid-template-columns:1.1fr .9fr; gap:34px; align-items:center; }
.case-video{ position:relative; aspect-ratio:16/10; border-radius:16px; overflow:hidden; border:1px solid var(--panel-line); background:#0c0c12; box-shadow:0 22px 54px rgba(0,0,0,.5); }
.case-video .cv{ width:100%; height:100%; object-fit:cover; display:block; background:#0c0c12; }
.cv-badge{ position:absolute; left:14px; top:13px; z-index:3; display:flex; align-items:center; gap:7px; font-family:var(--font-mono); font-size:10px; letter-spacing:.2em; color:var(--ink); background:rgba(0,0,0,.45); border:1px solid var(--panel-line); border-radius:99px; padding:5px 11px; backdrop-filter:blur(3px); }
.cv-dot{ width:7px; height:7px; border-radius:50%; background:var(--accent); box-shadow:0 0 8px var(--accent); }
.cv-play{ position:absolute; inset:0; z-index:2; display:grid; place-items:center; border:0; cursor:pointer; background:linear-gradient(180deg, rgba(0,0,0,.06), rgba(0,0,0,.5)); transition:opacity .25s, visibility .25s, background .25s; }
.cv-play:hover{ background:linear-gradient(180deg, rgba(0,0,0,.02), rgba(0,0,0,.4)); }
.cv-play .cv-ic{ width:74px; height:74px; border-radius:50%; background:var(--accent); color:#0a0a0a; display:grid; place-items:center; font-size:26px; padding-left:5px; box-shadow:0 14px 38px color-mix(in srgb,var(--accent) 45%,transparent); transition:transform .2s; }
.cv-play:hover .cv-ic{ transform:scale(1.08); }
.case-video.playing .cv-play{ opacity:0; visibility:hidden; }
.case-q{ font-family:var(--font-display); font-weight:600; font-size:27px; line-height:1.28; letter-spacing:-.01em; margin:0 0 22px; text-wrap:pretty; }
.case-q .qt{ color:var(--accent); }
.case-by{ display:flex; align-items:center; gap:15px; margin:0; }
.case-by img{ width:56px; height:56px; border-radius:50%; object-fit:cover; border:1px solid var(--accent); }
.case-by .nm{ font-family:var(--font-display); font-weight:600; font-size:19px; }
.case-by .rl{ font-family:var(--font-mono); font-size:11px; letter-spacing:.14em; color:var(--ink-dim); text-transform:uppercase; }
.case-people{ display:flex; gap:12px; overflow-x:auto; padding:6px 2px 10px; scrollbar-width:thin; scrollbar-color:var(--accent) var(--panel-line); }
.case-person{ flex:0 0 auto; display:flex; align-items:center; gap:11px; padding:8px 17px 8px 8px; border:1px solid var(--panel-line); border-radius:99px; background:var(--panel); color:var(--ink); cursor:pointer; font-family:inherit; transition:transform .2s, border-color .2s, background .2s; }
.case-person img{ width:40px; height:40px; border-radius:50%; object-fit:cover; }
.case-person .cp-tx{ display:flex; flex-direction:column; align-items:flex-start; line-height:1.15; }
.case-person .cp-nm{ font-family:var(--font-display); font-weight:600; font-size:14px; }
.case-person .cp-co{ font-family:var(--font-mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-dim); }
.case-person:not(.on):hover{ border-color:var(--accent); transform:translateY(-2px); }
.case-person.on{ border-color:var(--accent); background:color-mix(in srgb,var(--accent) 12%,transparent); }
.case-person.on img{ outline:2px solid var(--accent); outline-offset:1px; }

/* ---------- Compila Tech · podcast ---------- */
section.s.dark.podcast-compila{
  --secbg:#00261a; --railbg:#001b12;
  --ink:#eafce0; --ink-dim:#8fb488; --ink-faint:#5c7a55;
  --accent:#a8e828; --accent-2:#7bc41a;
  --panel:rgba(216,248,184,.05); --panel-line:rgba(168,232,40,.20); --grid:rgba(168,232,40,.05);
}
.podcast-compila .kicker{ color:var(--accent); }
.pc-head{ display:flex; align-items:center; gap:18px; flex-wrap:wrap; }
.pc-logo{ height:56px; width:auto; display:block; filter:drop-shadow(0 8px 22px rgba(168,232,40,.18)); }
.pc-by{ font-family:var(--font-mono); font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--ink-dim); padding-left:18px; border-left:1px solid var(--panel-line); }
.pc-by span{ display:block; }
.pc-ep{ background:rgba(0,0,0,.20); border:1px solid var(--panel-line); border-radius:16px; overflow:hidden; display:flex; flex-direction:column; transition:transform .25s, border-color .25s, box-shadow .25s; }
.pc-ep:hover{ transform:translateY(-5px); border-color:var(--accent); box-shadow:0 18px 44px rgba(0,0,0,.45); }
.pc-cover{ position:relative; display:block; text-decoration:none; color:inherit; }
.pc-cover image-slot{ display:block; width:100%; height:150px; }
.pc-cover::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, transparent 42%, rgba(0,38,26,.6)); pointer-events:none; }
.pc-play{ position:absolute; left:14px; bottom:14px; z-index:2; width:44px; height:44px; border-radius:50%; background:var(--accent); color:#00261a; display:grid; place-items:center; font-size:15px; padding-left:3px; box-shadow:0 8px 22px rgba(168,232,40,.4); transition:transform .2s; }
.pc-ep:hover .pc-play{ transform:scale(1.1); }
.pc-dur{ position:absolute; right:12px; top:12px; z-index:2; font-family:var(--font-mono); font-size:10px; letter-spacing:.14em; color:var(--ink); background:rgba(0,27,18,.72); border:1px solid var(--panel-line); border-radius:99px; padding:4px 10px; }
.pc-body{ padding:16px 18px 18px; display:flex; flex-direction:column; gap:9px; }
.pc-ep-n{ font-family:var(--font-mono); font-size:11px; letter-spacing:.2em; color:var(--accent); }
.pc-body h3{ font-family:var(--font-display); font-weight:600; font-size:19px; margin:0; color:var(--ink); }
.pc-body p{ margin:0; font-size:13px; line-height:1.5; color:var(--ink-dim); }
.pc-listen{ margin-top:4px; display:inline-flex; align-items:center; gap:9px; font-family:var(--font-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); text-decoration:none; }
.pc-listen-ic{ width:24px; height:24px; border-radius:50%; border:1px solid var(--accent); display:grid; place-items:center; font-size:9px; padding-left:1px; transition:.2s; }
.pc-listen:hover .pc-listen-ic{ background:var(--accent); color:#00261a; }

/* faq */
.faq-row{ border-top:1px solid var(--panel-line); padding:20px 0; display:grid; grid-template-columns:1fr 1.1fr; gap:40px; align-items:start; }
.faq-row:last-child{ border-bottom:1px solid var(--panel-line); }
.faq-row .q{ font-family:var(--font-display); font-weight:600; font-size:21px; text-transform:uppercase; letter-spacing:.01em; line-height:1.15; }
.faq-row .q .qmark{ color:var(--accent); margin-right:12px; font-family:var(--font-mono); font-size:15px; }
.faq-row .a{ font-size:15.5px; line-height:1.55; color:var(--ink-dim); }

/* resources */
.res .ix{ font-family:var(--font-mono); font-size:12px; letter-spacing:.2em; color:var(--accent); margin-bottom:16px; display:block; }
.res h3{ font-family:var(--font-display); font-weight:700; font-size:23px; text-transform:uppercase; line-height:1.1; margin:0 0 12px; }
.res p{ font-size:14.5px; color:var(--ink-dim); line-height:1.5; margin:0 0 20px; }
.res .lk{ font-family:var(--font-mono); font-size:12px; letter-spacing:.12em; color:var(--ink); text-decoration:none; border-bottom:1px solid var(--accent); padding-bottom:3px; }
/* featured image on blog / podcast cards */
.res .feat{ display:block; width:calc(100% + 36px); height:150px; margin:-17px -18px 16px; border-bottom:1px solid var(--panel-line); }
section.s.dark .res .feat{ border-bottom-color:rgba(255,255,255,.10); }
.res.play{ position:relative; }
.res.play .feat::after{ content:"▶"; position:absolute; left:14px; top:118px; width:30px; height:30px; display:grid; place-items:center; font-size:11px; color:#fff; background:var(--accent); border-radius:50%; pointer-events:none; }

/* blog carousel */
.blog-carousel{ margin-top:48px; }
.blog-carousel-viewport{ overflow:hidden; }
.blog-carousel-track{
  display:flex; gap:14px;
  transition:transform .45s cubic-bezier(.4,0,.2,1);
  will-change:transform;
}
.blog-carousel-track .blog-card{
  flex:0 0 calc((100% - 28px) / 3);
  min-width:0;
  display:flex;
  flex-direction:column;
}
.blog-carousel-track .blog-card .lk{
  margin-top:auto;
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:2;
  line-clamp:2;
  overflow:hidden;
  word-break:break-all;
}
.blog-carousel-nav{
  display:flex; align-items:center; justify-content:center; gap:18px;
  margin-top:28px;
}
.blog-carousel-btn{
  appearance:none; background:transparent;
  width:42px; height:42px;
  border:1px solid var(--panel-line); border-radius:50%;
  font-family:var(--font-display); font-size:24px; line-height:1;
  color:var(--ink); cursor:pointer;
  transition:border-color .2s, color .2s, background .2s;
}
.blog-carousel-btn:hover:not(:disabled){
  border-color:var(--accent);
  color:var(--accent);
  background:color-mix(in srgb,var(--accent) 10%,transparent);
}
.blog-carousel-btn:disabled{ opacity:.35; cursor:not-allowed; }
.blog-carousel-dots{ display:flex; align-items:center; gap:8px; }
.blog-dot{
  appearance:none; background:var(--panel-line);
  width:8px; height:8px; padding:0; border:0; border-radius:50%;
  cursor:pointer; transition:transform .2s, background .2s;
}
.blog-dot.on{
  background:var(--accent);
  transform:scale(1.25);
  box-shadow:0 0 10px color-mix(in srgb,var(--accent) 45%,transparent);
}

/* office photo references */
.gallery figure{ margin:0; display:flex; flex-direction:column; gap:8px; }
.gallery figure image-slot{ display:block; width:100%; height:176px; border:1px solid var(--panel-line); }
.gallery figcaption{ font-family:var(--font-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-dim); display:flex; align-items:center; gap:8px; }
.gallery figcaption::before{ content:""; width:6px; height:6px; background:var(--accent); border-radius:50%; flex:0 0 auto; }

/* contacto */
.sedes{ display:flex; gap:14px; flex-wrap:wrap; }
.sede{ font-family:var(--font-mono); font-size:15px; letter-spacing:.14em; color:var(--ink); border:1px solid var(--panel-line); padding:11px 17px; border-radius:2px; text-transform:uppercase; display:inline-flex; align-items:center; }
.sede .flag{ width:22px; height:22px; border-radius:50%; object-fit:cover; margin-right:8px; flex-shrink:0; }
.social{ display:flex; gap:14px; margin-top:6px; pointer-events:auto; }
.social a{ width:46px; height:46px; display:grid; place-items:center; border:1px solid var(--panel-line); border-radius:2px; transition:.2s; }
.social a:hover{ border-color:var(--accent); background:color-mix(in srgb,var(--accent) 12%,transparent); }
.social img{ height:20px; }
.label{ font-family:var(--font-mono); font-size:12px; letter-spacing:.24em; color:var(--ink-faint); text-transform:uppercase; margin-bottom:13px; }

/* contact form layout */
.contact-grid{ display:grid; grid-template-columns:0.82fr 1.18fr; gap:50px; align-items:start; margin-top:30px; }
.contact-left .clead{ font-size:18px; line-height:1.5; color:var(--ink-dim); max-width:40ch; margin:0 0 26px; }
.cbtns{ display:flex; flex-direction:column; gap:14px; max-width:400px; }
.cbtn{ display:flex; align-items:center; justify-content:center; gap:11px; height:60px; border-radius:50px; background:#FFD400; color:#1a1712; font-family:var(--font-display); font-weight:600; font-size:18px; letter-spacing:.01em; text-decoration:none; border:0; cursor:pointer; transition:background .2s, transform .2s, box-shadow .2s; }
.cbtn:hover{ background:#FFB300; transform:translateY(-2px); box-shadow:0 12px 30px rgba(255,180,0,.32); }
.cbtn svg{ width:21px; height:21px; }
.contact-meta{ margin-top:34px; }

.form-card{ background:#fff; border:1px solid rgba(26,23,18,.10); border-radius:16px; padding:34px 38px 30px; box-shadow:0 22px 60px rgba(26,23,18,.13); }
.form-card .fk{ font-family:var(--font-mono); font-size:12px; letter-spacing:.24em; text-transform:uppercase; color:var(--accent-3,#806300); margin:0 0 10px; }
.form-card h3{ font-family:var(--font-display); font-weight:700; font-size:30px; text-transform:uppercase; letter-spacing:-.005em; line-height:1.06; margin:0 0 10px; color:#1a1712; }
.form-card .fsub{ font-size:15px; color:#6b6450; margin:0 0 26px; }
.fgrid{ display:grid; grid-template-columns:1fr 1fr; gap:22px 30px; }
.field{ display:flex; flex-direction:column; gap:9px; }
.field.full{ grid-column:1 / -1; }
.field label{ font-family:var(--font-mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:#6b6450; }
.field input, .field textarea{ font-family:var(--font-body); font-size:15px; color:#1a1712; background:transparent; border:0; border-bottom:1px solid rgba(26,23,18,.20); padding:8px 0; outline:none; transition:border-color .2s; }
.field input::placeholder, .field textarea::placeholder{ color:#a59c80; }
.field input:focus, .field textarea:focus{ border-bottom-color:#FFB300; }
.field textarea{ resize:vertical; min-height:74px; line-height:1.5; }
.checks{ display:flex; flex-direction:column; gap:11px; margin-top:24px; }
.checks label{ display:flex; align-items:flex-start; gap:11px; font-size:13.5px; color:#6b6450; line-height:1.4; cursor:pointer; }
.checks input{ appearance:none; -webkit-appearance:none; width:18px; height:18px; flex:0 0 auto; margin-top:1px; border:1.5px solid rgba(26,23,18,.30); border-radius:4px; background:#fff; cursor:pointer; transition:.15s; position:relative; }
.checks input:checked{ background:#FFD400; border-color:#FFD400; }
.checks input:checked::after{ content:"✓"; position:absolute; inset:0; display:grid; place-items:center; font-size:12px; color:#1a1712; font-weight:700; }
.field input.invalid, .field textarea.invalid{ border-bottom-color:#c11007; }
span.field-error{
  display:none !important;
  font-family:var(--font-mono);
  font-size:11px;
  color:#c11007;
  letter-spacing:.04em;
}
span.field-error.visible{ display:block !important; }
.lang-es span.field-error.visible[data-lang="en"]{ display:none !important; }
.lang-en span.field-error.visible[data-lang="es"]{ display:none !important; }
.hidden{ display:none !important; }
.form-msg{ margin-top:20px; padding:14px 16px; border-radius:8px; font-size:14px; line-height:1.45; }
.form-msg.hidden{ display:none; }
.form-msg.success{ background:#ecfdf3; color:#166534; border:1px solid #86efac; }
.form-msg.error{ background:#fef2f2; color:#991b1b; border:1px solid #fca5a5; }
.submit:disabled{ opacity:.6; cursor:not-allowed; transform:none; box-shadow:none; }
.form-foot{ display:flex; justify-content:flex-end; margin-top:26px; }
.submit{ font-family:var(--font-mono); font-size:13px; letter-spacing:.18em; text-transform:uppercase; background:#FFD400; color:#1a1712; border:0; border-radius:8px; padding:14px 34px; cursor:pointer; font-weight:700; transition:background .2s, transform .2s, box-shadow .2s; }
.submit:hover{ background:#FFB300; transform:translateY(-2px); box-shadow:0 12px 30px rgba(255,180,0,.32); }
@media (max-width:1100px){ .contact-grid{ grid-template-columns:1fr; gap:34px; } .fgrid{ grid-template-columns:1fr 1fr; } }

/* packed-info helpers */
.caps{ display:flex; flex-wrap:wrap; gap:10px; margin-top:32px; }
.cap{ font-family:var(--font-mono); font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-dim); border:1px solid var(--panel-line); padding:7px 13px; border-radius:2px; }
.cap b{ color:var(--accent); font-weight:400; }
.step .out{ font-family:var(--font-mono); font-size:11.5px; letter-spacing:.03em; color:var(--accent); margin-top:13px; display:block; opacity:.9; }
.cta-line{ display:flex; align-items:center; gap:16px; flex-wrap:wrap; margin-top:30px; font-family:var(--font-display); font-weight:600; font-size:21px; }
.cta-line a{ color:var(--accent); text-decoration:none; font-family:var(--font-mono); font-size:13px; letter-spacing:.1em; border-bottom:1px solid var(--accent); padding-bottom:3px; }
.statline{ display:flex; gap:34px; flex-wrap:wrap; margin-top:30px; }
.stat .n{ font-family:var(--font-display); font-weight:700; font-size:40px; color:var(--accent); line-height:1; }
.stat .l{ font-family:var(--font-mono); font-size:11.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-dim); margin-top:8px; }

/* bilingual */
.lang-es [data-lang="en"]{ display:none; } .lang-en [data-lang="es"]{ display:none; }
p[data-lang], .block[data-lang]{ display:block; } span[data-lang]{ display:inline; }
.lang-es p[data-lang="en"], .lang-es .block[data-lang="en"]{ display:none; }
.lang-en p[data-lang="es"], .lang-en .block[data-lang="es"]{ display:none; }

/* reveal on scroll (JS-gated so it's visible without JS / in print) */
html.js .reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); transition-delay:calc(var(--d,0)*80ms); }
html.js .s.in .reveal{ opacity:1; transform:none; }

/* scroll hint */
.scroll-hint{ position:fixed; left:50%; bottom:26px; transform:translateX(-50%); z-index:40; font-family:var(--font-mono); font-size:11px; letter-spacing:.24em; color:var(--ink-faint); text-transform:uppercase; display:flex; align-items:center; gap:10px; transition:opacity .5s; }
.scroll-hint .arr{ width:7px; height:7px; border-right:1.5px solid var(--accent); border-bottom:1.5px solid var(--accent); transform:rotate(45deg); animation:bob 1.6s ease-in-out infinite; }
@keyframes bob{ 0%,100%{ transform:rotate(45deg) translate(0,0); opacity:.5 } 50%{ transform:rotate(45deg) translate(2px,2px); opacity:1 } }

@media (max-width:1100px){
  :root{ --rail:360px; --pad:56px; --rail-gap:32px; }
  h1.title{ font-size:64px; } h2.title{ font-size:46px; } .quote{ font-size:36px; }
  .g4{ grid-template-columns:repeat(2, minmax(0, 1fr)); } .g3{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
  .blog-carousel-track .blog-card{ flex-basis:calc((100% - 14px) / 2); }
  .logos{ grid-template-columns:repeat(2, minmax(0, 1fr)); gap:14px; }
  .logo-slot{ height:clamp(120px, 16vw, 150px); padding:10px 12px; }
}

@media (max-width:1180px){
  :root{ --rail:300px; --pad:44px; --rail-gap:40px; }
  .topbar{ padding-left:var(--pad); padding-right:32px; }
  section.s{ padding-right:calc(var(--rail) + var(--rail-gap) + 32px); }
  h1.title{ font-size:60px; }
  h2.title, section.s .title[style]{ font-size:44px !important; }
  .lead{ font-size:18px; }
  .case-stage{ grid-template-columns:1fr; gap:22px; align-items:start; }
}

@media (max-width:900px){
  :root{ --rail:0px; --pad:28px; --rail-gap:0px; }
  html{ scroll-snap-type:none; }
  .topbar{
    height:72px;
    padding:0 var(--pad);
    gap:18px;
  }
  .topbar .brand img{ height:26px; }
  .topbar .right{ gap:10px; }
  .topbtn{ padding:9px 12px; font-size:11px; letter-spacing:.06em; }
  .progress{ top:72px; }
  .pipe-rail, .dots{ display:none; }
  section.s,
  section.s.dark,
  section.s.light,
  section.s.dark.podcast-compila{
    min-height:auto;
    justify-content:flex-start;
    padding:108px var(--pad) 72px;
    background:
      radial-gradient(90% 38% at 15% 0%, color-mix(in srgb,var(--accent) 8%, transparent), transparent 58%),
      var(--secbg);
  }
  section.s.light{
    background:var(--secbg);
  }
  h1.title{ font-size:clamp(42px, 8vw, 56px); }
  h2.title, section.s .title[style]{ font-size:clamp(32px, 6.4vw, 42px) !important; }
  .lead{
    font-size:17px;
    max-width:64ch;
  }
  .kicker{
    font-size:12px;
    letter-spacing:.22em;
    gap:10px;
  }
  .kicker::before{ width:24px; }
  .gallery,
  .case-stage,
  .faq-row,
  .contact-grid{
    grid-template-columns:1fr;
  }
  .gallery.cols-2 image-slot,
  .gallery.cols-2 figure image-slot{
    height:280px;
  }
  .pc-head{ align-items:flex-start; }
  .pc-by{
    width:100%;
    padding-left:0;
    border-left:0;
  }
  .pc-eps.g3{ grid-template-columns:repeat(2,1fr); }
  .contact-grid{ gap:30px; }
}

@media (max-width:700px){
  :root{ --pad:20px; }
  body::after{ opacity:.25; }
  .topbar{
    height:64px;
    padding:0 16px;
  }
  .topbar .right{ margin-left:auto; }
  .topbar .brand img{ height:23px; }
  .lang button{ padding:7px 9px; }
  .topbtn{ display:none; }
  .progress{ top:64px; }
  section.s,
  section.s.dark,
  section.s.light,
  section.s.dark.podcast-compila{
    padding:88px var(--pad) 58px;
  }
  .blog-carousel-track .blog-card{ flex-basis:100%; }
  .blog-carousel-nav{ margin-top:22px; }
  .scroll-hint{ display:none; }
  h1.title{ font-size:clamp(36px, 11vw, 46px); line-height:1.04; }
  h2.title, section.s .title[style]{ font-size:clamp(29px, 8.6vw, 38px) !important; line-height:1.06; }
  .lead{ font-size:16px; line-height:1.5; margin-top:16px; }
  .row{ gap:10px; }
  .btn{
    width:100%;
    justify-content:center;
    min-height:48px;
    padding:13px 16px;
    font-size:12px;
    letter-spacing:.08em;
    text-align:center;
  }
  .caps{ margin-top:24px; gap:8px; }
  .cap{ font-size:10.5px; letter-spacing:.08em; padding:7px 9px; }
  .grid,
  .g4,
  .g3,
  .g2,
  .pc-eps.g3{
    grid-template-columns:minmax(0, 1fr);
  }
  .tile{ padding:16px; }
  .tile .tag{
    position:static;
    display:inline-block;
    margin-bottom:12px;
  }
  .trust{ margin-top:30px; }
  .logos{ gap:12px; }
  .logo-slot{
    height:clamp(108px, 26vw, 140px);
    padding:8px 10px;
  }
  .subkicker{
    font-size:11px;
    letter-spacing:.16em;
    line-height:1.4;
  }
  .cta-line{
    align-items:flex-start;
    flex-direction:column;
    font-size:18px;
    gap:10px;
  }
  .pf{ gap:16px; }
  .pf-side{
    flex-direction:column;
    gap:12px;
  }
  .pf-tabs{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:9px;
    width:100%;
  }
  .pf-tab{
    min-width:0;
    width:100%;
    padding:11px 12px;
    border-radius:12px;
    font-size:13px;
    line-height:1.05;
  }
  .pf-note{ display:none; }
  .pf-head{
    align-items:stretch;
    flex-direction:column;
    gap:10px;
  }
  .pf-lock{
    width:100%;
    justify-content:center;
    min-height:42px;
  }
  .pf-scroll{ height:68vh; padding-right:10px; }
  .pf-grid{ grid-template-columns:1fr; gap:14px; }
  .pf-card image-slot{ height:132px; }
  .pf-row{
    align-items:flex-start;
    flex-direction:column;
  }
  .pf-acts{ width:100%; justify-content:flex-end; }
  .pf-cta{
    flex-direction:column;
    text-align:center;
    padding:22px;
  }
  .pf-cta-tx{ align-items:center; }
  .pf-cta-tx b{ font-size:17px; max-width:18ch; }
  .quote{ font-size:30px; max-width:100%; }
  .person{ align-items:flex-start; }
  .case-video{ border-radius:10px; }
  .case-q{ font-size:22px; }
  .case-person{
    width:max-content;
    max-width:88vw;
  }
  .pc-logo{ height:44px; }
  .pc-cover image-slot,
  .res .feat{
    height:180px;
  }
  .gallery.cols-2 image-slot,
  .gallery.cols-2 figure image-slot{
    height:240px;
  }
  .sede{
    width:100%;
    font-size:12px;
    letter-spacing:.1em;
  }
  .social{ flex-wrap:wrap; }
  .cbtns{ max-width:none; }
  .cbtn{
    height:52px;
    font-size:16px;
    text-align:center;
  }
  .form-card{
    border-radius:12px;
    padding:24px 18px 22px;
  }
  .form-card h3{ font-size:24px; }
  .fgrid{ grid-template-columns:1fr; gap:18px; }
  .checks label{ font-size:12.5px; }
  .form-foot{ justify-content:stretch; }
  .submit{ width:100%; }
}

@media (max-width:420px){
  :root{ --pad:16px; }
  .topbar .brand img{ height:21px; }
  .lang{ font-size:10px; letter-spacing:.1em; }
  .lang button{ padding:6px 8px; }
  .kicker{ letter-spacing:.16em; }
  .pf-tabs{ grid-template-columns:1fr; }
  .pf-scroll{ height:72vh; }
  .gallery.cols-2 image-slot,
  .gallery.cols-2 figure image-slot{
    height:220px;
  }
}
