/* Tipografía de marca: Faktum (familia completa, Thin→ExtraBold + itálicas) */
@font-face{font-family:'Faktum';src:url('font/Faktum-Thin.otf') format('opentype');font-weight:100;font-style:normal;font-display:swap;}
@font-face{font-family:'Faktum';src:url('font/Faktum-ThinItalic.otf') format('opentype');font-weight:100;font-style:italic;font-display:swap;}
@font-face{font-family:'Faktum';src:url('font/Faktum-ExtraLight.otf') format('opentype');font-weight:200;font-style:normal;font-display:swap;}
@font-face{font-family:'Faktum';src:url('font/Faktum-ExtraLightItalic.otf') format('opentype');font-weight:200;font-style:italic;font-display:swap;}
@font-face{font-family:'Faktum';src:url('font/Faktum-Light.otf') format('opentype');font-weight:300;font-style:normal;font-display:swap;}
@font-face{font-family:'Faktum';src:url('font/Faktum-LightItalic.otf') format('opentype');font-weight:300;font-style:italic;font-display:swap;}
@font-face{font-family:'Faktum';src:url('font/Faktum-Regular.otf') format('opentype');font-weight:400;font-style:normal;font-display:swap;}
@font-face{font-family:'Faktum';src:url('font/Faktum-RegularItalic.otf') format('opentype');font-weight:400;font-style:italic;font-display:swap;}
@font-face{font-family:'Faktum';src:url('font/Faktum-Medium.otf') format('opentype');font-weight:500;font-style:normal;font-display:swap;}
@font-face{font-family:'Faktum';src:url('font/Faktum-MediumItalic.otf') format('opentype');font-weight:500;font-style:italic;font-display:swap;}
@font-face{font-family:'Faktum';src:url('font/Faktum-SemiBold.otf') format('opentype');font-weight:600;font-style:normal;font-display:swap;}
@font-face{font-family:'Faktum';src:url('font/Faktum-SemiBoldItalic.otf') format('opentype');font-weight:600;font-style:italic;font-display:swap;}
@font-face{font-family:'Faktum';src:url('font/Faktum-Bold.otf') format('opentype');font-weight:700;font-style:normal;font-display:swap;}
@font-face{font-family:'Faktum';src:url('font/Faktum-BoldItalic.otf') format('opentype');font-weight:700;font-style:italic;font-display:swap;}
@font-face{font-family:'Faktum';src:url('font/Faktum-ExtraBold.otf') format('opentype');font-weight:800;font-style:normal;font-display:swap;}
@font-face{font-family:'Faktum';src:url('font/Faktum-ExtraBoldItalic.otf') format('opentype');font-weight:800;font-style:italic;font-display:swap;}
/* ============================================================
   BIMO · DESIGN SYSTEM
   Dark ink + magenta (extraído del HTML original de BIMO)
   ============================================================ */
:root{
  /* ---------- BRAND CORE (real, de colors_and_type.css) ---------- */
  --bimo-magenta:        #ED3D97;
  --bimo-magenta-neon:   #FF0E9C;
  --bimo-magenta-deep:   #B01F6E;
  --bimo-magenta-wine:   #4A0E2E;
  --bimo-magenta-soft:   #FFD9EC;
  --bimo-magenta-tint:   #FFF1F8;
  --bimo-ink:            #0A0509;
  --bimo-ink-soft:       #14080F;
  --bimo-paper:          #FAF7F8;
  --bimo-white:          #FFFFFF;

  /* ---------- GLOW (resplandor magenta global) ---------- */
  /* Un único número controla TODO el resplandor: súbelo/bájalo aquí. */
  --glow-opacity:        0.35;
  --glow-strong:         color-mix(in srgb, var(--bimo-magenta) calc(var(--glow-opacity) * 80%), transparent);
  --glow-soft:           color-mix(in srgb, var(--bimo-magenta) calc(var(--glow-opacity) * 45%), transparent);

  /* ---------- DARK MODE (default) ---------- */
  --bg:                  var(--bimo-ink);
  --bg-glow:             radial-gradient(ellipse 90% 70% at 50% 50%, var(--bimo-magenta) 0%, var(--bimo-magenta-deep) 20%, var(--bimo-magenta-wine) 50%, var(--bimo-ink) 90%);
  --fg1:                 #FFFFFF;
  --fg2:                 rgba(255, 255, 255, 0.72);
  --fg3:                 rgba(255, 255, 255, 0.48);
  --fg-disabled:         rgba(255, 255, 255, 0.28);
  --stroke:              rgba(255, 255, 255, 0.10);
  --stroke-strong:       rgba(255, 255, 255, 0.22);

  /* glass surfaces */
  --glass-fill:          rgba(255, 255, 255, 0.06);
  --glass-stroke:        rgba(255, 255, 255, 0.22);

  /* ---------- SEMANTIC ---------- */
  --primary:             var(--bimo-magenta);
  --primary-hot:         var(--bimo-magenta-neon);
  --accent-glow:         0 0 40px var(--glow-soft), 0 0 16px var(--glow-strong);
  --success:             #4ADE80;
  --warning:             #FFB020;
  --danger:              #FF4E6B;

  /* ---------- RADII ---------- */
  --r-xs:8px; --r-sm:12px; --r-md:20px; --r-lg:28px; --r-xl:40px; --r-pill:999px; --r-squircle:28%;

  /* ---------- SPACING ---------- */
  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:24px; --s-6:32px; --s-7:48px; --s-8:64px; --s-9:96px; --s-10:128px;

  /* ---------- ELEVATION ---------- */
  --elev-1:0 1px 2px rgba(0,0,0,0.4); --elev-2:0 4px 16px rgba(0,0,0,0.45); --elev-3:0 12px 40px rgba(0,0,0,0.55);
  --elev-glow:0 10px 40px var(--glow-soft);

  /* ---------- MOTION ---------- */
  --ease-out:cubic-bezier(0.22, 1, 0.36, 1);
  --ease-in-out:cubic-bezier(0.65, 0, 0.35, 1);
  --ease-soft:cubic-bezier(0.4, 0.0, 0.2, 1);
  --dur-fast:180ms; --dur-base:320ms; --dur-slow:640ms; --dur-ambient:3200ms;

  /* ---------- TYPE ---------- */
  --font-sans:'Quicksand', 'DM Sans', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-mono:'Quicksand', 'DM Sans', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --tr-display:-0.03em; --tr-heading:-0.015em; --tr-body:0.002em; --tr-eyebrow:0.22em; --tr-wide:0.09em;
  --t-display:clamp(56px, 7vw, 96px); --t-h1:clamp(40px, 4.6vw, 60px); --t-h2:clamp(28px, 3vw, 40px);
  --t-h3:22px; --t-h4:18px; --t-body-lg:18px; --t-body:16px; --t-body-sm:14px; --t-caption:13px; --t-micro:11px;

  /* ---------- ALIAS de compatibilidad (secciones aún sin portar) ---------- */
  --magenta:var(--bimo-magenta);
  --magenta-hot:var(--bimo-magenta-neon);
  --magenta-soft:#ff7bc9;
  --fucsia:var(--bimo-magenta-neon);
  --violet:var(--bimo-magenta-deep);
  --cyan:var(--bimo-magenta);
  --bimo-ink-2:#14080F;
  --bimo-ink-3:#1c0f17;
  --line:var(--stroke);
  --line-2:var(--stroke-strong);
  --font-display:'Quicksand', var(--font-sans);
  --radius:20px; --radius-lg:28px; --radius-btn:10px; --maxw:1200px;
  --ease:var(--ease-out);
  --grad:linear-gradient(180deg,#FF4FAE 0%,#ED3D97 55%,#C92A7E 100%);
  --grad-text:linear-gradient(180deg,#FFFFFF 0%,#FFB3D9 100%);
}

/* ---------- LIGHT MODE OVERRIDES ---------- */
[data-theme="light"]{
  --bg:var(--bimo-paper);
  --fg1:var(--bimo-ink);
  --fg2:rgba(10, 5, 9, 0.65);
  --fg3:rgba(10, 5, 9, 0.40);
  --fg-disabled:rgba(10, 5, 9, 0.22);
  --stroke:rgba(10, 5, 9, 0.08);
  --stroke-strong:rgba(10, 5, 9, 0.18);
  --glass-fill:rgba(255, 255, 255, 0.55);
  --glass-stroke:rgba(255, 255, 255, 0.9);
}

/* ---------- TYPE STYLES ---------- */
*{box-sizing:border-box;}
html{scroll-behavior:smooth;scroll-padding-top:90px;-webkit-text-size-adjust:100%;}
html{overflow-x:hidden;}
body{margin:0;padding:0;overflow-x:hidden;position:relative;width:100%;max-width:100%;background:radial-gradient(1100px 700px at 12% -8%,rgba(255,255,255,0.05),transparent 60%),radial-gradient(900px 650px at 92% 10%,rgba(255,143,201,0.07),transparent 60%),radial-gradient(800px 600px at 50% 105%,rgba(237,61,151,0.06),transparent 65%),var(--bg);}
/* Escala global ~90% SOLO en desktop: web más compacta sin tocar maquetación.
   Se usa zoom (reflueye de verdad, sin franjas y respeta el navbar fijo) porque
   la web está en px. En móvil/tablet (<1024px) tamaño normal para legibilidad. */
@media(min-width:1024px){ body{ zoom:0.9; } }
body{
  color:var(--fg1);
  font-family:var(--font-sans);
  font-size:var(--t-body);
  line-height:1.55;
  letter-spacing:var(--tr-body);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  transition:background 320ms var(--ease-out);
}
h1,h2,h3,h4{font-family:var(--font-sans);text-wrap:balance;margin:0;}
h1{font-size:var(--t-h1);font-weight:700;letter-spacing:var(--tr-heading);line-height:1.04;}
h2{font-size:var(--t-h2);font-weight:700;letter-spacing:var(--tr-heading);line-height:1.1;}
h3{font-size:var(--t-h3);font-weight:600;letter-spacing:var(--tr-heading);line-height:1.2;}
h4{font-size:var(--t-h4);font-weight:600;letter-spacing:var(--tr-body);line-height:1.3;}
.t-display{font-size:var(--t-display);font-weight:700;letter-spacing:var(--tr-display);line-height:0.96;text-wrap:balance;}
.lede,.t-body-lg{font-size:var(--t-body-lg);font-weight:400;letter-spacing:var(--tr-body);line-height:1.45;color:var(--fg2);}
.t-eyebrow{font-size:var(--t-micro);font-weight:600;letter-spacing:var(--tr-eyebrow);text-transform:uppercase;color:var(--fg3);}
.t-mono,code{font-family:var(--font-mono);font-size:0.92em;letter-spacing:var(--tr-wide);font-weight:500;}

#page{position:relative;z-index:1;overflow-x:clip;}   /* confina cualquier desbordamiento horizontal sin romper scrolls internos */

::-webkit-scrollbar{width:10px;height:10px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:rgba(255,14,156,0.25);border-radius:999px;}
::-webkit-scrollbar-thumb:hover{background:rgba(255,14,156,0.45);}

::selection{background:var(--bimo-magenta);color:#fff;}

a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}

/* Foco visible accesible (teclado) */
:focus-visible{outline:2px solid var(--magenta);outline-offset:3px;border-radius:8px;}

/* ============================================================
   BIMO · DS COMPONENTS (real, de colors_and_type.css + bimo-ds.css)
   ============================================================ */
.bimo-magenta-btn{position:relative;background:linear-gradient(180deg,#FF4FAE 0%,#ED3D97 55%,#C92A7E 100%);color:#0A0509;border:none;box-shadow:inset 0 0.5px 0 rgba(255,255,255,0.7),inset 0 -0.5px 0 rgba(74,14,46,0.4),inset 0 0 0 0.5px rgba(255,255,255,0.1),0 4px 16px rgba(255,14,156,0.45);isolation:isolate;overflow:hidden;}

/* ROTATING GLOW RING */
@property --bimo-a  { syntax: '<angle>'; initial-value: 0deg; inherits: false; }
@property --bimo-c1 { syntax: '<color>'; initial-value: rgba(255,14,156,1);    inherits: false; }
@property --bimo-c2 { syntax: '<color>'; initial-value: rgba(255,14,156,0.05); inherits: false; }
@property --bimo-ch { syntax: '<color>'; initial-value: rgba(255,125,197,1);   inherits: false; }
@keyframes bimo-spin { to { --bimo-a: 360deg; } }
/* Pausar anillos cónicos (repintan en cada frame) cuando no están en pantalla */
.spin-off{animation-play-state:paused!important;}

/* BG · ambient circular gradients (HERO) */
.bimo-bg-ambient{position:relative;overflow:hidden;}
.bimo-bg-ambient::before{content:"";position:absolute;inset:0;pointer-events:none;z-index:0;background:radial-gradient(ellipse 72% 62% at 50% 52%, rgba(255,14,156,0.8) 0%, rgba(224,32,134,0.52) 16%, rgba(176,31,110,0.34) 32%, rgba(128,24,80,0.2) 48%, rgba(86,16,54,0.11) 64%, rgba(50,10,32,0.05) 80%, rgba(28,6,18,0.015) 91%, transparent 100%);opacity:var(--glow-opacity);animation:bimo-breathe-bg 6.5s ease-in-out infinite;}
.bimo-bg-ambient::after{content:"";position:absolute;inset:0;pointer-events:none;z-index:0;background:radial-gradient(circle 320px at 28% 30%, rgba(255,14,156,0.7) 0%, transparent 60%),radial-gradient(circle 280px at 72% 70%, rgba(255,80,180,0.5) 0%, transparent 60%),radial-gradient(circle 240px at 70% 25%, rgba(176,31,110,0.42) 0%, transparent 65%);opacity:var(--glow-opacity);filter:blur(14px);animation:bimo-orbit 14s ease-in-out infinite;}
@keyframes bimo-breathe-bg{0%,100%{opacity:0.92;transform:scale(1);}50%{opacity:1;transform:scale(1.04);}}
@keyframes bimo-orbit{0%,100%{transform:translate(0,0);}33%{transform:translate(3%,-2%);}66%{transform:translate(-2%,3%);}}

/* PILL · signature glass pill */
.bimo-pill-wrap{position:relative;isolation:isolate;display:block;padding:2px;border-radius:20px;--bimo-a:0deg;background:conic-gradient(from var(--bimo-a),rgba(255,14,156,0.10) 0deg,rgba(255,14,156,0.10) 40deg,rgba(255,14,156,0.85) 70deg,rgba(255,125,197,1) 90deg,rgba(255,14,156,0.85) 110deg,rgba(255,14,156,0.10) 140deg,rgba(255,14,156,0.10) 360deg);animation:bimo-spin 3.5s linear infinite;}
.bimo-pill-wrap::after{content:"";position:absolute;inset:-10px;border-radius:inherit;background:inherit;filter:blur(16px);opacity:var(--glow-opacity);z-index:-1;}
.bimo-pill-wrap::before{content:"";position:absolute;inset:-20px;border-radius:inherit;background:inherit;filter:blur(28px);opacity:calc(var(--glow-opacity) * 0.5);z-index:-2;}
.bimo-pill{position:relative;width:100%;min-height:56px;padding:0 28px;display:flex;align-items:center;gap:12px;border-radius:18px;background:#14080F;border:none;color:rgba(255,255,255,0.92);font-size:15px;letter-spacing:-0.005em;z-index:1;font-family:var(--font-sans);}
[data-theme="light"] .bimo-pill{background:#FFFFFF;color:var(--bimo-ink);}

/* CARD · canonical */
.bimo-card-ring{position:relative;isolation:isolate;--bimo-a:0deg;padding:1px;border-radius:28px;background:conic-gradient(from var(--bimo-a),rgba(255,14,156,0.10) 0deg,rgba(255,14,156,0.10) 40deg,rgba(255,14,156,0.65) 70deg,rgba(255,125,197,1) 90deg,rgba(255,14,156,0.65) 110deg,rgba(255,14,156,0.10) 140deg,rgba(255,14,156,0.10) 360deg);animation:bimo-spin 8s linear infinite,bimo-card-bloom 4s ease-in-out infinite;transition:transform 480ms cubic-bezier(.22,1,.36,1);}
.bimo-card-ring::after{display:none;}
.bimo-card-ring:hover{transform:translateY(-3px);}
@keyframes bimo-card-bloom{0%,100%{box-shadow:0 0 18px rgba(255,14,156,0.12),0 0 36px rgba(255,14,156,0.06);}50%{box-shadow:0 0 28px rgba(255,14,156,0.20),0 0 60px rgba(255,14,156,0.10);}}
.bimo-card{position:relative;height:100%;padding:28px;border-radius:27px;background:rgba(14,8,12,0.92);backdrop-filter:blur(20px) saturate(60%);-webkit-backdrop-filter:blur(20px) saturate(60%);box-shadow:inset 0 0.5px 0 rgba(255,255,255,0.10),inset 0 -0.5px 0 rgba(255,255,255,0.03);display:flex;flex-direction:column;gap:16px;overflow:hidden;}
.bimo-card::before{content:"";position:absolute;inset:1px 1px auto 1px;height:35%;border-radius:27px 27px 4px 4px;background:linear-gradient(180deg,rgba(255,255,255,0.04) 0%,rgba(255,255,255,0) 100%);pointer-events:none;z-index:0;}
.bimo-card > *{position:relative;z-index:1;}
[data-theme="light"] .bimo-card{background:rgba(255,255,255,0.96);box-shadow:inset 0 0.5px 0 rgba(255,255,255,0.95),inset 0 -0.5px 0 rgba(10,5,9,0.04);}
.bimo-card-ring--sm{padding:1px;border-radius:20px;}
.bimo-card-ring--sm .bimo-card{padding:20px;border-radius:19px;}
.bimo-card-ring--neutral{background:conic-gradient(from var(--bimo-a),rgba(255,255,255,0.03) 0deg,rgba(255,255,255,0.03) 60deg,rgba(255,255,255,0.22) 85deg,rgba(255,255,255,0.40) 90deg,rgba(255,255,255,0.22) 95deg,rgba(255,255,255,0.03) 120deg,rgba(255,255,255,0.03) 360deg);animation:bimo-spin 18s linear infinite;box-shadow:none;}

/* ICON TILE */
.bimo-icon-tile{position:relative;width:44px;height:44px;border-radius:28%;background:linear-gradient(180deg,#FF4FAE 0%,#ED3D97 55%,#C92A7E 100%);color:#0A0509;display:grid;place-items:center;box-shadow:inset 0 0.5px 0 rgba(255,255,255,0.75),inset 0 -0.5px 0 rgba(74,14,46,0.45),inset 0 0 0 0.5px rgba(255,255,255,0.12),0 6px 20px rgba(255,14,156,0.5);isolation:isolate;animation:bimo-tile-pulse 3.4s ease-in-out infinite;flex-shrink:0;}
.bimo-icon-tile::before{content:"";position:absolute;inset:1px 1px auto 1px;height:50%;border-radius:26% 26% 4px 4px;background:linear-gradient(180deg,rgba(255,255,255,0.35) 0%,rgba(255,255,255,0) 100%);pointer-events:none;}
.bimo-icon-tile > *{position:relative;z-index:1;}
.bimo-icon-tile--sm{width:36px;height:36px;}
.bimo-icon-tile--lg{width:52px;height:52px;}
@keyframes bimo-tile-pulse{0%,100%{box-shadow:inset 0 0.5px 0 rgba(255,255,255,0.75),inset 0 -0.5px 0 rgba(74,14,46,0.45),inset 0 0 0 0.5px rgba(255,255,255,0.12),0 6px 18px rgba(255,14,156,0.45);}50%{box-shadow:inset 0 0.5px 0 rgba(255,255,255,0.85),inset 0 -0.5px 0 rgba(74,14,46,0.55),inset 0 0 0 0.5px rgba(255,255,255,0.18),0 10px 28px rgba(255,14,156,0.7);}}

/* BUTTONS */
.bimo-btn-ring{position:relative;isolation:isolate;display:inline-block;--bimo-a:0deg;padding:1px;border-radius:999px;background:conic-gradient(from var(--bimo-a),rgba(255,14,156,0.10) 0deg,rgba(255,14,156,0.10) 40deg,rgba(255,14,156,0.65) 70deg,rgba(255,125,197,1) 90deg,rgba(255,14,156,0.65) 110deg,rgba(255,14,156,0.10) 140deg,rgba(255,14,156,0.10) 360deg);animation:bimo-spin 6s linear infinite,bimo-btn-bloom 4s ease-in-out infinite;transition:transform 280ms cubic-bezier(.22,1,.36,1);}
.bimo-btn-ring::after{display:none;}
.bimo-btn-ring:hover{transform:translateY(-2px);}
.bimo-btn-ring.is-primary{animation-duration:5s,3.4s;}
@keyframes bimo-btn-bloom{0%,100%{box-shadow:0 0 12px rgba(255,14,156,0.10),0 0 28px rgba(255,14,156,0.05);}50%{box-shadow:0 0 20px rgba(255,14,156,0.18),0 0 44px rgba(255,14,156,0.09);}}
.bimo-btn{position:relative;font-family:var(--font-sans);border:none;cursor:pointer;font-size:15px;font-weight:600;letter-spacing:-0.01em;padding:13px 22px;border-radius:var(--radius-btn);color:white;background:rgba(14,8,12,0.92);backdrop-filter:blur(20px) saturate(60%);-webkit-backdrop-filter:blur(20px) saturate(60%);box-shadow:inset 0 0.5px 0 rgba(255,255,255,0.12),inset 0 -0.5px 0 rgba(255,255,255,0.03);transition:background 220ms cubic-bezier(.22,1,.36,1),transform 90ms;overflow:hidden;display:inline-flex;align-items:center;gap:8px;white-space:nowrap;text-decoration:none;}
.bimo-btn::before{content:"";position:absolute;inset:1px 1px auto 1px;height:45%;border-radius:inherit;background:linear-gradient(180deg,rgba(255,255,255,0.06) 0%,rgba(255,255,255,0) 100%);pointer-events:none;z-index:0;}
.bimo-btn > *{position:relative;z-index:1;}
.bimo-btn:hover{background:rgba(28,12,22,0.92);}
.bimo-btn:active{transform:scale(0.97);}
.bimo-btn.is-rect{border-radius:14px;}
.bimo-btn.is-sm{font-size:13px;padding:9px 16px;gap:6px;}
.bimo-btn.is-lg{font-size:14px;padding:16px 28px;}
[data-theme="light"] .bimo-btn{background:rgba(255,255,255,0.92);color:var(--bimo-ink);box-shadow:inset 0 0.5px 0 rgba(255,255,255,0.95),inset 0 -0.5px 0 rgba(10,5,9,0.05);}
[data-theme="light"] .bimo-btn:hover{background:rgba(255,255,255,0.98);}
.bimo-btn.is-primary{background:linear-gradient(180deg,#FF4FAE 0%,#ED3D97 55%,#C92A7E 100%);color:#0A0509;box-shadow:inset 0 0.5px 0 rgba(255,255,255,0.7),inset 0 -0.5px 0 rgba(74,14,46,0.4),inset 0 0 0 0.5px rgba(255,255,255,0.1);}
.bimo-btn.is-primary::before{background:linear-gradient(180deg,rgba(255,255,255,0.32) 0%,rgba(255,255,255,0) 100%);}
.bimo-btn.is-primary:hover{background:linear-gradient(180deg,#FF67BC 0%,#F04CA0 55%,#C92A7E 100%);}
.bimo-btn-circle{width:48px;height:48px;border-radius:var(--radius-btn);padding:0;display:grid;place-items:center;}
.bimo-btn-circle.is-lg{width:52px;height:52px;}
.bimo-btn-text{background:transparent;border:none;cursor:pointer;font-family:var(--font-sans);font-size:14px;font-weight:600;letter-spacing:-0.005em;color:inherit;padding:8px 4px 8px 0;position:relative;display:inline-flex;align-items:center;gap:6px;text-decoration:none;}
.bimo-btn-text::before{content:"";position:absolute;left:0;right:22px;bottom:4px;height:1px;background:currentColor;opacity:0.5;transform:scaleX(0);transform-origin:left center;transition:transform 320ms cubic-bezier(.22,1,.36,1);}
.bimo-btn-text:hover::before{transform:scaleX(1);}
.bimo-btn-text .arrow{transition:transform 280ms cubic-bezier(.22,1,.36,1);display:inline-block;}
.bimo-btn-text:hover .arrow{transform:translateX(5px);}

/* CHIP */
.bimo-chip{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:var(--radius-btn);background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.10);color:rgba(255,255,255,0.78);font-size:13px;font-weight:500;font-family:var(--font-sans);cursor:pointer;letter-spacing:-0.005em;transition:all 200ms cubic-bezier(.22,1,.36,1);text-decoration:none;}
.bimo-chip:hover{background:rgba(255,14,156,0.10);border-color:rgba(255,14,156,0.35);color:white;}
.bimo-chip.is-active{background:rgba(255,14,156,0.14);border-color:rgba(255,14,156,0.5);color:white;}
[data-theme="light"] .bimo-chip{background:rgba(255,255,255,0.65);border-color:rgba(10,5,9,0.08);color:rgba(10,5,9,0.7);}
[data-theme="light"] .bimo-chip:hover{background:rgba(237,61,151,0.10);border-color:rgba(237,61,151,0.35);color:var(--bimo-ink);}

/* EYEBROW */
.bimo-eyebrow{font-size:11px;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;color:rgba(255,255,255,0.55);display:inline-flex;align-items:center;gap:10px;font-family:var(--font-sans);}
[data-theme="light"] .bimo-eyebrow{color:rgba(10,5,9,0.5);}
.bimo-eyebrow .bimo-pulse-dot{width:7px;height:7px;border-radius:999px;background:var(--bimo-magenta);box-shadow:0 0 10px var(--bimo-magenta);animation:bimo-pulse-dot 1.6s ease-in-out infinite;}
@keyframes bimo-pulse-dot{0%,100%{opacity:1;transform:scale(1);}50%{opacity:0.4;transform:scale(0.8);}}

/* GLASS PANEL */
.bimo-glass{background:rgba(255,255,255,0.06);backdrop-filter:blur(20px) saturate(140%);-webkit-backdrop-filter:blur(20px) saturate(140%);border:1px solid rgba(255,255,255,0.12);border-radius:24px;box-shadow:inset 0 1px 0 rgba(255,255,255,0.18),inset 0 -1px 0 rgba(255,14,156,0.25),0 16px 48px rgba(0,0,0,0.35);}
[data-theme="light"] .bimo-glass{background:rgba(255,255,255,0.7);border-color:rgba(255,255,255,0.9);box-shadow:inset 0 1px 0 rgba(255,255,255,0.95),inset 0 -1px 0 rgba(237,61,151,0.18),0 16px 48px rgba(237,61,151,0.1);}

/* UTILITIES */
.bimo-fade-in{animation:bimo-fade-in 380ms ease-out both;}
@keyframes bimo-fade-in{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}

/* TOAST */
.bimo-toast-host{position:fixed;top:84px;left:50%;transform:translateX(-50%);z-index:300;pointer-events:none;}
.bimo-toast-ring{position:relative;isolation:isolate;display:inline-block;padding:1.5px;border-radius:999px;--bimo-a:0deg;background:conic-gradient(from var(--bimo-a),rgba(74,222,128,0.05) 0deg,rgba(74,222,128,1) 70deg,rgba(180,245,200,1) 90deg,rgba(74,222,128,1) 110deg,rgba(74,222,128,0.05) 180deg,rgba(74,222,128,0.05) 360deg);animation:bimo-spin 4.5s linear infinite,bimo-toast-in 600ms cubic-bezier(.22,1,.36,1);pointer-events:auto;}
.bimo-toast-ring::after{content:"";position:absolute;inset:-8px;border-radius:inherit;background:inherit;filter:blur(12px);opacity:0.35;z-index:-1;animation:bimo-spin 4.5s linear infinite;}
@keyframes bimo-toast-in{0%{opacity:0;transform:translateY(14px) scale(0.94);}100%{opacity:1;transform:translateY(0) scale(1);}}
.bimo-toast-ring--leaving{animation:bimo-toast-out 320ms cubic-bezier(.22,1,.36,1) forwards;}
@keyframes bimo-toast-out{to{opacity:0;transform:translateY(-10px) scale(0.96);}}
.bimo-toast{position:relative;display:flex;align-items:center;gap:14px;padding:14px 22px 14px 14px;border-radius:999px;background:rgba(8,22,14,0.85);backdrop-filter:blur(22px) saturate(60%);-webkit-backdrop-filter:blur(22px) saturate(60%);color:white;font-family:var(--font-sans);box-shadow:inset 0 1px 0 rgba(255,255,255,0.15),inset 0 -1px 0 rgba(74,222,128,0.25),0 12px 36px rgba(34,160,80,0.15);}
.bimo-toast-icon{width:32px;height:32px;border-radius:999px;background:#4ADE80;display:grid;place-items:center;flex-shrink:0;color:#0A2A14;box-shadow:inset 0 1px 0 rgba(255,255,255,0.5),0 0 10px rgba(74,222,128,0.4);animation:bimo-toast-pop 700ms cubic-bezier(.22,1.6,.36,1) 100ms backwards;}
@keyframes bimo-toast-pop{0%{transform:scale(0.3) rotate(-25deg);opacity:0;}60%{transform:scale(1.15) rotate(5deg);opacity:1;}100%{transform:scale(1) rotate(0);opacity:1;}}
.bimo-toast-copy{display:flex;flex-direction:column;gap:2px;}
.bimo-toast-ti{font-size:14px;font-weight:600;letter-spacing:-0.005em;}
.bimo-toast-meta{font-size:12px;color:rgba(255,255,255,0.55);}

/* PAGE AMBIENT FIELD */
.bimo-ambient-field{position:absolute;inset:0;width:100%;height:100%;overflow:hidden;pointer-events:none;z-index:0;}
.bimo-ambient-field .blob{position:absolute;border-radius:50%;filter:blur(150px);will-change:transform;}
.bimo-ab-1{top:2%;left:50%;width:1100px;height:780px;transform:translateX(-50%);background:radial-gradient(circle,rgba(255,14,156,0.30),rgba(176,31,110,0.10) 45%,transparent 70%);animation:bimo-field-a 16s ease-in-out infinite alternate;}
.bimo-ab-2{top:16%;left:8%;width:760px;height:640px;background:radial-gradient(circle,rgba(255,14,156,0.16),transparent 68%);animation:bimo-field-b 19s ease-in-out infinite alternate;}
.bimo-ab-3{top:33%;left:82%;width:820px;height:700px;transform:translateX(-50%);background:radial-gradient(circle,rgba(176,31,110,0.18),transparent 68%);animation:bimo-field-a 22s ease-in-out infinite alternate;}
.bimo-ab-4{top:52%;left:18%;width:900px;height:720px;background:radial-gradient(circle,rgba(255,14,156,0.15),transparent 70%);animation:bimo-field-b 18s ease-in-out infinite alternate;}
.bimo-ab-5{top:70%;left:78%;width:820px;height:700px;transform:translateX(-50%);background:radial-gradient(circle,rgba(255,14,156,0.16),transparent 70%);animation:bimo-field-a 21s ease-in-out infinite alternate;}
.bimo-ab-6{top:90%;left:45%;width:1000px;height:760px;background:radial-gradient(circle,rgba(255,14,156,0.22),rgba(176,31,110,0.08) 45%,transparent 72%);animation:bimo-field-b 17s ease-in-out infinite alternate;}
@keyframes bimo-field-a{from{transform:translate(-50%,0) scale(1);}to{transform:translate(-50%,-3%) scale(1.06);}}
@keyframes bimo-field-b{from{transform:translate(0,0) scale(1);}to{transform:translate(2%,3%) scale(1.05);}}
[data-theme="light"] .bimo-ambient-field{opacity:0.5;}

/* GRAIN */
.bimo-grain{position:fixed;inset:0;pointer-events:none;z-index:2;opacity:0.035;mix-blend-mode:overlay;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='160' height='160' filter='url(%23n)'/></svg>");}

/* SCROLL REVEAL (real) */
/* Reveal: SOLO transform+opacity (sin filter/blur), corto y ease-out (móvil fluido) */
[data-bimo-reveal]{opacity:0;transform:translateY(20px);transition:opacity 360ms ease-out,transform 360ms ease-out;}
[data-bimo-reveal].is-in{opacity:1;transform:translateY(0);}

/* STAT NUMBER */
.bimo-stat-num{font-size:28px;font-weight:700;letter-spacing:-0.04em;background:linear-gradient(180deg,#FFFFFF 0%,#FFB3D9 100%);-webkit-background-clip:text;background-clip:text;color:transparent;display:inline-block;line-height:1;}

/* ---------- Layout helpers ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px;}
section{position:relative;padding:clamp(44px,6vw,84px) 0;}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-mono);font-size:12px;font-weight:500;
  letter-spacing:0.2em;text-transform:uppercase;color:var(--fg2);
}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--magenta);box-shadow:0 0 12px var(--magenta);}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;letter-spacing:-0.03em;line-height:1.03;margin:0;}
.h-sec{font-size:clamp(30px,4.6vw,54px);margin:18px 0 0;}
.lead{font-size:clamp(16px,1.6vw,19px);color:var(--fg2);max-width:620px;margin:20px 0 0;line-height:1.65;}
.center{text-align:center;}
.center .lead{margin-left:auto;margin-right:auto;}
.gradient-text{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent;}
.muted{color:var(--fg2);}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--font-sans);font-weight:600;font-size:15.5px;letter-spacing:-0.01em;
  padding:15px 26px;border-radius:var(--radius-btn);cursor:pointer;border:1px solid transparent;
  transition:transform .25s cubic-bezier(.2,.7,.2,1),box-shadow .25s,background .25s,border-color .25s;
  white-space:nowrap;
}
.btn svg{width:17px;height:17px;}
.btn-primary{background:var(--grad);color:#fff;box-shadow:0 8px 28px var(--glow-soft);background-size:160% 160%;}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 48px -12px rgba(255,14,156,0.85);background-position:100% 0;}
.btn-ghost{background:rgba(255,255,255,0.04);color:var(--fg1);border-color:var(--line-2);}
.btn-ghost:hover{transform:translateY(-2px);border-color:var(--magenta);background:rgba(237,61,151,0.10);}
.btn-lg{padding:18px 34px;font-size:16.5px;}
/* Micro-feedback al pulsar (escala 0.97) */
.btn:active{transform:scale(0.97);}
.send-btn:active{transform:scale(0.94);}
.chip:active{transform:scale(0.97);}

/* ============================================================
   NAVBAR
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  transition:background .2s ease,border-color .2s ease,backdrop-filter .2s ease;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(7,4,9,0.72);backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);border-bottom:1px solid var(--line);
}
/* Header full-width, pegado a las esquinas (estilo Higgsfield) */
/* Altura y logo FIJOS: al scrollear solo cambia el fondo (sin saltos). */
.nav-inner{width:100%;margin:0;padding:15px 30px;display:flex;align-items:center;gap:34px;}
.nav-left{display:flex;align-items:center;}
.nav-right{display:flex;align-items:center;gap:12px;margin-left:auto;}
@media(max-width:560px){.nav-inner{padding-left:18px;padding-right:18px;gap:14px;}}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--font-display);font-weight:700;font-size:22px;letter-spacing:-0.04em;}
/* Logo BIMO: blanco en dark, negro en light (compartido entre páginas) */
.brand-logo{height:18px;width:auto;display:block;filter:brightness(0) invert(1);}
[data-theme="light"] .brand-logo{filter:brightness(0);}
.brand-fallback{font-weight:700;font-size:18px;letter-spacing:-0.045em;}
footer .brand-logo{height:20px;}
.brand .mark{
  width:30px;height:30px;border-radius:9px;background:var(--grad);background-size:180% 180%;
  display:grid;place-items:center;font-size:15px;color:#fff;box-shadow:0 6px 20px -6px rgba(255,14,156,0.8);
  animation:markShift 6s ease infinite;
}
@keyframes markShift{0%,100%{background-position:0 0;}50%{background-position:100% 100%;}}
.nav-links{display:flex;align-items:center;gap:26px;}
.nav-links a{font-size:15px;color:var(--fg2);font-weight:500;transition:color .2s;position:relative;}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;background:var(--magenta);transition:width .25s;border-radius:2px;}
.nav-links a:hover{color:var(--fg1);}
.nav-links a:hover::after{width:100%;}
/* Desplegable (Servicios) */
.nav-dd{position:relative;}
.nav-dd-btn{display:inline-flex;align-items:center;gap:5px;font-size:15px;font-weight:500;color:var(--fg2);background:none;border:0;padding:0;cursor:pointer;font-family:inherit;transition:color .2s;}
.nav-dd-btn:hover,.nav-dd:hover .nav-dd-btn,.nav-dd[data-open] .nav-dd-btn{color:var(--fg1);}
.nav-dd-caret{width:14px;height:14px;transition:transform .25s;}
.nav-dd:hover .nav-dd-caret,.nav-dd[data-open] .nav-dd-caret{transform:rotate(180deg);}
.nav-dd-menu{position:absolute;top:calc(100% + 16px);left:50%;transform:translateX(-50%) translateY(6px);min-width:212px;display:flex;flex-direction:column;gap:2px;padding:8px;border-radius:16px;background:rgba(14,8,12,0.97);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,0.1);box-shadow:0 24px 60px -20px rgba(0,0,0,0.7),0 0 40px -22px rgba(255,14,156,0.45);opacity:0;visibility:hidden;transition:opacity .22s,transform .22s,visibility .22s;z-index:60;}
[data-theme="light"] .nav-dd-menu{background:rgba(255,255,255,0.98);border-color:rgba(10,5,9,0.1);box-shadow:0 24px 60px -22px rgba(237,61,151,0.25);}
.nav-dd-menu::before{content:"";position:absolute;top:-16px;left:0;right:0;height:16px;}
.nav-dd:hover .nav-dd-menu,.nav-dd:focus-within .nav-dd-menu,.nav-dd[data-open] .nav-dd-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
.nav-dd-menu a{font-size:14px;color:var(--fg2);padding:9px 12px;border-radius:10px;white-space:nowrap;transition:background .18s,color .18s;}
.nav-dd-menu a::after{display:none;}
.nav-dd-menu a:hover{background:rgba(255,14,156,0.1);color:var(--fg1);}
.nav-cta{display:flex;align-items:center;gap:12px;}
/* Badge "NUEVO" junto a Academia */
.nav-new{position:relative;overflow:hidden;display:inline-block;margin-left:7px;font-family:var(--font-mono);font-size:8px;font-weight:700;letter-spacing:0.05em;text-transform:uppercase;color:#fff;background:var(--bimo-magenta);padding:2px 7px;border-radius:var(--radius-btn);vertical-align:1.5px;box-shadow:0 0 8px -3px var(--glow-soft);}
.nav-new::after{content:"";position:absolute;inset:0;width:55%;background:linear-gradient(100deg,transparent,rgba(255,255,255,0.6),transparent);transform:translateX(-200%);pointer-events:none;}
@media (prefers-reduced-motion: no-preference){
  .nav-new::after{animation:navShimmer 2.8s ease-in-out infinite;}
  @keyframes navShimmer{0%{transform:translateX(-200%)}55%,100%{transform:translateX(360%)}}
}
/* Buscador pill (estilo Higgsfield) */
.nav-search{display:inline-flex;align-items:center;gap:9px;height:38px;padding:0 7px 0 13px;border-radius:var(--radius-btn);background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.12);color:var(--fg2);cursor:pointer;font-family:var(--font-sans);font-size:13.5px;min-width:208px;transition:border-color .22s,background .22s,box-shadow .22s;}
[data-theme="light"] .nav-search{background:rgba(10,5,9,0.04);border-color:rgba(10,5,9,0.12);}
.nav-search:hover{border-color:rgba(255,255,255,0.22);background:rgba(255,255,255,0.06);}
.nav-search:focus-visible,.nav-search.is-active{outline:none;border-color:var(--bimo-magenta);box-shadow:0 0 0 3px rgba(255,14,156,0.18);}
.nav-search svg{width:15px;height:15px;color:var(--fg3);flex:0 0 auto;}
.nav-search .ns-ph{flex:1;text-align:left;color:var(--fg3);}
.nav-search .ns-kbd{font-family:var(--font-mono);font-size:10.5px;color:var(--fg2);background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.13);border-radius:6px;padding:3px 6px;line-height:1;flex:0 0 auto;}
/* Modal de búsqueda (paleta de comandos) */
.search-modal{position:fixed;inset:0;z-index:300;display:none;justify-content:center;align-items:flex-start;padding:14vh 20px 20px;background:rgba(5,3,6,0.72);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);}
.search-modal.open{display:flex;animation:smFade .2s ease;}
@keyframes smFade{from{opacity:0;}to{opacity:1;}}
.sm-panel{width:100%;max-width:560px;border-radius:18px;overflow:hidden;background:rgba(16,9,14,0.98);border:1px solid rgba(255,255,255,0.12);box-shadow:0 40px 120px -30px rgba(0,0,0,0.8),0 0 60px -28px rgba(255,14,156,0.45);transform:translateY(-6px);animation:smRise .24s var(--ease) forwards;}
@keyframes smRise{to{transform:translateY(0);}}
.sm-input{display:flex;align-items:center;gap:12px;padding:16px 16px;border-bottom:1px solid rgba(255,255,255,0.08);}
.sm-input svg{width:18px;height:18px;color:var(--bimo-magenta);flex:0 0 auto;}
.sm-input input{flex:1;background:none;border:none;outline:none;color:var(--fg1);font-family:var(--font-sans);font-size:16px;letter-spacing:-0.01em;}
.sm-input input::placeholder{color:var(--fg3);}
.sm-esc{font-family:var(--font-mono);font-size:10px;color:var(--fg3);border:1px solid rgba(255,255,255,0.14);border-radius:6px;padding:3px 7px;}
.sm-results{list-style:none;margin:0;padding:8px;max-height:52vh;overflow-y:auto;}
.sm-results li{border-radius:11px;}
.sm-results a{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:11px;color:var(--fg2);text-decoration:none;transition:background .14s,color .14s;}
.sm-results a .sm-ic{width:30px;height:30px;border-radius:8px;flex:0 0 auto;display:grid;place-items:center;color:var(--bimo-magenta);background:rgba(255,14,156,0.1);border:1px solid rgba(255,14,156,0.22);}
.sm-results a .sm-ic svg{width:15px;height:15px;}
.sm-results a b{font-size:14px;font-weight:600;color:var(--fg1);display:block;line-height:1.25;}
.sm-results a span.sm-sub{font-size:12px;color:var(--fg3);}
.sm-results li.sel a,.sm-results a:hover{background:rgba(255,14,156,0.12);color:var(--fg1);}
.sm-empty{padding:22px 16px;text-align:center;color:var(--fg3);font-size:13.5px;}
.nav-toggle{display:none;background:none;border:0;color:var(--fg1);cursor:pointer;padding:6px;}
.nav-toggle svg{width:26px;height:26px;}
@media(max-width:900px){
  .nav-links{display:none;}
  .nav-cta .btn-ghost{display:none;}
  .nav-toggle{display:block;}
  /* buscador colapsa a icono redondo (mantiene logo + buscador + Hablemos visibles) */
  .nav-search{min-width:0;width:38px;padding:0;justify-content:center;}
  .nav-search .ns-ph,.nav-search .ns-kbd{display:none;}
  .nav.open .nav-links{
    display:flex;flex-direction:column;align-items:flex-start;position:absolute;top:100%;left:0;right:0;
    background:rgba(10,6,13,0.97);backdrop-filter:blur(16px);padding:24px 30px;gap:18px;border-bottom:1px solid var(--line);
  }
  /* Desplegable en móvil: se muestra expandido (sin flotante) */
  .nav-dd{width:100%;}
  .nav-dd-menu{position:static;opacity:1;visibility:visible;transform:none;min-width:0;background:none;border:0;box-shadow:none;padding:8px 0 0 14px;gap:12px;-webkit-backdrop-filter:none;backdrop-filter:none;margin-top:6px;border-left:1px solid var(--line);}
  [data-theme="light"] .nav-dd-menu{background:none;}
  .nav-dd-menu::before{display:none;}
  .nav-dd-caret{display:none;}
  .nav-dd-btn{font-size:15px;color:var(--fg1);font-weight:600;}
}

/* ============================================================
   HERO · SearchHero real (glass pill + anillo de glow rotatorio)
   ============================================================ */
.bimo-hero-section{min-height:calc(100vh - 72px);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:96px 24px 64px;}
.bimo-hero-stage{margin:auto 0;}            /* centrado vertical equilibrado */
.bimo-hero-scrollcue{margin-top:auto;}      /* cue anclado abajo, sin hueco gigante */
@media(max-width:640px){
  .bimo-hero-section{min-height:auto;justify-content:flex-start;padding:104px 20px 72px;}
  .bimo-hero-stage{margin:0;}
}
.bimo-hero-stage{position:relative;z-index:1;width:100%;max-width:920px;display:flex;flex-direction:column;align-items:center;gap:28px;text-align:center;}
.bimo-hero-headline{font-size:clamp(32px,4.6vw,60px);font-weight:700;letter-spacing:-0.045em;line-height:1.0;margin:0 auto;max-width:12.5em;color:#fff;text-wrap:balance;}
[data-theme="light"] .bimo-hero-headline{color:var(--bimo-ink);}
/* Titular rotativo del hero: parte fija + final que rota como UNA frase continua.
   La parte que rota es inline (fluye y se equilibra con "Tu negocio,"); el slide
   se hace con position:relative+top para no romper el ajuste de línea. */
/* Crossfade SOLO opacity (compositable en GPU, sin reflow). No usamos transform
   porque el span rota inline y debe poder partir en varias líneas; translate
   exigiría inline-block y rompería el ajuste de línea. */
.hero-rot{will-change:opacity;transition:opacity .3s cubic-bezier(.2,.7,.2,1);}
.hero-rot.is-out{opacity:0;transition-duration:.2s;}  /* desvanecido de salida */
.hero-rot.is-pre{opacity:0;transition:none;}          /* estado de entrada, sin transición */
@media(prefers-reduced-motion:reduce){.hero-rot{transition:none!important;opacity:1!important;}}
.bimo-hero-subline{font-size:16px;line-height:1.5;color:rgba(255,255,255,0.78);max-width:620px;margin:0;text-wrap:pretty;}
[data-theme="light"] .bimo-hero-subline{color:rgba(10,5,9,0.66);}
.bimo-hero-form{width:100%;max-width:720px;display:flex;flex-direction:column;align-items:center;gap:14px;}
.bimo-hero-input{flex:1;min-width:0;background:transparent;border:none;outline:none;color:inherit;font-family:var(--font-sans);font-size:15px;font-weight:400;letter-spacing:-0.005em;padding:22px 0;}
.bimo-hero-input::placeholder{color:rgba(255,255,255,0.55);}
[data-theme="light"] .bimo-hero-input::placeholder{color:rgba(10,5,9,0.5);}
.bimo-hero-send{box-shadow:inset 0 0.5px 0 rgba(255,255,255,0.7),inset 0 -0.5px 0 rgba(74,14,46,0.4),0 2px 10px var(--glow-soft)!important;transition:box-shadow 240ms cubic-bezier(.22,1,.36,1),transform 90ms;}
.bimo-hero-send:hover{box-shadow:inset 0 0.5px 0 rgba(255,255,255,0.8),inset 0 -0.5px 0 rgba(74,14,46,0.4),0 4px 16px var(--glow-strong)!important;}
.bimo-hero-answerbox{width:100%;padding:14px 22px;border-radius:22px;text-align:left;}
.bimo-hero-answerbox .row{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;}
.bimo-hero-answer-txt{font-size:15px;color:rgba(255,255,255,0.92);}
[data-theme="light"] .bimo-hero-answer-txt{color:rgba(10,5,9,0.85);}
.bimo-hero-modechips{display:flex;gap:8px;}
.bimo-hero-microcopy{font-size:12px;color:rgba(255,255,255,0.62);}
[data-theme="light"] .bimo-hero-microcopy{color:rgba(10,5,9,0.58);}
.bimo-hero-hints{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:6px;}
.hero-dots{display:none;}   /* solo visible en móvil (carrusel de chips) */
.bimo-hero-sent{display:flex;flex-direction:column;align-items:center;gap:22px;animation:bimo-fade-in 540ms cubic-bezier(.22,1,.36,1);}
.bimo-hero-sentpill{display:inline-flex;align-items:center;gap:14px;padding:14px 22px 14px 14px;border-radius:var(--radius-btn);}
.bimo-hero-sentpill .bimo-icon-tile{border-radius:var(--radius-btn);}
.bimo-hero-sentpill span{font-size:15px;font-weight:500;color:#fff;}
[data-theme="light"] .bimo-hero-sentpill span{color:var(--bimo-ink);}
.bimo-hero-scrollcue{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;color:rgba(255,255,255,0.62);font-size:10px;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;animation:bimo-bobup 2.4s ease-in-out infinite;z-index:1;}
[data-theme="light"] .bimo-hero-scrollcue{color:rgba(10,5,9,0.58);}
@keyframes bimo-bobup{0%,100%{transform:translateX(-50%) translateY(0);opacity:0.55;}50%{transform:translateX(-50%) translateY(-6px);opacity:1;}}
[hidden]{display:none!important;}

/* CTAs Hablemos / Nuestros servicios — SOLO móvil (ver @media ≤600) */
.hero-cta-mobile{display:none;}
/* botón secundario "fantasma": solo borde blanco + texto blanco, sin relleno */
.hero-cta-ghost{background:transparent!important;border:1px solid rgba(255,255,255,0.75);color:#fff!important;box-shadow:none!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important;}
.hero-cta-ghost::before{display:none!important;}
.hero-cta-ghost:hover{background:rgba(255,255,255,0.08)!important;border-color:#fff;}

/* ============================================================
   LOGO CLOUD
   ============================================================ */
.logos{padding:56px 0 34px;}
.logos .label{display:inline-flex;align-items:center;gap:10px;justify-content:center;width:100%;font-size:11px;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;color:var(--fg3);margin-bottom:30px;font-family:var(--font-mono);}
.logos .label::before{content:"";width:6px;height:6px;border-radius:999px;background:var(--bimo-magenta);box-shadow:0 0 10px var(--bimo-magenta);}
.logo-track-wrap{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);}
.logo-track{display:flex;width:max-content;animation:scrollX 32s linear infinite;}
.logo-track:hover{animation-play-state:paused;}
/* cada grupo se autocontiene: el padding-right hace de espaciado al enlazar con el
   siguiente grupo, así translateX(-50%) cae siempre en un límite limpio (sin huecos). */
.logo-group{display:flex;align-items:center;gap:64px;padding-right:64px;flex:none;}
@keyframes scrollX{to{transform:translateX(-50%);}}
.logo-item{display:flex;align-items:center;justify-content:center;filter:grayscale(1) brightness(1.6);opacity:.6;transition:opacity .3s,filter .3s;}
.logo-item img{height:32px;width:auto;max-width:160px;object-fit:contain;display:block;}
.logo-item:hover{opacity:1;filter:grayscale(0) brightness(1);}

/* ============================================================
   FOMO / MANIFESTO STRIP
   ============================================================ */
.fomo .big{font-family:var(--font-display);font-size:clamp(28px,4.4vw,52px);font-weight:600;line-height:1.12;letter-spacing:-0.03em;max-width:18ch;}
.fomo .big .hl{color:var(--magenta-soft);}
.fomo-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:50px;align-items:center;}
@media(max-width:840px){.fomo-grid{grid-template-columns:1fr;gap:34px;}}
.fomo-stats{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.fstat{border:1px solid var(--line);border-radius:var(--radius);padding:24px;background:var(--bimo-ink-2);position:relative;overflow:hidden;}
.fstat::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:var(--grad);}
.fstat .num{font-family:var(--font-display);font-size:clamp(30px,4vw,42px);font-weight:700;background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent;}
.fstat .lbl{color:var(--fg2);font-size:14px;margin-top:6px;}

/* ============================================================
   SERVICES OVERVIEW (3 tarjetas · componente real .bimo-card)
   ============================================================ */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:54px;}
@media(max-width:920px){.svc-grid{grid-template-columns:1fr;}}
.svc-grid .bimo-card{padding:30px;gap:0;}
.svc-grid .svc-num{font-family:var(--font-mono);font-size:12px;font-weight:600;letter-spacing:0.1em;color:rgba(255,255,255,0.35);margin-bottom:18px;}
[data-theme="light"] .svc-grid .svc-num{color:rgba(10,5,9,0.4);}
.svc-grid h3{font-size:var(--t-h3);margin:18px 0 12px;color:var(--fg1);}
.svc-grid .bimo-card > p{color:var(--fg2);font-size:15px;line-height:1.6;}
.svc-grid .feats{list-style:none;padding:0;margin:20px 0 0;display:grid;gap:10px;}
.svc-grid .feats li{display:flex;gap:10px;align-items:flex-start;font-size:14px;color:var(--fg2);}
.svc-grid .feats svg{width:17px;height:17px;color:var(--bimo-magenta);flex:0 0 17px;margin-top:2px;}
.svc-grid .more{margin-top:22px;}

/* ============================================================
   SERVICES DETAIL (alternating, Suno-style highlights)
   ============================================================ */
.detail-row{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;margin-top:0;}
.detail-row + .detail-row{margin-top:clamp(70px,9vw,120px);}
.detail-row.rev .detail-visual{order:2;}
@media(max-width:880px){.detail-row,.detail-row.rev{grid-template-columns:1fr;gap:34px;}.detail-row.rev .detail-visual{order:0;}}
.detail-text .num{font-family:var(--font-display);font-size:14px;font-weight:600;color:var(--magenta-soft);letter-spacing:0.1em;}
.detail-text h3{font-size:clamp(26px,3.4vw,38px);margin:14px 0 16px;}
.detail-text p{color:var(--fg2);font-size:16px;line-height:1.7;}
.detail-text .points{list-style:none;padding:0;margin:24px 0 0;display:grid;gap:14px;}
.detail-text .points li{display:flex;gap:13px;align-items:flex-start;}
.detail-text .points .chk{width:24px;height:24px;border-radius:8px;background:var(--grad);display:grid;place-items:center;flex:0 0 24px;}
.detail-text .points .chk svg{width:13px;height:13px;color:#fff;}
.detail-text .points b{font-family:var(--font-display);font-weight:600;font-size:15.5px;}
.detail-text .points span{display:block;color:var(--fg3);font-size:13.5px;margin-top:2px;}

.detail-visual{position:relative;}
.visual-card{
  border:1px solid var(--line-2);border-radius:var(--radius-lg);background:linear-gradient(180deg,rgba(20,12,24,0.92),rgba(10,6,13,0.8));
  box-shadow:0 40px 90px -40px rgba(123,60,240,0.45),inset 0 1px 0 rgba(255,255,255,0.05);padding:24px;overflow:hidden;
}
.visual-card .vc-head{display:flex;align-items:center;gap:10px;margin-bottom:18px;color:var(--fg3);font-family:var(--font-display);font-size:13px;letter-spacing:0.04em;}
.visual-card .vc-head .badge{margin-left:auto;font-size:11px;color:var(--cyan);background:rgba(33,230,193,0.1);padding:3px 10px;border-radius:999px;font-weight:600;}

/* mini agent nodes */
.node{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--line);border-radius:13px;background:rgba(255,255,255,0.02);margin-bottom:10px;transition:border-color .3s,transform .3s;}
.node:hover{border-color:var(--magenta);transform:translateX(4px);}
.node .nic{width:32px;height:32px;border-radius:9px;background:rgba(237,61,151,0.14);display:grid;place-items:center;color:var(--magenta-soft);flex:0 0 32px;}
.node .nic svg{width:16px;height:16px;}
.node .ntxt b{font-family:var(--font-display);font-size:14px;display:block;}
.node .ntxt span{font-size:12px;color:var(--fg3);}
.node .nstatus{margin-left:auto;font-size:11px;font-weight:600;color:var(--cyan);display:flex;align-items:center;gap:6px;}
.node .nstatus i{width:7px;height:7px;border-radius:50%;background:var(--cyan);box-shadow:0 0 8px var(--cyan);animation:pulse 1.6s infinite;}

/* audit gauge */
.gauge-wrap{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.gauge{border:1px solid var(--line);border-radius:14px;padding:16px;background:rgba(255,255,255,0.02);}
.gauge .gn{font-family:var(--font-display);font-size:28px;font-weight:700;}
.gauge .gl{font-size:12px;color:var(--fg3);margin-top:3px;}
.gauge.red .gn{color:#ff5a76;}
.gauge.green .gn{color:var(--cyan);}
.bar{height:8px;border-radius:999px;background:rgba(255,255,255,0.07);overflow:hidden;margin-top:12px;}
.bar i{display:block;height:100%;border-radius:999px;background:var(--grad);width:0;transition:width 1.4s cubic-bezier(.2,.7,.2,1);}

/* creative gallery */
.creative-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.creative{aspect-ratio:3/4;border-radius:12px;border:1px solid var(--line);position:relative;overflow:hidden;display:grid;place-items:end;padding:12px;
  background:linear-gradient(160deg,rgba(237,61,151,0.18),rgba(123,60,240,0.14));}
.creative:nth-child(2){background:linear-gradient(160deg,rgba(33,230,193,0.16),rgba(123,60,240,0.16));}
.creative:nth-child(3){background:linear-gradient(160deg,rgba(255,14,156,0.2),rgba(20,12,24,0.4));}
.creative:nth-child(4){background:linear-gradient(160deg,rgba(123,60,240,0.2),rgba(7,4,9,0.4));}
.creative:nth-child(5){background:linear-gradient(160deg,rgba(237,61,151,0.14),rgba(33,230,193,0.12));}
.creative:nth-child(6){background:linear-gradient(160deg,rgba(255,14,156,0.16),rgba(123,60,240,0.2));}
.creative .ctype{font-size:11px;font-weight:600;color:#fff;background:rgba(0,0,0,0.35);padding:3px 9px;border-radius:999px;backdrop-filter:blur(6px);}
.creative .play{position:absolute;top:12px;left:12px;width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,0.16);backdrop-filter:blur(6px);display:grid;place-items:center;}
.creative .play svg{width:13px;height:13px;color:#fff;}

/* ============================================================
   METRICS BAND
   ============================================================ */
.metrics{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:rgba(13,8,16,0.5);}
.metrics-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center;}
@media(max-width:760px){.metrics-grid{grid-template-columns:1fr 1fr;gap:36px 20px;}}
.metric .num{font-family:var(--font-display);font-size:clamp(38px,5.5vw,60px);font-weight:700;line-height:1;background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent;}
.metric .lbl{color:var(--fg2);font-size:14px;margin-top:12px;}

/* ============================================================
   PROCESS
   ============================================================ */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:54px;counter-reset:step;}
@media(max-width:920px){.steps{grid-template-columns:1fr 1fr;}}
@media(max-width:540px){.steps{grid-template-columns:1fr;}}
.step{position:relative;border:1px solid var(--line);border-radius:var(--radius);padding:28px 24px;background:var(--bimo-ink-2);transition:border-color .3s,transform .3s;}
.step:hover{border-color:var(--magenta);transform:translateY(-4px);}
.step .sn{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--bimo-ink);background:var(--grad);width:38px;height:38px;border-radius:11px;display:grid;place-items:center;margin-bottom:18px;color:#fff;}
.step h4{font-size:19px;margin-bottom:10px;}
.step p{color:var(--fg2);font-size:14.5px;line-height:1.6;}

/* ============================================================
   TESTIMONIALS / SOCIAL PROOF
   ============================================================ */
.tgrid{columns:3;column-gap:18px;margin-top:54px;}
@media(max-width:920px){.tgrid{columns:2;}}
@media(max-width:600px){.tgrid{columns:1;}}
.tcard{break-inside:avoid;margin-bottom:18px;border-radius:24px;padding:26px;
  background:rgba(255,255,255,0.06);backdrop-filter:blur(20px) saturate(140%);-webkit-backdrop-filter:blur(20px) saturate(140%);
  border:1px solid rgba(255,255,255,0.12);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.18),inset 0 -1px 0 rgba(255,14,156,0.25),0 16px 48px rgba(0,0,0,0.35);
  transition:transform .35s var(--ease),box-shadow .35s;}
.tcard:hover{transform:translateY(-3px);box-shadow:inset 0 1px 0 rgba(255,255,255,0.18),inset 0 -1px 0 rgba(255,14,156,0.35),0 22px 60px -20px rgba(255,14,156,0.3);}
[data-theme="light"] .tcard{background:rgba(255,255,255,0.7);border-color:rgba(255,255,255,0.9);box-shadow:inset 0 1px 0 rgba(255,255,255,0.95),inset 0 -1px 0 rgba(237,61,151,0.18),0 16px 48px rgba(237,61,151,0.1);}
.tcard .stars{color:var(--bimo-magenta);font-size:14px;letter-spacing:2px;margin-bottom:12px;}
.tcard p{font-size:15px;color:var(--fg1);line-height:1.6;}
.tcard .who{display:flex;align-items:center;gap:12px;margin-top:18px;}
.tcard .av{width:42px;height:42px;border-radius:28%;background:linear-gradient(180deg,#FF4FAE 0%,#ED3D97 55%,#C92A7E 100%);display:grid;place-items:center;font-family:var(--font-sans);font-weight:700;font-size:14px;color:#0A0509;flex:0 0 42px;box-shadow:inset 0 0.5px 0 rgba(255,255,255,0.7),0 6px 18px rgba(255,14,156,0.35);}
.tcard .who b{font-size:14.5px;font-family:var(--font-sans);font-weight:600;}
.tcard .who span{display:block;font-size:12px;color:var(--fg3);font-family:var(--font-mono);margin-top:2px;}

/* ============================================================
   MAGIC MOMENT (big statement / before-after)
   ============================================================ */
.magic{text-align:center;}
.magic-card{
  border:1px solid var(--line-2);border-radius:var(--radius-lg);padding:clamp(40px,6vw,72px);
  background:radial-gradient(120% 140% at 50% 0%,rgba(237,61,151,0.16),rgba(13,8,16,0.5) 60%);
  position:relative;overflow:hidden;
}
.magic-card h2{font-size:clamp(28px,4.6vw,52px);max-width:18ch;margin:0 auto;}
.ba{display:grid;grid-template-columns:1fr auto 1fr;gap:24px;align-items:center;margin-top:46px;text-align:left;}
@media(max-width:760px){.ba{grid-template-columns:1fr;}.ba .arrow{transform:rotate(90deg);justify-self:center;}}
.ba-col{border:1px solid var(--line);border-radius:var(--radius);padding:26px;background:rgba(10,6,13,0.5);}
.ba-col.after{border-color:rgba(237,61,151,0.5);box-shadow:0 0 0 1px rgba(237,61,151,0.2),0 30px 60px -30px rgba(237,61,151,0.5);}
.ba-col .tag{font-family:var(--font-display);font-size:12px;letter-spacing:0.14em;text-transform:uppercase;margin-bottom:16px;}
.ba-col.before .tag{color:var(--fg3);}
.ba-col.after .tag{color:var(--magenta-soft);}
.ba-col ul{list-style:none;padding:0;margin:0;display:grid;gap:13px;}
.ba-col li{display:flex;gap:11px;align-items:flex-start;font-size:14.5px;color:var(--fg2);}
.ba-col li svg{width:17px;height:17px;flex:0 0 17px;margin-top:2px;}
.ba-col.before li svg{color:#ff5a76;}
.ba-col.after li svg{color:var(--cyan);}
.ba .arrow{width:46px;height:46px;border-radius:50%;background:var(--grad);display:grid;place-items:center;color:#fff;}
.ba .arrow svg{width:22px;height:22px;}

/* ============================================================
   PRICING / COLLABORATION MODELS
   ============================================================ */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:54px;align-items:stretch;}
@media(max-width:920px){.plans{grid-template-columns:1fr;max-width:460px;margin-left:auto;margin-right:auto;}}
.plan{position:relative;border:1px solid var(--line);border-radius:var(--radius-lg);padding:34px 30px;background:var(--bimo-ink-2);display:flex;flex-direction:column;transition:transform .3s,border-color .3s;}
.plan:hover{transform:translateY(-5px);border-color:var(--line-2);}
.plan.featured{border-color:transparent;background:linear-gradient(180deg,var(--bimo-ink-3),var(--bimo-ink-2));}
.plan.featured::after{content:"";position:absolute;inset:0;border-radius:inherit;padding:1.5px;background:var(--grad);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;}
.plan .ribbon{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--grad);color:#fff;font-size:12px;font-weight:600;padding:5px 16px;border-radius:999px;font-family:var(--font-display);white-space:nowrap;box-shadow:0 8px 22px -8px rgba(255,14,156,0.8);}
.plan h3{font-size:21px;}
.plan .pdesc{color:var(--fg3);font-size:13.5px;margin-top:8px;min-height:38px;}
.plan .price{font-family:var(--font-display);font-size:clamp(30px,4vw,40px);font-weight:700;margin:20px 0 4px;}
.plan .price small{font-size:15px;color:var(--fg3);font-weight:500;}
.plan .pnote{font-size:12.5px;color:var(--fg3);margin-bottom:22px;}
.plan ul{list-style:none;padding:0;margin:0 0 26px;display:grid;gap:12px;flex:1;}
.plan ul li{display:flex;gap:11px;align-items:flex-start;font-size:14px;color:var(--fg2);}
.plan ul li svg{width:17px;height:17px;color:var(--magenta);flex:0 0 17px;margin-top:2px;}
.plan .btn{width:100%;}

/* ============================================================
   FAQ
   ============================================================ */
.faq-list{max-width:820px;margin:46px auto 0;display:grid;gap:12px;}
.faq{position:relative;border:1px solid var(--line);border-radius:var(--radius);background:var(--bimo-ink-2);overflow:hidden;transition:border-color .3s;}
@property --faq-ang{syntax:'<angle>';inherits:false;initial-value:0deg;}
.faq::after{content:'';position:absolute;inset:0;border-radius:inherit;padding:1px;pointer-events:none;opacity:0;background:conic-gradient(from var(--faq-ang),transparent 0deg,transparent 296deg,rgba(255,255,255,0.4) 322deg,rgba(255,255,255,0.95) 336deg,rgba(255,255,255,0.4) 350deg,transparent 360deg);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;}
@media(prefers-reduced-motion:no-preference){
  .faq[open]::after{animation:faq-halo-spin 1.6s linear,faq-halo-fade 1.6s ease-in-out;}
  @keyframes faq-halo-spin{0%{--faq-ang:0deg;}100%{--faq-ang:360deg;}}
  @keyframes faq-halo-fade{0%{opacity:0;}12%{opacity:1;}88%{opacity:1;}100%{opacity:0;}}
}
.faq[open]{border-color:var(--line-2);}
.faq summary{list-style:none;cursor:pointer;padding:22px 24px;display:flex;align-items:center;justify-content:space-between;gap:18px;font-family:var(--font-display);font-size:17px;font-weight:500;}
.faq summary::-webkit-details-marker{display:none;}
.faq summary .pm{width:22px;height:22px;flex:0 0 22px;display:grid;place-items:center;opacity:0.55;transition:transform .5s cubic-bezier(.4,0,.2,1),opacity .25s;}
.faq[open] summary .pm{transform:rotate(360deg);}
.faq summary .pm img{width:100%;height:100%;display:block;}
@media(prefers-reduced-motion:no-preference){
  .faq[open] summary .pm{animation:faq-icon-glow 1.6s ease-in-out;}
  @keyframes faq-icon-glow{
    0%{opacity:0.55;filter:drop-shadow(0 0 0 rgba(255,255,255,0));}
    35%{opacity:1;filter:drop-shadow(0 0 7px rgba(255,255,255,0.85));}
    60%{opacity:1;filter:drop-shadow(0 0 7px rgba(255,255,255,0.85));}
    100%{opacity:0.55;filter:drop-shadow(0 0 0 rgba(255,255,255,0));}
  }
}
.faq .ans{padding:0 24px 24px;color:var(--fg2);font-size:15px;line-height:1.7;}

/* ============================================================
   FINAL CTA / CONTACT
   ============================================================ */
.cta-final{position:relative;}
.cta-box{
  position:relative;border:1px solid rgba(255,14,156,0.22);border-radius:var(--radius-lg);overflow:hidden;
  padding:clamp(32px,5vw,60px);
  background:radial-gradient(120% 150% at 16% -10%,rgba(237,61,151,0.16),rgba(7,4,9,0.5) 55%);
}
.cta-box::before{content:"";position:absolute;z-index:0;inset:-30% 32% 35% -12%;pointer-events:none;background:radial-gradient(circle at 32% 42%, var(--glow-strong), transparent 60%);filter:blur(72px);opacity:0.5;}
.cta-grid{position:relative;z-index:1;display:grid;grid-template-columns:1fr;gap:clamp(30px,4vw,56px);align-items:center;}
@media(max-width:880px){.cta-grid{grid-template-columns:1fr;gap:34px;}}
.cta-badge{display:inline-flex;align-items:center;gap:8px;font-size:12.5px;font-weight:600;color:var(--fg1);background:rgba(255,14,156,0.1);border:1px solid rgba(255,14,156,0.28);padding:6px 12px;border-radius:var(--radius-btn);margin-bottom:18px;}
.cta-badge .dot{width:7px;height:7px;border-radius:50%;background:var(--bimo-magenta);box-shadow:0 0 8px var(--glow-strong);}
.cta-box h2{font-size:clamp(28px,4.2vw,50px);letter-spacing:-0.03em;line-height:1.05;margin:0;max-width:15ch;}
.cta-sub{color:var(--fg2);font-size:17px;margin:18px 0 0;max-width:44ch;line-height:1.5;}
.cta-trust{display:flex;align-items:center;gap:12px;margin:26px 0 30px;}
.cta-avs{display:flex;}
.cta-avs img{width:34px;height:34px;border-radius:50%;object-fit:cover;object-position:center 22%;border:2px solid var(--bimo-ink);background:#1a1014;}
.cta-avs img:nth-child(2){margin-left:-11px;}
.cta-trust .t{font-size:13.5px;color:var(--fg2);}
.cta-actions{display:flex;gap:12px;flex-wrap:wrap;}
.cta-agenda{border-radius:18px;background:rgba(255,255,255,0.045);border:1px solid rgba(255,255,255,0.11);padding:20px;box-shadow:0 26px 64px -32px rgba(0,0,0,0.75);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);}
[data-theme="light"] .cta-agenda{background:rgba(255,255,255,0.75);border-color:rgba(10,5,9,0.08);}
.cta-steps-h{font-size:16px;font-weight:700;color:var(--fg1);margin-bottom:18px;}
.cta-steps{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:15px;}
.cta-steps li{display:flex;gap:13px;align-items:flex-start;}
.cta-steps .n{flex:0 0 auto;width:26px;height:26px;border-radius:8px;display:grid;place-items:center;font-size:13px;font-weight:700;color:#0A0509;background:linear-gradient(180deg,#FF4FAE,#ED3D97);box-shadow:0 4px 12px -6px var(--glow-strong);}
.cta-steps li .tx{font-size:14px;color:var(--fg2);line-height:1.45;padding-top:3px;}
.cta-steps-div{height:1px;background:rgba(255,255,255,0.1);margin:20px 0 14px;}
[data-theme="light"] .cta-steps-div{background:rgba(10,5,9,0.1);}
.cta-steps-foot{text-align:center;font-size:12px;color:var(--fg3);}

/* ============================================================
   FOOTER
   ============================================================ */
footer{border-top:1px solid var(--line);padding:64px 0 40px;}
.foot-grid{display:grid;grid-template-columns:1.4fr 1.5fr 1fr 1fr;gap:40px;}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr 1fr;gap:34px;}}
.foot-brand .brand{margin-bottom:16px;}
.foot-brand p{color:var(--fg3);font-size:14px;max-width:30ch;}
.foot-col h5{font-family:var(--font-display);font-size:13px;letter-spacing:0.1em;text-transform:uppercase;color:var(--fg3);margin:0 0 16px;line-height:1.35;}
/* encabezado largo (marketing + IA): cabe limpio en dos líneas, mismo estilo */
.foot-col h5.svc-head{font-size:12px;letter-spacing:0.08em;}
.foot-col a{display:block;color:var(--fg2);font-size:14.5px;margin-bottom:11px;transition:color .2s;}
.foot-col a:hover{color:var(--magenta-soft);}
.foot-bottom{margin-top:50px;padding-top:26px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;color:var(--fg3);font-size:13px;}
/* fila legal: discreta, en línea con el copyright */
.foot-legal{margin-top:14px;display:flex;gap:18px;flex-wrap:wrap;}
.foot-legal a{color:var(--fg3);font-size:12px;text-decoration:none;transition:color .2s;}
.foot-legal a:hover{color:var(--magenta-soft);}

/* ============================================================
   WHATSAPP FLOAT
   ============================================================ */
.wa-float{position:fixed;bottom:24px;right:24px;z-index:90;width:58px;height:58px;border-radius:50%;background:#25D366;display:grid;place-items:center;box-shadow:0 14px 34px -8px rgba(37,211,102,0.7);transition:transform .25s;animation:waPop .6s 1s both;}
.wa-float:hover{transform:scale(1.08);}
.wa-float svg{width:30px;height:30px;color:#fff;}
@keyframes waPop{from{transform:scale(0);}to{transform:scale(1);}}
/* Botón flotante con personalidad (→ Cal.com) */
.waf{position:fixed;bottom:24px;right:24px;z-index:95;display:block;-webkit-tap-highlight-color:transparent;}
.waf-scale{display:block;transition:transform .3s cubic-bezier(.34,1.56,.64,1);}
.waf-circle{position:relative;width:60px;height:60px;border-radius:50%;background:linear-gradient(145deg,#2EE06F,#16A34A);display:grid;place-items:center;box-shadow:0 14px 34px -8px rgba(34,197,94,0.6),inset 0 1px 0 rgba(255,255,255,0.35);transition:box-shadow .3s;will-change:transform;}
.waf-circle svg{width:28px;height:28px;color:#fff;}
.waf-hand{position:absolute;top:-9px;left:-7px;font-size:22px;line-height:1;opacity:0;transform-origin:bottom right;pointer-events:none;}
.waf-bubble{position:absolute;right:72px;bottom:15px;white-space:nowrap;background:#fff;color:#0c0c0d;font-family:var(--font-sans);font-size:13.5px;font-weight:600;letter-spacing:-0.01em;padding:9px 14px;border-radius:14px;box-shadow:0 12px 32px -10px rgba(0,0,0,0.55);opacity:0;transform:translateX(10px) scale(.9);transform-origin:right center;transition:opacity .3s ease-out,transform .35s cubic-bezier(.34,1.56,.64,1);pointer-events:none;}
.waf-bubble::after{content:"";position:absolute;right:-6px;top:50%;transform:translateY(-50%);border:6px solid transparent;border-left-color:#fff;border-right:0;}
.waf-bubble.show{opacity:1;transform:translateX(0) scale(1);}
.waf-emoji{position:absolute;bottom:48px;right:22px;font-size:18px;line-height:1;pointer-events:none;opacity:0;will-change:transform,opacity;}
.waf:hover .waf-scale{transform:scale(1.1);}
.waf:hover .waf-circle{box-shadow:0 18px 46px -8px rgba(34,197,94,0.9),inset 0 1px 0 rgba(255,255,255,0.45);}
.waf:active .waf-scale{transform:scale(.86);transition:transform .1s ease-out;}
@media(max-width:560px){.waf{bottom:18px;right:16px;}.waf-circle{width:54px;height:54px;}.waf-circle svg{width:26px;height:26px;}}
@media (prefers-reduced-motion: no-preference){
  .waf-circle{animation:wafIdle 6s ease-in-out infinite;}
  .waf:hover .waf-circle,.waf:active .waf-circle{animation-play-state:paused;}
  .waf-hand{animation:wafHand 8s ease-in-out infinite;}
  @keyframes wafIdle{0%{transform:scale(1) rotate(0)}6%{transform:scale(1.045) rotate(0)}14%{transform:scale(1) rotate(0)}80%{transform:scale(1) rotate(0)}83%{transform:scale(1.03) rotate(-8deg)}87%{transform:scale(1.03) rotate(8deg)}90%{transform:scale(1.03) rotate(-6deg)}93%{transform:scale(1.02) rotate(5deg)}96%{transform:scale(1) rotate(0)}100%{transform:scale(1) rotate(0)}}
  @keyframes wafHand{0%{opacity:0;transform:translate(2px,4px) scale(.4) rotate(0)}84%{opacity:0;transform:translate(2px,4px) scale(.4) rotate(0)}86%{opacity:1;transform:translate(0,0) scale(1) rotate(-20deg)}89%{opacity:1;transform:translate(0,0) scale(1) rotate(10deg)}92%{opacity:1;transform:translate(0,0) scale(1) rotate(-14deg)}95%{opacity:1;transform:translate(0,0) scale(1) rotate(6deg)}98%{opacity:0;transform:translate(1px,2px) scale(.6) rotate(0)}100%{opacity:0;transform:translate(2px,4px) scale(.4) rotate(0)}}
  @keyframes wafRise{0%{opacity:0;transform:translateY(0) translateX(0) scale(.5) rotate(0)}15%{opacity:1}100%{opacity:0;transform:translateY(-72px) translateX(var(--dx,0)) scale(1) rotate(var(--rot,0))}}
}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity 360ms ease-out,transform 360ms ease-out;}
[data-reveal].in{opacity:1;transform:none;}
[data-reveal][data-delay="1"]{transition-delay:.08s;}
[data-reveal][data-delay="2"]{transition-delay:.16s;}
[data-reveal][data-delay="3"]{transition-delay:.24s;}
[data-reveal][data-delay="4"]{transition-delay:.32s;}
/* Variantes de entrada (varían por sección): lateral / zoom. Sobre los reveals existentes. */
[data-rv="left"]{transform:translateX(-44px);}
[data-rv="right"]{transform:translateX(44px);}
[data-rv="zoom"]{transform:scale(.93);}
[data-bimo-reveal].is-in[data-rv],[data-reveal].in[data-rv]{transform:none;}
/* Sin animación de entrada si el usuario pide menos movimiento */
@media(prefers-reduced-motion:reduce){
  [data-reveal],[data-bimo-reveal],[data-rv]{opacity:1!important;transform:none!important;transition:none!important;}
  .bimo-fade-in{animation:none!important;}
}
@media(prefers-reduced-motion:reduce){
  [data-rv]{transform:none!important;}
  [data-reveal]{opacity:1;transform:none;transition:none;}
  [data-bimo-reveal]{opacity:1;transform:none;filter:none;transition:none;}
  .logo-track,.bimo-pill-wrap,.bimo-pill-wrap::before,.bimo-pill-wrap::after,
  .bimo-bg-ambient::before,.bimo-bg-ambient::after,.bimo-ambient-field .blob,
  .bimo-pulse-dot,.bimo-icon-tile,.bimo-card-ring,.bimo-btn-ring,.bimo-hero-scrollcue,
  .bimo-toast-ring,.bimo-toast-ring::after,.bimo-toast-icon{animation:none!important;}
  html{scroll-behavior:auto;}
}

/* ============================================================
   UNIFICACIÓN CON EL DS REAL (secciones intermedias)
   Lleva las superficies de tarjeta al glass + bisel + glow del
   sistema original, sin reescribir el markup ni tocar textos.
   ============================================================ */
.fstat,.step,.plan,.faq,.visual-card,.ba-col,.gauge,.node{
  background:rgba(255,255,255,0.05)!important;
  border:1px solid rgba(255,255,255,0.10)!important;
  -webkit-backdrop-filter:blur(20px) saturate(120%);backdrop-filter:blur(20px) saturate(120%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.14),inset 0 -1px 0 rgba(255,14,156,0.22),0 16px 48px rgba(0,0,0,0.32)!important;
}
[data-theme="light"] .fstat,[data-theme="light"] .step,[data-theme="light"] .plan,
[data-theme="light"] .faq,[data-theme="light"] .visual-card,[data-theme="light"] .ba-col,
[data-theme="light"] .gauge,[data-theme="light"] .node{
  background:rgba(255,255,255,0.7)!important;border-color:rgba(255,255,255,0.9)!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.95),inset 0 -1px 0 rgba(237,61,151,0.18),0 16px 48px rgba(237,61,151,0.1)!important;
}
[data-theme="light"] .faq summary .pm img{filter:invert(1);}
.fstat,.plan,.faq{border-radius:24px!important;}
.step,.visual-card,.ba-col{border-radius:20px!important;}
.gauge,.node{border-radius:14px!important;}
/* hovers coherentes con el DS (elevación + glow magenta) */
.step:hover,.plan:hover,.fstat:hover{transform:translateY(-3px);box-shadow:inset 0 1px 0 rgba(255,255,255,0.16),inset 0 -1px 0 rgba(255,14,156,0.30),0 22px 60px -20px rgba(255,14,156,0.30)!important;}
.step:hover{border-color:rgba(255,14,156,0.35)!important;}
/* badge de paso → squircle biselado tipo icon-tile */
.step .sn{border-radius:28%!important;background:linear-gradient(180deg,#FF4FAE 0%,#ED3D97 55%,#C92A7E 100%)!important;color:#0A0509!important;box-shadow:inset 0 0.5px 0 rgba(255,255,255,0.7),inset 0 -0.5px 0 rgba(74,14,46,0.45),0 6px 18px rgba(255,14,156,0.45)!important;}
/* iconos de servicio-detalle dentro de su tarjeta */
.svc-ic{background:rgba(255,14,156,0.12)!important;}
/* botones de planes / CTAs heredan el bisel magenta del DS */
.btn-primary{background:linear-gradient(180deg,#FF4FAE 0%,#ED3D97 55%,#C92A7E 100%)!important;color:#0A0509!important;box-shadow:inset 0 0.5px 0 rgba(255,255,255,0.7),inset 0 -0.5px 0 rgba(74,14,46,0.4),0 3px 14px var(--glow-soft)!important;}
.btn-primary:hover{background:linear-gradient(180deg,#FF67BC 0%,#F04CA0 55%,#C92A7E 100%)!important;}
.btn-ghost{background:rgba(255,255,255,0.06)!important;border:1px solid rgba(255,255,255,0.12)!important;color:var(--fg1)!important;}
/* eyebrows antiguos → look mono del DS (punto magenta) */
.eyebrow .dot{box-shadow:0 0 10px var(--bimo-magenta);}

/* ====== Cursor personalizado (solo desktop con ratón fino) ====== */
@media (hover:hover) and (pointer:fine){
  html.cursorize, html.cursorize *{cursor:none;}
  /* los campos de escritura mantienen su caret nativo */
  html.cursorize input:not([type="button"]):not([type="submit"]):not([type="checkbox"]):not([type="radio"]),
  html.cursorize textarea,
  html.cursorize [contenteditable]{cursor:text;}
  /* Flecha tipo macOS, futurista con los colores de marca */
  .cursor-arrow{position:fixed;top:0;left:0;z-index:10000;pointer-events:none;width:24px;height:24px;opacity:0;
    filter:drop-shadow(0 1px 1px rgba(0,0,0,0.45)) drop-shadow(0 0 4px rgba(255,14,156,0.35));
    transition:opacity .25s ease,filter .25s ease;}
  .cursor-arrow svg{display:block;width:100%;height:100%;transform-origin:1px 1px;transition:transform .18s var(--ease);}
  .cursor-arrow .a-fill{fill:#ffffff;transition:fill .2s ease;}
  .cursor-arrow .a-edge{fill:none;stroke:var(--bimo-magenta);stroke-width:1.4;stroke-linejoin:round;transition:stroke .2s ease,stroke-width .2s ease;}
  .cursor-arrow.is-hover{filter:drop-shadow(0 1px 1.5px rgba(0,0,0,0.5));}
  .cursor-arrow.is-hover svg{transform:scale(1.32) rotate(-6deg);}
  .cursor-arrow.is-hover .a-fill{fill:var(--bimo-magenta);}
  /* borde blanco en hover: visible también sobre elementos rosas/magenta */
  .cursor-arrow.is-hover .a-edge{stroke:#fff;stroke-width:2.2;}
  .cursor-arrow.is-down svg{transform:scale(.82);}
  .cursor-arrow.is-hover.is-down svg{transform:scale(1.12) rotate(-6deg);}
  /* halo del cursor desactivado: puntero sin glow */
  .cursor-glow{display:none!important;}
  .cursor-hidden{opacity:0!important;}

  /* ====== Hover refinado (solo donde hay ratón → no se queda pegado en táctil) ====== */
  /* Botones pill: leve elevación + glow magenta suave */
  .bimo-btn{transition:background 220ms var(--ease),transform .26s var(--ease),box-shadow .26s var(--ease);}
  .bimo-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px -12px var(--glow-soft);}
  .bimo-btn.is-primary:hover{transform:translateY(-2px);box-shadow:0 10px 30px -12px var(--glow-strong);}
  .bimo-btn:active{transform:translateY(0);}
  /* Tarjetas (flota de agentes, equipo, why): leve elevación + borde magenta */
  .afa,.tm,.why-card{transition:opacity .55s var(--ease),transform .5s var(--ease),border-color .3s ease,box-shadow .3s ease;}
  .afa:hover,.tm:hover,.why-card:hover{transform:translateY(-4px);border-color:rgba(255,14,156,0.45);box-shadow:0 24px 60px -24px rgba(255,14,156,0.45);}
  /* Pills de LinkedIn del equipo */
  .tm-social{transition:border-color .25s ease,background .25s ease,transform .25s var(--ease);}
  .tm-social:hover{transform:translateY(-1px);}
  /* Enlaces del navbar: el subrayado ya anima; suavizamos también el color */
  .nav-links a,.nav-dd-btn{transition:color .25s ease;}
}
/* Reduced-motion: hovers sin desplazamiento (solo color/borde) */
@media (hover:hover) and (prefers-reduced-motion:reduce){
  .bimo-btn:hover,.bimo-btn.is-primary:hover,.afa:hover,.tm:hover,.why-card:hover,.tm-social:hover{transform:none!important;}
}

/* ===== Formulario de captación: consentimiento, Turnstile, error, envío ===== */
.bimo-turnstile{margin-top:14px;}
.bimo-turnstile:empty{display:none;}
.bimo-consent{display:flex;align-items:flex-start;gap:10px;margin-top:14px;font-size:13px;line-height:1.45;color:var(--fg2);text-align:left;cursor:pointer;}
.bimo-consent input{appearance:none;-webkit-appearance:none;width:18px;height:18px;flex:0 0 auto;margin-top:1px;border:1px solid rgba(255,255,255,0.28);border-radius:6px;background:rgba(255,255,255,0.04);display:grid;place-items:center;cursor:pointer;transition:border-color .2s,background .2s;}
.bimo-consent input:checked{background:var(--bimo-magenta);border-color:var(--bimo-magenta);}
.bimo-consent input:checked::after{content:"";width:5px;height:9px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg) translateY(-1px);}
.bimo-consent a{color:var(--magenta-soft);text-decoration:underline;}
.bimo-consent .req{opacity:.6;}
[data-theme="light"] .bimo-consent input{border-color:rgba(10,5,9,0.25);background:rgba(10,5,9,0.03);}
.bimo-form-error{margin-top:12px;font-size:13px;font-weight:500;color:#FF6B6B;background:rgba(255,77,79,0.10);border:1px solid rgba(255,77,79,0.35);border-radius:var(--radius-btn);padding:9px 13px;text-align:left;}
.bimo-hero-send.is-loading{opacity:.7;pointer-events:none;}
.bimo-hero-send.is-loading svg{animation:bimoSpin .7s linear infinite;}
@keyframes bimoSpin{to{transform:rotate(360deg);}}
@media (prefers-reduced-motion:reduce){.bimo-hero-send.is-loading svg,.cta-form-send.is-loading svg{animation:none;}}

/* ===== Formulario de contacto del CTA final ===== */
.cta-formwrap{margin-top:26px;padding-top:24px;border-top:1px solid rgba(255,255,255,0.1);}
[data-theme="light"] .cta-formwrap{border-top-color:rgba(10,5,9,0.1);}
.cta-or{display:flex;align-items:center;gap:14px;color:var(--fg3);font-size:12px;font-family:var(--font-sans);letter-spacing:0.04em;text-transform:uppercase;margin-bottom:18px;}
.cta-or::before,.cta-or::after{content:"";flex:1;height:1px;background:rgba(255,255,255,0.1);}
[data-theme="light"] .cta-or::before,[data-theme="light"] .cta-or::after{background:rgba(10,5,9,0.1);}
.cta-form{display:flex;flex-direction:column;gap:12px;}
.cta-form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
@media(max-width:620px){.cta-form-row{grid-template-columns:1fr;}}
.cta-form input:not([type="checkbox"]),.cta-form textarea{width:100%;font-family:var(--font-sans);font-size:15px;color:var(--fg1);background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.12);border-radius:var(--radius-btn);padding:13px 16px;transition:border-color .2s,box-shadow .2s;}
.cta-form textarea{resize:vertical;min-height:84px;line-height:1.5;}
.cta-form input:not([type="checkbox"])::placeholder,.cta-form textarea::placeholder{color:var(--fg3);}
.cta-form input:not([type="checkbox"]):focus,.cta-form textarea:focus{outline:none;border-color:var(--bimo-magenta);box-shadow:0 0 0 3px rgba(255,14,156,0.18);}
[data-theme="light"] .cta-form input:not([type="checkbox"]),[data-theme="light"] .cta-form textarea{background:rgba(10,5,9,0.03);border-color:rgba(10,5,9,0.12);}
/* la fila de consentimiento ocupa todo el ancho del formulario */
.cta-form .bimo-consent{width:100%;}

/* Selector de prefijo de país en los campos de teléfono */
.tel-prefix-wrap{position:relative;display:inline-flex;align-items:center;flex:0 0 auto;margin-right:6px;}
.tel-prefix{flex:1;font-family:var(--font-sans);font-size:15px;font-weight:500;color:inherit;cursor:pointer;border:none;outline:none;background:transparent;-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:0 16px 0 0;}
.tel-prefix option{color:#111;background:#fff;}
.tel-prefix-arrow{position:absolute;right:0;top:50%;transform:translateY(-50%);width:10px;height:6px;pointer-events:none;}
/* variante "caja" para el formulario CTA final */
.cta-tel{display:flex;gap:10px;align-items:stretch;}
.cta-tel input{flex:1;min-width:0;}
.cta-tel .tel-prefix-wrap{background-color:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.12);border-radius:var(--radius-btn);color:var(--fg1);padding:0 28px 0 14px;margin-right:0;}
.cta-tel .tel-prefix-arrow{right:12px;}
.cta-tel .tel-prefix-wrap:focus-within{border-color:var(--bimo-magenta);box-shadow:0 0 0 3px rgba(255,14,156,0.18);}
[data-theme="light"] .cta-tel .tel-prefix-wrap{background-color:rgba(10,5,9,0.03);border-color:rgba(10,5,9,0.12);}
[data-theme="light"] .cta-tel .tel-prefix{background-color:rgba(10,5,9,0.03);border-color:rgba(10,5,9,0.12);}
.cta-form-send{align-self:flex-start;margin-top:4px;}
.cta-form-send.is-loading{opacity:.7;pointer-events:none;}
.cta-form-send.is-loading svg{animation:bimoSpin .7s linear infinite;}
.cta-success{display:flex;align-items:center;gap:14px;margin-top:6px;padding:18px 20px;border-radius:var(--radius-btn);background:rgba(255,14,156,0.08);border:1px solid rgba(255,14,156,0.3);}
.cta-success-tile{width:40px;height:40px;border-radius:11px;flex:0 0 auto;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,#FF4FAE,var(--bimo-magenta-deep));}
.cta-success-tile svg{width:20px;height:20px;}
.cta-success b{display:block;color:var(--fg1);font-size:15px;}
.cta-success span{color:var(--fg2);font-size:13.5px;}

/* ============================================================
   RESPONSIVE MÓVIL (base / sm) — solo breakpoints pequeños.
   No afecta a tablet/desktop (≥ 760px queda igual que ahora).
   ============================================================ */
/* Nunca scroll horizontal, pase lo que pase con glows/marquees */
html,body{overflow-x:hidden;}
*{min-width:0;}

@media(max-width:600px){
  /* Padding horizontal consistente en todos los contenedores */
  .wrap{padding-left:20px;padding-right:20px;}
  /* Ritmo vertical compacto (antes ~72px arriba+abajo) */
  section{padding:38px 0;}

  /* Eyebrows de sección: legibles, sin cortarse ni pegarse al borde */
  .eyebrow,.bimo-eyebrow,.sg-eyebrow,.sec-eyebrow,.pt-eyebrow,.pt-cta-eyebrow{
    letter-spacing:0.12em;font-size:10px;max-width:100%;line-height:1.4;
  }
  /* Titulares y cuerpo de sección */
  .h-sec{font-size:clamp(26px,8vw,34px);line-height:1.1;margin-top:12px;}
  .lead{font-size:16px;line-height:1.6;margin-top:14px;}

  /* ---- HERO ---- */
  /* contain:paint = recorte estricto incluso de capas promovidas a GPU; evita que
     el glow animado se salga por los lados y descubra el fondo negro (BUG fondo). */
  .bimo-hero-section{padding-top:100px;padding-bottom:40px;contain:paint;}
  /* el glow del hero se difumina hacia abajo para que no quede un corte/línea
     con la sección siguiente (antes se clipaba de golpe por overflow:hidden) */
  .bimo-hero-section.bimo-bg-ambient::before,
  .bimo-hero-section.bimo-bg-ambient::after{
    -webkit-mask-image:linear-gradient(to bottom,#000 50%,transparent 86%);
    mask-image:linear-gradient(to bottom,#000 50%,transparent 86%);
  }
  /* La capa ::after es la que se TRASLADA (bimo-orbit) y lleva blur: en móvil la
     congelamos. Así no puede asomar por el lateral ni repinta el blur cada frame
     (rendimiento). La capa ::before (solo escala+opacity, sin blur) sigue viva. */
  .bimo-hero-section.bimo-bg-ambient::after{animation:none;transform:none;}
  /* ritmo compacto: h1 → subtítulo → buscador → chips como un bloque */
  .bimo-hero-stage{gap:11px;}
  /* eyebrow más pequeño (línea de arriba del titular) */
  .bimo-hero-section .bimo-eyebrow{display:block;font-size:8.5px;letter-spacing:0.08em;line-height:1.4;margin-bottom:2px!important;}
  /* h1 (titular rotativo): ocupa un poco más de ancho (menos líneas). SIN
     min-height:0 — así la altura reservada por JS (reserve(), dimensionada a la
     frase más larga) también aplica en móvil y el layout de abajo NO salta.
     display:flex + justify-content:flex-end ANCLA el texto ABAJO de esa altura
     reservada: el sobrante de las frases cortas queda ARRIBA, de modo que el
     espacio entre el titular y el subtítulo es SIEMPRE el mismo. */
  .bimo-hero-headline{font-size:clamp(31px,9.4vw,44px);line-height:1.06;max-width:13.5ch;
    display:flex;flex-direction:column;justify-content:flex-end;align-items:center;}
  /* subtítulo claramente subordinado al h1: más pequeño, más tenue, ancho corto */
  .bimo-hero-subline{font-size:10.5px;line-height:1.5;color:rgba(255,255,255,0.5);max-width:none;margin-top:0;}
  [data-theme="light"] .bimo-hero-subline{color:rgba(10,5,9,0.5);}
  /* buscador compacto y placeholder que cabe mejor */
  .bimo-pill{min-height:52px;padding:0 16px;}
  .bimo-hero-input{font-size:13.5px;padding:16px 0;}
  .bimo-hero-form{gap:12px;}
  /* chips en CARRUSEL horizontal: una fila, scroll táctil con momentum, sin barra.
     Full-bleed (margen negativo = padding del hero) para que el último chip se
     corte en el borde y se intuya que hay más. */
  .bimo-hero-hints{flex-wrap:nowrap;justify-content:flex-start;align-self:stretch;gap:8px;margin:6px 0 0;padding:2px 0;overflow-x:auto;overscroll-behavior-x:contain;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;max-width:100%;
    -webkit-mask-image:linear-gradient(to right,transparent 0,#000 4px,#000 calc(100% - 26px),transparent 100%);
    mask-image:linear-gradient(to right,transparent 0,#000 4px,#000 calc(100% - 26px),transparent 100%);}
  .bimo-hero-hints::-webkit-scrollbar{display:none;}
  /* cada chip muestra su texto COMPLETO en una línea, ancho por contenido */
  .bimo-chip{flex:0 0 auto;width:max-content;max-width:none;white-space:nowrap;overflow:visible;text-overflow:clip;font-size:12px;padding:11px 15px;min-height:44px;}
  /* dots indicadores debajo del carrusel */
  .hero-dots{display:flex;justify-content:center;gap:6px;margin-top:12px;}
  .hero-dots span{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.22);transition:width .25s ease,background .25s ease;}
  [data-theme="light"] .hero-dots span{background:rgba(10,5,9,0.2);}
  .hero-dots span.on{width:18px;border-radius:3px;background:var(--bimo-magenta);}
  /* glow del buscador: brillo ambiental difuso, sin franja/línea marcada */
  .bimo-pill-wrap::after{filter:blur(30px);opacity:calc(var(--glow-opacity) * 0.5);}
  .bimo-pill-wrap::before{filter:blur(46px);opacity:calc(var(--glow-opacity) * 0.25);}
  /* el cue "qué hacemos" se ocultaba/solapaba con los chips en móvil */
  .bimo-hero-scrollcue{display:none;}

  /* CTAs entre el hero y los logos: apilados, centrados, compactos (no grandes) */
  .hero-cta-mobile{display:flex;flex-direction:column;align-items:center;gap:10px;padding:10px 20px 2px;}
  .hero-cta-mobile .hero-cta-btn{width:100%;max-width:300px;justify-content:center;}

  /* Toast de confirmación: FIJO abajo centrado, por ENCIMA del botón flotante
     (que ocupa la esquina inferior derecha). Nunca sobre el titular del hero. */
  .bimo-toast-host{top:auto;bottom:calc(88px + env(safe-area-inset-bottom,0px));left:12px;right:12px;transform:none;display:flex;justify-content:center;}
  .bimo-toast-ring{display:block;max-width:100%;border-radius:18px;}
  .bimo-toast{border-radius:16px;padding:13px 16px;align-items:flex-start;gap:12px;}
  .bimo-toast-icon{margin-top:1px;}
  .bimo-toast-ti{font-size:13.5px;line-height:1.3;}
  .bimo-toast-meta{font-size:11.5px;line-height:1.4;}

  /* ---- Header móvil: barra sólida de UNA fila ----
     ☰ izquierda · logo "bimO" centrado exacto · lupa derecha.
     Posicionamiento absoluto (robusto en todos los navegadores; sin display:contents). */
  /* barra translúcida con blur (frosted), como en escritorio; no opaca */
  .nav{background:rgba(7,4,9,0.40);-webkit-backdrop-filter:blur(18px) saturate(140%);backdrop-filter:blur(18px) saturate(140%);border-bottom:1px solid var(--line);}
  .nav.scrolled{background:rgba(7,4,9,0.72);}   /* más sólida al scrollear (legibilidad) */
  .nav-inner{position:relative;display:block;min-height:60px;padding:0 14px;}
  .nav-links{display:none;}
  /* el CTA "Hablemos" del header cede sitio en móvil (queda el botón flotante,
     el CTA del hero y el CTA final para agendar) */
  .nav-right .bimo-btn{display:none;}
  /* logo centrado respecto al ancho del header */
  .nav-left{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);margin:0;}
  /* hamburguesa a la izquierda, centrada en vertical, área 44x44 */
  .nav-toggle{position:absolute;top:50%;left:10px;transform:translateY(-50%);display:grid;place-items:center;width:44px;height:44px;padding:0;}
  /* lupa a la derecha, área 44x44 */
  .nav-search{position:absolute;top:50%;right:10px;transform:translateY(-50%);width:44px;height:44px;}

  /* ---- Botón flotante: margen seguro + safe-area iOS, no tapa contenido ---- */
  .waf{right:14px;bottom:calc(16px + env(safe-area-inset-bottom,0px));}
  .waf-bubble{font-size:12.5px;}
}

@media(max-width:380px){
  .bimo-hero-headline{font-size:31px;}   /* grande pero un punto más contenido */
  .h-sec{font-size:clamp(22px,8vw,28px);}
  .wrap{padding-left:16px;padding-right:16px;}
}
