/* =====================================================================
   VELUM — Design System
   Premium textile-care brand. Warm-neutral palette, editorial serif
   display, restrained motion. Authored mobile-first.
   ===================================================================== */

/* ---------- Tokens ---------- */
:root {
  /* ===== Primitive — raw values; the ONLY place color literals live ===== */
  --c-paper:     #FBFAF6;
  --c-linen:     #F2EDE3;
  --c-mist:      #E4DED1;
  --c-soft:      #66625A;
  --c-ink:       #211F1B;
  --c-sage:      #ADB59C;
  --c-sage-deep: #646F57;
  --c-indigo:      #2E3A4B;   /* tinte textil noble — acento de marca */
  --c-indigo-soft: #9DB0C6;   /* índigo claro para superficies oscuras */
  --c-black:     #000;
  /* RGB channels — let semantic tokens compose alpha from a single source */
  --c-ink-rgb:   31, 30, 27;
  --c-paper-rgb: 251, 250, 246;
  --c-indigo-rgb: 46, 58, 75;

  /* ===== Semantic — purpose aliases (what the UI references) ===== */
  /* Palette */
  --paper:  var(--c-paper);        /* main background — warm off-white */
  --linen:  var(--c-linen);        /* secondary surface — cream        */
  --mist:   var(--c-mist);         /* warm light gray surface          */
  --soft:   var(--c-soft);         /* warm mid-gray — secondary text (AA) */
  --ink:    var(--c-ink);          /* warm charcoal — primary ink      */
  /* Accent — índigo (tinte textil noble): rompe el monocromo editorial, uso <=5% */
  --accent:      var(--c-indigo);       /* índigo — texto y acento sobre claro */
  --accent-soft: var(--c-indigo-soft);  /* índigo claro — acento sobre oscuro */
  --accent-rgb:  46, 58, 75;
  --sage:      var(--c-indigo-soft);    /* legacy alias → ahora índigo claro */
  --sage-deep: var(--c-indigo);         /* legacy alias → ahora índigo */
  --ink-deep:  var(--c-black);          /* hover: un punto más profundo que ink */

  /* Hairlines / borders */
  --line:       rgba(var(--c-ink-rgb), 0.12);
  --line-soft:  rgba(var(--c-ink-rgb), 0.06);
  --paper-line: rgba(var(--c-paper-rgb), 0.16);

  /* Type */
  --serif: "Cormorant Garamond", "Cormorant", Georgia, serif;
  --sans:  "DM Sans", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --mono:  "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;

  /* Rhythm */
  --gutter: clamp(20px, 5vw, 120px);
  --section-y: clamp(56px, 8vh, 132px);
  --maxw: 1440px;
  --radius: 4px;

  /* Motion */
  --ease: cubic-bezier(0.22, 0.61, 0.36, 1);
  --dur: 640ms;

  /* Fluid display sizes */
  --fs-hero: clamp(31px, 4.3vw, 58px);
  --fs-display: clamp(28px, 3.4vw, 46px);
  --fs-section: clamp(25px, 2.7vw, 38px);
  --fs-mid: clamp(21px, 2.1vw, 29px);
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }
body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 17px;
  line-height: 1.65;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; cursor: pointer; }
ul { margin: 0; padding: 0; list-style: none; }
h1, h2, h3, h4 { margin: 0; font-weight: 400; }
:focus-visible { outline: 2px solid var(--ink); outline-offset: 3px; border-radius: 2px; }
::selection { background: var(--ink); color: var(--paper); }

/* ---------- Layout primitives ---------- */
.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gutter); }
.section { padding-block: var(--section-y); position: relative; }
.section--linen { background: var(--linen); }
.section--mist  { background: var(--mist); }
.section--ink   { background: var(--ink); color: var(--paper); }
.section--tight { padding-block: clamp(48px, 7vh, 96px); }

.section--ink .soft-c { color: rgba(var(--c-paper-rgb),0.72); }

/* ---------- Type utilities ---------- */
.kicker {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--soft);
  font-weight: 500;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.kicker::before {
  content: "";
  width: 22px; height: 1px;
  background: var(--sage-deep);
  display: inline-block;
}
.kicker--plain::before { display: none; }
.section--ink .kicker, .cta-final .kicker { color: rgba(var(--c-paper-rgb),0.8); }

.display { font-family: var(--serif); font-weight: 300; line-height: 0.98; letter-spacing: -0.012em; font-size: var(--fs-display); }
.h-section { font-family: var(--serif); font-weight: 400; line-height: 1.04; letter-spacing: -0.005em; font-size: var(--fs-section); }
.h-mid { font-family: var(--serif); font-weight: 400; line-height: 1.08; font-size: var(--fs-mid); }
.serif-em { font-style: italic; font-weight: 400; color: var(--sage-deep); }
.section--ink .serif-em { color: var(--sage); }

/* Pointer highlight — draws a box + cursor around a key word on scroll-in */
.ph { position: relative; display: inline-block; white-space: nowrap; }
.ph__t { position: relative; z-index: 1; }
.ph__line { position: absolute; left: -0.06em; bottom: -0.1em; width: calc(100% + 0.12em); height: 0.34em; overflow: visible; pointer-events: none; }
.ph__rule { fill: none; stroke: var(--accent); stroke-width: 2; stroke-linecap: round; vector-effect: non-scaling-stroke; stroke-dasharray: 1; stroke-dashoffset: 1; }
.ph__ptr { position: absolute; right: -0.42em; bottom: -0.34em; width: 0.62em; height: 0.62em; fill: var(--accent); opacity: 0; transform: translate(-5px, -5px) scale(0.6); pointer-events: none; }
.ph.is-on .ph__rule { transition: stroke-dashoffset 700ms var(--ease); stroke-dashoffset: 0; }
.ph.is-on .ph__ptr { transition: opacity 280ms 520ms var(--ease), transform 380ms 520ms var(--ease); opacity: 1; transform: translate(0, 0) scale(1); }
.section--ink .ph__rule { stroke: var(--accent-soft); }
.section--ink .ph__ptr { fill: var(--accent-soft); }
@media (prefers-reduced-motion: reduce) {
  .ph__rule { stroke-dashoffset: 0; transition: none; }
  .ph__ptr { opacity: 1; transform: none; transition: none; }
}

.lede { font-size: clamp(16.5px, 1.4vw, 19px); line-height: 1.55; color: rgba(var(--c-ink-rgb),0.78); max-width: 60ch; }
.section--ink .lede, .cta-final .lede { color: rgba(var(--c-paper-rgb),0.8); }
.muted { color: var(--soft); }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--sans); font-size: 15px; font-weight: 500;
  letter-spacing: 0.01em;
  padding: 15px 26px; border-radius: 999px;
  border: 1px solid var(--ink);
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease),
              transform 240ms var(--ease), border-color var(--dur) var(--ease);
  will-change: transform;
}
.btn .arr { transition: transform 320ms var(--ease); }
.btn:hover .arr { transform: translateX(4px); }
.btn--primary { background: var(--ink); color: var(--paper); }
.btn--primary:hover { background: var(--ink-deep); transform: translateY(-2px); }
.btn--ghost { background: transparent; color: var(--ink); }
.btn--ghost:hover { background: var(--ink); color: var(--paper); transform: translateY(-2px); }
.section--ink .btn--primary { background: var(--paper); color: var(--ink); border-color: var(--paper); }
.section--ink .btn--ghost { color: var(--paper); border-color: var(--paper-line); }
.section--ink .btn--ghost:hover { background: var(--paper); color: var(--ink); }

.link-arrow {
  display: inline-flex; align-items: center; gap: 9px;
  font-size: 15px; font-weight: 500;
  border-bottom: 1px solid var(--line);
  padding-bottom: 3px;
  transition: border-color 320ms var(--ease), gap 320ms var(--ease);
}
.link-arrow:hover { border-color: var(--ink); gap: 13px; }

/* ---------- Wordmark / logo ---------- */
.wm {
  font-family: var(--serif);
  font-weight: 700;
  text-transform: lowercase;
  letter-spacing: 0.02em;
  padding-left: 0;
  line-height: 1;
  display: inline-block;
}
.logo-lockup { display: inline-flex; align-items: center; }
.logo-img { height: 56px; width: auto; display: block; }
.footer-brand .logo-img { height: 52px; }
.footer-brand .logo-img--tagline { height: 92px; }

/* =====================================================================
   Header
   ===================================================================== */
.site-header {
  position: fixed; inset: 0 0 auto 0; z-index: 1000;
  padding-block: 18px;
  transition: background var(--dur) var(--ease), box-shadow var(--dur) var(--ease),
              padding var(--dur) var(--ease), border-color var(--dur) var(--ease);
  border-bottom: 1px solid transparent;
}
.site-header .wrap { display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.site-header.scrolled {
  background: rgba(var(--c-paper-rgb),0.86);
  backdrop-filter: saturate(140%) blur(14px);
  -webkit-backdrop-filter: saturate(140%) blur(14px);
  border-bottom-color: var(--line);
  padding-block: 12px;
}
.nav { display: flex; align-items: center; gap: clamp(18px, 2vw, 34px); }
.nav a.nav-link {
  font-size: 14.5px; font-weight: 500; color: var(--ink);
  position: relative; padding-block: 6px;
}
.nav a.nav-link::after {
  content: ""; position: absolute; left: 0; bottom: 0; height: 1px; width: 0;
  background: var(--ink); transition: width 300ms var(--ease);
}
.nav a.nav-link:hover::after { width: 100%; }
.header-actions { display: flex; align-items: center; gap: 18px; }

/* Language switcher */
.lang-switch { display: inline-flex; align-items: center; gap: 2px; font-family: var(--mono); font-size: 12px; letter-spacing: 0.08em; }
.lang-switch a {
  display: inline-flex; align-items: center; justify-content: center;
  min-height: 44px; padding: 5px 9px; border-radius: 6px; color: var(--soft);
  transition: color 240ms var(--ease), background 240ms var(--ease);
}
.lang-switch a[aria-current="true"] { color: var(--ink); font-weight: 600; }
.lang-switch a:hover { background: var(--line-soft); color: var(--ink); }
.lang-switch .sep { color: var(--line); }

/* Mobile nav */
.nav-toggle { display: none; width: 44px; height: 44px; border: 0; background: transparent; position: relative; }
.nav-toggle span, .nav-toggle span::before, .nav-toggle span::after {
  content: ""; position: absolute; left: 10px; width: 24px; height: 1.6px; background: var(--ink);
  transition: transform 300ms var(--ease), opacity 200ms var(--ease);
}
.nav-toggle span { top: 21px; }
.nav-toggle span::before { top: -7px; } .nav-toggle span::after { top: 7px; }
body.nav-open .nav-toggle span { background: transparent; }
body.nav-open .nav-toggle span::before { transform: translateY(7px) rotate(45deg); }
body.nav-open .nav-toggle span::after { transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 980px) {
  .nav-toggle { display: block; z-index: 1100; }
  .nav {
    position: fixed; inset: 0; flex-direction: column; justify-content: center;
    gap: 28px; background: var(--paper); transform: translateX(100%);
    transition: transform 480ms var(--ease); padding: 80px var(--gutter);
  }
  body.nav-open .nav { transform: translateX(0); }
  .nav a.nav-link { font-size: 26px; font-family: var(--serif); font-weight: 400; }
  .nav .nav-cta-wrap { margin-top: 12px; }
  .header-actions .btn--primary { display: none; }
}

/* =====================================================================
   Hero
   ===================================================================== */
.hero { padding-top: clamp(110px, 14vh, 164px); padding-bottom: var(--section-y); position: relative; overflow: hidden; }
.hero__inner { position: relative; z-index: 2; display: grid; gap: clamp(30px, 4.5vw, 60px); align-items: center; }
@media (min-width: 900px){ .hero__inner { grid-template-columns: 1.02fr 0.98fr; } }
.hero__text { max-width: 38ch; }
.hero h1 { font-family: var(--serif); font-weight: 300; font-size: var(--fs-hero); line-height: 1.0; letter-spacing: -0.018em; margin-top: 22px; }
.hero h1 .serif-em { display: inline; }
.hero .lede { margin-top: 26px; max-width: 44ch; }
.hero .hero-cta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 34px; }

/* Hero photograph — unified warm grading, índigo veil, editorial frame */
.hero__media {
  position: relative; margin: 0; border-radius: var(--radius); overflow: hidden;
  aspect-ratio: 3 / 2.3; isolation: isolate;
  box-shadow: 0 30px 70px -38px rgba(var(--c-ink-rgb), 0.45);
}
.hero__media img { width: 100%; height: 100%; object-fit: cover; display: block; filter: saturate(0.9) contrast(1.03); }
.hero__media::after {
  content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none; mix-blend-mode: multiply;
  background: linear-gradient(180deg, rgba(var(--c-ink-rgb),0) 58%, rgba(var(--c-ink-rgb),0.20)),
              linear-gradient(115deg, rgba(var(--accent-rgb),0.16), transparent 60%);
}
.hero__media-weave { position: absolute; right: -7%; bottom: -7%; width: 40%; aspect-ratio: 1; color: var(--paper); opacity: 0.18; z-index: 2; pointer-events: none; }
@media (max-width: 900px){ .hero__media { aspect-ratio: 16 / 10; } }

/* ---------- Hero: portada en vídeo ---------- */
.hero--video { padding: 0; min-height: 100svh; display: flex; color: var(--paper); }
.hero--video .hero__bg { position: absolute; inset: 0; z-index: 0; background: var(--ink); overflow: hidden; }
.hero__bg--m { display: none; }
@media (max-width: 980px) { .hero__bg--d { display: none; } .hero__bg--m { display: block; } }
.hero__vid { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: 0; transition: opacity 1.4s var(--ease); will-change: opacity; }
.hero__vid.is-active { opacity: 1; }
.hero__scrim { position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    linear-gradient(to top, rgba(18,17,15,0.74) 0%, rgba(18,17,15,0.30) 30%, rgba(18,17,15,0) 56%),
    linear-gradient(to right, rgba(18,17,15,0.42) 0%, rgba(18,17,15,0) 52%); }
.hero--video .hero__inner { position: relative; z-index: 2; align-self: flex-end; width: 100%;
  display: grid; gap: 22px; align-items: end;
  padding-top: clamp(120px, 18vh, 200px); padding-bottom: clamp(46px, 8vh, 92px); }
@media (min-width: 900px){ .hero--video .hero__inner { grid-template-columns: minmax(0,1fr) auto; } }
.hero--video .hero__text { max-width: 54ch; align-self: end;
  padding: clamp(26px, 3vw, 40px) clamp(26px, 3vw, 44px); border-radius: 22px; }
.hero--video .hero__text.liquid-glass { background: rgba(15,14,12,0.12);
  backdrop-filter: blur(4px) saturate(112%); -webkit-backdrop-filter: blur(4px) saturate(112%); }
.hero--video .kicker, .hero--video .hero__title, .hero--video .lede { text-shadow: 0 1px 18px rgba(10,9,8,0.35); }
.hero--video .kicker { color: rgba(var(--c-paper-rgb), 0.82); }
.hero--video .kicker::before { background: rgba(var(--c-paper-rgb), 0.7); }
.hero--video .hero__title { font-family: var(--serif); font-weight: 300; font-size: var(--fs-hero); line-height: 1.0; letter-spacing: -0.018em; color: var(--paper); margin: 0; }
.hero--video .hero__title .serif-em { display: inline; color: var(--accent-soft); }
.hero--video .lede { margin-top: 24px; max-width: 62ch; color: rgba(var(--c-paper-rgb), 0.92); }
.hero--video .hero-cta { margin-top: 32px; }
.hero--video .btn--primary { background: var(--paper); color: var(--ink); }
.hero--video .btn--primary:hover { background: rgba(var(--c-paper-rgb), 0.88); }
.hero--video .hero__tag { align-self: end; justify-self: start; padding: 12px 20px; border-radius: 14px;
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--paper); }
@media (min-width: 900px){ .hero--video .hero__tag { justify-self: end; } }
@media (max-width: 760px){
  /* En móvil se sirven clips verticales (9:16) que llenan la pantalla sin recorte
     lateral; el hero mantiene altura completa. */
  .hero--video .lede { margin-top: 18px; }
  .hero--video .hero__text { padding: clamp(22px, 5vw, 30px) clamp(20px, 5vw, 28px); }
}

/* char-by-char entrance del titular */
.hero__title .word { display: inline-block; }
.hero__title .char { display: inline-block; opacity: 0; transform: translateX(-14px);
  transition: opacity .5s var(--ease), transform .5s var(--ease); }
.hero__title.is-in .char { opacity: 1; transform: none; }

/* Liquid glass */
.liquid-glass { position: relative; overflow: hidden; background: rgba(18,17,15,0.34);
  backdrop-filter: blur(6px) saturate(130%); -webkit-backdrop-filter: blur(6px) saturate(130%);
  box-shadow: inset 0 1px 1px rgba(255,255,255,0.10); }
.liquid-glass::before { content: ""; position: absolute; inset: 0; border-radius: inherit; padding: 1.2px;
  background: linear-gradient(180deg, rgba(255,255,255,0.35) 0%, rgba(255,255,255,0.10) 22%, rgba(255,255,255,0) 45%,
    rgba(255,255,255,0) 60%, rgba(255,255,255,0.10) 80%, rgba(255,255,255,0.30) 100%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude; pointer-events: none; }
.btn--glass { color: var(--paper); border: 1px solid rgba(var(--c-paper-rgb), 0.30);
  background: rgba(18,17,15,0.28); backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease); }
.btn--glass:hover { background: var(--paper); color: var(--ink); border-color: var(--paper); }

/* Header claro mientras flota sobre la portada en vídeo */
.site-header.over-hero .logo-img { filter: brightness(0) invert(1); }
.site-header.over-hero .nav a.nav-link { color: rgba(var(--c-paper-rgb), 0.90); }
.site-header.over-hero .nav a.nav-link::after { background: var(--paper); }
.site-header.over-hero .lang-switch a { color: rgba(var(--c-paper-rgb), 0.66); }
.site-header.over-hero .lang-switch a[aria-current="true"] { color: var(--paper); }
.site-header.over-hero .lang-switch a:hover { color: var(--paper); background: rgba(var(--c-paper-rgb), 0.14); }
.site-header.over-hero .lang-switch .sep { color: rgba(var(--c-paper-rgb), 0.34); }
.site-header.over-hero .nav-toggle span,
.site-header.over-hero .nav-toggle span::before,
.site-header.over-hero .nav-toggle span::after { background: var(--paper); }
.site-header.over-hero .btn--primary { background: var(--paper); color: var(--ink); }
@media (prefers-reduced-motion: reduce){
  .hero__vid { transition: none; }
  .hero__title .char { opacity: 1; transform: none; transition: none; }
}

/* =====================================================================
   Trust bar / stats
   ===================================================================== */
.trustbar { border-block: 1px solid var(--line); background: var(--linen); }
.trustbar .wrap { display: grid; gap: clamp(28px, 4vw, 56px); padding-block: clamp(40px, 6vh, 72px); }
.trustbar .trust-line { font-family: var(--serif); font-size: clamp(18px, 1.7vw, 25px); font-weight: 400; line-height: 1.3; max-width: 32ch; }
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(20px, 3vw, 48px); }
.stat { border-top: 2px solid var(--ink); padding-top: 18px; }
.stat .num { font-family: var(--serif); font-weight: 300; font-size: clamp(30px, 3.2vw, 46px); line-height: 1; letter-spacing: -0.01em; font-variant-numeric: lining-nums; display: flex; align-items: flex-end; min-height: clamp(30px, 3.2vw, 46px); }
.stat .num.is-word { font-size: clamp(19px, 1.8vw, 25px); letter-spacing: 0; line-height: 1.05; }
.stat .label { font-family: var(--mono); font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--soft); margin-top: 12px; line-height: 1.45; }
@media (max-width: 760px){ .stats { grid-template-columns: repeat(2, 1fr); } }

/* =====================================================================
   Manifesto
   ===================================================================== */
.manifesto .wrap { display: grid; grid-template-columns: minmax(0, 1fr); gap: 40px; }
.manifesto .h-section { max-width: 16ch; }
.manifesto__body { font-family: var(--serif); font-weight: 300; font-size: clamp(20px, 1.9vw, 28px); line-height: 1.34; max-width: 30em; color: var(--ink); }
.manifesto__body .promise { font-style: italic; }
@media (min-width: 900px){
  .manifesto .wrap { grid-template-columns: 0.72fr 1.28fr; align-items: center; }
}

/* =====================================================================
   Section heads
   ===================================================================== */
.section-head { display: grid; gap: 18px; margin-bottom: clamp(40px, 6vh, 72px); max-width: 760px; }
.section-head.center { margin-inline: auto; text-align: center; justify-items: center; }

/* =====================================================================
   Services
   ===================================================================== */
.services-grid { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
@media (max-width: 900px) { .services-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .services-grid { grid-template-columns: 1fr; } }
.svc-card {
  border-right: 1px solid var(--line); border-bottom: 1px solid var(--line);
  padding: clamp(18px, 1.9vw, 26px); display: flex; flex-direction: column; gap: 11px;
  min-height: 0; position: relative; transition: background 420ms var(--ease);
}
.svc-card .svc-icon { width: 32px; height: 32px; margin-bottom: 2px; }
.svc-card:hover { background: var(--linen); }
.svc-card--cta { background: var(--ink); color: var(--paper); }
.svc-card--cta:hover { background: var(--ink-deep); }
.svc-card.svc-card--cta .svc-index { color: rgba(var(--c-paper-rgb),0.6); }
.svc-card--cta h3 { color: var(--paper); }
.svc-card.svc-card--cta p { color: rgba(var(--c-paper-rgb),0.8); }
.svc-card--cta .link-arrow { margin-top: auto; align-self: flex-start; color: var(--paper); border-bottom-color: var(--paper-line); }
.svc-card--cta .link-arrow:hover { border-bottom-color: var(--paper); }
/* CTA glass button inside the dark services box */
.svc-card--cta .svc-cta-btn {
  display: inline-flex; align-items: center; gap: 9px; align-self: flex-start; margin-top: auto;
  padding: 13px 28px; border-radius: 999px; cursor: pointer;
  font-family: inherit; font-size: 14px; font-weight: 500; letter-spacing: 0.01em; color: var(--paper);
  background: rgba(var(--c-paper-rgb), 0.10);
  border: 1px solid rgba(var(--c-paper-rgb), 0.45);
  backdrop-filter: blur(7px) saturate(130%); -webkit-backdrop-filter: blur(7px) saturate(130%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.16), 0 8px 26px rgba(0,0,0,0.30);
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.svc-card--cta .svc-cta-btn .arr { transition: transform var(--dur) var(--ease); }
.svc-card--cta:hover .svc-cta-btn { background: var(--paper); color: var(--ink); border-color: var(--paper); box-shadow: 0 12px 32px rgba(0,0,0,0.34); }
.svc-card--cta:hover .svc-cta-btn .arr { transform: translateX(4px); }
.svc-card .svc-index { font-family: var(--mono); font-size: 12px; letter-spacing: 0.16em; color: var(--soft); }
.svc-card .svc-icon { width: 40px; height: 40px; color: var(--accent); margin-bottom: 6px; }
.svc-card h3 { font-family: var(--serif); font-size: clamp(20px, 1.6vw, 25px); font-weight: 400; line-height: 1.05; }
.svc-card p { color: rgba(var(--c-ink-rgb),0.74); font-size: 16px; line-height: 1.6; margin: 0; }

/* =====================================================================
   Sectors
   ===================================================================== */
.sectors-grid { display: grid; gap: clamp(20px, 2.4vw, 32px); grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); }
.sector-card {
  background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius);
  display: flex; flex-direction: column;
  transition: transform 480ms var(--ease), box-shadow 480ms var(--ease);
  position: relative; overflow: hidden;
}
.sector-card__media { margin: 0; aspect-ratio: 3 / 2; overflow: hidden; position: relative; isolation: isolate; }
.sector-card__media img { width: 100%; height: 100%; object-fit: cover; display: block; filter: saturate(0.9) contrast(1.03); transition: transform 640ms var(--ease); }
.sector-card:hover .sector-card__media img { transform: scale(1.04); }
.sector-card__media::after { content: ""; position: absolute; inset: 0; pointer-events: none; mix-blend-mode: multiply;
  background: linear-gradient(160deg, rgba(var(--accent-rgb),0.12), transparent 55%), linear-gradient(0deg, rgba(var(--c-ink-rgb),0.14), transparent 42%); }
.sector-card__body { padding: clamp(22px, 2.2vw, 34px); display: flex; flex-direction: column; gap: 15px; flex: 1; }
.sector-card:hover { transform: translateY(-6px); box-shadow: 0 30px 60px -30px rgba(var(--c-ink-rgb),0.28); }
.sector-card .sector-tag { font-family: var(--mono); font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--sage-deep); }
.sector-card h3 { font-family: var(--serif); font-size: clamp(22px, 1.9vw, 28px); font-weight: 400; line-height: 1; }
.sector-card p { color: rgba(var(--c-ink-rgb),0.74); font-size: 16px; margin: 0; }
.sector-items { display: flex; flex-wrap: wrap; gap: 8px; margin-top: auto; padding-top: 14px; border-top: 1px solid var(--line-soft); }
.sector-items li { font-size: 13px; font-family: var(--mono); letter-spacing: 0.02em; color: var(--soft); background: var(--linen); padding: 6px 12px; border-radius: 999px; }

/* =====================================================================
   Process
   ===================================================================== */
/* Proceso — infografía de flujo conectado */
.flow { list-style: none; margin: clamp(34px, 4.5vw, 56px) 0 0; padding: 0;
  display: grid; grid-template-columns: repeat(5, 1fr); }
.flow-step { position: relative; display: flex; flex-direction: column; align-items: center;
  text-align: center; gap: 13px; padding: 0 clamp(8px, 1vw, 16px); }
/* conector horizontal entre nodos */
.flow-step::before { content: ""; position: absolute; top: 26px; right: 50%; width: 100%; height: 2px;
  background: var(--line); z-index: 0; }
.flow-step:first-child::before { display: none; }
.flow-node { position: relative; z-index: 1; width: 52px; height: 52px; border-radius: 50%;
  background: var(--paper); border: 1.5px solid var(--accent); display: grid; place-items: center; }
.flow-num { font-family: var(--serif); font-size: 19px; font-weight: 400; color: var(--accent); line-height: 1; }
.flow-icon { width: 30px; height: 30px; color: var(--accent); }
.flow-card { display: flex; flex-direction: column; align-items: center; gap: 7px; }
.flow-card h3 { font-family: var(--serif); font-weight: 400; font-size: clamp(17px, 1.4vw, 21px); line-height: 1.1; text-wrap: balance; }
.flow-card p { color: rgba(var(--c-ink-rgb),0.72); font-size: 14.5px; line-height: 1.55; margin: 0; max-width: 30ch; }
@media (max-width: 860px) {
  .flow { grid-template-columns: 1fr; }
  .flow-step { flex-direction: row; text-align: left; align-items: flex-start; gap: 18px;
    padding: 0 0 clamp(22px, 3vw, 30px); }
  .flow-step::before { top: 0; right: auto; left: 25px; width: 2px; height: 100%; }
  .flow-step:first-child::before { display: block; }
  .flow-step:last-child::before { display: none; }
  .flow-node { flex: 0 0 auto; }
  .flow-card { align-items: flex-start; gap: 6px; }
  .flow-card p { max-width: none; text-align: left; }
}

/* =====================================================================
   Why VELUM
   ===================================================================== */
.why-grid { display: grid; gap: 2px; background: var(--paper-line); grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
.why-cell { background: var(--ink); padding: clamp(26px, 2.6vw, 40px); display: flex; flex-direction: column; gap: 12px; min-height: 140px; }
.why-cell .why-num { font-family: var(--mono); font-size: 12px; letter-spacing: 0.16em; color: rgba(var(--c-paper-rgb),0.5); }
.why-cell h3 { font-family: var(--serif); font-size: clamp(20px, 1.6vw, 25px); font-weight: 400; color: var(--paper); line-height: 1.1; transition: color 320ms var(--ease); }
.why-cell p { color: rgba(var(--c-paper-rgb),0.72); font-size: 16px; margin: 0; }
/* En escritorio (con ratón): por defecto solo el título; al pasar el cursor se
   despliega la descripción. En táctil/móvil se muestra todo (no hay hover). */
@media (hover: hover) and (pointer: fine) {
  .why-cell { cursor: default; }
  .why-cell p {
    max-height: 0; opacity: 0; overflow: hidden;
    transition: max-height 560ms var(--ease), opacity 380ms var(--ease);
  }
  .why-cell h3::after {
    content: "+"; margin-left: 8px; font-family: var(--mono); font-size: 0.7em;
    color: var(--accent-soft); opacity: 0.7; transition: opacity 320ms var(--ease), transform 320ms var(--ease);
    display: inline-block; vertical-align: middle;
  }
  .why-cell:hover h3, .why-cell:focus-within h3 { color: var(--accent-soft); }
  .why-cell:hover h3::after, .why-cell:focus-within h3::after { opacity: 0; transform: rotate(45deg); }
  .why-cell:hover p, .why-cell:focus-within p { max-height: 28em; opacity: 1; }
}

/* =====================================================================
   Manager / split feature
   ===================================================================== */
.split { display: grid; gap: clamp(36px, 5vw, 80px); align-items: center; }
@media (min-width: 900px){ .split { grid-template-columns: 1.05fr 0.95fr; } }
.split__visual {
  margin: 0; aspect-ratio: 4/3.4; border-radius: var(--radius);
  position: relative; overflow: hidden; isolation: isolate;
  box-shadow: 0 30px 70px -40px rgba(var(--c-ink-rgb), 0.4);
}
.split__visual img { width: 100%; height: 100%; object-fit: cover; display: block; filter: saturate(0.9) contrast(1.03); }
.split__visual::after { content: ""; position: absolute; inset: 0; pointer-events: none; mix-blend-mode: multiply;
  background: linear-gradient(160deg, rgba(var(--accent-rgb),0.14), transparent 58%), linear-gradient(0deg, rgba(var(--c-ink-rgb),0.16), transparent 45%); }
.split__visual .badge {
  position: absolute; left: 18px; top: 18px; z-index: 2; font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--paper);
  background: rgba(var(--c-ink-rgb), 0.55); backdrop-filter: blur(6px);
  padding: 7px 12px; border-radius: 999px;
}

/* Gallery carousel — sector tabs + horizontal scroll-snap */
.car-head { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: flex-end; gap: 20px; margin-bottom: clamp(24px, 4vh, 40px); }
.car-head .h-mid { font-family: var(--serif); font-weight: 400; }
.car-tabs { display: flex; flex-wrap: wrap; gap: 8px; }
.car-tab { font-family: var(--mono); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--soft); background: transparent; border: 1px solid var(--line); border-radius: 999px; padding: 9px 16px; min-height: 40px; transition: color 240ms var(--ease), background 240ms var(--ease), border-color 240ms var(--ease); }
.car-tab:hover { color: var(--ink); border-color: var(--soft); }
.car-tab.is-active { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.car-track { display: none; gap: clamp(12px, 1.5vw, 20px); grid-auto-flow: column; grid-auto-columns: minmax(260px, 31.5%); overflow-x: auto; scroll-snap-type: x mandatory; padding-bottom: 10px; -webkit-overflow-scrolling: touch; scrollbar-width: thin; }
.car-track.is-active { display: grid; }
@media (max-width: 760px){ .car-track { grid-auto-columns: minmax(78%, 80%); } }
.car-track::-webkit-scrollbar { height: 6px; }
.car-track::-webkit-scrollbar-thumb { background: var(--line); border-radius: 3px; }
.car-slide { margin: 0; scroll-snap-align: start; border-radius: var(--radius); overflow: hidden; position: relative; isolation: isolate; aspect-ratio: 4 / 3; }
.car-slide img { width: 100%; height: 100%; object-fit: cover; display: block; filter: saturate(0.9) contrast(1.03); transition: transform 640ms var(--ease); }
.car-slide:hover img { transform: scale(1.04); }
.car-slide::after { content: ""; position: absolute; inset: 0; pointer-events: none; mix-blend-mode: multiply;
  background: linear-gradient(150deg, rgba(var(--accent-rgb),0.10), transparent 60%); }
@media (prefers-reduced-motion: reduce){ .car-slide img { transition: none; } }

/* =====================================================================
   Sustainability
   ===================================================================== */
.sust-claims { display: grid; gap: 0; margin-top: 36px; }
.sust-claim { display: flex; gap: 18px; align-items: baseline; padding-block: 18px; border-top: 1px solid var(--paper-line); }
.sust-claim:last-child { border-bottom: 1px solid var(--paper-line); }
.sust-claim .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--sage); flex: none; transform: translateY(8px); }
.sust-claim p { margin: 0; font-size: clamp(16px, 1.3vw, 18px); color: rgba(var(--c-paper-rgb),0.86); }

/* Credential strip (standards) inside the dark Sustainability section */
.cred-strip { margin-top: clamp(36px, 5vh, 56px); padding-top: clamp(28px, 4vh, 40px); border-top: 1px solid var(--paper-line); }
.cred-strip__label { font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(var(--c-paper-rgb),0.5); }
.cred-list { display: flex; flex-wrap: wrap; gap: 10px 12px; margin-top: 16px; }
.cred-list li { font-family: var(--mono); font-size: 13px; letter-spacing: 0.04em; color: var(--paper); border: 1px solid var(--paper-line); border-radius: 999px; padding: 8px 16px; }
.cred-note { margin: 18px 0 0; font-size: 12.5px; color: rgba(var(--c-paper-rgb),0.5); max-width: 80ch; }

/* =====================================================================
   Coverage
   ===================================================================== */
.coverage .wrap { display: grid; gap: clamp(36px, 5vw, 72px); align-items: center; }
@media (min-width: 900px){ .coverage .wrap { grid-template-columns: 1fr 1fr; } }
.coverage__map { position: relative; }
.coverage__legend { display: flex; gap: 28px; margin-top: 24px; flex-wrap: wrap; }
.coverage__legend .item { display: inline-flex; align-items: center; gap: 10px; font-size: 14px; font-family: var(--mono); letter-spacing: 0.04em; }
.coverage__legend .swatch { width: 14px; height: 14px; border-radius: 3px; }
.swatch--now { background: var(--accent); }
.swatch--soon { background: var(--mist); border: 1px solid var(--soft); }
.swatch--plant { background: var(--accent); border-radius: 50%; }
.swatch--ally { background: var(--paper); border: 1.6px solid var(--accent); border-radius: 50%; }

/* ---------- Nuestros productos ---------- */
.products-grid { display: grid; gap: 1px; background: var(--line); border: 1px solid var(--line); margin-top: clamp(28px, 4vw, 48px); grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
.product-card { background: var(--paper); padding: clamp(26px, 2.6vw, 40px); display: flex; flex-direction: column; gap: 12px; }
.product-tag { font-family: var(--mono); font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--sage-deep); }
.product-card h3 { font-family: var(--serif); font-weight: 400; font-size: clamp(20px, 1.7vw, 26px); line-height: 1.08; }
.product-list { list-style: none; padding: 0; margin: 4px 0 0; display: flex; flex-direction: column; gap: 9px; }
.product-list li { position: relative; padding-left: 18px; font-size: 15px; color: rgba(var(--c-ink-rgb),0.78); line-height: 1.45; }
.product-list li::before { content: ""; position: absolute; left: 0; top: 11px; width: 9px; height: 1px; background: var(--sage-deep); }
.product-foot { margin-top: clamp(20px, 2.4vw, 32px); font-size: 14px; color: var(--soft); max-width: 72ch; }

/* ---------- Mobile dock (app-style bottom nav) ---------- */
.mobile-dock { display: none; }
@media (max-width: 980px) {
  .site-header .nav-toggle { display: none; }
  body { padding-bottom: 124px; }
  .to-top { bottom: 120px; }
  /* En móvil el dock flotante ya lleva el CTA y la navegación: quitamos los
     botones y el tag del hero (evita duplicar «Pedir presupuesto» y el solape). */
  .hero--video .hero-cta, .hero--video .hero__tag { display: none; }
  .hero--video .hero__inner { padding-bottom: 128px; }
  .mobile-dock { display: flex; flex-direction: column; align-items: center; gap: 10px;
    position: fixed; left: 0; right: 0; bottom: 6px; z-index: 1150; pointer-events: none; }
  .mobile-dock > * { pointer-events: auto; }
  .dock-bar { display: flex; align-items: center; gap: 2px; padding: 7px; border-radius: 22px;
    max-width: calc(100vw - 20px);
    background: rgba(18,17,15,0.92); backdrop-filter: blur(16px) saturate(140%);
    -webkit-backdrop-filter: blur(16px) saturate(140%);
    box-shadow: 0 12px 40px rgba(0,0,0,0.38), inset 0 1px 0 rgba(255,255,255,0.06); }
  .dock-item { position: relative; width: 46px; height: 46px; flex: none; display: inline-flex;
    align-items: center; justify-content: center; border-radius: 14px;
    color: rgba(var(--c-paper-rgb),0.62);
    transition: color var(--dur) var(--ease), background var(--dur) var(--ease); }
  .dock-item svg { width: 23px; height: 23px; }
  .dock-item:active { background: rgba(var(--c-paper-rgb),0.06); }
  .dock-item.is-active { color: var(--accent-soft); background: rgba(var(--c-paper-rgb),0.08); }
  .dock-dot { display: none; }
  .dock-item.is-active .dock-dot { display: block; position: absolute; bottom: 6px; left: 50%;
    transform: translateX(-50%); width: 4px; height: 4px; border-radius: 50%; background: var(--accent-soft); }
  .dock-item.is-active::after { content: attr(data-label); position: absolute; bottom: calc(100% + 12px);
    left: 50%; transform: translateX(-50%); background: rgba(18,17,15,0.96); color: var(--paper);
    font-family: var(--mono); font-size: 12px; letter-spacing: 0.04em; padding: 7px 12px; border-radius: 9px;
    white-space: nowrap; pointer-events: none; box-shadow: 0 6px 20px rgba(0,0,0,0.3); }
  .dock-item.is-active::before { content: ""; position: absolute; bottom: calc(100% + 5px); left: 50%;
    transform: translateX(-50%); border: 6px solid transparent; border-top-color: rgba(18,17,15,0.96); pointer-events: none; }
  .dock-sep { width: 1px; height: 26px; background: rgba(var(--c-paper-rgb),0.16); margin: 0 5px; flex: none; }
  .dock-cta { font-family: inherit; font-size: 13px; font-weight: 500; letter-spacing: 0.02em; color: var(--paper);
    padding: 9px 22px; border-radius: 999px; background: rgba(18,17,15,0.72);
    border: 1px solid rgba(var(--c-paper-rgb),0.22); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); }
  .dock-cta:hover { background: var(--paper); color: var(--ink); }
}
@media (prefers-reduced-motion: reduce) { .dock-item { transition: none; } }

/* =====================================================================
   Standards — sober credentials band (light surface)
   ===================================================================== */
.standards__head { display: grid; gap: 16px; max-width: 760px; margin-bottom: clamp(32px, 5vh, 56px); }
.standards__grid { display: grid; gap: 0; border-top: 1px solid var(--line); grid-template-columns: 1fr; margin: 0; }
.std-item { display: grid; gap: 6px; grid-template-columns: 1fr; padding-block: clamp(16px, 2.2vh, 24px); border-bottom: 1px solid var(--line); }
@media (min-width: 760px) { .std-item { grid-template-columns: 220px 1fr; gap: clamp(20px, 3vw, 44px); align-items: baseline; } }
.std-code { font-family: var(--mono); font-size: 14px; letter-spacing: 0.08em; color: var(--accent); font-weight: 500; }
.std-desc { margin: 0; color: rgba(var(--c-ink-rgb), 0.74); font-size: 16px; line-height: 1.55; max-width: 60ch; }
.standards__note { margin-top: 22px; font-size: 12.5px; color: var(--soft); max-width: 80ch; }

/* =====================================================================
   FAQ
   ===================================================================== */
.faq-list { border-top: 1px solid var(--line); max-width: 920px; }
.faq-item { border-bottom: 1px solid var(--line); }
.faq-q {
  width: 100%; text-align: left; background: transparent; border: 0; padding: 26px 48px 26px 0;
  font-family: var(--serif); font-size: clamp(18px, 1.5vw, 22px); font-weight: 400; position: relative; color: var(--ink);
}
.faq-q::after {
  content: ""; position: absolute; right: 6px; top: 50%; width: 14px; height: 14px;
  background: no-repeat center/contain;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14'%3E%3Cpath d='M7 0v14M0 7h14' stroke='%23211F1B' stroke-width='1.4'/%3E%3C/svg%3E");
  transform: translateY(-50%) rotate(0); transition: transform 360ms var(--ease);
}
.faq-item[open] .faq-q::after { transform: translateY(-50%) rotate(45deg); }
.faq-a { padding: 0 48px 28px 0; color: rgba(var(--c-ink-rgb),0.76); max-width: 64ch; }
.faq-q::-webkit-details-marker { display: none; }

/* =====================================================================
   Final CTA + form
   ===================================================================== */
.cta-final { background: var(--ink); color: var(--paper); }
.cta-final .h-section { max-width: 18ch; }
.contact-grid { display: grid; gap: clamp(36px, 5vw, 72px); }
@media (min-width: 920px){ .contact-grid { grid-template-columns: 0.85fr 1.15fr; align-items: start; } }

.form { display: grid; gap: 20px; }
.form .row { display: grid; gap: 20px; }
@media (min-width: 620px){ .form .row.two { grid-template-columns: 1fr 1fr; } }
.field { display: flex; flex-direction: column; gap: 8px; }
.field label { font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(var(--c-paper-rgb),0.85); }
.field input, .field select, .field textarea {
  font: inherit; font-size: 16px; color: var(--paper); background: transparent;
  border: 0; border-bottom: 1px solid var(--paper-line); padding: 10px 2px;
  border-radius: 0; transition: border-color 300ms var(--ease);
}
.field textarea { resize: vertical; min-height: 92px; }
.field input::placeholder, .field textarea::placeholder { color: rgba(var(--c-paper-rgb),0.66); }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-bottom-color: var(--paper); }
.field select { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23FBFAF6' stroke-width='1.3' fill='none'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 4px center; background-size: 12px; }
.field select option { color: var(--ink); }
.consent { display: flex; gap: 12px; align-items: flex-start; font-size: 13.5px; color: rgba(var(--c-paper-rgb),0.84); line-height: 1.5; }
.consent input { margin-top: 4px; accent-color: var(--sage); flex: none; }
.consent a { text-decoration: underline; text-underline-offset: 2px; }
.form-success { display: none; padding: 18px 0; font-family: var(--serif); font-size: 22px; color: var(--sage); }
.form.sent .form-grid { display: none; }
.form.sent .form-success { display: block; }

/* =====================================================================
   Footer
   ===================================================================== */
.site-footer { background: var(--ink); color: var(--paper); padding-top: clamp(56px, 8vh, 96px); padding-bottom: 36px; }
.footer-top { display: grid; gap: clamp(36px, 5vw, 64px); padding-bottom: clamp(48px, 7vh, 80px); border-bottom: 1px solid var(--paper-line); }
@media (min-width: 880px){ .footer-top { grid-template-columns: 1.4fr 1fr 1fr 1fr; } }
.footer-brand .wm { font-size: 30px; color: var(--paper); }
.footer-brand p { color: rgba(var(--c-paper-rgb),0.62); font-size: 15px; max-width: 36ch; margin: 20px 0 0; }
.footer-col h4 { font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(var(--c-paper-rgb),0.5); margin-bottom: 18px; }
.footer-col a { display: block; color: rgba(var(--c-paper-rgb),0.78); font-size: 15px; padding-block: 7px; transition: color 240ms var(--ease); }
.footer-col a:hover { color: var(--paper); }
.footer-bottom { display: flex; flex-wrap: wrap; gap: 18px 32px; justify-content: space-between; align-items: center; padding-top: 28px; }
.footer-bottom .legal-links { display: flex; flex-wrap: wrap; gap: 22px; }
.footer-bottom a, .footer-bottom span { font-size: 13px; color: rgba(var(--c-paper-rgb),0.55); }
.footer-bottom a:hover { color: var(--paper); }
.footer-tagline { font-family: var(--mono); font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase; color: rgba(var(--c-paper-rgb),0.5); }

/* =====================================================================
   Cookie banner
   ===================================================================== */
.cookie-banner {
  position: fixed; left: 50%; bottom: 22px; transform: translate(-50%, 140%);
  z-index: 1200; width: min(960px, calc(100vw - 32px));
  background: var(--ink); color: var(--paper); border-radius: 14px;
  padding: 22px 26px; display: grid; gap: 18px; align-items: center;
  box-shadow: 0 24px 60px -20px rgba(0,0,0,0.5);
  transition: transform 560ms var(--ease); border: 1px solid var(--paper-line);
}
.cookie-banner[data-show] { transform: translate(-50%, 0); }
.cookie-banner p { margin: 0; font-size: 14px; line-height: 1.55; color: rgba(var(--c-paper-rgb),0.8); }
.cookie-banner p a { text-decoration: underline; text-underline-offset: 2px; }
.cookie-actions { display: flex; flex-wrap: wrap; gap: 10px; }
.cookie-actions .btn { padding: 11px 20px; font-size: 14px; }
.cookie-actions .btn--mini-ghost { border-color: var(--paper-line); color: var(--paper); background: transparent; }
.cookie-actions .btn--mini-ghost:hover { background: var(--paper-line); }
@media (min-width: 760px){ .cookie-banner { grid-template-columns: 1fr auto; } }

/* =====================================================================
   Cookie preferences panel (CMP)
   ===================================================================== */
.cookie-panel[hidden] { display: none; }
.cookie-panel {
  position: fixed; inset: 0; z-index: 1300;
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
}
.cookie-panel__backdrop {
  position: absolute; inset: 0; background: rgba(0,0,0,0.5);
  opacity: 0; transition: opacity 320ms var(--ease);
}
.cookie-panel.is-open .cookie-panel__backdrop { opacity: 1; }
.cookie-panel__box {
  position: relative; z-index: 1; width: 100%; max-width: 520px;
  max-height: calc(100vh - 40px); overflow-y: auto;
  background: var(--paper); color: var(--ink); border: 1px solid var(--line);
  border-radius: 14px; padding: clamp(24px, 4vw, 36px);
  box-shadow: 0 30px 70px -24px rgba(0,0,0,0.45);
  transform: translateY(12px) scale(0.98); opacity: 0;
  transition: transform 380ms var(--ease), opacity 320ms var(--ease);
}
.cookie-panel.is-open .cookie-panel__box { transform: none; opacity: 1; }
.cookie-panel__box h2 { font-size: clamp(20px, 3vw, 26px); margin: 0 44px 10px 0; }
.cookie-panel__intro { margin: 0 0 8px; font-size: 14.5px; line-height: 1.6; color: var(--soft); }
.cookie-panel__close {
  position: absolute; top: 14px; right: 14px;
  width: 38px; height: 38px; display: inline-flex; align-items: center; justify-content: center;
  font-size: 24px; line-height: 1; background: transparent; color: var(--ink);
  border: 1px solid var(--line); border-radius: 999px; cursor: pointer;
  transition: background 240ms var(--ease), border-color 240ms var(--ease);
}
.cookie-panel__close:hover { background: var(--linen); border-color: var(--ink); }

.cookie-cat { padding: 18px 0; border-top: 1px solid var(--line); }
.cookie-cat:last-of-type { border-bottom: 1px solid var(--line); }
.cookie-cat__head { display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.cookie-cat__name { font-size: 15.5px; font-weight: 600; color: var(--ink); }
.cookie-cat__tag {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--soft);
}
.cookie-cat p { margin: 8px 0 0; font-size: 13.5px; line-height: 1.55; color: var(--soft); }

.cookie-panel__actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 24px; }
.cookie-panel__actions .btn { padding: 11px 20px; font-size: 14px; }
.cookie-panel__actions .btn--mini-ghost {
  border-color: var(--line); color: var(--ink); background: transparent;
}
.cookie-panel__actions .btn--mini-ghost:hover { background: var(--linen); border-color: var(--ink); }

/* ---------- Accessible switch ---------- */
.cookie-switch { position: relative; display: inline-flex; flex: none; width: 48px; height: 28px; }
.cookie-switch input {
  /* Hidden visually but kept accessible (focusable, in the a11y tree). */
  position: absolute; inset: 0; margin: 0; width: 100%; height: 100%;
  opacity: 0; cursor: pointer; z-index: 2;
}
.cookie-switch__track {
  position: absolute; inset: 0; border-radius: 999px;
  background: var(--line); border: 1px solid var(--line);
  transition: background 240ms var(--ease), border-color 240ms var(--ease);
}
.cookie-switch__track::after {
  content: ""; position: absolute; top: 3px; left: 3px;
  width: 20px; height: 20px; border-radius: 50%; background: var(--paper);
  box-shadow: 0 1px 3px rgba(0,0,0,0.25);
  transition: transform 240ms var(--ease);
}
.cookie-switch input:checked + .cookie-switch__track {
  background: var(--accent); border-color: var(--accent);
}
.cookie-switch input:checked + .cookie-switch__track::after { transform: translateX(20px); }
.cookie-switch input:focus-visible + .cookie-switch__track {
  outline: 2px solid var(--ink); outline-offset: 3px;
}

@media (prefers-reduced-motion: reduce) {
  .cookie-panel__backdrop,
  .cookie-panel__box,
  .cookie-switch__track,
  .cookie-switch__track::after { transition: none; }
}

@media (max-width: 560px) {
  .cookie-panel { padding: 0; }
  .cookie-panel__box {
    max-width: none; width: 100%; min-height: 100vh; max-height: 100vh;
    border-radius: 0; border: 0;
  }
  .cookie-panel__actions .btn { flex: 1 1 auto; justify-content: center; }
}

/* =====================================================================
   Legal / content pages
   ===================================================================== */
.legal-hero { padding-top: clamp(150px, 22vh, 240px); padding-bottom: clamp(40px, 6vh, 72px); background: var(--linen); border-bottom: 1px solid var(--line); }
.legal-body { padding-block: clamp(56px, 8vh, 96px); }
.legal-body .wrap { max-width: 820px; }
.legal-body h2 { font-family: var(--serif); font-size: clamp(21px, 1.9vw, 27px); font-weight: 400; margin-top: 52px; margin-bottom: 18px; }
.legal-body h3 { font-family: var(--sans); font-size: 18px; font-weight: 600; margin-top: 32px; margin-bottom: 10px; }
.legal-body p, .legal-body li { color: rgba(var(--c-ink-rgb),0.8); font-size: 16.5px; line-height: 1.7; }
.legal-body ul { list-style: disc; padding-left: 22px; margin: 12px 0; display: grid; gap: 8px; }
.legal-body a { text-decoration: underline; text-underline-offset: 2px; }
.legal-body table { border-collapse: collapse; width: 100%; margin: 20px 0; font-size: 14px; }
.legal-body th, .legal-body td { border: 1px solid var(--line); padding: 10px 12px; text-align: left; vertical-align: top; }
.legal-body th { background: var(--linen); font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; font-weight: 500; }
.legal-meta { font-family: var(--mono); font-size: 12px; letter-spacing: 0.06em; color: var(--soft); margin-top: 14px; }

/* =====================================================================
   Scroll reveal
   ===================================================================== */
.has-js [data-reveal] { opacity: 0; transform: translateY(26px); }
[data-reveal] { transition: opacity 760ms var(--ease), transform 760ms var(--ease); }
[data-reveal].in { opacity: 1; transform: none; }
[data-reveal][data-reveal-delay="1"] { transition-delay: 80ms; }
[data-reveal][data-reveal-delay="2"] { transition-delay: 160ms; }
[data-reveal][data-reveal-delay="3"] { transition-delay: 240ms; }
[data-reveal][data-reveal-delay="4"] { transition-delay: 320ms; }
@media (prefers-reduced-motion: reduce) {
  [data-reveal] { opacity: 1 !important; transform: none !important; transition: none !important; }
  .btn, .sector-card, .arr { transition: none !important; }
}

/* Iberia map — real geography, strokes kept crisp via non-scaling-stroke */
.iberia { width: 100%; height: auto; max-width: 460px; margin-inline: auto; color: var(--ink); display: block; }
.iberia-coast { fill: rgba(var(--c-ink-rgb), 0.06); stroke: rgba(var(--c-ink-rgb), 0.55); stroke-width: 1.2; stroke-linejoin: round; vector-effect: non-scaling-stroke; }
.pt-soon { fill: rgba(var(--accent-rgb), 0.06); stroke: rgba(var(--accent-rgb), 0.7); stroke-width: 1.2; stroke-dasharray: 3 3; stroke-linejoin: round; vector-effect: non-scaling-stroke; }
.iberia .plant { fill: var(--accent); }
.iberia .ally { fill: var(--paper); stroke: var(--accent); stroke-width: 1.4; vector-effect: non-scaling-stroke; }
.iberia .map-label { font-size: 4.4px; fill: var(--soft); text-anchor: middle; letter-spacing: 0.02em; }
.iberia .pt-label { fill: var(--accent); opacity: 0.85; }

/* Mobile-only nav CTA (inside the slide-out panel) */
.nav-cta-mobile { display: none; }
@media (max-width: 980px){
  .nav-cta-mobile { display: inline-flex; }
  .nav .lang-switch { transform: scale(1.25); margin-top: 8px; }
}
@media (min-width: 981px){ .nav .nav-cta-wrap { display: none; } }

/* Legal pages */
.legal-disclaimer { background: var(--mist); border-left: 3px solid var(--sage-deep); padding: 16px 20px; font-size: 14.5px; color: rgba(var(--c-ink-rgb),0.78); border-radius: 0 var(--radius) var(--radius) 0; margin-bottom: 8px; }
.legal-body h2:first-of-type { margin-top: 24px; }

/* =====================================================================
   Section "view all" link
   ===================================================================== */
.section-more { margin-top: clamp(32px, 4vh, 52px); }

/* =====================================================================
   Detail pages (Servicios / Sectores)
   ===================================================================== */
.page-hero { padding-top: clamp(150px, 22vh, 240px); padding-bottom: clamp(44px, 7vh, 80px); background: var(--linen); border-bottom: 1px solid var(--line); }
.crumbs { font-family: var(--mono); font-size: 12px; letter-spacing: 0.08em; color: var(--soft); display: flex; gap: 10px; align-items: center; }
.crumbs a { border-bottom: 1px solid transparent; transition: border-color 240ms var(--ease); }
.crumbs a:hover { border-color: var(--soft); }
.crumbs [aria-current="page"] { color: var(--ink); }

.detail { display: block; }
.detail-block { padding-block: clamp(40px, 6vh, 72px); border-top: 1px solid var(--line); display: grid; gap: clamp(24px, 4vw, 56px); scroll-margin-top: 104px; }
.detail-block:first-child { border-top: 0; padding-top: 0; }
.detail-block:last-child { border-bottom: 1px solid var(--line); }
@media (min-width: 900px){ .detail-block { grid-template-columns: 0.85fr 1.15fr; align-items: start; } }
.detail-block__head { display: flex; flex-direction: column; gap: 16px; }
.detail-index { font-family: var(--serif); font-size: clamp(28px, 2.8vw, 42px); font-weight: 300; line-height: 1; color: var(--sage-deep); }
.detail-tag { font-family: var(--mono); font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sage-deep); }
.detail-block__head .lede { font-size: clamp(17px, 1.7vw, 20px); }

.detail-cols { display: grid; gap: clamp(24px, 3vw, 44px); }
@media (min-width: 620px){ .detail-cols { grid-template-columns: 1fr 1fr; } }
.detail-col__title { font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--soft); margin-bottom: 16px; padding-bottom: 12px; border-bottom: 1px solid var(--line); }
.detail-list { display: flex; flex-direction: column; gap: 12px; }
.detail-list li { position: relative; padding-left: 22px; font-size: 16px; line-height: 1.55; color: rgba(var(--c-ink-rgb),0.82); }
.detail-list li::before { content: ""; position: absolute; left: 0; top: 11px; width: 9px; height: 1px; background: var(--sage-deep); }
.chips { display: flex; flex-wrap: wrap; gap: 10px; align-content: flex-start; }
.chips li { font-family: var(--mono); font-size: 13px; letter-spacing: 0.02em; color: var(--ink); background: var(--linen); border: 1px solid var(--line); padding: 9px 15px; border-radius: 999px; }

.detail-related { grid-column: 1 / -1; display: flex; flex-wrap: wrap; gap: 12px 18px; align-items: center; padding-top: 22px; border-top: 1px solid var(--line-soft); }
.detail-related__label { font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--soft); }
.chip-links { display: flex; flex-wrap: wrap; gap: 10px; }
.chip-link { display: inline-flex; align-items: center; gap: 6px; font-size: 13.5px; font-weight: 500; color: var(--ink); border: 1px solid var(--line); border-radius: 999px; padding: 8px 14px; transition: background 240ms var(--ease), border-color 240ms var(--ease); }
.chip-link span { transition: transform 280ms var(--ease); }
.chip-link:hover { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.chip-link:hover span { transform: translateX(3px); }

/* Skip link */
.skip-link { position: absolute; left: -999px; top: 8px; background: var(--ink); color: var(--paper); padding: 10px 16px; border-radius: 6px; z-index: 2000; }
.skip-link:focus { left: 8px; }

/* =====================================================================
   Responsive refinement — tablet & mobile
   Goal: shorter, calmer, no horizontal overflow, real tap targets.
   ===================================================================== */

/* Tablet / collapsed-nav range */
@media (max-width: 980px) {
  /* The language switcher lives inside the slide-out menu on mobile —
     keep the top bar to just logo + menu button. */
  .header-actions .lang-switch { display: none; }
  .header-actions { gap: 8px; }
}

@media (max-width: 760px) {
  :root {
    --section-y: 52px;
    --gutter: 22px;
    --fs-hero: clamp(29px, 8.5vw, 44px);
    --fs-section: clamp(23px, 6vw, 32px);
    --fs-mid: clamp(20px, 5.2vw, 27px);
  }

  /* Hero: tighter under the fixed header */
  .hero { padding-top: 104px; }
  .hero .lede { margin-top: 22px; }
  .hero .hero-cta { margin-top: 30px; gap: 12px; }
  .hero .btn { width: 100%; justify-content: center; }

  /* Drop forced min-heights so cards size to content — big length saver */
  .svc-card, .why-cell { min-height: 0; }
  .svc-card { padding: 26px 24px; }
  .why-cell { padding: 30px 26px; }

  /* Manager photo: show on mobile (now a real image, not decorative) */
  .split__visual { aspect-ratio: 16/11; }

  /* Section heads breathe less */
  .section-head { margin-bottom: 32px; gap: 14px; }

  /* Trust stats: tighter */
  .trustbar .wrap { gap: 28px; }
  .stat .num { font-size: clamp(28px, 8.5vw, 40px); }

  /* Manifesto + split stack cleanly */
  .manifesto .wrap, .coverage .wrap, .split { gap: 28px; }

  /* Detail / legal blocks */
  .detail-block { padding-block: 32px; }
  .page-hero { padding-top: 104px; }

  /* Cookie banner: full-width, stacked, thumb-friendly */
  .cookie-banner { padding: 18px 18px; gap: 14px; bottom: 12px; }
  .cookie-actions { width: 100%; }
  .cookie-actions .btn { flex: 1 1 auto; justify-content: center; }
}

@media (max-width: 560px) {
  /* Avoid the decorative weave drifting under hero text on small screens */
  .hero__weave { display: none; }

  /* Legal/cookie tables: contained, horizontally scrollable instead of
     blowing out the viewport width. */
  .legal-body table { display: block; max-width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .legal-body thead, .legal-body tbody { display: table; width: 100%; min-width: 460px; }
  .legal-body th, .legal-body td { font-size: 13px; padding: 8px 10px; }

  /* Stack the two-up form fields */
  .form .row.two { grid-template-columns: 1fr; }
}

/* Guarantee no element forces sideways scrolling */
html, body { max-width: 100%; }
img, svg, table { max-width: 100%; }

/* =====================================================================
   Design refinement pass — premium finishing
   ===================================================================== */

/* Anchored sections clear the fixed header when reached via nav links */
section[id] { scroll-margin-top: 92px; }

/* Typographic finishing — balanced headlines, tidy paragraph rag */
.display, .h-section, .h-mid, .hero h1, .quote, .trust-line,
.sector-card h3, .svc-card h3 { text-wrap: balance; }
.manifesto__body { text-wrap: pretty; }
.lede, .svc-card p, .sector-card p, .why-cell p, .process-step p,
.faq-a, .sust-claim p, .detail-block__head .lede { text-wrap: pretty; }

/* Párrafos de contenido justificados en toda la web (guionado para evitar huecos) */
.lede, .manifesto__body, .svc-card p, .sector-card p, .process-step p,
.why-cell p, .product-card p, .product-list li, .faq-a, .faq-a p,
.detail-block__head .lede, .detail-list li, .legal-body p, .legal-body li,
.prod-family p, .prod-fam-list li {
  text-align: justify; text-justify: inter-word;
  hyphens: auto; -webkit-hyphens: auto;
}

/* Woven thread texture on dark surfaces — echoes the Tejido mark.
   Two hairline grids crossing = warp & weft. Kept whisper-faint. */
.section--ink, .cta-final { position: relative; isolation: isolate; }
.section--ink::before, .cta-final::before {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background-image:
    repeating-linear-gradient(90deg, rgba(var(--c-paper-rgb),0.045) 0 1px, transparent 1px 30px),
    repeating-linear-gradient(0deg,  rgba(var(--c-paper-rgb),0.038) 0 1px, transparent 1px 30px);
  -webkit-mask-image: radial-gradient(130% 120% at 85% 0%, #000 25%, transparent 78%);
          mask-image: radial-gradient(130% 120% at 85% 0%, #000 25%, transparent 78%);
}
.section--ink > .wrap, .cta-final > .wrap { position: relative; z-index: 1; }

/* Service cards — a quiet sage thread grows along the top edge on hover */
.svc-card::after {
  content: ""; position: absolute; left: 0; top: -1px; height: 2px; width: 0;
  background: var(--sage-deep); transition: width 460ms var(--ease);
}
.svc-card:hover::after { width: 100%; }

/* Sector cards — accent the tag on hover */
.sector-card .sector-tag { transition: color 320ms var(--ease); }
.sector-card:hover .sector-tag { color: var(--ink); }

/* Reveal — soften the settle with a faint de-blur (motion-safe only) */
@media (prefers-reduced-motion: no-preference) {
  [data-reveal] { transition: opacity 760ms var(--ease), transform 760ms var(--ease), filter 760ms var(--ease); }
  .has-js [data-reveal]:not(.in) { filter: blur(5px); }
  [data-reveal].in { filter: blur(0); }
}

/* Crisper focus ring on dark surfaces */
.section--ink :focus-visible, .cta-final :focus-visible, .site-footer :focus-visible { outline-color: var(--sage); }

/* Active section indicator in the nav (driven by the scroll-spy) */
.nav a.nav-link[data-active]::after { width: 100%; }

/* Scroll progress bar — thin sage thread across the very top */
.scroll-progress {
  position: fixed; inset: 0 0 auto 0; height: 2px; z-index: 1500;
  background: var(--sage-deep); transform: scaleX(0); transform-origin: 0 50%;
  transition: transform 90ms linear; will-change: transform;
}
@media (prefers-reduced-motion: reduce) { .scroll-progress { transition: none; } }

/* Back-to-top */
.to-top {
  position: fixed; right: 22px; bottom: 22px; z-index: 1150;
  width: 48px; height: 48px; border-radius: 50%;
  background: var(--ink); color: var(--paper); border: 1px solid var(--ink);
  display: grid; place-items: center; font-size: 19px; line-height: 1;
  opacity: 0; transform: translateY(12px); pointer-events: none;
  box-shadow: 0 14px 34px -12px rgba(var(--c-ink-rgb),0.55);
  transition: opacity 320ms var(--ease), transform 320ms var(--ease), background 200ms var(--ease);
}
.to-top.show { opacity: 1; transform: none; pointer-events: auto; }
.to-top:hover { background: var(--ink-deep); transform: translateY(-2px); }
@media (max-width: 560px) { .to-top { right: 14px; bottom: 14px; width: 44px; height: 44px; } }
@media (prefers-reduced-motion: reduce) { .to-top { transition: opacity 200ms linear; } }

/* =====================================================================
   Sector cards — products hint + link to the products page
   ===================================================================== */
.sector-products { margin-top: auto; padding-top: 16px; border-top: 1px solid var(--line-soft); display: flex; flex-direction: column; gap: 12px; }
.sector-products__label { font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--soft); }
.sector-products .sector-items { margin-top: 0; padding-top: 0; border-top: 0; }
.sector-products__more { align-self: flex-start; font-size: 14px; }

/* =====================================================================
   Products page — claims, families, personalisation, certifications
   ===================================================================== */
.prod-claims { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); }
@media (max-width: 880px) { .prod-claims { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .prod-claims { grid-template-columns: 1fr; } }
.prod-claim { background: var(--linen); padding: clamp(22px, 2.4vw, 32px); display: flex; flex-direction: column; gap: 8px; }
.prod-claim h3 { font-family: var(--serif); font-weight: 400; font-size: clamp(18px, 1.5vw, 22px); line-height: 1.12; }
.prod-claim p { font-size: 15px; color: rgba(var(--c-ink-rgb),0.74); margin: 0; line-height: 1.55; }

/* Familias en pestañas (interactivo) */
.prod-gama { margin-top: clamp(26px, 3.4vw, 44px); }
.prod-tabs { display: flex; flex-wrap: wrap; align-items: flex-end; gap: 0 clamp(18px, 2.6vw, 42px); border-bottom: 1px solid var(--line); margin-bottom: clamp(26px, 3.2vw, 44px); }
.prod-tab { appearance: none; -webkit-appearance: none; background: none; border: 0; cursor: pointer; padding: 0 0 14px; position: relative; font-family: var(--serif); font-weight: 400; font-size: clamp(19px, 1.8vw, 26px); line-height: 1; color: rgba(var(--c-ink-rgb),0.42); transition: color 300ms var(--ease); }
.prod-tab::after { content: ""; position: absolute; left: 0; bottom: -1px; height: 2px; width: 0; background: var(--accent); transition: width 380ms var(--ease); }
.prod-tab:hover { color: rgba(var(--c-ink-rgb),0.72); }
.prod-tab.is-active { color: var(--ink); }
.prod-tab.is-active::after { width: 100%; }
.prod-panel[hidden] { display: none; }
@media (prefers-reduced-motion: no-preference) {
  .prod-panel:not([hidden]) { animation: prodFade 440ms var(--ease); }
}
@keyframes prodFade { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }
.prod-family { display: grid; gap: clamp(18px, 2.2vw, 34px); }
@media (min-width: 920px) { .prod-family { grid-template-columns: 0.82fr 1.4fr; align-items: start; } }
.prod-family__head { display: flex; flex-direction: column; gap: 12px; }
.prod-fam-tag { font-family: var(--mono); font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--sage-deep); }
.prod-family__head h3 { font-family: var(--serif); font-weight: 400; }
.prod-groups { display: grid; gap: 1px; background: var(--line); border: 1px solid var(--line); grid-template-columns: 1fr 1fr; }
@media (max-width: 620px) { .prod-groups { grid-template-columns: 1fr; } }
.prod-group { background: var(--paper); padding: clamp(18px, 1.8vw, 26px); display: flex; flex-direction: column; gap: 7px; }
.prod-group h4 { font-family: var(--sans); font-weight: 600; font-size: 15px; letter-spacing: 0.01em; color: var(--ink); }
.prod-group p { font-size: 14.5px; line-height: 1.55; color: rgba(var(--c-ink-rgb),0.72); margin: 0; }

.prod-custom { display: grid; gap: clamp(24px, 3vw, 48px); }
@media (min-width: 860px) { .prod-custom { grid-template-columns: 1fr 1fr; align-items: center; } }
.prod-custom-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 14px; }
.prod-custom-list li { position: relative; padding-left: 26px; color: rgba(var(--c-ink-rgb),0.82); font-size: 16px; line-height: 1.5; }
.prod-custom-list li::before { content: ""; position: absolute; left: 0; top: 11px; width: 13px; height: 1.5px; background: var(--accent); }

.prod-certs { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; margin-top: clamp(24px, 3vw, 40px); }
@media (max-width: 880px) { .prod-certs { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .prod-certs { grid-template-columns: 1fr; } }
.prod-cert { border-top: 2px solid var(--accent); padding-top: 14px; display: flex; flex-direction: column; gap: 6px; }
.prod-cert h4 { font-family: var(--mono); font-size: 12.5px; letter-spacing: 0.05em; color: var(--ink); }
.prod-cert p { font-size: 14px; color: rgba(var(--c-ink-rgb),0.7); margin: 0; line-height: 1.5; }
