/* Agile Design — Design System v1.0 */

:root {
  --color-primary:        #18203E;
  --color-primary-dark:   #0B1120;
  --color-primary-light:  #1E2A52;
  --color-secondary:       #E8364F;
  --color-secondary-hover: #D12A42;
  --color-secondary-soft:  rgba(232,54,79,0.08);
  --color-chati:       #E21384;
  --color-chati-hover: #C20F71;
  --color-chati-soft:  rgba(226,19,132,0.10);
  --color-accent-blue:       #4B75FF;
  --color-accent-blue-soft:  rgba(75,117,255,0.08);
  --color-accent-green:      #B6DB00;
  --color-accent-green-soft: rgba(182,219,0,0.10);
  --color-accent-green-text: #5A6E00;
  --color-success: #10B981;
  --color-neutral-900: #0F172A;
  --color-neutral-700: #334155;
  --color-neutral-600: #475569;
  --color-neutral-500: #64748B;
  --color-neutral-400: #94A3B8;
  --color-neutral-300: #CBD5E1;
  --color-neutral-200: #E2E8F0;
  --color-neutral-100: #EEF0F6;
  --color-neutral-50:  #F7F8FC;
  --color-white: #FFFFFF;
  --bg-page:    var(--color-neutral-50);
  --bg-surface: var(--color-white);
  --fg1: var(--color-primary);
  --fg2: var(--color-neutral-700);
  --fg3: var(--color-neutral-500);
  --fg4: var(--color-neutral-400);
  --border-default:  var(--color-neutral-200);
  --border-hairline: var(--color-neutral-100);
  --brand-accent:      #E8364F;
  --brand-accent-hover:#D12A42;
  --brand-accent-soft: rgba(232,54,79,0.08);
  --font-display: 'Outfit', system-ui, sans-serif;
  --font-body:    'DM Sans', system-ui, sans-serif;
  --font-mono:    'JetBrains Mono', ui-monospace, monospace;
  --card-radius: 16px;
  --ease-standard: cubic-bezier(0.4, 0, 0.2, 1);
  --shadow-card-subtle:   0 1px 4px rgba(0,0,0,0.04);
  --shadow-card-soft:     0 4px 20px rgba(24,32,62,0.06);
  --shadow-card-elevated: 0 8px 30px rgba(24,32,62,0.10), 0 0 0 1px rgba(24,32,62,0.03);
  --shadow-card-dramatic: 0 16px 48px rgba(24,32,62,0.14), 0 4px 12px rgba(232,54,79,0.04);
  --shadow-xl:    0 20px 60px rgba(0,0,0,0.12);
  --shadow-cta:       0 4px 14px rgba(232,54,79,0.30);
  --shadow-cta-hover: 0 6px 20px rgba(232,54,79,0.40);
}

/* ---- Reset ---- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: var(--font-body); background: var(--bg-page); color: var(--fg2); -webkit-font-smoothing: antialiased; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

/* ---- Layout ---- */
.ad-container { max-width: 1200px; margin: 0 auto; padding: 0 32px; }
.ad-container-sm { max-width: 860px; margin: 0 auto; padding: 0 32px; }

/* ---- Buttons ---- */
.ad-btn { display: inline-flex; align-items: center; justify-content: center; gap: 7px; font-family: var(--font-display); font-weight: 600; border: none; cursor: pointer; border-radius: 9999px; transition: all .3s var(--ease-standard); white-space: nowrap; text-decoration: none; }
.ad-btn-sm  { padding: 9px 18px;  font-size: 13px; }
.ad-btn-md  { padding: 12px 26px; font-size: 14px; }
.ad-btn-lg  { padding: 15px 30px; font-size: 15px; }
.ad-btn-primary { background: var(--color-secondary); color: #fff; box-shadow: var(--shadow-cta); }
.ad-btn-primary:hover { background: var(--color-secondary-hover); transform: translateY(-1px); box-shadow: var(--shadow-cta-hover); }
.ad-btn-secondary { background: transparent; color: var(--fg2); border: 2px solid var(--color-neutral-300); }
.ad-btn-secondary:hover { border-color: var(--brand-accent); color: var(--brand-accent); }
.ad-btn-outline-light { background: rgba(255,255,255,0.04); color: #fff; border: 2px solid rgba(255,255,255,0.28); }
.ad-btn-outline-light:hover { border-color: #fff; background: rgba(255,255,255,0.10); }

/* ---- Cards ---- */
.ad-card { background: #fff; border: 1px solid var(--border-default); border-radius: var(--card-radius); box-shadow: var(--shadow-card-soft); transition: transform .35s var(--ease-standard), box-shadow .35s var(--ease-standard), border-color .3s; position: relative; }
.ad-card-hover { overflow: hidden; }
.ad-card-hover::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: transparent; transition: background .3s; z-index: 1; }
.ad-card-hover:hover { transform: translateY(-4px); box-shadow: var(--shadow-card-elevated); }
.ad-card-hover:hover::before { background: var(--brand-accent); }
.ad-card-hover:hover .svc-icon { transform: scale(1.08) rotate(-3deg); }
.ad-card-hover:hover .svc-link { gap: 11px; }
.svc-icon { transition: transform .3s var(--ease-standard); }
.svc-link { transition: gap .25s var(--ease-standard); display: inline-flex; align-items: center; gap: 6px; }
.lift-row:hover { border-color: color-mix(in srgb, var(--color-secondary) 30%, transparent); transform: translateX(4px); box-shadow: var(--shadow-card-soft); }
.cmp-row:hover { background: var(--bg-page); }

/* ---- Pill ---- */
.ad-pill { display: inline-flex; align-items: center; font-family: var(--font-display); font-size: 11px; font-weight: 600; padding: 5px 13px; border-radius: 9999px; letter-spacing: 0.02em; }

/* ---- Eyebrow / headings ---- */
.ad-eyebrow { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; }
.ad-eyebrow-line { width: 24px; height: 2px; background: var(--brand-accent); border-radius: 1px; flex-shrink: 0; }
.ad-eyebrow-text { font-family: var(--font-display); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: var(--brand-accent); }
.ad-eyebrow-text-light { color: rgba(255,255,255,0.7); }
.ad-eyebrow.center { justify-content: center; }

/* ---- Toast ---- */
.ad-toast { position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%) translateY(140px); background: var(--color-primary-dark); color: #fff; padding: 15px 22px; border-radius: 12px; font-family: var(--font-display); font-size: 14px; font-weight: 500; display: flex; align-items: center; gap: 10px; box-shadow: var(--shadow-xl); z-index: 200; transition: transform .45s var(--ease-standard); }
.ad-toast.show { transform: translateX(-50%) translateY(0); }

/* ---- Reveal animation ---- */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity .7s var(--ease-standard), transform .7s var(--ease-standard); will-change: opacity, transform; }
.reveal.is-visible { opacity: 1; transform: none; }

/* ---- Animations ---- */
@keyframes float1 { 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-9px); } }
@keyframes float2 { 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(8px);  } }
@keyframes indIn  { from{ opacity:0; transform:translateY(10px); } to{ opacity:1; transform:none; } }

/* ============================================================
   NAV
   ============================================================ */
.ad-nav { position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,0.6); backdrop-filter: blur(14px); border-bottom: 1px solid transparent; transition: all .3s var(--ease-standard); }
.ad-nav.scrolled { background: rgba(255,255,255,0.82); border-color: var(--border-hairline); }
.ad-nav-inner { display: flex; align-items: center; justify-content: space-between; height: 66px; }
.ad-nav-logo img { height: 40px; }
.ad-nav-links { display: flex; gap: 28px; list-style: none; margin: 0; padding: 0; }
.ad-nav-links li { display: flex; position: relative; align-items: center; }
.ad-nav-link, .ad-nav-links a { font-family: var(--font-display); font-size: 14px; font-weight: 500; color: var(--fg2); transition: color .2s; }
.ad-nav-link:hover, .ad-nav-links a:hover { color: var(--brand-accent); }
.ad-nav-links .menu-item-has-children > a::after { content: ''; display: inline-block; width: 6px; height: 6px; margin-left: 5px; border-right: 1.5px solid currentColor; border-bottom: 1.5px solid currentColor; transform: translateY(-2px) rotate(45deg); }
.ad-nav-links .sub-menu { display: none; list-style: none; flex-direction: column; gap: 0; position: absolute; top: 100%; left: 0; min-width: 200px; padding: 8px; margin: 0; background: #fff; border: 1px solid var(--border-hairline); border-radius: 10px; box-shadow: 0 12px 28px rgba(24,32,62,0.12); z-index: 60; }
.ad-nav-links .menu-item-has-children:hover > .sub-menu,
.ad-nav-links .menu-item-has-children:focus-within > .sub-menu { display: flex; }
.ad-nav-links .sub-menu a { display: block; padding: 8px 10px; border-radius: 6px; white-space: nowrap; }
.ad-nav-links .sub-menu a:hover { background: var(--surface-2, rgba(24,32,62,0.04)); }

/* ============================================================
   HERO
   ============================================================ */
.hero { position: relative; overflow: hidden; background: linear-gradient(135deg,#0B1120 0%,#0D1835 40%,#0F2060 75%,#1A3580 100%); }
.hero-glow-1 { position: absolute; top: -160px; right: -60px; width: 760px; height: 760px; border-radius: 50%; background: radial-gradient(circle, rgba(75,117,255,0.32) 0%, rgba(75,117,255,0.08) 45%, transparent 70%); pointer-events: none; }
.hero-glow-2 { position: absolute; bottom: -180px; left: -80px; width: 520px; height: 520px; border-radius: 50%; background: radial-gradient(circle, rgba(24,32,62,0.9) 0%, transparent 65%); pointer-events: none; }
.hero-glow-3 { position: absolute; top: 38%; left: 70%; width: 680px; height: 680px; transform: translate(-50%,-50%); background: radial-gradient(circle, rgba(232,54,79,0.18) 0%, transparent 60%); pointer-events: none; }
.hero-inner { position: relative; padding: 92px 32px 96px; display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 56px; align-items: center; }
.hero-badge { display: inline-flex; align-items: center; gap: 8px; background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.14); backdrop-filter: blur(4px); padding: 6px 16px; border-radius: 9999px; margin-bottom: 26px; }
.hero-badge-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--brand-accent); flex-shrink: 0; }
.hero-badge-text { font-family: var(--font-display); font-size: 11px; font-weight: 600; color: rgba(255,255,255,0.72); text-transform: uppercase; letter-spacing: 0.08em; }
.hero-h1 { font-family: var(--font-display); font-weight: 800; font-size: clamp(38px, 5vw, 58px); line-height: 1.06; letter-spacing: -0.025em; color: #fff; margin: 0; text-wrap: balance; }
.hero-h1 .hl { color: var(--brand-accent); }
.hero-subhead-strong { font-family: var(--font-display); font-weight: 600; font-size: 19px; line-height: 1.4; color: rgba(255,255,255,0.9); max-width: 540px; margin-top: 18px; }
.hero-subhead-body { font-family: var(--font-body); font-size: 17px; line-height: 1.7; color: rgba(255,255,255,0.6); max-width: 540px; margin-top: 12px; }
.hero-subhead-body strong { color: #fff; }
.hero-ctas { display: flex; gap: 14px; margin-top: 32px; flex-wrap: wrap; }
.hero-trust { display: flex; gap: 36px; margin-top: 48px; flex-wrap: wrap; }
.hero-trust-n { font-family: var(--font-display); font-weight: 800; font-size: 24px; color: #fff; letter-spacing: -0.01em; }
.hero-trust-l { font-size: 12.5px; color: rgba(255,255,255,0.5); margin-top: 3px; line-height: 1.4; }

/* Chati mock */
.chati-wrap { display: flex; justify-content: center; }
.chati-relative { position: relative; }
.chati-mock { width: 100%; max-width: 360px; background: #fff; border-radius: 22px; box-shadow: var(--shadow-card-dramatic); overflow: hidden; border: 1px solid rgba(255,255,255,0.6); }
.chati-header { display: flex; align-items: center; gap: 12px; padding: 14px 16px; background: linear-gradient(135deg,#18203E,#1E2A52); }
.chati-avatar { width: 40px; height: 40px; border-radius: 50%; background: rgba(255,255,255,0.12); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.chati-name { font-family: var(--font-display); font-size: 14px; font-weight: 700; color: #fff; }
.chati-status { font-size: 11px; color: rgba(255,255,255,0.6); display: flex; align-items: center; gap: 5px; }
.chati-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--color-success); flex-shrink: 0; }
.chati-body { padding: 16px; display: flex; flex-direction: column; gap: 10px; background: #F4F5FA; }
.chati-msg { max-width: 82%; }
.chati-msg.in { align-self: flex-start; }
.chati-msg.bot { align-self: flex-end; }
.chati-bubble { font-family: var(--font-body); font-size: 13.5px; line-height: 1.5; padding: 9px 13px; border-radius: 14px; }
.chati-msg.in  .chati-bubble { background: #fff; color: var(--fg2); border-bottom-left-radius: 4px; box-shadow: var(--shadow-card-subtle); }
.chati-msg.bot .chati-bubble { background: var(--color-chati); color: #fff; border-bottom-right-radius: 4px; }
.chati-tick { display: flex; align-items: center; gap: 4px; justify-content: flex-end; margin-top: 4px; font-size: 10px; color: var(--fg4); }
.chati-footer { display: flex; align-items: center; gap: 10px; padding: 12px 16px; background: #fff; border-top: 1px solid var(--border-hairline); }
.chati-input { flex: 1; font-size: 13px; color: var(--fg4); }
.chati-send { width: 34px; height: 34px; border-radius: 50%; background: var(--color-chati); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }

/* floating badges */
.hero-badge-float { position: absolute; z-index: 2; background: #fff; border-radius: 14px; padding: 12px 16px; box-shadow: var(--shadow-card-dramatic); display: flex; align-items: center; gap: 10px; }
.hero-badge-float.top  { top: -18px; right: -10px; animation: float1 5s ease-in-out infinite; }
.hero-badge-float.btm  { bottom: -16px; left: -26px; animation: float2 6s ease-in-out infinite; }
.hero-badge-icon { border-radius: 10px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.hero-badge-float .n  { font-family: var(--font-display); font-weight: 800; font-size: 16px; color: var(--fg1); line-height: 1; }
.hero-badge-float .n.sm { font-size: 15px; }
.hero-badge-float .l  { font-size: 10.5px; color: var(--fg4); }

/* ============================================================
   COSTO OCULTO
   ============================================================ */
.cost-section { background: var(--bg-surface); padding: 92px 0; border-bottom: 1px solid var(--border-hairline); }
.cost-grid { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 56px; align-items: start; }
.cost-alert { display: inline-flex; align-items: flex-start; gap: 14px; padding: 20px 22px; background: var(--brand-accent-soft); border: 1px solid color-mix(in srgb, var(--brand-accent) 18%, transparent); border-radius: 16px; max-width: 420px; margin-top: 24px; }
.cost-alert p { margin: 0; font-family: var(--font-body); font-size: 15px; line-height: 1.6; color: var(--fg2); }
.cost-alert p strong { color: var(--fg1); }
.pain-list { display: flex; flex-direction: column; gap: 14px; }
.pain-row { display: flex; gap: 18px; padding: 20px 22px; background: var(--bg-page); border: 1px solid var(--border-default); border-radius: 16px; align-items: flex-start; transition: all .3s var(--ease-standard); }
.pain-icon-wrap { width: 44px; height: 44px; border-radius: 12px; background: var(--bg-surface); border: 1px solid var(--border-default); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.pain-row h3 { font-family: var(--font-display); font-size: 16px; font-weight: 700; color: var(--fg1); margin: 2px 0 4px; }
.pain-row p  { font-size: 14px; color: var(--fg3); line-height: 1.6; margin: 0; }

/* Diagnóstico (01) — grid de puntos de dolor con icono, exclusivo de servicios que llenan servicio_dolor_* */
.svc-diag-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 20px; }
.svc-diag-card { display: flex; gap: 18px; align-items: flex-start; padding: 28px 30px; background: var(--bg-surface); border: 1px solid var(--border-default); border-radius: 18px; box-shadow: var(--shadow-card-subtle); transition: all .3s var(--ease-standard); }
.svc-diag-card:hover { border-color: color-mix(in srgb, var(--color-secondary) 30%, transparent); box-shadow: var(--shadow-card-elevated); transform: translateY(-2px); }
.svc-diag-icon-wrap { width: 48px; height: 48px; border-radius: 14px; background: var(--color-secondary-soft); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.svc-diag-card h3 { font-family: var(--font-display); font-size: 17px; font-weight: 700; color: var(--fg1); margin: 0 0 4px; }
.svc-diag-card p { font-family: var(--font-body); font-size: 15px; line-height: 1.5; color: var(--fg3); margin: 0; }
.svc-diag-callout { display: flex; gap: 16px; align-items: flex-start; max-width: 760px; margin-top: 20px; padding: 26px 30px; background: var(--color-secondary-soft); border: 1px solid color-mix(in srgb, var(--color-secondary) 18%, transparent); border-radius: 18px; }
.svc-diag-callout-icon { color: var(--color-secondary); flex-shrink: 0; margin-top: 2px; }
.svc-diag-callout p { font-family: var(--font-body); font-size: 16.5px; line-height: 1.55; color: var(--fg1); margin: 0; }

/* Embudo de marketing (02) — exclusivo de servicio_embudo_* (Marketing Digital) */
.svc-funnel-grid { display: grid; grid-template-columns: 1fr 1.05fr; gap: 50px; align-items: start; }
.svc-funnel-label { font-family: var(--font-display); font-size: 12px; font-weight: 700; color: var(--fg4); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 16px; }
.svc-funnel-sources { display: flex; flex-direction: column; gap: 12px; margin-bottom: 20px; }
.svc-funnel-source-row { display: flex; gap: 16px; align-items: flex-start; padding: 18px 20px; background: var(--bg-surface); border-radius: 14px; }
.svc-funnel-source-icon { width: 42px; height: 42px; border-radius: 12px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.svc-chip-green { background: #F1F4E4; color: #5E6D1E; }
.svc-chip-blue  { background: #EAEDFB; color: #5277F6; }
.svc-chip-pink  { background: #F6E4EF; color: #D03482; }
.svc-funnel-source-title { font-family: var(--font-display); font-size: 15.5px; font-weight: 700; color: var(--fg1); margin-bottom: 2px; }
.svc-funnel-source-text { font-family: var(--font-body); font-size: 14px; color: var(--fg3); }
.svc-funnel-callout { max-width: none; margin-top: 0; }
.svc-funnel-card { padding: 32px; }
.svc-funnel-stages { display: flex; flex-direction: column; }
.svc-funnel-stage { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin: 0 auto; padding: 18px 24px; border-radius: 14px; box-shadow: 0 10px 24px rgba(24,32,62,0.14); }
.svc-funnel-stage-label { display: flex; align-items: center; gap: 10px; font-family: var(--font-display); font-size: 15px; font-weight: 700; color: #fff; }
.svc-funnel-stage-value { font-family: var(--font-display); font-size: 19px; font-weight: 800; color: #fff; flex-shrink: 0; }
.svc-funnel-stage-navy   { background: #19203C; }
.svc-funnel-stage-blue   { background: #5277F6; }
.svc-funnel-stage-maroon { background: #B24337; }
.svc-funnel-stage-red    { background: var(--color-secondary); }
.svc-funnel-transition { display: flex; align-items: center; justify-content: center; gap: 6px; padding: 10px 0; font-family: var(--font-body); font-size: 13px; color: var(--fg4); }
.svc-funnel-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; margin-top: 28px; padding-top: 24px; border-top: 1px solid var(--border-hairline); }
.svc-funnel-stat-value { font-family: var(--font-display); font-size: 24px; font-weight: 800; color: var(--fg1); margin-bottom: 4px; }
.svc-funnel-stat-text { font-family: var(--font-body); font-size: 13px; color: var(--fg3); line-height: 1.4; }

/* Scorecard de madurez digital (02) — exclusivo de servicios que llenan servicio_scorecard_* */
.svc-score-card { padding: 0; overflow: hidden; }
.svc-score-head { display: flex; align-items: center; gap: 18px; padding: 26px 32px; background: linear-gradient(135deg,#0B1120 0%,#0D1835 40%,#0F2060 75%,#1A3580 100%); }
.svc-score-head-icon { width: 56px; height: 56px; border-radius: 14px; background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.14); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.svc-score-head-text { flex: 1; min-width: 0; }
.svc-score-head-title { font-family: var(--font-display); font-size: 18px; font-weight: 700; color: #fff; }
.svc-score-head-sub { font-family: var(--font-body); font-size: 13px; color: rgba(255,255,255,0.55); margin-top: 2px; }
.svc-score-head-level { display: flex; flex-direction: column; align-items: flex-end; gap: 8px; flex-shrink: 0; }
.svc-score-level-dots { display: flex; gap: 5px; }
.svc-score-level-dot { width: 22px; height: 6px; border-radius: 3px; background: rgba(255,255,255,0.18); }
.svc-score-level-dot.is-filled { background: var(--color-secondary); }
.svc-score-level-label { font-family: var(--font-display); font-size: 13px; font-weight: 600; color: #fff; white-space: nowrap; }
.svc-score-rows { display: flex; flex-direction: column; }
.svc-score-row { display: flex; align-items: center; gap: 18px; padding: 22px 32px; border-bottom: 1px solid var(--border-hairline); }
.svc-score-row:last-child { border-bottom: none; }
.svc-score-row-icon { width: 48px; height: 48px; border-radius: 13px; background: var(--color-secondary-soft); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.svc-score-row-text { flex: 1; min-width: 0; }
.svc-score-row-title { font-family: var(--font-display); font-size: 16px; font-weight: 700; color: var(--fg1); }
.svc-score-row-desc { font-family: var(--font-body); font-size: 13.5px; color: var(--fg3); margin-top: 2px; }
.svc-score-row-bar { width: 160px; height: 8px; border-radius: 9999px; background: var(--border-default); overflow: hidden; flex-shrink: 0; }
.svc-score-row-bar span { display: block; height: 100%; border-radius: 9999px; background: var(--color-secondary); }
.svc-score-row-val { width: 38px; text-align: right; font-family: var(--font-display); font-size: 15px; font-weight: 700; color: var(--fg1); flex-shrink: 0; }

/* ============================================================
   SERVICIOS
   ============================================================ */
.services-section { background: var(--bg-page); padding: 92px 0; }
.services-intro p { font-family: var(--font-body); font-size: 16px; line-height: 1.7; color: var(--fg2); font-weight: 500; max-width: 680px; margin: 0 0 44px; }
.services-intro .hl { color: var(--brand-accent); }
.cards-2 { display: grid; grid-template-columns: repeat(2,1fr); gap: 22px; }
.svc-card-inner { padding: 30px; height: 100%; display: flex; flex-direction: column; }
.svc-card-top { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 20px; }
.svc-icon { width: 54px; height: 54px; border-radius: 14px; display: flex; align-items: center; justify-content: center; }
.svc-card-title { font-family: var(--font-display); font-size: 22px; font-weight: 700; color: var(--fg1); margin: 0 0 4px; letter-spacing: -0.01em; }
.svc-card-sub { font-family: var(--font-display); font-size: 14px; font-weight: 600; margin-bottom: 12px; }
.svc-card-desc { font-size: 14.5px; color: var(--fg3); line-height: 1.65; margin: 0 0 20px; flex: 1; }
.svc-related-card { display: block; padding: 30px; }
.svc-related-icon { background: var(--brand-accent-soft); margin-bottom: 22px; }
.svc-related-title { font-family: var(--font-display); font-size: 20px; font-weight: 700; color: var(--fg1); margin: 0 0 14px; letter-spacing: -0.01em; }
.svc-related-card .svc-link { color: var(--brand-accent); font-family: var(--font-display); font-size: 14px; font-weight: 600; }

/* ============================================================
   MÉTRICAS (dark)
   ============================================================ */
.metrics-section { position: relative; overflow: hidden; background: linear-gradient(135deg,#0B1120 0%,#0F2060 60%,#1A3580 100%); padding: 88px 0; }
.metrics-glow-1 { position: absolute; top: -120px; right: -60px; width: 600px; height: 600px; border-radius: 50%; background: radial-gradient(circle,rgba(75,117,255,0.25) 0%,transparent 65%); pointer-events: none; }
.metrics-glow-2 { position: absolute; bottom: -100px; left: 30%; width: 400px; height: 400px; border-radius: 50%; background: radial-gradient(circle,rgba(232,54,79,0.10) 0%,transparent 65%); pointer-events: none; }
.cards-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; margin-top: 52px; }
.metric-card { background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.10); border-radius: 18px; padding: 30px 28px; backdrop-filter: blur(4px); height: 100%; }
.metric-icon-wrap { width: 46px; height: 46px; border-radius: 12px; background: rgba(255,255,255,0.06); display: flex; align-items: center; justify-content: center; margin-bottom: 18px; }
.metric-n { font-family: var(--font-display); font-weight: 800; font-size: 46px; color: #fff; line-height: 1; letter-spacing: -0.02em; }
.metric-l { font-size: 14.5px; color: rgba(255,255,255,0.6); line-height: 1.5; margin-top: 12px; }
.logos-row { margin-top: 52px; padding-top: 36px; border-top: 1px solid rgba(255,255,255,0.08); }
.logos-label { text-align: center; font-family: var(--font-display); font-size: 11px; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(255,255,255,0.4); margin-bottom: 24px; }
.logos-list { display: flex; justify-content: center; align-items: center; gap: 18px; flex-wrap: wrap; }
.logo-placeholder { width: 138px; height: 52px; border-radius: 12px; background: rgba(255,255,255,0.03); border: 1px dashed rgba(255,255,255,0.16); display: flex; align-items: center; justify-content: center; gap: 8px; color: rgba(255,255,255,0.3); font-family: var(--font-display); font-size: 12px; font-weight: 500; }

/* ============================================================
   INDUSTRIAS (explorador interactivo)
   ============================================================ */
.industries-section { background: var(--bg-surface); padding: 92px 0; border-top: 1px solid var(--border-hairline); }
.ind-header { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; flex-wrap: wrap; margin-bottom: 44px; }
.ind-count { display: flex; align-items: center; gap: 14px; padding: 14px 22px; background: #fff; border: 1px solid var(--border-default); border-radius: 16px; box-shadow: var(--shadow-card-subtle); }
.ind-count-n { font-family: var(--font-display); font-weight: 800; font-size: 40px; line-height: 1; color: var(--brand-accent); letter-spacing: -0.02em; }
.ind-count-l { font-family: var(--font-display); font-size: 12px; font-weight: 600; line-height: 1.4; color: var(--fg3); }
.ind-grid { display: grid; grid-template-columns: 0.86fr 1.14fr; gap: 24px; align-items: stretch; }
.ind-list { display: flex; flex-direction: column; gap: 8px; }
/* Variante en single-servicio.php: lista más angosta que el panel, con scroll interno
   acotado a la altura del panel para que toda la sección quepa en el alto de pantalla. */
.svc-ind-grid { grid-template-columns: 0.66fr 1.34fr; align-items: start; }
.svc-ind-list { max-height: 760px; overflow-y: auto; padding-right: 6px; scrollbar-width: thin; }
.svc-ind-list::-webkit-scrollbar { width: 6px; }
.svc-ind-list::-webkit-scrollbar-thumb { background: var(--border-default); border-radius: 6px; }
.svc-ind-list::-webkit-scrollbar-track { background: transparent; }
.ind-tab, .svc-ind-tab { display: flex; align-items: center; gap: 14px; width: 100%; text-align: left; padding: 13px 16px; background: #fff; border: 1px solid var(--border-default); border-radius: 14px; cursor: pointer; transition: border-color .25s var(--ease-standard), box-shadow .25s var(--ease-standard), transform .25s var(--ease-standard); }
.ind-tab:hover, .svc-ind-tab:hover { transform: translateX(3px); }
.ind-tab.is-active { transform: translateX(3px); border-color: color-mix(in srgb, var(--brand-accent) 40%, transparent); box-shadow: var(--shadow-card-soft); }
/* .svc-ind-tab.is-active: color por tono de industria, aplicado inline vía JS (ver activateTab en single-servicio.php) */
.svc-ind-tab.is-active { transform: translateX(3px); }
.ind-tab-chip { width: 40px; height: 40px; border-radius: 11px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: background .25s; }
.ind-tab-txt { display: flex; flex-direction: column; gap: 2px; flex: 1; min-width: 0; }
.ind-tab-name { font-family: var(--font-display); font-size: 15px; font-weight: 700; color: var(--fg1); letter-spacing: -0.01em; line-height: 1.2; }
.ind-oneliner { font-size: 12px; color: var(--fg4); line-height: 1.3; }
.ind-panel { position: relative; overflow: hidden; padding: 34px 36px; box-shadow: var(--shadow-card-elevated); }
.ind-panel-glow { position: absolute; top: -120px; right: -120px; width: 360px; height: 360px; pointer-events: none; border-radius: 50%; }
.ind-panel-in { position: relative; animation: indIn .4s var(--ease-standard); }
.ind-panel-chip { width: 56px; height: 56px; border-radius: 15px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.ind-panel-top { display: flex; align-items: center; gap: 14px; margin-bottom: 22px; }
.ind-panel-label-tag { font-family: var(--font-display); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 3px; }
.ind-panel-h3 { font-family: var(--font-display); font-size: 23px; font-weight: 800; color: var(--fg1); margin: 0; letter-spacing: -0.015em; line-height: 1.2; text-wrap: balance; }
.ind-panel-badge { display: flex; align-items: center; gap: 10px; background: var(--brand-accent-soft); border: 1px solid color-mix(in srgb, var(--brand-accent) 18%, transparent); border-radius: 12px; padding: 12px 18px; margin: 0 0 20px; }
.ind-panel-badge span { font-family: var(--font-display); font-size: 14px; font-weight: 600; color: var(--fg1); line-height: 1.4; }
.ind-panel-intro { font-family: var(--font-body); font-size: 15.5px; line-height: 1.7; color: var(--fg3); margin: 0 0 24px; max-width: 560px; }
.ind-panel-cols { display: grid; grid-template-columns: 1.35fr 1fr; gap: 30px; padding: 22px 0 6px; margin-top: 4px; border-top: 1px solid var(--border-hairline); }
.ind-col-label { font-family: var(--font-display); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: var(--fg4); margin: 0 0 14px; }
.ind-solve-list { list-style: none; display: flex; flex-direction: column; gap: 11px; margin: 0; padding: 0; }
.ind-solve-item { display: flex; gap: 11px; align-items: flex-start; }
.ind-solve-check { width: 22px; height: 22px; border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 1px; }
.ind-solve-text { font-size: 14.5px; color: var(--fg2); line-height: 1.5; }
.ind-build-list { display: flex; flex-direction: column; gap: 9px; }
.ind-build-chip { display: flex; align-items: center; gap: 9px; padding: 11px 14px; background: var(--bg-surface); border: 1px solid var(--border-hairline); border-radius: 11px; font-family: var(--font-display); font-size: 13.5px; font-weight: 600; color: var(--fg2); }
.ind-panel-cta { display: flex; align-items: center; gap: 22px; flex-wrap: wrap; margin-top: 26px; padding-top: 24px; border-top: 1px solid var(--border-hairline); }
.ind-cross-link { display: inline-flex; align-items: center; gap: 7px; font-family: var(--font-display); font-size: 14px; font-weight: 600; transition: gap .25s; }
.ind-cross-link:hover { gap: 11px; }

/* ============================================================
   POR QUÉ AGILE
   ============================================================ */
.why-section { background: var(--bg-page); padding: 92px 0; }
.cmp-table { overflow: hidden; box-shadow: var(--shadow-card-elevated); }
.cmp-grid { display: grid; grid-template-columns: 1.1fr 1.2fr 1.2fr; }
.cmp-head-empty { padding: 20px 24px; }
.cmp-head-us { padding: 20px 24px; background: var(--color-primary); display: flex; align-items: center; gap: 10px; }
.cmp-head-them { padding: 20px 24px; display: flex; align-items: center; }
.cmp-head-us span { font-family: var(--font-display); font-weight: 700; font-size: 16px; color: #fff; }
.cmp-head-them span { font-family: var(--font-display); font-weight: 600; font-size: 15px; color: var(--fg3); }
.cmp-row { border-top: 1px solid var(--border-hairline); transition: background .25s; }
.cmp-cell-label { padding: 18px 24px; display: flex; align-items: center; gap: 12px; }
.cmp-cell-label span { font-family: var(--font-display); font-weight: 700; font-size: 14.5px; color: var(--fg1); }
.cmp-cell-us   { padding: 18px 24px; display: flex; align-items: flex-start; gap: 10px; background: color-mix(in srgb, var(--brand-accent) 4%, transparent); }
.cmp-cell-them { padding: 18px 24px; display: flex; align-items: flex-start; gap: 10px; }
.cmp-cell-us span   { font-size: 14.5px; color: var(--fg2); line-height: 1.5; font-weight: 500; }
.cmp-cell-them span { font-size: 14.5px; color: var(--fg4); line-height: 1.5; }

/* ============================================================
   PROCESO
   ============================================================ */
.process-section { background: var(--bg-surface); padding: 92px 0; border-top: 1px solid var(--border-hairline); }
.cards-4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 24px; position: relative; }
.proc-line { position: absolute; top: 36px; left: 12.5%; right: 12.5%; height: 2px; background: linear-gradient(90deg, var(--border-default), var(--brand-accent), var(--border-default)); opacity: 0.5; }
.proc-icon-wrap { width: 72px; height: 72px; border-radius: 20px; background: var(--bg-surface); border: 1px solid var(--border-default); box-shadow: var(--shadow-card-soft); display: flex; align-items: center; justify-content: center; margin-bottom: 20px; position: relative; }
.proc-badge { position: absolute; top: -8px; right: -8px; width: 26px; height: 26px; border-radius: 50%; background: var(--color-primary); color: #fff; font-family: var(--font-display); font-size: 11px; font-weight: 700; display: flex; align-items: center; justify-content: center; }
.proc-dur { font-family: var(--font-display); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--brand-accent); margin-bottom: 6px; }
.proc-title { font-family: var(--font-display); font-size: 17px; font-weight: 700; color: var(--fg1); margin: 0 0 8px; line-height: 1.3; }
.proc-desc  { font-size: 14px; color: var(--fg3); line-height: 1.6; margin: 0; }

/* ============================================================
   FAQ
   ============================================================ */
.faq-section { background: var(--bg-page); padding: 92px 0; }
.faq-list { display: flex; flex-direction: column; gap: 14px; }
.faq-item { overflow: hidden; transition: all .3s var(--ease-standard); }
.faq-item.is-open { box-shadow: var(--shadow-card-soft); border-color: color-mix(in srgb, var(--brand-accent) 30%, transparent); }
.faq-trigger { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 22px 26px; background: transparent; border: none; cursor: pointer; text-align: left; }
.faq-q { font-family: var(--font-display); font-size: 17px; font-weight: 700; color: var(--fg1); line-height: 1.4; }
.faq-icon { width: 32px; height: 32px; border-radius: 50%; background: var(--bg-page); display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: all .3s var(--ease-standard); }
.faq-item.is-open .faq-icon { background: var(--brand-accent); }
.faq-chevron { transition: transform .3s var(--ease-standard); }
.faq-item.is-open .faq-chevron { transform: rotate(180deg); }
.faq-body { max-height: 0; overflow: hidden; transition: max-height .35s var(--ease-standard); }
.faq-body-inner { padding: 0 26px 24px; font-family: var(--font-body); font-size: 15px; line-height: 1.7; color: var(--fg3); }
.faq-body-inner strong { color: var(--fg2); }

/* ============================================================
   CTA FINAL
   ============================================================ */
.final-cta-section { padding: 40px 32px 80px; background: var(--bg-page); }
.final-cta-box { position: relative; overflow: hidden; border-radius: 28px; background: linear-gradient(135deg,#0B1120 0%,#0F2060 55%,#1A3580 100%); padding: 64px 56px; max-width: 1100px; margin: 0 auto; }
.final-cta-glow-1 { position: absolute; top: -80px; right: -60px; width: 500px; height: 500px; border-radius: 50%; background: radial-gradient(circle, rgba(75,117,255,0.22) 0%, transparent 65%); pointer-events: none; }
.final-cta-glow-2 { position: absolute; top: 50%; right: -5%; width: 480px; height: 480px; transform: translateY(-50%); background: radial-gradient(circle, rgba(232,54,79,0.18), transparent 62%); pointer-events: none; }
.final-cta-inner { position: relative; max-width: 720px; }
.final-cta-h2 { font-family: var(--font-display); font-weight: 800; font-size: clamp(30px,4vw,42px); line-height: 1.1; letter-spacing: -0.02em; color: #fff; margin: 0 0 16px; text-wrap: balance; }
.final-cta-h2 .hl { color: var(--color-secondary); }
.final-cta-body { font-family: var(--font-body); font-size: 17px; line-height: 1.7; color: rgba(255,255,255,0.62); margin: 0 0 32px; max-width: 560px; }
.final-cta-btns { display: flex; gap: 14px; flex-wrap: wrap; }
.final-cta-note { display: flex; align-items: center; gap: 8px; margin-top: 24px; font-size: 13px; color: rgba(255,255,255,0.5); }

/* ============================================================
   FOOTER
   ============================================================ */
.ad-footer { background: linear-gradient(160deg,#0B1120 0%,#0D1835 60%,#0F2060 100%); padding: 72px 0 40px; position: relative; overflow: hidden; }
.footer-glow { position: absolute; top: -80px; right: -60px; width: 440px; height: 440px; border-radius: 50%; background: radial-gradient(circle, rgba(75,117,255,0.14) 0%, transparent 65%); pointer-events: none; }
.footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1.5fr 1fr; gap: 40px; }
.footer-logo { height: 40px; margin-bottom: 20px; }
.footer-tagline { color: rgba(255,255,255,0.5); font-size: 14px; line-height: 1.7; max-width: 290px; margin: 0; }
.footer-socials { display: flex; gap: 10px; margin-top: 22px; }
.footer-social-btn { width: 38px; height: 38px; border-radius: 10px; border: 1px solid rgba(255,255,255,0.12); display: flex; align-items: center; justify-content: center; transition: all .25s; }
.footer-social-btn:hover { border-color: var(--brand-accent); background: rgba(255,255,255,0.04); }
.footer-col-head { font-family: var(--font-display); font-size: 11px; font-weight: 700; color: rgba(255,255,255,0.4); text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 16px; }
.footer-link { display: block; color: rgba(255,255,255,0.6); font-size: 14px; padding: 6px 0; transition: color .2s; }
.footer-link:hover { color: #fff; }
.footer-ind-grid { display: grid; grid-template-columns: 1fr 1fr; column-gap: 20px; }
.footer-bottom { margin-top: 48px; padding-top: 26px; border-top: 1px solid rgba(255,255,255,0.08); display: flex; justify-content: space-between; align-items: center; gap: 16px; flex-wrap: wrap; color: rgba(255,255,255,0.38); font-size: 13px; }

/* ============================================================
   PÁGINA DE SERVICIO (single-servicio.php)
   ============================================================ */
.svc-hero-inner { position: relative; padding: 40px 0 88px; }
.svc-breadcrumb { display: flex; align-items: center; gap: 8px; font-family: var(--font-display); font-size: 13px; color: rgba(255,255,255,0.5); margin-bottom: 36px; }
.svc-breadcrumb a { color: rgba(255,255,255,0.55); }
.svc-breadcrumb span { color: #fff; }
.svc-hero-grid { display: grid; grid-template-columns: 1.25fr 0.75fr; gap: 56px; align-items: center; }
.svc-hero .hero-h1 { font-size: clamp(32px, 4vw, 46px); }
.svc-hero .hero-subhead-strong,
.svc-hero .hero-subhead-body { text-align: justify; text-justify: inter-word; hyphens: auto; }

.svc-hero-panel { background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.16); border-radius: 22px; padding: 26px 26px 22px; box-shadow: 0 20px 50px rgba(0,0,0,0.28); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); }
.svc-hero-panel-head { display: flex; align-items: center; gap: 14px; padding-bottom: 18px; margin-bottom: 6px; border-bottom: 1px solid rgba(255,255,255,0.14); }
.svc-hero-panel-chip { width: 48px; height: 48px; border-radius: 13px; background: var(--brand-accent); display: flex; align-items: center; justify-content: center; flex-shrink: 0; box-shadow: 0 6px 18px color-mix(in srgb, var(--brand-accent) 38%, transparent); }
.svc-hero-panel-tag { font-family: var(--font-display); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: rgba(255,255,255,0.55); }
.svc-hero-panel-title { font-family: var(--font-display); font-size: 16px; font-weight: 700; color: #fff; margin-top: 1px; }
.svc-hero-panel-list { display: flex; flex-direction: column; }
.svc-hero-panel-item { display: flex; gap: 13px; align-items: flex-start; padding: 12px 0; border-bottom: 1px solid rgba(255,255,255,0.12); }
.svc-hero-panel-item:last-child { border-bottom: none; }
.svc-hero-panel-check { width: 24px; height: 24px; border-radius: 50%; background: rgba(255,255,255,0.12); display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 1px; }
.svc-hero-panel-item span:last-child { font-family: var(--font-body); font-size: 14.5px; font-weight: 500; color: rgba(255,255,255,0.88); line-height: 1.5; }

.svc-section { padding: 88px 0; border-top: 1px solid var(--border-hairline); }
.svc-section.bg-surface { background: var(--bg-surface); }

.svc-timeline { display: flex; justify-content: center; }
.svc-timeline-inner { position: relative; display: flex; flex-direction: column; gap: 28px; width: 100%; max-width: 770px; }
.svc-timeline-line { position: absolute; top: 28px; bottom: 28px; left: 27px; width: 2px; background: var(--color-secondary); opacity: 0.3; }
.svc-timeline-row { position: relative; display: flex; gap: 24px; align-items: flex-start; }
.svc-timeline-num { position: relative; z-index: 1; width: 56px; height: 56px; border-radius: 50%; background: var(--color-secondary); color: #fff; font-family: var(--font-display); font-weight: 800; font-size: 18px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; box-shadow: var(--shadow-cta); }
.svc-step-card { flex: 1; min-width: 0; background: var(--bg-surface); border: 1px solid var(--border-default); border-radius: 16px; padding: 24px 26px; transition: all .3s var(--ease-standard); }
.svc-step-head { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; margin-bottom: 10px; }
.svc-step-icon-chip { width: 44px; height: 44px; border-radius: 12px; background: var(--color-secondary-soft); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.svc-step-head h3 { font-family: var(--font-display); font-size: 18px; font-weight: 700; color: var(--fg1); flex: 1; min-width: 140px; }
.svc-step-pill { background: var(--bg-page); color: var(--fg3); border: 1px solid var(--border-default); }
.svc-step-card p { font-size: 15px; color: var(--fg3); line-height: 1.65; margin: 0; }

.svc-incl-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 12px; }
.svc-incl-item { display: flex; gap: 13px; align-items: flex-start; padding: 16px 20px; background: var(--bg-surface); border: 1px solid var(--border-default); border-radius: 12px; height: 100%; position: relative; transition: transform .3s var(--ease-standard), box-shadow .3s var(--ease-standard); }
.svc-incl-check { width: 24px; height: 24px; border-radius: 50%; background: var(--color-accent-green-soft); display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 1px; }
.svc-incl-item span:last-child { font-size: 14.5px; color: var(--fg2); line-height: 1.55; }

.svc-table-wrap { overflow-x: auto; }
.svc-table-card { overflow: hidden; box-shadow: var(--shadow-card-elevated); }
.svc-table { width: 100%; border-collapse: collapse; min-width: 640px; }
.svc-table th { text-align: left; padding: 18px 22px; font-family: var(--font-display); font-weight: 700; font-size: 14.5px; color: var(--fg1); border-bottom: 1px solid var(--border-hairline); }
.svc-table th.hot { display: flex; align-items: center; gap: 6px; background: var(--fg1); color: #fff; }
.svc-table td { padding: 16px 22px; border-top: 1px solid var(--border-hairline); font-size: 14.5px; color: var(--fg3); vertical-align: top; }
.svc-table td.first { font-family: var(--font-display); font-weight: 700; color: var(--fg1); }
.svc-table td.hot { font-weight: 600; color: var(--fg1); background: color-mix(in srgb, var(--brand-accent) 9%, transparent); }
.svc-table-note { margin-top: 16px; font-size: 13px; color: var(--fg4); font-style: italic; }

.svc-results-section { position: relative; overflow: hidden; background: linear-gradient(135deg,#0B1120 0%,#18203E 60%,#1E2A52 100%); padding: 88px 0; }
.svc-results-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 16px; margin-top: 44px; }
.svc-result-item { display: flex; gap: 14px; align-items: center; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.1); border-top: 3px solid var(--brand-accent); border-radius: 14px; padding: 20px 22px; height: 100%; }
.svc-result-check { width: 32px; height: 32px; border-radius: 10px; background: var(--brand-accent-soft); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.svc-result-item span:last-child { font-size: 15px; color: rgba(255,255,255,0.85); line-height: 1.55; }
.svc-results-note { text-align: center; margin-top: 24px; font-size: 13px; color: rgba(255,255,255,0.4); font-style: italic; }

.pain-icon-wrap-soft { background: var(--brand-accent-soft); border: none; }
.svc-dolor-conclusion { display: flex; align-items: flex-start; gap: 14px; margin-top: 28px; padding: 22px 26px; background: var(--brand-accent-soft); border: 1px solid color-mix(in srgb, var(--brand-accent) 18%, transparent); border-radius: 16px; max-width: 760px; }
.svc-dolor-conclusion p { margin: 0; font-family: var(--font-body); font-size: 15.5px; line-height: 1.65; color: var(--fg2); }

/* Chati demo (interactive chat simulation) */
.svc-chatidemo-section { position: relative; overflow: hidden; background: linear-gradient(135deg,#0B1120 0%,#1A0830 50%,#2D0B4E 100%); border-top: none; }
.svc-chatidemo-glow-1 { position: absolute; top: -100px; right: -60px; width: 560px; height: 560px; border-radius: 50%; background: radial-gradient(circle, rgba(226,19,132,0.22) 0%, transparent 65%); pointer-events: none; }
.svc-chatidemo-glow-2 { position: absolute; top: 40%; left: 78%; width: 620px; height: 620px; transform: translate(-50%,-50%); background: radial-gradient(circle, color-mix(in srgb, var(--color-chati) 20%, transparent) 0%, transparent 62%); pointer-events: none; }
.svc-chatidemo-grid { position: relative; display: grid; grid-template-columns: 1fr 0.85fr; gap: 56px; align-items: center; }

.svc-chatidemo-stepper { display: flex; flex-direction: column; gap: 10px; margin-top: 32px; }
.svc-chatidemo-stage { display: flex; gap: 14px; align-items: center; padding: 14px 16px; border-radius: 14px; background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.08); transition: all .4s var(--ease-standard); }
.svc-chatidemo-stage.is-active { background: rgba(255,255,255,0.07); border-color: color-mix(in srgb, var(--color-chati) 45%, transparent); }
.svc-chatidemo-stage.is-current .svc-chatidemo-stage-icon { box-shadow: 0 0 0 6px color-mix(in srgb, var(--color-chati) 22%, transparent); }
.svc-chatidemo-stage-icon { width: 40px; height: 40px; border-radius: 11px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; background: rgba(255,255,255,0.06); color: rgba(255,255,255,0.4); transition: all .4s var(--ease-standard); }
.svc-chatidemo-stage.is-active .svc-chatidemo-stage-icon { background: var(--color-chati); color: #fff; }
.svc-chatidemo-stage-text { flex: 1; }
.svc-chatidemo-stage-title { font-family: var(--font-display); font-size: 15px; font-weight: 700; color: rgba(255,255,255,0.55); transition: color .4s; }
.svc-chatidemo-stage.is-active .svc-chatidemo-stage-title { color: #fff; }
.svc-chatidemo-stage-desc { font-size: 12.5px; color: rgba(255,255,255,0.35); margin-top: 1px; transition: color .4s; }
.svc-chatidemo-stage.is-active .svc-chatidemo-stage-desc { color: rgba(255,255,255,0.6); }
.svc-chatidemo-stage-check { color: var(--color-chati); display: none; flex-shrink: 0; }
.svc-chatidemo-stage.is-active .svc-chatidemo-stage-check { display: block; }

.svc-chatidemo-body { height: 392px; overflow-y: auto; scroll-behavior: smooth; }
.svc-chatidemo-body .chati-msg.bot .chati-bubble { background: var(--color-chati); }
.svc-chatidemo-body .chati-send,
.chati-footer .chati-send { background: var(--color-chati); }
.svc-chatidemo-typing .chati-bubble { background: var(--color-chati); display: inline-flex; align-items: center; gap: 4px; padding: 11px 14px; }
.svc-chatidemo-typing-dot { width: 6px; height: 6px; border-radius: 50%; background: rgba(255,255,255,0.85); animation: chatidemoTyping 1s ease-in-out infinite; }
.svc-chatidemo-typing-dot:nth-child(2) { animation-delay: .15s; }
.svc-chatidemo-typing-dot:nth-child(3) { animation-delay: .3s; }

@keyframes chatidemoTyping { 0%,60%,100% { opacity: .35; transform: translateY(0); } 30% { opacity: 1; transform: translateY(-3px); } }
@keyframes chatidemoMsgIn { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }
.svc-chatidemo-body .chati-msg { animation: chatidemoMsgIn .35s var(--ease-standard); }

/* Casos de uso (situación → solución) */
.svc-usecases-list { display: flex; flex-direction: column; gap: 16px; }
.svc-usecases-row { display: grid; grid-template-columns: 1fr 1fr; border: 1px solid var(--border-default); border-radius: 18px; overflow: hidden; box-shadow: var(--shadow-card-soft); position: relative; }
.svc-usecases-row::after { content: ''; position: absolute; top: 0; bottom: 0; left: 50%; width: 4px; background: var(--brand-accent); z-index: 2; }
.svc-usecases-situation { position: relative; overflow: hidden; background: linear-gradient(135deg,#0B1120 0%,#18203E 100%); padding: 26px 30px; display: flex; gap: 18px; align-items: flex-start; }
.svc-usecases-num-bg { position: absolute; right: 18px; bottom: -16px; font-family: var(--font-display); font-weight: 800; font-size: 92px; line-height: 1; color: rgba(255,255,255,0.05); pointer-events: none; user-select: none; }
.svc-usecases-icon { position: relative; z-index: 1; width: 52px; height: 52px; border-radius: 14px; background: var(--brand-accent); display: flex; align-items: center; justify-content: center; flex-shrink: 0; box-shadow: 0 8px 20px color-mix(in srgb, var(--brand-accent) 35%, transparent); }
.svc-usecases-situation-text { position: relative; z-index: 1; }
.svc-usecases-label { font-family: var(--font-display); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: var(--brand-accent); margin-bottom: 6px; }
.svc-usecases-quote { margin: 0; font-family: var(--font-body); font-style: italic; font-size: 15.5px; line-height: 1.5; color: #fff; }
.svc-usecases-solution { display: flex; align-items: center; gap: 16px; padding: 26px 30px; background: var(--bg-surface); }
.svc-usecases-check { width: 42px; height: 42px; border-radius: 50%; background: var(--brand-accent); display: flex; align-items: center; justify-content: center; flex-shrink: 0; box-shadow: 0 6px 16px color-mix(in srgb, var(--brand-accent) 35%, transparent); }
.svc-usecases-solution-text { margin: 0; font-family: var(--font-body); font-size: 15.5px; font-weight: 600; color: var(--fg1); line-height: 1.5; }

/* Planes con selector de moneda */
.svc-currency { display: flex; flex-direction: column; align-items: center; gap: 12px; margin-top: 36px; }
.svc-currency-label { font-family: var(--font-display); font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--fg4); }
.svc-currency-toggle { display: inline-flex; gap: 4px; padding: 4px; background: var(--bg-surface); border-radius: 9999px; border: 1px solid var(--border-default); }
.svc-currency-btn { display: inline-flex; align-items: center; gap: 8px; border: none; cursor: pointer; border-radius: 9999px; padding: 11px 24px; font-family: var(--font-display); font-size: 14px; font-weight: 600; background: transparent; color: var(--fg3); transition: all .25s var(--ease-standard); }
.svc-currency-btn.is-active { background: var(--brand-accent); color: #fff; box-shadow: 0 6px 16px color-mix(in srgb, var(--brand-accent) 35%, transparent); }
.svc-currency-caption { display: inline-flex; align-items: center; gap: 7px; font-size: 13.5px; color: var(--fg3); }
.svc-currency-caption strong { color: var(--fg1); font-weight: 600; }

.svc-plans-grid { align-items: stretch; }
.svc-plan-card { padding: 28px; display: flex; flex-direction: column; position: relative; box-shadow: var(--shadow-card-subtle); }
.svc-plan-card.featured { border-color: var(--brand-accent); box-shadow: var(--shadow-card-dramatic); }
.svc-plan-badge { position: absolute; top: -13px; left: 50%; transform: translateX(-50%); background: var(--brand-accent); color: #fff; font-family: var(--font-display); font-size: 10px; font-weight: 700; padding: 5px 16px; border-radius: 9999px; text-transform: uppercase; letter-spacing: 0.05em; white-space: nowrap; }
.svc-plan-name { font-family: var(--font-display); font-size: 13px; font-weight: 700; color: var(--fg1); text-transform: uppercase; letter-spacing: 0.05em; }
.svc-plan-name.featured { color: var(--brand-accent); }
.svc-plan-model { font-size: 12.5px; color: var(--fg4); margin-top: 2px; margin-bottom: 14px; }
.svc-plan-price { font-family: var(--font-display); font-size: 30px; font-weight: 800; color: var(--fg1); letter-spacing: -0.01em; line-height: 1.1; margin-bottom: 6px; }
.svc-plan-unit { font-size: 13px; color: var(--fg4); margin-bottom: 22px; }
.svc-plan-cta { width: 100%; justify-content: center; margin-top: auto; }

/* ============================================================
   SECTION HELPERS
   ============================================================ */
.section-h2 { font-family: var(--font-display); font-weight: 800; font-size: 38px; line-height: 1.12; letter-spacing: -0.015em; color: var(--fg1); margin: 0 0 16px; text-wrap: balance; }
.section-h2.light { color: #fff; }
.section-h2.center { text-align: center; }
.section-lead { font-family: var(--font-body); font-size: 17px; line-height: 1.7; color: var(--fg3); }
.section-lead.light { color: rgba(255,255,255,0.62); }
.section-lead.center { text-align: center; }
.hl { color: var(--brand-accent); }
.mt-sm { margin-top: 14px; }
.mt-md { margin-top: 44px; }
.mb-md { margin-bottom: 44px; }
.text-center { text-align: center; }
.flex-col-center { display: flex; flex-direction: column; align-items: center; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 980px) {
  .ad-nav-links { display: none; }
  .hero-inner { grid-template-columns: 1fr; gap: 48px; }
  .svc-hero-grid { grid-template-columns: 1fr; gap: 40px; }
  .svc-chatidemo-grid { grid-template-columns: 1fr; gap: 40px; }
  .svc-usecases-row { grid-template-columns: 1fr; }
  .cost-grid { grid-template-columns: 1fr; gap: 36px; }
  .cards-2 { grid-template-columns: 1fr; }
  .svc-diag-grid { grid-template-columns: 1fr; }
  .svc-funnel-grid { grid-template-columns: 1fr; }
  .svc-funnel-stats { grid-template-columns: 1fr; gap: 14px; }
  .svc-score-head { flex-wrap: wrap; }
  .svc-score-head-level { align-items: flex-start; width: 100%; }
  .svc-score-row { flex-wrap: wrap; }
  .svc-score-row-bar { width: 100%; order: 3; }
  .svc-score-row-val { order: 2; }
  .cards-3 { grid-template-columns: 1fr; }
  .cards-4 { grid-template-columns: 1fr 1fr; }
  .proc-line { display: none; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
  .ind-grid { grid-template-columns: 1fr; gap: 20px; }
  .ind-list { flex-direction: row; overflow-x: auto; gap: 10px; padding-bottom: 8px; scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch; }
  .ind-tab  { min-width: 210px; scroll-snap-align: start; }
  .ind-tab:hover, .ind-tab.is-active { transform: none; }
  .ind-oneliner { display: none; }
  .cmp-grid { grid-template-columns: 1fr; }
  .svc-results-grid { grid-template-columns: 1fr; }
}
@media (max-width: 620px) {
  .cards-4 { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; }
  .ind-panel { padding: 26px 22px; }
  .ind-panel-cols { grid-template-columns: 1fr; gap: 24px; }
  .ind-tab { min-width: 168px; }
  .final-cta-box { padding: 40px 28px; }
  .cmp-row > div:first-child { background: var(--bg-page); }
  .svc-incl-grid { grid-template-columns: 1fr; }
}
