/* ============================================================
   ALEKS® — Estudio digital
   Sistema de diseño · main.css
   ------------------------------------------------------------
   01. Tokens (color, tipografía, espacio, motion)
   02. Fuentes
   03. Reset + base
   04. Tipografía
   05. Layout (container, section, grids)
   06. Navegación / Header
   07. Botones + CTA
   08. Loader / Intro
   09. Cursor personalizado
   10. Hero
   11. Bento + tarjetas de servicio
   12. Portfolio / proyectos
   13. Marquee + testimonios
   14. Stats, proceso, FAQ, banda demo
   15. Instagram + about
   16. Formulario de contacto
   17. Footer + WhatsApp flotante
   18. Páginas legales / blog / 404
   19. Reveals + utilidades de motion
   20. Responsive + reduced motion
   ============================================================ */

/* ---------- 01 · TOKENS ---------- */
:root {
  color-scheme: light;

  /* Color — luz */
  --bg: #ffffff;
  --bg-soft: #f6f6f4;
  --bg-card: #fbfbfa;
  --glass: rgba(255, 255, 255, 0.66);
  --glass-strong: rgba(255, 255, 255, 0.82);
  --ink: #0c0c0d;
  --ink-soft: #46464d;
  --ink-mute: #6d6d75;
  --ink-faint: #9b9ba1;
  --line: rgba(12, 12, 13, 0.08);
  --line-strong: rgba(12, 12, 13, 0.16);
  --inverse-bg: #0c0c0d;
  --inverse-ink: #f5f5f3;
  --ok: #1f7a4d;
  --err: #b3372f;

  /* Sombras — extremadamente suaves, en capas */
  --shadow-s: 0 1px 2px rgba(16, 16, 18, 0.04), 0 4px 12px rgba(16, 16, 18, 0.05);
  --shadow-m: 0 1px 2px rgba(16, 16, 18, 0.05), 0 10px 30px rgba(16, 16, 18, 0.07), 0 30px 60px -20px rgba(16, 16, 18, 0.09);
  --shadow-l: 0 2px 4px rgba(16, 16, 18, 0.05), 0 18px 50px rgba(16, 16, 18, 0.10), 0 60px 120px -30px rgba(16, 16, 18, 0.16);
  --shadow-glow: 0 0 0 1px var(--line);

  /* Tipografía */
  --font-sans: "Manrope", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-serif: "Instrument Serif", ui-serif, Georgia, serif;

  /* Escala fluida */
  --text-xs: 0.75rem;
  --text-s: 0.875rem;
  --text-base: clamp(1rem, 0.96rem + 0.2vw, 1.125rem);
  --text-l: clamp(1.125rem, 1.05rem + 0.4vw, 1.375rem);
  --text-xl: clamp(1.4rem, 1.2rem + 1vw, 2rem);
  --text-2xl: clamp(1.9rem, 1.4rem + 2.2vw, 3.25rem);
  --text-3xl: clamp(2.5rem, 1.6rem + 4.2vw, 5rem);
  --text-hero: clamp(2.9rem, 1.4rem + 7vw, 7.75rem);

  /* Espacio */
  --s-1: clamp(0.5rem, 0.4rem + 0.35vw, 0.75rem);
  --s-2: clamp(1rem, 0.85rem + 0.6vw, 1.5rem);
  --s-3: clamp(1.5rem, 1.2rem + 1.2vw, 2.5rem);
  --s-4: clamp(2.5rem, 1.8rem + 2.4vw, 4.5rem);
  --s-5: clamp(4rem, 2.8rem + 4.5vw, 7.5rem);
  --s-6: clamp(6rem, 4rem + 7vw, 11rem);

  /* Layout */
  --container: min(1280px, 100vw - clamp(2.5rem, 6vw, 5rem));
  --container-wide: min(1520px, 100vw - clamp(1.5rem, 4vw, 3rem));
  --nav-h: 72px;
  --r-s: 12px;
  --r-m: 20px;
  --r-l: 28px;
  --r-pill: 999px;

  /* Motion */
  --ease-out: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-io: cubic-bezier(0.83, 0, 0.17, 1);
  --ease-spring: cubic-bezier(0.34, 1.3, 0.5, 1);
  --dur-1: 0.35s;
  --dur-2: 0.7s;
  --dur-3: 1.1s;

  /* Ruido sutil (textura) */
  --noise: 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)' opacity='0.5'/%3E%3C/svg%3E");
}

[data-theme="dark"] {
  color-scheme: dark;
  --bg: #0a0a0b;
  --bg-soft: #111113;
  --bg-card: #131315;
  --glass: rgba(19, 19, 21, 0.62);
  --glass-strong: rgba(19, 19, 21, 0.85);
  --ink: #f4f4f2;
  --ink-soft: #c2c2c8;
  --ink-mute: #94949c;
  --ink-faint: #64646c;
  --line: rgba(244, 244, 242, 0.09);
  --line-strong: rgba(244, 244, 242, 0.18);
  --inverse-bg: #f4f4f2;
  --inverse-ink: #0c0c0d;
  --ok: #4cc38a;
  --err: #e5766e;
  --shadow-s: 0 1px 2px rgba(0, 0, 0, 0.35), 0 4px 12px rgba(0, 0, 0, 0.35);
  --shadow-m: 0 1px 2px rgba(0, 0, 0, 0.4), 0 10px 30px rgba(0, 0, 0, 0.45), 0 30px 60px -20px rgba(0, 0, 0, 0.5);
  --shadow-l: 0 2px 4px rgba(0, 0, 0, 0.45), 0 18px 50px rgba(0, 0, 0, 0.55), 0 60px 120px -30px rgba(0, 0, 0, 0.6);
}

/* ---------- 02 · FUENTES ---------- */
@font-face {
  font-family: "Manrope";
  src: url("../fonts/manrope-var-latin.woff2") format("woff2");
  font-weight: 200 800;
  font-display: swap;
}
@font-face {
  font-family: "Instrument Serif";
  src: url("../fonts/instrument-serif-latin.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Instrument Serif";
  src: url("../fonts/instrument-serif-italic-latin.woff2") format("woff2");
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}

/* ---------- 03 · RESET + BASE ---------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
  scroll-padding-top: calc(var(--nav-h) + 24px);
}

body {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  font-weight: 450;
  line-height: 1.65;
  letter-spacing: -0.011em;
  color: var(--ink-soft);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: clip;
  min-height: 100svh;
  transition: background-color 0.5s var(--ease-out), color 0.5s var(--ease-out);
}

/* Textura de ruido global, casi imperceptible */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  background-image: var(--noise);
  background-size: 160px;
  opacity: 0.028;
  pointer-events: none;
  z-index: 2000;
  mix-blend-mode: multiply;
}
[data-theme="dark"] body::before { mix-blend-mode: screen; opacity: 0.04; }

img, svg, video, canvas { display: block; max-width: 100%; height: auto; }
button, input, select, textarea { font: inherit; color: inherit; background: none; border: none; }
button { cursor: pointer; }
a { color: inherit; text-decoration: none; }
ul[role="list"], ol[role="list"] { list-style: none; }
::selection { background: var(--ink); color: var(--bg); }

:focus-visible {
  outline: 2px solid var(--ink);
  outline-offset: 3px;
  border-radius: 4px;
}

.sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip-path: inset(50%);
  white-space: nowrap;
  border: 0;
}

.skip-link {
  position: fixed;
  top: 12px; left: 12px;
  z-index: 3000;
  padding: 0.75rem 1.25rem;
  background: var(--ink);
  color: var(--bg);
  border-radius: var(--r-pill);
  font-weight: 600;
  font-size: var(--text-s);
  transform: translateY(-200%);
  transition: transform 0.3s var(--ease-out);
}
.skip-link:focus-visible { transform: translateY(0); }

/* ---------- 04 · TIPOGRAFÍA ---------- */
h1, h2, h3, h4 {
  color: var(--ink);
  font-weight: 600;
  line-height: 1.06;
  letter-spacing: -0.035em;
  text-wrap: balance;
}
h1 { font-size: var(--text-hero); font-weight: 550; letter-spacing: -0.045em; }
h2 { font-size: var(--text-3xl); font-weight: 560; letter-spacing: -0.04em; }
h3 { font-size: var(--text-xl); letter-spacing: -0.025em; line-height: 1.2; }
h4 { font-size: var(--text-l); line-height: 1.3; letter-spacing: -0.02em; }

.serif, em.accent {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  letter-spacing: -0.01em;
}
em.accent { font-size: 1.04em; }

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  font-size: var(--text-xs);
  font-weight: 650;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.eyebrow::before {
  content: "";
  width: 22px; height: 1px;
  background: var(--ink-mute);
  opacity: 0.6;
}

.lead { font-size: var(--text-l); line-height: 1.6; color: var(--ink-mute); max-width: 56ch; text-wrap: pretty; }
.small { font-size: var(--text-s); color: var(--ink-mute); }

.pill {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.45rem 1rem;
  border: 1px solid var(--line-strong);
  border-radius: var(--r-pill);
  font-size: var(--text-s);
  font-weight: 550;
  color: var(--ink-soft);
  background: var(--glass);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.pill .dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--ok);
  animation: pulse-dot 2.4s ease-in-out infinite;
}
@keyframes pulse-dot {
  0%, 100% { box-shadow: 0 0 0 0 rgba(31, 122, 77, 0.35); }
  50% { box-shadow: 0 0 0 6px rgba(31, 122, 77, 0); }
}

/* ---------- 05 · LAYOUT ---------- */
.container { width: var(--container); margin-inline: auto; }
.container-wide { width: var(--container-wide); margin-inline: auto; }

.section { padding-block: var(--s-6); position: relative; }
.section-soft { background: var(--bg-soft); }
.section-tight { padding-block: var(--s-5); }

.section-head {
  display: grid;
  gap: var(--s-2);
  max-width: 780px;
  margin-bottom: var(--s-4);
}
.section-head.center { margin-inline: auto; text-align: center; justify-items: center; }
.section-head .lead { margin-top: 0.25rem; }

.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--s-3); }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-2); }

.divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--line-strong), transparent);
  border: none;
}

/* Fondo de sección con degradados suaves */
.bg-orbs { position: absolute; inset: 0; overflow: hidden; pointer-events: none; }
.bg-orbs i {
  position: absolute;
  border-radius: 50%;
  filter: blur(90px);
  opacity: 0.5;
  background: radial-gradient(circle, rgba(12, 12, 13, 0.055), transparent 65%);
}
[data-theme="dark"] .bg-orbs i { background: radial-gradient(circle, rgba(244, 244, 242, 0.05), transparent 65%); }

/* ---------- 06 · NAVEGACIÓN ---------- */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  height: var(--nav-h);
  display: flex;
  align-items: center;
  transition: transform 0.5s var(--ease-out);
}
.nav.is-hidden { transform: translateY(-110%); }

.nav-inner {
  width: var(--container-wide);
  margin-inline: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-2);
  padding: 0.55rem 0.6rem 0.55rem 1.4rem;
  border-radius: var(--r-pill);
  border: 1px solid transparent;
  transition: width 0.6s var(--ease-out), background-color 0.4s var(--ease-out),
              border-color 0.4s var(--ease-out), box-shadow 0.4s var(--ease-out),
              backdrop-filter 0.4s var(--ease-out);
}
.nav.is-scrolled .nav-inner {
  width: min(1060px, 100vw - 2rem);
  background: var(--glass);
  border-color: var(--line);
  box-shadow: var(--shadow-s);
  backdrop-filter: blur(18px) saturate(1.5);
  -webkit-backdrop-filter: blur(18px) saturate(1.5);
}

.brand {
  font-weight: 750;
  font-size: 1.28rem;
  letter-spacing: -0.05em;
  color: var(--ink);
  display: inline-flex;
  align-items: baseline;
  line-height: 1;
  gap: 1px;
}
.brand sup { font-size: 0.5em; font-weight: 500; transform: translateY(-2px); opacity: 0.55; }
.brand .brand-dot { color: var(--ink); font-family: var(--font-serif); font-style: italic; }

.nav-links {
  display: flex;
  align-items: center;
  gap: clamp(0.25rem, 1vw, 0.9rem);
  list-style: none;
}
.nav-links li { flex: none; }

/* Enlace con roll tipográfico: sans → serif itálica, letra a letra */
.nav-link {
  position: relative;
  display: inline-block;
  white-space: nowrap;
  padding: 0.5rem 0.55rem;
  font-size: 0.92rem;
  font-weight: 550;
  color: var(--ink-soft);
  border-radius: var(--r-s);
  line-height: 1.25;
}
.nav-link .roll {
  display: inline-block;
  position: relative;
  overflow: clip;
  clip-path: inset(0);
  line-height: 1.25;
  vertical-align: bottom;
}
.nav-link .roll .ch { display: inline-block; white-space: pre; transition: transform 0.45s var(--ease-out); transition-delay: calc(var(--i) * 22ms); }
.nav-link .roll .ch-b {
  position: absolute;
  left: 0; top: 0;
  transform: translateY(115%);
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  font-size: 1.13em;
  color: var(--ink);
}
.nav-link:hover .roll .ch-a, .nav-link:focus-visible .roll .ch-a { transform: translateY(-115%); }
.nav-link:hover .roll .ch-b, .nav-link:focus-visible .roll .ch-b { transform: translateY(0); }
.nav-link[aria-current="page"] { color: var(--ink); }
.nav-link[aria-current="page"]::after {
  content: "";
  position: absolute;
  left: 50%; bottom: 2px;
  width: 4px; height: 4px;
  border-radius: 50%;
  background: var(--ink);
  transform: translateX(-50%);
}

.nav-actions { display: flex; align-items: center; gap: 0.5rem; }

/* Interruptor de tema */
.theme-toggle {
  position: relative;
  width: 42px; height: 42px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  border: 1px solid var(--line);
  color: var(--ink);
  background: transparent;
  transition: background-color 0.3s var(--ease-out), transform 0.3s var(--ease-spring), border-color 0.3s;
}
.theme-toggle:hover { background: var(--bg-soft); transform: scale(1.06); }
.theme-toggle:active { transform: scale(0.94); }
.theme-toggle svg { width: 17px; height: 17px; }
.theme-toggle .sun, .theme-toggle .moon { position: absolute; transition: transform 0.55s var(--ease-spring), opacity 0.3s; }
.theme-toggle .moon { opacity: 0; transform: rotate(90deg) scale(0.4); }
[data-theme="dark"] .theme-toggle .sun { opacity: 0; transform: rotate(-90deg) scale(0.4); }
[data-theme="dark"] .theme-toggle .moon { opacity: 1; transform: rotate(0) scale(1); }

/* Botón hamburguesa */
.nav-burger {
  display: none;
  width: 42px; height: 42px;
  border-radius: 50%;
  border: 1px solid var(--line);
  place-items: center;
}
.nav-burger span {
  position: relative;
  width: 16px; height: 1.6px;
  background: var(--ink);
  border-radius: 2px;
  transition: transform 0.4s var(--ease-spring), background 0.2s;
}
.nav-burger span::before, .nav-burger span::after {
  content: "";
  position: absolute;
  left: 0;
  width: 16px; height: 1.6px;
  background: var(--ink);
  border-radius: 2px;
  transition: transform 0.4s var(--ease-spring), top 0.4s var(--ease-spring);
}
.nav-burger span::before { top: -5.5px; }
.nav-burger span::after { top: 5.5px; }
.nav-burger[aria-expanded="true"] span { background: transparent; }
.nav-burger[aria-expanded="true"] span::before { top: 0; transform: rotate(45deg); }
.nav-burger[aria-expanded="true"] span::after { top: 0; transform: rotate(-45deg); }

/* Menú móvil a pantalla completa */
.mobile-menu {
  position: fixed;
  inset: 0;
  z-index: 900;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: calc(var(--nav-h) + 2rem) 8vw 3rem;
  background: var(--glass-strong);
  backdrop-filter: blur(28px) saturate(1.6);
  -webkit-backdrop-filter: blur(28px) saturate(1.6);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.5s var(--ease-out), visibility 0s 0.5s;
}
.mobile-menu.is-open { opacity: 1; visibility: visible; transition: opacity 0.5s var(--ease-out); }
.mobile-menu ul { list-style: none; display: grid; gap: 0.4rem; }
.mobile-menu a.mobile-link {
  display: inline-flex;
  align-items: baseline;
  gap: 0.9rem;
  font-size: clamp(2.1rem, 8.5vw, 3.6rem);
  font-weight: 580;
  letter-spacing: -0.04em;
  line-height: 1.15;
  color: var(--ink);
  overflow: hidden;
}
.mobile-link .idx { font-size: 0.85rem; font-weight: 500; color: var(--ink-faint); font-family: var(--font-serif); font-style: italic; }
.mobile-menu .mobile-link > .txt { display: inline-block; transform: translateY(110%); transition: transform 0.7s var(--ease-out); }
.mobile-menu.is-open .mobile-link > .txt { transform: translateY(0); transition-delay: calc(var(--i) * 55ms + 0.1s); }
.mobile-menu .mobile-foot {
  margin-top: var(--s-4);
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  opacity: 0;
  transform: translateY(14px);
  transition: opacity 0.6s var(--ease-out) 0.4s, transform 0.6s var(--ease-out) 0.4s;
}
.mobile-menu.is-open .mobile-foot { opacity: 1; transform: none; }

/* ---------- 07 · BOTONES ---------- */
.btn {
  --btn-bg: var(--ink);
  --btn-ink: var(--bg);
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  padding: 0.95rem 1.7rem;
  border-radius: var(--r-pill);
  background: var(--btn-bg);
  color: var(--btn-ink);
  font-weight: 620;
  font-size: 0.98rem;
  letter-spacing: -0.01em;
  line-height: 1;
  overflow: hidden;
  isolation: isolate;
  transition: transform 0.35s var(--ease-spring), box-shadow 0.35s var(--ease-out), background-color 0.3s;
  will-change: transform;
}
.btn:hover { transform: translateY(-2px); box-shadow: var(--shadow-m); }
.btn:active { transform: translateY(0) scale(0.97); }

/* Relleno líquido en hover */
.btn::before {
  content: "";
  position: absolute;
  inset: -2px;
  z-index: -1;
  background: radial-gradient(120px 120px at var(--mx, 50%) var(--my, 50%), rgba(255, 255, 255, 0.22), transparent 60%);
  opacity: 0;
  transition: opacity 0.35s;
}
.btn:hover::before { opacity: 1; }
[data-theme="dark"] .btn::before { background: radial-gradient(120px 120px at var(--mx, 50%) var(--my, 50%), rgba(0, 0, 0, 0.16), transparent 60%); }

.btn .arr { display: inline-grid; place-items: center; width: 1em; height: 1em; overflow: hidden; }
.btn .arr svg { width: 0.85em; height: 0.85em; transition: transform 0.4s var(--ease-out); }
.btn:hover .arr svg { transform: translate(2.5px, -2.5px); }

.btn-ghost {
  --btn-bg: transparent;
  --btn-ink: var(--ink);
  border: 1px solid var(--line-strong);
  background: var(--glass);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.btn-ghost:hover { background: var(--bg-soft); box-shadow: var(--shadow-s); }

.btn-inverse { --btn-bg: var(--inverse-ink); --btn-ink: var(--inverse-bg); }
.on-dark .btn-ghost { --btn-ink: var(--inverse-ink); border-color: rgba(245, 245, 243, 0.25); background: rgba(245, 245, 243, 0.06); }
.on-dark .btn-ghost:hover { background: rgba(245, 245, 243, 0.12); }

.btn-s { padding: 0.7rem 1.2rem; font-size: 0.88rem; }
.btn-l { padding: 1.15rem 2.1rem; font-size: 1.05rem; }

.btn-wa { --btn-bg: #17352a; --btn-ink: #e9fbf2; }
[data-theme="dark"] .btn-wa { --btn-bg: #dcfce9; --btn-ink: #12291f; }

/* Enlace con subrayado que se dibuja */
.link-draw {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-weight: 620;
  color: var(--ink);
  padding-bottom: 2px;
  background: linear-gradient(currentColor, currentColor) no-repeat 100% 100% / 0% 1.5px;
  transition: background-size 0.45s var(--ease-out);
}
.link-draw:hover { background-position: 0 100%; background-size: 100% 1.5px; }
.link-draw svg { width: 0.8em; height: 0.8em; transition: transform 0.35s var(--ease-out); }
.link-draw:hover svg { transform: translate(2px, -2px); }

/* ---------- 08 · LOADER / INTRO ---------- */
.loader {
  position: fixed;
  inset: 0;
  z-index: 4000;
  display: none;
  background: var(--bg);
  transition: transform 1s var(--ease-io), visibility 0s 1s;
}
.js .loader { display: block; }
.loader.is-leaving { pointer-events: none; }
.loader.is-done { transform: translateY(-100%); visibility: hidden; }
.loader-canvas { position: absolute; inset: 0; width: 100%; height: 100%; }
.loader-ui {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  padding-bottom: clamp(2rem, 6vh, 4rem);
  gap: 1rem;
  pointer-events: none;
}
.loader-count {
  font-size: var(--text-s);
  font-weight: 550;
  color: var(--ink-mute);
  font-variant-numeric: tabular-nums;
  display: flex;
  align-items: baseline;
  gap: 0.75rem;
}
.loader-count .lbl { font-family: var(--font-serif); font-style: italic; color: var(--ink-faint); }
.loader-bar {
  width: min(280px, 60vw);
  height: 1px;
  background: var(--line);
  overflow: hidden;
}
.loader-bar i {
  display: block;
  height: 100%;
  width: 100%;
  background: var(--ink);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.3s var(--ease-out);
}
/* Cortina secundaria para la revelación en dos tiempos */
.loader::after {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--inverse-bg);
  transform: translateY(101%);
  transition: transform 0.9s var(--ease-io);
}
.loader.is-leaving::after { transform: translateY(0); transition-delay: 0s; }
.loader.is-leaving .loader-ui, .loader.is-leaving .loader-canvas { opacity: 0; transition: opacity 0.4s; }

/* ---------- 09 · CURSOR PERSONALIZADO ---------- */
@media (hover: hover) and (pointer: fine) {
  .has-cursor, .has-cursor a, .has-cursor button, .has-cursor [data-tilt] { cursor: none; }
  .has-cursor input, .has-cursor textarea, .has-cursor select, .has-cursor label { cursor: auto; }
}
.cursor-dot, .cursor-ring, .cursor-canvas {
  position: fixed;
  top: 0; left: 0;
  pointer-events: none;
  z-index: 5000;
}
.cursor-canvas { width: 100vw; height: 100vh; mix-blend-mode: difference; opacity: 0.9; }
.cursor-dot {
  width: 6px; height: 6px;
  margin: -3px 0 0 -3px;
  border-radius: 50%;
  background: #fff;
  mix-blend-mode: difference;
  transition: transform 0.25s var(--ease-out), opacity 0.25s;
}
.cursor-ring {
  width: 38px; height: 38px;
  margin: -19px 0 0 -19px;
  border-radius: var(--r-pill);
  border: 1.2px solid #fff;
  mix-blend-mode: difference;
  display: grid;
  place-items: center;
  transition: width 0.4s var(--ease-spring), height 0.4s var(--ease-spring),
              margin 0.4s var(--ease-spring), border-color 0.3s, background-color 0.3s,
              border-radius 0.3s, opacity 0.3s;
}
.cursor-ring .cursor-label {
  font-size: 0.72rem;
  font-weight: 650;
  letter-spacing: 0.02em;
  color: #000;
  white-space: nowrap;
  opacity: 0;
  transform: scale(0.6);
  transition: opacity 0.25s, transform 0.35s var(--ease-spring);
}
/* Estados */
.cursor-hide .cursor-dot, .cursor-hide .cursor-ring { opacity: 0; }
.cursor-link .cursor-ring { width: 56px; height: 56px; margin: -28px 0 0 -28px; background: rgba(255,255,255,0.12); }
.cursor-link .cursor-dot { transform: scale(0.5); }
.cursor-text .cursor-ring { width: 3px; height: 34px; margin: -17px 0 0 -1.5px; border-radius: 3px; background: #fff; border-color: transparent; }
.cursor-text .cursor-dot { opacity: 0; }
.cursor-view .cursor-ring {
  width: 96px; height: 96px;
  margin: -48px 0 0 -48px;
  background: #fff;
  border-color: transparent;
  mix-blend-mode: normal;
  box-shadow: var(--shadow-m);
}
.cursor-view .cursor-ring .cursor-label { opacity: 1; transform: scale(1); }
.cursor-view .cursor-dot { opacity: 0; }
.cursor-press .cursor-ring { transform: scale(0.86); }

/* ---------- 10 · HERO ---------- */
.hero {
  position: relative;
  min-height: 100svh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-top: calc(var(--nav-h) + var(--s-3));
  overflow: clip;
}
.hero-canvas { position: absolute; inset: 0; width: 100%; height: 100%; pointer-events: none; }
.hero-grad {
  position: absolute;
  inset: -20%;
  pointer-events: none;
  background:
    radial-gradient(46% 42% at 24% 22%, rgba(12,12,13,0.05), transparent 68%),
    radial-gradient(38% 36% at 82% 68%, rgba(12,12,13,0.045), transparent 66%);
  animation: grad-drift 26s ease-in-out infinite alternate;
}
[data-theme="dark"] .hero-grad {
  background:
    radial-gradient(46% 42% at 24% 22%, rgba(244,244,242,0.05), transparent 68%),
    radial-gradient(38% 36% at 82% 68%, rgba(244,244,242,0.045), transparent 66%);
}
@keyframes grad-drift {
  from { transform: translate3d(-1.5%, -1%, 0) scale(1); }
  to { transform: translate3d(1.5%, 2%, 0) scale(1.06); }
}

.hero-inner {
  position: relative;
  width: var(--container);
  margin-inline: auto;
  display: grid;
  grid-template-columns: minmax(0, 1fr) clamp(320px, 40vw, 560px);
  align-items: center;
  gap: clamp(1.5rem, 4vw, 4.5rem);
  z-index: 2;
}
.hero-copy { display: grid; gap: var(--s-3); justify-items: start; min-width: 0; }
.hero h1 { max-width: 15ch; font-size: clamp(2.8rem, 1.2rem + 5vw, 5.75rem); }
.hero h1 .rotator {
  display: inline-grid;
  overflow: hidden;
  vertical-align: baseline;
  position: relative;
}
.hero h1 .rotator > span {
  grid-area: 1 / 1;
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  white-space: nowrap;
  opacity: 0;
  transform: translateY(110%) rotate(2deg);
  transition: transform 0.85s var(--ease-out), opacity 0.5s;
  will-change: transform;
}
.hero h1 .rotator > span.is-in { opacity: 1; transform: translateY(0) rotate(0); }
.hero h1 .rotator > span.is-out { opacity: 0; transform: translateY(-110%) rotate(-2deg); }

.hero-sub { max-width: 46ch; }
.hero-cta { display: flex; flex-wrap: wrap; align-items: center; gap: 1rem; }
.hero-proof {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem 1.75rem;
  color: var(--ink-mute);
  font-size: var(--text-s);
  font-weight: 550;
}
.hero-proof b { color: var(--ink); font-weight: 750; font-variant-numeric: tabular-nums; }

/* Composición flotante de proyectos en el hero (columna derecha del grid) */
.hero-stage {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  align-self: center;
  transform: translateY(var(--py, 0px));
  z-index: 1;
  perspective: 1500px;
  pointer-events: none;
}
.hero-stage .shot {
  position: absolute;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid var(--line);
  box-shadow: var(--shadow-l);
  background: var(--bg-card);
  will-change: transform;
}
.hero-stage .shot img { width: 100%; height: 100%; object-fit: cover; object-position: top; }
/* Composición centrada verticalmente: las tres piezas caben dentro del cuadro */
.hero-stage .shot-a { width: 86%; aspect-ratio: 16/10.4; right: 0; top: 6%; transform: rotateY(-9deg) rotateX(4deg); }
.hero-stage .shot-b { width: 60%; aspect-ratio: 16/10.4; left: -6%; top: 46%; transform: rotateY(7deg) rotateX(-3deg); }
.hero-stage .shot-c { width: 25%; aspect-ratio: 9/19; right: 3%; top: 40%; border-radius: 20px; transform: rotateY(-14deg); z-index: 2; }
.hero-stage .shot .bar {
  height: 22px;
  display: flex;
  align-items: center;
  gap: 4px;
  padding-inline: 9px;
  border-bottom: 1px solid var(--line);
  background: var(--bg-soft);
}
.hero-stage .shot .bar i { width: 5px; height: 5px; border-radius: 50%; background: var(--line-strong); }
.hero-scroll-hint {
  position: absolute;
  bottom: 1.75rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  color: var(--ink-faint);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  z-index: 3;
}
.hero-scroll-hint .line {
  width: 1px; height: 44px;
  background: var(--line-strong);
  overflow: hidden;
  position: relative;
}
.hero-scroll-hint .line::after {
  content: "";
  position: absolute;
  left: 0; top: -100%;
  width: 100%; height: 100%;
  background: var(--ink);
  animation: scroll-hint 2.2s var(--ease-io) infinite;
}
@keyframes scroll-hint {
  0% { top: -100%; }
  55%, 100% { top: 100%; }
}

/* Marquee bajo el hero */
.hero-marquee { border-block: 1px solid var(--line); padding-block: 1.1rem; }

/* ---------- 11 · BENTO + SERVICIOS ---------- */
.bento {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: clamp(0.9rem, 1.6vw, 1.4rem);
}
.bento-cell {
  position: relative;
  grid-column: span 4;
  border-radius: var(--r-l);
  border: 1px solid var(--line);
  background: var(--bg-card);
  padding: clamp(1.5rem, 2.6vw, 2.25rem);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
  min-height: 320px;
  transition: transform 0.5s var(--ease-out), box-shadow 0.5s var(--ease-out), border-color 0.4s;
}
.bento-cell:hover { transform: translateY(-4px); box-shadow: var(--shadow-m); border-color: var(--line-strong); }
.bento-cell.is-wide { grid-column: span 8; }
.bento-cell.is-tall { grid-row: span 2; }
.bento-cell h3 { font-size: 1.25rem; margin-top: auto; }
.bento-cell p { font-size: 0.95rem; color: var(--ink-mute); line-height: 1.55; }
.bento-cell .cell-tag {
  position: absolute;
  top: 1.4rem; right: 1.4rem;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-faint);
}
.bento-viz {
  position: relative;
  flex: 1;
  min-height: 120px;
  margin: -0.4rem -0.4rem 0.4rem;
  display: grid;
  place-items: center;
  overflow: hidden;
}

/* Viz: navegador esqueleto que se construye en bucle */
.viz-browser {
  width: min(320px, 88%);
  border-radius: 12px;
  border: 1px solid var(--line-strong);
  background: var(--bg);
  box-shadow: var(--shadow-s);
  overflow: hidden;
  transform: rotate(-2deg) translateY(4px);
  transition: transform 0.6s var(--ease-spring);
}
.bento-cell:hover .viz-browser { transform: rotate(0deg) translateY(0); }
.viz-browser .vb-bar { height: 20px; border-bottom: 1px solid var(--line); display: flex; gap: 4px; align-items: center; padding-inline: 8px; }
.viz-browser .vb-bar i { width: 5px; height: 5px; border-radius: 50%; background: var(--line-strong); }
.viz-browser .vb-body { padding: 12px; display: grid; gap: 7px; }
.viz-browser .sk {
  height: 8px;
  border-radius: 4px;
  background: var(--line);
  transform-origin: left;
  animation: sk-build 4.4s var(--ease-out) infinite;
}
.viz-browser .sk-hero { height: 40px; border-radius: 7px; background: linear-gradient(120deg, var(--line), var(--line-strong), var(--line)); background-size: 200% 100%; animation: sk-build 4.4s var(--ease-out) infinite, sk-shine 4.4s linear infinite; }
.viz-browser .sk:nth-child(2) { width: 72%; animation-delay: 0.18s; }
.viz-browser .sk:nth-child(3) { width: 52%; animation-delay: 0.32s; }
.viz-browser .sk-cta { width: 34%; height: 14px; border-radius: 7px; background: var(--ink); opacity: 0.85; animation-delay: 0.5s; }
@keyframes sk-build {
  0% { transform: scaleX(0); opacity: 0; }
  12%, 82% { transform: scaleX(1); opacity: 1; }
  94%, 100% { transform: scaleX(1); opacity: 0; }
}
@keyframes sk-shine {
  0%, 30% { background-position: 120% 0; }
  70%, 100% { background-position: -60% 0; }
}

/* Viz: tarjetas de feed que rotan */
.viz-feed { display: grid; grid-template-columns: repeat(3, 58px); gap: 8px; }
.viz-feed i {
  aspect-ratio: 4/5;
  border-radius: 9px;
  border: 1px solid var(--line-strong);
  background: linear-gradient(150deg, var(--bg-soft), var(--line));
  animation: feed-pop 3.6s var(--ease-spring) infinite;
}
.viz-feed i:nth-child(2) { animation-delay: 0.35s; }
.viz-feed i:nth-child(3) { animation-delay: 0.7s; }
.viz-feed i:nth-child(4) { animation-delay: 1.05s; }
.viz-feed i:nth-child(5) { animation-delay: 1.4s; }
.viz-feed i:nth-child(6) { animation-delay: 1.75s; }
@keyframes feed-pop {
  0%, 100% { transform: translateY(0) scale(1); }
  12% { transform: translateY(-5px) scale(1.05); box-shadow: var(--shadow-s); }
  24% { transform: translateY(0) scale(1); }
}

/* Viz: gráfico SEO ascendente */
.viz-seo { display: flex; align-items: flex-end; gap: 9px; height: 96px; }
.viz-seo i {
  width: 16px;
  border-radius: 5px 5px 2px 2px;
  background: var(--line-strong);
  height: calc(var(--h) * 1%);
  transform-origin: bottom;
  animation: bar-rise 3.8s var(--ease-out) infinite;
}
.viz-seo i:last-child { background: var(--ink); }
@keyframes bar-rise {
  0% { transform: scaleY(0); }
  18%, 86% { transform: scaleY(1); }
  100% { transform: scaleY(0); }
}

/* Viz: línea de tiempo de vídeo */
.viz-video { width: min(300px, 90%); display: grid; gap: 6px; }
.viz-video .track {
  height: 26px;
  border-radius: 7px;
  border: 1px solid var(--line-strong);
  background: repeating-linear-gradient(90deg, var(--line) 0 22px, transparent 22px 24px);
  position: relative;
  overflow: hidden;
}
.viz-video .track::after {
  content: "";
  position: absolute;
  inset-block: 0;
  left: 0;
  width: 2px;
  background: var(--ink);
  animation: playhead 3.2s linear infinite;
}
.viz-video .track:nth-child(2) { width: 78%; }
.viz-video .track:nth-child(3) { width: 56%; }
@keyframes playhead { to { left: 100%; } }

/* Viz: nodos de automatización */
.viz-nodes { position: relative; width: 200px; height: 110px; }
.viz-nodes i {
  position: absolute;
  width: 13px; height: 13px;
  border-radius: 50%;
  border: 1.5px solid var(--ink);
  background: var(--bg);
  animation: node-pulse 2.8s ease-in-out infinite;
}
.viz-nodes svg { position: absolute; inset: 0; width: 100%; height: 100%; }
.viz-nodes svg path {
  stroke: var(--line-strong);
  stroke-width: 1.4;
  fill: none;
  stroke-dasharray: 5 6;
  animation: dash-flow 2.2s linear infinite;
}
@keyframes node-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(12,12,13,0.18); }
  50% { box-shadow: 0 0 0 7px rgba(12,12,13,0); }
}
@keyframes dash-flow { to { stroke-dashoffset: -22; } }

/* Viz: carrito / ecommerce */
.viz-shop { display: flex; align-items: center; gap: 12px; }
.viz-shop .prod {
  width: 92px;
  border-radius: 12px;
  border: 1px solid var(--line-strong);
  background: var(--bg);
  padding: 9px;
  display: grid;
  gap: 6px;
  box-shadow: var(--shadow-s);
  animation: prod-tilt 4s var(--ease-spring) infinite;
}
.viz-shop .prod .ph { aspect-ratio: 1; border-radius: 8px; background: linear-gradient(150deg, var(--bg-soft), var(--line)); }
.viz-shop .prod .ln { height: 6px; border-radius: 3px; background: var(--line); width: 80%; }
.viz-shop .buy {
  padding: 8px 14px;
  border-radius: var(--r-pill);
  background: var(--ink);
  color: var(--bg);
  font-size: 0.72rem;
  font-weight: 700;
  animation: buy-pop 4s var(--ease-spring) infinite;
}
@keyframes prod-tilt { 0%,100% { transform: rotate(-2deg); } 50% { transform: rotate(2deg) translateY(-4px); } }
@keyframes buy-pop { 0%, 55%, 100% { transform: scale(1); } 62% { transform: scale(1.14); } 70% { transform: scale(1); } }

/* Servicios (página Servicios) — acordeón desplegable con detalle */
.svc-list { display: grid; }
.svc-item { border-top: 1px solid var(--line); }
.svc-item:last-child { border-bottom: 1px solid var(--line); }
.svc-head {
  position: relative;
  width: 100%;
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  align-items: center;
  gap: clamp(0.9rem, 2.5vw, 2rem);
  text-align: left;
  padding: clamp(1.35rem, 2.8vw, 2.1rem) clamp(0.4rem, 1.4vw, 1.2rem);
  transition: padding-left 0.4s var(--ease-out), background 0.4s var(--ease-out);
}
.svc-head:hover { background: var(--bg-soft); padding-left: clamp(0.9rem, 2vw, 1.6rem); }
.svc-head .idx {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--text-s);
  color: var(--ink-faint);
  min-width: 2rem;
  font-variant-numeric: tabular-nums;
}
.svc-head .ttl {
  font-size: clamp(1.4rem, 3.2vw, 2.5rem);
  font-weight: 570;
  letter-spacing: -0.035em;
  color: var(--ink);
  line-height: 1.1;
  transition: transform 0.45s var(--ease-out);
}
.svc-head:hover .ttl { transform: translateX(6px); }
.svc-head .svc-tag {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-mute);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-pill);
  padding: 0.34rem 0.85rem;
  white-space: nowrap;
}
.svc-head .svc-ico {
  width: 44px; height: 44px;
  border-radius: 50%;
  border: 1px solid var(--line-strong);
  display: grid;
  place-items: center;
  color: var(--ink);
  transition: transform 0.5s var(--ease-spring), background 0.35s, color 0.35s;
}
.svc-head .svc-ico svg { width: 15px; height: 15px; }
.svc-item.is-open .svc-head .svc-ico { transform: rotate(135deg); background: var(--ink); color: var(--bg); border-color: var(--ink); }
.svc-item.is-open .svc-head .ttl { transform: translateX(6px); }

.svc-panel {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.55s var(--ease-out);
}
.svc-panel > .svc-panel-in { overflow: hidden; min-height: 0; }
.svc-item.is-open .svc-panel { grid-template-rows: 1fr; }
.svc-panel-in {
  display: grid;
  gap: 1.1rem;
  padding: 0 clamp(0.4rem, 1.4vw, 1.2rem) clamp(1.6rem, 3vw, 2.2rem) calc(2rem + clamp(0.9rem, 2.5vw, 2rem));
  max-width: 62ch;
}
.svc-panel-in > * { opacity: 0; transform: translateY(10px); transition: opacity 0.5s var(--ease-out), transform 0.5s var(--ease-out); }
.svc-item.is-open .svc-panel-in > * { opacity: 1; transform: none; }
.svc-item.is-open .svc-panel-in > *:nth-child(2) { transition-delay: 0.06s; }
.svc-item.is-open .svc-panel-in > *:nth-child(3) { transition-delay: 0.12s; }
.svc-panel-in > p { color: var(--ink-mute); font-size: 1.02rem; line-height: 1.6; }
.svc-points {
  list-style: none;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.65rem 1.5rem;
}
.svc-points li {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  font-size: 0.95rem;
  color: var(--ink-soft);
}
.svc-points .ck {
  flex: none;
  width: 20px; height: 20px;
  margin-top: 1px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: color-mix(in srgb, var(--ok) 14%, transparent);
  color: var(--ok);
}
.svc-points .ck svg { width: 11px; height: 11px; }

/* ---------- 12 · PORTFOLIO ---------- */
.work-list { display: grid; gap: var(--s-5); }
.work-item {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--s-3);
  align-items: center;
}
.work-item .work-media { grid-column: 1 / 8; }
.work-item .work-info { grid-column: 8 / 13; }
.work-item.is-flip .work-media { grid-column: 6 / 13; order: 2; }
.work-item.is-flip .work-info { grid-column: 1 / 6; order: 1; }

.frame {
  position: relative;
  display: block;
  border-radius: var(--r-m);
  background: var(--bg-card);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-m);
  transform-style: preserve-3d;
  will-change: transform;
}
.frame .frame-bar {
  display: flex;
  align-items: center;
  gap: 5px;
  height: 34px;
  padding-inline: 14px;
  border-bottom: 1px solid var(--line);
  border-radius: calc(var(--r-m) - 1px) calc(var(--r-m) - 1px) 0 0;
  background: color-mix(in srgb, var(--bg-soft) 86%, transparent);
  position: relative;
  z-index: 3;
}
.frame .frame-bar i { width: 7px; height: 7px; border-radius: 50%; background: var(--line-strong); }
.frame .frame-bar .url {
  margin-inline: auto;
  font-size: 0.7rem;
  font-weight: 550;
  color: var(--ink-mute);
  background: var(--bg);
  border: 1px solid var(--line);
  padding: 2.5px 12px;
  border-radius: var(--r-pill);
  letter-spacing: 0.01em;
}
.frame .frame-view {
  display: block;
  aspect-ratio: 16 / 10.6;
  overflow: hidden;
  position: relative;
  border-radius: 0 0 calc(var(--r-m) - 1px) calc(var(--r-m) - 1px);
}
.frame .frame-view img.tall {
  width: 100%;
  height: auto;
  transition: transform 4.5s cubic-bezier(0.3, 0, 0.4, 1);
  will-change: transform;
}
.frame:hover .frame-view img.tall { transform: translateY(calc(-1 * var(--pan, 62%))); }
/* Brillo que sigue al cursor */
.frame .glare {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background: radial-gradient(420px 300px at var(--gx, 50%) var(--gy, 40%), rgba(255, 255, 255, 0.16), transparent 62%);
  opacity: 0;
  transition: opacity 0.4s;
  mix-blend-mode: soft-light;
}
.frame:hover .glare { opacity: 1; }

.work-info { display: grid; gap: 1rem; justify-items: start; }
.work-info .work-num {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--text-l);
  color: var(--ink-faint);
}
.work-info h3 { font-size: var(--text-2xl); font-weight: 570; }
.work-info .tags { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.work-info .tag {
  font-size: 0.72rem;
  font-weight: 650;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--ink-mute);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-pill);
  padding: 0.32rem 0.8rem;
}
.work-info p { color: var(--ink-mute); max-width: 44ch; }

/* Grid compacto (resto de proyectos) */
.work-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1rem, 2vw, 1.75rem); }
.work-card {
  position: relative;
  display: block;
  border-radius: var(--r-m);
  border: 1px solid var(--line);
  background: var(--bg-card);
  overflow: hidden;
  transition: transform 0.55s var(--ease-out), box-shadow 0.55s var(--ease-out), border-color 0.4s;
  will-change: transform;
}
.work-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-l); border-color: var(--line-strong); }
.work-card .wc-media { display: block; aspect-ratio: 16/11; overflow: hidden; border-radius: calc(var(--r-m) - 1px) calc(var(--r-m) - 1px) 0 0; }
.work-card .wc-info { display: flex; }
.work-card .wc-media img { width: 100%; height: auto; transition: transform 3.5s cubic-bezier(0.3, 0, 0.4, 1); }
.work-card:hover .wc-media img { transform: translateY(calc(-1 * var(--pan, 55%))); }
.work-card .wc-info {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.1rem 1.3rem;
  border-top: 1px solid var(--line);
}
.work-card .wc-info strong { color: var(--ink); font-weight: 650; font-size: 1.02rem; letter-spacing: -0.02em; }
.work-card .wc-info span { font-size: 0.78rem; color: var(--ink-mute); font-weight: 550; }
.work-card .wc-arrow {
  flex: none;
  width: 34px; height: 34px;
  border-radius: 50%;
  border: 1px solid var(--line-strong);
  display: grid;
  place-items: center;
  color: var(--ink);
  transition: background 0.3s, color 0.3s, transform 0.45s var(--ease-spring);
}
.work-card .wc-arrow svg { width: 13px; height: 13px; }
.work-card:hover .wc-arrow { background: var(--ink); color: var(--bg); transform: rotate(-45deg); }

/* Dúo desktop + móvil (destacados portfolio) */
.duo { position: relative; }
.duo .duo-mobile {
  position: absolute;
  right: -3.5%;
  bottom: -7%;
  width: 23%;
  aspect-ratio: 390 / 700;
  border-radius: clamp(12px, 1.6vw, 22px);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-l);
  overflow: hidden;
  background: var(--bg-card);
  z-index: 4;
  transition: transform 0.6s var(--ease-spring);
}
.duo:hover .duo-mobile { transform: translateY(-8px) rotate(1.5deg); }
.duo .duo-mobile img { width: 100%; height: 100%; object-fit: cover; object-position: top; }

/* ---------- 13 · MARQUEE + TESTIMONIOS ---------- */
.marquee {
  overflow: hidden;
  display: flex;
  user-select: none;
  mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}
.marquee-track {
  display: flex;
  align-items: center;
  gap: clamp(1.5rem, 3vw, 3rem);
  flex: none;
  padding-inline-end: clamp(1.5rem, 3vw, 3rem);
  animation: marquee var(--mq-dur, 30s) linear infinite;
}
.marquee:hover .marquee-track { animation-play-state: paused; }
.marquee.is-paused .marquee-track { animation-play-state: paused; }
.marquee-track.rev { animation-direction: reverse; }
@keyframes marquee { to { transform: translateX(-100%); } }
.marquee .mq-item {
  display: inline-flex;
  align-items: center;
  gap: clamp(1.5rem, 3vw, 3rem);
  font-size: var(--text-s);
  font-weight: 620;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-mute);
  white-space: nowrap;
}
.marquee .mq-item::after { content: "✦"; font-size: 0.7em; color: var(--ink-faint); }

/* Marquee gigante (cinta de texto grande) */
.marquee-xl .mq-item {
  font-size: clamp(2.6rem, 7vw, 6rem);
  font-weight: 580;
  letter-spacing: -0.03em;
  text-transform: none;
  color: var(--ink);
}
.marquee-xl .mq-item em { font-family: var(--font-serif); font-style: italic; font-weight: 400; color: var(--ink-mute); }
.marquee-xl .mq-item::after { color: var(--line-strong); }

.t-card {
  flex: none;
  width: min(400px, 82vw);
  padding: 1.7rem 1.8rem;
  border-radius: var(--r-m);
  border: 1px solid var(--line);
  background: var(--glass);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: var(--shadow-s);
  display: grid;
  gap: 1.1rem;
  white-space: normal;
  transition: transform 0.5s var(--ease-out), box-shadow 0.5s;
}
/* En el marquee todas las tarjetas comparten alto; el texto largo se recorta */
.t-marquee .marquee-track { align-items: stretch; gap: 1.1rem; padding-inline-end: 1.1rem; }
.t-marquee .t-card { grid-template-rows: 1fr auto; height: 100%; }
.t-marquee .t-card blockquote {
  display: -webkit-box;
  -webkit-line-clamp: 6;
  line-clamp: 6;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.t-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-m); }
.t-card blockquote {
  font-size: 1.02rem;
  line-height: 1.6;
  color: var(--ink-soft);
  letter-spacing: -0.01em;
}
.t-card blockquote::before { content: "“"; font-family: var(--font-serif); font-size: 1.6em; line-height: 0; vertical-align: -0.3em; color: var(--ink-faint); margin-right: 2px; }
.t-card figcaption { display: flex; align-items: center; gap: 0.85rem; }
.t-card .avatar {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: var(--ink);
  color: var(--bg);
  display: grid;
  place-items: center;
  font-weight: 700;
  font-size: 0.82rem;
  letter-spacing: 0.02em;
  flex: none;
}
.t-card figcaption strong { display: block; color: var(--ink); font-weight: 650; font-size: 0.95rem; }
.t-card figcaption span { font-size: 0.8rem; color: var(--ink-mute); }
.t-card .stars { margin-left: auto; color: var(--ink); font-size: 0.75rem; letter-spacing: 2px; }

/* ---------- 14 · STATS + PROCESO + FAQ + DEMO ---------- */
.stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-block: 1px solid var(--line);
}
.stat {
  padding: clamp(1.75rem, 3vw, 2.75rem) 1rem;
  text-align: center;
  display: grid;
  gap: 0.35rem;
  border-inline-start: 1px solid var(--line);
}
.stat:first-child { border-inline-start: none; }
.stat b {
  font-size: clamp(2.2rem, 4.5vw, 3.6rem);
  font-weight: 620;
  letter-spacing: -0.04em;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
  line-height: 1;
}
.stat b sup { font-size: 0.45em; font-family: var(--font-serif); font-style: italic; font-weight: 400; margin-left: 2px; }
.stat b span { font-size: inherit; color: inherit; font-weight: inherit; }
.stat > span { font-size: var(--text-s); color: var(--ink-mute); font-weight: 550; }

/* Banner de entrega exprés 72 h */
.express-badge {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: clamp(1.25rem, 3vw, 2.5rem);
  padding: clamp(1.5rem, 3vw, 2.25rem) clamp(1.5rem, 3vw, 2.5rem);
  border-radius: var(--r-l);
  border: 1px solid var(--line);
  background: var(--glass);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: var(--shadow-s);
}
.express-badge .eb-num {
  font-size: clamp(3.4rem, 8vw, 5.5rem);
  font-weight: 640;
  letter-spacing: -0.05em;
  line-height: 0.9;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.express-badge .eb-num span {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  font-size: 0.42em;
  margin-left: 2px;
  color: var(--ink-mute);
}
.express-badge .eb-body strong {
  display: block;
  font-size: var(--text-l);
  font-weight: 650;
  letter-spacing: -0.02em;
  color: var(--ink);
  margin-bottom: 0.3rem;
}
.express-badge .eb-body p { color: var(--ink-mute); font-size: 0.96rem; line-height: 1.55; max-width: 52ch; }
@media (max-width: 760px) {
  .express-badge { grid-template-columns: auto 1fr; }
  .express-badge .btn { grid-column: 1 / -1; justify-self: start; }
}

/* Proceso — línea temporal vertical */
.steps { position: relative; display: grid; gap: 0; max-width: 880px; margin-inline: auto; }
.steps::before {
  content: "";
  position: absolute;
  left: 27px;
  top: 30px;
  bottom: 30px;
  width: 1px;
  background: var(--line-strong);
}
.steps .steps-progress {
  position: absolute;
  left: 27px;
  top: 30px;
  width: 1px;
  height: calc((100% - 60px) * var(--p, 0));
  background: var(--ink);
  transition: height 0.15s linear;
}
.step {
  position: relative;
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: clamp(1.25rem, 3vw, 2.25rem);
  padding-block: clamp(1.5rem, 3vw, 2.5rem);
}
.step .step-dot {
  width: 56px; height: 56px;
  border-radius: 50%;
  border: 1px solid var(--line-strong);
  background: var(--bg);
  display: grid;
  place-items: center;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 1.05rem;
  color: var(--ink);
  position: relative;
  z-index: 2;
  transition: background 0.4s, color 0.4s, transform 0.4s var(--ease-spring), box-shadow 0.4s;
}
.step.is-active .step-dot { background: var(--ink); color: var(--bg); transform: scale(1.08); box-shadow: var(--shadow-m); }
.step .step-body { display: grid; gap: 0.5rem; align-content: start; }
.step .step-meta { font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.13em; text-transform: uppercase; color: var(--ink-faint); }
.step h3 { font-size: var(--text-xl); }
.step p { color: var(--ink-mute); max-width: 58ch; }
.step .step-chips { display: flex; flex-wrap: wrap; gap: 0.45rem; margin-top: 0.4rem; }
.step .step-chips i {
  font-style: normal;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--ink-mute);
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: var(--r-pill);
  padding: 0.28rem 0.75rem;
}

/* FAQ — acordeón */
.faq { max-width: 820px; margin-inline: auto; }
.faq-item { border-bottom: 1px solid var(--line); }
.faq-q {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  text-align: left;
  padding: 1.5rem 0.25rem;
  font-size: var(--text-l);
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--ink);
  transition: padding-left 0.35s var(--ease-out);
}
.faq-q:hover { padding-left: 0.8rem; }
.faq-q .faq-ico {
  flex: none;
  width: 34px; height: 34px;
  border-radius: 50%;
  border: 1px solid var(--line-strong);
  display: grid;
  place-items: center;
  transition: transform 0.5s var(--ease-spring), background 0.35s, color 0.35s;
}
.faq-q .faq-ico svg { width: 13px; height: 13px; }
.faq-item.is-open .faq-q .faq-ico { transform: rotate(135deg); background: var(--ink); color: var(--bg); border-color: var(--ink); }
.faq-a {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.55s var(--ease-out);
}
.faq-a > div { overflow: hidden; }
.faq-a p { padding: 0 0.25rem 1.6rem; color: var(--ink-mute); max-width: 64ch; }
.faq-item.is-open .faq-a { grid-template-rows: 1fr; }

/* Banda demo gratuita — sección invertida */
.demo-band {
  position: relative;
  background: var(--inverse-bg);
  color: var(--inverse-ink);
  border-radius: var(--r-l);
  padding: clamp(3rem, 6vw, 5.5rem) clamp(1.75rem, 5vw, 5rem);
  overflow: hidden;
  isolation: isolate;
}
.demo-band::before {
  content: "";
  position: absolute;
  inset: -30%;
  background:
    radial-gradient(40% 34% at 78% 20%, rgba(255, 255, 255, 0.08), transparent 65%),
    radial-gradient(34% 30% at 12% 85%, rgba(255, 255, 255, 0.06), transparent 60%);
  z-index: -1;
  animation: grad-drift 20s ease-in-out infinite alternate;
}
[data-theme="dark"] .demo-band::before {
  background:
    radial-gradient(40% 34% at 78% 20%, rgba(12, 12, 13, 0.08), transparent 65%),
    radial-gradient(34% 30% at 12% 85%, rgba(12, 12, 13, 0.06), transparent 60%);
}
.demo-band h2 { color: inherit; max-width: 16ch; }
.demo-band .lead { color: color-mix(in srgb, var(--inverse-ink) 68%, transparent); }
.demo-band .demo-grid {
  display: grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: var(--s-4);
  align-items: center;
}
.demo-band .demo-points { display: grid; gap: 1.1rem; }
.demo-band .demo-point {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
  padding: 1.1rem 1.25rem;
  border: 1px solid color-mix(in srgb, var(--inverse-ink) 14%, transparent);
  border-radius: var(--r-m);
  background: color-mix(in srgb, var(--inverse-ink) 5%, transparent);
  backdrop-filter: blur(8px);
  transition: transform 0.45s var(--ease-out), background 0.35s;
}
.demo-band .demo-point:hover { transform: translateX(6px); background: color-mix(in srgb, var(--inverse-ink) 9%, transparent); }
.demo-band .demo-point .n { font-family: var(--font-serif); font-style: italic; opacity: 0.55; }
.demo-band .demo-point strong { display: block; font-weight: 650; margin-bottom: 0.15rem; }
.demo-band .demo-point p { font-size: 0.92rem; opacity: 0.72; line-height: 1.55; }

/* ---------- 15 · REDES + RESEÑA + ABOUT ---------- */
/* Tarjetas de red social (seguir) */
.social-cards { display: grid; grid-template-columns: repeat(2, 1fr); gap: clamp(1rem, 2vw, 1.5rem); }
.social-card {
  position: relative;
  display: flex;
  align-items: center;
  gap: clamp(1rem, 2.2vw, 1.5rem);
  padding: clamp(1.5rem, 3vw, 2.1rem);
  border-radius: var(--r-l);
  border: 1px solid var(--line);
  background: var(--bg-card);
  overflow: hidden;
  isolation: isolate;
  transition: transform 0.5s var(--ease-out), box-shadow 0.5s var(--ease-out), border-color 0.4s;
}
.social-card::before {
  content: "";
  position: absolute;
  z-index: -1;
  inset: auto auto -40% -20%;
  width: 60%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--ink) 6%, transparent), transparent 70%);
  opacity: 0;
  transition: opacity 0.5s var(--ease-out), transform 0.6s var(--ease-out);
}
.social-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-l); border-color: var(--line-strong); }
.social-card:hover::before { opacity: 1; transform: translate(20%, -15%); }
.social-card .sc-ico {
  flex: none;
  width: clamp(52px, 6vw, 64px);
  height: clamp(52px, 6vw, 64px);
  border-radius: 18px;
  display: grid;
  place-items: center;
  color: var(--bg);
  background: var(--ink);
  transition: transform 0.5s var(--ease-spring);
}
.social-card .sc-ico svg { width: 46%; height: 46%; }
.social-card:hover .sc-ico { transform: scale(1.06) rotate(-4deg); }
.social-card .sc-body { flex: 1 1 auto; display: grid; gap: 0.15rem; min-width: 0; }
.social-card .sc-body strong { font-size: var(--text-l); font-weight: 650; letter-spacing: -0.02em; color: var(--ink); }
.social-card .sc-handle { font-size: 0.85rem; color: var(--ink-mute); font-weight: 550; }
.social-card .sc-desc { font-size: 0.9rem; color: var(--ink-mute); margin-top: 0.35rem; line-height: 1.45; }
.social-card .sc-follow {
  flex: none;
  margin-left: auto;
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.55rem 1.1rem;
  border-radius: var(--r-pill);
  border: 1px solid var(--line-strong);
  font-size: 0.85rem;
  font-weight: 620;
  color: var(--ink);
  white-space: nowrap;
  transition: background 0.35s, color 0.35s, border-color 0.35s;
}
.social-card .sc-follow .arr svg { width: 0.8em; height: 0.8em; transition: transform 0.4s var(--ease-out); }
.social-card:hover .sc-follow { background: var(--ink); color: var(--bg); border-color: var(--ink); }
.social-card:hover .sc-follow .arr svg { transform: translate(2px, -2px); }

/* CTA de reseña (Google) */
.review-cta {
  margin-top: var(--s-4);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-2);
  padding: clamp(1.5rem, 3vw, 2.2rem) clamp(1.5rem, 3vw, 2.5rem);
  border-radius: var(--r-l);
  border: 1px solid var(--line);
  background: var(--bg-soft);
}
.review-cta .rc-text { display: grid; gap: 0.3rem; }
.review-cta .rc-stars { display: inline-flex; gap: 3px; color: var(--ink); margin-bottom: 0.2rem; }
.review-cta .rc-stars svg { width: 15px; height: 15px; }
.review-cta .rc-text strong { font-size: var(--text-l); font-weight: 650; letter-spacing: -0.02em; color: var(--ink); }
.review-cta .rc-text .small { max-width: 48ch; }
.review-cta .btn .sc-g { display: inline-grid; place-items: center; width: 1.05em; height: 1.05em; }
.review-cta .btn .sc-g svg { width: 100%; height: 100%; }

/* Iconos sociales del footer */
.footer-social { display: flex; gap: 0.6rem; }
.footer-social a {
  width: 40px; height: 40px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  border: 1px solid color-mix(in srgb, var(--inverse-ink) 16%, transparent);
  color: color-mix(in srgb, var(--inverse-ink) 72%, transparent);
  transition: background 0.3s, color 0.3s, transform 0.35s var(--ease-spring), border-color 0.3s;
}
.footer-social a svg { width: 17px; height: 17px; }
.footer-social a:hover { background: var(--inverse-ink); color: var(--inverse-bg); border-color: var(--inverse-ink); transform: translateY(-2px); }

/* Placeholder de fotografía — indica exactamente qué foto colocar */
.ph-media {
  position: relative;
  display: grid;
  place-items: center;
  background:
    linear-gradient(160deg, var(--bg-soft), color-mix(in srgb, var(--line) 55%, var(--bg-soft))),
    var(--bg-soft);
  overflow: hidden;
  border-radius: inherit;
  min-height: 100%;
  width: 100%;
}
.ph-media::before {
  content: "";
  position: absolute;
  inset: 10px;
  border: 1.5px dashed var(--line-strong);
  border-radius: calc(var(--r-m) - 6px);
  pointer-events: none;
}
.ph-media .ph-label {
  display: grid;
  justify-items: center;
  gap: 0.55rem;
  text-align: center;
  padding: 1.25rem;
  color: var(--ink-mute);
  max-width: 30ch;
}
.ph-media .ph-label svg { width: 26px; height: 26px; opacity: 0.6; }
.ph-media .ph-label strong { font-size: 0.85rem; font-weight: 700; color: var(--ink-soft); letter-spacing: 0.01em; }
.ph-media .ph-label span { font-size: 0.74rem; line-height: 1.45; opacity: 0.85; }
.ph-media .ph-tag {
  position: absolute;
  top: 1.1rem; left: 1.1rem;
  font-size: 0.62rem;
  font-weight: 750;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 0.3rem 0.7rem;
  background: var(--glass-strong);
  border: 1px solid var(--line);
  border-radius: var(--r-pill);
  color: var(--ink-mute);
  backdrop-filter: blur(6px);
}

.about-grid { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: var(--s-4); align-items: start; }
.about-photo { border-radius: var(--r-l); overflow: hidden; aspect-ratio: 4/5; position: sticky; top: calc(var(--nav-h) + 24px); box-shadow: var(--shadow-m); }
.about-body { display: grid; gap: var(--s-3); }
.about-body .big-quote {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--text-xl);
  line-height: 1.35;
  color: var(--ink);
  letter-spacing: -0.01em;
}
.value-list { display: grid; gap: 0; border-top: 1px solid var(--line); }
.value-item { display: grid; grid-template-columns: auto 1fr; gap: 1.25rem; padding: 1.4rem 0.25rem; border-bottom: 1px solid var(--line); align-items: baseline; transition: padding-left 0.35s var(--ease-out); }
.value-item:hover { padding-left: 0.8rem; }
.value-item .vi { font-family: var(--font-serif); font-style: italic; color: var(--ink-faint); font-size: 0.95rem; min-width: 2rem; }
.value-item strong { color: var(--ink); font-weight: 650; display: block; margin-bottom: 0.2rem; }
.value-item p { font-size: 0.95rem; color: var(--ink-mute); }

/* ---------- 16 · FORMULARIO ---------- */
.contact-layout { display: grid; grid-template-columns: 1fr 0.72fr; gap: var(--s-4); align-items: start; }

.form {
  display: grid;
  gap: 1.6rem;
  padding: clamp(1.75rem, 3.5vw, 3rem);
  border-radius: var(--r-l);
  border: 1px solid var(--line);
  background: var(--bg-card);
  box-shadow: var(--shadow-s);
  position: relative;
  overflow: hidden;
}
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.6rem; }

.field { position: relative; display: grid; gap: 0.4rem; }
.field label {
  font-size: 0.8rem;
  font-weight: 650;
  letter-spacing: 0.04em;
  color: var(--ink-soft);
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}
.field label .opt { font-weight: 500; color: var(--ink-faint); font-size: 0.72rem; }
.field .control {
  position: relative;
  border-radius: var(--r-s);
  border: 1px solid var(--line-strong);
  background: var(--bg);
  transition: border-color 0.3s, box-shadow 0.3s, transform 0.3s var(--ease-out);
}
.field input, .field textarea, .field select {
  width: 100%;
  padding: 0.95rem 2.8rem 0.95rem 1.1rem;
  font-size: 1rem;
  color: var(--ink);
  border-radius: inherit;
  outline: none;
}
.field textarea { min-height: 150px; resize: vertical; padding-right: 1.1rem; }
.field input::placeholder, .field textarea::placeholder { color: var(--ink-faint); }
.field .control:focus-within {
  border-color: var(--ink);
  box-shadow: 0 0 0 3.5px color-mix(in srgb, var(--ink) 9%, transparent);
  transform: translateY(-1px);
}
/* Línea inferior que se dibuja al enfocar */
.field .control::after {
  content: "";
  position: absolute;
  left: 8%; right: 8%;
  bottom: -1px;
  height: 1.5px;
  background: var(--ink);
  transform: scaleX(0);
  transition: transform 0.45s var(--ease-out);
}
.field .control:focus-within::after { transform: scaleX(1); }
.field .state-ico {
  position: absolute;
  right: 0.9rem;
  top: 50%;
  transform: translateY(-50%) scale(0.4);
  width: 20px; height: 20px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  opacity: 0;
  transition: opacity 0.25s, transform 0.35s var(--ease-spring);
}
.field .state-ico svg { width: 11px; height: 11px; }
.field.is-valid .state-ico.ok, .field.is-invalid .state-ico.ko { opacity: 1; transform: translateY(-50%) scale(1); }
.field .state-ico.ok { background: color-mix(in srgb, var(--ok) 14%, transparent); color: var(--ok); }
.field .state-ico.ko { background: color-mix(in srgb, var(--err) 12%, transparent); color: var(--err); }
.field.is-invalid .control { border-color: color-mix(in srgb, var(--err) 55%, var(--line-strong)); }
.field.is-invalid .control::after { background: var(--err); transform: scaleX(1); }
.field .field-err {
  font-size: 0.78rem;
  font-weight: 550;
  color: var(--err);
  min-height: 1.1em;
  opacity: 0;
  transform: translateY(-3px);
  transition: opacity 0.3s, transform 0.3s var(--ease-out);
}
.field.is-invalid .field-err { opacity: 1; transform: none; }
.field .count { font-variant-numeric: tabular-nums; font-size: 0.72rem; color: var(--ink-faint); }

/* Selector de servicio como chips */
.chip-set { display: flex; flex-wrap: wrap; gap: 0.55rem; }
.chip-set .chip { position: relative; }
.chip-set input { position: absolute; inset: 0; opacity: 0; cursor: pointer; }
.chip-set .chip span {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.6rem 1.1rem;
  border-radius: var(--r-pill);
  border: 1px solid var(--line-strong);
  font-size: 0.87rem;
  font-weight: 580;
  color: var(--ink-soft);
  background: var(--bg);
  transition: background 0.3s, color 0.3s, border-color 0.3s, transform 0.3s var(--ease-spring);
}
.chip-set .chip span::before { content: "+"; font-weight: 500; opacity: 0.5; transition: 0.3s; }
.chip-set .chip:hover span { transform: translateY(-2px); border-color: var(--ink-mute); }
.chip-set input:checked + span { background: var(--ink); color: var(--bg); border-color: var(--ink); }
.chip-set input:checked + span::before { content: "✓"; opacity: 1; }
.chip-set input:focus-visible + span { outline: 2px solid var(--ink); outline-offset: 3px; }

.form .consent { display: flex; gap: 0.7rem; align-items: flex-start; font-size: 0.82rem; color: var(--ink-mute); }
.form .consent input {
  appearance: none;
  flex: none;
  width: 19px; height: 19px;
  margin-top: 1px;
  border: 1.5px solid var(--line-strong);
  border-radius: 6px;
  display: grid;
  place-items: center;
  transition: background 0.25s, border-color 0.25s, transform 0.3s var(--ease-spring);
  cursor: pointer;
}
.form .consent input:checked { background: var(--ink); border-color: var(--ink); transform: scale(1.05); }
.form .consent input:checked::after { content: "✓"; color: var(--bg); font-size: 0.7rem; font-weight: 800; }
.form .consent a { text-decoration: underline; text-underline-offset: 2px; }

.form-submit { display: flex; align-items: center; gap: 1.25rem; flex-wrap: wrap; }
.btn-submit { min-width: 220px; position: relative; }
.btn-submit .txt-2 { position: absolute; opacity: 0; transform: translateY(12px); }
.btn-submit .txt-1, .btn-submit .txt-2 { transition: opacity 0.3s, transform 0.4s var(--ease-out); display: inline-flex; align-items: center; gap: 0.5rem; }
.btn-submit.is-busy .txt-1 { opacity: 0; transform: translateY(-12px); }
.btn-submit.is-busy .txt-2 { opacity: 1; transform: none; }
.btn-submit .spinner {
  width: 15px; height: 15px;
  border-radius: 50%;
  border: 2px solid color-mix(in srgb, currentColor 30%, transparent);
  border-top-color: currentColor;
  animation: spin 0.7s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

.form-success {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  place-content: center;
  gap: 1rem;
  text-align: center;
  padding: 2rem;
  background: var(--bg-card);
  border-radius: inherit;
  opacity: 0;
  visibility: hidden;
  transform: scale(0.96);
  transition: opacity 0.5s, transform 0.6s var(--ease-out), visibility 0s 0.5s;
  z-index: 5;
}
.form.is-sent .form-success { opacity: 1; visibility: visible; transform: none; transition: opacity 0.5s, transform 0.6s var(--ease-out); }
.form-success .check {
  width: 74px; height: 74px;
  border-radius: 50%;
  background: var(--ink);
  color: var(--bg);
  display: grid;
  place-items: center;
}
.form-success .check svg { width: 30px; height: 30px; }
.form-success .check svg path {
  stroke-dasharray: 40;
  stroke-dashoffset: 40;
}
.form.is-sent .check svg path { animation: draw-check 0.7s var(--ease-out) 0.35s forwards; }
@keyframes draw-check { to { stroke-dashoffset: 0; } }
.form-success [data-send-another] { margin-top: 0.4rem; }

/* Panel lateral de contacto */
.contact-aside { display: grid; gap: 1.1rem; position: sticky; top: calc(var(--nav-h) + 24px); }
.contact-card {
  padding: 1.6rem 1.7rem;
  border-radius: var(--r-m);
  border: 1px solid var(--line);
  background: var(--bg-card);
  display: grid;
  gap: 0.4rem;
  transition: transform 0.45s var(--ease-out), box-shadow 0.45s;
}
.contact-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-m); border-color: var(--line-strong); }
.contact-card:focus-visible { outline: 2px solid var(--ink); outline-offset: 3px; }
/* La tarjeta entera es el enlace: el subrayado se dibuja al pasar por cualquier parte */
.contact-card .link-draw { pointer-events: none; }
.contact-card:hover .link-draw { background-position: 0 100%; background-size: 100% 1.5px; }
.contact-card:hover .link-draw svg { transform: translate(2px, -2px); }
.contact-card .cc-ico {
  width: 42px; height: 42px;
  border-radius: 12px;
  border: 1px solid var(--line-strong);
  display: grid;
  place-items: center;
  color: var(--ink);
  margin-bottom: 0.6rem;
}
.contact-card .cc-ico svg { width: 18px; height: 18px; }
.contact-card strong { color: var(--ink); font-weight: 650; letter-spacing: -0.01em; }
.contact-card p { font-size: 0.88rem; color: var(--ink-mute); }
.contact-card .link-draw { margin-top: 0.5rem; font-size: 0.92rem; }

/* ---------- 17 · FOOTER + WHATSAPP ---------- */
.footer {
  position: relative;
  background: var(--inverse-bg);
  color: color-mix(in srgb, var(--inverse-ink) 66%, transparent);
  margin-top: var(--s-6);
  overflow: clip;
}
.footer .footer-cta {
  padding-block: var(--s-6) var(--s-5);
  text-align: center;
  display: grid;
  justify-items: center;
  gap: var(--s-3);
  position: relative;
}
.footer .footer-cta h2 {
  color: var(--inverse-ink);
  font-size: clamp(2.6rem, 7.5vw, 6.5rem);
  letter-spacing: -0.045em;
  max-width: 14ch;
}
.footer .footer-cta .lead { color: color-mix(in srgb, var(--inverse-ink) 60%, transparent); margin-inline: auto; }
.footer-main {
  width: var(--container);
  margin-inline: auto;
  display: grid;
  grid-template-columns: 1.3fr repeat(3, minmax(140px, 0.6fr));
  gap: var(--s-3);
  padding-block: var(--s-4);
  border-top: 1px solid color-mix(in srgb, var(--inverse-ink) 12%, transparent);
}
.footer-brand { display: grid; gap: 1rem; align-content: start; }
.footer-brand .brand { color: var(--inverse-ink); font-size: 1.5rem; }
.footer-brand p { font-size: 0.92rem; max-width: 30ch; line-height: 1.6; }
.footer h4 {
  color: var(--inverse-ink);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  margin-bottom: 1.1rem;
  opacity: 0.85;
}
.footer ul { list-style: none; display: grid; gap: 0.55rem; }
.footer ul a {
  font-size: 0.94rem;
  display: inline-block;
  transition: color 0.25s, transform 0.3s var(--ease-out);
}
.footer ul a:hover { color: var(--inverse-ink); transform: translateX(4px); }
.footer-bottom {
  width: var(--container);
  margin-inline: auto;
  padding-block: 1.5rem;
  border-top: 1px solid color-mix(in srgb, var(--inverse-ink) 10%, transparent);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem 1.5rem;
  font-size: 0.8rem;
}
.footer-bottom .legal-links { display: flex; flex-wrap: wrap; gap: 1.25rem; }
.footer-bottom a:hover { color: var(--inverse-ink); }
.footer .footer-word {
  display: block;
  text-align: center;
  font-weight: 750;
  font-size: clamp(4.5rem, 17vw, 15rem);
  letter-spacing: -0.05em;
  line-height: 0.86;
  color: color-mix(in srgb, var(--inverse-ink) 7%, transparent);
  user-select: none;
  pointer-events: none;
  margin-top: -0.5rem;
}
.footer .footer-word sup { font-size: 0.3em; vertical-align: 1.1em; font-weight: 500; }

/* WhatsApp flotante */
.wa-float {
  position: fixed;
  right: clamp(1rem, 2.5vw, 1.75rem);
  bottom: clamp(1rem, 2.5vw, 1.75rem);
  z-index: 850;
  width: 56px; height: 56px;
  border-radius: 50%;
  background: var(--ink);
  color: var(--bg);
  display: grid;
  place-items: center;
  box-shadow: var(--shadow-m);
  transform: translateY(140%) scale(0.6);
  opacity: 0;
  transition: transform 0.6s var(--ease-spring), opacity 0.4s, background 0.3s;
}
.wa-float svg { width: 24px; height: 24px; }
.wa-float.is-on { transform: none; opacity: 1; }
.wa-float:hover { transform: scale(1.08); }
.wa-float:active { transform: scale(0.95); }
.wa-float::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  border: 1.5px solid var(--ink);
  animation: wa-ping 2.6s var(--ease-out) infinite;
}
@keyframes wa-ping {
  0% { transform: scale(1); opacity: 0.5; }
  70%, 100% { transform: scale(1.55); opacity: 0; }
}
.wa-float .wa-tip {
  position: absolute;
  right: calc(100% + 12px);
  top: 50%;
  transform: translateY(-50%) translateX(6px);
  background: var(--glass-strong);
  color: var(--ink);
  border: 1px solid var(--line);
  backdrop-filter: blur(12px);
  padding: 0.5rem 0.9rem;
  border-radius: var(--r-pill);
  font-size: 0.78rem;
  font-weight: 620;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s, transform 0.4s var(--ease-out);
  box-shadow: var(--shadow-s);
}
.wa-float:hover .wa-tip { opacity: 1; transform: translateY(-50%) translateX(0); }

/* ---------- 18 · LEGAL + BLOG + 404 + PÁGINA GENÉRICA ---------- */
.page-hero {
  padding: calc(var(--nav-h) + var(--s-5)) 0 var(--s-4);
  position: relative;
  overflow: clip;
}
.page-hero h1 { font-size: clamp(2.6rem, 7vw, 5.5rem); max-width: 16ch; }
.page-hero .lead { margin-top: var(--s-2); }
.breadcrumbs {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin-bottom: var(--s-3);
}
.breadcrumbs a:hover { color: var(--ink); }
.breadcrumbs .sep { opacity: 0.5; }

.prose { max-width: 760px; display: grid; gap: 1.1rem; }
.prose h2 { font-size: var(--text-xl); margin-top: var(--s-2); }
.prose h3 { font-size: var(--text-l); margin-top: var(--s-1); }
.prose ul, .prose ol { padding-left: 1.3rem; display: grid; gap: 0.5rem; color: var(--ink-mute); }
.prose p { color: var(--ink-mute); }
.prose strong { color: var(--ink-soft); }
.prose a { color: var(--ink); text-decoration: underline; text-underline-offset: 3px; }

.blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1rem, 2vw, 1.75rem); }
.post-card {
  border-radius: var(--r-m);
  border: 1px solid var(--line);
  background: var(--bg-card);
  overflow: hidden;
  display: grid;
  transition: transform 0.5s var(--ease-out), box-shadow 0.5s;
}
.post-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-m); }
.post-card .pc-media { aspect-ratio: 16/10; }
.post-card .pc-body { padding: 1.4rem 1.5rem 1.6rem; display: grid; gap: 0.6rem; }
.post-card .pc-meta { font-size: 0.72rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-faint); }
.post-card h3 { font-size: 1.15rem; line-height: 1.35; }
.post-card p { font-size: 0.9rem; color: var(--ink-mute); }

.err-hero {
  min-height: 100svh;
  display: grid;
  place-items: center;
  place-content: center;
  gap: 1.5rem;
  text-align: center;
  padding: 2rem;
}
.err-hero .code {
  font-size: clamp(6rem, 25vw, 16rem);
  font-weight: 650;
  letter-spacing: -0.06em;
  line-height: 0.9;
  color: var(--ink);
}
.err-hero .code em { font-family: var(--font-serif); font-style: italic; font-weight: 400; }

/* CTA intermedio reutilizable */
.mid-cta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-2);
  padding: clamp(1.75rem, 3.5vw, 2.75rem) clamp(1.5rem, 3vw, 2.75rem);
  border-radius: var(--r-l);
  border: 1px solid var(--line);
  background: var(--glass);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: var(--shadow-s);
}
.mid-cta h3 { font-size: var(--text-xl); max-width: 22ch; }
.mid-cta .small { margin-top: 0.3rem; }
.mid-cta .cta-buttons { display: flex; flex-wrap: wrap; gap: 0.75rem; }

/* ---------- 19 · REVEALS + MOTION ---------- */
/* Reveal genérico al hacer scroll. El will-change se aplica solo mientras
   dura la transición (lo gestiona reveal.js): son animaciones de un solo
   uso, y dejar la capa promovida para siempre en cada bloque de la página
   es memoria de GPU malgastada, sobre todo en equipos modestos. */
.js [data-reveal] {
  opacity: 0;
  transform: translateY(26px);
  filter: blur(5px);
  transition: opacity 0.9s var(--ease-out), transform 1s var(--ease-out), filter 0.8s var(--ease-out);
  transition-delay: var(--rd, 0s);
}
.js [data-reveal].is-in { opacity: 1; transform: none; filter: none; }
.js [data-reveal="fade"] { transform: none; }
.js [data-reveal="left"] { transform: translateX(-30px); }
.js [data-reveal="right"] { transform: translateX(30px); }
.js [data-reveal="scale"] { transform: scale(0.94); }

/* Hijos escalonados */
.js [data-reveal-group] > * {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.8s var(--ease-out), transform 0.9s var(--ease-out);
}
.js [data-reveal-group].is-in > * { opacity: 1; transform: none; }
.js [data-reveal-group].is-in > *:nth-child(1) { transition-delay: 0.05s; }
.js [data-reveal-group].is-in > *:nth-child(2) { transition-delay: 0.13s; }
.js [data-reveal-group].is-in > *:nth-child(3) { transition-delay: 0.21s; }
.js [data-reveal-group].is-in > *:nth-child(4) { transition-delay: 0.29s; }
.js [data-reveal-group].is-in > *:nth-child(5) { transition-delay: 0.37s; }
.js [data-reveal-group].is-in > *:nth-child(6) { transition-delay: 0.45s; }
.js [data-reveal-group].is-in > *:nth-child(7) { transition-delay: 0.53s; }
.js [data-reveal-group].is-in > *:nth-child(8) { transition-delay: 0.61s; }

/* Titulares partidos por palabras (máscara) */
.js [data-split] .w { display: inline-block; overflow: clip; vertical-align: bottom; padding-bottom: 0.08em; margin-bottom: -0.08em; }
.js [data-split] .wi {
  display: inline-block;
  transform: translateY(115%) rotate(1.5deg);
  transition: transform 1s var(--ease-out);
  transition-delay: calc(var(--wi, 0) * 0.045s + var(--rd, 0s));
}
.js [data-split].is-in .wi { transform: none; }

/* Parallax */
[data-parallax] { will-change: transform; }

/* Zoom de imagen al hacer scroll */
.js [data-zoom] img { transform: scale(1.12); transition: transform 1.6s var(--ease-out); }
.js [data-zoom].is-in img { transform: scale(1); }

/* Vistas de página (transición de entrada) */
.js main { animation: page-in 0.8s var(--ease-out) both; }
@keyframes page-in {
  from { opacity: 0; transform: translateY(14px); }
  to { opacity: 1; transform: none; }
}

/* Transición de tema con View Transitions API */
::view-transition-old(root), ::view-transition-new(root) { animation: none; mix-blend-mode: normal; }
::view-transition-old(root) { z-index: 1; }
::view-transition-new(root) { z-index: 2; }

/* ---------- 20 · RESPONSIVE ---------- */
@media (max-width: 1200px) {
  .hero-stage { opacity: 0.85; width: clamp(280px, 30vw, 460px); }
}

@media (max-width: 1024px) {
  :root { --nav-h: 64px; }
  .nav-links { display: none; }
  .nav-burger { display: grid; }
  .nav .btn-nav-cta { display: none; }
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
  .bento-cell { grid-column: span 6; }
  .bento-cell.is-wide { grid-column: span 12; }
  .work-item, .work-item.is-flip { grid-template-columns: 1fr; gap: var(--s-2); }
  .work-item .work-media, .work-item.is-flip .work-media { grid-column: 1 / -1; order: 1; }
  .work-item .work-info, .work-item.is-flip .work-info { grid-column: 1 / -1; order: 2; }
  .work-grid { grid-template-columns: repeat(2, 1fr); }
  .demo-band .demo-grid { grid-template-columns: 1fr; }
  .contact-layout { grid-template-columns: 1fr; }
  .contact-aside { position: static; grid-template-columns: repeat(2, 1fr); }
  .about-grid { grid-template-columns: 1fr; }
  .about-photo { position: static; max-width: 420px; }
  .footer-main { grid-template-columns: 1fr 1fr; }
  .hero { min-height: auto; padding-bottom: var(--s-4); }
  .hero-inner { grid-template-columns: 1fr; gap: var(--s-2); }
  .hero-stage {
    transform: none;
    width: 100%;
    max-width: 520px;
    aspect-ratio: 16 / 11;
    margin: var(--s-2) auto 0;
    opacity: 1;
  }
  .hero-stage .shot-a { top: 2%; }
  .hero-stage .shot-b { top: 44%; }
  .hero-stage .shot-c { top: 30%; }
  .social-cards { grid-template-columns: 1fr; }
  .stats { grid-template-columns: repeat(2, 1fr); }
  .stat { border-inline-start: none; border-top: 1px solid var(--line); }
  .stat:nth-child(-n+2) { border-top: none; }
  .stat:nth-child(even) { border-inline-start: 1px solid var(--line); }
}

@media (max-width: 640px) {
  .grid-2, .grid-3, .form-row, .work-grid, .blog-grid, .contact-aside { grid-template-columns: 1fr; }
  .bento-cell, .bento-cell.is-wide { grid-column: span 12; min-height: 260px; }
  .hero h1 { font-size: clamp(2.7rem, 12vw, 4rem); max-width: 18ch; }
  .hero-stage { aspect-ratio: 4 / 3; }
  .hero-scroll-hint { display: none; }
  .svc-head { grid-template-columns: 1fr auto; column-gap: 0.75rem; }
  .svc-head .idx { display: none; }
  .svc-head .svc-tag { display: none; }
  .svc-head .svc-ico { width: 40px; height: 40px; }
  .svc-panel-in { padding-left: clamp(0.4rem, 1.4vw, 1.2rem); }
  .svc-points { grid-template-columns: 1fr; }
  .duo .duo-mobile { width: 30%; right: -2%; }
  .footer-main { grid-template-columns: 1fr; gap: var(--s-3); }
  .mid-cta { flex-direction: column; align-items: flex-start; }
  .t-card { width: min(340px, 86vw); }
  .step { grid-template-columns: 44px 1fr; gap: 1rem; }
  .step .step-dot { width: 44px; height: 44px; font-size: 0.9rem; }
  .steps::before, .steps .steps-progress { left: 21px; }
  .wa-float { width: 52px; height: 52px; }
  .wa-float .wa-tip { display: none; }
  .social-card { flex-wrap: wrap; }
  .social-card .sc-follow { margin-left: 0; width: 100%; justify-content: center; }
  .review-cta { flex-direction: column; align-items: flex-start; }
  .review-cta .btn { width: 100%; }
}

/* Ultrawide: limita el ancho del contenido y agranda el aire */
@media (min-width: 1920px) {
  :root { --container: min(1360px, 100vw - 6rem); --container-wide: min(1680px, 100vw - 8rem); }
}

/* Pantallas táctiles: desactiva efectos de cursor */
@media (hover: none) {
  .cursor-dot, .cursor-ring, .cursor-canvas { display: none !important; }
}

/* ---------- REDUCED MOTION ---------- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  html { scroll-behavior: auto; }
  .js [data-reveal], .js [data-reveal-group] > *, .js [data-split] .wi {
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
  }
  .marquee-track { animation: none; }
  .marquee { overflow-x: auto; }
  .cursor-dot, .cursor-ring, .cursor-canvas { display: none !important; }
  .loader { display: none !important; }
  .hero-stage .shot, [data-parallax] { transform: none !important; }
}

/* ---------- 21 · MARCA AAS (logo vectorial, tematizable vía mask) ---------- */
.brand-mark {
  display: block;
  height: var(--mark-h, 26px);
  aspect-ratio: 1673 / 596;
  background-color: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='17 13 1673 596' fill='currentColor' role='img'%3E%3Cpath d='M 317.7 27.3 C 313.6 35.1%2C 308.4 44.9%2C 306.3 49 C 301.4 58.2%2C 292.6 75%2C 273.7 111.5 C 265.8 126.9%2C 256.2 145.4%2C 252.5 152.5 C 231.2 193.6%2C 202.5 249%2C 194.3 265 C 189 275.2%2C 182.6 287.6%2C 180 292.5 C 177.4 297.5%2C 165.2 320.9%2C 153 344.5 C 127.4 394%2C 120.4 407.4%2C 114.5 418.5 C 112.2 422.9%2C 107.4 431.9%2C 104 438.5 C 100.5 445.1%2C 95.6 454.6%2C 93 459.5 C 90.4 464.5%2C 85 474.8%2C 81 482.5 C 77 490.2%2C 73 497.9%2C 72 499.5 C 71 501.2%2C 65.9 511.1%2C 60.5 521.5 C 55.1 532%2C 50.4 541%2C 50 541.5 C 49.6 542.1%2C 44.5 552%2C 38.5 563.5 C 32.6 575.1%2C 25.3 589.1%2C 22.3 594.8 C 19.3 600.5%2C 17 605.4%2C 17.3 605.6 C 18.1 606.4%2C 95.4 606.5%2C 96.7 605.7 C 98 604.9%2C 104.8 592.2%2C 138.8 526.5 C 162.9 479.9%2C 175 456.5%2C 186 435.5 C 194.1 420%2C 217.8 374.1%2C 237 337 C 245.9 319.7%2C 255.2 301.9%2C 257.5 297.5 C 259.9 293.1%2C 265.4 282.5%2C 269.7 274 C 274.1 265.5%2C 280.2 253.8%2C 283.2 248 C 286.2 242.2%2C 292.7 229.9%2C 297.5 220.5 C 302.3 211.2%2C 308.6 199%2C 311.5 193.5 C 314.4 188%2C 318.7 179.8%2C 321 175.2 C 323.4 170.7%2C 325.7 167.1%2C 326.2 167.2 C 326.7 167.4%2C 331.4 175.9%2C 336.6 186 C 341.9 196.2%2C 352.3 216.2%2C 359.8 230.5 C 367.3 244.8%2C 380.4 270%2C 388.9 286.5 C 408.4 324.1%2C 420.7 347.7%2C 433.6 372.3 C 439.1 382.9%2C 448.6 401.2%2C 454.7 413 C 460.7 424.8%2C 467.5 437.9%2C 469.7 442 C 475.3 452.4%2C 490.5 481.1%2C 498 495.5 C 501.4 502.1%2C 507.3 513.1%2C 511 520 C 520.2 537%2C 523.3 542.9%2C 541 576.8 L 556.3 606 623.6 606 L 691 606 698.1 591.8 C 702 583.9%2C 711.2 566%2C 718.5 552 C 725.7 538%2C 738.1 513.9%2C 746 498.5 C 753.8 483.1%2C 760.6 470.1%2C 761 469.5 C 761.4 469%2C 767 458.2%2C 773.5 445.5 C 790.5 412.3%2C 824.2 347.4%2C 843 311.5 C 851.9 294.5%2C 864.7 269.9%2C 871.3 257 C 878 244.1%2C 888.9 222.9%2C 895.7 210 C 902.5 197.1%2C 910.2 182.3%2C 912.8 177.3 C 915.3 172.2%2C 917.9 168%2C 918.6 168 C 919.2 168%2C 924.1 176.7%2C 929.5 187.3 C 934.9 197.8%2C 940.2 208.1%2C 941.3 210 C 942.4 211.9%2C 948.7 224.1%2C 955.3 237 C 961.9 249.9%2C 969.9 265.2%2C 973 271 C 976.2 276.8%2C 981.3 286.7%2C 984.5 293 C 987.7 299.3%2C 993.9 311.3%2C 998.5 319.5 C 1003 327.8%2C 1014.7 349.8%2C 1024.5 368.5 C 1034.3 387.2%2C 1047.4 412.2%2C 1053.6 424 C 1064.9 445.6%2C 1066.5 448.8%2C 1065.9 449.2 C 1065.7 449.3%2C 1007 449.7%2C 935.5 450 L 805.5 450.5 794 472.5 C 787.7 484.6%2C 779.9 499.3%2C 776.7 505.2 C 773.6 511%2C 771 516.6%2C 771 517.5 C 771 518.9%2C 784.6 519.1%2C 936.7 518.9 C 1034.4 518.8%2C 1102.5 519.1%2C 1102.7 519.6 C 1102.9 520.1%2C 1106.7 527.5%2C 1111.3 536 C 1115.9 544.5%2C 1122.9 557.8%2C 1127 565.5 C 1131 573.2%2C 1135.1 580.9%2C 1136 582.5 C 1136.9 584.2%2C 1140 590.1%2C 1142.9 595.8 L 1148.2 606 1187.6 606 C 1214.8 606%2C 1227 605.7%2C 1227 604.9 C 1227 604%2C 1221.3 592.8%2C 1202 555.5 C 1198 547.8%2C 1193.3 538.8%2C 1191.5 535.5 C 1189.7 532.2%2C 1183.6 520.5%2C 1178 509.5 C 1172.3 498.5%2C 1167.4 489.1%2C 1167 488.5 C 1166.6 488%2C 1163 481.2%2C 1159 473.5 C 1155 465.8%2C 1149.6 455.5%2C 1147 450.5 C 1136.8 431.2%2C 1131.1 420.2%2C 1112.8 385 C 1102.3 364.9%2C 1092.1 345.4%2C 1090 341.5 C 1086.1 334.4%2C 1038 241.6%2C 1013 193 C 1005.5 178.4%2C 996 160%2C 991.8 152 C 987.7 144%2C 979.4 128.1%2C 973.5 116.5 C 961.5 93%2C 948.8 68.5%2C 934.6 41 C 929.3 30.8%2C 923.9 20.4%2C 922.7 17.8 C 921.5 15.2%2C 920 13.1%2C 919.3 13 C 918.7 13%2C 916.6 16%2C 914.7 19.8 C 912.9 23.5%2C 907.9 33.1%2C 903.7 41.3 C 899.5 49.4%2C 892.7 62.4%2C 888.6 70.3 C 884.6 78.1%2C 865.5 114.7%2C 846.2 151.5 C 827 188.4%2C 799.9 240.3%2C 786 267 C 751.7 332.9%2C 750.3 335.6%2C 746.5 342.5 C 744.7 345.8%2C 738 358.9%2C 731.5 371.5 C 725 384.2%2C 719.4 395%2C 719 395.5 C 718.6 396.1%2C 714.1 404.6%2C 709 414.5 C 698.9 434.1%2C 690.1 450.9%2C 686.2 458 C 684.8 460.5%2C 677.2 475.1%2C 669.2 490.5 C 661.3 505.9%2C 651.7 524.1%2C 648 531 C 644.3 537.9%2C 637.4 551%2C 632.6 560.3 C 627.8 569.5%2C 623.5 577%2C 623.1 577 C 622.6 577%2C 621.2 574.9%2C 619.8 572.3 C 616.9 566.5%2C 605.9 545.4%2C 591.5 518 C 585.6 506.7%2C 578 492.3%2C 574.7 486 C 571.5 479.7%2C 565.9 469.1%2C 562.5 462.5 C 559 455.9%2C 550.3 439%2C 543 425 C 535.7 411%2C 528.5 397.3%2C 527 394.5 C 525.5 391.8%2C 521 383.2%2C 517 375.5 C 513 367.8%2C 507.8 357.9%2C 505.5 353.5 C 496.8 337.1%2C 490.9 325.9%2C 479 303 C 472.3 290.1%2C 464.6 275.5%2C 462 270.5 C 450.4 248.4%2C 439.8 228%2C 416.2 182.5 C 408.6 167.7%2C 398.2 147.7%2C 393.1 138.3 C 372.5 99.3%2C 357.2 70.2%2C 336.2 30 C 328.9 15.9%2C 327.1 13%2C 326 13 C 325.5 13%2C 321.8 19.4%2C 317.7 27.3 M 1369.5 41.6 C 1310.1 46.9%2C 1263.3 73.6%2C 1233.7 119.1 C 1212.6 151.6%2C 1204.5 196.7%2C 1212.6 237 C 1216.1 254.2%2C 1225.6 277.1%2C 1235.2 291.3 C 1242.2 301.7%2C 1253.5 315.2%2C 1259.7 320.5 C 1288 345.1%2C 1313.3 356.7%2C 1351.1 362.6 C 1359.9 364%2C 1376 364.4%2C 1456.5 365 C 1558.5 365.8%2C 1552.6 365.4%2C 1567.1 370.9 C 1580.3 375.9%2C 1594.6 386.8%2C 1603.3 398.5 C 1613.7 412.5%2C 1618 423%2C 1620.7 441 C 1622.4 452.6%2C 1621.7 461.5%2C 1617.9 475.8 C 1609.5 507.7%2C 1581.9 532.7%2C 1549.6 538 C 1545.8 538.6%2C 1485.8 539%2C 1390.3 539 C 1306 539%2C 1237 539.4%2C 1237 539.8 C 1237 540.3%2C 1241.8 549.8%2C 1247.6 561.1 C 1253.5 572.3%2C 1261.1 587.1%2C 1264.5 594.1 C 1268 601%2C 1271.5 607.2%2C 1272.3 607.8 C 1273.5 608.8%2C 1303.2 609%2C 1413.7 608.8 L 1553.5 608.4 1565 606.2 C 1580.1 603.2%2C 1592 599.1%2C 1605.5 592.4 C 1620.7 584.9%2C 1632.9 575.8%2C 1645.7 562.7 C 1666.8 541%2C 1679.4 517.5%2C 1687.2 485 C 1689.2 476.5%2C 1689.5 473.1%2C 1689.5 451.5 C 1689.5 429.7%2C 1689.2 426.6%2C 1687.1 418 C 1680.2 390%2C 1668.7 367.7%2C 1650.5 346.9 C 1629.6 323%2C 1597.8 304.8%2C 1565.6 298.3 C 1558.6 296.9%2C 1544.5 296.6%2C 1461 296 C 1366.3 295.4%2C 1364.3 295.4%2C 1354.6 293.2 C 1327.6 287.2%2C 1306.2 272.5%2C 1292.6 250.7 C 1286 240.1%2C 1283.4 233.6%2C 1280.9 221.2 C 1278.6 209.8%2C 1278.5 201.4%2C 1280.5 189.7 C 1286.4 156.3%2C 1308.9 130.1%2C 1342.7 117.4 C 1361.7 110.3%2C 1366.5 110%2C 1489.5 109.9 L 1597.5 109.9 1604.4 100.7 C 1633.6 62.1%2C 1647.3 43.4%2C 1647.4 42 C 1647.5 40.7%2C 1634 40.5%2C 1516 40.4 C 1412.6 40.3%2C 1381.3 40.5%2C 1369.5 41.6'/%3E%3C/svg%3E") no-repeat center / contain;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='17 13 1673 596' fill='currentColor' role='img'%3E%3Cpath d='M 317.7 27.3 C 313.6 35.1%2C 308.4 44.9%2C 306.3 49 C 301.4 58.2%2C 292.6 75%2C 273.7 111.5 C 265.8 126.9%2C 256.2 145.4%2C 252.5 152.5 C 231.2 193.6%2C 202.5 249%2C 194.3 265 C 189 275.2%2C 182.6 287.6%2C 180 292.5 C 177.4 297.5%2C 165.2 320.9%2C 153 344.5 C 127.4 394%2C 120.4 407.4%2C 114.5 418.5 C 112.2 422.9%2C 107.4 431.9%2C 104 438.5 C 100.5 445.1%2C 95.6 454.6%2C 93 459.5 C 90.4 464.5%2C 85 474.8%2C 81 482.5 C 77 490.2%2C 73 497.9%2C 72 499.5 C 71 501.2%2C 65.9 511.1%2C 60.5 521.5 C 55.1 532%2C 50.4 541%2C 50 541.5 C 49.6 542.1%2C 44.5 552%2C 38.5 563.5 C 32.6 575.1%2C 25.3 589.1%2C 22.3 594.8 C 19.3 600.5%2C 17 605.4%2C 17.3 605.6 C 18.1 606.4%2C 95.4 606.5%2C 96.7 605.7 C 98 604.9%2C 104.8 592.2%2C 138.8 526.5 C 162.9 479.9%2C 175 456.5%2C 186 435.5 C 194.1 420%2C 217.8 374.1%2C 237 337 C 245.9 319.7%2C 255.2 301.9%2C 257.5 297.5 C 259.9 293.1%2C 265.4 282.5%2C 269.7 274 C 274.1 265.5%2C 280.2 253.8%2C 283.2 248 C 286.2 242.2%2C 292.7 229.9%2C 297.5 220.5 C 302.3 211.2%2C 308.6 199%2C 311.5 193.5 C 314.4 188%2C 318.7 179.8%2C 321 175.2 C 323.4 170.7%2C 325.7 167.1%2C 326.2 167.2 C 326.7 167.4%2C 331.4 175.9%2C 336.6 186 C 341.9 196.2%2C 352.3 216.2%2C 359.8 230.5 C 367.3 244.8%2C 380.4 270%2C 388.9 286.5 C 408.4 324.1%2C 420.7 347.7%2C 433.6 372.3 C 439.1 382.9%2C 448.6 401.2%2C 454.7 413 C 460.7 424.8%2C 467.5 437.9%2C 469.7 442 C 475.3 452.4%2C 490.5 481.1%2C 498 495.5 C 501.4 502.1%2C 507.3 513.1%2C 511 520 C 520.2 537%2C 523.3 542.9%2C 541 576.8 L 556.3 606 623.6 606 L 691 606 698.1 591.8 C 702 583.9%2C 711.2 566%2C 718.5 552 C 725.7 538%2C 738.1 513.9%2C 746 498.5 C 753.8 483.1%2C 760.6 470.1%2C 761 469.5 C 761.4 469%2C 767 458.2%2C 773.5 445.5 C 790.5 412.3%2C 824.2 347.4%2C 843 311.5 C 851.9 294.5%2C 864.7 269.9%2C 871.3 257 C 878 244.1%2C 888.9 222.9%2C 895.7 210 C 902.5 197.1%2C 910.2 182.3%2C 912.8 177.3 C 915.3 172.2%2C 917.9 168%2C 918.6 168 C 919.2 168%2C 924.1 176.7%2C 929.5 187.3 C 934.9 197.8%2C 940.2 208.1%2C 941.3 210 C 942.4 211.9%2C 948.7 224.1%2C 955.3 237 C 961.9 249.9%2C 969.9 265.2%2C 973 271 C 976.2 276.8%2C 981.3 286.7%2C 984.5 293 C 987.7 299.3%2C 993.9 311.3%2C 998.5 319.5 C 1003 327.8%2C 1014.7 349.8%2C 1024.5 368.5 C 1034.3 387.2%2C 1047.4 412.2%2C 1053.6 424 C 1064.9 445.6%2C 1066.5 448.8%2C 1065.9 449.2 C 1065.7 449.3%2C 1007 449.7%2C 935.5 450 L 805.5 450.5 794 472.5 C 787.7 484.6%2C 779.9 499.3%2C 776.7 505.2 C 773.6 511%2C 771 516.6%2C 771 517.5 C 771 518.9%2C 784.6 519.1%2C 936.7 518.9 C 1034.4 518.8%2C 1102.5 519.1%2C 1102.7 519.6 C 1102.9 520.1%2C 1106.7 527.5%2C 1111.3 536 C 1115.9 544.5%2C 1122.9 557.8%2C 1127 565.5 C 1131 573.2%2C 1135.1 580.9%2C 1136 582.5 C 1136.9 584.2%2C 1140 590.1%2C 1142.9 595.8 L 1148.2 606 1187.6 606 C 1214.8 606%2C 1227 605.7%2C 1227 604.9 C 1227 604%2C 1221.3 592.8%2C 1202 555.5 C 1198 547.8%2C 1193.3 538.8%2C 1191.5 535.5 C 1189.7 532.2%2C 1183.6 520.5%2C 1178 509.5 C 1172.3 498.5%2C 1167.4 489.1%2C 1167 488.5 C 1166.6 488%2C 1163 481.2%2C 1159 473.5 C 1155 465.8%2C 1149.6 455.5%2C 1147 450.5 C 1136.8 431.2%2C 1131.1 420.2%2C 1112.8 385 C 1102.3 364.9%2C 1092.1 345.4%2C 1090 341.5 C 1086.1 334.4%2C 1038 241.6%2C 1013 193 C 1005.5 178.4%2C 996 160%2C 991.8 152 C 987.7 144%2C 979.4 128.1%2C 973.5 116.5 C 961.5 93%2C 948.8 68.5%2C 934.6 41 C 929.3 30.8%2C 923.9 20.4%2C 922.7 17.8 C 921.5 15.2%2C 920 13.1%2C 919.3 13 C 918.7 13%2C 916.6 16%2C 914.7 19.8 C 912.9 23.5%2C 907.9 33.1%2C 903.7 41.3 C 899.5 49.4%2C 892.7 62.4%2C 888.6 70.3 C 884.6 78.1%2C 865.5 114.7%2C 846.2 151.5 C 827 188.4%2C 799.9 240.3%2C 786 267 C 751.7 332.9%2C 750.3 335.6%2C 746.5 342.5 C 744.7 345.8%2C 738 358.9%2C 731.5 371.5 C 725 384.2%2C 719.4 395%2C 719 395.5 C 718.6 396.1%2C 714.1 404.6%2C 709 414.5 C 698.9 434.1%2C 690.1 450.9%2C 686.2 458 C 684.8 460.5%2C 677.2 475.1%2C 669.2 490.5 C 661.3 505.9%2C 651.7 524.1%2C 648 531 C 644.3 537.9%2C 637.4 551%2C 632.6 560.3 C 627.8 569.5%2C 623.5 577%2C 623.1 577 C 622.6 577%2C 621.2 574.9%2C 619.8 572.3 C 616.9 566.5%2C 605.9 545.4%2C 591.5 518 C 585.6 506.7%2C 578 492.3%2C 574.7 486 C 571.5 479.7%2C 565.9 469.1%2C 562.5 462.5 C 559 455.9%2C 550.3 439%2C 543 425 C 535.7 411%2C 528.5 397.3%2C 527 394.5 C 525.5 391.8%2C 521 383.2%2C 517 375.5 C 513 367.8%2C 507.8 357.9%2C 505.5 353.5 C 496.8 337.1%2C 490.9 325.9%2C 479 303 C 472.3 290.1%2C 464.6 275.5%2C 462 270.5 C 450.4 248.4%2C 439.8 228%2C 416.2 182.5 C 408.6 167.7%2C 398.2 147.7%2C 393.1 138.3 C 372.5 99.3%2C 357.2 70.2%2C 336.2 30 C 328.9 15.9%2C 327.1 13%2C 326 13 C 325.5 13%2C 321.8 19.4%2C 317.7 27.3 M 1369.5 41.6 C 1310.1 46.9%2C 1263.3 73.6%2C 1233.7 119.1 C 1212.6 151.6%2C 1204.5 196.7%2C 1212.6 237 C 1216.1 254.2%2C 1225.6 277.1%2C 1235.2 291.3 C 1242.2 301.7%2C 1253.5 315.2%2C 1259.7 320.5 C 1288 345.1%2C 1313.3 356.7%2C 1351.1 362.6 C 1359.9 364%2C 1376 364.4%2C 1456.5 365 C 1558.5 365.8%2C 1552.6 365.4%2C 1567.1 370.9 C 1580.3 375.9%2C 1594.6 386.8%2C 1603.3 398.5 C 1613.7 412.5%2C 1618 423%2C 1620.7 441 C 1622.4 452.6%2C 1621.7 461.5%2C 1617.9 475.8 C 1609.5 507.7%2C 1581.9 532.7%2C 1549.6 538 C 1545.8 538.6%2C 1485.8 539%2C 1390.3 539 C 1306 539%2C 1237 539.4%2C 1237 539.8 C 1237 540.3%2C 1241.8 549.8%2C 1247.6 561.1 C 1253.5 572.3%2C 1261.1 587.1%2C 1264.5 594.1 C 1268 601%2C 1271.5 607.2%2C 1272.3 607.8 C 1273.5 608.8%2C 1303.2 609%2C 1413.7 608.8 L 1553.5 608.4 1565 606.2 C 1580.1 603.2%2C 1592 599.1%2C 1605.5 592.4 C 1620.7 584.9%2C 1632.9 575.8%2C 1645.7 562.7 C 1666.8 541%2C 1679.4 517.5%2C 1687.2 485 C 1689.2 476.5%2C 1689.5 473.1%2C 1689.5 451.5 C 1689.5 429.7%2C 1689.2 426.6%2C 1687.1 418 C 1680.2 390%2C 1668.7 367.7%2C 1650.5 346.9 C 1629.6 323%2C 1597.8 304.8%2C 1565.6 298.3 C 1558.6 296.9%2C 1544.5 296.6%2C 1461 296 C 1366.3 295.4%2C 1364.3 295.4%2C 1354.6 293.2 C 1327.6 287.2%2C 1306.2 272.5%2C 1292.6 250.7 C 1286 240.1%2C 1283.4 233.6%2C 1280.9 221.2 C 1278.6 209.8%2C 1278.5 201.4%2C 1280.5 189.7 C 1286.4 156.3%2C 1308.9 130.1%2C 1342.7 117.4 C 1361.7 110.3%2C 1366.5 110%2C 1489.5 109.9 L 1597.5 109.9 1604.4 100.7 C 1633.6 62.1%2C 1647.3 43.4%2C 1647.4 42 C 1647.5 40.7%2C 1634 40.5%2C 1516 40.4 C 1412.6 40.3%2C 1381.3 40.5%2C 1369.5 41.6'/%3E%3C/svg%3E") no-repeat center / contain;
}
.brand { color: var(--ink); }
.brand:hover .brand-mark { opacity: 0.82; }
.brand-mark { transition: opacity 0.3s var(--ease-out); }

/* Lockup con tagline (footer, menú) */
.brand-lockup { display: inline-flex; flex-direction: column; gap: 0.6rem; color: var(--ink); }
.brand-lockup .brand-mark { --mark-h: 30px; }
.brand-tagline {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  font-size: 0.62rem;
  font-weight: 650;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  white-space: nowrap;
}
.brand-tagline .sep { width: 1px; height: 0.85em; background: currentColor; opacity: 0.5; }
.footer .brand-lockup { color: var(--inverse-ink); }
.footer .brand-tagline { color: color-mix(in srgb, var(--inverse-ink) 58%, transparent); }
.on-dark .brand-lockup, .on-dark .brand-mark { color: var(--inverse-ink); }

/* Showcase de marca (página Agencia, sustituye a la foto de perfil) */
.brand-showcase {
  width: 100%;
  height: 100%;
  min-height: 380px;
  display: grid;
  place-content: center;
  justify-items: center;
  gap: 1.6rem;
  padding: 2rem;
  border-radius: var(--r-l);
  background:
    radial-gradient(120% 90% at 50% 0%, color-mix(in srgb, var(--line) 60%, transparent), transparent 70%),
    var(--bg-soft);
  border: 1px solid var(--line);
  position: relative;
  overflow: hidden;
}
.brand-showcase::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--noise);
  background-size: 160px;
  opacity: 0.03;
  mix-blend-mode: multiply;
}
[data-theme="dark"] .brand-showcase::before { mix-blend-mode: screen; opacity: 0.05; }
.brand-showcase .brand-mark { --mark-h: clamp(56px, 12vw, 96px); color: var(--ink); }
.brand-showcase .brand-tagline {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  font-size: clamp(0.66rem, 1.3vw, 0.78rem);
  font-weight: 650;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.brand-showcase .brand-tagline .sep { width: 1px; height: 1.1em; background: currentColor; opacity: 0.45; }

/* ---------- 22 · BANNER DE COOKIES / ANALÍTICA ---------- */
.cookie-banner[hidden] { display: none; }
.cookie-banner {
  position: fixed;
  left: clamp(1rem, 2.5vw, 1.75rem);
  bottom: clamp(1rem, 2.5vw, 1.75rem);
  z-index: 900;
  width: min(400px, calc(100vw - 2rem));
  padding: 1.25rem 1.4rem;
  display: grid;
  gap: 1rem;
  border-radius: var(--r-m);
  border: 1px solid var(--line);
  background: var(--glass-strong);
  backdrop-filter: blur(20px) saturate(1.5);
  -webkit-backdrop-filter: blur(20px) saturate(1.5);
  box-shadow: var(--shadow-l);
  transform: translateY(160%);
  opacity: 0;
  transition: transform 0.6s var(--ease-spring), opacity 0.4s var(--ease-out);
}
.cookie-banner.is-visible { transform: none; opacity: 1; }
.cookie-banner .ck-body strong {
  display: block;
  color: var(--ink);
  font-weight: 650;
  letter-spacing: -0.01em;
  margin-bottom: 0.3rem;
}
.cookie-banner .ck-body p { font-size: 0.85rem; line-height: 1.5; color: var(--ink-mute); }
.cookie-banner .ck-body a { color: var(--ink); text-decoration: underline; text-underline-offset: 2px; }
.cookie-banner .ck-actions { display: flex; gap: 0.6rem; justify-content: flex-end; }
.cookie-banner .ck-actions .btn { flex: 0 0 auto; }

/* En móvil ocupa casi todo el ancho; el botón de WhatsApp sube para no solaparse */
@media (max-width: 560px) {
  .cookie-banner { left: 1rem; right: 1rem; width: auto; }
  .cookie-banner .ck-actions .btn { flex: 1; }
  body.cookie-open .wa-float { transform: translateY(-152px); }
  body.cookie-open .wa-float:hover { transform: translateY(-152px) scale(1.08); }
}

@media (prefers-reduced-motion: reduce) {
  .cookie-banner { transition: opacity 0.3s; transform: none; }
}

/* ---------- 23 · POPUP DE TESTIMONIO ---------- */
.t-card[role="button"] { cursor: pointer; }
.t-card[role="button"]:hover { transform: translateY(-4px); box-shadow: var(--shadow-m); }
.t-card[role="button"]:focus-visible { outline: 2px solid var(--ink); outline-offset: 3px; }

.t-modal[hidden] { display: none; }
.t-modal {
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: grid;
  place-items: center;
  padding: clamp(1rem, 4vw, 2.5rem);
}
.t-modal-backdrop {
  position: absolute;
  inset: 0;
  background: color-mix(in srgb, var(--inverse-bg) 42%, transparent);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  opacity: 0;
  transition: opacity 0.4s var(--ease-out);
}
.t-modal.is-open .t-modal-backdrop { opacity: 1; }
.t-modal-card {
  position: relative;
  width: min(560px, 100%);
  max-height: min(80vh, 640px);
  overflow: auto;
  margin: 0;
  padding: clamp(1.75rem, 4vw, 2.75rem);
  display: grid;
  gap: 1.25rem;
  border-radius: var(--r-l);
  border: 1px solid var(--line);
  background: var(--bg-card);
  box-shadow: var(--shadow-l);
  opacity: 0;
  transform: translateY(18px) scale(0.96);
  transition: opacity 0.45s var(--ease-out), transform 0.55s var(--ease-spring);
}
.t-modal.is-open .t-modal-card { opacity: 1; transform: none; }
.t-modal-card .stars { color: var(--ink); font-size: 0.8rem; letter-spacing: 3px; }
.t-modal-card .tm-quote {
  font-size: clamp(1.1rem, 2.4vw, 1.4rem);
  line-height: 1.55;
  letter-spacing: -0.015em;
  color: var(--ink-soft);
}
.t-modal-card .tm-quote::before {
  content: "“";
  font-family: var(--font-serif);
  font-size: 1.5em;
  line-height: 0;
  vertical-align: -0.3em;
  color: var(--ink-faint);
  margin-right: 3px;
}
.t-modal-card figcaption { display: flex; align-items: center; gap: 0.9rem; }
.t-modal-card .avatar {
  width: 46px; height: 46px;
  border-radius: 50%;
  background: var(--ink);
  color: var(--bg);
  display: grid;
  place-items: center;
  font-weight: 700;
  font-size: 0.9rem;
  flex: none;
}
.t-modal-card figcaption strong { display: block; color: var(--ink); font-weight: 650; }
.t-modal-card figcaption .tm-role { font-size: 0.85rem; color: var(--ink-mute); }
.t-modal-close {
  position: absolute;
  top: 1rem; right: 1rem;
  width: 38px; height: 38px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  border: 1px solid var(--line-strong);
  color: var(--ink);
  background: var(--bg);
  transition: background 0.3s, color 0.3s, transform 0.3s var(--ease-spring);
}
.t-modal-close svg { width: 14px; height: 14px; }
.t-modal-close:hover { background: var(--ink); color: var(--bg); transform: rotate(90deg); }

@media (prefers-reduced-motion: reduce) {
  .t-modal-card { transition: opacity 0.2s; transform: none; }
  .t-modal-close:hover { transform: none; }
}
