/* ============================================================
   Aurea Legal — Design System
   Dark navy base · electric-blue primary · warm-gold accent
   ============================================================ */

:root {
  /* ---- Type families (swapped by Tweaks) ---- */
  --font-display: "Schibsted Grotesk", "Helvetica Neue", Arial, sans-serif;
  --font-body: "Schibsted Grotesk", "Helvetica Neue", Arial, sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, "SFMono-Regular", monospace;
  --display-weight: 420;
  --display-tracking: -0.03em;

  /* ---- Accent (hue driven by Tweaks) ---- */
  --accent-h: 248;
  --accent: oklch(0.67 0.155 var(--accent-h));
  --accent-bright: oklch(0.76 0.14 var(--accent-h));
  --accent-deep: oklch(0.52 0.16 var(--accent-h));
  --warm: oklch(0.82 0.105 72);          /* warm-gold secondary */
  --warm-dim: oklch(0.72 0.09 72);

  /* ---- Neutrals (cool navy) ---- */
  --bg-deep: oklch(0.135 0.028 262);
  --bg-base: oklch(0.165 0.032 260);
  --bg-raise: oklch(0.205 0.034 258);
  --ink: oklch(0.97 0.006 250);
  --ink-dim: oklch(0.80 0.02 250);
  --ink-faint: oklch(0.62 0.026 252);
  --ink-ghost: oklch(0.50 0.028 254);

  --line: color-mix(in oklch, var(--ink) 12%, transparent);
  --line-soft: color-mix(in oklch, var(--ink) 7%, transparent);
  --glass: color-mix(in oklch, var(--ink) 5%, transparent);
  --glass-raise: color-mix(in oklch, var(--ink) 8%, transparent);

  --maxw: 1220px;
  --pad: clamp(20px, 5vw, 72px);
  --radius: 18px;
  --radius-lg: 26px;
}

/* ============================================================
   Reset / base
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-body);
  background: var(--bg-deep);
  color: var(--ink);
  font-size: 17px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  letter-spacing: var(--display-tracking);
  line-height: 1.02;
  margin: 0;
  text-wrap: balance;
}
p { margin: 0; text-wrap: pretty; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
::selection { background: color-mix(in oklch, var(--accent) 40%, transparent); color: var(--ink); }

/* ============================================================
   Shared atoms
   ============================================================ */
.wrap { width: 100%; max-width: var(--maxw); margin: 0 auto; padding-inline: var(--pad); }

.eyebrow {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-faint);
  display: inline-flex;
  align-items: center;
  gap: 0.7em;
}
.eyebrow::before {
  content: "";
  width: 22px; height: 1px;
  background: linear-gradient(90deg, var(--accent), transparent);
}
.eyebrow--num::before { display: none; }
.eyebrow--num { color: var(--ink-ghost); }
.eyebrow--num b { color: var(--accent-bright); font-weight: 500; }

.lede { color: var(--ink-dim); font-size: clamp(1.05rem, 1.5vw, 1.3rem); line-height: 1.55; max-width: 56ch; }

.section { position: relative; padding-block: clamp(80px, 11vw, 160px); }
.section__head { max-width: 760px; }
.section__head .eyebrow { margin-bottom: 26px; }
.section-title { font-size: clamp(2.1rem, 4.6vw, 3.7rem); }
.section-title em { font-style: normal; color: var(--ink-faint); }
.section__head p { margin-top: 24px; }

/* hairline grid decoration */
.hairlines { position: absolute; inset: 0; pointer-events: none; overflow: hidden; z-index: 0; }
.hairlines span { position: absolute; top: 0; bottom: 0; width: 1px; background: var(--line-soft); }

/* Pills / buttons */
.btn {
  display: inline-flex; align-items: center; gap: 14px;
  padding: 9px 9px 9px 24px;
  border-radius: 999px;
  font-size: 0.95rem; font-weight: 500;
  border: 1px solid var(--line);
  background: var(--glass);
  color: var(--ink);
  cursor: pointer;
  transition: border-color .3s, background .3s, transform .3s;
  backdrop-filter: blur(10px);
}
.btn .ico {
  width: 34px; height: 34px; border-radius: 50%;
  display: grid; place-items: center;
  background: var(--accent); color: #06101f;
  transition: transform .35s cubic-bezier(.2,.8,.2,1), background .3s;
}
.btn:hover { border-color: color-mix(in oklch, var(--accent) 55%, transparent); transform: translateY(-2px); }
.btn:hover .ico { transform: translateX(3px); background: var(--accent-bright); }
.btn--solid { background: var(--accent); border-color: transparent; color: #06101f; padding-left: 26px; }
.btn--solid .ico { background: #06101f; color: var(--accent-bright); }
.btn--solid:hover { background: var(--accent-bright); }
.btn--ghost { background: transparent; }

.chip {
  display: inline-flex; align-items: center; gap: 9px;
  padding: 7px 16px 7px 12px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: var(--glass);
  font-family: var(--font-mono);
  font-size: 0.72rem; letter-spacing: 0.06em;
  color: var(--ink-dim);
  backdrop-filter: blur(8px);
}
.chip .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 10px var(--accent); }
.chip .dot--warm { background: var(--warm); box-shadow: 0 0 10px var(--warm); }

.card {
  position: relative;
  background: var(--glass);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  backdrop-filter: blur(16px);
}

/* glows */
.glow { position: absolute; border-radius: 50%; filter: blur(90px); pointer-events: none; opacity: var(--glow-strength, 1); z-index: 0; }

/* starfield + crosshairs */
.starfield { position: absolute; inset: 0; pointer-events: none; z-index: 0; opacity: calc(0.9 * var(--glow-strength, 1)); }
.cross { position: absolute; width: 16px; height: 16px; opacity: 0.55; }
.cross::before, .cross::after { content: ""; position: absolute; background: color-mix(in oklch, var(--ink) 45%, transparent); }
.cross::before { left: 50%; top: 0; bottom: 0; width: 1px; transform: translateX(-50%); }
.cross::after { top: 50%; left: 0; right: 0; height: 1px; transform: translateY(-50%); }

/* image placeholders */
image-slot { display: block; }
.ph {
  position: relative; overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background:
    repeating-linear-gradient(135deg,
      color-mix(in oklch, var(--ink) 4%, transparent) 0 10px,
      transparent 10px 20px),
    var(--bg-raise);
}
.ph__tag {
  position: absolute; left: 14px; bottom: 12px;
  font-family: var(--font-mono); font-size: 0.66rem;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--ink-ghost);
}

/* ============================================================
   Header
   ============================================================ */
.site-head {
  position: fixed; top: 0; left: 0; right: 0; z-index: 50;
  transition: background .4s, border-color .4s, backdrop-filter .4s;
  border-bottom: 1px solid transparent;
}
.site-head.scrolled {
  background: color-mix(in oklch, var(--bg-deep) 72%, transparent);
  backdrop-filter: blur(18px) saturate(1.2);
  border-bottom-color: var(--line-soft);
}
.site-head__inner { display: flex; align-items: center; justify-content: space-between; height: 74px; }
.brand { display: flex; align-items: center; gap: 11px; font-family: var(--font-display); font-size: 1.18rem; letter-spacing: -0.02em; }
.brand b { font-weight: 600; }
.brand .mark { width: 26px; height: 26px; position: relative; flex: none; }
.brand .mark::before, .brand .mark::after { content:""; position:absolute; inset:0; border-radius: 7px; }
.brand .mark::before { background: conic-gradient(from 210deg, var(--accent), var(--warm), var(--accent)); opacity: .9; }
.brand .mark::after { inset: 6px; border-radius: 4px; background: var(--bg-deep); }
.nav { display: flex; align-items: center; gap: 34px; }
.nav a { font-size: 0.92rem; color: var(--ink-dim); transition: color .25s; }
.nav a:hover { color: var(--ink); }
.nav-cta { display: inline-flex; }
@media (max-width: 880px){ .nav .nav-links { display: none; } }

/* ============================================================
   Hero
   ============================================================ */
.hero { position: relative; padding-top: 150px; padding-bottom: clamp(70px,9vw,130px); overflow: hidden; min-height: 100svh; display: flex; align-items: center; }
.hero__bg { position: absolute; inset: 0; z-index: 0; background:
   radial-gradient(120% 90% at 50% -10%, color-mix(in oklch, var(--accent-deep) 30%, transparent), transparent 60%),
   radial-gradient(80% 60% at 85% 110%, color-mix(in oklch, var(--bg-base) 90%, transparent), transparent 70%),
   linear-gradient(180deg, var(--bg-deep), var(--bg-base) 55%, var(--bg-deep)); }
.hero .glow--1 { width: 620px; height: 620px; top: -180px; left: 50%; transform: translateX(-50%); background: radial-gradient(circle, color-mix(in oklch, var(--accent) 55%, transparent), transparent 65%); }
.hero .glow--2 { width: 360px; height: 360px; bottom: -120px; right: 4%; background: radial-gradient(circle, color-mix(in oklch, var(--warm) 32%, transparent), transparent 68%); }

.hero__inner { position: relative; z-index: 2; width: 100%; }
.hero__grid { display: grid; grid-template-columns: 1.15fr 0.85fr; gap: clamp(28px, 4vw, 60px); align-items: center; }
.hero__top { display: flex; align-items: center; gap: 14px; margin-bottom: 30px; flex-wrap: wrap; }
.hero h1 { font-size: clamp(2.7rem, 6.4vw, 5.7rem); letter-spacing: -0.035em; }
.hero h1 .soft { color: var(--ink-faint); }
.hero h1 .accent { color: var(--accent-bright); }
.hero__sub { margin-top: 30px; max-width: 50ch; }
.hero__cta { margin-top: 42px; display: flex; align-items: center; gap: 18px; flex-wrap: wrap; }
.hero__meta { margin-top: 54px; display: flex; gap: 40px; flex-wrap: wrap; }
.hero__meta .stat .n { font-family: var(--font-display); font-size: 1.9rem; letter-spacing: -0.02em; display: block; }
.hero__meta .stat .l { font-size: 0.82rem; color: var(--ink-faint); margin-top: 4px; }

/* hero visual stack */
.hero__visual { position: relative; aspect-ratio: 4/5; min-height: 360px; }
.hero__visual .card-float {
  position: absolute; border-radius: 20px;
  background: linear-gradient(150deg, color-mix(in oklch, var(--accent) 28%, var(--bg-raise)), color-mix(in oklch, var(--bg-raise) 92%, transparent));
  border: 1px solid color-mix(in oklch, var(--ink) 16%, transparent);
  box-shadow: 0 40px 90px -30px color-mix(in oklch, var(--accent) 60%, transparent), inset 0 1px 0 color-mix(in oklch, var(--ink) 22%, transparent);
  backdrop-filter: blur(6px);
}
.hero__visual .cf-1 { inset: 8% 18% 30% 6%; transform: rotate(-9deg); animation: floaty 7s ease-in-out infinite; }
.hero__visual .cf-2 { inset: 22% 4% 14% 26%; transform: rotate(7deg); background: linear-gradient(150deg, color-mix(in oklch, var(--warm) 18%, var(--bg-raise)), color-mix(in oklch, var(--bg-deep) 90%, transparent)); animation: floaty 8s ease-in-out infinite reverse; }
.hero__visual .panel {
  position: absolute; right: -4%; bottom: 2%; width: 58%;
  border-radius: 16px; padding: 16px; z-index: 3;
}
@keyframes floaty { 0%,100%{ translate: 0 0; } 50%{ translate: 0 -14px; } }

.hero__visual .mini {
  position: absolute; z-index: 4;
}
.mini-stat { left: -6%; top: 30%; }
@media (max-width: 860px){
  .hero__grid { grid-template-columns: 1fr; }
  .hero__visual { display: none; }
  body[data-hero="split"] .hero__visual { display: none; }
}

/* hero variant: centered */
body[data-hero="centered"] .hero__grid { grid-template-columns: 1fr; text-align: center; justify-items: center; }
body[data-hero="centered"] .hero__visual { display: none; }
body[data-hero="centered"] .hero__top,
body[data-hero="centered"] .hero__cta,
body[data-hero="centered"] .hero__meta { justify-content: center; }
body[data-hero="centered"] .hero__sub { margin-inline: auto; }
body[data-hero="centered"] .hero h1 { font-size: clamp(2.9rem, 8vw, 6.4rem); max-width: 16ch; }

/* hero variant: editorial (text only, left) */
body[data-hero="editorial"] .hero__grid { grid-template-columns: 1fr; }
body[data-hero="editorial"] .hero__visual { display: none; }
body[data-hero="editorial"] .hero h1 { font-size: clamp(3rem, 9vw, 7rem); max-width: 15ch; }

/* ============================================================
   Agente — chat
   ============================================================ */
.agent { background: linear-gradient(180deg, var(--bg-deep), var(--bg-base)); }
.agent__grid { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(30px,4vw,64px); align-items: stretch; }
@media (max-width: 900px){ .agent__grid { grid-template-columns: 1fr; } }
.agent__copy { align-self: center; }
.agent__copy h2 { font-size: clamp(2rem, 4vw, 3.2rem); margin-top: 22px; }
.agent__copy p { margin-top: 22px; }
.agent__pills { margin-top: 30px; display: flex; flex-wrap: wrap; gap: 10px; }

.chat {
  display: flex; flex-direction: column;
  min-height: 520px; max-height: 620px;
  padding: 0; overflow: hidden;
  box-shadow: 0 50px 120px -50px color-mix(in oklch, var(--accent) 50%, transparent);
}
.chat__bar { display: flex; align-items: center; gap: 12px; padding: 16px 20px; border-bottom: 1px solid var(--line-soft); }
.chat__bar .av { width: 30px; height: 30px; border-radius: 9px; background: conic-gradient(from 200deg, var(--accent), var(--warm)); position: relative; flex: none; }
.chat__bar .av::after { content:""; position:absolute; inset: 6px; border-radius: 4px; background: var(--bg-raise); }
.chat__bar .who { font-size: 0.92rem; font-weight: 500; }
.chat__bar .st { font-family: var(--font-mono); font-size: 0.64rem; letter-spacing: 0.1em; color: var(--ink-faint); text-transform: uppercase; display: flex; align-items: center; gap: 6px; }
.chat__bar .st::before { content:""; width: 7px; height: 7px; border-radius: 50%; background: oklch(0.78 0.16 150); box-shadow: 0 0 8px oklch(0.78 0.16 150); }
.chat__bar .meta { margin-left: auto; }

.chat__log { flex: 1; overflow-y: auto; padding: 22px 20px; display: flex; flex-direction: column; gap: 16px; scrollbar-width: thin; scrollbar-color: var(--line) transparent; }
.msg { display: flex; gap: 10px; max-width: 86%; }
.msg--new { animation: msgin .4s ease both; }
@keyframes msgin { from { opacity: 0; transform: translateY(8px); } }
.msg__b { padding: 13px 16px; border-radius: 16px; font-size: 0.95rem; line-height: 1.5; }
.msg--bot { align-self: flex-start; }
.msg--bot .msg__b { background: var(--glass-raise); border: 1px solid var(--line-soft); border-top-left-radius: 5px; color: var(--ink); }
.msg--user { align-self: flex-end; }
.msg--user .msg__b { background: var(--accent); color: #06101f; border-top-right-radius: 5px; font-weight: 450; }
.msg__b p + p { margin-top: 9px; }
.msg__b strong { color: var(--warm); font-weight: 600; }
.msg--user .msg__b strong { color: #06101f; }

.typing { display: inline-flex; gap: 5px; padding: 4px 2px; }
.typing i { width: 7px; height: 7px; border-radius: 50%; background: var(--ink-faint); animation: blink 1.2s infinite; }
.typing i:nth-child(2){ animation-delay: .2s; } .typing i:nth-child(3){ animation-delay: .4s; }
@keyframes blink { 0%,60%,100%{ opacity: .25; transform: translateY(0);} 30%{ opacity: 1; transform: translateY(-3px);} }

.chat__suggest { display: flex; gap: 8px; flex-wrap: wrap; padding: 0 20px 12px; }
.chat__suggest button {
  font-size: 0.78rem; color: var(--ink-dim);
  border: 1px solid var(--line); background: transparent;
  padding: 7px 13px; border-radius: 999px; cursor: pointer;
  transition: border-color .25s, color .25s, background .25s;
}
.chat__suggest button:hover { border-color: color-mix(in oklch, var(--accent) 55%, transparent); color: var(--ink); background: var(--glass); }

.chat__input { display: flex; gap: 10px; padding: 14px 16px; border-top: 1px solid var(--line-soft); align-items: center; }
.chat__input input {
  flex: 1; background: var(--bg-deep); border: 1px solid var(--line);
  color: var(--ink); border-radius: 12px; padding: 13px 16px;
  font-family: var(--font-body); font-size: 0.95rem; outline: none;
  transition: border-color .25s;
}
.chat__input input::placeholder { color: var(--ink-ghost); }
.chat__input input:focus { border-color: color-mix(in oklch, var(--accent) 60%, transparent); }
.chat__send {
  width: 46px; height: 46px; flex: none; border-radius: 12px; border: none;
  background: var(--accent); color: #06101f; cursor: pointer;
  display: grid; place-items: center; transition: background .25s, transform .25s;
}
.chat__send:hover { background: var(--accent-bright); }
.chat__send:disabled { opacity: .45; cursor: not-allowed; }
.chat__note { font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.05em; color: var(--ink-ghost); text-align: center; padding: 0 0 14px; }

/* ============================================================
   Propuesta de valor — pillars
   ============================================================ */
.value { background: var(--bg-base); }
.pillars { margin-top: 70px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
@media (max-width: 820px){ .pillars { grid-template-columns: 1fr; } }
.pillar { padding: 30px 28px 34px; display: flex; flex-direction: column; min-height: 280px; transition: border-color .35s, transform .35s, background .35s; }
.pillar:hover { border-color: color-mix(in oklch, var(--accent) 45%, transparent); transform: translateY(-4px); background: var(--glass-raise); }
.pillar__ix { font-family: var(--font-mono); font-size: 0.72rem; color: var(--accent-bright); letter-spacing: 0.1em; }
.pillar__glyph { width: 46px; height: 46px; margin: 22px 0 26px; border-radius: 12px; border: 1px solid var(--line); display: grid; place-items: center; background: var(--glass); }
.pillar__glyph svg { width: 22px; height: 22px; stroke: var(--accent-bright); fill: none; stroke-width: 1.5; }
.pillar h3 { font-size: 1.4rem; }
.pillar p { margin-top: 12px; color: var(--ink-dim); font-size: 0.97rem; flex: 1; }
.pillar .tag { margin-top: 20px; font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-faint); }

/* highlight banner under pillars */
.value__note { margin-top: 18px; padding: 26px 30px; display: flex; align-items: center; gap: 20px; flex-wrap: wrap; background: linear-gradient(100deg, color-mix(in oklch, var(--accent) 16%, transparent), transparent 70%); }
.value__note .big { font-family: var(--font-display); font-size: clamp(1.2rem,2vw,1.6rem); letter-spacing: -0.02em; max-width: 40ch; }
.value__note .big b { color: var(--accent-bright); font-weight: 500; }

/* ============================================================
   Expediente Inteligente — before/after
   ============================================================ */
.expediente { background: linear-gradient(180deg, var(--bg-base), var(--bg-deep)); }
.exp__grid { margin-top: 64px; display: grid; grid-template-columns: 1fr auto 1fr; gap: 28px; align-items: center; }
@media (max-width: 900px){ .exp__grid { grid-template-columns: 1fr; } .exp__arrow { transform: rotate(90deg); justify-self: center; } }
.exp__col h4 { font-size: 1.15rem; display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.exp__col h4 .k { font-family: var(--font-mono); font-size: 0.62rem; padding: 4px 9px; border-radius: 6px; letter-spacing: 0.08em; text-transform: uppercase; }
.exp--before h4 .k { background: color-mix(in oklch, var(--warm) 18%, transparent); color: var(--warm); }
.exp--after h4 .k { background: color-mix(in oklch, var(--accent) 20%, transparent); color: var(--accent-bright); }

.doc-mess { padding: 22px; min-height: 320px; position: relative; overflow: hidden; }
.doc-mess .scrap { position: absolute; background: var(--bg-raise); border: 1px solid var(--line); border-radius: 6px; padding: 9px 11px; font-family: var(--font-mono); font-size: 0.6rem; color: var(--ink-faint); box-shadow: 0 14px 30px -18px #000; }
.doc-mess .scrap .ln { height: 4px; background: var(--line); border-radius: 2px; margin: 5px 0; }
.doc-mess .scrap .ln.s { width: 60%; }

.doc-clean { padding: 22px; min-height: 320px; }
.doc-clean .row { display: flex; align-items: center; gap: 12px; padding: 12px 0; border-bottom: 1px solid var(--line-soft); }
.doc-clean .row:last-child { border-bottom: none; }
.doc-clean .row .ck { width: 22px; height: 22px; border-radius: 6px; flex: none; display: grid; place-items: center; background: color-mix(in oklch, var(--accent) 22%, transparent); }
.doc-clean .row .ck svg { width: 12px; height: 12px; stroke: var(--accent-bright); stroke-width: 2.2; fill: none; }
.doc-clean .row .t { font-size: 0.9rem; }
.doc-clean .row .t small { display: block; color: var(--ink-faint); font-size: 0.74rem; margin-top: 2px; font-family: var(--font-mono); letter-spacing: 0.03em; }
.doc-clean .row .badge { margin-left: auto; font-family: var(--font-mono); font-size: 0.6rem; color: var(--accent-bright); border: 1px solid color-mix(in oklch, var(--accent) 40%, transparent); padding: 3px 8px; border-radius: 999px; }

.exp__arrow { width: 56px; height: 56px; border-radius: 50%; border: 1px solid var(--line); display: grid; place-items: center; background: var(--glass); }
.exp__arrow svg { width: 22px; height: 22px; stroke: var(--accent-bright); fill: none; stroke-width: 1.6; }

/* ============================================================
   Servicios
   ============================================================ */
.services { background: var(--bg-deep); }
.svc-list { margin-top: 60px; display: grid; gap: 1px; background: var(--line-soft); border: 1px solid var(--line-soft); border-radius: var(--radius); overflow: hidden; }
.svc {
  background: var(--bg-base); padding: 30px clamp(22px,3vw,40px);
  display: grid; grid-template-columns: 56px 1fr auto; gap: 26px; align-items: center;
  transition: background .35s;
  cursor: default;
}
.svc:hover { background: var(--glass-raise); }
.svc__n { font-family: var(--font-mono); font-size: 0.78rem; color: var(--ink-ghost); }
.svc__main h3 { font-size: clamp(1.3rem, 2.4vw, 1.85rem); }
.svc__main p { margin-top: 10px; color: var(--ink-dim); font-size: 0.97rem; max-width: 62ch; }
.svc__tags { display: flex; gap: 8px; margin-top: 16px; flex-wrap: wrap; }
.svc__tags span { font-family: var(--font-mono); font-size: 0.64rem; letter-spacing: 0.05em; color: var(--ink-faint); border: 1px solid var(--line-soft); padding: 4px 10px; border-radius: 999px; }
.svc__arrow { width: 44px; height: 44px; border-radius: 50%; border: 1px solid var(--line); display: grid; place-items: center; transition: background .3s, transform .3s; }
.svc:hover .svc__arrow { background: var(--accent); transform: rotate(-45deg); }
.svc__arrow svg { width: 18px; height: 18px; stroke: var(--ink); fill: none; stroke-width: 1.6; transition: stroke .3s; }
.svc:hover .svc__arrow svg { stroke: #06101f; }
@media (max-width: 720px){ .svc { grid-template-columns: 1fr; gap: 14px; } .svc__arrow { display: none; } }

/* grid variant */
body[data-svc="grid"] .svc-list { grid-template-columns: repeat(2, 1fr); background: transparent; border: none; gap: 16px; }
body[data-svc="grid"] .svc { border: 1px solid var(--line); border-radius: var(--radius); grid-template-columns: 1fr; align-items: start; }
body[data-svc="grid"] .svc__arrow { position: absolute; top: 24px; right: 24px; }
body[data-svc="grid"] .svc { position: relative; }
@media (max-width: 720px){ body[data-svc="grid"] .svc-list { grid-template-columns: 1fr; } }

/* ============================================================
   Metodología
   ============================================================ */
.method { background: linear-gradient(180deg, var(--bg-deep), var(--bg-base)); }
.steps { margin-top: 64px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; position: relative; }
@media (max-width: 900px){ .steps { grid-template-columns: 1fr 1fr; gap: 30px 18px; } }
@media (max-width: 540px){ .steps { grid-template-columns: 1fr; } }
.step { position: relative; padding: 0 26px 0 0; }
.step__node { display: flex; align-items: center; gap: 14px; margin-bottom: 24px; }
.step__node .dot { width: 14px; height: 14px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 0 5px color-mix(in oklch, var(--accent) 18%, transparent); flex: none; z-index: 2; }
.step__node .bar { flex: 1; height: 1px; background: linear-gradient(90deg, var(--accent), var(--line)); }
.step:last-child .step__node .bar { background: var(--line-soft); }
.step__k { font-family: var(--font-mono); font-size: 0.7rem; color: var(--accent-bright); letter-spacing: 0.1em; }
.step h3 { font-size: 1.3rem; margin-top: 10px; }
.step p { margin-top: 12px; color: var(--ink-dim); font-size: 0.93rem; }
@media (max-width: 540px){ .step { padding-bottom: 8px; } }

/* ============================================================
   Equipo / Nosotros
   ============================================================ */
.team { background: var(--bg-base); }
.team__grid { margin-top: 60px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
@media (max-width: 900px){ .team__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px){ .team__grid { grid-template-columns: 1fr; max-width: 360px; margin-inline: auto; } }
.member { display: flex; flex-direction: column; }
.member__photo { width: 100%; aspect-ratio: 3/4; border-radius: var(--radius); overflow: hidden; border: 1px solid var(--line); background: repeating-linear-gradient(135deg, color-mix(in oklch, var(--ink) 4%, transparent) 0 10px, transparent 10px 20px), var(--bg-raise); }
.member__photo image-slot { width: 100%; height: 100%; color: color-mix(in oklch, var(--ink) 55%, transparent) !important; }
.member__photo img { display: block; width: 100%; height: 100%; object-fit: cover; object-position: center; }
.member__photo-img--wide { object-position: 52% 34%; }
.member__name { margin-top: 16px; font-family: var(--font-display); font-size: 1.12rem; letter-spacing: -0.01em; }
.member__role { margin-top: 4px; font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.05em; color: var(--accent-bright); text-transform: uppercase; }
.member__tagline { font-size: 0.88rem; line-height: 1.4; margin-top: 6px; }
.member__bio { margin-top: 6px; font-size: 0.86rem; color: var(--ink-faint); line-height: 1.55; }
.team__disc { margin-top: 40px; display: flex; gap: 30px; flex-wrap: wrap; }
.team__disc .d { display: flex; align-items: center; gap: 10px; font-size: 0.9rem; color: var(--ink-dim); }
.team__disc .d .dot { width: 9px; height: 9px; border-radius: 50%; }
.team__promise { }
.tagline { }

/* ============================================================
   Por qué ahora
   ============================================================ */
.urgency { background: var(--bg-base); }
.urgency__grid { margin-top: 56px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
@media (max-width: 820px){ .urgency__grid { grid-template-columns: 1fr; max-width: 500px; margin-inline: auto; } }
.urgency-card { padding: 32px; }
.urgency-card .pillar__ix { font-family: var(--font-mono); font-size: 0.72rem; color: var(--accent-bright); letter-spacing: 0.08em; }
.urgency-card h3 { font-size: 1.25rem; margin-top: 14px; }
.urgency-card p { margin-top: 10px; color: var(--ink-dim); font-size: 0.93rem; line-height: 1.6; }
.urgency__cta { }

/* ============================================================
   Casos de uso
   ============================================================ */
.cases { background: linear-gradient(180deg, var(--bg-deep), var(--bg-base)); }
.cases__grid { margin-top: 56px; display: flex; flex-direction: column; gap: 18px; }
.case { display: grid; grid-template-columns: 40px 1fr auto; gap: 20px; padding: 30px; align-items: start; }
@media (max-width: 640px){ .case { grid-template-columns: 1fr; } }
.case__n { font-family: var(--font-mono); font-size: 0.78rem; color: var(--ink-ghost); }
.case__body h3 { font-size: clamp(1.2rem, 2vw, 1.7rem); }
.case__compare { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 16px; }
@media (max-width: 540px){ .case__compare { grid-template-columns: 1fr; } }
.case__before, .case__after { padding: 14px; border-radius: 12px; }
.case__before { background: color-mix(in oklch, var(--warm-dim) 8%, transparent); }
.case__after { background: color-mix(in oklch, var(--accent-deep) 15%, transparent); }
.case__label { font-family: var(--font-mono); font-size: 0.64rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-ghost); margin-bottom: 6px; display: block; }
.case__before p, .case__after p { font-size: 0.88rem; color: var(--ink-dim); line-height: 1.55; margin: 0; }
.case__result { margin-top: 18px; padding: 12px 16px; border-radius: 10px; background: var(--glass); font-size: 0.9rem; color: var(--ink-dim); border-left: 3px solid var(--accent-bright); }
.case .tag { justify-self: end; align-self: center; }
@media (max-width: 640px){ .case .tag { justify-self: start; } }
.cases__note { }

/* ============================================================
   FAQs
   ============================================================ */
.faqs { background: var(--bg-base); }
.faqs__list { margin-top: 48px; display: flex; flex-direction: column; gap: 10px; max-width: 860px; margin-inline: auto; }
.faq { padding: 0; border: 1px solid var(--line); }
.faq summary { display: flex; justify-content: space-between; align-items: center; padding: 22px 26px; cursor: pointer; list-style: none; }
.faq summary::-webkit-details-marker { display: none; }
.faq__q { font-family: var(--font-display); font-size: 1.05rem; letter-spacing: -0.01em; color: var(--ink); }
.faq__icon { width: 20px; height: 20px; border-radius: 50%; border: 1.5px solid var(--line); position: relative; flex: none; transition: background .3s, border-color .3s; }
.faq__icon::before, .faq__icon::after { content: ""; position: absolute; background: var(--ink-ghost); transition: transform .3s; }
.faq__icon::before { top: 8px; left: 4px; width: 10px; height: 1.5px; }
.faq__icon::after { top: 4px; left: 8px; width: 1.5px; height: 10px; }
.faq[open] .faq__icon::after { transform: rotate(90deg); }
.faq[open] .faq__icon { background: var(--accent-deep); border-color: var(--accent-deep); }
.faq__a { padding: 0 26px 22px; }
.faq__a p { font-size: 0.93rem; color: var(--ink-dim); line-height: 1.65; margin: 0; }
.faq:hover { border-color: var(--ink-ghost); }

/* ============================================================
   Hero note
   ============================================================ */
.hero__note { }

/* ============================================================
   Cierre
   ============================================================ */
.close { position: relative; overflow: hidden; text-align: center; padding-block: clamp(110px, 16vw, 220px); background: var(--bg-deep); }
.close .glow--c { width: 700px; height: 500px; left: 50%; top: 50%; transform: translate(-50%,-50%); background: radial-gradient(circle, color-mix(in oklch, var(--accent) 40%, transparent), transparent 65%); }
.close__inner { position: relative; z-index: 2; max-width: 1000px; margin: 0 auto; }
.close h2 { font-size: clamp(2.2rem, 5.5vw, 4.6rem); letter-spacing: -0.035em; max-width: 18ch; margin: 26px auto 0; }
.close h2 .accent { color: var(--accent-bright); }
.close p { margin: 28px auto 0; max-width: 52ch; color: var(--ink-dim); }
.close__cta { margin-top: 46px; display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }

/* ============================================================
   Footer
   ============================================================ */
.foot { background: var(--bg-deep); border-top: 1px solid var(--line-soft); padding-block: 70px 40px; }
.foot__top { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 40px; }
@media (max-width: 820px){ .foot__top { grid-template-columns: 1fr 1fr; gap: 34px; } }
@media (max-width: 480px){ .foot__top { grid-template-columns: 1fr; } }
.foot__brand .brand { font-size: 1.3rem; margin-bottom: 18px; }
.foot__brand p { color: var(--ink-faint); font-size: 0.9rem; max-width: 34ch; }
.foot__brand .contact { margin-top: 20px; display: flex; flex-direction: column; gap: 7px; }
.foot__brand .contact a { font-family: var(--font-mono); font-size: 0.82rem; color: var(--ink-dim); transition: color .25s; }
.foot__brand .contact a:hover { color: var(--accent-bright); }
.foot__col h5 { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-ghost); margin: 0 0 18px; font-weight: 500; }
.foot__col ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 11px; }
.foot__col a { font-size: 0.9rem; color: var(--ink-dim); transition: color .25s; }
.foot__col a:hover { color: var(--ink); }
.foot__bar { margin-top: 56px; padding-top: 26px; border-top: 1px solid var(--line-soft); display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.foot__bar span { font-size: 0.78rem; color: var(--ink-ghost); font-family: var(--font-mono); letter-spacing: 0.03em; }

/* ============================================================
   Reveal on scroll
   ============================================================ */
html.anim .reveal { opacity: 0; transform: translateY(26px); transition: opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1); }
html.anim .reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce){ html.anim .reveal { opacity: 1; transform: none; transition: none; } .hero__visual .cf-1, .hero__visual .cf-2 { animation: none; } }
