/* ═══════════════════════════════════════════════════
   IMPELLIA v2 — Full Premium Redesign
   ═══════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --dark:      #0A0F1E;
  --dark-2:    #0E1628;
  --dark-3:    #111E35;
  --mid:       #1A2A48;
  --blue:      #4F8EF7;
  --violet:    #6366F1;
  --ice:       #F0F6FF;
  --muted:     #5E7BA0;
  --muted-2:   #8AA5C8;
  --white:     #FFFFFF;
  --green:     #22C55E;
  --font:      'Plus Jakarta Sans',system-ui,-apple-system,sans-serif;
  --radius:    6px;
  --radius-lg: 16px;
  --nav-h:     72px;
  --w:         1240px;
  --px:        clamp(20px,5vw,80px);
  --py:        clamp(80px,10vw,130px);
}

html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font);background:var(--dark);color:var(--ice);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
ul{list-style:none}
button{border:none;background:none;cursor:pointer;font:inherit}

/* ── Utility ──────────────────────────────────────── */
.section-inner{max-width:var(--w);margin:0 auto;padding:var(--py) var(--px)}
.eyebrow{display:block;font-size:.72rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--blue);margin-bottom:1rem}
.gradient-text{background:linear-gradient(135deg,var(--blue) 0%,var(--violet) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.section-header{text-align:center;margin-bottom:60px}
.section-header h2{font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:300;letter-spacing:-.025em;line-height:1.2;margin-bottom:.8rem}
.section-sub{font-size:.975rem;color:var(--muted-2);max-width:560px;margin:0 auto}

[data-scroll]{opacity:0;transform:translateY(24px);transition:opacity .65s ease,transform .65s ease}
[data-scroll="fade-right"]{transform:translateX(-30px)}
[data-scroll="fade-left"]{transform:translateX(30px)}
[data-scroll].in-view{opacity:1;transform:translate(0)}
@media(prefers-reduced-motion:reduce){[data-scroll]{opacity:1;transform:none}}

/* ── Buttons ───────────────────────────────────────── */
.btn-primary{display:inline-block;background:var(--blue);color:var(--dark);padding:14px 28px;border-radius:100px;font-size:.92rem;font-weight:600;letter-spacing:.02em;transition:transform .2s,box-shadow .2s}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(79,142,247,.4)}
.btn-primary.large{padding:18px 40px;font-size:1rem}
.btn-ghost{display:inline-block;color:var(--muted-2);padding:14px 24px;border-radius:100px;border:1px solid rgba(255,255,255,.1);font-size:.92rem;transition:color .2s,border-color .2s}
.btn-ghost:hover{color:var(--ice);border-color:rgba(255,255,255,.3)}

/* ══════════════ NAV ══════════════════════════════════ */
#nav{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-h);transition:background .3s,backdrop-filter .3s}
#nav.scrolled{background:rgba(10,15,30,.9);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom:1px solid rgba(79,142,247,.1)}
.nav-inner{max-width:var(--w);margin:0 auto;padding:0 var(--px);height:100%;display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav-logo{display:flex;align-items:center;gap:10px;flex-shrink:0}
.nav-logo-text{font-size:.82rem;font-weight:300;letter-spacing:.22em;color:var(--ice)}
.nav-links{display:flex;align-items:center;gap:28px;flex:1;justify-content:center}
.nav-links a{font-size:.85rem;color:var(--muted-2);transition:color .2s;font-weight:400;white-space:nowrap}
.nav-links a:hover{color:var(--ice)}
.nav-cta{color:var(--blue)!important;font-weight:500!important}
.nav-right{display:flex;align-items:center;gap:16px}

/* Language switch */
.lang-switch{display:flex;gap:4px}
.lang-btn{font-size:.72rem;font-weight:600;letter-spacing:.08em;color:var(--muted);padding:5px 9px;border-radius:4px;transition:color .2s,background .2s}
.lang-btn:hover{color:var(--ice)}
.lang-btn.active{color:var(--blue);background:rgba(79,142,247,.1)}

.nav-hamburger{display:none;flex-direction:column;gap:5px;padding:6px}
.nav-hamburger span{display:block;width:22px;height:1.5px;background:var(--ice);transition:transform .3s,opacity .3s}

/* ══════════════ HERO ══════════════════════════════════ */
#hero{min-height:100svh;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden;padding-top:var(--nav-h)}
#heroCanvas{position:absolute;inset:0;width:100%;height:100%}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(10,15,30,.2) 0%,rgba(10,15,30,.6) 70%,var(--dark) 100%)}
.hero-content{position:relative;z-index:2;max-width:var(--w);margin:0 auto;padding:0 var(--px) 80px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(79,142,247,.1);border:1px solid rgba(79,142,247,.2);border-radius:100px;padding:6px 16px;font-size:.75rem;letter-spacing:.1em;color:var(--blue);text-transform:uppercase;margin-bottom:2rem}
.badge-dot{width:6px;height:6px;border-radius:50%;background:var(--blue);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.hero-title{font-size:clamp(3rem,7.5vw,6rem);font-weight:200;line-height:1.06;letter-spacing:-.025em;color:var(--white);margin-bottom:1.5rem;max-width:860px}
.hero-sub{font-size:clamp(1rem,1.5vw,1.18rem);color:var(--muted-2);max-width:560px;margin-bottom:2.5rem;line-height:1.75;font-weight:300}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:4rem}
.hero-stats{display:flex;gap:36px;flex-wrap:wrap;align-items:flex-start}
.stat{display:flex;flex-direction:column;gap:4px}
.stat-n{font-size:clamp(1.8rem,3vw,2.6rem);font-weight:200;color:var(--white);letter-spacing:-.025em;line-height:1}
.stat-l{font-size:.72rem;color:var(--muted);max-width:130px;line-height:1.4}
.stat-sep{width:1px;height:44px;background:rgba(255,255,255,.08);align-self:center}
.hero-scroll-hint{position:absolute;bottom:32px;left:50%;transform:translateX(-50%)}
.hero-scroll-hint span{display:block;width:1px;height:60px;background:linear-gradient(to bottom,var(--blue),transparent);animation:scrollLine 2.2s infinite}
@keyframes scrollLine{0%{opacity:0;transform:scaleY(0);transform-origin:top}50%{opacity:1;transform:scaleY(1);transform-origin:top}100%{opacity:0;transform:scaleY(1);transform-origin:bottom}}

/* ══════════════ LOGOS STRIP ══════════════════════════ */
.logos-strip{border-top:1px solid rgba(255,255,255,.05);border-bottom:1px solid rgba(255,255,255,.05);padding:22px 0;overflow:hidden}
.logos-inner{max-width:var(--w);margin:0 auto;padding:0 var(--px);display:flex;align-items:center;gap:28px;flex-wrap:wrap}
.logos-label{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);white-space:nowrap;flex-shrink:0}
.logos-track{display:flex;gap:10px;flex-wrap:wrap}
.logo-pill{font-size:.75rem;color:var(--muted-2);padding:5px 12px;border:1px solid rgba(255,255,255,.07);border-radius:100px;white-space:nowrap;transition:color .2s,border-color .2s}
.logo-pill:hover{color:var(--ice);border-color:rgba(79,142,247,.3)}

/* ══════════════ SERVICES ══════════════════════════════ */
.services-section{background:var(--dark-2)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.service-card{background:var(--dark-3);display:flex;flex-direction:column;transition:background .3s;border:1px solid transparent;position:relative}
.service-card:hover{background:rgba(15,24,48,1);border-color:rgba(79,142,247,.15);z-index:1}
.service-card.featured{background:linear-gradient(155deg,rgba(79,142,247,.09),rgba(99,102,241,.06));border:1px solid rgba(79,142,247,.2)}
.service-badge{position:absolute;top:16px;right:16px;background:rgba(79,142,247,.15);color:var(--blue);font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:4px 10px;border-radius:100px;border:1px solid rgba(79,142,247,.25)}

/* service image area */
.service-img{height:180px;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}
.service-img--chat{background:linear-gradient(135deg,rgba(79,142,247,.06),rgba(99,102,241,.04))}
.service-img--flow{background:linear-gradient(135deg,rgba(99,102,241,.06),rgba(79,142,247,.04))}
.service-img--agent{background:linear-gradient(135deg,rgba(79,142,247,.08),rgba(6,182,212,.04))}
.service-img--web{background:linear-gradient(135deg,rgba(15,28,56,.8),rgba(30,50,90,.4))}
.service-img--consult{background:linear-gradient(135deg,rgba(79,142,247,.06),rgba(30,50,90,.3))}
.service-img--retainer{background:linear-gradient(135deg,rgba(99,102,241,.06),rgba(79,142,247,.04))}
.svc-visual{width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative}

/* chat bubbles visual */
.chat-bubble{display:flex;align-items:center;gap:6px;padding:7px 12px;border-radius:12px;font-size:.72rem;position:absolute;max-width:155px;line-height:1.3}
.chat-bubble.left{background:rgba(255,255,255,.08);left:20px}
.chat-bubble.left:nth-child(1){top:22px}
.chat-bubble.left:nth-child(3){bottom:22px;left:28px}
.chat-bubble.right{background:rgba(79,142,247,.2);right:20px;top:50%;transform:translateY(-50%);flex-direction:column;align-items:flex-end}
.ai-tag{background:var(--blue);color:var(--dark);font-size:.6rem;font-weight:700;padding:2px 6px;border-radius:4px;letter-spacing:.06em}
.pulse-ring{position:absolute;right:28px;top:50%;transform:translateY(-50%);width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 rgba(34,197,94,.5);animation:pingRing 1.8s infinite}
@keyframes pingRing{0%{box-shadow:0 0 0 0 rgba(34,197,94,.4)}70%{box-shadow:0 0 0 12px rgba(34,197,94,0)}100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}}

/* flow visual */
.flow-visual{position:relative}
.flow-node{position:absolute;background:rgba(79,142,247,.15);border:1px solid rgba(79,142,247,.3);border-radius:6px;padding:5px 10px;font-size:.7rem;color:var(--blue);font-weight:600}
.flow-node.n1{left:16px;top:50%;transform:translateY(-50%)}
.flow-node.n2{left:50%;top:50%;transform:translate(-50%,-50%);background:rgba(79,142,247,.25);border-color:var(--blue)}
.flow-node.n3{right:16px;top:30%}
.flow-node.n4{right:16px;bottom:28%}
.flow-line{position:absolute;background:linear-gradient(90deg,rgba(79,142,247,.4),rgba(79,142,247,.1));height:1px}
.flow-line.l1{left:78px;top:50%;width:calc(50% - 78px)}
.flow-line.l2{right:78px;top:35%;width:80px;transform:rotate(-25deg)}

/* agent brain visual */
.agent-brain{position:relative;width:110px;height:110px;display:flex;align-items:center;justify-content:center}
.a-core{width:28px;height:28px;border-radius:50%;background:radial-gradient(circle,var(--blue),var(--violet));box-shadow:0 0 20px rgba(79,142,247,.5)}
.a-ring{position:absolute;border-radius:50%;border:1px solid;animation:spin linear infinite}
.a-ring.r1{width:60px;height:60px;border-color:rgba(79,142,247,.3);animation-duration:6s}
.a-ring.r2{width:95px;height:95px;border-color:rgba(99,102,241,.2);animation-duration:10s;animation-direction:reverse}
@keyframes spin{to{transform:rotate(360deg)}}
.a-node{position:absolute;width:8px;height:8px;border-radius:50%;background:var(--blue)}
.a-node.an1{top:6px;left:50%;transform:translateX(-50%)}
.a-node.an2{right:6px;top:50%;transform:translateY(-50%)}
.a-node.an3{bottom:6px;left:50%;transform:translateX(-50%)}
.a-node.an4{left:6px;top:50%;transform:translateY(-50%)}

/* browser mockup visual */
.browser-mockup{width:160px;border-radius:8px;overflow:hidden;border:1px solid rgba(255,255,255,.12)}
.browser-bar{background:rgba(255,255,255,.07);padding:8px 10px;display:flex;gap:5px;align-items:center}
.dot{width:7px;height:7px;border-radius:50%}
.dot.r{background:rgba(255,92,92,.6)}
.dot.y{background:rgba(255,200,60,.6)}
.dot.g{background:rgba(52,211,153,.6)}
.browser-body{background:rgba(10,15,30,.8);padding:10px}
.brow-hero{height:35px;background:linear-gradient(135deg,rgba(79,142,247,.3),rgba(99,102,241,.2));border-radius:4px;margin-bottom:8px}
.brow-lines{display:flex;flex-direction:column;gap:5px;margin-bottom:8px}
.brow-lines span{display:block;height:4px;background:rgba(255,255,255,.08);border-radius:2px}
.brow-lines span:last-child{width:60%}
.brow-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:5px}
.brow-cards span{display:block;height:22px;background:rgba(79,142,247,.15);border-radius:3px}

/* consult chart is inline SVG */

/* retainer calendar */
.calendar-widget{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:16px;width:130px}
.cal-header{font-size:.75rem;font-weight:600;color:var(--blue);margin-bottom:10px;text-align:center}
.cal-body{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:10px}
.cal-dot{width:20px;height:20px;border-radius:50%;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08)}
.cal-dot.done{background:rgba(79,142,247,.25);border-color:rgba(79,142,247,.4)}
.cal-dot.active{background:var(--blue);box-shadow:0 0 8px rgba(79,142,247,.6);animation:pulse 2s infinite}
.cal-label{font-size:.65rem;color:var(--green);text-align:center;display:flex;align-items:center;justify-content:center;gap:4px}
.cal-label::before{content:'●';font-size:.5rem}

/* service body */
.service-body{padding:28px 28px 32px;flex:1;display:flex;flex-direction:column}
.service-num{display:block;font-size:.68rem;color:var(--muted);letter-spacing:.16em;margin-bottom:8px}
.service-body h3{font-size:1.1rem;font-weight:500;margin-bottom:10px;color:var(--ice)}
.service-body p{font-size:.85rem;color:var(--muted-2);line-height:1.68;margin-bottom:16px}
.svc-tags{display:flex;flex-direction:column;gap:6px;margin-bottom:20px;flex:1}
.svc-tags li{font-size:.78rem;color:var(--muted);padding-left:14px;position:relative}
.svc-tags li::before{content:'·';position:absolute;left:0;color:var(--blue);font-size:1rem;line-height:1.2}
.svc-link{font-size:.82rem;color:var(--blue);font-weight:500;transition:letter-spacing .2s}
.svc-link:hover{letter-spacing:.04em}

/* ══════════════ PORTFOLIO ══════════════════════════════ */
.portfolio-section{background:var(--dark)}
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.port-card{display:flex;flex-direction:column;border-radius:var(--radius-lg);overflow:hidden;border:1px solid rgba(255,255,255,.06);transition:transform .3s,border-color .3s,box-shadow .3s;background:var(--dark-2)}
.port-card:hover{transform:translateY(-6px);border-color:rgba(79,142,247,.25);box-shadow:0 20px 60px rgba(0,0,0,.4)}
.port-card--wide{grid-column:span 1}
.port-preview{position:relative;overflow:hidden;height:200px;background:var(--dark-3)}
.port-preview img{width:100%;height:100%;object-fit:cover;object-position:top;transition:transform .5s ease}
.port-card:hover .port-preview img{transform:scale(1.04)}
.port-preview.no-img{background:linear-gradient(135deg,rgba(79,142,247,.08),rgba(99,102,241,.06))}
.port-preview.no-img::after{content:'';position:absolute;inset:0;background:
  repeating-linear-gradient(45deg,rgba(79,142,247,.04) 0,rgba(79,142,247,.04) 1px,transparent 0,transparent 50%)
  0 0/20px 20px}
.port-overlay{position:absolute;inset:0;background:rgba(10,15,30,.7);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s;backdrop-filter:blur(4px)}
.port-card:hover .port-overlay{opacity:1}
.port-visit{font-size:.85rem;font-weight:500;color:var(--white);border:1px solid rgba(255,255,255,.4);padding:8px 20px;border-radius:100px;transition:background .2s}
.port-visit:hover{background:rgba(255,255,255,.1)}
.port-info{padding:16px 20px;display:flex;flex-direction:column;gap:4px}
.port-cat{font-size:.7rem;color:var(--blue);letter-spacing:.08em;text-transform:uppercase}
.port-info strong{font-size:.9rem;font-weight:500;color:var(--ice)}

/* ══════════════ PROCESS ══════════════════════════════ */
.process-section{background:var(--dark-2)}
.process-steps{display:flex;align-items:flex-start;justify-content:center;gap:0;margin-bottom:48px}
.process-step{flex:1;max-width:220px;display:flex;flex-direction:column;align-items:center;text-align:center;padding:0 8px}
.step-head{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:16px}
.step-num{font-size:2.8rem;font-weight:200;color:rgba(79,142,247,.2);line-height:1;letter-spacing:-.03em}
.step-icon{width:44px;height:44px;background:rgba(79,142,247,.1);border:1px solid rgba(79,142,247,.2);border-radius:10px;display:flex;align-items:center;justify-content:center}
.process-step h3{font-size:.95rem;font-weight:500;color:var(--ice);margin-bottom:6px}
.step-hook{font-size:.8rem;color:var(--blue);font-style:italic}
.process-arrow{font-size:1.4rem;color:rgba(79,142,247,.3);padding-top:28px;flex-shrink:0}
.process-cta{text-align:center}

/* ══════════════ MARKETS ══════════════════════════════ */
.markets-section{background:var(--dark)}
.markets-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.market-card{background:var(--dark-2);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-lg);overflow:hidden;transition:border-color .3s,transform .3s}
.market-card:hover{border-color:rgba(79,142,247,.2);transform:translateY(-3px)}
.market-map{height:200px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.eu-map{background:linear-gradient(135deg,rgba(79,142,247,.06),rgba(99,102,241,.04))}
.latam-map{background:linear-gradient(135deg,rgba(34,197,94,.05),rgba(79,142,247,.04))}
.map-dots{position:relative;width:200px;height:160px}
.mdot{position:absolute;font-size:1.1rem;cursor:default;transition:transform .2s;filter:drop-shadow(0 2px 4px rgba(0,0,0,.4))}
.mdot:hover{transform:scale(1.3)}
.market-glow{position:absolute;width:200px;height:200px;border-radius:50%;filter:blur(60px);pointer-events:none}
.eu-glow{background:rgba(79,142,247,.08);top:50%;left:50%;transform:translate(-50%,-50%)}
.latam-glow{background:rgba(34,197,94,.08);top:50%;left:50%;transform:translate(-50%,-50%)}
.market-content{padding:28px 32px}
.market-flag-big{font-size:2.5rem;margin-bottom:12px}
.market-content h3{font-size:1.25rem;font-weight:500;margin-bottom:14px}
.market-kpi{display:flex;align-items:baseline;gap:8px;margin-bottom:16px}
.kpi-n{font-size:2rem;font-weight:200;color:var(--blue);letter-spacing:-.025em;line-height:1}
.kpi-l{font-size:.8rem;color:var(--muted-2)}
.market-countries{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}
.market-countries span{font-size:.78rem;color:var(--muted-2);background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:100px;padding:3px 10px}
.market-langs{font-size:.75rem;color:var(--muted);padding-top:12px;border-top:1px solid rgba(255,255,255,.05)}

/* ══════════════ CASES ACCORDION ══════════════════════ */
.cases-section{background:var(--dark-2)}
.cases-accordion{display:flex;flex-direction:column;gap:2px}
.case-item{background:var(--dark-3);overflow:hidden}
.case-item.open{background:rgba(15,24,50,1)}
.case-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;padding:22px 28px;cursor:pointer;transition:background .2s;text-align:left}
.case-trigger:hover{background:rgba(79,142,247,.04)}
.case-trigger-main{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.case-sector{font-size:.88rem;color:var(--muted-2);font-weight:400}
.case-item.open .case-sector{color:var(--ice)}
.case-result-badge{font-size:.75rem;font-weight:600;color:var(--blue);background:rgba(79,142,247,.12);border:1px solid rgba(79,142,247,.2);padding:4px 12px;border-radius:100px;white-space:nowrap}
.case-chevron{font-size:1.4rem;color:var(--muted);transition:transform .3s;flex-shrink:0;line-height:1}
.case-item.open .case-chevron{transform:rotate(45deg);color:var(--blue)}
.case-body{max-height:0;overflow:hidden;transition:max-height .45s cubic-bezier(.4,0,.2,1)}
.case-item.open .case-body{max-height:400px}
.case-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.04);padding:0}
.case-col{padding:24px 28px;background:var(--dark-2)}
.col-label{display:block;font-size:.66rem;color:var(--blue);letter-spacing:.15em;text-transform:uppercase;margin-bottom:8px}
.case-col.prob p,.case-col.sol p{font-size:.85rem;color:var(--muted-2);line-height:1.65}
.result-metrics{display:flex;flex-direction:column;gap:12px}
.rm{display:flex;align-items:baseline;gap:8px}
.rm-n{font-size:1.6rem;font-weight:200;color:var(--blue);letter-spacing:-.025em;line-height:1}
.rm-l{font-size:.78rem;color:var(--muted-2)}

/* ══════════════ ABOUT / FOUNDER ══════════════════════ */
.about-section{background:var(--dark)}
.about-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:80px;align-items:flex-start}
.about-text .eyebrow{margin-bottom:1rem}
.about-text h2{font-size:clamp(1.6rem,2.8vw,2.3rem);font-weight:300;line-height:1.22;letter-spacing:-.022em;margin-bottom:1.4rem}
.about-text>p{font-size:.9rem;color:var(--muted-2);line-height:1.78;margin-bottom:1rem}
.about-pillars{display:flex;flex-direction:column;gap:20px;margin-top:1.8rem}
.pillar{display:flex;gap:14px;align-items:flex-start}
.pillar-icon{font-size:1.1rem;margin-top:3px;flex-shrink:0}
.pillar strong{display:block;font-size:.9rem;font-weight:500;color:var(--ice);margin-bottom:4px}
.pillar p{font-size:.82rem;color:var(--muted-2);line-height:1.6}

/* founder card */
.founder-card{background:var(--dark-2);border:1px solid rgba(79,142,247,.14);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:20px}
.founder-photo-wrapper{width:100%;height:280px;overflow:hidden;position:relative;background:var(--dark-3)}
.founder-photo{width:100%;height:100%;object-fit:cover;object-position:center top}
.founder-ph-fallback{width:100%;height:100%;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(79,142,247,.15),rgba(99,102,241,.1))}
.founder-initials{width:90px;height:90px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--violet));display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:300;color:var(--white)}
.founder-details{padding:24px 28px}
.founder-name-block{margin-bottom:16px}
.founder-name-block strong{display:block;font-size:1.1rem;font-weight:500;margin-bottom:4px}
.founder-title,.founder-loc{display:block;font-size:.8rem;color:var(--muted-2)}
.founder-loc{font-size:.75rem;color:var(--muted);margin-top:2px}
.founder-bio{font-size:.83rem;color:var(--muted-2);line-height:1.7;margin-bottom:16px}
.founder-skills{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:20px}
.founder-skills span{font-size:.7rem;color:var(--muted-2);border:1px solid rgba(255,255,255,.08);border-radius:100px;padding:3px 10px}
.founder-linkedin{display:inline-flex;align-items:center;gap:7px;font-size:.8rem;color:var(--blue);font-weight:500;border:1px solid rgba(79,142,247,.25);padding:8px 16px;border-radius:100px;transition:background .2s}
.founder-linkedin:hover{background:rgba(79,142,247,.08)}

.trust-badges{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.trust-badge{background:var(--dark-2);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius);padding:16px;text-align:center}
.tb-n{display:block;font-size:1.5rem;font-weight:200;color:var(--blue);letter-spacing:-.02em;line-height:1;margin-bottom:4px}
.tb-l{font-size:.72rem;color:var(--muted);line-height:1.3}

/* ══════════════ CTA ════════════════════════════════ */
.cta-section{position:relative;background:var(--dark-2);overflow:hidden}
.cta-bg{position:absolute;inset:0;background:radial-gradient(ellipse 70% 80% at 50% 50%,rgba(79,142,247,.08) 0%,rgba(99,102,241,.05) 50%,transparent 100%);pointer-events:none}
.cta-section .section-inner{padding-top:100px;padding-bottom:100px}
.cta-content{text-align:center;max-width:700px;margin:0 auto;position:relative;z-index:1}
.eyebrow.light{color:rgba(79,142,247,.7)}
.cta-content h2{font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:300;line-height:1.2;letter-spacing:-.025em;margin-bottom:1rem}
.cta-content>p{font-size:1rem;color:var(--muted-2);margin-bottom:2.4rem}
.cta-actions{margin-bottom:1.2rem}
.cta-email-note{font-size:.82rem;color:var(--muted);margin-bottom:2rem}
.cta-email-note a{color:var(--blue);text-decoration:underline}
.cta-guarantees{display:flex;gap:24px;justify-content:center;flex-wrap:wrap}
.cta-guarantees span{font-size:.78rem;color:var(--muted);display:flex;gap:6px;align-items:center}
.cta-guarantees>span>span:first-child{color:var(--green)}

/* ══════════════ FOOTER ════════════════════════════ */
.site-footer{background:var(--dark);border-top:1px solid rgba(255,255,255,.05)}
.footer-inner{max-width:var(--w);margin:0 auto;padding:60px var(--px) 36px;display:grid;grid-template-columns:1fr 2fr;gap:60px}
.footer-brand .nav-logo{margin-bottom:14px}
.footer-brand p{font-size:.82rem;color:var(--muted);line-height:1.6;margin-bottom:10px}
.footer-email{font-size:.82rem;color:var(--blue)}
.footer-links{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.footer-col{display:flex;flex-direction:column;gap:10px}
.footer-col strong{font-size:.72rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2);margin-bottom:4px}
.footer-col a{font-size:.82rem;color:var(--muted);transition:color .2s}
.footer-col a:hover{color:var(--ice)}
.footer-bottom{max-width:var(--w);margin:0 auto;padding:18px var(--px);border-top:1px solid rgba(255,255,255,.04);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;font-size:.75rem;color:var(--muted)}
.footer-lang{margin:0}

/* ══════════════ RESPONSIVE ════════════════════════ */
@media(max-width:1100px){
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .portfolio-grid{grid-template-columns:repeat(2,1fr)}
  .nav-links{gap:18px}
  .nav-links a{font-size:.8rem}
}
@media(max-width:960px){
  .nav-links{gap:14px}
  .nav-links a{font-size:.78rem}
}
@media(max-width:960px){
  .about-grid{grid-template-columns:1fr;gap:48px}
  .markets-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  .nav-links{display:none}
  .nav-links.open{display:flex;flex-direction:column;position:fixed;top:var(--nav-h);left:0;right:0;background:rgba(10,15,30,.97);padding:28px var(--px) 40px;gap:20px;backdrop-filter:blur(18px);border-bottom:1px solid rgba(255,255,255,.06)}
  .nav-hamburger{display:flex}
  .services-grid{grid-template-columns:1fr}
  .portfolio-grid{grid-template-columns:1fr}
  .process-steps{flex-direction:column;align-items:center;gap:24px}
  .process-arrow{display:none}
  .case-cols{grid-template-columns:1fr}
  .cases-accordion .case-item.open .case-body{max-height:900px}
  .footer-inner{grid-template-columns:1fr;gap:40px}
  .footer-links{grid-template-columns:1fr 1fr}
  .trust-badges{grid-template-columns:repeat(3,1fr)}
  .hero-stats{flex-direction:column;gap:20px}
  .stat-sep{display:none}
}
@media(max-width:520px){
  .hero-title{font-size:2.6rem}
  .hero-actions{flex-direction:column}
  .portfolio-grid{grid-template-columns:1fr}
  .footer-links{grid-template-columns:1fr}
  .trust-badges{grid-template-columns:1fr 1fr}
  .markets-grid{grid-template-columns:1fr}
  .cta-guarantees{flex-direction:column;align-items:center}
}

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

/* ══════════════ PREMIUM UPGRADES v3 ════════════════════
   UI UX Pro Max: Liquid Glass + OLED Dark + Motion One
   ════════════════════════════════════════════════════ */

/* ── OLED deeper blacks ─────────────────────────────── */
:root{
  --dark:    #000000;
  --dark-2:  #080c18;
  --dark-3:  #0c1220;
  --mid:     #0f1a30;
}

/* ── Grain texture overlay ──────────────────────────── */
#grain{
  position:fixed;inset:0;z-index:9998;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
  opacity:.028;mix-blend-mode:overlay
}

/* ── Gradient mesh background ───────────────────────── */
#mesh-bg{
  position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(ellipse 60% 50% at 20% 20%,rgba(79,142,247,.07) 0%,transparent 60%),
    radial-gradient(ellipse 50% 40% at 80% 70%,rgba(99,102,241,.06) 0%,transparent 55%),
    radial-gradient(ellipse 40% 60% at 50% 100%,rgba(124,126,255,.04) 0%,transparent 50%);
  animation:meshDrift 20s ease-in-out infinite alternate
}
@keyframes meshDrift{
  0%{background-position:0% 0%,100% 100%,50% 0%}
  100%{background-position:10% 15%,90% 80%,60% 100%}
}

/* ── Liquid Glass nav ───────────────────────────────── */
#nav.scrolled{
  background:rgba(0,0,0,.65);
  backdrop-filter:blur(28px) saturate(180%);
  -webkit-backdrop-filter:blur(28px) saturate(180%);
  border-bottom:1px solid rgba(91,159,255,.12);
  box-shadow:0 1px 0 rgba(91,159,255,.06),0 8px 32px rgba(0,0,0,.4)
}

/* ── Liquid Glass service cards ─────────────────────── */
.service-card{
  background:rgba(8,12,24,.6);
  backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);
  border:1px solid rgba(255,255,255,.06);
  transition:background .4s,border-color .4s,transform .5s cubic-bezier(.34,1.56,.64,1),box-shadow .4s
}
.service-card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.04) 0%,transparent 50%);
  border-radius:inherit;pointer-events:none
}
.service-card:hover{
  background:rgba(12,18,32,.8);
  border-color:rgba(91,159,255,.25);
  transform:translateY(-10px) scale(1.015);
  box-shadow:0 30px 80px rgba(0,0,0,.6),0 0 0 1px rgba(91,159,255,.15),inset 0 1px 0 rgba(255,255,255,.08)
}
.service-card.featured{
  background:linear-gradient(155deg,rgba(91,159,255,.12),rgba(124,126,255,.08));
  border-color:rgba(91,159,255,.3);
  box-shadow:0 0 40px rgba(91,159,255,.08)
}

/* ── Liquid Glass portfolio cards ───────────────────── */
.port-card{
  background:rgba(8,12,24,.7);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.07)
}
.port-card:hover{
  border-color:rgba(91,159,255,.3);
  box-shadow:0 40px 80px rgba(0,0,0,.6),inset 0 1px 0 rgba(255,255,255,.07)
}

/* ── Iridescent gradient text ───────────────────────── */
.gradient-text{
  background:linear-gradient(135deg,#5B9FFF 0%,#A78BFA 40%,#EC4899 70%,#5B9FFF 100%);
  background-size:300% 300%;
  animation:iridescent 8s ease infinite;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  filter:drop-shadow(0 0 30px rgba(91,159,255,.3))
}
@keyframes iridescent{
  0%,100%{background-position:0% 50%}
  50%{background-position:100% 50%}
}

/* ── Shimmer CTA button ─────────────────────────────── */
.btn-primary{
  position:relative;overflow:hidden;
  background:linear-gradient(135deg,var(--blue),var(--violet));
  border:1px solid rgba(255,255,255,.15);
  box-shadow:0 4px 24px rgba(91,159,255,.25)
}
.btn-primary::before{
  content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);
  transform:skewX(-20deg);transition:left .6s ease
}
.btn-primary:hover::before{left:150%}
.btn-primary:hover{
  transform:translateY(-3px);
  box-shadow:0 0 60px rgba(91,159,255,.7),0 8px 32px rgba(91,159,255,.4),inset 0 1px 0 rgba(255,255,255,.2)
}

/* ── Process cards liquid glass ─────────────────────── */
.proc-step-card{
  background:rgba(8,12,24,.65);
  backdrop-filter:blur(14px) saturate(130%);
  -webkit-backdrop-filter:blur(14px) saturate(130%);
  border:1px solid rgba(255,255,255,.07)
}
.proc-step-card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.04) 0%,transparent 60%);
  border-radius:inherit;pointer-events:none
}
.proc-step-card:hover{
  border-color:rgba(91,159,255,.3);
  box-shadow:0 30px 80px rgba(91,159,255,.15),inset 0 1px 0 rgba(255,255,255,.1)
}

/* ── Market cards ───────────────────────────────────── */
.market-card{
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  background:rgba(8,12,24,.7);border:1px solid rgba(255,255,255,.07)
}
.market-card:hover{
  border-color:rgba(91,159,255,.3);
  box-shadow:0 40px 80px rgba(91,159,255,.12),inset 0 1px 0 rgba(255,255,255,.06)
}

/* ── Case accordion glass ───────────────────────────── */
.case-item{
  background:rgba(8,12,24,.7);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.05);
  transition:border-color .3s
}
.case-item.open{
  background:rgba(12,18,32,.85);
  border-color:rgba(91,159,255,.2)
}

/* ── CTA section enhanced ───────────────────────────── */
.cta-section{
  background:transparent;
  position:relative
}
.cta-bg{
  background:
    radial-gradient(ellipse 80% 90% at 50% 50%,rgba(91,159,255,.14) 0%,rgba(124,126,255,.09) 40%,transparent 70%),
    radial-gradient(ellipse 40% 40% at 20% 80%,rgba(236,72,153,.06) 0%,transparent 50%)
}

/* ── Founder card glass ─────────────────────────────── */
.founder-photo-wrapper{
  box-shadow:0 0 0 1px rgba(91,159,255,.2),0 0 0 4px rgba(91,159,255,.06),0 20px 60px rgba(0,0,0,.5)
}

/* ── Trust badges glass ─────────────────────────────── */
.trust-badge{
  background:rgba(8,12,24,.8);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(91,159,255,.12)
}

/* ── Footer glass ───────────────────────────────────── */
.site-footer{
  background:rgba(0,0,0,.9);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-top:1px solid rgba(91,159,255,.08)
}

/* ── Hero enhanced ──────────────────────────────────── */
.hero-badge{
  background:rgba(91,159,255,.1);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(91,159,255,.25);
  box-shadow:0 0 30px rgba(91,159,255,.12),inset 0 1px 0 rgba(255,255,255,.08)
}
.hero-title{text-shadow:0 0 80px rgba(91,159,255,.08)}

/* ── Scroll hint enhanced ───────────────────────────── */
.hero-scroll-hint span{
  background:linear-gradient(to bottom,rgba(91,159,255,.9),rgba(124,126,255,.3),transparent);
  box-shadow:0 0 8px rgba(91,159,255,.4)
}

/* ── Number stats glow ──────────────────────────────── */
.stat-n,.ci-n,.rm-n,.kpi-n,.tb-n,.sdg-n{
  text-shadow:0 0 20px rgba(91,159,255,.4)
}

/* ── Section eyebrow pulse ──────────────────────────── */
.eyebrow{
  color:#5B9FFF;
  text-shadow:0 0 20px rgba(91,159,255,.3)
}

/* ── Svc detail panel glass ─────────────────────────── */
.svc-detail-panel{
  background:rgba(0,0,0,.95);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)
}

/* ── Magnetic cursor glow ───────────────────────────── */
#cursor-glow{
  width:420px;height:420px;
  background:radial-gradient(circle,rgba(91,159,255,.12) 0%,rgba(124,126,255,.05) 35%,transparent 65%);
  transition:none
}

/* ══════════════ HERO VIDEO ══════════════════════════ */
#heroVideo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.38;z-index:0}
.hero-overlay{z-index:1}
#heroCanvas{z-index:2;mix-blend-mode:screen}
.hero-content{z-index:3}
.hero-scroll-hint{z-index:3}
.badge-logo{flex-shrink:0}

/* ══════════════ SERVICE PHOTO ═══════════════════════ */
.service-img--photo{height:220px;overflow:hidden;background:var(--dark-3)}
.service-img--photo img{width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .5s ease;filter:brightness(.85) saturate(.9)}
.service-card:hover .service-img--photo img{transform:scale(1.05);filter:brightness(.95) saturate(1)}

/* ══════════════ PROCESS INFOGRAPHIC ═════════════════ */
.process-infographic{display:flex;align-items:stretch;justify-content:center;gap:0;margin-bottom:52px;flex-wrap:nowrap}
.proc-step-card{flex:1;max-width:240px;background:var(--dark-3);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-lg);padding:28px 22px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;transition:border-color .3s,transform .3s,background .3s;position:relative}
.proc-step-card:hover{border-color:rgba(79,142,247,.3);transform:translateY(-4px);background:rgba(15,24,50,.9)}
.proc-step-card--highlight{background:linear-gradient(155deg,rgba(79,142,247,.1),rgba(99,102,241,.07));border-color:rgba(79,142,247,.25)}
.proc-icon-wrap{width:64px;height:64px;background:rgba(79,142,247,.08);border:1px solid rgba(79,142,247,.18);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:4px}
.proc-step-num{font-size:2.4rem;font-weight:200;color:rgba(79,142,247,.25);letter-spacing:-.03em;line-height:1}
.proc-step-card h3{font-size:.93rem;font-weight:500;color:var(--ice);line-height:1.3}
.proc-step-card p{font-size:.78rem;color:var(--blue);font-style:italic;line-height:1.4}
.proc-tags{display:flex;flex-wrap:wrap;gap:5px;justify-content:center;margin-top:4px}
.proc-tags span{font-size:.65rem;color:var(--muted);border:1px solid rgba(255,255,255,.07);border-radius:100px;padding:2px 8px}
.proc-connector{display:flex;align-items:center;justify-content:center;padding:0 4px;flex-shrink:0;opacity:.7}

/* ══════════════ MARKETS WITH PHOTO ═════════════════ */
.market-photo-wrap{height:220px;position:relative;overflow:hidden}
.market-photo{width:100%;height:100%;object-fit:cover;object-position:center;filter:brightness(.7) saturate(.85);transition:transform .5s ease,filter .3s}
.market-card:hover .market-photo{transform:scale(1.04);filter:brightness(.8) saturate(1)}
.market-photo-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(10,15,30,.1) 0%,rgba(10,15,30,.65) 100%)}
.market-photo-dots{position:absolute;inset:0}
.market-photo-dots .mdot{position:absolute;font-size:1.2rem;filter:drop-shadow(0 2px 6px rgba(0,0,0,.6));transition:transform .2s}
.market-photo-dots .mdot:hover{transform:scale(1.3)}

/* ══════════════ CASES IMPACT STRIP ═════════════════ */
.cases-impact{display:flex;justify-content:center;align-items:center;gap:0;flex-wrap:wrap;margin-bottom:48px;background:var(--dark-3);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-lg);overflow:hidden}
.ci-stat{flex:1;min-width:140px;display:flex;flex-direction:column;align-items:center;gap:6px;padding:32px 20px;border-right:1px solid rgba(255,255,255,.05);position:relative}
.ci-stat:last-child{border-right:none}
.ci-ring{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);opacity:.35}
.ci-n{font-size:1.8rem;font-weight:200;color:var(--blue);letter-spacing:-.025em;line-height:1;position:relative;z-index:1}
.ci-l{font-size:.68rem;color:var(--muted);text-align:center;line-height:1.4;max-width:110px;position:relative;z-index:1}

/* ══════════════ FOUNDER PHOTO UPGRADE ══════════════ */
.founder-photo-wrapper{position:relative}
.founder-photo{filter:contrast(1.05) brightness(.97)}
.founder-photo-badge{position:absolute;bottom:14px;left:14px;background:rgba(10,15,30,.85);backdrop-filter:blur(8px);border:1px solid rgba(79,142,247,.3);color:var(--blue);font-size:.68rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:5px 12px;border-radius:100px}
.founder-card{border:none;background:transparent;overflow:visible}
.founder-photo-wrapper{border-radius:var(--radius-lg);overflow:hidden;border:1px solid rgba(79,142,247,.2);box-shadow:0 0 0 4px rgba(79,142,247,.05),0 0 0 8px rgba(99,102,241,.03);margin-bottom:20px}
.founder-details{padding:0}
.founder-name-block{margin-bottom:12px}
.founder-bio{font-size:.88rem;color:var(--ice);line-height:1.75;margin-bottom:16px;font-weight:300}

/* ══════════════ RESPONSIVE ADDITIONS ═══════════════ */
@media(max-width:960px){
  .process-infographic{flex-wrap:wrap;gap:12px}
  .proc-step-card{max-width:calc(50% - 8px)}
  .proc-connector{display:none}
  .cases-impact{flex-wrap:wrap}
  .ci-stat{min-width:100px;border-right:none;border-bottom:1px solid rgba(255,255,255,.05)}
  .ci-stat:last-child{border-bottom:none}
}
@media(max-width:600px){
  .proc-step-card{max-width:100%}
  .cases-impact{flex-direction:column}
}

/* ══════════════ SPACEX-STYLE DYNAMICS ══════════════════ */

/* Scroll-snapping sections */
/* scroll-snap removed — single snap point fights iOS smooth scroll */
#hero{}

/* Section cinematic fade-in from bottom — override base */
[data-scroll]{opacity:.15;transform:translateY(40px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
[data-scroll="fade-right"]{opacity:.15;transform:translateX(-40px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
[data-scroll="fade-left"]{opacity:.15;transform:translateX(40px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
[data-scroll="fade-up"]{opacity:.15;transform:translateY(50px);transition:opacity .75s cubic-bezier(.16,1,.3,1),transform .75s cubic-bezier(.16,1,.3,1)}
[data-scroll].in-view{opacity:1;transform:translate(0)}

/* Staggered children */
[data-stagger]>*{opacity:.15;transform:translateY(24px);transition:opacity .6s cubic-bezier(.16,1,.3,1),transform .6s cubic-bezier(.16,1,.3,1)}
[data-stagger].in-view>*:nth-child(1){opacity:1;transform:none;transition-delay:.04s}
[data-stagger].in-view>*:nth-child(2){opacity:1;transform:none;transition-delay:.1s}
[data-stagger].in-view>*:nth-child(3){opacity:1;transform:none;transition-delay:.16s}
[data-stagger].in-view>*:nth-child(4){opacity:1;transform:none;transition-delay:.22s}
[data-stagger].in-view>*:nth-child(5){opacity:1;transform:none;transition-delay:.28s}
[data-stagger].in-view>*:nth-child(6){opacity:1;transform:none;transition-delay:.34s}

/* Parallax hero text */
.hero-content{will-change:transform}

/* Hero text cinematic entrance */
.hero-badge{animation:none}
.hero-title .gradient-text{background-size:200% 200%;animation:gradientShift 6s ease infinite}
@keyframes gradientShift{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}

/* Section dividers — SpaceX dark lines */
.services-section,
.portfolio-section,
.process-section,
.markets-section,
.cases-section,
.about-section,
.cta-section{position:relative}

/* Cinematic fullwidth section image backgrounds */
.services-section::before,
.process-section::before,
.cases-section::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 0%,rgba(10,15,30,.96) 100%);pointer-events:none;z-index:0}
.services-section .section-inner,
.process-section .section-inner,
.cases-section .section-inner{position:relative;z-index:1}

/* Nav transparent-to-solid SpaceX style */
#nav{transition:background .5s,backdrop-filter .5s,box-shadow .5s}
#nav.scrolled{box-shadow:0 1px 0 rgba(255,255,255,.05)}

/* Magnetic hover on cards */
.service-card{transition:background .3s,border-color .3s,transform .4s cubic-bezier(.34,1.56,.64,1),box-shadow .4s}
.service-card:hover{transform:translateY(-8px) scale(1.01);box-shadow:0 30px 80px rgba(0,0,0,.5)}

.port-card{transition:transform .5s cubic-bezier(.34,1.56,.64,1),border-color .3s,box-shadow .4s}
.port-card:hover{transform:translateY(-10px) scale(1.02);box-shadow:0 40px 80px rgba(0,0,0,.5)}

/* Proc cards spring */
.proc-step-card{transition:border-color .4s,transform .5s cubic-bezier(.34,1.56,.64,1),background .3s,box-shadow .4s}
.proc-step-card:hover{transform:translateY(-10px) scale(1.03);box-shadow:0 30px 80px rgba(79,142,247,.15)}

/* Market card parallax hover */
.market-card{transition:border-color .4s,transform .5s cubic-bezier(.34,1.56,.64,1),box-shadow .4s}
.market-card:hover{transform:translateY(-6px);box-shadow:0 40px 80px rgba(0,0,0,.4)}

/* Cursor glow trail */
#cursor-glow{position:fixed;pointer-events:none;z-index:9999;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(79,142,247,.07) 0%,transparent 70%);transform:translate(-50%,-50%);transition:transform 0.08s linear;mix-blend-mode:screen}

/* SpaceX-style section text reveal — line by line */
.reveal-line{overflow:hidden;display:block}
.reveal-line span{display:block;transform:translateY(110%);transition:transform .9s cubic-bezier(.16,1,.3,1)}
.reveal-line.in-view span{transform:translateY(0)}

/* Glowing CTA button */
.btn-primary{position:relative;overflow:hidden}
.btn-primary::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.15),transparent);opacity:0;transition:opacity .3s}
.btn-primary:hover::after{opacity:1}
.btn-primary:hover{box-shadow:0 0 40px rgba(79,142,247,.6),0 8px 32px rgba(79,142,247,.4)}

/* Number counter animation */
@keyframes countUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.stat-n,.rm-n,.ci-n,.kpi-n,.tb-n{animation:none}
.in-view .stat-n{animation:countUp .8s cubic-bezier(.16,1,.3,1) both}

/* Hero video overlay more cinematic */
#heroVideo{opacity:.45;transition:opacity 1s ease}

/* Smooth scroll indicator pulse */
.hero-scroll-hint span{background:linear-gradient(to bottom,rgba(79,142,247,.8),transparent)}

/* Logo strip marquee */
.logos-track{animation:marquee 22s linear infinite;flex-wrap:nowrap;overflow:visible}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.logos-strip{overflow:hidden}
.logos-inner{overflow:hidden}

/* SpaceX-like section caption */
.section-header .eyebrow{position:relative;display:inline-block}
.section-header .eyebrow::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--blue);transition:width .6s cubic-bezier(.16,1,.3,1)}
.section-header.in-view .eyebrow::after{width:100%}

/* ══════════════ VIBRANCY BOOST ════════════════════════ */
/* Brighter accent colors */
:root{
  --blue:   #5B9FFF;
  --violet: #7C7EFF;
  --green:  #34D86A;
}

/* Richer gradient text */
.gradient-text{
  background:linear-gradient(135deg,#5B9FFF 0%,#A78BFA 50%,#C084FC 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  background-size:200% 200%;
  filter:drop-shadow(0 0 20px rgba(91,159,255,.25));
}

/* Brighter hero badge */
.hero-badge{background:rgba(91,159,255,.15);border-color:rgba(91,159,255,.35);box-shadow:0 0 24px rgba(91,159,255,.1)}

/* Brighter service card featured */
.service-card.featured{background:linear-gradient(155deg,rgba(91,159,255,.14),rgba(124,126,255,.1));border-color:rgba(91,159,255,.35)}

/* More vivid card hover glow */
.service-card:hover{box-shadow:0 30px 80px rgba(91,159,255,.2),0 0 0 1px rgba(91,159,255,.2)}
.port-card:hover{box-shadow:0 40px 80px rgba(91,159,255,.18)}
.proc-step-card:hover{box-shadow:0 30px 80px rgba(91,159,255,.22)}

/* Brighter eyebrow */
.eyebrow{color:#5B9FFF}

/* Brighter KPI / stat numbers */
.kpi-n,.ci-n,.rm-n,.stat-n{color:#5B9FFF}

/* Brighter button glow */
.btn-primary:hover{box-shadow:0 0 50px rgba(91,159,255,.7),0 8px 32px rgba(91,159,255,.5)}

/* More vivid CTA section */
.cta-bg{background:radial-gradient(ellipse 80% 90% at 50% 50%,rgba(91,159,255,.14) 0%,rgba(124,126,255,.09) 50%,transparent 100%)}

/* Brighter svc-link */
.svc-link{font-size:.85rem;color:#5B9FFF;font-weight:600;letter-spacing:.01em;transition:letter-spacing .2s,color .2s}
.svc-link:hover{color:#A78BFA;letter-spacing:.05em}

/* Brighter market flag */
.market-flag-big{font-size:2rem;font-weight:700;color:#5B9FFF;letter-spacing:.05em;margin-bottom:8px}

/* Brighter hero video opacity */
#heroVideo{opacity:.52}

/* Brighter cursor glow */
#cursor-glow{width:380px;height:380px;background:radial-gradient(circle,rgba(91,159,255,.1) 0%,rgba(124,126,255,.04) 40%,transparent 70%)}

/* Nav CTA brighter */
.nav-cta{color:#5B9FFF!important}

/* Brighter section borders */
.market-card:hover{border-color:rgba(91,159,255,.35);box-shadow:0 40px 80px rgba(91,159,255,.15)}

/* ══════════════ SERVICE DETAIL PANELS (overlay) ════════ */
.svc-detail-panel{position:fixed;inset:0;z-index:400;background:var(--dark);overflow-y:auto;transform:translateX(100%);transition:transform .65s cubic-bezier(.16,1,.3,1);will-change:transform}
.svc-detail-panel.open{transform:none}

.sdp-inner{max-width:var(--w);margin:0 auto;padding:80px var(--px) 100px}

.svc-detail-back{display:inline-flex;align-items:center;gap:6px;font-size:.78rem;color:var(--muted-2);margin-bottom:40px;transition:color .2s;border:1px solid rgba(255,255,255,.07);padding:6px 14px;border-radius:100px;background:transparent;cursor:pointer}
.svc-detail-back:hover{color:var(--blue);border-color:rgba(91,159,255,.25)}

.svc-detail-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:72px;align-items:start}
.svc-detail-grid--reverse{grid-template-columns:1fr 1.2fr}

.svc-detail-main .eyebrow{margin-bottom:1.2rem}

.svc-detail-h2{font-size:clamp(1.8rem,3vw,2.8rem);font-weight:300;line-height:1.15;letter-spacing:-.025em;margin-bottom:1.2rem}

.svc-detail-lead{font-size:1.05rem;color:var(--muted-2);line-height:1.75;margin-bottom:2rem;max-width:520px;font-weight:300}

.svc-detail-block{margin-bottom:1.8rem}
.svc-detail-block h3{font-size:.85rem;font-weight:600;color:var(--blue);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.7rem}
.svc-detail-block p{font-size:.9rem;color:var(--muted-2);line-height:1.8}

.svc-detail-list{display:flex;flex-direction:column;gap:8px}
.svc-detail-list li{font-size:.88rem;color:var(--muted-2);line-height:1.65;padding-left:16px;position:relative}
.svc-detail-list li::before{content:'';position:absolute;left:0;top:9px;width:5px;height:1px;background:var(--blue);box-shadow:0 0 6px rgba(91,159,255,.6)}

.svc-detail-gains{display:flex;gap:0;margin-bottom:2.2rem;border:1px solid rgba(91,159,255,.15);border-radius:var(--radius-lg);overflow:hidden}
.sdg-stat{flex:1;padding:20px 16px;text-align:center;border-right:1px solid rgba(91,159,255,.1);background:rgba(91,159,255,.03)}
.sdg-stat:last-child{border-right:none}
.sdg-n{display:block;font-size:1.8rem;font-weight:200;color:var(--blue);letter-spacing:-.025em;line-height:1;margin-bottom:4px;text-shadow:0 0 20px rgba(91,159,255,.4)}
.sdg-l{font-size:.68rem;color:var(--muted);line-height:1.35}

.svc-detail-aside{display:flex;flex-direction:column;gap:20px;position:sticky;top:100px}

.svc-detail-quote{background:linear-gradient(135deg,rgba(91,159,255,.1),rgba(124,126,255,.06));border:1px solid rgba(91,159,255,.2);border-radius:var(--radius-lg);padding:28px;position:relative}
.svc-detail-quote::before{content:'\201C';position:absolute;top:-10px;left:20px;font-size:4rem;line-height:1;color:rgba(91,159,255,.3);font-family:serif}
.svc-detail-quote p{font-size:.92rem;color:var(--ice);line-height:1.7;font-style:italic;margin-bottom:12px}
.svc-detail-quote cite{font-size:.72rem;color:var(--muted);font-style:normal;letter-spacing:.05em}

.svc-detail-chips{display:flex;flex-wrap:wrap;gap:8px}
.svc-detail-chips span{font-size:.74rem;color:var(--blue);background:rgba(91,159,255,.08);border:1px solid rgba(91,159,255,.2);border-radius:100px;padding:5px 12px;transition:background .2s,border-color .2s}
.svc-detail-chips span:hover{background:rgba(91,159,255,.15);border-color:rgba(91,159,255,.4)}

.svc-detail-cta-note{font-size:.75rem;color:var(--muted);text-align:center;padding-top:4px}

@media(max-width:960px){
  .svc-detail-grid,.svc-detail-grid--reverse{grid-template-columns:1fr;gap:48px}
  .svc-detail-grid--reverse .svc-detail-aside{order:-1}
  .svc-detail-aside{position:static}
}
@media(max-width:768px){
  .svc-detail-section .section-inner{padding-top:60px;padding-bottom:60px}
  .svc-detail-h2{font-size:1.8rem}
  .svc-detail-gains{flex-direction:column}
  .sdg-stat{border-right:none;border-bottom:1px solid rgba(91,159,255,.1)}
  .sdg-stat:last-child{border-bottom:none}
}

/* ── Service Icons (SVG replacing photos) ───────────── */
.service-icon{width:100%;height:160px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg) var(--radius-lg) 0 0;background:var(--dark-2);overflow:hidden;border-bottom:1px solid rgba(91,159,255,.08)}
.service-icon svg{width:100%;height:100%;max-height:160px}
.service-icon--sm{height:130px}
.service-icon--sm svg{max-height:130px}

/* ── Services secondary group label ────────────────── */
.svc-secondary-header{text-align:center;margin:64px 0 32px;position:relative}
.svc-secondary-header::before{content:'';position:absolute;top:50%;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(91,159,255,.15),transparent)}
.svc-secondary-header span{position:relative;display:inline-block;font-size:.72rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);background:var(--dark);padding:0 20px}

/* Secondary cards slightly smaller */
.services-grid--secondary .service-card{opacity:.9}
.services-grid--secondary .service-card .service-body h3{font-size:1.05rem}
.services-grid--core{margin-bottom:0}

/* ── Pricing Section ────────────────────────────────── */
.pricing-section{background:var(--dark-2);border-top:1px solid rgba(91,159,255,.07);border-bottom:1px solid rgba(91,159,255,.07)}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:stretch}
@media(max-width:900px){.pricing-grid{grid-template-columns:1fr;max-width:460px;margin:0 auto}}

.pricing-card{background:var(--dark-3);border:1px solid rgba(91,159,255,.1);border-radius:var(--radius-lg);padding:36px 32px;display:flex;flex-direction:column;gap:24px;position:relative;transition:border-color .3s,transform .25s}
.pricing-card:hover{border-color:rgba(91,159,255,.25);transform:translateY(-4px)}
.pricing-card--featured{border-color:rgba(91,159,255,.35);background:linear-gradient(160deg,rgba(91,159,255,.06) 0%,var(--dark-3) 60%);box-shadow:0 0 40px rgba(91,159,255,.12)}
.pricing-card--featured:hover{border-color:rgba(91,159,255,.55);box-shadow:0 0 60px rgba(91,159,255,.2)}

.pc-badge{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--blue),var(--violet));color:#fff;font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:5px 18px;border-radius:100px;white-space:nowrap}

.pc-top{display:flex;flex-direction:column;gap:8px}
.pc-name{font-size:1.35rem;font-weight:600;color:var(--ice)}
.pc-desc{font-size:.85rem;color:var(--muted-2);line-height:1.5}

.pc-features{display:flex;flex-direction:column;gap:10px;flex:1}
.pc-features li{font-size:.85rem;color:var(--muted-2);padding-left:20px;position:relative;line-height:1.45}
.pc-features li::before{content:'✓';position:absolute;left:0;color:var(--blue);font-weight:700;font-size:.8rem}

.pc-dual-price{display:flex;gap:0;padding:16px 0;border-top:1px solid rgba(91,159,255,.1);align-items:stretch}
.pc-dual-price--custom .pc-impl--custom{font-size:1.1rem}
.pc-region{display:flex;flex-direction:column;gap:3px;flex:1;padding:0 12px}
.pc-region:first-child{padding-left:0}
.pc-region:last-child{padding-right:0}
.pc-region-label{font-size:.65rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-bottom:2px}
.pc-region-sep{width:1px;background:rgba(91,159,255,.12);flex-shrink:0;margin:2px 0}
.pc-impl{font-size:1.25rem;font-weight:700;color:var(--ice);letter-spacing:-.02em;line-height:1.2}
.pc-impl--custom{font-size:1rem;background:linear-gradient(135deg,var(--blue),var(--violet));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.pc-retainer{font-size:.78rem;color:var(--muted);font-weight:400}

.pc-cta{text-align:center;width:100%}
.pricing-note{text-align:center;margin-top:32px;font-size:.78rem;color:var(--muted);letter-spacing:.03em}

/* ── WhatsApp Floating Button ───────────────────────── */
.whatsapp-fab{position:fixed;bottom:28px;right:28px;z-index:300;width:58px;height:58px;border-radius:50%;background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,.4);transition:transform .25s,box-shadow .25s}
.whatsapp-fab:hover{transform:scale(1.1) translateY(-2px);box-shadow:0 8px 32px rgba(37,211,102,.55)}
.whatsapp-fab svg{width:28px;height:28px;flex-shrink:0}

/* ── Footer WhatsApp link ───────────────────────────── */
.footer-wa{display:flex;align-items:center;gap:6px;color:var(--muted-2);font-size:.83rem;transition:color .2s}
.footer-wa:hover{color:#25D366}
.footer-wa svg{flex-shrink:0;opacity:.8}

/* ── Footer legal links ─────────────────────────── */
.footer-legal-links{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.footer-legal-links a{font-size:.75rem;color:var(--muted);transition:color .2s}
.footer-legal-links a:hover{color:var(--muted-2)}
@media(max-width:720px){.footer-bottom{flex-wrap:wrap;gap:16px}.footer-legal-links{order:2;width:100%;justify-content:center}}

/* ── Pricing single-price block ─────────────────────── */
.pc-price{display:flex;flex-direction:column;gap:4px;padding:16px 0;border-top:1px solid rgba(91,159,255,.1)}
.pc-price .pc-impl{font-size:1.6rem;font-weight:700;color:var(--ice);letter-spacing:-.03em;line-height:1.1}
.pc-price .pc-impl--custom{font-size:1.15rem;background:linear-gradient(135deg,var(--blue),var(--violet));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.pc-price .pc-retainer{font-size:.82rem;color:var(--muted);font-weight:400}

/* ── Service card hover state ────────────────────────── */
.service-card{transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}
.service-card:hover{transform:translateY(-4px);border-color:rgba(91,159,255,.3);box-shadow:0 0 24px rgba(91,159,255,.12)}

/* ── SVG animation keyframes ─────────────────────────── */

/* Chatbots: typing dots bounce */
@keyframes tdBounce{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-5px)}}
.td{animation:tdBounce 1.2s ease-in-out infinite;animation-play-state:paused}
.td2{animation-delay:.18s}
.td3{animation-delay:.36s}
.services-grid.in-view .td,.services-grid--secondary.in-view .td{animation-play-state:running}

/* Flujos: dashed lines flow (marching ants) */
@keyframes flowDash{to{stroke-dashoffset:-22}}
.flow-line{animation:flowDash 1.4s linear infinite;animation-play-state:paused}
.services-grid.in-view .flow-line{animation-play-state:running}

/* Agentes: pulsing glow ring */
@keyframes apRing{0%{transform:scale(1);opacity:.55}100%{transform:scale(2.4);opacity:0}}
.ap-ring{transform-origin:120px 80px;transform-box:user-space-on-use;animation:apRing 2.2s ease-out infinite;animation-play-state:paused}
.services-grid.in-view .ap-ring{animation-play-state:running}

/* Webs: content lines scroll up */
@keyframes wlScroll{0%,10%{transform:translateY(0);opacity:1}75%,85%{transform:translateY(-18px);opacity:.2}86%{transform:translateY(10px);opacity:0}100%{transform:translateY(0);opacity:1}}
.wl-content{animation:wlScroll 3.2s ease-in-out infinite;animation-play-state:paused}
.services-grid--secondary.in-view .wl-content{animation-play-state:running}

/* Consultoría: compass needle sweep */
@keyframes cnSpin{0%{transform:rotate(0deg)}25%{transform:rotate(42deg)}65%{transform:rotate(-28deg)}100%{transform:rotate(15deg)}}
.cn-needle{transform-origin:100px 65px;transform-box:user-space-on-use;animation:cnSpin 4s ease-in-out infinite alternate;animation-play-state:paused}
.services-grid--secondary.in-view .cn-needle{animation-play-state:running}

/* Soporte: shield check heartbeat */
@keyframes spPulse{0%,100%{filter:drop-shadow(0 0 2px rgba(91,159,255,.2));stroke-width:2.5}45%{filter:drop-shadow(0 0 10px rgba(91,159,255,.9));stroke-width:3.8}55%{filter:drop-shadow(0 0 4px rgba(91,159,255,.4));stroke-width:2.5}70%{filter:drop-shadow(0 0 10px rgba(91,159,255,.8));stroke-width:3.8}}
.sp-check{animation:spPulse 2s ease-in-out infinite;animation-play-state:paused}
.services-grid--secondary.in-view .sp-check{animation-play-state:running}

/* ── Markets Cinematic — Liquid Glass + Video ────── */
.markets-cinematic{
  position:relative;overflow:hidden;
  min-height:80vh;display:flex;align-items:center;
  padding:var(--py) 0;
  background:var(--dark);
}
.mkt-video-bg{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;z-index:0;
  filter:saturate(1.15) brightness(.6);
}
.mkt-video-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(
    180deg,
    rgba(10,15,30,.72) 0%,
    rgba(10,15,30,.38) 35%,
    rgba(10,15,30,.38) 65%,
    rgba(10,15,30,.78) 100%
  );
}
.mkt-content{position:relative;z-index:2;width:100%}
.mkt-content .section-header h2{color:#fff}
.mkt-content .section-sub{color:rgba(255,255,255,.6)}
.mkt-content .eyebrow{color:rgba(255,255,255,.5)}

.mkt-glass-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:28px;margin-top:56px;
}

.mkt-glass-card{
  position:relative;overflow:hidden;
  padding:42px 38px;border-radius:28px;
  background:rgba(10,15,30,.22);
  backdrop-filter:blur(44px) saturate(1.4);
  -webkit-backdrop-filter:blur(44px) saturate(1.4);
  box-shadow:inset 0 1px 1px rgba(255,255,255,.1),0 24px 64px rgba(0,0,0,.4);
  transition:transform .3s ease,box-shadow .3s ease;
}
.mkt-glass-card::before{
  content:'';position:absolute;inset:0;
  border-radius:inherit;padding:1px;
  background:linear-gradient(
    160deg,
    rgba(255,255,255,.38) 0%,
    rgba(255,255,255,.12) 25%,
    transparent 50%,
    rgba(91,159,255,.18) 78%,
    rgba(124,126,255,.38) 100%
  );
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  pointer-events:none;
}
.mkt-glass-card:hover{
  transform:translateY(-7px);
  box-shadow:inset 0 1px 1px rgba(255,255,255,.16),0 40px 90px rgba(0,0,0,.55),0 0 70px rgba(91,159,255,.1);
}

.mgc-glow{
  position:absolute;width:260px;height:260px;border-radius:50%;
  filter:blur(90px);opacity:.15;pointer-events:none;top:-60px;right:-60px;
}
.mgc-glow--blue{background:#4F8EF7}
.mgc-glow--violet{background:#6366F1}

.mgc-flag{
  display:inline-block;
  font-size:.65rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(255,255,255,.5);
  background:rgba(255,255,255,.08);
  border-radius:100px;padding:5px 16px;margin-bottom:22px;
}
.mkt-glass-card h3{
  font-size:2.1rem;font-weight:600;color:#fff;
  letter-spacing:-.03em;margin-bottom:22px;line-height:1.1;
}
.mgc-kpi{display:flex;align-items:baseline;gap:10px;margin-bottom:12px}
.mgc-kpi .kpi-n{
  font-size:3rem;font-weight:700;color:#fff;
  letter-spacing:-.05em;line-height:1;
}
.mgc-kpi .kpi-l{font-size:.85rem;color:rgba(255,255,255,.5)}
.mgc-langs{font-size:.78rem;color:rgba(255,255,255,.4);margin-bottom:26px}
.mgc-cities{
  list-style:none;display:flex;flex-wrap:wrap;gap:8px;
  padding-top:22px;border-top:1px solid rgba(255,255,255,.07);
}
.mgc-cities li{
  font-size:.75rem;color:rgba(255,255,255,.55);
  background:rgba(255,255,255,.06);border-radius:100px;padding:4px 14px;
}

@media(max-width:768px){.mkt-glass-grid{grid-template-columns:1fr}}
@media(max-width:600px){.mkt-glass-card{padding:30px 24px}}
@media(max-width:600px){.mgc-kpi .kpi-n{font-size:2.2rem}}

/* ── Portfolio Cinematic — Video Background ──────── */
.portfolio-cinematic{position:relative;overflow:hidden}
.port-video-bg{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;z-index:0;opacity:0;
  filter:brightness(.45) saturate(1.3);
  transition:opacity .05s linear;
}
.port-video-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(
    180deg,
    rgba(10,15,30,.78) 0%,
    rgba(10,15,30,.42) 40%,
    rgba(10,15,30,.42) 60%,
    rgba(10,15,30,.82) 100%
  );
}
.portfolio-cinematic .section-inner{position:relative;z-index:2}
.portfolio-cinematic .section-header h2,
.portfolio-cinematic .section-header .eyebrow{color:#fff}
.portfolio-cinematic .section-sub{color:rgba(255,255,255,.6)}

/* ── CTA Cinematic — HLS Video + Liquid Glass ────── */
.cta-cinematic{position:relative;overflow:hidden;min-height:640px}
.cta-video-bg{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;z-index:0;opacity:0;
  filter:brightness(.55) saturate(1.25);
  transition:opacity .05s linear;
}
.cta-video-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(
    180deg,
    rgba(10,15,30,.82) 0%,
    rgba(10,15,30,.35) 35%,
    rgba(10,15,30,.35) 65%,
    rgba(10,15,30,.88) 100%
  );
}
.cta-cinematic .section-inner{position:relative;z-index:2;display:flex;align-items:center;justify-content:center}

.cta-glass-card{
  position:relative;overflow:hidden;
  border-radius:36px;padding:3px;
  max-width:780px;width:100%;margin:0 auto;
  background:linear-gradient(
    160deg,
    rgba(255,255,255,.32) 0%,
    rgba(255,255,255,.08) 25%,
    transparent 50%,
    rgba(91,159,255,.15) 78%,
    rgba(124,126,255,.32) 100%
  );
}
.cta-glass-inner{
  background:rgba(8,12,28,.38);
  backdrop-filter:blur(48px) saturate(1.5);
  -webkit-backdrop-filter:blur(48px) saturate(1.5);
  border-radius:34px;padding:64px 72px;
  text-align:center;
  box-shadow:inset 0 1px 1px rgba(255,255,255,.1),0 32px 80px rgba(0,0,0,.45);
}
.cta-eyebrow-glass{color:rgba(255,255,255,.5)!important}
.cta-title-glass{
  font-size:clamp(1.75rem,4vw,2.8rem);font-weight:600;color:#fff;
  letter-spacing:-.03em;line-height:1.15;margin:16px 0 20px;
}
.cta-sub-glass{color:rgba(255,255,255,.6);max-width:520px;margin:0 auto 32px}
.cta-btn-glass{
  background:linear-gradient(135deg,var(--blue),var(--violet))!important;
  border:none!important;
  box-shadow:0 8px 32px rgba(91,159,255,.35)!important;
  font-size:1rem;
}
.cta-btn-glass:hover{transform:translateY(-2px) scale(1.02)!important;box-shadow:0 14px 40px rgba(91,159,255,.5)!important}
.cta-email-glass{color:rgba(255,255,255,.45)!important}
.cta-email-glass a{color:rgba(255,255,255,.7)!important}
.cta-guarantees-glass{color:rgba(255,255,255,.55)!important;border-top:1px solid rgba(255,255,255,.08)!important;padding-top:24px!important}
@media(max-width:720px){.cta-glass-inner{padding:44px 28px}}
@media(max-width:480px){.cta-glass-inner{padding:36px 20px}}

/* ════════════════════════════════════════════
   COOKIE CONSENT BANNER + MODAL
════════════════════════════════════════════ */
.cookie-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:9998;
  padding:20px var(--px) 24px;
  background:rgba(10,15,30,.92);
  backdrop-filter:blur(24px) saturate(160%);
  -webkit-backdrop-filter:blur(24px) saturate(160%);
  border-top:1px solid rgba(91,159,255,.15);
  box-shadow:0 -8px 40px rgba(0,0,0,.45);
  transform:translateY(100%);
  transition:transform .35s cubic-bezier(.4,0,.2,1);
}
.cookie-banner.is-visible{transform:translateY(0)}
.cookie-banner-inner{
  max-width:var(--w);margin:0 auto;
  display:flex;align-items:center;gap:24px;flex-wrap:wrap;
}
.cookie-banner-text{flex:1;min-width:260px}
.cookie-banner-text strong{
  display:block;color:var(--ice);font-size:.95rem;font-weight:600;margin-bottom:6px;
}
.cookie-banner-text p{
  color:var(--muted-2);font-size:.82rem;line-height:1.6;margin:0;
}
.cookie-banner-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center;flex-shrink:0}

/* Cookie buttons */
.ck-btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 20px;border-radius:8px;font-size:.82rem;font-weight:600;
  cursor:pointer;transition:all .2s;font-family:var(--font);white-space:nowrap;
}
.ck-btn--primary{
  background:linear-gradient(135deg,var(--blue),var(--violet));
  border:none;color:#fff;
  box-shadow:0 4px 16px rgba(91,159,255,.3);
}
.ck-btn--primary:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(91,159,255,.45)}
.ck-btn--ghost{
  background:transparent;
  border:1px solid rgba(255,255,255,.18);
  color:var(--muted-2);
}
.ck-btn--ghost:hover{border-color:rgba(255,255,255,.35);color:var(--ice)}
.ck-btn--link{
  background:transparent;border:none;
  color:rgba(91,159,255,.8);text-decoration:underline;
  padding:10px 8px;
}
.ck-btn--link:hover{color:var(--blue)}

/* Footer cookie button */
.footer-cookie-btn{
  background:transparent;border:none;padding:0;
  color:var(--muted);font-size:.8rem;font-family:var(--font);
  cursor:pointer;transition:color .2s;
  text-decoration:underline;text-underline-offset:3px;
}
.footer-cookie-btn:hover{color:var(--ice)}

/* ── Modal ── */
.cookie-modal{
  position:fixed;inset:0;z-index:9999;
  display:flex;align-items:center;justify-content:center;padding:20px;
  opacity:0;transition:opacity .3s;pointer-events:none;
}
.cookie-modal.is-visible{opacity:1;pointer-events:auto}

.cookie-modal-overlay{
  position:absolute;inset:0;
  background:rgba(5,8,18,.75);
  backdrop-filter:blur(6px);
}
.cookie-modal-card{
  position:relative;z-index:1;width:100%;max-width:520px;
  background:rgba(14,20,40,.97);
  border:1px solid rgba(91,159,255,.2);
  border-radius:20px;
  box-shadow:0 40px 120px rgba(0,0,0,.65),0 0 0 1px rgba(255,255,255,.04);
  overflow:hidden;
  transform:translateY(20px) scale(.97);
  transition:transform .3s cubic-bezier(.4,0,.2,1);
}
.cookie-modal.is-visible .cookie-modal-card{transform:translateY(0) scale(1)}

.cookie-modal-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:24px 28px 20px;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.cookie-modal-header h2{
  font-size:1.1rem;font-weight:600;color:var(--ice);margin:0;
}
.cookie-modal-close{
  background:transparent;border:none;color:var(--muted);
  font-size:1.1rem;cursor:pointer;padding:4px 8px;border-radius:6px;
  transition:all .2s;font-family:var(--font);
}
.cookie-modal-close:hover{background:rgba(255,255,255,.07);color:var(--ice)}

.cookie-modal-body{padding:8px 28px}
.cookie-category{padding:20px 0;border-bottom:1px solid rgba(255,255,255,.05)}
.cookie-category:last-child{border-bottom:none}
.cookie-cat-row{display:flex;align-items:flex-start;justify-content:space-between;gap:20px}
.cookie-cat-info{flex:1}
.cookie-cat-info strong{display:block;color:var(--ice);font-size:.9rem;margin-bottom:6px}
.cookie-cat-info p{color:var(--muted-2);font-size:.8rem;line-height:1.55;margin:0}
.cookie-always{
  flex-shrink:0;font-size:.72rem;font-weight:600;color:var(--blue);
  background:rgba(91,159,255,.12);border:1px solid rgba(91,159,255,.2);
  border-radius:6px;padding:4px 10px;white-space:nowrap;margin-top:2px;
}

/* Toggle switch */
.ck-toggle{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0;margin-top:2px}
.ck-toggle-input{opacity:0;width:0;height:0;position:absolute}
.ck-toggle-slider{
  position:absolute;inset:0;border-radius:24px;cursor:pointer;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);
  transition:all .25s;
}
.ck-toggle-slider::before{
  content:'';position:absolute;
  width:18px;height:18px;border-radius:50%;
  left:2px;top:50%;transform:translateY(-50%);
  background:rgba(255,255,255,.5);
  transition:all .25s;
}
.ck-toggle-input:checked + .ck-toggle-slider{
  background:linear-gradient(135deg,var(--blue),var(--violet));
  border-color:transparent;
}
.ck-toggle-input:checked + .ck-toggle-slider::before{
  left:calc(100% - 20px);background:#fff;
}

.cookie-modal-footer{
  padding:20px 28px 24px;
  border-top:1px solid rgba(255,255,255,.06);
  display:flex;justify-content:flex-end;
}
.cookie-modal-footer .ck-btn--primary{padding:12px 28px;font-size:.88rem}

@media(max-width:500px){
  .cookie-banner-inner{flex-direction:column;align-items:flex-start}
  .cookie-banner-actions{width:100%;justify-content:space-between}
  .cookie-modal-card{border-radius:16px}
  .cookie-modal-header,.cookie-modal-body,.cookie-modal-footer{padding-left:20px;padding-right:20px}
}

/* ── Market switch link (CTA section) ── */
.cta-market-switch{
  margin:12px 0 4px;font-size:.78rem;color:rgba(255,255,255,.4);
  display:flex;align-items:center;justify-content:center;gap:6px;flex-wrap:wrap;
}
#cta-market-toggle{
  color:rgba(91,159,255,.75);text-decoration:underline;
  text-underline-offset:2px;cursor:pointer;transition:color .2s;
}
#cta-market-toggle:hover{color:#4F8EF7}

/* ════════════════════════════════════════════
   PRICING — Web Premium full-width card
════════════════════════════════════════════ */
.pricing-web-card{
  margin-top:32px;
  display:flex;align-items:center;gap:48px;flex-wrap:wrap;
  background:linear-gradient(135deg,rgba(79,142,247,.07) 0%,rgba(99,102,241,.07) 100%);
  border:1px solid rgba(79,142,247,.22);
  border-radius:var(--radius-lg);
  padding:44px 48px;
  position:relative;overflow:hidden;
}
.pricing-web-card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(79,142,247,.04),transparent 60%);
  pointer-events:none;
}
.pwc-left{flex:1;min-width:260px}
.pwc-right{
  flex-shrink:0;width:260px;
  display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;
}

.pwc-badge{
  display:inline-block;
  font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--blue);background:rgba(79,142,247,.12);
  border:1px solid rgba(79,142,247,.25);border-radius:20px;
  padding:4px 14px;margin-bottom:14px;
}
.pwc-name{
  font-size:1.6rem;font-weight:700;color:var(--ice);
  letter-spacing:-.03em;margin-bottom:10px;
}
.pwc-desc{
  color:var(--muted-2);font-size:.9rem;line-height:1.65;
  max-width:480px;margin-bottom:20px;
}
.pwc-features{
  list-style:none;padding:0;margin:0;
  display:flex;flex-direction:column;gap:8px;
}
.pwc-features li{
  color:var(--muted-2);font-size:.85rem;padding-left:20px;position:relative;
}
.pwc-features li::before{
  content:'✓';position:absolute;left:0;color:var(--blue);font-weight:700;
}

/* Price block */
.pwc-price-block{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  background:rgba(10,15,30,.5);border:1px solid rgba(255,255,255,.07);
  border-radius:14px;padding:20px 28px;width:100%;
}
.pwc-label{
  font-size:.7rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted);margin-bottom:4px;
}
.pwc-anchor{
  font-size:1rem;color:var(--muted);
  text-decoration:line-through;text-decoration-color:rgba(255,80,80,.6);
  text-decoration-thickness:2px;
}
.pwc-desde{
  font-size:1.7rem;font-weight:700;
  background:linear-gradient(135deg,var(--blue),var(--violet));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;letter-spacing:-.02em;
}
.pwc-note{font-size:.72rem;color:var(--muted);margin-top:4px}

.pwc-cta{width:100%;text-align:center;justify-content:center}
.pwc-sub{font-size:.75rem;color:var(--muted);margin:0}

@media(max-width:768px){
  .pricing-web-card{flex-direction:column;padding:32px 24px;gap:32px}
  .pwc-right{width:100%}
}
