/* ===== RESET & BASE ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Plus Jakarta Sans',sans-serif;color:#1A1A1A;background:#FFFFFF;line-height:1.6;overflow-x:hidden}
a{text-decoration:none;color:inherit;transition:color .2s}
ul{list-style:none}
img{max-width:100%;height:auto;display:block}
video{display:block;vertical-align:bottom;border:none;outline:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,textarea,select{font-family:inherit;font-size:1rem}

/* grain texture removed */

/* ===== MODERN SCROLL ANIMATIONS ===== */
.fade-in{opacity:0;transform:translateY(24px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.fade-in.visible{opacity:1;transform:translateY(0)}
.fade-in-left{opacity:0;transform:translateX(-32px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.fade-in-left.visible{opacity:1;transform:translateX(0)}
.fade-in-right{opacity:0;transform:translateX(32px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.fade-in-right.visible{opacity:1;transform:translateX(0)}
.stagger-1{transition-delay:.1s}.stagger-2{transition-delay:.2s}.stagger-3{transition-delay:.3s}.stagger-4{transition-delay:.4s}

/* ===== BENTO GRID ===== */
.bento-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:auto;gap:16px}
.bento-card{background:#fff;border:1px solid var(--border);border-radius:20px;padding:32px;transition:transform .35s cubic-bezier(.4,0,.2,1),box-shadow .35s cubic-bezier(.4,0,.2,1),border-color .35s;overflow:hidden;position:relative}
.bento-card:hover{border-color:var(--teal);box-shadow:0 20px 48px rgba(0,0,0,.08),0 0 0 1px rgba(73,196,168,.1);transform:translateY(-4px) scale(1.01)}
.bento-card.span-2{grid-column:span 2}
.bento-card.span-row-2{grid-row:span 2}
.bento-card.dark{background:var(--dark);border-color:transparent;color:#fff}
.bento-card.teal{background:var(--teal);border-color:transparent;color:#fff}
.bento-card h3{font-size:1.25rem;font-weight:700;margin-bottom:8px}
.bento-card p{font-size:.9375rem;color:var(--text-sec);line-height:1.6}
.bento-card.dark p,.bento-card.teal p{color:rgba(255,255,255,.7)}
.bento-icon{width:48px;height:48px;border-radius:12px;background:var(--teal-light);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.bento-icon svg{width:24px;height:24px;stroke:var(--teal);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.bento-card.dark .bento-icon{background:rgba(73,196,168,.15)}
.bento-card.teal .bento-icon{background:rgba(255,255,255,.2)}
.bento-card.teal .bento-icon svg{stroke:#fff}
.bento-stat{font-size:2.5rem;font-weight:800;color:var(--teal-text);line-height:1}
.bento-card.dark .bento-stat,.bento-card.teal .bento-stat{color:#fff}

/* ===== COLORS ===== */
:root{
  --teal:#49C4A8;--teal-hover:#3BAA91;--teal-light:rgba(73,196,168,.1);
  --teal-text:#308370;
  /* CTA color: darker teal to pass WCAG AA (5.11:1 vs white). Used only in primary buttons. */
  --teal-button:#287B65;--teal-button-hover:#1F6B57;
  --bg-white:#FFFFFF;--bg-alt:#F5F5F5;--text:#1A1A1A;--text-sec:#656D7B;
  --border:#E5E7EB;--dark:#0F172A;--dark-lighter:#1E293B;
  --dark-card:#0D283D;--indigo:#6366F1;--indigo-light:#EEF2FF;
  --error:#E74C3C;--label-color:#33475B;--input-border:#CBD6E2;
  --text-muted:#5F6B7C;--text-light:#656D7B;--light:#F8F8F1;
}

/* ===== UTILITY ===== */
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.section{padding:80px 0}
.section-alt{background:#FAFAFA}
.section-dark{background:var(--dark);color:#fff}
.text-center{text-align:center}
.text-teal{color:var(--teal-text)}
.text-sec{color:var(--text-sec)}
.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}.mt-48{margin-top:48px}.mt-64{margin-top:64px}
.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.mb-32{margin-bottom:32px}.mb-48{margin-bottom:48px}
.flex{display:flex}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}
.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-24{gap:24px}.gap-32{gap:32px}.gap-48{gap:48px}
.grid{display:grid}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}

/* ===== SPACING SCALE ===== */
.al-py-24{padding-top:24px;padding-bottom:24px}
.al-py-32{padding-top:32px;padding-bottom:32px}
.al-py-40{padding-top:40px;padding-bottom:40px}
.al-py-48{padding-top:48px;padding-bottom:48px}
.al-py-64{padding-top:64px;padding-bottom:64px}
.al-py-80{padding-top:80px;padding-bottom:80px}
.al-py-96{padding-top:96px;padding-bottom:96px}
.al-px-16{padding-left:16px;padding-right:16px}
.al-px-24{padding-left:24px;padding-right:24px}
.al-px-32{padding-left:32px;padding-right:32px}
.al-px-40{padding-left:40px;padding-right:40px}
.al-px-48{padding-left:48px;padding-right:48px}
.al-p-24{padding:24px}.al-p-32{padding:32px}.al-p-40{padding:40px}.al-p-48{padding:48px}
.al-mt-16{margin-top:16px}.al-mt-24{margin-top:24px}.al-mt-32{margin-top:32px}.al-mt-48{margin-top:48px}.al-mt-64{margin-top:64px}
.al-mb-16{margin-bottom:16px}.al-mb-24{margin-bottom:24px}.al-mb-32{margin-bottom:32px}.al-mb-48{margin-bottom:48px}
/* ===== 12-COL GRID SYSTEM ===== */
.al-grid{display:grid;gap:24px;max-width:1200px;margin:0 auto}
.al-cols-2{grid-template-columns:repeat(2,1fr)}
.al-cols-3{grid-template-columns:repeat(3,1fr)}
.al-cols-4{grid-template-columns:repeat(4,1fr)}
.al-cols-5{grid-template-columns:repeat(5,1fr)}
.al-cols-5-7{grid-template-columns:5fr 7fr}
.al-cols-7-5{grid-template-columns:7fr 5fr}
.al-cols-6-6{grid-template-columns:1fr 1fr}
.al-gap-16{gap:16px}.al-gap-32{gap:32px}.al-gap-48{gap:48px}

/* ===== TYPOGRAPHY ===== */
h1{font-size:3rem;font-weight:800;line-height:1.15;letter-spacing:-.02em}
h2{font-size:2.25rem;font-weight:700;line-height:1.2;letter-spacing:-.01em}
h3{font-size:1.5rem;font-weight:600;line-height:1.3}
h4{font-size:1.125rem;font-weight:600;line-height:1.4}
.subtitle{font-size:1.125rem;color:var(--text-sec);max-width:640px;margin-left:auto;margin-right:auto;text-wrap:balance;hyphens:none}
h1,h2,h3,.section-title{text-wrap:balance;hyphens:none}
.section-label{display:inline-block;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--teal-text);background:var(--teal-light);padding:4px 16px;border-radius:100px;margin-bottom:16px}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:12px;font-weight:600;font-size:1rem;transition:all .25s;white-space:nowrap}
.btn-primary{background:var(--teal);color:var(--dark);font-weight:700}
.btn-primary:hover{background:var(--teal-hover);transform:translateY(-1px);box-shadow:0 8px 24px rgba(73,196,168,.35)}
.btn-primary:active{background:#2F9F84;transform:translateY(0);box-shadow:none}
.btn:focus-visible{outline:2px solid var(--teal);outline-offset:2px;box-shadow:0 0 0 4px rgba(73,196,168,.25)}
.btn-outline{border:2px solid var(--teal);color:var(--teal)}
.btn-outline:hover{background:var(--teal);color:#fff}
.btn-outline:active{background:var(--teal-hover);color:#fff}
.btn-white{background:#fff;color:var(--dark)}
.btn-white:hover{background:#f0f0f0}
.btn-white:active{background:#e5e5e5}
.btn-dark{background:var(--dark);color:#fff}
.btn-dark:hover{background:var(--dark-lighter)}
.btn-dark:active{background:#151f30}
.btn-sm{padding:8px 20px;font-size:.875rem;border-radius:10px}
a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,button:focus-visible,[onclick]:focus-visible{outline:2px solid var(--teal);outline-offset:2px;box-shadow:0 0 0 4px rgba(73,196,168,.25)}
[onclick]:active{opacity:.9;transform:scale(.98)}
.microcopy{font-size:.85rem;color:var(--text-sec);margin-top:12px}
.dark-section .microcopy,.cta-section .microcopy{color:rgba(255,255,255,.5)}


/* ===== ALEPHOO DS UTILITY CLASSES ===== */
.al-pos-rel{position:relative}
.al-cursor{cursor:pointer}
.al-no-deco{text-decoration:none;color:inherit}
.al-p-20{padding:20px}
.al-color-white{color:#fff}
.al-color-teal{color:var(--teal-text)}
.al-color-error{color:var(--error)}
.al-flex-center-12{display:flex;align-items:center;gap:12px}
.al-flex-8{display:flex;gap:8px;align-items:center;margin-bottom:10px}
.al-cover{width:100%;height:100%;object-fit:cover}
.al-cover-160{width:100%;height:160px;object-fit:cover}
.al-res-stat{background:rgba(255,255,255,.06);border-radius:12px;padding:20px;text-align:center}
.al-res-label{font-size:.75rem;color:rgba(255,255,255,.45);margin-top:4px}
.al-res-card{border-radius:16px;overflow:hidden;box-shadow:0 2px 16px rgba(0,0,0,.05);background:#fff}
.al-res-thumb{height:180px;overflow:hidden}
.al-res-pad{padding:0;overflow:hidden;cursor:pointer}
.al-res-tag-wrap{padding:16px 16px}
.al-text-xs-sec{font-size:.7rem;color:var(--text-sec)}
.al-text-body{font-size:1rem;line-height:1.35}
.al-text-desc{font-size:.85rem;color:var(--text-sec);margin-top:6px;line-height:1.5}
.al-text-sm-mt{font-size:.88rem;margin-top:6px}
.al-heading-stat{font-size:1.75rem;font-weight:800;color:#fff}
.al-heading-stat-teal{font-size:1.75rem;font-weight:800;color:var(--teal-text)}
.al-indigo-tag{background:var(--indigo-light);color:var(--indigo)}
.al-cat-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--indigo);background:var(--indigo-light);padding:4px 8px;border-radius:6px;display:inline-block}
.al-logo-faded{height:72px;opacity:.5;filter:grayscale(100%)}
.al-form-label{display:block;font-size:.8rem;font-weight:600;color:var(--label-color);margin-bottom:4px}
.al-icon-28{width:28px;height:28px}
.al-icon-14{width:14px;height:14px}
.al-icon-16{width:16px;height:16px}
.al-icon-20{width:20px;height:20px}
.al-icon-32{width:32px;height:32px}
.al-icon-36{width:36px;height:36px}


/* ===== ALEPHOO DS UTILITY CLASSES — BATCH 2 ===== */
.al-play-btn{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center}
.al-cat-tag{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--indigo);background:rgba(99,102,241,.08);padding:4px 8px;border-radius:6px;display:inline-block}
.al-form-input{width:100%;padding:8px 12px;border:1px solid var(--input-border);border-radius:4px;font-size:.875rem;outline:none;background:#fff;transition:border-color .2s;box-sizing:border-box}
.al-text-white-40{color:rgba(255,255,255,.4)}
.al-text-white-55{color:rgba(255,255,255,.55);margin-top:12px;line-height:1.7;font-size:.95rem}
.al-text-white-85{font-size:.92rem;color:rgba(255,255,255,.85)}
.al-text-white-85-sm{color:rgba(255,255,255,.85);font-size:.75rem;font-weight:600;line-height:1.2}
.al-logo-56{height:56px;opacity:.7}
.al-logo-56-inv{height:56px;filter:brightness(0) invert(1)}
.al-pos-rel-400{position:relative;min-height:400px}
.al-cover-abs{width:100%;height:100%;object-fit:cover;position:absolute;top:0;left:0}
.al-overlay-bottom{position:absolute;bottom:0;left:0;right:0;padding:24px;background:linear-gradient(transparent,rgba(0,0,0,.7))}
.al-p-40{padding:40px}
.al-mt-28{margin-top:28px}
.al-seg-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border-radius:20px;overflow:hidden;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1)}
.al-feat-pill{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:12px 20px;display:flex;align-items:center;gap:10px}
.al-teal-icon{width:56px;height:56px;border-radius:14px;background:rgba(73,196,168,.12);display:flex;align-items:center;justify-content:center}
.al-icon-24{width:24px;height:24px}
.al-heading-white-lg{color:#fff;font-size:1.5rem}
.al-text-thin{font-weight:400;opacity:.7}

/* ===== HEADER ===== */
.header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(255,255,255,.95);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);transition:box-shadow .3s}
.header.scrolled{box-shadow:0 2px 20px rgba(0,0,0,.06)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:72px;max-width:1200px;margin:0 auto;padding:0 24px}
.logo{display:flex;align-items:center;gap:0}
.logo svg{height:32px}
.nav{display:flex;align-items:center;gap:32px}
.nav-link{font-size:.9375rem;font-weight:500;color:var(--text);transition:color .2s;position:relative}
.nav-link:hover{color:var(--teal-text)}
.nav-dropdown{position:relative}
.nav-dropdown .dropdown-menu{position:absolute;top:calc(100% + 12px);left:-16px;background:#fff;border:1px solid var(--border);border-radius:12px;padding:8px;min-width:220px;opacity:0;visibility:hidden;transform:translateY(8px);transition:all .2s;box-shadow:0 12px 32px rgba(0,0,0,.08)}
.nav-dropdown:hover .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown-item{display:block;padding:8px 16px;border-radius:8px;font-size:.9375rem;color:var(--text);transition:background .15s}
.dropdown-item:hover{background:var(--bg-alt);color:var(--teal-text)}
.header-actions{display:flex;align-items:center;gap:12px}
.mobile-toggle{display:none;flex-direction:column;gap:5px;padding:8px;min-width:44px;min-height:44px;align-items:center;justify-content:center;background:transparent;border:none;cursor:pointer}
.mobile-toggle span{display:block;width:22px;height:2px;background:var(--text);transition:transform .25s ease,opacity .2s ease;transform-origin:center}
.mobile-toggle.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.mobile-toggle.active span:nth-child(2){opacity:0}
.mobile-toggle.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-nav{display:none;position:fixed;top:72px;left:0;right:0;bottom:0;background:#fff;padding:24px;z-index:999;overflow-y:auto}
.mobile-nav.active{display:block}
.mobile-nav a{display:block;padding:12px 0;font-size:1.125rem;font-weight:500;border-bottom:1px solid var(--border)}
.mobile-nav-group{margin-bottom:8px}
.mobile-nav-heading{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-sec);margin:18px 0 4px;padding:0;border:none}
.mobile-nav-group:first-child .mobile-nav-heading{margin-top:0}
.mobile-nav-group a{padding:10px 0;font-size:1.05rem;font-weight:500}
.mobile-nav-ctas{display:flex;flex-direction:column;gap:10px;margin-top:24px;padding-top:20px;border-top:1px solid var(--border)}
.mobile-nav .mobile-nav-ctas a.btn{display:inline-flex;width:100%;justify-content:center;align-items:center;text-align:center;padding:12px 24px;font-size:1rem;font-weight:600;border-bottom:none}
.mobile-nav .mobile-nav-ctas a.btn-outline{border:2px solid var(--teal);color:var(--teal)}
.mobile-nav .mobile-nav-ctas a.btn-primary{background:var(--teal);color:var(--dark);font-weight:700}

/* ===== HERO ===== */
.hero{padding:120px 0 56px;background:#FFFFFF;position:relative;overflow:hidden}
.hero-glow{position:absolute;top:20%;left:-10%;width:500px;height:500px;background:radial-gradient(circle,rgba(73,196,168,.08) 0%,transparent 70%);pointer-events:none;z-index:0}
.parallax-orb{transition:transform .1s linear;will-change:transform}
.hero .container{position:relative;z-index:1}
.social-proof{display:flex;align-items:center;gap:12px;margin-top:12px;padding:8px 0}
.social-proof-flags{display:flex;gap:-4px}
.social-proof-flag{width:24px;height:24px;border-radius:50%;border:2px solid #fff;object-fit:cover;margin-left:-6px;box-shadow:0 1px 3px rgba(0,0,0,.1)}
.social-proof-flag:first-child{margin-left:0}
.social-proof-text{font-size:.8rem;color:var(--text-sec);font-weight:500;line-height:1.4}
.social-proof-text strong{color:var(--text);font-weight:700}
.hero-split{display:grid;grid-template-columns:5fr 6fr;gap:48px;align-items:center}
.hero h1{font-size:3.25rem;font-weight:800;line-height:1.1;letter-spacing:-.03em}
.hero h1 span{color:var(--teal-text)}
.hero .subtitle{margin-top:14px;margin-left:0;margin-right:0;font-size:1.05rem;line-height:1.6}
.hero .text-center .subtitle,
.hero [style*="text-align:center"] .subtitle,
.hero [style*="text-align: center"] .subtitle{margin-left:auto;margin-right:auto}
.hero-metrics{display:flex;gap:28px;margin-top:16px;padding:12px 0}
.hero-metric{display:flex;flex-direction:column}
.hero-metric-value{font-size:1.5rem;font-weight:800;color:var(--teal-text);line-height:1}
.hero-metric-label{font-size:.75rem;color:var(--text-sec);margin-top:3px}
.hero-actions{display:flex;gap:12px;margin-top:18px;flex-wrap:wrap}
.hero-video-wrap{display:flex;align-items:center;min-height:100%}
.hero-video{width:100%;display:block;border-radius:20px}

/* ===== METRICS BAR ===== */
.metrics-bar{display:flex;justify-content:center;gap:48px;flex-wrap:wrap;padding:32px 0}
.metric{text-align:center}
.metric-value{font-size:2.25rem;font-weight:800;color:var(--teal-text)}
.metric-label{font-size:.875rem;color:var(--text-sec);margin-top:4px}
.section-dark .metric-label{color:rgba(255,255,255,.6)}

/* ===== CARDS ===== */
.card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:32px;transition:transform .35s cubic-bezier(.4,0,.2,1),box-shadow .35s cubic-bezier(.4,0,.2,1),border-color .35s}
.card:hover{transform:translateY(-5px) scale(1.01);box-shadow:0 20px 48px rgba(0,0,0,.09),0 0 0 1px rgba(73,196,168,.1);border-color:var(--teal)}
.card-icon{width:48px;height:48px;background:var(--teal-light);border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.card-icon svg{width:24px;height:24px;color:var(--teal-text)}
.section-dark .card{background:var(--dark-lighter);border-color:rgba(255,255,255,.08)}
.section-dark .card:hover{border-color:var(--teal)}

/* ===== CLIENT LOGOS ===== */
.logo-grid{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:24px}
.logo-grid img{height:48px;width:auto;object-fit:contain;filter:grayscale(100%) opacity(.5);transition:all .3s}
.logo-grid img:hover{filter:grayscale(0%) opacity(1)}

/* ===== VIDEO CARD ===== */
.video-card{border-radius:16px;overflow:hidden;background:#fff;border:1px solid var(--border);transition:transform .35s cubic-bezier(.4,0,.2,1),box-shadow .35s cubic-bezier(.4,0,.2,1),border-color .35s}
.video-card:hover{transform:translateY(-5px) scale(1.015);box-shadow:0 20px 48px rgba(0,0,0,.09),0 0 0 1px rgba(73,196,168,.1);border-color:var(--teal)}
.video-card img{transition:transform .4s cubic-bezier(.4,0,.2,1)}
.video-card:hover img{transform:scale(1.04)}
.video-card img{width:100%;aspect-ratio:16/9;object-fit:cover}
.video-card-body{padding:20px}
.video-card-body h4{font-size:1rem;line-height:1.4}
.video-card-body p{font-size:.875rem;color:var(--text-sec);margin-top:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* ===== TABS ===== */
.tabs{display:flex;gap:4px;border-radius:12px;background:var(--bg-alt);padding:4px;overflow-x:auto}
.tab{padding:8px 20px;border-radius:10px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;color:var(--text-sec)}
.tab.active{background:#fff;color:var(--teal-text);box-shadow:0 2px 8px rgba(0,0,0,.06)}

/* ===== FAQ ACCORDION ===== */
.faq-item{border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:8px;transition:border-color .25s,box-shadow .25s,background .25s}
.faq-item:hover{border-color:var(--teal);box-shadow:0 4px 16px rgba(73,196,168,.08)}
.faq-item.open{border-color:var(--teal);background:rgba(73,196,168,.02)}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;padding:20px 24px;cursor:pointer;font-weight:600;font-size:1rem;background:#fff;border:none;text-align:left;color:inherit;font-family:inherit;line-height:inherit}
.faq-q:focus-visible{outline:2px solid var(--teal);outline-offset:-2px}
.faq-q svg{width:20px;height:20px;color:var(--text-sec);transition:transform .3s;flex-shrink:0}
.faq-item.open .faq-q svg{transform:rotate(45deg);color:var(--teal-text)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease;padding:0 24px}
.faq-a-inner{padding:0 0 20px;color:var(--text-sec);font-size:.9375rem;line-height:1.7}
.faq-item.open .faq-a{max-height:500px}

/* ===== PRICING ===== */
.pricing-card{border:1px solid var(--border);border-radius:16px;padding:40px 32px;background:#fff;text-align:center;position:relative;transition:transform .35s cubic-bezier(.4,0,.2,1),box-shadow .35s cubic-bezier(.4,0,.2,1),border-color .35s}
.pricing-card:hover{transform:translateY(-5px);box-shadow:0 20px 48px rgba(0,0,0,.1),0 0 0 1px rgba(73,196,168,.1);border-color:var(--teal)}
.pricing-card.featured{border:2px solid var(--teal);transform:scale(1.04)}
.pricing-card.featured:hover{transform:scale(1.04) translateY(-4px)}
.pricing-badge{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--teal);color:#fff;padding:4px 20px;border-radius:100px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.pricing-name{font-size:1.25rem;font-weight:700;margin-top:12px}
.pricing-features{text-align:left;margin:24px 0}
.pricing-features li{padding:8px 0;display:flex;align-items:flex-start;gap:10px;font-size:.9375rem;color:var(--text-sec)}
.pricing-features li svg{width:18px;height:18px;flex-shrink:0;margin-top:2px}
.check-icon{color:var(--teal-text)}
.cross-icon{color:#D1D5DB}

/* ===== WHEEL SOLUCIONES ===== */
.wheel-container{position:relative;width:520px;height:520px;transform:scale(0.77);transform-origin:center center;margin:-60px}
.connections-svg{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;pointer-events:none}
.conn-line{stroke:#E5E7EB;stroke-width:1.5;stroke-dasharray:500;stroke-dashoffset:500;transition:stroke .4s ease}
.conn-line.visible{animation:drawLine .8s ease forwards}
.conn-line.active-line{stroke:var(--teal);stroke-width:2}
@keyframes drawLine{to{stroke-dashoffset:0}}
.travel-dot{fill:var(--teal);r:3;opacity:0}
.travel-dot.active{opacity:1;animation:travelPulse 2s ease-in-out infinite}
@keyframes travelPulse{0%,100%{opacity:.3;r:2.5}50%{opacity:1;r:3.5}}
.center-hub{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:130px;height:130px;background:#fff;border:2px solid var(--teal);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10;box-shadow:0 0 0 6px rgba(73,196,168,.08),0 8px 24px rgba(0,0,0,.06);opacity:0;animation:hubEnter .6s cubic-bezier(.16,1,.3,1) .1s forwards}
@keyframes hubEnter{from{opacity:0;transform:translate(-50%,-50%) scale(.8)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}
.center-icon{width:36px;height:36px;background:rgba(73,196,168,.08);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:8px}
.center-icon svg{width:20px;height:20px;stroke:var(--teal);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.center-label{font-size:.875rem;font-weight:800;color:#1A1A1A;letter-spacing:-.01em;line-height:1}
.center-sublabel{font-size:.625rem;font-weight:500;color:var(--text-sec);margin-top:3px;letter-spacing:.02em}
.solution-node{position:absolute;z-index:5;opacity:0;transform:translateY(12px);cursor:default;transition:opacity .5s ease,transform .5s cubic-bezier(.16,1,.3,1)}
.solution-node.visible{opacity:1;transform:translateY(0)}
.node-card{background:#fff;border:1px solid #E5E7EB;border-radius:12px;padding:12px 16px;display:flex;align-items:center;gap:12px;transition:all .25s ease;box-shadow:0 1px 3px rgba(0,0,0,.04);min-width:160px}
.node-card:hover{box-shadow:0 8px 24px rgba(0,0,0,.06);border-color:rgba(73,196,168,.2);transform:translateY(-2px)}
.solution-node.active .node-card{border-color:var(--teal);box-shadow:0 4px 16px rgba(73,196,168,.12);background:rgba(73,196,168,.04)}
.node-icon{width:40px;height:40px;flex-shrink:0;background:rgba(73,196,168,.08);border-radius:10px;display:flex;align-items:center;justify-content:center;transition:all .25s ease}
.solution-node.active .node-icon{background:var(--teal)}
.node-icon svg{width:20px;height:20px;stroke:var(--teal);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;transition:stroke .25s ease}
.solution-node.active .node-icon svg{stroke:#fff}
.node-text{display:flex;flex-direction:column;gap:2px}
.node-label{font-size:.8125rem;font-weight:700;color:#1A1A1A;line-height:1.2}
.node-desc{font-size:.6875rem;font-weight:500;color:var(--text-sec);line-height:1.3}
.solution-node.active .node-desc{color:var(--teal-text)}
.node-0{top:6px;left:50%;transform:translate(-50%,12px)}.node-0.visible{transform:translate(-50%,0)}
.node-1{top:115px;right:-6px;transform:translate(0,12px)}.node-1.visible{transform:translate(0,0)}.node-1 .node-card{flex-direction:row}
.node-2{bottom:115px;right:-6px;transform:translate(0,12px)}.node-2.visible{transform:translate(0,0)}
.node-3{bottom:6px;left:50%;transform:translate(-50%,12px)}.node-3.visible{transform:translate(-50%,0)}
.node-4{bottom:115px;left:-6px;transform:translate(0,12px)}.node-4.visible{transform:translate(0,0)}.node-4 .node-card{flex-direction:row-reverse;text-align:right}
.node-5{top:115px;left:-6px;transform:translate(0,12px)}.node-5.visible{transform:translate(0,0)}.node-5 .node-card{flex-direction:row-reverse;text-align:right}
.pilar-num{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:6px;background:rgba(73,196,168,.08);border:1px solid rgba(73,196,168,.2);font-size:.5625rem;font-weight:700;color:var(--teal);flex-shrink:0;position:absolute;top:-6px;right:-6px;transition:all .25s ease}
.solution-node.active .pilar-num{background:var(--teal);color:#fff;border-color:var(--teal)}
.orbit-circle{position:absolute;top:50%;left:50%;width:300px;height:300px;transform:translate(-50%,-50%);border:1px solid #E5E7EB;border-radius:50%;z-index:0;opacity:0;transition:opacity .8s ease}
.orbit-circle.visible{opacity:.5}
.progress-ring{position:absolute;top:50%;left:50%;width:300px;height:300px;transform:translate(-50%,-50%) rotate(-90deg);z-index:2;pointer-events:none}
.progress-ring circle{fill:none;stroke-width:2;stroke-linecap:round}
.progress-ring .bg-ring{stroke:transparent}
.progress-ring .fg-ring{stroke:var(--teal);opacity:.25;stroke-dasharray:942;stroke-dashoffset:942;transition:stroke-dashoffset 2.2s ease-in-out}

/* ===== FEATURE CHIPS ===== */
.feature-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px}
.feature-chip{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:999px;font-size:.8125rem;font-weight:600;background:rgba(73,196,168,.1);color:var(--teal);border:1px solid rgba(73,196,168,.15);transition:all .2s}
.feature-chip:hover{background:rgba(73,196,168,.18)}
.hde-card .feature-chip{background:rgba(73,196,168,.12);color:#49C4A8;border-color:rgba(73,196,168,.2)}
.hde-card .feature-chip:hover{background:rgba(73,196,168,.22)}

/* ===== FOOTER ===== */
.footer{background:var(--dark);color:#fff;padding:64px 0 32px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:40px}
.footer-brand p{color:rgba(255,255,255,.5);font-size:.875rem;margin-top:10px;line-height:1.6}
.footer a.footer-badges,.footer-badges{display:flex;gap:12px;align-items:center;margin-top:24px;padding:0;cursor:pointer;flex-wrap:wrap;font-size:0}
.footer-badges img{height:88px;width:auto;opacity:.85;transition:all .2s;display:block}
.footer-badges:hover img{opacity:1}
.footer-badges img:hover{opacity:1;transform:scale(1.05)}
.footer h5{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.4);margin-bottom:16px}
.footer a{display:block;padding:4px 0;font-size:.9375rem;color:rgba(255,255,255,.7);transition:color .2s}
.footer a:hover{color:var(--teal-text)}
.footer-bottom{margin-top:48px;padding-top:24px;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
.footer-phones{display:flex;gap:24px;flex-wrap:wrap;font-size:.8125rem;color:rgba(255,255,255,.5)}
.footer-phones a{color:inherit;text-decoration:none;padding:0;font-size:inherit;font-weight:inherit;display:inline;transition:color .2s}
.footer-phones a:hover{color:var(--teal-text)}
.footer-copy{font-size:.8125rem;color:rgba(255,255,255,.3);display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.footer-legal-link{color:rgba(255,255,255,.55)!important;font-size:inherit;font-weight:inherit;padding:0;display:inline;transition:color .2s}
.footer-legal-link:hover{color:var(--teal-text)!important}
.footer-legal-sep{color:rgba(255,255,255,.2)}

/* ===== HubSpot Chat — ocultar en páginas con form (evita conflicto CRO con el form embebido) ===== */
.page-contacto #hubspot-messages-iframe-container,
.page-precios #hubspot-messages-iframe-container{display:none!important;visibility:hidden!important;pointer-events:none!important}

/* ===== HubSpot Forms — reservar altura del contenedor para evitar CLS al cargar iframe ===== */
#hs-form-precios,#hs-form-contacto{min-height:540px}
@media(max-width:768px){
  #hs-form-precios,#hs-form-contacto{min-height:800px}
}

/* ===== HubSpot Chat — asegurar z-index correcto y posicionamiento para que aparezca sobre otros elementos ===== */
#hubspot-messages-iframe-container{
  z-index:10000!important;
  position:fixed!important;
  bottom:0!important;
  right:0!important;
  display:block!important;
  visibility:visible!important;
  opacity:1!important;
  pointer-events:auto!important;
}
#hubspot-messages-iframe-container iframe,
#hubspot-conversations-iframe{
  z-index:10000!important;
  display:block!important;
  visibility:visible!important;
  opacity:1!important;
}

/* Mobile: asegurar que el chat sea visible y funcional con ajustes específicos */
@media(max-width:768px){
  #hubspot-messages-iframe-container{
    z-index:10001!important;
    display:block!important;
    visibility:visible!important;
    pointer-events:auto!important;
    position:fixed!important;
    bottom:16px!important;
    right:16px!important;
    left:auto!important;
    top:auto!important;
    opacity:1!important;
    transform:none!important;
  }
  #hubspot-messages-iframe-container iframe,
  #hubspot-conversations-iframe{
    z-index:10001!important;
    display:block!important;
    visibility:visible!important;
    opacity:1!important;
    transform:none!important;
  }
  /* Asegurar que nada oculte el chat en mobile */
  body:not(.page-contacto):not(.page-precios) #hubspot-messages-iframe-container{
    display:block!important;
  }
}

/* ===== AVISO DE PRIVACIDAD (barra inferior) ===== */
.alephoo-privacy{position:fixed;left:0;right:0;bottom:0;background:#0F172A;color:rgba(255,255,255,.92);box-shadow:0 -8px 32px rgba(15,23,42,.18);padding:14px 24px;z-index:9998;font-family:"Plus Jakarta Sans",system-ui,-apple-system,sans-serif;border-top:1px solid rgba(73,196,168,.18);transform:translateY(100%);transition:transform .42s cubic-bezier(.2,.8,.3,1);will-change:transform}
.alephoo-privacy.visible{transform:translateY(0)}
.alephoo-privacy.dismissing{transform:translateY(100%);pointer-events:none}
.alephoo-privacy .ap-inner{max-width:1200px;margin:0 auto;padding-right:120px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.alephoo-privacy .ap-text{font-size:.82rem;line-height:1.5;color:rgba(255,255,255,.82);margin:0;flex:1;min-width:0}
.alephoo-privacy .ap-text a{color:#49C4A8;text-decoration:underline;font-weight:600}
.alephoo-privacy .ap-text a:hover{color:#fff}
.alephoo-privacy .ap-btn{font-family:inherit;background:#49C4A8;color:#0F172A;padding:9px 22px;font-size:.85rem;font-weight:700;border:none;border-radius:8px;cursor:pointer;transition:background .2s,transform .2s,box-shadow .2s;flex-shrink:0;white-space:nowrap}
.alephoo-privacy .ap-btn:hover{background:#3BAA91;transform:translateY(-1px);box-shadow:0 6px 18px rgba(73,196,168,.35)}
.alephoo-privacy .ap-btn:focus-visible{outline:2px solid #49C4A8;outline-offset:3px}
@media(max-width:768px){
  .alephoo-privacy{padding:14px 16px}
  .alephoo-privacy .ap-inner{padding-right:0;flex-direction:column;align-items:stretch;gap:12px}
  .alephoo-privacy .ap-text{font-size:.78rem;text-align:left;padding-right:96px}
  .alephoo-privacy .ap-btn{align-self:flex-start;padding:10px 26px}
}
@media(prefers-reduced-motion:reduce){
  .alephoo-privacy{transition:opacity .2s ease;transform:none;opacity:0}
  .alephoo-privacy.visible{opacity:1;transform:none}
  .alephoo-privacy.dismissing{opacity:0;transform:none}
}

/* ===== NOTICIAS ===== */
.news-card{border:1px solid var(--border);border-radius:16px;overflow:hidden;background:#fff;transition:all .3s}
.news-card:hover{transform:translateY(-4px);box-shadow:0 16px 48px rgba(0,0,0,.08);border-color:var(--teal)}
.news-card-body{padding:24px}
.news-badge{display:inline-block;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;background:var(--teal-light);color:var(--teal);padding:4px 8px;border-radius:6px}
.news-date{font-size:.8rem;color:var(--text-sec);margin-top:8px}
.news-card-body h4{margin-top:12px;font-size:1.05rem}
.news-card-body p{font-size:.875rem;color:var(--text-sec);margin-top:8px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.news-read-more{display:inline-flex;align-items:center;gap:6px;color:var(--teal-text);font-weight:600;font-size:.875rem;margin-top:12px}

/* ===== CLIENTS GRID ===== */
.client-card{border-radius:16px;overflow:hidden;border:1px solid var(--border);transition:all .3s;background:#fff}
.client-card:hover{box-shadow:0 12px 32px rgba(0,0,0,.08);border-color:var(--teal)}
.client-card img{width:100%;aspect-ratio:16/10;object-fit:cover}
.client-card-body{padding:20px}
.client-card-body h4{font-size:1rem}
.client-country{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--teal-text)}

/* ===== FILTER TABS ===== */
.filter-tabs{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-bottom:32px}
.filter-tab{padding:8px 20px;border-radius:100px;font-size:.875rem;font-weight:600;cursor:pointer;border:1px solid var(--border);transition:all .2s;color:var(--text-sec)}
.filter-tab.active{background:var(--teal);color:#fff;border-color:var(--teal)}

/* ===== INTEGRATIONS ===== */
.integration-logo{width:120px;height:80px;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid var(--border);border-radius:12px;padding:16px;transition:all .3s}
.integration-logo:hover{border-color:var(--teal);box-shadow:0 8px 24px rgba(0,0,0,.06)}
.integration-logo img{max-height:40px;max-width:80px;object-fit:contain}

/* ===== PRODUCT VIDEO SECTION ===== */
.product-video-section{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.product-video-section video{width:100%;border-radius:12px;box-shadow:0 12px 32px rgba(0,0,0,.1)}
.product-video-section.reverse{direction:rtl}
.product-video-section.reverse > *{direction:ltr}

/* ===== CTA SECTION ===== */
.cta-section{background:var(--dark);padding:80px 0;text-align:center}
.cta-section h2{color:#fff}
.cta-section .subtitle{color:rgba(255,255,255,.6)}

/* ===== SECURITY PAGE ===== */
.security-hero{background:var(--dark);padding:120px 0 80px;text-align:center;position:relative;overflow:hidden}
.shield-icon{width:80px;height:80px;margin:0 auto 24px;background:rgba(73,196,168,.15);border-radius:24px;display:flex;align-items:center;justify-content:center}
.shield-icon svg{width:40px;height:40px;color:var(--teal-text)}

/* ===== FEATURE LIST ===== */
.feature-list{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.feature-item{display:flex;gap:12px;align-items:flex-start;padding:16px;border-radius:12px;transition:background .2s}
.feature-item:hover{background:var(--bg-alt)}
.feature-item svg{width:20px;height:20px;color:var(--teal-text);flex-shrink:0;margin-top:3px}
.feature-item span{font-size:.9375rem}

/* ===== CONTACT FORM ===== */
.contact-form{max-width:560px}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:.875rem;font-weight:600;margin-bottom:6px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:10px;font-size:1rem;transition:border-color .2s;background:#fff}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(73,196,168,.1)}

/* ===== ANIMATIONS ===== */
.fade-in{opacity:0;transform:translateY(24px);transition:opacity .6s,transform .6s}
.fade-in.visible{opacity:1;transform:translateY(0)}

/* ===== RESPONSIVE ===== */
@media(max-width:768px){
  .nav{display:none}
  .header-actions .btn-outline{display:none}
  .header-actions .btn-primary{padding:9px 14px;font-size:.85rem}
  .header-actions{gap:6px}
  .mobile-toggle{display:flex}
  h1{font-size:2rem !important;line-height:1.2 !important}
  h2{font-size:1.75rem}
  .hero{padding:96px 0 32px}
  .hero h1{font-size:2rem !important}
  .bento-grid{grid-template-columns:1fr}
  .bento-card.span-2,.bento-card.span-row-2{grid-column:span 1;grid-row:span 1}
  .hero-split{grid-template-columns:1fr;text-align:center;gap:24px}
  .hero-metrics{justify-content:center;gap:16px}
  .hero-metric-value{font-size:1.25rem}
  .hero-actions{justify-content:center}
  .hero-video-wrap{min-height:auto}
  .hero-video{border-radius:16px}
  .section{padding:48px 0}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .al-cols-2,.al-cols-3,.al-cols-4,.al-cols-5,.al-cols-5-7,.al-cols-7-5,.al-cols-6-6{grid-template-columns:1fr}
  .product-video-section{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:32px}
  .footer-brand{padding-bottom:8px}
  .footer-badges{gap:14px;margin-top:18px;justify-content:flex-start}
  .footer-badges img{height:54px}
  .metrics-bar{gap:24px}
  .metric-value{font-size:1.75rem}
  .pricing-card.featured{transform:scale(1)}
  .feature-list{grid-template-columns:1fr}
  .hero-content{margin:0 auto}
  .footer-bottom{flex-direction:column;text-align:center}
  .footer-phones{justify-content:center}
  /* Mobile: inline grids que no se cubrian */
  .contact-cards{grid-template-columns:1fr 1fr !important;gap:16px !important}
  .timeline-grid{grid-template-columns:1fr 1fr !important;gap:16px !important}
  .precios-grid{grid-template-columns:1fr !important;gap:40px !important}
  .precios-steps{grid-template-columns:1fr !important;gap:32px !important}
  .integration-grid{grid-template-columns:1fr 1fr !important;gap:16px !important}
  .nosotros-metrics{gap:24px !important}
  .nosotros-metrics>div:not([class]){font-size:2rem !important}
  .clientes-metrics{gap:24px !important}
  .clientes-metrics span[style*="font-size:2.5rem"]{font-size:1.8rem !important}
  .thankyou-steps{gap:24px !important}
  .thankyou-steps>div{max-width:100% !important;flex:1 1 100%}
  .thankyou-hero h1{font-size:1.8rem !important}
  .thankyou-ctas{flex-direction:column !important;align-items:center}
  /* Contacto hero: colapsar a 1 columna en mobile */
  #page-contacto .fade-in[style*="grid-template-columns"]{grid-template-columns:1fr !important;gap:32px !important}
  #page-contacto .fade-in>div:first-child{text-align:center}
  #page-contacto .fade-in>div:first-child h1{font-size:1.8rem}
  #page-contacto .fade-in>div:first-child p{margin-left:auto;margin-right:auto}
  #page-contacto .fade-in>div:first-child>div[style*="flex-wrap"]{justify-content:center}
  #page-contacto .fade-in>div:first-child>div[style*="border-top"]{justify-content:center}
  #page-contacto .fade-in>div:last-child{padding:24px !important;border-radius:20px !important}
  #page-contacto .fade-in>div:last-child div[style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr !important}
  #page-contacto section:first-child{padding:64px 0 40px !important}
  /* Precios — trust statement: stackeado limpio en mobile (sin dots separadores) */
  .precios-trust{flex-direction:column !important;align-items:center !important;gap:8px !important;font-size:.72rem !important;padding-bottom:16px !important}
  .precios-trust > [aria-hidden]{display:none !important}
}
@media(min-width:769px) and (max-width:1024px){
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:repeat(3,1fr)}
}

/* ===== LOGO MARQUEE ===== */
.logo-marquee{overflow:hidden;position:relative;padding:16px 0}
.logo-marquee::before,.logo-marquee::after{content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none}
.logo-marquee::before{left:0;background:linear-gradient(to right,#fff,transparent)}
.logo-marquee::after{right:0;background:linear-gradient(to left,#fff,transparent)}
.section-alt .logo-marquee::before{background:linear-gradient(to right,#F5F5F5,transparent)}
.section-alt .logo-marquee::after{background:linear-gradient(to left,#F5F5F5,transparent)}
.logo-track{display:flex;align-items:center;gap:48px;animation:marquee 30s linear infinite;width:max-content}
.logo-track:hover{animation-play-state:paused}
.logo-track img{height:72px;width:auto;filter:grayscale(100%) opacity(.6);transition:filter .3s}
.logo-track img:hover{filter:grayscale(0%) opacity(1)}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ===== HDE INTRO ===== */
.hde-intro{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;margin-bottom:64px}
.hde-intro-img img{width:100%;border-radius:20px;display:block}
.hde-intro-text h2{font-size:2.75rem;font-weight:800;line-height:1.1;letter-spacing:-.02em}
.hde-intro-text .section-label{display:inline-block}

/* ===== HDE DARK CARD ===== */
.hde-card{background:#0D283D;border-radius:24px;padding:40px 48px 40px 48px;color:#fff;transition:box-shadow .4s cubic-bezier(.4,0,.2,1)}
.hde-card:hover{box-shadow:0 24px 64px rgba(0,0,0,.2),0 0 0 1px rgba(73,196,168,.08)}
.hde-pills{display:flex;gap:8px;margin-bottom:28px}
.hde-pill{padding:8px 24px;font-weight:600;font-size:.9rem;color:rgba(255,255,255,.6);cursor:pointer;border-radius:999px;border:1.5px solid rgba(255,255,255,.2);background:transparent;transition:all .25s}
.hde-pill:hover{color:#fff;border-color:rgba(255,255,255,.5)}
.hde-pill.active{color:#fff;background:#49C4A8;border-color:#49C4A8}
.hde-panel{display:none;animation:tabFadeIn .4s ease}
.hde-panel.active{display:grid;grid-template-columns:1fr 1.15fr;gap:48px;align-items:center}
.hde-panel h3{color:#fff;font-size:2rem;line-height:1.2}
.hde-panel h3 em{font-style:normal;color:#49C4A8}
.hde-panel .text-sec{color:rgba(255,255,255,.7);font-size:.95rem;line-height:1.7}
.hde-panel .btn-primary{background:var(--teal);color:var(--dark);font-weight:700}
.hde-panel .btn-primary:hover{background:var(--teal-hover)}
.hde-panel .hde-img{border-radius:16px;overflow:hidden;width:100%}
.hde-panel .hde-img img,.hde-panel .hde-img video{width:100%;display:block;border-radius:0;aspect-ratio:16/10;object-fit:cover}
@keyframes tabFadeIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* ===== VIDEO CAROUSEL ===== */
.video-carousel{position:relative;overflow:hidden}
.video-carousel-track{display:flex;gap:24px;transition:transform .45s cubic-bezier(.4,0,.2,1);flex-wrap:nowrap}
.video-carousel-track .video-card{flex:0 0 auto;cursor:pointer;width:calc((100% - 48px) / 3)}
.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:#fff;border:1px solid #E5E7EB;box-shadow:0 4px 12px rgba(0,0,0,.08);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:3;transition:all .2s}
.carousel-btn:hover{background:#49C4A8;border-color:#49C4A8;color:#fff;box-shadow:0 4px 16px rgba(73,196,168,.3)}
.carousel-btn svg{width:20px;height:20px}
.carousel-btn.prev{left:-8px}
.carousel-btn.next{right:-8px}
.carousel-dots{display:flex;justify-content:center;gap:8px;margin-top:24px}
/* Dot visual: 8px circle. Actual tappable area: 44x44 (WCAG 2.5.5) thanks to padding:18px + box-sizing:content-box. */
.carousel-dot{width:8px;height:8px;flex-shrink:0;border-radius:50%;background:#E5E7EB;border:none;cursor:pointer;transition:all .2s;padding:18px;background-clip:content-box;box-sizing:content-box}
.carousel-dot.active{background:#49C4A8;width:24px;border-radius:4px;background-clip:content-box}

@media(max-width:768px){
  .wheel-container{transform:scale(0.5);margin:-120px}
  .wheel-wrapper{max-height:300px;overflow:hidden}
  .hero-split .wheel-wrapper{display:none}
  .hde-intro{grid-template-columns:1fr;gap:32px}
  .hde-intro-text h2{font-size:2rem}
  .hde-card{padding:24px 20px;border-radius:16px}
  .hde-panel.active{grid-template-columns:1fr}
  .hde-panel h3{font-size:1.6rem}
  .video-carousel-track .video-card{width:100% !important}
  .hde-pills{display:grid;grid-template-columns:1fr 1fr;gap:8px;align-items:stretch;overflow:visible}
  .hde-pill{padding:10px 12px;font-size:.82rem;text-align:center;white-space:normal;line-height:1.3;display:flex;align-items:center;justify-content:center}
  .carousel-btn{display:none}
}

/* ===== THANK YOU CHECK ANIMATION ===== */
.thankyou-check-circle{stroke-dasharray:151;stroke-dashoffset:151;animation:drawCircle .8s cubic-bezier(.65,0,.35,1) .3s forwards}
.thankyou-check-mark{stroke-dasharray:30;stroke-dashoffset:30;animation:drawCheck .4s cubic-bezier(.65,0,.35,1) .9s forwards}
.thankyou-check-container{animation:checkPop .5s cubic-bezier(.34,1.56,.64,1) .2s both}
@keyframes drawCircle{to{stroke-dashoffset:0}}
@keyframes drawCheck{to{stroke-dashoffset:0}}
@keyframes checkPop{0%{transform:scale(0);opacity:0}100%{transform:scale(1);opacity:1}}

/* ===== REDUCED MOTION ===== */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important;scroll-behavior:auto !important}
  .fade-in,.fade-in-left,.fade-in-right{opacity:1;transform:none}
  .logo-track{animation:none}
  .wheel-container .solution-node{opacity:1;transform:none}
  .thankyou-check-circle,.thankyou-check-mark,.thankyou-check-container{animation:none;stroke-dashoffset:0;opacity:1;transform:scale(1)}
}

/* ===== SKIP LINK ===== */
.skip-link{position:absolute;top:-100%;left:16px;background:var(--teal);color:#fff;padding:12px 24px;border-radius:0 0 12px 12px;font-weight:600;font-size:.875rem;z-index:10000;transition:top .2s}
.skip-link:focus{top:0}

/* ===== PAGE VISIBILITY ===== */
.page{display:none}
.page.active{display:block}

/* ===== CASO CAROUSEL ===== */
.caso-slide .product-video-section{grid-template-columns:1fr 1fr}
@media(max-width:768px){
  .caso-slide .product-video-section{grid-template-columns:1fr}
  .caso-slide .grid-2,.caso-slide .grid-3{grid-template-columns:repeat(2,1fr)}
}