/* ==============================================
   COLMENERO CONSULTING — style.css v4
   Light-first design with dark mode toggle
   Fonts: Sora + DM Serif Display
   ============================================== */

@import url('https://fonts.googleapis.com/css2?family=Sora:wght@300;400;500;600;700;800&family=DM+Serif+Display:ital@0;1&display=swap');

/* ─── TOKENS ─── */
:root {
  --cyan:    #38bdf8;
  --cyan2:   #0ea5e9;
  --teal:    #14b8a6;
  --ease:    cubic-bezier(.16,1,.3,1);
  --r:       10px;
  --r-lg:    16px;
  --r-xl:    20px;
  --r-2xl:   28px;

  /* Light theme */
  --bg:      #ffffff;
  --bg2:     #f8fafc;
  --bg3:     #f1f5f9;
  --border:  rgba(0,0,0,.07);
  --border2: rgba(0,0,0,.11);
  --text:    #0f172a;
  --text2:   #334155;
  --text3:   #64748b;
  --text4:   #94a3b8;
  --card-bg: #ffffff;
  --card-border: rgba(0,0,0,.08);
  --logo-fill: #0f172a;
  --mock-bg: #f8fafc;
  --mock-row-bg: #ffffff;
  --mock-row-hover: #f1f5f9;
}

[data-theme="dark"] {
  --bg:      #0a1628;
  --bg2:     #0f1f3a;
  --bg3:     #152645;
  --border:  rgba(255,255,255,.07);
  --border2: rgba(255,255,255,.12);
  --text:    #f1f5f9;
  --text2:   rgba(255,255,255,.82);
  --text3:   rgba(255,255,255,.5);
  --text4:   rgba(255,255,255,.28);
  --card-bg: rgba(15,31,58,.95);
  --card-border: rgba(255,255,255,.1);
  --logo-fill: #ffffff;
  --mock-bg: rgba(15,31,58,.9);
  --mock-row-bg: rgba(255,255,255,.04);
  --mock-row-hover: rgba(255,255,255,.07);
}

/* ─── RESET ─── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;overflow-x:clip;}
body{
  font-family:'Sora',-apple-system,BlinkMacSystemFont,sans-serif;
  background:var(--bg);
  color:var(--text);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  transition:background .3s,color .3s;
}
a{text-decoration:none;color:inherit;}
ul{list-style:none;}
img{max-width:100%;display:block;}
button{font-family:inherit;cursor:pointer;}
.wrap{max-width:1120px;margin:0 auto;padding:0 clamp(16px,3.5vw,36px);}

/* ─── REVEAL ─── */
.reveal,.reveal-l,.reveal-r{opacity:0;transition:opacity .7s var(--ease),transform .7s var(--ease);}
.reveal{transform:translateY(24px);}
.reveal-l{transform:translateX(-24px);}
.reveal-r{transform:translateX(24px);}
.reveal.on,.reveal-l.on,.reveal-r.on{opacity:1;transform:none;}

/* ─── TYPOGRAPHY ─── */
.h1{
  font-family:'DM Serif Display',Georgia,serif;
  font-size:clamp(2.4rem,5.2vw,4.4rem);
  line-height:1.05;
  font-weight:400;
  color:var(--text);
  letter-spacing:-.02em;
}
.h1 em{font-style:italic;color:var(--cyan2);}

.h2{
  font-family:'DM Serif Display',Georgia,serif;
  font-size:clamp(2.2rem,4vw,3.6rem);
  line-height:1.1;
  font-weight:400;
  color:var(--text);
  letter-spacing:-.02em;
}
.h2 em{font-style:italic;color:var(--cyan2);}

/* ─── LABEL PILLS ─── */
.label-pill{
  display:inline-flex;align-items:center;gap:6px;
  font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  padding:5px 13px;border-radius:100px;
  background:rgba(56,189,248,.1);
  color:var(--cyan2);
  border:1px solid rgba(56,189,248,.2);
}
.label-pill.purple{background:rgba(139,92,246,.1);color:#7c3aed;border-color:rgba(139,92,246,.2);}
.label-pill.pink{background:rgba(236,72,153,.1);color:#be185d;border-color:rgba(236,72,153,.2);}
.label-pill.teal{background:rgba(20,184,166,.1);color:#0f766e;border-color:rgba(20,184,166,.2);}
[data-theme="dark"] .label-pill.purple{color:#a78bfa;}
[data-theme="dark"] .label-pill.pink{color:#f472b6;}
[data-theme="dark"] .label-pill.teal{color:#2dd4bf;}

/* ─── TAGS ─── */
.tag{display:inline-flex;align-items:center;gap:4px;font-size:.62rem;font-weight:700;padding:3px 9px;border-radius:100px;white-space:nowrap;}
.tag-green {background:rgba(16,185,129,.12);color:#059669;}
.tag-blue  {background:rgba(14,165,233,.12);color:var(--cyan2);}
.tag-purple{background:rgba(139,92,246,.12);color:#7c3aed;}
.tag-orange{background:rgba(234,88,12,.12);color:#c2410c;}
[data-theme="dark"] .tag-green {background:rgba(16,185,129,.18);color:#34d399;}
[data-theme="dark"] .tag-blue  {background:rgba(56,189,248,.18);color:var(--cyan);}
[data-theme="dark"] .tag-purple{background:rgba(139,92,246,.18);color:#a78bfa;}
[data-theme="dark"] .tag-orange{background:rgba(251,146,60,.18);color:#fb923c;}

/* ─── BUTTONS ─── */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'Sora',sans-serif;font-weight:600;font-size:.88rem;
  padding:12px 24px;border-radius:100px;
  border:1.5px solid transparent;cursor:pointer;
  transition:all .22s var(--ease);white-space:nowrap;
}
.btn svg{width:14px;height:14px;flex-shrink:0;}
.btn-primary{background:var(--text);color:var(--bg);border-color:var(--text);}
.btn-primary:hover{background:var(--cyan2);border-color:var(--cyan2);color:#fff;transform:translateY(-1px);box-shadow:0 8px 24px rgba(14,165,233,.25);}
.btn-ghost{background:transparent;color:var(--text3);border-color:var(--border2);}
.btn-ghost:hover{color:var(--text);border-color:var(--text);background:var(--bg3);}

/* ─── LOGO ─── */
.logo-text{fill:var(--logo-fill);}
.logo-svg{height:34px;width:auto;}
.logo-svg-fallback{display:none;}

/* Logo image — show correct version per theme */
.logo-img{
  height:48px;
  width:auto;
  max-width:240px;
  object-fit:contain;
  display:block;
}
/* In light mode: show light version, hide dark */
.logo-img-dark{display:none;}
/* In dark mode: hide light, show dark (same file but we invert via filter if needed) */
[data-theme="dark"] .logo-img-light{display:none;}
[data-theme="dark"] .logo-img-dark{display:block;}
/* If logo img fails to load, show the SVG fallback */
.logo-img-light[style*="display:none"] ~ .logo-svg-fallback,
.logo-img-dark[style*="display:none"] ~ .logo-svg-fallback{display:block;}

/* ═══════════════════════
   HEADER
   ═══════════════════════ */
#hdr{
  position:fixed;top:0;left:0;right:0;z-index:200;
  padding-top:12px;
  transition:background .3s,border-color .3s,box-shadow .3s,padding-top .3s;
}
#hdr.scrolled{
  padding-top:0;
  background-color:rgba(255,255,255,.96);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border-bottom:1px solid var(--border);
  box-shadow:0 1px 24px rgba(0,0,0,.06);
}
[data-theme="dark"] #hdr.scrolled{
  background-color:rgba(10,22,40,.9);
  box-shadow:0 1px 40px rgba(0,0,0,.4);
}
.nav{display:flex;align-items:center;height:68px;gap:0;}
.nav-logo{margin-right:auto;}
.nav-links{display:flex;align-items:center;gap:2px;margin:0 auto;}
.nav-a{
  font-size:.85rem;font-weight:500;color:var(--text3);
  padding:7px 14px;border-radius:8px;
  transition:color .18s,background .18s;
}
.nav-a:hover{color:var(--text);background:var(--bg3);}

/* Producto link en nav — destacado con color índigo */
.nav-a-product{
  color:var(--indigo);font-weight:600;
  display:inline-flex;align-items:center;gap:7px;
}
.nav-a-product:hover{color:var(--indigo);background:rgba(99,102,241,.08);}
.mob-a-product{
  color:var(--indigo)!important;font-weight:700;
  display:flex;align-items:center;gap:8px;
}

/* Badge "Nuevo" en links de nav */
.nav-new-badge{
  display:inline-flex;align-items:center;
  font-size:.6rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;
  padding:2px 6px;border-radius:999px;
  background:var(--indigo);color:#fff;
  box-shadow:0 2px 6px rgba(99,102,241,.3);
  line-height:1;
  animation:nav-new-pulse 2.4s ease-in-out infinite;
}
@keyframes nav-new-pulse{
  0%,100%{box-shadow:0 2px 6px rgba(99,102,241,.3);}
  50%{box-shadow:0 2px 14px rgba(99,102,241,.55);}
}

.nav-end{display:flex;align-items:center;gap:8px;margin-left:auto;}
.nav-login{font-size:.85rem;font-weight:500;color:var(--text3);padding:7px 14px;border-radius:8px;transition:color .18s,background .18s;}
.nav-login:hover{color:var(--text);background:var(--bg3);}

/* ─── NAV PORTAL DROPDOWN ─── */
.nav-portal{position:relative;}
.nav-portal-btn{display:flex;align-items:center;gap:5px;font-size:.85rem;font-weight:500;color:var(--text3);padding:7px 14px;border-radius:8px;background:none;border:none;cursor:pointer;transition:color .18s,background .18s;font-family:inherit;}
.nav-portal-btn:hover{color:var(--text);background:var(--bg3);}
.nav-portal-btn svg{width:12px;height:12px;transition:transform .2s;}
.nav-portal.open .nav-portal-btn svg{transform:rotate(180deg);}
.nav-portal-menu{position:absolute;top:calc(100% + 8px);right:0;background:var(--card-bg,#fff);border:1px solid var(--border);border-radius:12px;padding:6px;min-width:220px;box-shadow:0 22px 50px rgba(15,23,42,.16),0 8px 16px rgba(15,23,42,.08);opacity:0;visibility:hidden;pointer-events:none;transform:translateY(-6px);transition:opacity .18s,transform .18s,visibility .18s;z-index:1000;}
.nav-portal-menu.left{right:auto;left:0;min-width:320px}
.nav-portal.open .nav-portal-menu{opacity:1 !important;visibility:visible !important;pointer-events:auto !important;transform:translateY(0) !important;}
.nav-portal-menu a{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;font-size:.85rem;font-weight:500;color:var(--text2);transition:background .15s,color .15s;text-decoration:none;}
.nav-portal-menu a:hover{background:var(--bg3);color:var(--text);}
.nav-portal-menu a svg{width:15px;height:15px;opacity:.6;flex-shrink:0;}
.nav-portal-menu a strong{display:block;color:var(--text);font-weight:600;font-size:.86rem;line-height:1.2;}
.nav-portal-menu a span.sub{display:block;font-size:.7rem;color:var(--text3);font-weight:500;letter-spacing:.01em;margin-top:1px;}
.nav-portal-menu hr{margin:5px 8px;border:0;border-top:1px solid var(--border);}

/* ─── LANGUAGE TOGGLE ─── */
.lang-toggle{display:flex;align-items:center;gap:6px;margin-left:12px;padding:7px 14px;border:none;border-radius:8px;background:none;cursor:pointer;font-family:inherit;font-size:.85rem;font-weight:500;color:var(--text3);transition:color .18s,background .18s;}
.lang-toggle:hover{color:var(--text);background:var(--bg3);}
.lang-globe{width:15px;height:15px;flex-shrink:0;opacity:.5;transition:opacity .18s;}
.lang-toggle:hover .lang-globe{opacity:.8;}
.lang-code{font-weight:500;letter-spacing:.02em;}

/* ─── THEME TOGGLE ─── */
.theme-toggle{
  display:flex;align-items:center;justify-content:center;
  width:36px;height:36px;border-radius:10px;
  background:var(--bg3);border:1px solid var(--border2);
  color:var(--text3);transition:all .2s;
}
.theme-toggle:hover{color:var(--text);border-color:var(--border2);}
.theme-toggle svg{width:16px;height:16px;}
.icon-moon{display:none;}
[data-theme="dark"] .icon-sun{display:none;}
[data-theme="dark"] .icon-moon{display:block;}

/* ─── HAMBURGER ─── */
.hamburger{display:none;flex-direction:column;gap:5px;padding:8px;background:none;border:none;}
.hamburger span{display:block;width:22px;height:1.5px;background:var(--text);border-radius:3px;transition:transform .28s,opacity .28s;}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px);}
.hamburger.open span:nth-child(2){opacity:0;}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);}

/* ─── MOB NAV ─── */
.mob-nav{display:none;position:fixed;inset:0;z-index:199;background:var(--bg);flex-direction:column;align-items:center;justify-content:center;gap:6px;}
.mob-nav.open{display:flex;}
.mob-a{font-family:'DM Serif Display',serif;font-size:2rem;font-style:italic;font-weight:400;color:var(--text3);padding:10px 28px;border-radius:12px;transition:color .18s;}
.mob-a:hover{color:var(--cyan2);}
.mob-close{position:absolute;top:22px;right:26px;background:none;border:none;color:var(--text4);font-size:1.5rem;cursor:pointer;}
.mob-close:hover{color:var(--text);}
.mob-portal{display:flex;flex-direction:column;align-items:stretch;gap:6px;margin-top:24px;width:min(280px,80vw);padding-top:18px;border-top:1px solid var(--border);}
.mob-portal-label{text-align:center;font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text4);margin-bottom:4px;}
.mob-portal-a{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:10px;background:var(--bg2);color:var(--text2);font-size:.95rem;font-weight:500;transition:background .18s,color .18s;}
.mob-portal-a:hover{background:var(--bg3);color:var(--text);}
.mob-portal-a svg{width:18px;height:18px;opacity:.7;}

/* ═══════════════════════
   HERO
   ═══════════════════════ */
.hero{
  min-height:100svh;display:flex;align-items:center;
  padding:110px 0 80px;position:relative;overflow:hidden;
}
.hero-copy{padding-top:20px;}
.hero::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 70% 60% at 70% -10%,rgba(56,189,248,.12) 0%,transparent 65%),
             radial-gradient(ellipse 40% 50% at 10% 90%,rgba(20,184,166,.07) 0%,transparent 60%);
}
[data-theme="dark"] .hero::before{
  background:radial-gradient(ellipse 70% 60% at 70% -10%,rgba(56,189,248,.15) 0%,transparent 65%),
             radial-gradient(ellipse 40% 50% at 10% 90%,rgba(20,184,166,.1) 0%,transparent 60%);
}
.hero-inner{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}

.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--text3);margin-bottom:28px;
}
.badge-dot{width:6px;height:6px;border-radius:50%;background:var(--cyan2);animation:pulse-dot 2.4s ease-in-out infinite;}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.4;transform:scale(1.5);}}

.h1-sub{display:block;font-size:.45em;font-weight:600;color:var(--text3);letter-spacing:.01em;margin-top:.35em;opacity:.7;font-style:normal;}
.hero-p{font-size:1.05rem;line-height:1.75;color:var(--text3);max-width:440px;margin:20px 0 36px;}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:36px;}
.hero-trust{display:flex;gap:22px;flex-wrap:wrap;}
.trust-item{display:flex;align-items:center;gap:6px;font-size:.78rem;color:var(--text4);font-weight:500;}
.trust-item svg{width:13px;height:13px;color:var(--cyan2);}

/* ─── MOCKUP ─── */
.hero-visual{position:relative;}
.mockup{
  background:var(--mock-bg);
  border:1px solid var(--card-border);
  border-radius:var(--r-2xl);
  box-shadow:0 24px 60px rgba(0,0,0,.08),0 4px 16px rgba(0,0,0,.04);
  overflow:hidden;
}
[data-theme="dark"] .mockup{box-shadow:0 32px 80px rgba(0,0,0,.5);}
.mock-bar{
  background:var(--bg3);
  border-bottom:1px solid var(--border);
  padding:12px 18px;display:flex;align-items:center;gap:10px;
}
.mock-dots{display:flex;gap:6px;}
.mock-dots span{width:10px;height:10px;border-radius:50%;}
.mock-dots span:nth-child(1){background:#ff5f57;}
.mock-dots span:nth-child(2){background:#ffbb2e;}
.mock-dots span:nth-child(3){background:#29c840;}
.mock-lbl{font-size:.63rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text4);margin:0 auto;}
.mock-rows{padding:14px;display:flex;flex-direction:column;gap:7px;}
.mock-row{
  display:flex;align-items:center;gap:11px;
  padding:11px 13px;
  background:var(--mock-row-bg);
  border:1px solid var(--border);
  border-radius:12px;
  transition:background .2s,border-color .2s;cursor:default;
}
.mock-row:hover{background:var(--mock-row-hover);border-color:rgba(56,189,248,.3);}
.mock-ico{width:34px;height:34px;border-radius:9px;background:var(--bg3);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.mock-ico img{width:20px;height:20px;object-fit:contain;}
.mock-body{flex:1;min-width:0;}
.mock-title{font-size:.8rem;font-weight:600;color:var(--text);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.mock-sub{font-size:.7rem;color:var(--text4);}

/* ─── FLOAT CARDS ─── */
.float-card{
  position:absolute;
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:var(--r-lg);
  box-shadow:0 12px 40px rgba(0,0,0,.1);
  padding:12px 16px;display:flex;align-items:center;gap:10px;white-space:nowrap;
  animation:float-y 4.5s ease-in-out infinite;
}
[data-theme="dark"] .float-card{box-shadow:0 16px 48px rgba(0,0,0,.5);}
@keyframes float-y{0%,100%{transform:translateY(0);}50%{transform:translateY(-8px);}}
.fc-top{top:-24px;right:-18px;animation-delay:0s;}
.fc-bottom{bottom:-20px;left:-22px;animation-delay:-2.2s;}
.fc-ico{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.fc-ico svg{width:14px;height:14px;}
.fc-ico.success{background:rgba(16,185,129,.12);color:#059669;}
.fc-ico.teal{background:rgba(20,184,166,.12);color:#0f766e;}
.fc-ico.alert{background:rgba(220,38,38,.12);color:#dc2626;}
[data-theme="dark"] .fc-ico.success{background:rgba(16,185,129,.2);color:#34d399;}
[data-theme="dark"] .fc-ico.teal{background:rgba(20,184,166,.2);color:#2dd4bf;}
[data-theme="dark"] .fc-ico.alert{background:rgba(220,38,38,.2);color:#f87171;}

/* Mock window footer — status bar */
.mock-footer{
  display:flex;align-items:center;gap:8px;
  padding:9px 14px;
  border-top:1px solid var(--border);
  background:#f8fafc;
  font-size:.72rem;color:var(--text3);font-weight:500;
  font-variant-numeric:tabular-nums;
}
.mock-status-dot{
  width:8px;height:8px;border-radius:50%;
  background:#10b981;
  box-shadow:0 0 0 3px rgba(16,185,129,.15);
  animation:mock-status-pulse 2.4s ease-in-out infinite;
  flex-shrink:0;
}
@keyframes mock-status-pulse{
  0%,100%{box-shadow:0 0 0 3px rgba(16,185,129,.15);}
  50%{box-shadow:0 0 0 6px rgba(16,185,129,.05);}
}
[data-theme="dark"] .mock-footer{background:rgba(255,255,255,.03);}
.fc-txt strong{display:block;font-size:.77rem;font-weight:700;color:var(--text);}
.fc-txt span{font-size:.68rem;color:var(--text4);}

/* ═══════════════════════
   TICKER
   ═══════════════════════ */
.clients-section{
  padding:48px 0;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  background:var(--bg2);
}
.clients-lbl{text-align:center;margin-bottom:24px;font-size:.68rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--text4);}
.ticker-outer{overflow:hidden;position:relative;}
.ticker-outer::before,.ticker-outer::after{content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none;}
.ticker-outer::before{left:0;background:linear-gradient(90deg,var(--bg2),transparent);}
.ticker-outer::after{right:0;background:linear-gradient(-90deg,var(--bg2),transparent);}
.ticker-belt{display:flex;align-items:center;animation:ticker-go 36s linear infinite;width:max-content;}

.ticker-item{
  display:flex;align-items:center;justify-content:center;
  height:96px;
  padding:0 36px;
  flex-shrink:0;
}
.ticker-item img{
  height:64px;
  width:auto;
  max-width:300px;
  object-fit:contain;
  /* Color but transparent background via mix-blend-mode */
  filter:opacity(.75);
  mix-blend-mode:multiply;
  transition:filter .3s ease;
}
/* Logos verticales (globo + texto apilado): mayor altura para igualar peso visual */
.ticker-item--tall img{
  height:92px;
  max-width:120px;
}
.ticker-item:hover img{
  filter:opacity(1);
}
[data-theme="dark"] .ticker-item img{
  filter:opacity(.6);
  mix-blend-mode:screen;
}
[data-theme="dark"] .ticker-item:hover img{
  filter:opacity(.9);
}

@keyframes ticker-go{from{transform:translateX(0);}to{transform:translateX(-33.333%);}}
/* 33.333% because we have 3 copies → scroll exactly 1 copy width */
/* ═══════════════════════
   SERVICES — feature rows
   ═══════════════════════ */
.feat-section{padding:120px 0;border-top:1px solid var(--border);}
.feat-section.alt{background:var(--bg2);}
.feat-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.feat-inner.rev{direction:rtl;}
.feat-inner.rev>*{direction:ltr;}

.feat-copy .label-pill{margin-bottom:20px;}
.feat-copy .h2{margin-bottom:18px;}
.feat-desc{font-size:.97rem;line-height:1.75;color:var(--text3);margin-bottom:28px;}

.feat-list{display:flex;flex-direction:column;gap:12px;margin-bottom:32px;}
.feat-list li{display:flex;align-items:flex-start;gap:10px;font-size:.88rem;color:var(--text2);line-height:1.55;font-weight:500;}
.check{width:18px;height:18px;border-radius:50%;background:rgba(14,165,233,.1);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;}
.check svg{width:9px;height:9px;color:var(--cyan2);}
[data-theme="dark"] .check{background:rgba(56,189,248,.13);}

/* Feature Card */
.feat-card{
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:var(--r-2xl);
  overflow:hidden;
  box-shadow:0 8px 32px rgba(0,0,0,.06),0 1px 4px rgba(0,0,0,.04);
}
[data-theme="dark"] .feat-card{box-shadow:0 24px 64px rgba(0,0,0,.45);}
.feat-card-hdr{
  padding:16px 18px;
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:10px;
  background:var(--bg2);
}
.fch-ico{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.fch-ico svg{width:16px;height:16px;}
.cyan-bg{background:rgba(14,165,233,.12);color:var(--cyan2);}
.purple-bg{background:rgba(139,92,246,.12);color:#7c3aed;}
.pink-bg{background:rgba(236,72,153,.12);color:#be185d;}
.teal-bg{background:rgba(20,184,166,.12);color:#0f766e;}
[data-theme="dark"] .cyan-bg{color:var(--cyan);}
[data-theme="dark"] .purple-bg{color:#a78bfa;}
[data-theme="dark"] .pink-bg{color:#f472b6;}
[data-theme="dark"] .teal-bg{color:#2dd4bf;}
.fch-title{font-size:.85rem;font-weight:700;color:var(--text);margin-bottom:2px;}
.fch-sub{font-size:.68rem;color:var(--text4);}

.feat-card-body{padding:12px 14px;display:flex;flex-direction:column;gap:6px;}
.feat-row{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:10px;
  border:1px solid var(--border);
  transition:background .2s,border-color .2s;
}
.feat-row:hover{background:var(--bg3);border-color:rgba(14,165,233,.2);}
.feat-row.dimmed{opacity:.45;}
.fr-ico{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.fr-ico svg{width:13px;height:13px;}
.cyan-ico{background:rgba(14,165,233,.1);color:var(--cyan2);}
.purple-ico{background:rgba(139,92,246,.1);color:#7c3aed;}
.blue-ico{background:rgba(99,102,241,.1);color:#4f46e5;}
.orange-ico{background:rgba(234,88,12,.1);color:#c2410c;}
.green-ico{background:rgba(16,185,129,.1);color:#059669;}
[data-theme="dark"] .cyan-ico{color:var(--cyan);}
[data-theme="dark"] .purple-ico{color:#a78bfa;}
[data-theme="dark"] .blue-ico{color:#818cf8;}
[data-theme="dark"] .orange-ico{color:#fb923c;}
[data-theme="dark"] .green-ico{color:#34d399;}
.fr-body{flex:1;min-width:0;}
.fr-body strong{display:block;font-size:.79rem;font-weight:600;color:var(--text);}
.fr-body span{font-size:.69rem;color:var(--text4);}

/* ═══════════════════════
   STATS
   ═══════════════════════ */
.stats-section{
  padding:100px 0;
  border-top:1px solid var(--border);
  background:var(--bg2);
}
.stats-eyebrow{text-align:center;margin-bottom:56px;}
.stats-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:var(--border);
  border:1px solid var(--border);
  border-radius:var(--r-2xl);overflow:hidden;
}
.stat-item{
  background:var(--card-bg);
  padding:52px 36px;
  display:flex;flex-direction:column;align-items:flex-start;
  transition:background .25s;
  position:relative;
  overflow:hidden;
}
.stat-item::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--cyan2),var(--teal));
  transform:scaleX(0);transform-origin:left;
  transition:transform .4s var(--ease);
}
.stat-item:hover::before{transform:scaleX(1);}
.stat-item:hover{background:var(--bg3);}

.stat-number{
  font-family:'DM Serif Display',serif;
  font-size:clamp(3rem,5vw,4.5rem);
  font-weight:400;line-height:1;
  color:var(--text);margin-bottom:10px;letter-spacing:-.02em;
}
.stat-number em{font-style:normal;color:var(--cyan2);}
.stat-label{font-size:.82rem;font-weight:500;color:var(--text3);line-height:1.5;margin-bottom:18px;}

.stat-bar{height:3px;background:var(--bg3);border-radius:100px;width:100%;margin-top:auto;}
.stat-bar-fill{height:100%;background:linear-gradient(90deg,var(--cyan2),var(--teal));border-radius:100px;width:0;transition:width 1.2s var(--ease);}
.stat-bar-fill.animated{width:var(--w,80%);}

.stat-stars{display:flex;gap:3px;margin-top:auto;}
.stat-stars svg{width:16px;height:16px;color:var(--cyan2);}

/* ═══════════════════════
   METHODOLOGY
   ═══════════════════════ */
.how-section{padding:120px 0;border-top:1px solid var(--border);}
.how-head{text-align:center;max-width:640px;margin:0 auto 80px;}
.how-desc{font-size:.97rem;color:var(--text3);line-height:1.75;margin-top:16px;}

.how-steps{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:var(--border);
  border:1px solid var(--border);
  border-radius:var(--r-2xl);overflow:hidden;
}
.how-step{
  background:var(--card-bg);
  padding:0;
  position:relative;
  transition:background .25s;
  display:flex;flex-direction:column;
  overflow:hidden;
}
.how-step:hover{background:var(--bg3);}
.how-step-num{
  font-family:'DM Serif Display',serif;
  font-size:4rem;font-weight:400;font-style:italic;
  color:var(--border2);
  padding:28px 28px 0;
  line-height:1;
  transition:color .3s;
}
.how-step:hover .how-step-num{color:rgba(14,165,233,.2);}
.how-step-body{padding:8px 28px 32px;flex:1;}
.how-step-icon{
  width:40px;height:40px;border-radius:12px;
  background:rgba(14,165,233,.1);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:16px;color:var(--cyan2);
  transition:background .3s,transform .3s;
}
.how-step:hover .how-step-icon{background:var(--cyan2);color:#fff;transform:scale(1.05);}
.how-step-icon svg{width:18px;height:18px;}
.how-step h3{font-size:1.05rem;font-weight:700;color:var(--text);margin-bottom:10px;}
.how-step p{font-size:.85rem;line-height:1.7;color:var(--text3);}
.how-step-details{
  display:flex;flex-direction:column;gap:5px;margin-top:20px;
  padding-top:16px;border-top:1px solid var(--border);
}
.how-step-details span{
  font-size:.72rem;font-weight:600;
  color:var(--cyan2);
  display:flex;align-items:center;gap:5px;
}
.how-step-details span::before{content:'→';opacity:.6;}

/* ═══════════════════════
   PRICING
   ═══════════════════════ */
.pricing-section{padding:120px 0;border-top:1px solid var(--border);background:var(--bg2);}
.pricing-head{text-align:center;margin-bottom:40px;}
.pricing-desc{font-size:.97rem;color:var(--text3);margin-top:12px;}

.billing-toggle{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:52px;}
.bill-lbl{font-size:.88rem;font-weight:500;color:var(--text4);transition:color .2s;}
.bill-lbl.active{color:var(--text);font-weight:600;}
.tog-wrap{position:relative;width:48px;height:26px;cursor:pointer;display:block;}
.tog-wrap input{opacity:0;width:0;height:0;position:absolute;}
.tog-track{position:absolute;inset:0;background:var(--bg3);border-radius:50px;border:1.5px solid var(--border2);transition:background .25s,border-color .25s;}
.tog-track::before{content:'';position:absolute;width:18px;height:18px;left:3px;bottom:3px;background:var(--text3);border-radius:50%;transition:transform .25s;box-shadow:0 1px 3px rgba(0,0,0,.2);}
.tog-wrap input:checked + .tog-track{background:var(--text);border-color:var(--text);}
.tog-wrap input:checked + .tog-track::before{transform:translateX(22px);background:#fff;}
.save-badge{background:rgba(14,165,233,.1);color:var(--cyan2);font-size:.7rem;font-weight:700;padding:4px 12px;border-radius:100px;border:1px solid rgba(14,165,233,.2);}

.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--r-2xl);overflow:hidden;}
.plan{background:var(--card-bg);padding:44px 40px;position:relative;transition:background .25s;}
.plan:hover{background:var(--bg);}
.plan.featured{background:var(--text);}
[data-theme="dark"] .plan.featured{background:rgba(14,165,233,.08);}
.plan.featured:hover{background:var(--text2);}
[data-theme="dark"] .plan.featured:hover{background:rgba(14,165,233,.12);}

.plan-badge{
  position:absolute;top:0;left:50%;transform:translateX(-50%);
  background:var(--cyan2);color:#fff;
  font-size:.6rem;font-weight:800;padding:5px 16px;border-radius:0 0 10px 10px;letter-spacing:.1em;text-transform:uppercase;
}
.plan-tier{font-size:.68rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--text4);margin-bottom:8px;}
.plan.featured .plan-tier{color:rgba(255,255,255,.5);}
[data-theme="dark"] .plan.featured .plan-tier{color:var(--cyan2);}
.plan-desc{font-size:.85rem;color:var(--text3);margin-bottom:28px;}
.plan.featured .plan-desc{color:rgba(255,255,255,.6);}

.plan-price{display:flex;align-items:baseline;gap:3px;margin-bottom:6px;}
.price-curr{font-size:1rem;font-weight:700;color:var(--text);align-self:flex-start;margin-top:10px;}
.plan.featured .price-curr{color:#fff;}
.price-val{font-family:'DM Serif Display',serif;font-size:3.5rem;line-height:1;font-weight:400;color:var(--text);letter-spacing:-.02em;}
.plan.featured .price-val{color:#fff;}
.price-val.custom{font-size:2.2rem;}
.price-per{font-size:.78rem;color:var(--text4);margin-left:4px;}
.plan.featured .price-per{color:rgba(255,255,255,.5);}
.plan-note{font-size:.75rem;color:var(--text4);margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--border);}
.plan.featured .plan-note{color:rgba(255,255,255,.4);border-bottom:1px solid rgba(255,255,255,.1);}

.plan-feats{margin-bottom:28px;display:flex;flex-direction:column;gap:11px;}
.plan-feats li{display:flex;align-items:flex-start;gap:9px;font-size:.85rem;color:var(--text2);line-height:1.4;font-weight:500;}
.plan.featured .plan-feats li{color:rgba(255,255,255,.8);}
.plan-feats li svg{width:14px;height:14px;color:var(--cyan2);flex-shrink:0;margin-top:2px;}
.plan.featured .plan-feats li svg{color:rgba(255,255,255,.7);}

.plan-btn{
  display:block;width:100%;text-align:center;padding:13px;border-radius:100px;
  font-weight:700;font-size:.88rem;font-family:'Sora',sans-serif;
  border:1.5px solid var(--border2);background:transparent;
  color:var(--text2);cursor:pointer;transition:all .22s var(--ease);
}
.plan-btn:hover{border-color:var(--text);color:var(--text);background:var(--bg3);}
.plan-btn.primary{background:#fff;color:var(--text);border-color:transparent;}
.plan-btn.primary:hover{background:var(--cyan2);color:#fff;box-shadow:0 6px 20px rgba(14,165,233,.3);}

/* ═══════════════════════
   TESTIMONIALS
   ═══════════════════════ */
.testi-section{padding:120px 0;border-top:1px solid var(--border);}
.testi-head{text-align:center;margin-bottom:56px;}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--r-2xl);overflow:hidden;}
.testi-card{background:var(--card-bg);padding:40px;display:flex;flex-direction:column;transition:background .25s;}
.testi-card:hover{background:var(--bg3);}
.testi-stars{display:flex;gap:3px;margin-bottom:20px;}
.testi-stars svg{width:14px;height:14px;color:var(--cyan2);}
.testi-text{font-size:.93rem;line-height:1.8;color:var(--text2);font-style:italic;flex:1;margin-bottom:24px;}
.testi-author{display:flex;align-items:center;gap:12px;padding-top:20px;border-top:1px solid var(--border);}
.testi-av{
  width:40px;height:40px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--cyan2),var(--teal));
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:.72rem;color:#fff;overflow:hidden;
}
.testi-info strong{display:block;font-size:.84rem;font-weight:700;color:var(--text);}
.testi-info span{font-size:.72rem;color:var(--text4);}

/* ═══════════════════════
   FAQ
   ═══════════════════════ */
.faq-section{padding:120px 0;border-top:1px solid var(--border);background:var(--bg2);}
.faq-inner{display:grid;grid-template-columns:1fr 1.6fr;gap:80px;align-items:start;}
.faq-sub{font-size:.95rem;color:var(--text3);line-height:1.7;margin-top:12px;}

.faq-list{
  border:1px solid var(--border);
  border-radius:var(--r-xl);overflow:hidden;
  background:var(--card-bg);
}
.faq-item{border-bottom:1px solid var(--border);}
.faq-item:last-child{border-bottom:none;}
.faq-q{
  width:100%;background:none;border:none;cursor:pointer;
  padding:22px 26px;display:flex;align-items:center;justify-content:space-between;gap:20px;text-align:left;
  transition:background .2s;
}
.faq-q:hover{background:var(--bg3);}
.faq-item.open .faq-q{background:var(--bg2);}
.faq-q span:first-child{font-size:.92rem;font-weight:600;color:var(--text);line-height:1.4;}
.faq-ico{width:28px;height:28px;border-radius:50%;border:1.5px solid var(--border2);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text4);transition:all .25s;}
.faq-ico svg{width:12px;height:12px;transition:transform .3s;}
.faq-item.open .faq-ico{background:var(--text);border-color:var(--text);color:#fff;}
.faq-item.open .faq-ico svg{transform:rotate(180deg);}
.faq-a{display:none;padding:0 26px 22px;font-size:.88rem;color:var(--text3);line-height:1.75;}
.faq-item.open .faq-a{display:block;}

/* ═══════════════════════
   CTA
   ═══════════════════════ */
.cta-section{padding:120px 0;border-top:1px solid var(--border);}
.cta-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.cta-copy .h2{margin-top:20px;margin-bottom:16px;}
.cta-desc{font-size:.97rem;color:var(--text3);line-height:1.75;}

.cta-actions{display:flex;flex-direction:column;gap:10px;}
.cta-btn{
  display:flex;align-items:center;gap:14px;
  padding:18px 22px;border-radius:var(--r-lg);
  border:1.5px solid var(--border2);
  background:var(--card-bg);
  transition:all .22s var(--ease);
}
.cta-btn:hover{border-color:var(--text);transform:translateX(4px);}
.cta-btn.primary{background:var(--text);border-color:var(--text);}
.cta-btn.primary:hover{background:var(--cyan2);border-color:var(--cyan2);}
.cta-btn-icon{
  width:44px;height:44px;border-radius:10px;
  background:var(--bg3);display:flex;align-items:center;justify-content:center;
  flex-shrink:0;color:var(--text3);
}
.cta-btn.primary .cta-btn-icon{background:rgba(255,255,255,.15);color:#fff;}
.cta-btn-icon svg{width:18px;height:18px;}
.cta-btn-icon.whatsapp{background:rgba(37,211,102,.1);color:#25d366;}
.cta-btn-icon.calendar{background:rgba(14,165,233,.1);color:var(--cyan2);}
.cta-btn div strong{display:block;font-size:.92rem;font-weight:700;color:var(--text);}
.cta-btn div span{font-size:.78rem;color:var(--text4);}
.cta-btn.primary div strong{color:#fff;}
.cta-btn.primary div span{color:rgba(255,255,255,.6);}
.cta-arrow{width:16px;height:16px;color:var(--text4);margin-left:auto;flex-shrink:0;transition:transform .2s,color .2s;}
.cta-btn:hover .cta-arrow{transform:translateX(3px);color:var(--text3);}
.cta-btn.primary .cta-arrow{color:rgba(255,255,255,.5);}
.cta-btn.primary:hover .cta-arrow{color:rgba(255,255,255,.8);}

/* ── Email card CTA ── */
.cta-email-card{
  display:block;
  position:relative;
  border-radius:16px;
  overflow:hidden;
  text-decoration:none;
  border:1.5px solid var(--border2);
  transition:transform .28s var(--ease), box-shadow .28s var(--ease), border-color .28s;
  background:var(--card-bg);
}
.cta-email-card:hover{
  transform:translateY(-4px);
  box-shadow:0 24px 48px rgba(0,0,0,.12);
  border-color:var(--cyan2);
}
.cta-email-bg{
  position:absolute;inset:0;
  background:linear-gradient(135deg, rgba(56,182,232,.06) 0%, transparent 60%);
  pointer-events:none;
}
.cta-email-content{padding:22px 24px;}
.cta-email-top{
  display:flex;align-items:center;gap:10px;
  margin-bottom:18px;
  padding-bottom:14px;
  border-bottom:1px solid var(--border);
}
.cta-email-dots{display:flex;gap:6px;}
.cta-email-dots span{width:11px;height:11px;border-radius:50%;display:block;}
.cta-email-label{
  font-size:.62rem;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--text4);margin-left:4px;
}
.cta-email-fields{margin-bottom:14px;}
.cta-email-field{
  font-size:.8rem;color:var(--text3);padding:5px 0;
  border-bottom:1px solid var(--border);
  display:flex;gap:8px;
}
.cta-email-field span{
  color:var(--text4);font-weight:600;min-width:54px;font-size:.75rem;
}
.cta-email-body{
  font-size:.83rem;color:var(--text4);line-height:1.7;
  min-height:52px;padding:6px 0 18px;
  font-style:italic;
}
.cta-email-send{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:14px;border-top:1px solid var(--border);
}
.cta-email-send-btn{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--text);color:#fff;
  padding:9px 20px;border-radius:100px;
  font-size:.8rem;font-weight:700;
  transition:background .2s, transform .2s;
}
.cta-email-send-btn svg{width:13px;height:13px;}
.cta-email-card:hover .cta-email-send-btn{
  background:var(--cyan2);
  transform:translateX(2px);
}
.cta-email-hint{font-size:.72rem;color:var(--text4);}

/* ═══════════════════════
   FOOTER
   ═══════════════════════ */
footer{border-top:1px solid var(--border);padding:72px 0 32px;background:var(--bg2);}
.footer-top{display:grid;grid-template-columns:1.4fr .9fr .9fr .9fr 1.9fr;gap:32px;margin-bottom:48px;}
.footer-brand p{font-size:.83rem;line-height:1.7;color:var(--text4);max-width:220px;margin-top:14px;}
.footer-col h5{font-size:.65rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--text4);margin-bottom:16px;}
.footer-col li{margin-bottom:9px;}
.footer-col li a{font-size:.83rem;color:var(--text3);transition:color .18s;}
.footer-col li a:hover{color:var(--text);}
.footer-nap address{font-style:normal;font-size:.82rem;line-height:1.75;color:var(--text3);margin-bottom:10px;white-space:nowrap;}
.footer-nap address strong{color:var(--text2);font-weight:600;}
.footer-hours{font-size:.78rem;color:var(--text4);margin:0 0 8px;white-space:nowrap;}
.footer-area{font-size:.78rem;color:var(--text4);margin:0;font-style:italic;}
.footer-bottom{border-top:1px solid var(--border);padding-top:24px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;font-size:.77rem;color:var(--text4);}
.footer-legal{display:flex;gap:18px;}
.footer-legal a{font-size:.77rem;color:var(--text4);transition:color .18s;}
.footer-legal a:hover{color:var(--text3);}

/* ═══════════════════════
   RESPONSIVE — sistema multi-breakpoint para soportar zoom in/out
   en desktop. Más breakpoints intermedios = transiciones suaves.
   ═══════════════════════ */

/* Tablet-landscape grande (1024-1280px) — ajustes finos */
@media(max-width:1280px){
  .hero-inner{gap:32px;}
}

/* Tablet landscape (900-1024px) — grids empiezan a colapsar */
@media(max-width:1024px){
  .plans{grid-template-columns:1fr;}
  .stats-grid{grid-template-columns:1fr 1fr;}
  .testi-grid{grid-template-columns:1fr;}
  .how-steps{grid-template-columns:1fr 1fr;}
  .cta-inner{grid-template-columns:1fr;}
}

/* Tablet portrait (768-900px) — hero pasa a 1 col mockup pero todavía 2 col en algunas grids */
@media(max-width:900px){
  .nav-links,.nav-login,.nav-cta,.nav-portal{display:none;}
  .hamburger{display:flex;}
  .hero-inner{grid-template-columns:1fr;gap:0;}
  .hero-visual{display:none;}
  .feat-inner,.feat-inner.rev{grid-template-columns:1fr;direction:ltr;}
  .feat-inner .feat-card{display:none;}
  .aiops-mockup-col{display:none;}
  .aiops-inner{grid-template-columns:1fr;}
  #aiops-section>.wrap{max-width:1120px;margin:0 auto;}
  .faq-inner{grid-template-columns:1fr;}
  .footer-top{grid-template-columns:1fr 1fr;}
}

/* Mobile landscape / tablet small (640-768px) — ajustes mid */
@media(max-width:768px){
  .h1{line-height:1.1;}
}

/* Mobile (480-640px) */
@media(max-width:640px){
  .stats-grid{grid-template-columns:1fr 1fr;}
  .how-steps{grid-template-columns:1fr;}
  .footer-top{grid-template-columns:1fr;}
  .footer-bottom{flex-direction:column;text-align:center;}
  .footer-legal{justify-content:center;}
  .hero-ctas{flex-direction:column;}
  .feat-section,.how-section,.pricing-section,.testi-section,.faq-section,.cta-section{padding:64px 0;}
  .hero{padding:80px 0 48px;}
  footer{padding:48px 0 24px;}
  .feat-inner{gap:40px;}
}

/* Legales: sin hamburger en mobile → mantenemos nav-links visibles en compacto */
@media(max-width:900px){
  body.legal-body-page .nav-links{display:flex !important;gap:6px;flex-wrap:wrap;justify-content:flex-end;}
  body.legal-body-page .nav-links .nav-a{padding:4px 8px;font-size:.78rem;}
  body.legal-body-page .nav-links .nav-cta{padding:6px 12px;font-size:.78rem;}
}

/* ═══════════════════════
   CREATIVE FEATURE CARDS v2
   ═══════════════════════ */

/* ── Shared card elements ── */
.card-accent-bar{height:3px;width:100%;}

.product-badge{
  display:inline-flex;align-items:center;gap:7px;
  font-size:.7rem;font-weight:700;letter-spacing:.06em;
  padding:5px 12px;border-radius:100px;color:#fff;
}
.pa-badge{background:linear-gradient(135deg,#0052cc,#0066FF);}
.apps-badge{background:linear-gradient(135deg,#5e1f5e,#742774);}
.bi-badge{background:linear-gradient(135deg,#c9a800,#F2C811);color:#1a1100;}
.arch-badge{background:linear-gradient(135deg,#0f766e,#14b8a6);}

.live-indicator{
  display:flex;align-items:center;gap:6px;margin-left:auto;
  font-size:.72rem;font-weight:600;color:#059669;
}
.live-dot{width:6px;height:6px;border-radius:50%;background:#10b981;animation:pulse-live 2s ease-in-out infinite;}
@keyframes pulse-live{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(16,185,129,.4);}50%{opacity:.8;box-shadow:0 0 0 5px rgba(16,185,129,0);}}

/* Power Automate header */
.pa-hdr,.apps-hdr,.bi-hdr,.arch-hdr{
  padding:14px 18px;
  display:flex;align-items:center;gap:10px;
  background:var(--bg2);
  border-bottom:1px solid var(--border);
}

.bi-updated{
  display:flex;align-items:center;gap:6px;margin-left:auto;
  font-size:.72rem;font-weight:500;color:var(--text4);
}
.bi-dot{background:#F2C811;}

.arch-scope{
  font-size:.7rem;color:var(--text4);margin-left:auto;
  font-family:monospace;
}

/* ── Flow title area (Power Automate) ── */
.flow-title-area{
  padding:14px 18px 10px;
  border-bottom:1px solid var(--border);
}
.flow-name{font-size:.9rem;font-weight:700;color:var(--text);}
.flow-meta{font-size:.7rem;color:var(--text4);margin-top:3px;}

/* ── Flow steps with connectors ── */
.flow-steps{display:flex;flex-direction:column;gap:0;padding:10px 14px 14px;}
.flow-step{
  display:flex;align-items:center;gap:10px;
  padding:9px 10px;border-radius:10px;
  border:1px solid var(--border);
  margin-bottom:6px;
  position:relative;
  transition:background .2s,border-color .2s;
}
.flow-step:hover{background:var(--bg3);}
.flow-step.pending{opacity:.55;}

.step-node{
  width:20px;height:20px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
}
.step-node svg{width:10px;height:10px;}
.done-node{background:#10b981;}
.pending-node{background:var(--bg3);border:1.5px solid var(--border2);color:var(--text4);}

.step-ico{
  width:28px;height:28px;border-radius:7px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.step-ico svg{width:13px;height:13px;}
.step-body{flex:1;min-width:0;}
.step-body strong{display:block;font-size:.79rem;font-weight:600;color:var(--text);}
.step-body span{font-size:.68rem;color:var(--text4);}

.mini-tag{font-size:.6rem;font-weight:800;padding:2px 8px;border-radius:100px;white-space:nowrap;}
.ai-tag{background:rgba(139,92,246,.12);color:#7c3aed;}
.teams-tag{background:rgba(80,89,201,.12);color:#5059C9;}
.pending-tag{background:rgba(234,88,12,.1);color:#c2410c;}

/* ── Power Apps tabs ── */
.apps-new-badge{
  margin-left:auto;
  font-size:.62rem;font-weight:800;letter-spacing:.06em;
  padding:4px 10px;border-radius:100px;
  background:linear-gradient(135deg,#742774,#9E2E9E);
  color:#fff;
}

/* ── App tabs (interactive) ── */
.app-type-tabs{
  display:flex;border-bottom:1px solid var(--border);
  background:var(--bg2);
  overflow-x:auto;
  scrollbar-width:none;
}
.app-type-tabs::-webkit-scrollbar{display:none;}

.app-tab{
  display:flex;align-items:center;gap:5px;
  padding:11px 15px;font-size:.72rem;font-weight:600;
  color:var(--text4);cursor:pointer;white-space:nowrap;
  border:none;background:none;font-family:'Sora',sans-serif;
  border-bottom:2px solid transparent;
  position:relative;
  transition:color .2s,border-color .2s,background .2s;
}
.app-tab svg{transition:color .2s;}
.app-tab:hover{color:var(--text2);background:rgba(116,39,116,.04);}
.app-tab.active-tab{
  color:#742774;
  border-bottom-color:#742774;
  background:rgba(116,39,116,.05);
}
.app-tab.active-tab svg{color:#742774;}
[data-theme="dark"] .app-tab.active-tab{color:#c084fc;border-bottom-color:#c084fc;background:rgba(192,132,252,.06);}
[data-theme="dark"] .app-tab.active-tab svg{color:#c084fc;}

/* ── Apps panels ── */
.apps-panels{position:relative;overflow:hidden;}
.apps-panel{
  display:none;
  padding:14px 16px 16px;
  animation:panel-in .28s cubic-bezier(.16,1,.3,1);
  flex-direction:column;
  gap:8px;
}
.apps-panel.active-panel{display:flex;}
@keyframes panel-in{
  from{opacity:0;transform:translateY(8px);}
  to{opacity:1;transform:none;}
}

/* Panel intro block */
.panel-intro{
  padding:10px 14px 12px;
  border-radius:10px;
  background:var(--bg3);
  border:1px solid var(--border);
  margin-bottom:10px;
}
.panel-eyebrow{
  display:inline-block;
  font-size:.64rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  color:var(--text4);margin-bottom:5px;
}
.new-eyebrow{color:#742774;}
[data-theme="dark"] .new-eyebrow{color:#c084fc;}
.panel-desc{
  font-size:.8rem;line-height:1.6;color:var(--text3);
}

.apps-panels .feat-card-body{gap:8px;}
.apps-panel .feat-row{margin-bottom:8px;}
.apps-panel .feat-row:last-child{margin-bottom:0;}
.apps-row,.bi-row,.arch-row{
  background:var(--bg2);
  border-color:var(--border);
  transition:background .2s,border-color .2s;
}
.apps-row:hover{background:var(--bg3);border-color:rgba(116,39,116,.25);}
.bi-row:hover{background:var(--bg3);border-color:rgba(242,200,17,.3);}
.arch-row:hover{background:var(--bg3);border-color:rgba(20,184,166,.25);}

/* check-circle (green check badge) */
.check-circle{
  width:22px;height:22px;border-radius:50%;
  background:#10b981;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  color:#fff;
}
.check-circle svg{width:10px;height:10px;}

/* ── Power BI chart area ── */
.bi-chart-area{
  padding:16px 18px;
  border-bottom:1px solid var(--border);
  background:var(--bg2);
}
.bi-chart-label{font-size:.72rem;font-weight:700;color:var(--text3);margin-bottom:12px;text-transform:uppercase;letter-spacing:.08em;}
.bi-chart-bars{
  display:flex;align-items:flex-end;gap:6px;
  height:60px;margin-bottom:14px;
  position:relative;
}
.bi-bar-group{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;height:100%;}
.bi-bar{
  width:100%;border-radius:3px 3px 0 0;
  height:var(--h);
  background:var(--c);
  transition:height 1s cubic-bezier(.16,1,.3,1);
  opacity:.85;
  margin-top:auto;
}
.bi-bar:hover{opacity:1;}
.bi-bar-sub{font-size:.6rem;color:var(--text4);font-weight:600;}
.bi-kpi-row{display:flex;align-items:center;gap:0;padding-top:12px;border-top:1px solid var(--border);}
.bi-kpi{flex:1;text-align:center;}
.bi-kpi-val{display:block;font-size:.95rem;font-weight:800;color:var(--text);font-family:'DM Serif Display',serif;}
.bi-kpi-val.up{color:#059669;}
.bi-kpi-lbl{font-size:.65rem;color:var(--text4);font-weight:500;}
.bi-kpi-divider{width:1px;height:28px;background:var(--border);}

/* ── Architecture score area ── */
.arch-score-area{
  display:flex;gap:18px;align-items:flex-start;
  padding:16px 18px;border-bottom:1px solid var(--border);
  background:var(--bg2);
}
.arch-score-left{flex:0 0 auto;}
.arch-score-num{
  font-family:'DM Serif Display',serif;
  font-size:3rem;font-weight:400;line-height:1;
  color:#14b8a6;
}
.arch-score-lbl{font-size:.68rem;font-weight:600;color:var(--text4);margin-bottom:8px;text-transform:uppercase;letter-spacing:.08em;}
.arch-score-bar{height:4px;background:var(--bg3);border-radius:100px;width:80px;}
.arch-score-fill{height:100%;border-radius:100px;transition:width 1.2s cubic-bezier(.16,1,.3,1);}
.arch-score-items{display:flex;flex-direction:column;gap:6px;flex:1;}
.arch-score-item{
  display:flex;align-items:center;gap:7px;
  font-size:.75rem;font-weight:600;
  padding:5px 10px;border-radius:8px;
}
.arch-score-item svg{width:12px;height:12px;flex-shrink:0;}
.arch-score-item.ok{background:rgba(16,185,129,.08);color:#059669;}
.arch-score-item.warn{background:rgba(234,88,12,.08);color:#c2410c;}
[data-theme="dark"] .arch-score-item.ok{background:rgba(16,185,129,.12);color:#34d399;}
[data-theme="dark"] .arch-score-item.warn{background:rgba(234,88,12,.12);color:#fb923c;}

/* ═══════════════════════
   METHODOLOGY v2 — Interactive
   ═══════════════════════ */

.how-section{padding:100px 0;background:var(--bg);}
.how-head{text-align:center;max-width:600px;margin:0 auto 60px;}
.how-desc{font-size:1.05rem;color:var(--text3);margin-top:16px;line-height:1.7;}

/* Two-column layout */
.meto-layout{
  display:grid;
  grid-template-columns:320px 1fr;
  gap:0;
  border:1px solid var(--border);
  border-radius:20px;
  overflow:hidden;
  background:var(--bg);
  box-shadow:0 4px 40px rgba(0,0,0,.06);
}

/* ── Left nav ── */
.meto-nav{
  background:var(--bg2);
  border-right:1px solid var(--border);
  display:flex;
  flex-direction:column;
  padding:8px;
  gap:0;
}

.meto-nav-item{
  display:flex;align-items:center;gap:14px;
  padding:16px 14px;border-radius:12px;
  cursor:pointer;
  transition:background .2s;
  position:relative;
}
.meto-nav-item:hover{background:var(--bg3);}
.meto-nav-item.active{background:var(--bg);box-shadow:0 2px 12px rgba(0,0,0,.06);}

.meto-nav-num{
  font-family:'DM Serif Display',serif;
  font-size:1.3rem;font-weight:400;
  color:var(--text4);
  flex-shrink:0;width:28px;text-align:center;
  transition:color .2s;
}
.meto-nav-item.active .meto-nav-num{color:var(--cyan2);}

.meto-nav-info{flex:1;min-width:0;}
.meto-nav-info strong{display:block;font-size:.83rem;font-weight:700;color:var(--text);line-height:1.3;}
.meto-nav-info span{font-size:.72rem;color:var(--text4);}

.meto-nav-arrow{color:var(--border2);transition:color .2s,transform .2s;}
.meto-nav-arrow svg{width:14px;height:14px;}
.meto-nav-item.active .meto-nav-arrow{color:var(--cyan2);transform:none;}

/* Progress connector between steps */
.meto-progress-bar{
  width:2px;height:24px;
  background:var(--border);
  margin:0 0 0 28px;
  border-radius:100px;
  overflow:hidden;
  flex-shrink:0;
}
.meto-progress-fill{
  width:100%;height:0%;
  background:linear-gradient(180deg,var(--cyan2),var(--teal));
  transition:height .6s cubic-bezier(.16,1,.3,1);
  border-radius:100px;
}

/* ── Right panels ── */
.meto-panels{position:relative;min-height:420px;}
.meto-panel{
  display:none;
  padding:40px 44px;
  animation:meto-in .32s cubic-bezier(.16,1,.3,1);
}
.meto-panel.active-panel{display:block;}
@keyframes meto-in{
  from{opacity:0;transform:translateY(12px);}
  to{opacity:1;transform:none;}
}

.meto-panel-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;}

.meto-icon-wrap{
  width:52px;height:52px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
}
.meto-icon-wrap svg{width:22px;height:22px;}

.meto-duration{
  display:flex;align-items:center;gap:7px;
  font-size:.75rem;font-weight:600;color:var(--text4);
  background:var(--bg2);border:1px solid var(--border);
  padding:6px 14px;border-radius:100px;
}
.meto-duration svg{width:13px;height:13px;}

.meto-title{
  font-family:'DM Serif Display',serif;
  font-size:1.8rem;font-weight:400;
  color:var(--text);margin-bottom:12px;
}

.meto-desc{
  font-size:.93rem;line-height:1.75;
  color:var(--text3);margin-bottom:28px;
}

.meto-deliverables{display:flex;flex-direction:column;gap:10px;margin-bottom:28px;}
.meto-dlv{
  display:flex;align-items:center;gap:10px;
  font-size:.85rem;color:var(--text2);
}
.meto-dlv svg{
  width:16px;height:16px;flex-shrink:0;
  color:#10b981;
  background:rgba(16,185,129,.1);
  border-radius:50%;padding:2px;
}

.meto-output{
  display:flex;align-items:center;gap:12px;
  padding:14px 18px;
  background:var(--bg2);border:1px solid var(--border);
  border-radius:12px;
}
.meto-output-lbl{
  font-size:.65rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  color:var(--text4);white-space:nowrap;
}
.meto-output-val{
  font-size:.83rem;font-weight:600;color:var(--text);
}

/* Bottom CTA strip */
.meto-cta{
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;
  margin-top:32px;
  padding:28px 36px;
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:16px;
}
.meto-cta-text{display:flex;flex-direction:column;gap:4px;}
.meto-cta-text strong{font-size:1rem;font-weight:700;color:var(--text);}
.meto-cta-text span{font-size:.83rem;color:var(--text4);}

/* Responsive */
@media(max-width:860px){
  .meto-layout{grid-template-columns:1fr;}
  .meto-nav{border-right:none;border-bottom:1px solid var(--border);flex-direction:row;flex-wrap:wrap;padding:12px;}
  .meto-nav-item{flex:1;min-width:140px;}
  .meto-progress-bar{display:none;}
  .meto-panel{padding:28px 24px;}
  .meto-cta{flex-direction:column;text-align:center;}
}
@media(max-width:520px){
  .meto-nav-item{min-width:100%;}
  .meto-nav-arrow{display:none;}
}

/* ═══════════════════════
   NEXO CHATBOT WIDGET
   Brand: #1a3a6b (navy) + #38b6e8 (cyan)
   ═══════════════════════ */

/* Brand tokens */
:root{
  --nexo-navy:  #1a3a6b;
  --nexo-blue:  #1e5fa8;
  --nexo-cyan:  #38b6e8;
  --nexo-light: #e8f4fb;
}

#chat-widget{
  position:fixed;
  bottom:28px;right:28px;
  z-index:1000;
  font-family:'Sora',sans-serif;
}

/* ── Bubble ── */
#chat-bubble{
  width:60px;height:60px;border-radius:50%;
  background:linear-gradient(145deg,#1a3a6b 0%,#1e5fa8 50%,#38b6e8 100%);
  border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(26,58,107,.45), 0 1px 4px rgba(0,0,0,.15);
  transition:transform .25s var(--ease),box-shadow .25s var(--ease);
  position:relative;z-index:2;
}
#chat-bubble:hover{
  transform:scale(1.07);
  box-shadow:0 8px 28px rgba(26,58,107,.5), 0 2px 8px rgba(56,182,232,.3);
}
#chat-bubble:active{transform:scale(.95);}

.chat-bubble-icon{
  position:absolute;
  display:flex;align-items:center;justify-content:center;
  transition:opacity .22s,transform .28s var(--ease);
}
.chat-bubble-icon svg{width:26px;height:26px;}
.chat-icon-close{opacity:0;transform:rotate(-90deg) scale(.6);}

#chat-widget.is-open #chat-bubble{
  background:linear-gradient(145deg,#334155,#475569);
  box-shadow:0 4px 16px rgba(0,0,0,.25);
}
#chat-widget.is-open .chat-icon-open{opacity:0;transform:rotate(80deg) scale(.6);}
#chat-widget.is-open .chat-icon-close{opacity:1;transform:rotate(0) scale(1);}

/* Ping dot */
.chat-bubble-ping{
  position:absolute;top:3px;right:3px;
  width:11px;height:11px;border-radius:50%;
  background:#38b6e8;
  border:2px solid white;
  animation:nexo-ping 2.2s ease-in-out infinite;
}
#chat-widget.is-open .chat-bubble-ping{display:none;}
@keyframes nexo-ping{
  0%,100%{box-shadow:0 0 0 0 rgba(56,182,232,.55);}
  50%{box-shadow:0 0 0 6px rgba(56,182,232,0);}
}

/* Bubble icon breathe */
.chat-icon-open svg{
  animation:nexo-breathe 4s ease-in-out infinite;
  transform-origin:center;
}
@keyframes nexo-breathe{
  0%,100%{transform:scale(1);}
  50%{transform:scale(1.1);}
}
#chat-widget.is-open .chat-icon-open svg{animation:none;}

/* ── Window ── */
#chat-window{
  position:absolute;
  bottom:74px;right:0;
  width:368px;
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:20px;
  box-shadow:0 24px 64px rgba(0,0,0,.15),0 4px 20px rgba(0,0,0,.08);
  display:flex;flex-direction:column;
  overflow:hidden;
  opacity:0;
  transform:translateY(18px) scale(.96);
  pointer-events:none;
  transition:opacity .3s var(--ease),transform .3s var(--ease);
  max-height:540px;
}
#chat-widget.is-open #chat-window{
  opacity:1;transform:translateY(0) scale(1);pointer-events:all;
}

/* ── Header ── */
.chat-header{
  display:flex;align-items:center;gap:11px;
  padding:14px 16px;
  background:linear-gradient(135deg, var(--nexo-navy) 0%, var(--nexo-blue) 60%, var(--nexo-cyan) 100%);
  flex-shrink:0;
}
.chat-header-avatar{
  width:40px;height:40px;flex-shrink:0;
  border-radius:10px;overflow:hidden;
  border:1.5px solid rgba(255,255,255,.25);
  box-shadow:0 2px 8px rgba(0,0,0,.2);
}
.chat-header-avatar svg{width:100%;height:100%;display:block;}
.chat-header-info{flex:1;min-width:0;}
.chat-header-info strong{
  display:flex;align-items:center;gap:6px;
  font-size:.78rem;font-weight:700;color:#fff;
  letter-spacing:.01em;
}
.nexo-badge{
  font-size:.5rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;
  background:rgba(255,255,255,.2);
  color:rgba(255,255,255,.9);
  padding:2px 6px;border-radius:100px;
  border:1px solid rgba(255,255,255,.25);
}
.chat-header-info span{
  font-size:.6rem;color:rgba(255,255,255,.75);
  display:flex;align-items:center;gap:5px;margin-top:3px;
}
.chat-status-dot{
  width:6px;height:6px;border-radius:50%;
  background:#7dd3fc;display:inline-block;
  animation:nexo-ping 2.2s ease-in-out infinite;
}
.chat-header-actions{display:flex;align-items:center;gap:4px;flex-shrink:0;}
.chat-hdr-btn{
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.15);
  width:30px;height:30px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:rgba(255,255,255,.85);
  transition:background .2s,color .2s;
}
.chat-hdr-btn:hover{background:rgba(255,255,255,.22);color:#fff;}
.chat-hdr-btn svg{width:14px;height:14px;}

/* ── Messages ── */
.chat-messages{
  flex:1;overflow-y:auto;
  padding:16px 14px 8px;
  display:flex;flex-direction:column;gap:10px;
  scroll-behavior:smooth;
}
.chat-messages::-webkit-scrollbar{width:4px;}
.chat-messages::-webkit-scrollbar-track{background:transparent;}
.chat-messages::-webkit-scrollbar-thumb{background:var(--border2);border-radius:100px;}

.chat-msg{display:flex;flex-direction:column;gap:3px;max-width:88%;}
.chat-msg.bot{align-self:flex-start;}
.chat-msg.user{align-self:flex-end;align-items:flex-end;}

.chat-msg-bubble{
  padding:10px 14px;
  border-radius:16px;
  font-size:.74rem;line-height:1.65;
}
.chat-msg.bot .chat-msg-bubble{
  background:var(--bg2);border:1px solid var(--border);
  border-bottom-left-radius:4px;color:var(--text);
}
.chat-msg.user .chat-msg-bubble{
  background:linear-gradient(135deg,var(--nexo-navy),var(--nexo-cyan));
  color:#fff;border-bottom-right-radius:4px;
}
.chat-msg-time{font-size:.6rem;color:var(--text4);padding:0 4px;}

/* Chips */
.chat-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px;}
.chat-chip{
  font-family:'Sora',sans-serif;
  font-size:.63rem;font-weight:600;
  padding:6px 12px;border-radius:100px;
  border:1px solid rgba(56,182,232,.35);
  background:rgba(56,182,232,.06);
  color:var(--nexo-blue);
  cursor:pointer;
  transition:background .2s,border-color .2s,color .2s,transform .15s;
  white-space:nowrap;
}
.chat-chip:hover{
  background:rgba(56,182,232,.15);
  border-color:var(--nexo-cyan);
  color:var(--nexo-navy);
  transform:translateY(-1px);
}

/* Typing */
.chat-typing{padding:4px 18px 8px;display:flex;align-items:center;gap:4px;}
.chat-typing span{
  width:7px;height:7px;border-radius:50%;
  background:var(--nexo-cyan);opacity:.5;
  animation:typing-bounce .9s ease-in-out infinite;
}
.chat-typing span:nth-child(2){animation-delay:.15s;}
.chat-typing span:nth-child(3){animation-delay:.3s;}
@keyframes typing-bounce{
  0%,60%,100%{transform:translateY(0);opacity:.5;}
  30%{transform:translateY(-6px);opacity:1;}
}

/* Input */
.chat-input-area{
  display:flex;align-items:flex-end;gap:8px;
  padding:10px 12px 8px;
  border-top:1px solid var(--border);
  background:var(--bg);flex-shrink:0;
}
.chat-input{
  flex:1;font-family:'Sora',sans-serif;
  font-size:.74rem;line-height:1.5;
  padding:9px 12px;
  background:var(--bg2);
  border:1px solid var(--border2);
  border-radius:12px;color:var(--text);
  resize:none;max-height:96px;outline:none;
  transition:border-color .2s;
}
.chat-input:focus{border-color:var(--nexo-cyan);}
.chat-input::placeholder{color:var(--text4);}
.chat-send{
  width:38px;height:38px;flex-shrink:0;
  background:linear-gradient(135deg,var(--nexo-navy),var(--nexo-cyan));
  border:none;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  color:white;cursor:pointer;
  transition:opacity .2s,transform .15s;
}
.chat-send:disabled{opacity:.3;cursor:default;}
.chat-send:not(:disabled):hover{transform:scale(1.07);}
.chat-send svg{width:15px;height:15px;}

/* CTA bar */
.chat-cta-bar{
  padding:8px 12px 10px;
  border-top:1px solid var(--border);
  background:var(--bg2);
  display:flex;flex-direction:column;align-items:stretch;gap:5px;
  flex-shrink:0;
}
.chat-cta-contact{
  font-family:'Sora',sans-serif;
  font-size:.7rem;font-weight:700;
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:9px 14px;border-radius:10px;
  background:linear-gradient(135deg,var(--nexo-navy),var(--nexo-blue));
  color:#fff;border:none;cursor:pointer;
  transition:opacity .2s,transform .15s,box-shadow .2s;
  box-shadow:0 2px 10px rgba(26,58,107,.25);
}
.chat-cta-contact:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 16px rgba(26,58,107,.35);}
.chat-cta-contact svg{width:14px;height:14px;flex-shrink:0;}
.chat-footer-note{
  text-align:center;font-size:.58rem;
  color:var(--text4);letter-spacing:.05em;
}

/* Mobile */
@media(max-width:480px){
  #chat-window{width:calc(100vw - 32px);right:-14px;bottom:74px;}
  #chat-widget{bottom:20px;right:16px;}
}

/* ══════════════════════════════════════
   AI OPS CENTER — mockup section
   ══════════════════════════════════════ */

/* Label pill variant */
.label-pill.indigo{background:rgba(99,102,241,.1);color:#4f46e5;border-color:rgba(99,102,241,.2);}
[data-theme="dark"] .label-pill.indigo{color:#818cf8;}

/* Grid: text col vs mockup col — only on desktop */
@media(min-width:901px){
  .aiops-inner{grid-template-columns:1.8fr 1.65fr;gap:40px;}
}

/* Bleed-right: remove right constraint so mockup reaches viewport edge */
@media(min-width:901px){
  #aiops-section>.wrap{
    max-width:none;
    padding-right:0;
    padding-left:max(36px,calc((100vw - 1120px)/2 + 36px));
  }
}

/* Padding so box-shadow doesn't clip at edges */
.aiops-mockup-col{padding:16px 52px 8px 4px;}

/* Sliding screenshots inside the mockup window */
.aiops-slides{
  position:relative;
  aspect-ratio:16/9;
  background:var(--bg3);
  overflow:hidden;
}
.aiops-slide{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;object-position:top left;
  opacity:0;
  animation:aiSlide 20s infinite;
}
.aiops-slide:nth-child(1){animation-delay:0s;}
.aiops-slide:nth-child(2){animation-delay:4s;}
.aiops-slide:nth-child(3){animation-delay:8s;}
.aiops-slide:nth-child(4){animation-delay:12s;}
.aiops-slide:nth-child(5){animation-delay:16s;}

@keyframes aiSlide{
  0%        {opacity:0;transform:scale(1.012);}
  4%,17%    {opacity:1;transform:scale(1);}
  20%,100%  {opacity:0;transform:scale(1.012);}
}

/* Slide indicators (below mockup) */
.aiops-dots{
  display:flex;justify-content:center;gap:7px;
  padding:10px 0 4px;
}
.aiops-dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--border2);
  animation:aiDot 20s infinite;
}
.aiops-dot:nth-child(1){animation-delay:0s;}
.aiops-dot:nth-child(2){animation-delay:4s;}
.aiops-dot:nth-child(3){animation-delay:8s;}
.aiops-dot:nth-child(4){animation-delay:12s;}
.aiops-dot:nth-child(5){animation-delay:16s;}

@keyframes aiDot{
  0%        {background:#4f46e5;transform:scale(1.4);}
  4%,17%    {background:#4f46e5;transform:scale(1.4);}
  20%,100%  {background:var(--border2);transform:scale(1);}
}

/* ─── AI OPS PAGE — Showcase (carousel con screenshots reales) ─── */
.aiops-showcase{
  max-width:1140px;margin:0 auto;
}
.aiops-showcase-frame{
  position:relative;
  background:#fff;
  border:1px solid var(--border);
  border-radius:14px;
  overflow:hidden;
  box-shadow:0 30px 80px -20px rgba(15,23,42,.25), 0 12px 30px -10px rgba(15,23,42,.12);
}
.aiops-showcase-bar{
  display:flex;align-items:center;gap:14px;
  padding:11px 16px;
  background:linear-gradient(180deg,#f8fafc,#f1f5f9);
  border-bottom:1px solid var(--border);
}
.aiops-showcase-dots{display:flex;gap:6px;}
.aiops-showcase-dots span{
  width:11px;height:11px;border-radius:50%;
  background:#cbd5e1;
}
.aiops-showcase-dots span:nth-child(1){background:#ff5f57;}
.aiops-showcase-dots span:nth-child(2){background:#ffbd2e;}
.aiops-showcase-dots span:nth-child(3){background:#28c840;}
.aiops-showcase-url{
  flex:1;text-align:center;
  font-family:'SF Mono','Consolas',monospace;
  font-size:.78rem;color:var(--text3);
  background:#fff;border:1px solid var(--border);
  padding:5px 14px;border-radius:6px;
  max-width:480px;margin:0 auto;
}
.aiops-showcase-slides{
  position:relative;
  aspect-ratio:1440 / 900;
  background:#fafbfc;
}
.aiops-showcase-slide{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:top center;
  opacity:0;transition:opacity .6s ease;
  display:block;
}
.aiops-showcase-slide.active{opacity:1;}
.aiops-showcase-tabs{
  display:flex;gap:6px;justify-content:center;flex-wrap:wrap;
  margin-top:18px;
}
.aiops-showcase-tab{
  background:#fff;border:1px solid var(--border);
  padding:7px 14px;border-radius:999px;
  font-family:inherit;font-size:.78rem;font-weight:600;color:var(--text2);
  cursor:pointer;
  transition:background .18s,color .18s,border-color .18s,transform .18s;
}
.aiops-showcase-tab:hover{
  background:#f8fafc;border-color:#cbd5e1;transform:translateY(-1px);
}
.aiops-showcase-tab.active{
  background:#6366f1;border-color:#6366f1;color:#fff;
  box-shadow:0 4px 12px rgba(99,102,241,.3);
}
@media (max-width: 540px){
  .aiops-showcase-url{font-size:.7rem;padding:4px 10px;max-width:60vw;}
  .aiops-showcase-tab{font-size:.72rem;padding:6px 11px;}
}

/* ─── AI OPS PAGE — Lucide icon base size ─── */
[data-lucide]{width:22px;height:22px;display:inline-block;}

/* ─── AI OPS PAGE — Feature cards con accent ─── */
.aiops-feat-card{
  --accent:#6366f1;
  position:relative;
  background:#fff;
  border:1px solid var(--border);
  border-radius:14px;
  padding:24px 22px 22px;
  border-top:3px solid var(--accent);
  transition:transform .2s,box-shadow .2s,border-color .2s;
}
.aiops-feat-card:hover{
  transform:translateY(-3px);
  box-shadow:0 14px 32px rgba(15,23,42,.07);
}
.aiops-feat-ico{
  width:44px;height:44px;
  display:flex;align-items:center;justify-content:center;
  border-radius:12px;
  background:color-mix(in srgb, var(--accent) 12%, transparent);
  color:var(--accent);
  margin-bottom:14px;
}
.aiops-feat-ico [data-lucide]{width:22px;height:22px;stroke-width:2.2;}
.aiops-feat-title{
  font-size:1.08rem;font-weight:800;color:var(--text);
  margin:0 0 8px;letter-spacing:-.01em;
}
.aiops-feat-desc{
  color:var(--text2);font-size:.88rem;line-height:1.55;margin:0;
}

/* ─── AI OPS PAGE — Steps ────────────────── */
.aiops-step{
  position:relative;text-align:left;
  background:#fff;
  border:1px solid var(--border);
  border-radius:14px;
  padding:26px 24px 22px;
  transition:transform .2s,box-shadow .2s;
}
.aiops-step:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(15,23,42,.07);}
.aiops-step-num{
  position:absolute;top:-10px;right:18px;
  font-family:'DM Serif Display',serif;
  font-size:2.6rem;font-weight:400;font-style:italic;
  color:#6366f1;opacity:.18;
  line-height:1;letter-spacing:-.02em;
}
.aiops-step-ico{
  width:44px;height:44px;
  display:flex;align-items:center;justify-content:center;
  border-radius:12px;
  background:rgba(99,102,241,.1);
  color:#6366f1;
  margin-bottom:14px;
}
.aiops-step-ico [data-lucide]{width:22px;height:22px;stroke-width:2.2;}
.aiops-step-title{
  font-size:1.05rem;font-weight:800;color:var(--text);
  margin:0 0 8px;
}
.aiops-step-desc{
  color:var(--text2);font-size:.88rem;line-height:1.55;margin:0;
}

/* ─── AI OPS PAGE — Pricing tier cards ────── */
.aiops-tier-card{
  position:relative;
  background:#fff;
  border:1px solid var(--border);
  border-radius:14px;
  padding:24px 22px;
  display:flex;flex-direction:column;
  transition:transform .2s,box-shadow .2s;
}
.aiops-tier-card:hover{transform:translateY(-3px);box-shadow:0 14px 32px rgba(15,23,42,.07);}
.aiops-tier-card-featured{
  border:2px solid #6366f1;
  background:linear-gradient(180deg,#fff 0%,#eef2ff 100%);
  box-shadow:0 6px 18px rgba(99,102,241,.14);
}
.aiops-tier-card-badge{
  position:absolute;top:-11px;left:50%;transform:translateX(-50%);
  background:#6366f1;color:#fff;
  font-size:.66rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;
  padding:4px 12px;border-radius:999px;white-space:nowrap;
  box-shadow:0 4px 12px rgba(99,102,241,.3);
}
.aiops-tier-card-name{font-size:.96rem;font-weight:800;color:var(--text);}
.aiops-tier-card-desc{font-size:.78rem;color:var(--text3);margin-top:3px;}
.aiops-tier-card-price{margin-top:14px;display:flex;align-items:baseline;gap:5px;}
.aiops-tier-card-num{
  font-size:2.1rem;font-weight:800;color:var(--text);
  font-variant-numeric:tabular-nums;letter-spacing:-.02em;line-height:1;
}
.aiops-tier-card-cur{font-size:.86rem;color:var(--text3);font-weight:600;}
.aiops-tier-card-price-soft{
  font-size:1.05rem;font-weight:800;color:var(--text);
  margin-top:18px;
}
.aiops-tier-card-annual{
  margin-top:6px;font-size:.74rem;color:#6366f1;font-weight:700;
}
.aiops-tier-card-list{
  list-style:none;padding:0;margin:18px 0 0;
  display:flex;flex-direction:column;gap:7px;
  font-size:.82rem;color:var(--text2);line-height:1.45;
}
.aiops-tier-card-list li{position:relative;padding-left:18px;}
.aiops-tier-card-list li::before{
  content:"";position:absolute;left:2px;top:6px;
  width:7px;height:7px;border-radius:50%;
  background:#6366f1;opacity:.65;
}

/* ─── AI OPS PAGE — FAQ ──────────────────── */
.aiops-faq{
  background:#fff;border:1px solid var(--border);border-radius:12px;
  padding:16px 22px;transition:border-color .15s;
}
.aiops-faq:hover{border-color:#cbd5e1;}
.aiops-faq summary{
  font-weight:700;cursor:pointer;font-size:.95rem;color:var(--text);
  display:flex;align-items:center;justify-content:space-between;
  list-style:none;
}
.aiops-faq summary::-webkit-details-marker{display:none;}
.aiops-faq summary::after{
  content:"+";font-size:1.4rem;font-weight:400;color:#6366f1;
  transition:transform .2s;
}
.aiops-faq[open] summary::after{content:"−";}
.aiops-faq p{
  margin:12px 0 0;color:var(--text2);
  font-size:.9rem;line-height:1.65;
}

/* ─── AI OPS PAGE — Nav link active ─────── */
.nav-a-active{color:var(--text)!important;background:rgba(99,102,241,.08);}

/* ─── AI OPS PAGE — grids fluidos ───────────── */
.aiops-page-stats{
  max-width:980px;margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;
  padding:28px 32px;
  background:linear-gradient(135deg,#f8fafc 0%,#eef2ff 100%);
  border:1px solid var(--border);border-radius:18px;
}
.aiops-page-stats > div{text-align:center;}
.aiops-page-pricing{
  display:grid;grid-template-columns:repeat(4,1fr);gap:16px;
  max-width:1120px;margin:0 auto;
}
.aiops-page-features{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
  max-width:1080px;margin:0 auto;
}
.aiops-page-steps{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  max-width:980px;margin:0 auto;
}
@media(max-width:1100px){
  .aiops-page-pricing{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:900px){
  .aiops-page-stats{grid-template-columns:repeat(2,1fr);padding:22px 20px;}
  .aiops-page-features{grid-template-columns:repeat(2,1fr);}
  .aiops-page-steps{grid-template-columns:1fr;gap:32px;}
}
@media(max-width:540px){
  .aiops-page-stats{grid-template-columns:1fr;}
  .aiops-page-pricing{grid-template-columns:1fr;}
  .aiops-page-features{grid-template-columns:1fr;}
}

/* ─── HERO ANNOUNCE CHIP ───────────────────── */
.hero-announce{
  display:inline-flex;align-items:center;gap:10px;
  padding:6px 14px 6px 6px;
  margin-bottom:24px;
  background:#fff;
  border:1px solid var(--border2);
  border-radius:999px;
  font-size:.82rem;color:var(--text2);
  text-decoration:none;
  transition:transform .15s,border-color .15s,box-shadow .15s;
  box-shadow:0 1px 3px rgba(15,23,42,.04);
}
.hero-announce:hover{
  border-color:var(--indigo);
  box-shadow:0 4px 14px rgba(99,102,241,.16);
  transform:translateY(-1px);
}
.hero-announce-badge{
  display:inline-flex;align-items:center;
  background:var(--indigo);color:#fff;
  font-size:.65rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  padding:3px 9px;border-radius:999px;
}
.hero-announce-text{font-weight:500;color:var(--text2);}
.hero-announce:hover .hero-announce-text{color:var(--text);}
.hero-announce-arrow{
  width:14px;height:14px;color:var(--indigo);
  transition:transform .18s;
}
.hero-announce:hover .hero-announce-arrow{transform:translateX(3px);}

@media (max-width: 540px){
  .hero-announce{font-size:.74rem;padding:5px 12px 5px 5px;gap:8px;}
  .hero-announce-badge{font-size:.6rem;padding:2px 7px;}
}

/* Demo CTA area */
.aiops-cta-wrap{display:flex;flex-wrap:wrap;gap:10px;align-items:center;}

/* ─── STATS BANNER ──────────────────────────── */
.aiops-stats{
  margin-top:60px;
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
  padding:28px 32px;
  background:linear-gradient(135deg,#f8fafc 0%,#eef2ff 100%);
  border:1px solid var(--border2);
  border-radius:18px;
}
.aiops-stat{text-align:center;}
.aiops-stat-num{
  font-size:2.4rem;font-weight:800;color:var(--indigo);
  line-height:1;letter-spacing:-.02em;
  font-variant-numeric:tabular-nums;
}
.aiops-stat-unit{font-size:1rem;color:var(--text3);font-weight:600;margin-left:3px;}
.aiops-stat-lbl{
  margin-top:8px;
  font-size:.78rem;color:var(--text2);
  line-height:1.45;
}
@media (max-width: 900px){
  .aiops-stats{grid-template-columns:repeat(2,1fr);}
}
@media (max-width: 540px){
  .aiops-stats{grid-template-columns:1fr;padding:22px 20px;}
}

/* ─── PRICING ───────────────────────────────── */
.aiops-pricing{
  margin-top:64px;
}
.aiops-pricing-head{text-align:center;margin-bottom:28px;}
.aiops-pricing-head .h3{margin:0 0 8px;font-size:1.8rem;}
.aiops-pricing-sub{
  color:var(--text3);font-size:.92rem;
  max-width:640px;margin:0 auto;
}
.aiops-pricing-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:16px;
}
.aiops-tier{
  position:relative;
  background:#fff;
  border:1px solid var(--border2);
  border-radius:14px;
  padding:22px 20px;
  display:flex;flex-direction:column;
  transition:transform .2s,box-shadow .2s,border-color .2s;
}
.aiops-tier:hover{
  transform:translateY(-3px);
  box-shadow:0 12px 28px rgba(15,23,42,.08);
  border-color:#cbd5e1;
}
.aiops-tier-featured{
  border:2px solid var(--indigo);
  background:linear-gradient(180deg,#fff 0%,#eef2ff 100%);
  box-shadow:0 6px 18px rgba(99,102,241,.14);
}
.aiops-tier-badge{
  position:absolute;top:-11px;left:50%;transform:translateX(-50%);
  background:var(--indigo);color:#fff;
  font-size:.66rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;
  padding:4px 12px;border-radius:999px;
  box-shadow:0 4px 12px rgba(99,102,241,.3);
  white-space:nowrap;
}
.aiops-tier-name{font-size:.96rem;font-weight:800;color:var(--text);}
.aiops-tier-desc{font-size:.76rem;color:var(--text3);margin-top:3px;}
.aiops-tier-price{
  margin-top:14px;display:flex;align-items:baseline;gap:5px;
}
.aiops-tier-num{
  font-size:2.2rem;font-weight:800;color:var(--text);
  font-variant-numeric:tabular-nums;letter-spacing:-.02em;line-height:1;
}
.aiops-tier-cur{font-size:.86rem;color:var(--text3);font-weight:600;}
.aiops-tier-price-soft{
  font-size:1.05rem;font-weight:700;color:var(--text);
  margin-top:18px;
}
.aiops-tier-annual{
  margin-top:6px;
  font-size:.74rem;color:var(--indigo);font-weight:600;
}
.aiops-tier-list{
  list-style:none;padding:0;margin:18px 0 0;
  display:flex;flex-direction:column;gap:6px;
  font-size:.78rem;color:var(--text2);line-height:1.4;
}
.aiops-tier-list li{
  padding-left:18px;position:relative;
}
.aiops-tier-list li::before{
  content:"";
  position:absolute;left:2px;top:6px;
  width:8px;height:8px;border-radius:50%;
  background:var(--indigo);opacity:.65;
}
@media (max-width: 1100px){
  .aiops-pricing-grid{grid-template-columns:repeat(2,1fr);}
}
@media (max-width: 540px){
  .aiops-pricing-grid{grid-template-columns:1fr;}
}
.demo-hint{
  display:inline-flex;align-items:center;flex-wrap:wrap;gap:5px;
  font-size:.75rem;color:var(--text3);
}
.demo-hint strong{color:var(--text2);font-weight:600;}
.demo-hint code{
  background:var(--bg3);
  padding:1px 7px;border-radius:5px;
  font-family:monospace;font-size:.72rem;
  color:var(--text2);border:1px solid var(--border2);
}