/* ============================================================
   PEUSSO — sistema visual
   Base = dirección "Luz". Overrides por [data-dir] y [data-accent].
   Azul marino = estructura. Acento (rojo institucional) = energía.
   ============================================================ */

:root {
  /* palette */
  --bg:        #ffffff;
  --bg-soft:   #f6f7f9;
  --bg-navy:   #0a1f44;
  --navy:      #0a1f44;
  --navy-700:  #122c5c;
  --navy-500:  #2a4377;
  --ink:       #0c1730;
  --ink-soft:  #3a455c;
  --muted:     #717c92;
  --line:      #e6e9ef;
  --line-strong:#d2d7e0;
  --accent:    #e11b22;   /* rojo Peusso */
  --accent-700:#bf141b;
  --accent-tint:#fdecec;
  --on-navy-soft: #b9c4dc;

  /* type */
  --font-display: "Space Grotesk", "Helvetica Neue", Helvetica, Arial, sans-serif;
  --font-body:    "Hanken Grotesk", "Helvetica Neue", Helvetica, Arial, sans-serif;
  --font-mono:    "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;

  --display-weight: 600;
  --display-tracking: -0.025em;
  --display-leading: 0.98;
  --eyebrow-transform: uppercase;
  --eyebrow-font: var(--font-mono);

  /* shape & space */
  --radius:     16px;
  --radius-sm:  10px;
  --radius-lg:  26px;
  --maxw:       1240px;
  --gutter:     clamp(20px, 5vw, 56px);
  --section-pad: clamp(72px, 9vw, 150px);
  --card-bg: #ffffff;
  --card-border: 1px solid var(--line);
  --card-shadow: 0 1px 2px rgba(12,23,48,.04), 0 18px 40px -28px rgba(12,23,48,.22);
  --grid-lines: 0;
}

/* ---------- EDITORIAL ---------- */
[data-dir="editorial"] {
  --font-display: "Instrument Serif", Georgia, "Times New Roman", serif;
  --display-weight: 400;
  --display-tracking: -0.005em;
  --display-leading: 0.96;
  --eyebrow-transform: uppercase;
  --eyebrow-font: var(--font-body);
  --radius: 6px;
  --radius-sm: 4px;
  --radius-lg: 10px;
  --card-shadow: 0 1px 2px rgba(12,23,48,.05), 0 26px 50px -34px rgba(12,23,48,.26);
}

/* ---------- TÉCNICO ---------- */
[data-dir="tecnico"] {
  --font-display: "Space Grotesk", "Helvetica Neue", Helvetica, Arial, sans-serif;
  --display-weight: 500;
  --display-tracking: -0.03em;
  --bg-soft: #f4f5f7;
  --radius: 4px;
  --radius-sm: 3px;
  --radius-lg: 6px;
  --section-pad: clamp(64px, 7.5vw, 120px);
  --card-shadow: none;
  --card-border: 1px solid var(--line-strong);
  --grid-lines: 1;
}

/* ---------- ACCENTS ---------- */
[data-accent="red"]   { --accent:#e11b22; --accent-700:#bf141b; --accent-tint:#fdecec; }
[data-accent="amber"] { --accent:#e29521; --accent-700:#c47e12; --accent-tint:#fbf1df; }
[data-accent="cyan"]  { --accent:#1486c4; --accent-700:#0f6fa3; --accent-tint:#e4f2fa; }

/* ============================================================ */
* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 84px; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 17px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
::selection { background: var(--navy); color:#fff; }
a { color: inherit; text-decoration: none; }
img { display:block; max-width:100%; }
h1,h2,h3,h4 { font-family: var(--font-display); font-weight: var(--display-weight);
  letter-spacing: var(--display-tracking); line-height: var(--display-leading);
  margin:0; color: var(--navy); text-wrap: balance; }

.wrap { max-width: var(--maxw); margin:0 auto; padding-inline: var(--gutter); }
.eyebrow {
  font-family: var(--eyebrow-font);
  text-transform: var(--eyebrow-transform);
  letter-spacing: .16em;
  font-size: 12px;
  font-weight: 600;
  color: var(--accent);
  display:inline-flex; align-items:center; gap:10px;
}
.eyebrow::before { content:""; width:26px; height:1px; background: var(--accent); display:inline-block; }
.eyebrow.no-tick::before { display:none; }

.section { padding-block: var(--section-pad); position: relative; }
.section-head { max-width: 760px; }
.section-head h2 { font-size: clamp(30px, 4.4vw, 56px); margin-top: 18px; }
.section-head p { color: var(--ink-soft); font-size: clamp(16px,1.5vw,19px); margin: 20px 0 0; max-width: 60ch; }

/* buttons */
.btn { display:inline-flex; align-items:center; gap:10px; font-family: var(--font-body);
  font-weight:600; font-size:15px; padding:14px 24px; border-radius: 999px; cursor:pointer;
  border:1px solid transparent; transition: transform .18s ease, background .18s ease, color .18s ease, border-color .18s; white-space:nowrap; }
[data-dir="tecnico"] .btn, [data-dir="editorial"] .btn { border-radius: var(--radius-sm); }
.btn:active { transform: translateY(1px); }
.btn-primary { background: var(--navy); color:#fff; }
.btn-primary:hover { background: var(--navy-700); }
.btn-accent { background: var(--accent); color:#fff; }
.btn-accent:hover { background: var(--accent-700); }
.btn-ghost { background: transparent; color: var(--navy); border-color: var(--line-strong); }
.btn-ghost:hover { border-color: var(--navy); }
.btn .arr { transition: transform .2s ease; }
.btn:hover .arr { transform: translateX(3px); }

/* generic card */
.card { background: var(--card-bg); border: var(--card-border); border-radius: var(--radius); box-shadow: var(--card-shadow); }

/* reveal animation */
.reveal { opacity:0; transform: translateY(22px); transition: opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
.reveal.in { opacity:1; transform:none; }
.reveal[data-delay="1"]{ transition-delay:.07s } .reveal[data-delay="2"]{ transition-delay:.14s }
.reveal[data-delay="3"]{ transition-delay:.21s } .reveal[data-delay="4"]{ transition-delay:.28s }
.reveal[data-delay="5"]{ transition-delay:.35s }
@media (prefers-reduced-motion: reduce){ .reveal{opacity:1;transform:none;transition:none} html{scroll-behavior:auto} }

/* ============== NAV ============== */
.nav { position: sticky; top:0; z-index: 60; background: color-mix(in srgb, var(--bg) 82%, transparent);
  backdrop-filter: saturate(1.4) blur(14px); border-bottom:1px solid transparent; transition: border-color .3s, background .3s; }
.nav.scrolled { border-bottom-color: var(--line); }
.nav-in { display:flex; align-items:center; gap:32px; height:72px; }
.brand { display:flex; align-items:center; }
.brand-logo { height:30px; width:auto; display:block; }
.foot-brand .brand-logo { height:34px; }
.nav-links { display:flex; align-items:center; gap:30px; margin-left:8px; }
.nav-links a { font-size:14.5px; font-weight:500; color:var(--ink-soft); position:relative; padding:6px 0; }
.nav-links a:hover { color: var(--navy); }
.nav-links a::after { content:""; position:absolute; left:0; right:100%; bottom:0; height:2px; background:var(--accent); transition:right .25s ease; }
.nav-links a:hover::after { right:0; }
.nav-cta { margin-left:auto; display:flex; align-items:center; gap:14px; }
.nav-burger { display:none; }
@media (max-width: 920px){
  .nav-links { display:none; }
  .nav-cta .btn-ghost { display:none; }
}

/* ============== HERO ============== */
.hero { position:relative; overflow:hidden; padding-top: clamp(56px,8vw,104px); padding-bottom: clamp(48px,6vw,96px); }
.hero-grid { display:grid; grid-template-columns: 1.15fr .85fr; gap: clamp(28px,4vw,64px); align-items:center; }
.hero h1 { font-size: clamp(46px, 8vw, 104px); }
.hero h1 .lit { color: var(--accent); position:relative; }
.hero-lead { color:var(--ink-soft); font-size: clamp(17px,1.7vw,21px); max-width: 50ch; margin:26px 0 34px; }
.hero-cta { display:flex; gap:14px; flex-wrap:wrap; }
.hero-eyebrow { margin-bottom: 26px; }

/* light beam visual */
.beam { position:relative; aspect-ratio: 4/5; border-radius: var(--radius-lg); overflow:hidden;
  background: linear-gradient(180deg, #0a1f44, #060f25); box-shadow: 0 40px 80px -50px rgba(10,31,68,.6); }
.beam::before { content:""; position:absolute; inset:0;
  background:
    radial-gradient(120% 70% at 50% -10%, color-mix(in srgb, var(--accent) 55%, transparent), transparent 60%),
    radial-gradient(60% 50% at 70% 110%, rgba(120,160,255,.25), transparent 70%); }
.beam-grid { position:absolute; inset:0; background-image:
   linear-gradient(rgba(255,255,255,.06) 1px, transparent 1px),
   linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px);
   background-size: 42px 42px; mask-image: radial-gradient(80% 80% at 50% 30%, #000, transparent); }
.filament, .filament-h { position:absolute;
  background: linear-gradient(180deg, transparent, color-mix(in srgb,var(--accent) 80%,#fff) 45%, #fff 50%, color-mix(in srgb,var(--accent) 80%,#fff) 55%, transparent);
  filter: blur(.3px); box-shadow: 0 0 16px 2px color-mix(in srgb,var(--accent) 65%, transparent); opacity:0; }
.filament { top:0; height:100%; width:2px; left:50%; animation: scanX 12s ease-in-out infinite; }
.filament-h { left:0; width:100%; height:2px; top:50%; animation: scanY 12s ease-in-out infinite;
  background: linear-gradient(90deg, transparent, color-mix(in srgb,var(--accent) 80%,#fff) 45%, #fff 50%, color-mix(in srgb,var(--accent) 80%,#fff) 55%, transparent); }
@keyframes scanX {
  0%{ left:12%; opacity:0 } 3%{ opacity:1 } 22%{ left:88%; opacity:1 }
  26%{ left:50%; opacity:0 } 54%{ left:50%; opacity:0 }
  58%{ left:50%; opacity:1 } 78%{ left:50%; opacity:1 }
  86%{ left:50%; opacity:0 } 100%{ left:12%; opacity:0 } }
@keyframes scanY {
  0%{ top:10%; opacity:0 } 28%{ top:10%; opacity:0 } 31%{ opacity:1 }
  50%{ top:90%; opacity:1 } 54%{ top:50%; opacity:0 }
  58%{ top:50%; opacity:1 } 78%{ top:50%; opacity:1 }
  86%{ top:50%; opacity:0 } 100%{ top:50%; opacity:0 } }
.spark { position:absolute; left:50%; top:50%; width:14px; height:14px; transform:translate(-50%,-50%); border-radius:50%;
  background:#fff; box-shadow:0 0 30px 10px color-mix(in srgb,var(--accent) 70%,#fff), 0 0 80px 30px color-mix(in srgb,var(--accent) 40%, transparent); animation: pulse 3.4s ease-in-out infinite; }
@keyframes pulse { 0%,100%{ transform:translate(-50%,-50%) scale(1); opacity:.95 } 50%{ transform:translate(-50%,-50%) scale(1.5); opacity:1 } }
.beam-readout { position:absolute; left:18px; bottom:18px; right:18px; font-family:var(--font-mono); font-size:11px; color:var(--on-navy-soft);
  display:flex; justify-content:space-between; letter-spacing:.04em; }
.beam-tag { position:absolute; top:18px; left:18px; font-family:var(--font-mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:#fff; opacity:.7;}

@media (max-width: 860px){ .hero-grid{ grid-template-columns:1fr; } .beam{ aspect-ratio: 16/11; } }

/* hero stat strip */
.stats { display:grid; grid-template-columns: repeat(4,1fr); gap:1px; background:var(--line); border-block:1px solid var(--line); margin-top: clamp(40px,5vw,72px); }
.stat { background:var(--bg); padding: 26px var(--gutter) 26px 0; }
.stat:first-child{ padding-left:0 }
.stat .n { font-family:var(--font-display); font-weight:var(--display-weight); font-size: clamp(28px,3.4vw,42px); color:var(--navy); letter-spacing:-.02em; }
.stat .l { font-size:13.5px; color:var(--muted); margin-top:4px; }
.stat .n em { font-style:normal; color:var(--accent); }
@media (max-width:780px){ .stats{ grid-template-columns:repeat(2,1fr);} .stat{ padding:20px; } .stat:first-child{padding-left:20px} }

/* ============== SOLUCIONES ============== */
.sol-grid { display:grid; grid-template-columns: repeat(12,1fr); gap:18px; margin-top:56px; }
.sol { grid-column: span 4; padding: 30px; display:flex; flex-direction:column; min-height: 290px; transition: transform .25s ease, box-shadow .25s ease, border-color .25s; }
.sol:hover { transform: translateY(-4px); box-shadow: 0 30px 60px -36px rgba(10,31,68,.4); border-color: var(--line-strong); }
.sol.feature { grid-column: span 6; background: var(--navy); border-color:transparent; color:#fff; }
.sol.feature h3, .sol.feature .sol-k { color:#fff; }
.sol.feature p { color: var(--on-navy-soft); }
.sol.wide { grid-column: span 6; }
.sol-k { font-family:var(--font-mono); font-size:12px; letter-spacing:.1em; color:var(--muted); }
.sol .ico { width:42px; height:42px; border-radius:11px; display:grid; place-items:center; background:var(--accent-tint); color:var(--accent); margin-bottom:auto; }
.sol.feature .ico { background: rgba(255,255,255,.12); color:#fff; }
.sol h3 { font-size:23px; margin:20px 0 10px; }
.sol p { color:var(--ink-soft); font-size:15px; margin:0; }
.sol .more { margin-top:18px; font-weight:600; font-size:14px; color:var(--accent); display:inline-flex; gap:7px; align-items:center; }
.sol.feature .more { color:#fff; }
@media (max-width:900px){ .sol, .sol.feature, .sol.wide { grid-column: span 6; } }
@media (max-width:620px){ .sol, .sol.feature, .sol.wide { grid-column: 1 / -1; min-height:0; } }

/* ============== AI DEMO ============== */
.ai { background: var(--bg-navy); color:#fff; border-radius: 0; position:relative; overflow:hidden; }
.ai::before { content:""; position:absolute; inset:0; background:
   radial-gradient(60% 60% at 85% 0%, color-mix(in srgb,var(--accent) 30%, transparent), transparent 60%),
   radial-gradient(50% 50% at 0% 100%, rgba(90,140,255,.18), transparent 70%); pointer-events:none; }
.ai .wrap { position:relative; }
.ai h2 { color:#fff; }
.ai .section-head p { color: var(--on-navy-soft); }
.ai-grid { display:grid; grid-template-columns: .9fr 1.1fr; gap: clamp(30px,5vw,70px); align-items:center; margin-top:54px; }
.ai-points { list-style:none; padding:0; margin:30px 0 0; display:flex; flex-direction:column; gap:18px; }
.ai-points li { display:flex; gap:14px; align-items:flex-start; color:var(--on-navy-soft); font-size:15.5px; }
.ai-points .dot { width:22px;height:22px;flex:none;border-radius:50%; background:rgba(255,255,255,.08); display:grid;place-items:center; color:var(--accent); margin-top:1px; }
[data-accent] .ai-points .dot { color: color-mix(in srgb, var(--accent) 70%, #fff); }
.ai-points b { color:#fff; font-weight:600; }

.chat { background: rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.12); border-radius:18px; padding:20px; backdrop-filter: blur(6px);
  box-shadow: 0 40px 90px -50px rgba(0,0,0,.8); }
.chat-top { display:flex; align-items:center; gap:10px; padding-bottom:16px; border-bottom:1px solid rgba(255,255,255,.1); margin-bottom:18px; }
.chat-top .av { width:30px;height:30px;border-radius:9px; background:var(--accent); display:grid; place-items:center; color:#fff; font-family:var(--font-display); font-weight:700; font-size:14px; }
.chat-top .t { font-size:14px; font-weight:600; }
.chat-top .s { font-family:var(--font-mono); font-size:11px; color:#7fe0a8; display:flex; align-items:center; gap:6px; margin-left:auto; }
.chat-top .s::before{ content:""; width:7px;height:7px;border-radius:50%; background:#43d17f; box-shadow:0 0 10px #43d17f; }
.bubble { max-width:84%; padding:12px 15px; border-radius:14px; font-size:14.5px; line-height:1.5; margin-bottom:12px; }
.bubble.user { margin-left:auto; background:var(--accent); color:#fff; border-bottom-right-radius:5px; }
.bubble.bot { background:rgba(255,255,255,.08); color:#eaf0ff; border-bottom-left-radius:5px; border:1px solid rgba(255,255,255,.08); }
.bubble.bot .prod { display:flex; gap:12px; align-items:center; margin-top:12px; padding:11px; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1); border-radius:10px; }
.prod .ph { width:44px;height:44px;border-radius:7px; flex:none; background:
   repeating-linear-gradient(135deg, rgba(255,255,255,.12) 0 6px, rgba(255,255,255,.04) 6px 12px); }
.prod .pn { font-weight:600; font-size:13px; }
.prod .pp { font-family:var(--font-mono); font-size:12px; color:#7fe0a8; }
.prod .stk { margin-left:auto; font-family:var(--font-mono); font-size:11px; color:var(--on-navy-soft); }
.typing { display:inline-flex; gap:4px; padding:13px 15px; }
.typing span { width:7px;height:7px;border-radius:50%; background:rgba(255,255,255,.5); animation: blink 1.2s infinite; }
.typing span:nth-child(2){ animation-delay:.2s } .typing span:nth-child(3){ animation-delay:.4s }
@keyframes blink { 0%,60%,100%{ opacity:.3; transform:translateY(0) } 30%{ opacity:1; transform:translateY(-3px) } }
.chat-input { display:flex; align-items:center; gap:10px; margin-top:6px; padding:11px 13px; border-radius:12px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); }
.chat-input .ph-text { flex:1; color:var(--on-navy-soft); font-size:14px; }
.chat-input .send { width:32px;height:32px;border-radius:9px; background:var(--accent); display:grid; place-items:center; color:#fff; flex:none; }
.caret { display:inline-block; width:2px; height:1em; background:currentColor; margin-left:2px; vertical-align:-2px; animation: caret 1s step-end infinite; }
@keyframes caret { 50%{ opacity:0 } }
@media (max-width:840px){ .ai-grid{ grid-template-columns:1fr; } }

/* ============== TRAYECTORIA ============== */
.trj { display:grid; grid-template-columns: .8fr 1.2fr; gap:clamp(30px,5vw,70px); margin-top:56px; align-items:start; }
.tl { border-left:2px solid var(--line); display:flex; flex-direction:column; gap:2px; }
.tl-item { position:relative; padding:0 0 30px 28px; }
.tl-item::before { content:""; position:absolute; left:-7px; top:4px; width:12px;height:12px;border-radius:50%; background:var(--bg); border:2px solid var(--line-strong); }
.tl-item.hot::before { background:var(--accent); border-color:var(--accent); box-shadow:0 0 0 4px var(--accent-tint); }
.tl-item .y { font-family:var(--font-mono); font-size:13px; color:var(--accent); font-weight:600; }
.tl-item .h { font-family:var(--font-display); font-weight:var(--display-weight); color:var(--navy); font-size:17px; margin:4px 0 4px; }
.tl-item p { margin:0; font-size:14.5px; color:var(--ink-soft); }
.trj-aside .big-n { font-family:var(--font-display); font-weight:var(--display-weight); font-size:clamp(70px,10vw,120px); color:var(--navy); line-height:.9; letter-spacing:-.04em; }
.trj-aside .big-n em{ color:var(--accent); font-style:normal; }
.cert { display:flex; gap:14px; align-items:center; margin-top:30px; padding:18px; }
.cert .seal { width:54px;height:54px; border-radius:50%; border:2px solid var(--accent); color:var(--accent); display:grid;place-items:center; font-family:var(--font-mono); font-weight:700; font-size:12px; flex:none; text-align:center; line-height:1.05; }
.cert .ct { font-size:14px; color:var(--ink-soft); }
.cert .ct b{ color:var(--navy); display:block; font-family:var(--font-display); }
@media (max-width:820px){ .trj{ grid-template-columns:1fr; } }

/* ============== OBRAS ============== */
.obras-grid { display:grid; grid-template-columns: repeat(12,1fr); gap:16px; margin-top:54px; }
.obra { grid-column: span 4; border-radius:var(--radius); overflow:hidden; position:relative; aspect-ratio:4/3; background:var(--navy); }
.obra.tall { grid-column: span 4; }
.obra.big { grid-column: span 8; aspect-ratio:16/9; }
.obra .ph { position:absolute; inset:0; background:
   repeating-linear-gradient(135deg, #16305f 0 14px, #112650 14px 28px); }
.obra .ph::after { content: attr(data-ph); position:absolute; inset:0; display:grid; place-items:center; font-family:var(--font-mono); font-size:11px; letter-spacing:.1em; color:rgba(255,255,255,.4); text-transform:uppercase; }
.obra .grad { position:absolute; inset:0; background:linear-gradient(180deg, transparent 40%, rgba(7,15,37,.85)); }
.obra .meta { position:absolute; left:20px; right:20px; bottom:18px; color:#fff; }
.obra .meta .k { font-family:var(--font-mono); font-size:11px; letter-spacing:.1em; color:var(--on-navy-soft); text-transform:uppercase; }
.obra .meta .h { font-family:var(--font-display); font-weight:var(--display-weight); font-size:19px; margin-top:5px; }
.obra:hover .ph { transform:scale(1.04); }
.obra .ph { transition: transform .5s ease; }
@media (max-width:900px){ .obra, .obra.big, .obra.tall { grid-column: span 6; aspect-ratio:4/3; } }
@media (max-width:560px){ .obra, .obra.big, .obra.tall { grid-column: 1/-1; } }

/* ============== LOGÍSTICA ============== */
.log { background:var(--bg-soft); }
.log-grid2 { display:grid; grid-template-columns: 1fr 1fr; gap:clamp(30px,5vw,64px); align-items:stretch; margin-top:54px; }
.log-side { display:flex; flex-direction:column; gap:16px; justify-content:center; }
.log-card { padding:24px; }
.log-card .n { font-family:var(--font-display); font-weight:var(--display-weight); font-size:34px; color:var(--navy); letter-spacing:-.02em; }
.log-card .n em{ color:var(--accent); font-style:normal; }
.log-card .l { font-size:13.5px; color:var(--ink-soft); margin-top:6px; }

.map { border-radius:var(--radius-lg); background:var(--navy); position:relative; overflow:hidden; padding:22px; display:flex; flex-direction:column;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.05), 0 40px 80px -50px rgba(10,31,68,.7); }
.map::before { content:""; position:absolute; inset:0; background-image:
   linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px), linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px);
   background-size:30px 30px; mask-image:radial-gradient(90% 80% at 50% 45%, #000, transparent); }
.map-frame { position:relative; flex:1; min-height:0; display:flex; align-items:center; justify-content:center; padding:6px 0; }

/* 3 capas: panel (fondo) + img (silueta) + puntos */
.ar-stage { position:relative; width:100%; max-width:440px; margin:0 auto; aspect-ratio:448/550; }
.ar-img { position:absolute; inset:0; width:100%; height:100%; object-fit:contain; opacity:.88;
  filter: drop-shadow(0 0 12px rgba(255,255,255,.12)); }
.ar-pt { position:absolute; width:0; height:0; transform:translate(-50%,-50%); z-index:2; transition:none; }
.ar-pt .dot { position:absolute; left:0; top:0; width:10px; height:10px; border-radius:50%; background:#fff;
  transform:translate(-50%,-50%); box-shadow:0 0 0 3px rgba(10,31,68,.55), 0 0 9px rgba(255,255,255,.55); }
.ar-pt.hub .dot { width:15px; height:15px; background:var(--accent);
  box-shadow:0 0 0 4px rgba(10,31,68,.55), 0 0 16px color-mix(in srgb,var(--accent) 75%,transparent); }
.ar-pt .ring { position:absolute; left:0; top:0; width:15px; height:15px; border-radius:50%;
  border:1.5px solid var(--accent); transform:translate(-50%,-50%); transform-origin:center;
  animation: ping 3s ease-out infinite; }
@keyframes ping { 0%{ transform:translate(-50%,-50%) scale(.7); opacity:.85 } 100%{ transform:translate(-50%,-50%) scale(3.4); opacity:0 } }
.ar-pt .lbl { position:absolute; top:50%; left:14px; transform:translateY(-50%); white-space:nowrap;
  font-family:var(--font-mono); font-size:11.5px; letter-spacing:.02em; color:var(--on-navy-soft); }
.ar-pt.lbl-l .lbl { left:auto; right:14px; }
.ar-pt.hub .lbl { left:18px; color:#fff; font-weight:600; font-size:13px; }
.map-foot { position:relative; display:flex; justify-content:space-between; font-family:var(--font-mono); font-size:10.5px; letter-spacing:.08em;
  color:var(--on-navy-soft); text-transform:uppercase; padding-top:14px; margin-top:6px; border-top:1px solid rgba(255,255,255,.1); }
@media (max-width:820px){ .log-grid2{ grid-template-columns:1fr; } .log-side{ flex-direction:row; flex-wrap:wrap; } .log-side .log-card{ flex:1 1 44%; } }
@media (max-width:520px){ .log-side .log-card{ flex:1 1 100%; } .ar-pt .lbl{ font-size:10.5px; } }

/* ============== CONTACTO ============== */
.cta-band { background:var(--navy); color:#fff; border-radius:var(--radius-lg); padding: clamp(36px,5vw,64px); display:grid; grid-template-columns:1.2fr 1fr; gap:40px; align-items:center; }
.cta-band h2 { color:#fff; font-size:clamp(28px,3.6vw,46px); }
.cta-band p { color:var(--on-navy-soft); margin:16px 0 0; }
.form { display:flex; flex-direction:column; gap:12px; }
.form .row { display:flex; gap:12px; }
.form input, .form textarea { width:100%; font-family:var(--font-body); font-size:15px; padding:14px 16px; border-radius:12px; border:1px solid rgba(255,255,255,.18); background:rgba(255,255,255,.06); color:#fff; }
.form input::placeholder, .form textarea::placeholder { color:var(--on-navy-soft); }
.form input:focus, .form textarea:focus { outline:none; border-color:var(--accent); }
[data-dir="tecnico"] .form input, [data-dir="tecnico"] .form textarea, [data-dir="editorial"] .form input, [data-dir="editorial"] .form textarea { border-radius:var(--radius-sm); }
@media (max-width:780px){ .cta-band{ grid-template-columns:1fr; } }

.branches { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:48px; }
.branch { padding:22px; }
.branch .city { font-family:var(--font-display); font-weight:var(--display-weight); color:var(--navy); font-size:18px; }
.branch .k { font-family:var(--font-mono); font-size:11px; color:var(--accent); letter-spacing:.1em; text-transform:uppercase; }
.branch p { margin:8px 0 0; font-size:14px; color:var(--ink-soft); }
@media (max-width:760px){ .branches{ grid-template-columns:1fr; } }

/* ============== FOOTER ============== */
.foot { border-top:1px solid var(--line); padding-block:56px 36px; }
.foot-grid { display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap:30px; }
.foot h5 { font-family:var(--font-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); margin:0 0 16px; font-weight:600; }
.foot a { display:block; color:var(--ink-soft); font-size:14.5px; padding:5px 0; }
.foot a:hover { color:var(--accent); }
.foot-brand p { color:var(--muted); font-size:14px; max-width:34ch; margin:16px 0 0; }
.foot-bottom { display:flex; justify-content:space-between; align-items:center; gap:16px; margin-top:46px; padding-top:24px; border-top:1px solid var(--line); color:var(--muted); font-size:13px; flex-wrap:wrap; }
.foot-bottom .iso { font-family:var(--font-mono); }
@media (max-width:780px){ .foot-grid{ grid-template-columns:1fr 1fr; gap:28px; } }

/* disable motion / light fx */
.no-fx .spark, .no-fx .ar-pt .ring { animation: none !important; }
.no-fx .ar-pt .ring { display:none; }
.no-fx .filament, .no-fx .filament-h { animation:none; opacity:.55; left:50%; top:50%; }
.no-fx .spark { box-shadow: 0 0 22px 6px color-mix(in srgb,var(--accent) 55%,#fff); }
.no-fx .reveal { transition-duration: .25s; }

/* técnico grid overlay accents */
[data-dir="tecnico"] .section { border-top:1px solid var(--line); }
[data-dir="tecnico"] .eyebrow { color:var(--accent); }
[data-dir="tecnico"] .sol-k, [data-dir="tecnico"] .stat .l { letter-spacing:.06em; }
