/* casa.css — Sistema de diseño Casa PRODI (Industria & Finanzas).
   Extraído del home rediseñado. Compartido por todas las páginas del sitio.
   Tokens, tipografía, nav, botones, reveal, secciones, footer. NO editar a mano por página: cambios globales aquí. */
  :root{
    --paper:#f5f0e6;
    --paper-2:#efe7d6;
    --paper-card:#faf7ef;
    --ink:#1a1714;
    --ink-2:#26201a;
    --ink-soft:#46403a;
    --ink-mute:#7c746a;
    --line:#e2d9c7;
    --line-strong:#d8cdb6;
    --line-soft:#ebe3d4;
    --clay:#b5573f;
    --clay-deep:#9a4530;
    --gold:#a87b46;
    --oro:#c9a227;              /* oro metalico (acento Sandvik: precision) */
    --on-dark:#f5f0e6;
    --maxw:1320px;
    --gut:clamp(20px, 5vw, 72px);
    --ease:cubic-bezier(.16,.84,.34,1);
    --ease-out:cubic-bezier(.22,1,.36,1);
    --ease-title:cubic-bezier(.19,1,.22,1);
    --serif:"Zodiak",Georgia,"Times New Roman",serif;
    --sans:"General Sans",system-ui,-apple-system,sans-serif;
    --r:3px;
  }

  *{box-sizing:border-box}
  html{ -webkit-text-size-adjust:100%; }
  html.lenis,html.lenis body{height:auto}
  .lenis.lenis-smooth{scroll-behavior:auto !important}
  .lenis.lenis-stopped{overflow:hidden}

  body{
    margin:0;background:var(--paper);color:var(--ink);
    font-family:var(--sans);font-weight:400;font-size:clamp(16px,1.05vw,18px);line-height:1.6;
    -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;
  }
  ::selection{background:var(--clay);color:var(--paper)}
  a{color:inherit;text-decoration:none}
  img{display:block;max-width:100%}
  h1,h2,h3,h4{margin:0;font-family:var(--serif);font-weight:500;letter-spacing:-.008em;line-height:1.04;text-wrap:balance}
  p{margin:0}
  button{font-family:inherit}
  :focus-visible{outline:2px solid var(--clay);outline-offset:3px;border-radius:var(--r)}

  .wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut)}
  .skip{position:absolute;left:-9999px;top:0;background:var(--ink);color:var(--paper);padding:12px 18px;z-index:200}
  .skip:focus{left:12px;top:12px}

  /* ---------- type ---------- */
  .eyebrow{font-size:clamp(11px,.78vw,13px);letter-spacing:.2em;text-transform:uppercase;font-weight:600;color:var(--clay)}
  .display{font-size:clamp(2.1rem,7.4vw,7rem);line-height:1.04;letter-spacing:-.012em;font-weight:500;overflow-wrap:break-word}
  .h2{font-size:clamp(2rem,4.4vw,3.5rem);line-height:1.07;letter-spacing:-.018em;font-weight:500}
  .lead{font-size:clamp(1.22rem,1.7vw,1.55rem);line-height:1.45;letter-spacing:-.006em;color:var(--ink-soft);font-weight:400;text-wrap:pretty}
  .small{font-size:14px;color:var(--ink-mute);line-height:1.6}
  .accent{color:var(--clay);font-style:italic}
  .tnum{font-variant-numeric:tabular-nums lining-nums}

  @media (min-width:1080px){
    .display{line-height:.97;letter-spacing:-.022em}
  }

  /* ---------- nav ---------- */
  header.nav{position:fixed;inset:0 0 auto 0;z-index:100;background:rgba(245,240,230,.72);backdrop-filter:saturate(160%) blur(11px);transition:background .35s var(--ease-out),box-shadow .35s var(--ease-out),backdrop-filter .35s var(--ease-out)}
  header.nav.scrolled{background:rgba(245,240,230,.93);backdrop-filter:saturate(160%) blur(14px);box-shadow:0 1px 0 var(--line)}
  .nav-inner{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut);height:76px;display:flex;align-items:center;justify-content:space-between;gap:24px;transition:height .35s var(--ease-out)}
  header.nav.scrolled .nav-inner{height:64px}
  .brand{display:inline-flex;align-items:center;gap:12px}
  .brand .lock{display:flex;flex-direction:column;line-height:1}
  .brand .name{font-family:var(--serif);font-weight:600;font-size:20px;letter-spacing:.005em;color:inherit}
  .brand .name .stop{color:var(--clay)}
  .brand .tag{font-family:var(--sans);font-size:10px;letter-spacing:.18em;font-weight:600;color:var(--ink-mute);text-transform:uppercase;margin-top:5px}
  .nav-links{display:flex;align-items:center;gap:clamp(14px,1.7vw,30px)}
  .nav-links a{font-size:15px;font-weight:500;letter-spacing:.005em;color:var(--ink-soft);position:relative;padding:6px 0;transition:color .3s var(--ease-out)}
  .nav-links a::after{content:"";position:absolute;left:0;bottom:0;height:1.5px;width:100%;background:var(--clay);transform:scaleX(0);transform-origin:right;transition:transform .4s var(--ease-out)}
  .nav-links a:hover{color:var(--clay)}
  .nav-links a:hover::after{transform:scaleX(1);transform-origin:left}
  .nav-cta{display:flex;align-items:center;gap:12px}
  .btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--sans);font-weight:600;font-size:15px;letter-spacing:.01em;padding:12px 22px;border-radius:100px;border:1px solid transparent;cursor:pointer;line-height:1;transition:transform .28s var(--ease-out),background .3s var(--ease-out),color .3s,border-color .3s,box-shadow .3s var(--ease-out)}
  .btn-solid{background:var(--clay);color:var(--paper)}
  .btn-solid:hover{background:var(--clay-deep);transform:translateY(-2px);box-shadow:0 12px 30px -12px rgba(154,69,48,.5)}
  .btn-solid:active{background:var(--clay-deep);transform:translateY(0) scale(.97);transition-duration:.09s}
  .btn-ink{background:var(--ink);color:var(--paper)}
  .btn-ink:hover{background:var(--ink-2);transform:translateY(-2px);box-shadow:0 12px 30px -16px rgba(26,23,20,.55)}
  .btn-ink:active{transform:translateY(0) scale(.97);transition-duration:.09s}
  .btn-ghost{border-color:var(--line);color:var(--ink);background:transparent}
  .btn-ghost:hover{border-color:var(--ink);transform:translateY(-2px)}
  .btn-ghost:active{transform:translateY(0) scale(.97);transition-duration:.09s}
  .btn-paper{background:var(--paper);color:var(--ink)}
  .btn-paper:hover{transform:translateY(-2px);box-shadow:0 14px 32px -16px rgba(0,0,0,.5)}
  .btn-paper:active{transform:translateY(0) scale(.97);transition-duration:.09s}
  .btn-outline-light{border-color:rgba(245,240,230,.4);color:var(--on-dark)}
  .btn-outline-light:hover{border-color:var(--on-dark);transform:translateY(-2px)}
  .btn-outline-light:active{transform:translateY(0) scale(.97);transition-duration:.09s}
  .btn .arr{transition:transform .4s var(--ease-out)}
  .btn:hover .arr{transform:translateX(5px)}

  .link-arrow{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:15px;letter-spacing:.005em;color:var(--ink);position:relative}
  .link-arrow .arr{transition:transform .4s var(--ease-out)}
  .link-arrow::after{content:"";position:absolute;left:0;bottom:-3px;width:100%;height:1.5px;background:var(--clay);transform:scaleX(0);transform-origin:right;transition:transform .45s var(--ease-out)}
  .link-arrow:hover::after{transform:scaleX(1);transform-origin:left}
  .link-arrow:hover .arr{transform:translateX(5px)}

  .hamb{display:none;width:46px;height:46px;border:1px solid var(--line);background:transparent;border-radius:var(--r);position:relative;cursor:pointer}
  .hamb span{position:absolute;left:12px;right:12px;height:1.6px;background:var(--ink);transition:transform .4s var(--ease),opacity .3s}
  .hamb span:nth-child(1){top:17px}.hamb span:nth-child(2){top:23px}.hamb span:nth-child(3){top:29px}
  body.menu-open .hamb span:nth-child(1){top:23px;transform:rotate(45deg)}
  body.menu-open .hamb span:nth-child(2){opacity:0}
  body.menu-open .hamb span:nth-child(3){top:23px;transform:rotate(-45deg)}
  .drawer{position:fixed;inset:0;z-index:99;background:var(--paper);transform:translateY(-100%);transition:transform .5s var(--ease);display:flex;flex-direction:column;padding:100px var(--gut) 44px;visibility:hidden}
  body.menu-open .drawer{transform:translateY(0);visibility:visible}
  .drawer a{font-family:var(--serif);font-size:clamp(1.6rem,6vw,2.3rem);font-weight:500;padding:13px 0;border-bottom:1px solid var(--line-soft);color:var(--ink);opacity:0;transform:translateY(14px);transition:color .3s,transform .5s var(--ease-out),opacity .5s var(--ease-out)}
  body.menu-open .drawer a{opacity:1;transform:none}
  body.menu-open .drawer a:nth-child(1){transition-delay:.16s}
  body.menu-open .drawer a:nth-child(2){transition-delay:.21s}
  body.menu-open .drawer a:nth-child(3){transition-delay:.26s}
  body.menu-open .drawer a:nth-child(4){transition-delay:.31s}
  body.menu-open .drawer a:nth-child(5){transition-delay:.36s}
  body.menu-open .drawer a:nth-child(6){transition-delay:.41s}
  body.menu-open .drawer a:nth-child(7){transition-delay:.46s}
  .drawer a:hover{color:var(--clay);transform:translateX(8px)}
  body.menu-open .drawer a:hover{transform:translateX(8px)}
  .drawer .drawer-foot{margin-top:auto;display:flex;flex-direction:column;gap:14px;padding-top:26px}
  .drawer .drawer-foot a{font-family:var(--sans);font-size:15px;border-bottom:0;opacity:0;transform:translateY(14px);transition:opacity .5s var(--ease-out),transform .5s var(--ease-out)}
  body.menu-open .drawer .drawer-foot a{opacity:1;transform:none;transition-delay:.5s}

  /* ---------- reveal / motion ---------- */
  .reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
  .reveal-sm{opacity:0;transform:translateY(18px);transition:opacity .55s var(--ease-out),transform .55s var(--ease-out)}
  .reveal.in,.reveal-sm.in{opacity:1;transform:none}
  .reveal-d1{transition-delay:.08s}.reveal-d2{transition-delay:.16s}.reveal-d3{transition-delay:.24s}.reveal-d4{transition-delay:.32s}
  .lines span{display:block;overflow:hidden;padding-bottom:.12em;margin-bottom:-.12em}
  .lines span i{display:block;font-style:normal;transform:translateY(112%);transition:transform .9s var(--ease-title),opacity .35s var(--ease-out);opacity:0}
  .lines.in span i{transform:none;opacity:1}
  .lines.in span:nth-child(2) i{transition-delay:.14s}
  .lines.in span:nth-child(3) i{transition-delay:.28s}
  .lines.in span:nth-child(4) i{transition-delay:.42s}

  /* ---------- hero (ASCII 3D izquierda · texto derecha) ---------- */
  .hero{position:relative;padding:clamp(116px,15vh,174px) 0 clamp(54px,8vh,100px);overflow:hidden}
  .hero .wrap{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:clamp(28px,4vw,64px);align-items:center;min-height:min(68vh,600px)}
  /* izquierda: animacion ASCII 3D, totalmente contenida en su celda (sin solaparse) */
  .hero-ascii{position:relative;align-self:stretch;min-width:0;min-height:360px;display:flex;align-items:center;justify-content:center;overflow:hidden;pointer-events:none;background:radial-gradient(125% 130% at 30% 14%,#272c36,#13161d);border-radius:14px;border:1px solid rgba(184,143,90,.18);padding:18px}
  .ascii{display:block;margin:0;max-width:100%;max-height:100%}
  /* derecha: bloque de texto alineado a la derecha */
  .hero-content{display:flex;flex-direction:column;align-items:flex-end;text-align:right;min-width:0}
  .hero-content .eyebrow{margin-bottom:22px;color:var(--oro)}
  .hero h1{margin:0;font-size:clamp(1.9rem,4.6vw,4.2rem);line-height:1.05;letter-spacing:-.012em}
  .hero h1 .accent{font-family:var(--serif)}
  .hero .lead{max-width:42ch;margin-top:26px}
  .hero-actions{display:flex;gap:13px;flex-wrap:wrap;justify-content:flex-end;margin-top:36px}
  .hero-meta{margin-top:40px;padding-top:24px;border-top:1px solid var(--line);font-size:clamp(14px,1.05vw,16px);color:var(--ink-soft);max-width:52ch;line-height:1.55}
  .hero-meta b{font-family:var(--serif);font-weight:600;color:var(--ink);letter-spacing:-.01em;font-variant-numeric:tabular-nums lining-nums}
  .hero-meta .sep{color:var(--ink-mute);margin:0 .5em;font-style:normal}

  /* ---------- art slots (warm duotone, parallax, editorial framing) ---------- */
  .slot{position:relative;width:100%;height:100%;overflow:hidden;isolation:isolate}
  .slot::after{content:attr(data-label);position:absolute;left:22px;bottom:20px;right:22px;font-size:12px;letter-spacing:.01em;color:rgba(245,240,230,.78);font-weight:500;z-index:4;line-height:1.45}
  .slot::before{content:"";position:absolute;inset:0;z-index:3;background:linear-gradient(180deg,transparent 42%,rgba(26,23,20,.5))}
  .slot .badge{position:absolute;top:22px;left:22px;z-index:4;font-family:var(--serif);font-style:italic;font-size:15px;color:rgba(245,240,230,.92)}
  /* flat duotone fills — no specular radial highlight */
  .slot-clay{background:linear-gradient(150deg,#b5573f 0%,#8a3f2b 100%)}
  .slot-sand{background:linear-gradient(150deg,#cdb588 0%,#a87b46 100%)}
  .slot-hero{background:linear-gradient(150deg,#9a4530 0%,#5e2a1d 100%)}
  /* oversized editorial number / wordmark cropped by the frame edge */
  .slot-figure{position:absolute;z-index:2;font-family:var(--serif);font-weight:500;line-height:.8;pointer-events:none;user-select:none}
  .slot-figure.num{right:-.06em;bottom:-.18em;font-size:clamp(11rem,30vw,26rem);color:rgba(245,240,230,.07)}
  .slot-figure.word{left:.04em;top:-.04em;font-size:clamp(4.6rem,12vw,9rem);letter-spacing:-.02em;color:rgba(245,240,230,.08)}
  .slot-sand .slot-figure{color:rgba(40,32,22,.10)}
  /* contained print grain via SVG turbulence — texture, not page-noise */
  .slot-grain{position:absolute;inset:0;z-index:2;opacity:.16;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");pointer-events:none}
  .parallax-media{position:absolute;inset:-14% 0;will-change:transform;z-index:1;transition:transform .9s var(--ease-out)}

  /* ---------- sections ---------- */
  section{position:relative}
  .band{padding:clamp(84px,11vh,150px) 0}
  .band-paper2{background:var(--paper-2)}
  .sec-head{max-width:62ch}
  .sec-head .eyebrow{display:inline-block;margin-bottom:20px}
  .sec-head h2{margin-bottom:0}
  .sec-head .sub{margin-top:22px;font-size:clamp(17px,1.9vw,20px);line-height:1.55;color:var(--ink-soft);max-width:52ch;text-wrap:pretty}

  /* ---------- clients (editorial logo cintillo, no grid lines) ---------- */
  .clients{padding:clamp(48px,6vh,80px) 0 clamp(64px,8vh,104px);border-top:1px solid var(--line)}
  .clients .lab{display:flex;align-items:baseline;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:44px}
  .clients .lab .f500{font-family:var(--serif);font-style:italic;font-size:clamp(15px,1.3vw,17px);color:var(--ink-soft);max-width:24ch;text-align:right}
  .logo-cintillo{display:flex;flex-wrap:wrap;align-items:center;gap:clamp(28px,4.5vw,68px) clamp(36px,5.5vw,80px)}
  .logo-cintillo img{max-height:30px;width:auto;max-width:140px;object-fit:contain;filter:grayscale(1) brightness(.42) contrast(.95);opacity:.66;transition:filter .35s var(--ease-out),opacity .35s var(--ease-out),transform .45s var(--ease-out)}
  .logo-cintillo img:hover{filter:grayscale(1) brightness(.22);opacity:1;transform:scale(1.04)}

  /* ---------- divisions ---------- */
  /* panel de cifra signature dentro del visual de cada division (llena el slot, autoridad Sandvik) */
  .slot-hero{position:absolute;z-index:5;left:0;right:0;bottom:0;padding:clamp(24px,3vw,44px);color:#f7f2e8}
  .slot-hero b{display:block;font-family:var(--serif);font-weight:600;font-size:clamp(3rem,6.5vw,5.4rem);line-height:.9;letter-spacing:-.02em;font-variant-numeric:tabular-nums lining-nums}
  .slot-hero span{display:block;margin-top:10px;font-size:clamp(15px,1.5vw,18px);font-weight:500;max-width:22ch;opacity:.95;line-height:1.3}
  .slot-hero em{display:block;margin-top:16px;font-style:normal;font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;opacity:.72}
  .slot-sand .slot-hero{color:#251a10}
  .division{padding:clamp(80px,12vh,150px) 0;border-top:1px solid var(--line)}
  .division-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,80px);align-items:center}
  .division.flip .division-grid{direction:rtl}
  .division.flip .division-grid > *{direction:ltr}
  .division-num{font-size:13px;letter-spacing:.13em;font-weight:600;color:var(--clay);text-transform:uppercase}
  .division h3{font-size:clamp(2rem,4.2vw,3.3rem);margin:18px 0 22px;line-height:1.02;letter-spacing:-.018em}
  .division .lead{max-width:46ch}
  .division .lead b{color:var(--ink);font-weight:600}
  .division-visual{position:relative;aspect-ratio:5/4;border-radius:10px;overflow:hidden;box-shadow:0 50px 90px -55px rgba(26,23,20,.55);transition:box-shadow .6s var(--ease),transform .6s var(--ease)}
  .division-visual:hover{transform:translateY(-3px);box-shadow:0 60px 100px -50px rgba(26,23,20,.6)}
  .division-visual:hover .parallax-media{transform:scale(1.05)}
  /* asymmetric stats: one protagonist figure + two inline notes */
  .stat-row{display:flex;align-items:flex-end;gap:clamp(22px,3.4vw,52px);margin:34px 0;flex-wrap:wrap;padding-top:30px;border-top:1px solid var(--line)}
  .stat-lead b{display:block;font-family:var(--serif);font-size:clamp(2.8rem,5.4vw,4rem);font-weight:600;letter-spacing:-.018em;line-height:.95}
  .stat-lead span{font-size:13px;color:var(--ink-mute);display:block;margin-top:10px;max-width:18ch;line-height:1.4}
  .stat-notes{display:flex;flex-direction:column;gap:14px;padding-bottom:6px}
  .stat-note{display:flex;align-items:baseline;gap:10px;line-height:1.3}
  .stat-note b{font-family:var(--serif);font-size:clamp(1.2rem,1.7vw,1.45rem);font-weight:600;letter-spacing:-.01em;color:var(--ink);font-variant-numeric:tabular-nums lining-nums;white-space:nowrap}
  .stat-note span{font-size:13px;color:var(--ink-mute);max-width:22ch;line-height:1.35}
  .pill-row{display:flex;flex-wrap:wrap;gap:9px;margin-top:4px}
  .pill{font-size:12.5px;letter-spacing:.01em;font-weight:500;color:var(--ink-soft);border:1px solid var(--line);padding:7px 16px;border-radius:100px;background:var(--paper-card)}

  /* ---------- proof (warm dark band, editorial asymmetry) ---------- */
  /* CIFRAS DURAS (autoridad por prueba — estilo Sandvik) */
  .figures{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--paper-card)}
  .figures .wrap{display:grid;grid-template-columns:repeat(4,1fr)}
  .fig{padding:clamp(34px,5vw,62px) clamp(14px,2vw,34px);border-left:1px solid var(--line-soft)}
  .fig:first-child{border-left:0}
  .fig b{display:inline-flex;align-items:flex-start;font-family:var(--serif);font-size:clamp(2.5rem,4.6vw,3.7rem);font-weight:600;letter-spacing:-.02em;color:var(--ink);line-height:.9;font-variant-numeric:tabular-nums lining-nums}
  .fig b .u{color:var(--oro);font-size:.42em;line-height:1;margin-top:.16em;margin-left:.06em;font-weight:600}     /* unidad como superindice consistente */
  .fig span{display:block;margin-top:14px;font-size:12.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-mute);font-weight:600;line-height:1.4}
  @media(max-width:720px){.figures .wrap{grid-template-columns:repeat(2,1fr)}.fig:nth-child(odd){border-left:0}.fig:nth-child(-n+2){border-bottom:1px solid var(--line-soft)}}
  /* EMPRESAS — grid de 4 tarjetas (una por empresa industrial) */
  .firms{padding:clamp(70px,10vh,128px) 0}
  .firms-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,1.5vw,22px);margin-top:clamp(34px,4vw,52px)}
  .firm{display:flex;flex-direction:column;background:var(--paper-card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:transform .4s var(--ease-out),border-color .3s,box-shadow .4s var(--ease-out)}
  .firm:hover{transform:translateY(-4px);border-color:var(--line-strong);box-shadow:0 22px 50px -30px rgba(26,23,20,.5)}
  /* foto REAL visible, grado editorial leve (cohesion) + degradado solo abajo para el nombre; color pleno al hover */
  .firm-photo{position:relative;aspect-ratio:4/3;overflow:hidden;background:#14110e;display:flex;align-items:flex-end;padding:18px}
  .firm-photo::before{content:'';position:absolute;inset:0;background-image:var(--photo);background-size:cover;background-position:center;filter:grayscale(.36) contrast(1.05) brightness(.99);transition:filter .55s var(--ease-out),transform .7s var(--ease-out)}
  .firm-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(14,11,8,.92) 0%,rgba(14,11,8,.2) 42%,rgba(14,11,8,0) 64%)}
  .firm:hover .firm-photo::before{filter:grayscale(0) contrast(1.04) brightness(1.03);transform:scale(1.05)}
  .firm-photo .fname{position:relative;z-index:2;font-family:var(--sans);font-weight:600;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--oro)}
  .firm-body{padding:20px 20px 22px;display:flex;flex-direction:column;gap:14px;flex:1}
  .firm-body p{font-size:14.5px;line-height:1.5;color:var(--ink-soft);flex:1}
  .firm-go{font-size:13px;font-weight:600;letter-spacing:.02em;color:var(--ink);display:inline-flex;align-items:center;gap:7px;transition:color .3s}
  .firm:hover .firm-go{color:var(--clay)}
  @media(max-width:920px){.firms-grid{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:520px){.firms-grid{grid-template-columns:1fr}}
  /* ANALISIS / insights — banda viva (subida, que no se sienta abandonada) */
  .insights{background:var(--paper-2);border-top:1px solid var(--line-strong)}
  .insights .sec-head{text-align:center;max-width:760px;margin-left:auto;margin-right:auto}   /* header centralizado */
  .insights .sec-head .sub{margin-left:auto;margin-right:auto}
  /* "el subrayado del analista": trazo de tinta a mano bajo la palabra clave del titular; se dibuja al entrar en vista */
  .ul-mark{position:relative;white-space:nowrap}
  .ul-stroke{position:absolute;left:-3px;right:-3px;bottom:-.16em;width:calc(100% + 6px);height:.4em;overflow:visible;pointer-events:none}
  .ul-stroke path{stroke:var(--oro);stroke-width:1.8;fill:none;stroke-linecap:round;stroke-dasharray:104;stroke-dashoffset:104;transition:stroke-dashoffset .8s cubic-bezier(.16,1,.3,1) .35s}
  .card-market .ul-stroke path{stroke:#e8c878}            /* oro un punto mas claro sobre fondo oscuro */
  .card.in .ul-stroke path{stroke-dashoffset:0}           /* el trazo se dibuja cuando la tarjeta aparece */
  @media(prefers-reduced-motion:reduce){.ul-stroke path{transition:none;stroke-dashoffset:0}}
  .live{display:inline-flex;align-items:center;gap:6px;color:var(--clay);font-weight:700}
  .live-dot{width:7px;height:7px;border-radius:50%;background:var(--clay);box-shadow:0 0 0 0 rgba(181,87,63,.55);animation:livePulse 1.9s ease-out infinite}
  @keyframes livePulse{0%{box-shadow:0 0 0 0 rgba(181,87,63,.5)}70%{box-shadow:0 0 0 8px rgba(181,87,63,0)}100%{box-shadow:0 0 0 0 rgba(181,87,63,0)}}
  @media(prefers-reduced-motion:reduce){.live-dot{animation:none}}
  .proof{background:var(--ink);color:var(--on-dark);padding:clamp(80px,11vh,140px) 0;overflow:hidden}
  .proof .eyebrow{color:#e0a48b}
  .proof h2{max-width:24ch}
  .proof-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(36px,5vw,72px);margin-top:64px;align-items:start}
  .proof-hero b{display:block;font-family:var(--serif);font-size:clamp(3.4rem,7vw,5.2rem);font-weight:500;letter-spacing:-.022em;line-height:.92}
  .proof-hero span{display:block;margin-top:18px;font-size:clamp(15px,1.4vw,17px);color:rgba(245,240,230,.7);line-height:1.5;max-width:30ch}
  .proof-list{display:flex;flex-direction:column}
  .proof-item{border-top:1px solid rgba(245,240,230,.18);padding:22px 0}
  .proof-item:last-child{border-bottom:1px solid rgba(245,240,230,.18)}
  .proof-item b{display:block;font-family:var(--serif);font-size:clamp(1.5rem,2.4vw,2rem);font-weight:500;letter-spacing:-.012em;line-height:1.05;font-variant-numeric:tabular-nums lining-nums}
  .proof-item span{display:block;margin-top:8px;font-size:14px;color:rgba(245,240,230,.66);line-height:1.45;max-width:34ch}

  /* ---------- national (editorial, sin puntos) ---------- */
  .national{background:var(--paper-2)}
  .cities-row{display:flex;flex-wrap:wrap;margin-top:40px;border-top:1px solid var(--line)}
  .city{padding:26px 44px 26px 0;margin-right:44px;border-right:1px solid var(--line)}
  .city:last-child{border-right:0;margin-right:0;padding-right:0}
  .city .nm{font-family:var(--serif);font-size:clamp(1.5rem,2.4vw,1.9rem);font-weight:500;color:var(--ink);letter-spacing:-.004em}
  .city .rg{display:block;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute);font-weight:600;margin-top:7px}
  .city.more .nm{color:var(--ink-mute);font-style:italic}

  /* ---------- analysis ---------- */
  .analysis-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(26px,4vw,56px);margin-top:58px}
  .card{border:1px solid var(--line);border-radius:12px;background:var(--paper-card);padding:clamp(28px,3vw,44px);display:flex;flex-direction:column;justify-content:space-between;min-height:300px;transition:transform .4s var(--ease-out),box-shadow .4s var(--ease-out),border-color .4s var(--ease-out)}
  .card:hover{transform:translateY(-6px);box-shadow:0 36px 64px -44px rgba(26,23,20,.4);border-color:var(--line-strong)}
  .card:hover .link-arrow .arr{transform:translateX(5px)}
  .card:hover .link-arrow::after{transform:scaleX(1);transform-origin:left}
  .card .eyebrow{margin-bottom:16px}
  .card h3{font-size:clamp(1.5rem,2.3vw,2rem);line-height:1.08;letter-spacing:-.004em}
  .card .link-arrow{margin-top:30px}
  .ticker{display:flex;gap:28px;margin-top:24px;flex-wrap:wrap}
  .ticker div b{display:block;font-family:var(--serif);font-size:clamp(1.5rem,2.2vw,1.95rem);font-weight:600;letter-spacing:-.01em;line-height:1.05;font-variant-numeric:tabular-nums lining-nums}
  .ticker div span{font-size:12px;color:var(--ink-mute);letter-spacing:.06em;text-transform:uppercase;font-weight:600;margin-top:3px;display:block}
  .card-market{background:var(--ink);color:var(--on-dark);border-color:transparent}
  .card-market:hover{border-color:transparent;background:#221b16}
  .card-market .eyebrow{color:#e0a48b}.card-market .small{color:rgba(245,240,230,.62)}
  .card-market .ticker div b{color:#f0c3ad}.card-market .ticker div span{color:rgba(245,240,230,.55)}
  .card-market .link-arrow{color:#f0c3ad}.card-market .link-arrow::after{background:#e0a48b}

  /* ---------- closer CTA (full-bleed clay band, left-aligned) ---------- */
  .closer{padding:clamp(120px,16vh,210px) 0 clamp(86px,11vh,150px)}
  .closer-inner{background:var(--clay);color:var(--paper);margin-right:calc(50% - 50vw);margin-left:calc(50% - 50vw);padding:clamp(56px,9vw,120px) 0;position:relative;overflow:hidden}
  .closer-pad{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut)}
  .closer-inner h2{font-size:clamp(2.2rem,5.4vw,4.4rem);max-width:18ch;color:var(--paper);line-height:1.04;letter-spacing:-.018em}
  .closer-inner h2 em{font-style:italic;color:#f6e2d2;font-weight:500;display:inline-block}
  .closer-inner p{margin:26px 0 40px;max-width:50ch;color:rgba(245,240,230,.9);font-size:clamp(17px,2vw,20px);line-height:1.5;text-wrap:pretty}
  .closer-cta{display:flex;gap:14px;flex-wrap:wrap}
  .closer-inner .contact{margin-top:40px;padding-top:30px;border-top:1px solid rgba(245,240,230,.26);max-width:50ch}
  .closer-inner .contact .cl{display:block;font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:rgba(245,240,230,.7);margin-bottom:12px}
  .closer-inner .contact a{font-family:var(--serif);font-size:clamp(1.4rem,2.6vw,2rem);font-weight:500;color:var(--paper);letter-spacing:-.01em;border-bottom:1px solid rgba(245,240,230,.45);transition:border-color .3s}
  .closer-inner .contact a:hover{border-color:var(--paper)}

  /* ---------- footer ---------- */
  footer{background:var(--ink);color:rgba(245,240,230,.72);padding:clamp(70px,9vh,108px) 0 40px}
  .foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:clamp(28px,3vw,48px);padding-bottom:56px;border-bottom:1px solid rgba(245,240,230,.14)}
  .foot-brand .brand{color:var(--paper)}
  .foot-brand .brand .tag{color:rgba(245,240,230,.5)}
  .foot-brand p{margin-top:20px;max-width:33ch;color:rgba(245,240,230,.62);font-size:14.5px;line-height:1.6}
  .foot-col h4{font-family:var(--sans);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:rgba(245,240,230,.5);font-weight:600;margin-bottom:18px}
  .foot-col a{display:block;padding:7px 0;color:rgba(245,240,230,.82);font-size:15px;transition:color .3s,transform .3s var(--ease-out)}
  .foot-col a:hover{color:var(--paper);transform:translateX(5px)}
  .foot-bottom{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;padding-top:30px;font-size:13px;color:rgba(245,240,230,.5)}
  .foot-bottom a{color:rgba(245,240,230,.7)}.foot-bottom a:hover{color:var(--paper)}
  .foot-cities{display:flex;gap:16px;flex-wrap:wrap}

  /* ---------- responsive ---------- */
  @media (max-width:1080px){
    .hero-media{height:clamp(280px,52vw,460px)}
    .division-grid{grid-template-columns:1fr;gap:36px}
    .division.flip .division-grid{direction:ltr}
    .analysis-grid{grid-template-columns:1fr}
    .proof-grid{grid-template-columns:1fr;gap:48px}
    .foot-top{grid-template-columns:1fr 1fr}
  }
  @media (max-width:760px){
    .nav-links,.nav-cta .btn{display:none}
    .hamb{display:block}
    .nav-cta .btn.show-mobile{display:inline-flex}
    .clients .lab .f500{text-align:left}
    .foot-top{grid-template-columns:1fr}
    .stat-row{gap:28px}
    .cities-row{flex-direction:column}
    .city{border-right:0;border-bottom:1px solid var(--line);margin-right:0;padding:18px 0}
    .city:last-child{border-bottom:0}
    .hero{padding:106px 0 0}
    .hero .wrap{grid-template-columns:minmax(0,1fr);gap:30px;min-height:0}
    .hero-ascii{order:-1;min-height:240px;max-height:330px;align-self:center}
    .ascii{font-size:clamp(2.6px,1.5vw,4.6px)}
    .hero-content{align-items:flex-start;text-align:left}
    .hero h1{font-size:clamp(2rem,8.4vw,3.1rem);line-height:1.07;letter-spacing:-.006em}
    .hero-actions{justify-content:flex-start}
    .hero .lead{font-size:clamp(1.12rem,4.6vw,1.32rem);margin-top:22px;max-width:100%}
    .hero-meta{margin-top:30px;padding-top:22px;max-width:100%}
  }

  @media (prefers-reduced-motion:reduce){
    *{scroll-behavior:auto !important}
    .reveal,.reveal-sm{opacity:1;transform:none;transition:none}
    .lines span i{transform:none;opacity:1;transition:none}
    .parallax-media{transform:none !important;transition:none}
    .btn:hover,.card:hover,.division-visual:hover{transform:none}
    .drawer a{opacity:1;transform:none;transition:color .3s}
  }

/* ====== Patrones para páginas internas (no-home) ====== */
/* page hero (internas, sin animación ASCII) */
.page-hero{padding:clamp(118px,15vh,184px) 0 clamp(40px,6vh,72px)}
.page-hero .eyebrow{display:inline-block;margin-bottom:20px;color:var(--clay)}
.page-hero h1{font-size:clamp(2.2rem,5.6vw,4.6rem);line-height:1.04;letter-spacing:-.018em;max-width:20ch}
.page-hero .lead{margin-top:26px;max-width:60ch}
.page-hero.dark{background:var(--ink);color:var(--on-dark)}
.page-hero.dark .lead{color:rgba(245,240,230,.78)}.page-hero.dark .eyebrow{color:#e0a48b}
/* prosa para artículos de blog */
.prose{max-width:68ch;margin:0 auto;font-size:clamp(17px,1.25vw,19px);line-height:1.7;color:var(--ink-soft)}
.prose h2{font-family:var(--serif);font-size:clamp(1.6rem,3vw,2.3rem);margin:1.8em 0 .55em;color:var(--ink);line-height:1.14;letter-spacing:-.012em}
.prose h3{font-family:var(--serif);font-size:clamp(1.3rem,2.2vw,1.7rem);margin:1.5em 0 .45em;color:var(--ink)}
.prose p{margin:0 0 1.1em}
.prose ul,.prose ol{margin:0 0 1.2em;padding-left:1.3em}.prose li{margin:.4em 0}
.prose a{color:var(--clay);border-bottom:1px solid var(--line-strong);transition:border-color .3s}.prose a:hover{border-color:var(--clay)}
.prose blockquote{margin:1.6em 0;padding:.3em 0 .3em 1.4em;border-left:3px solid var(--clay);font-family:var(--serif);font-style:italic;font-size:1.14em;color:var(--ink)}
.prose strong{color:var(--ink);font-weight:600}
.prose img{border-radius:var(--r);margin:1.4em 0}
/* tarjetas info genéricas + grids utilitarios */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(16px,2vw,28px)}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,28px)}
@media(max-width:880px){.grid-3{grid-template-columns:1fr}.grid-2{grid-template-columns:1fr}}
.info-card{background:var(--paper-card);border:1px solid var(--line);border-radius:var(--r);padding:clamp(24px,2.6vw,36px);transition:transform .4s var(--ease-out),box-shadow .4s var(--ease-out),border-color .3s}
.info-card:hover{transform:translateY(-4px);border-color:var(--line-strong);box-shadow:0 22px 50px -30px rgba(26,23,20,.4)}
.info-card h3{font-size:clamp(1.25rem,2vw,1.65rem);margin-bottom:12px;letter-spacing:-.01em}
.info-card p{color:var(--ink-soft);font-size:15.5px;line-height:1.55}

/* ====== Header: menú desplegable (izquierda) + buscador predominante (centro) ====== */
.nav-menu{position:relative;flex-shrink:0}
.nav-menu-btn{display:inline-flex;align-items:center;gap:11px;height:44px;padding:0 18px;border:1px solid var(--line);border-radius:100px;background:var(--paper-card);color:var(--ink);font-family:var(--sans);font-weight:600;font-size:14.5px;letter-spacing:.005em;cursor:pointer;transition:border-color .3s,background .3s,transform .2s}
.nav-menu-btn:hover{border-color:var(--line-strong);transform:translateY(-1px)}
.nav-menu-btn .nm-bars{display:inline-flex;flex-direction:column;gap:3.6px}
.nav-menu-btn .nm-bars span{height:1.7px;background:currentColor;border-radius:2px;transition:transform .3s var(--ease-out),opacity .25s,width .3s}
.nav-menu-btn .nm-bars span:nth-child(1){width:17px}.nav-menu-btn .nm-bars span:nth-child(2){width:12px}.nav-menu-btn .nm-bars span:nth-child(3){width:17px}
.nav-menu.open .nm-bars span:nth-child(1){transform:translateY(5.3px) rotate(45deg)}
.nav-menu.open .nm-bars span:nth-child(2){opacity:0}
.nav-menu.open .nm-bars span:nth-child(3){transform:translateY(-5.3px) rotate(-45deg);width:17px}
.nav-menu-panel{position:absolute;top:calc(100% + 12px);left:0;min-width:300px;max-width:calc(100vw - 40px);background:var(--paper);border:1px solid var(--line);border-radius:14px;box-shadow:0 30px 70px -36px rgba(26,23,20,.5);padding:10px;opacity:0;transform:translateY(-10px);pointer-events:none;transition:opacity .28s var(--ease-out),transform .28s var(--ease-out);z-index:120}
.nav-menu.open .nav-menu-panel{opacity:1;transform:none;pointer-events:auto}
.nav-menu-panel a{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:13px 16px;border-radius:9px;font-family:var(--serif);font-size:1.16rem;font-weight:500;color:var(--ink);letter-spacing:-.006em;transition:background .2s,color .2s}
.nav-menu-panel a:hover{background:var(--paper-2);color:var(--clay)}
.nav-menu-panel a[aria-current="page"]{color:var(--clay)}
.nav-menu-panel a::after{content:"→";color:var(--clay);font-size:.9em;opacity:0;transform:translateX(-5px);transition:opacity .2s,transform .2s}
.nav-menu-panel a:hover::after{opacity:1;transform:none}
.nav-menu-panel .nmp-sep{height:1px;background:var(--line-soft);margin:9px 6px}
.nav-menu-panel .nmp-cta{display:flex;gap:10px;padding:4px 6px 6px}
.nav-menu-panel .nmp-cta .btn{flex:1;justify-content:center;padding:11px 16px}
/* buscador predominante */
.header-search{position:relative;flex:1 1 auto;min-width:0;max-width:720px;margin:0 clamp(12px,2vw,28px)}
.header-search-box{display:flex;align-items:center;gap:13px;height:48px;padding:0 20px;background:var(--paper-card);border:1px solid var(--line);border-radius:100px;transition:border-color .3s,box-shadow .3s,background .3s}
.header-search.focus .header-search-box{border-color:var(--clay);background:var(--paper);box-shadow:0 10px 30px -16px rgba(181,87,63,.4)}
.header-search-box svg{width:19px;height:19px;stroke:var(--ink-mute);fill:none;stroke-width:1.8;stroke-linecap:round;flex-shrink:0;transition:stroke .3s}
.header-search.focus .header-search-box svg{stroke:var(--clay)}
.header-search-box input{flex:1;min-width:0;border:0;background:transparent;font-family:var(--sans);font-size:15.5px;color:var(--ink);outline:none}
.header-search-box input::placeholder{color:var(--ink-mute);opacity:.85}
.header-search-box .hs-key{font-size:11px;color:var(--ink-mute);border:1px solid var(--line);border-radius:5px;padding:2px 7px;flex-shrink:0}
.header-search-results{position:absolute;top:calc(100% + 10px);left:0;right:0;background:var(--paper);border:1px solid var(--line);border-radius:14px;box-shadow:0 34px 80px -40px rgba(26,23,20,.55);padding:8px;max-height:min(64vh,470px);overflow:auto;opacity:0;transform:translateY(-10px);pointer-events:none;transition:opacity .25s var(--ease-out),transform .25s var(--ease-out);z-index:120}
.header-search.open .header-search-results{opacity:1;transform:none;pointer-events:auto}
.header-search-results .sr{display:flex;align-items:center;gap:16px;padding:13px 18px;border-radius:10px;cursor:pointer;transition:background .2s;color:inherit}
.header-search-results .sr:hover,.header-search-results .sr.active{background:var(--paper-2)}
.header-search-results .sr-body{flex:1;min-width:0}
.header-search-results .sr-t{font-family:var(--serif);font-size:1.05rem;font-weight:500;color:var(--ink);letter-spacing:-.005em}
.header-search-results .sr-d{font-size:13px;color:var(--ink-mute);margin-top:3px;line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.header-search-results .sr-arr{color:var(--clay);font-size:18px;opacity:0;transform:translateX(-4px);transition:opacity .2s,transform .2s}
.header-search-results .sr:hover .sr-arr,.header-search-results .sr.active .sr-arr{opacity:1;transform:none}
.header-search-results .sr-empty{padding:30px 18px;color:var(--ink-mute);font-size:14px;text-align:center}
.header-search-results mark{background:rgba(201,162,39,.28);color:inherit;border-radius:2px;padding:0 1px}
@media(min-width:881px){.nav-menu-panel .nmp-cta,.nav-menu-panel .nmp-sep{display:none}}
@media(max-width:880px){
  .nav-cta{display:none}
  .nav-menu-btn .nm-label{display:none}.nav-menu-btn{padding:0;width:44px;justify-content:center;gap:0}
  .header-search{margin:0 10px}.header-search-box .hs-key{display:none}
  .brand .tag{display:none}
}
@media(max-width:520px){.header-search-box{height:44px}.brand .name{font-size:17px}}
@media(prefers-reduced-motion:reduce){.nav-menu-panel,.header-search-results{transition:opacity .2s}}
