/* ===== RESET & BASE ===== */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{background:#111;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}
body{background:#111;color:#fff;font-family:'Inter',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;min-height:100vh;overflow-x:hidden}

/* GPU compositing hint for all animated elements */
[data-animate],
.case-hero,.case-card,.step,.reveal-item,
.service-row-item,.sector-item,.sectors-card-box{
  will-change:transform,opacity;
  backface-visibility:hidden;
  -webkit-backface-visibility:hidden
}

/* ===== SCROLL PROGRESS BAR ===== */
.scroll-progress{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,#34d399,#6ee7b7);z-index:10000;width:0%;transition:width 0.05s linear;pointer-events:none}

/* ===== WRAP (Container) ===== */
.wrap{width:100%;max-width:1600px;margin:0 auto}
@media(max-width:1599.98px){.wrap{max-width:1200px}}
@media(max-width:1199.98px){.wrap{max-width:1000px}}
@media(max-width:999.98px){.wrap{max-width:390px}}

/* ===== TOPBAR ===== */
.topbar{position:relative;z-index:100;opacity:0;transform:translate3d(0,-20px,0);transition:opacity .6s cubic-bezier(.16,1,.3,1),transform .6s cubic-bezier(.16,1,.3,1)}
.topbar.visible{opacity:1;transform:translate3d(0,0,0)}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;height:80px;padding:20px}
.topbar-social{display:flex;gap:10px}
.topbar-email-group{display:flex;gap:10px}
.social-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid #333;background:#111;color:#fff;text-decoration:none;transition:background .2s,border-color .3s,transform .2s}
.social-btn:hover{background:#1a1a1a;border-color:#34d399;transform:translateY(-2px)}
.social-btn svg{width:24px;height:24px;fill:#fff}
.topbar-cta{display:flex;align-items:center;padding:0 16px;height:40px;border:1px solid #34d399;background:#34d399;color:#111;font-family:'Inter',sans-serif;font-size:14px;font-weight:700;text-decoration:none;line-height:1;transition:background .2s,transform .2s,box-shadow .2s}
.topbar-cta:hover{background:#2ec48d;transform:translateY(-2px);box-shadow:0 4px 12px rgba(52,211,153,.3)}
.topbar-email{display:flex;align-items:center;padding:0 16px;height:40px;border:1px solid #333;background:#111;color:#fff;font-family:'Inter',sans-serif;font-size:14px;font-weight:600;text-decoration:none;line-height:1;transition:background .2s,border-color .3s,transform .2s}
.topbar-email:hover{background:#1a1a1a;border-color:#34d399;transform:translateY(-2px)}

/* ===== HEADER / HERO ===== */
.header{display:flex;flex-direction:column!important;justify-content:center;align-items:center;padding:0;min-height:25vw;opacity:0;transform:translate3d(0,30px,0);transition:opacity .7s cubic-bezier(.16,1,.3,1) .08s,transform .7s cubic-bezier(.16,1,.3,1) .08s}
.header.visible{opacity:1;transform:translate3d(0,0,0)}
.hero-container{position:relative;display:flex;align-items:center;justify-content:center;width:100%}
.hero-text{font-family:'Inter',sans-serif;font-weight:750;font-size:clamp(65px,27vw,580px);letter-spacing:-.04em;line-height:1;color:#fff;text-align:center;user-select:none;position:relative;z-index:1;white-space:nowrap;-webkit-font-variation-settings:"opsz" 32,"wght" 750;font-variation-settings:"opsz" 32,"wght" 750}
.green-strip{position:absolute;width:100%;height:2.6vw;min-height:20px;max-height:48px;background:#34d399;left:0;top:50%;transform:translateY(-50%) translateY(24px) rotate(-4deg);z-index:2;box-shadow:0 3px rgba(0,0,0,.15);overflow:hidden;pointer-events:none;opacity:0;transition:opacity .6s cubic-bezier(.16,1,.3,1) .35s,transform .6s cubic-bezier(.16,1,.3,1) .35s}
.green-strip.visible{opacity:1;transform:translateY(-50%) rotate(-3deg)}
.marquee-track{display:flex;white-space:nowrap;height:100%;align-items:center}
@keyframes marquee-scroll{from{transform:translate3d(0,0,0)}to{transform:translate3d(-50%,0,0)}}
.marquee-track span{font-family:'Inter Tight',sans-serif;font-weight:700;font-size:clamp(16px,2.4vw,26px);color:#111;padding:0 2vw;display:inline-block;line-height:1;flex-shrink:0}
.marquee-track span em{font-style:italic}

/* ===== INTRO ===== */
.intro{display:flex;flex-flow:column;align-items:center;padding:0 20px 80px;text-align:center;opacity:0;transform:translate3d(0,20px,0);transition:opacity .6s cubic-bezier(.16,1,.3,1) .18s,transform .6s cubic-bezier(.16,1,.3,1) .18s}
.intro.visible{opacity:1;transform:translate3d(0,0,0)}
.intro h2{font-family:'Inter Tight',sans-serif;font-weight:700;font-size:28px;letter-spacing:0;line-height:1.2;color:#fff}
.intro-spacer{height:24px}
.client-marquee{position:relative;width:400px;max-width:100%;height:40px;overflow:hidden}
.client-marquee::before,.client-marquee::after{content:'';position:absolute;top:0;bottom:0;width:60px;z-index:2;pointer-events:none}
.client-marquee::before{left:0;background:linear-gradient(to right,#111,transparent)}
.client-marquee::after{right:0;background:linear-gradient(to left,#111,transparent)}
.client-track{display:flex;gap:20px;align-items:center;height:40px}
.client-logo{width:40px;height:40px;border-radius:50%;flex-shrink:0;object-fit:cover;background:#222}

/* ===== PORTFOLIO CARDS ===== */
.portfolio-wrap{opacity:0;transform:translate3d(0,30px,0);transition:opacity .7s cubic-bezier(.16,1,.3,1) .25s,transform .7s cubic-bezier(.16,1,.3,1) .25s;margin-bottom:-500px;position:relative;z-index:1}
.portfolio-wrap.visible{opacity:1;transform:translate3d(0,0,0)}
.portfolio{display:flex;flex-flow:row;width:100%;padding:0 20px;gap:20px;align-items:stretch}
.portfolio-row{display:contents}
.column{display:flex;flex-flow:column;flex:1;gap:20px}
.column-1{padding-top:15px}
.column-2{padding-top:0}
.column-3{padding-top:30px}
.column-4{padding-top:8px}
.card{background:#1d1d1d;box-shadow:0 6px rgba(0,0,0,.4);cursor:pointer;display:flex;flex-flow:column;border-radius:0;transition:box-shadow .2s,transform .3s;position:relative;padding:0;gap:0}
.card:hover{box-shadow:0 8px 24px rgba(52,211,153,.08);transform:translateY(-2px)}
.card-banner{position:relative;width:100%;overflow:hidden;background:#1a1a1a;line-height:0;transition:transform .6s cubic-bezier(.2,.8,.2,1);scrollbar-width:none;-ms-overflow-style:none;backface-visibility:hidden;flex:1;contain:layout style}
.card-banner::-webkit-scrollbar{display:none}
.card:hover .card-banner{transform:scale(1.02)}
.card-emoji{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:clamp(32px,4vw,64px);opacity:.2;pointer-events:none;transition:transform .6s cubic-bezier(.2,.8,.2,1)}
.card:hover .card-emoji{transform:translate(-50%,-50%) scale(1.1)}
.card-hover-zone{position:absolute;inset:0;cursor:none;z-index:1}
.card-hover-icon{position:absolute;pointer-events:none;width:60px;height:60px;border-radius:50%;background:#34d399;box-shadow:0 3px rgba(0,0,0,.15);display:flex;align-items:center;justify-content:center;transform:scale(0);opacity:0;transition:transform .2s cubic-bezier(.2,.8,.2,1),opacity 0s;z-index:4}
.card:hover .card-hover-icon{transform:scale(1)}
.card-hover-icon svg{width:24px;height:24px;fill:none;stroke:#111;stroke-width:2.5}
.card-details{display:flex;align-items:flex-start;padding:12px 16px;flex-shrink:0}
.card-text{flex:1;min-width:0}
.card-text h3{font-family:'Inter',sans-serif;font-weight:600;font-size:16px;letter-spacing:-.2px;line-height:1.4;color:#fff;margin:0}
.card-text p{font-family:'Inter',sans-serif;font-weight:500;font-size:14px;letter-spacing:-.2px;line-height:1.4;color:#777;margin:2px 0 0}

/* ===== VIDEO SECTION ===== */
.video-section{position:relative;height:85vh;display:flex;align-items:center;justify-content:center;overflow:hidden;z-index:2}
.video-section::before{content:'';position:absolute;top:0;left:0;right:0;height:140px;background:linear-gradient(to bottom,rgba(17,17,17,0.98) 0%,rgba(17,17,17,0.7) 40%,rgba(17,17,17,0.2) 80%,transparent 100%);z-index:3;pointer-events:none}
.video-section::after{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:#34d399;opacity:.3;z-index:4}
.video-full{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;transform:scale(1.15)}
.video-overlay{position:absolute;inset:0;z-index:1;background:rgba(0,0,0,.8);pointer-events:none}
.video-placeholder{position:absolute;inset:0;z-index:0;background:radial-gradient(ellipse at 50% 40%,#1a2a1f 0%,#0d0d0d 100%);display:flex;align-items:center;justify-content:center;pointer-events:none;transition:opacity .5s}
.video-placeholder::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(52,211,153,.03) 0%,transparent 50%,rgba(52,211,153,.03) 100%);animation:video-shimmer 3s ease-in-out infinite}
@keyframes video-shimmer{0%,100%{opacity:.6}50%{opacity:1}}
.video-content{position:relative;z-index:2;display:flex;flex-flow:column;align-items:center;text-align:center;max-width:1000px;width:100%;padding:0 20px}
.video-label{font-family:'Inter',sans-serif;font-weight:700;font-size:18px;letter-spacing:.15em;text-transform:uppercase;color:#34d399;margin-bottom:16px;text-shadow:0 2px 12px rgba(0,0,0,.9)}
.video-heading{font-family:'Inter Tight',sans-serif;font-weight:700;font-size:clamp(45px,6.25vw,80px);line-height:1.1;color:#fff;margin:0 0 16px;text-shadow:0 2px 16px rgba(0,0,0,.9)}
.video-sub{font-family:'Inter',sans-serif;font-weight:500;font-size:22px;line-height:1.6;color:#ddd;margin:0;max-width:750px;text-shadow:0 2px 12px rgba(0,0,0,.9)}

/* ===== VIDEO DIVIDER (Enhanced) ===== */
.video-divider{position:relative;z-index:2;height:2px;background:transparent;overflow:visible;margin-top:-1px}
.video-divider::before{content:'';position:absolute;inset:0;background:linear-gradient(to right,transparent,#34d399 30%,#34d399 70%,transparent);animation:divider-glow 3s ease-in-out infinite}
.video-divider::after{content:'';position:absolute;top:-8px;left:0;right:0;height:18px;background:linear-gradient(to right,transparent 0%,rgba(52,211,153,.15) 30%,rgba(52,211,153,.15) 70%,transparent 100%);filter:blur(8px);animation:divider-glow 3s ease-in-out infinite}
@keyframes divider-glow{0%,100%{opacity:.4}50%{opacity:1}}

/* ===== TRANSITION BRIDGE ===== */
.section-bridge{position:relative;height:120px;background:linear-gradient(to bottom,#111 0%,#0d0d0d 50%,#111 100%);overflow:hidden;z-index:2}
.section-bridge::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:200px;height:200px;background:radial-gradient(circle,rgba(52,211,153,.06) 0%,transparent 70%);border-radius:50%;animation:bridge-pulse 4s ease-in-out infinite}
@keyframes bridge-pulse{0%,100%{transform:translate(-50%,-50%) scale(1);opacity:.5}50%{transform:translate(-50%,-50%) scale(1.5);opacity:1}}

/* ===== STATS SECTION (Enhanced) ===== */
.stats-section{padding:120px 20px 100px;background:#111;overflow:hidden;position:relative}
.stats-section::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(52,211,153,.04) 1px,transparent 1px);background-size:40px 40px;pointer-events:none}
.stats-section .wrap{max-width:1200px}
.stats-header-title{font-family:'Inter Tight',sans-serif;font-weight:700;font-size:clamp(28px,4vw,46px);line-height:0.88;letter-spacing:-0.02em;margin:0 0 60px;text-transform:uppercase}
.stats-header-title .color-dark{color:#fff}
.stats-header-title .color-medium{color:#34d399}
.stats-header-title .color-light{color:#555}
.stats-grid-row{display:grid;grid-template-columns:repeat(3,1fr);gap:60px;margin-bottom:60px}
.stat-card{display:flex;flex-flow:column;align-items:center;position:relative}
.stat-number-box{font-size:clamp(64px,8vw,110px);font-weight:700;color:#fff;line-height:.95;letter-spacing:-.03em;margin-bottom:0;display:flex;align-items:baseline;font-family:'Inter Tight',sans-serif;position:relative}
.stat-number{font-variant-numeric:tabular-nums}
.stat-suffix{font-family:'Inter Tight',sans-serif}
.stat-label-text{font-size:15px;color:#777;font-weight:500;line-height:1.4;letter-spacing:-.01em;font-family:'Inter',sans-serif;text-align:center;margin-top:8px}
.stats-footer-row{display:grid;grid-template-columns:1fr 260px;gap:80px;align-items:stretch}
.services-list-container{display:flex;flex-flow:column;gap:18px;margin:0;padding:0}
.service-row-item{font-family:'Inter',sans-serif;font-size:clamp(18px,2vw,26px);font-weight:500;color:#ccc;line-height:1.1;letter-spacing:-.01em}
.sectors-card-box{background:#34d399;border-radius:10px;padding:18px 22px;display:flex;flex-flow:column;height:100%;justify-content:flex-start;color:#111;opacity:0;transform:translateY(30px);transition:opacity 1s cubic-bezier(.16,1,.3,1),transform 1s cubic-bezier(.16,1,.3,1),box-shadow .3s}
.sectors-card-box.visible{opacity:1;transform:translateY(0)}
.sectors-card-box:hover{box-shadow:0 8px 32px rgba(52,211,153,.3)}
.sectors-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.sectors-card-title{font-family:'Inter',sans-serif;font-size:18px;font-weight:500;letter-spacing:-.02em}
.sectors-asterisk{width:18px;height:18px;color:#111;animation:asterisk-spin 8s linear infinite}
@keyframes asterisk-spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.sectors-list-grid{display:flex;flex-flow:column;gap:4px}
.sector-item{font-family:'Inter',sans-serif;font-size:clamp(18px,2vw,26px);font-weight:500;line-height:1.1;letter-spacing:-.01em}
.reveal-item{opacity:0;transform:translateY(30px);transition:opacity 1s cubic-bezier(.16,1,.3,1),transform 1s cubic-bezier(.16,1,.3,1)}
.reveal-item.visible{opacity:1;transform:translateY(0)}
.service-row-item,.sector-item{opacity:0;transform:translateY(20px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.service-row-item.visible,.sector-item.visible{opacity:1;transform:translateY(0)}



/* ===== CASE STUDY SHOWCASE ===== */
.cases-section{padding:100px 20px 80px;overflow:hidden}
.cases-section .wrap{max-width:1200px}
.cases-header{margin-bottom:48px}
.cases-title{font-family:'Inter Tight',sans-serif;font-weight:700;font-size:clamp(28px,4vw,46px);line-height:.88;letter-spacing:-.02em;text-transform:uppercase}

/* Shared pill styles */
.case-pill{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;border:1px solid #2a2a2a;font-family:'Inter',sans-serif;font-weight:600;font-size:12px;color:#aaa;letter-spacing:.02em;white-space:nowrap}
.case-pill--green{background:rgba(52,211,153,.1);border-color:rgba(52,211,153,.3);color:#34d399}
.case-avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;flex-shrink:0;border:2px solid #2a2a2a}
.case-author-info{display:flex;flex-flow:column;gap:2px}
.case-author-name{font-family:'Inter',sans-serif;font-weight:600;font-size:14px;color:#fff}
.case-author-role{font-family:'Inter',sans-serif;font-weight:400;font-size:12px;color:#777}

/* Hero case card */
.case-hero{position:relative;overflow:hidden;border:1px solid #2a2a2a;margin-bottom:20px;opacity:0;transform:translateY(40px);transition:opacity .8s cubic-bezier(.2,.8,.2,1),transform .8s cubic-bezier(.2,.8,.2,1),border-color .3s}
.case-hero.visible{opacity:1;transform:translateY(0)}
.case-hero:hover{border-color:rgba(52,211,153,.3)}
.case-hero-visual{position:relative;width:100%;height:320px;overflow:hidden}
.case-hero-visual img{width:100%;height:100%;object-fit:cover;object-position:top;transition:transform .6s cubic-bezier(.2,.8,.2,1)}
.case-hero:hover .case-hero-visual img{transform:scale(1.03)}
.case-hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 30%,rgba(17,17,17,.95) 100%)}
.case-hero-content{padding:28px 32px 32px;position:relative;z-index:1;margin-top:-80px}
.case-hero-pills{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.case-hero-quote{font-family:'Inter',sans-serif;font-weight:400;font-size:17px;line-height:1.7;color:#ccc;font-style:italic;margin-bottom:20px;max-width:700px}
.case-hero-author{display:flex;align-items:center;gap:12px}

/* Card row */
.case-row{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.case-card{border:1px solid #2a2a2a;overflow:hidden;opacity:0;transform:translateY(40px);transition:opacity .8s cubic-bezier(.2,.8,.2,1),transform .8s cubic-bezier(.2,.8,.2,1),border-color .3s}
.case-card.visible{opacity:1;transform:translateY(0)}
.case-card:hover{border-color:rgba(52,211,153,.3)}
.case-card-visual{position:relative;width:100%;height:220px;overflow:hidden}
.case-card-visual img{width:100%;height:100%;object-fit:cover;object-position:top;transition:transform .6s cubic-bezier(.2,.8,.2,1)}
.case-card:hover .case-card-visual img{transform:scale(1.03)}
.case-card-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 40%,rgba(17,17,17,.9) 100%)}
.case-card-body{padding:24px 24px 28px;position:relative;z-index:1;margin-top:-50px}
.case-card-pills{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}
.case-card-quote{font-family:'Inter',sans-serif;font-weight:400;font-size:14px;line-height:1.7;color:#ccc;font-style:italic;margin-bottom:16px}
.case-card-author{display:flex;align-items:center;gap:12px}

/* ===== PROCESS SECTION — IMMERSIVE ===== */
.process-section{padding:100px 20px 80px;overflow:hidden}
.process-section .wrap{max-width:1200px}
.process-header{margin-bottom:60px}
.process-title{font-family:'Inter Tight',sans-serif;font-weight:700;font-size:clamp(28px,5vw,46px);line-height:.88;letter-spacing:-.02em;text-transform:uppercase}

/* Step layout */
.step{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;margin-bottom:80px;opacity:0;transform:translateY(50px);transition:opacity .8s cubic-bezier(.2,.8,.2,1),transform .8s cubic-bezier(.2,.8,.2,1)}
.step.visible{opacity:1;transform:translateY(0)}
.step--reverse{direction:rtl}
.step--reverse>*{direction:ltr}
.step:last-child{margin-bottom:0}

/* Step info */
.step-info{text-align:center}
.step-label{display:inline-flex;align-items:center;padding:6px 16px;background:rgba(52,211,153,.1);border:1px solid rgba(52,211,153,.25);font-family:'Inter',sans-serif;font-weight:600;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:#34d399;margin-bottom:20px}
.step-heading{font-family:'Inter Tight',sans-serif;font-weight:700;font-size:clamp(20px,2.2vw,28px);line-height:1.2;color:#fff;margin-bottom:12px}
.step-desc{font-family:'Inter',sans-serif;font-weight:400;font-size:15px;line-height:1.7;color:#999;margin-bottom:20px}
.step-chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.step-chip{display:inline-flex;align-items:center;padding:6px 14px;border:1px solid #2a2a2a;font-family:'Inter',sans-serif;font-weight:500;font-size:12px;color:#777;transition:border-color .3s,color .3s}
.step:hover .step-chip{border-color:#333;color:#aaa}

/* Step visual / mockup */
.step-visual{position:relative}
.step-visual-inner{position:relative}
.step-mockup{background:#1a1a1a;border:1px solid #2a2a2a;overflow:hidden;transition:border-color .3s,box-shadow .3s}
.step:hover .step-mockup{border-color:#333;box-shadow:0 8px 32px rgba(0,0,0,.4)}

/* Mock browser chrome */
.mock-browser{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid #2a2a2a;background:#161616}
.mock-dots{display:flex;gap:5px}
.mock-dots span{width:8px;height:8px;border-radius:50%;background:#333}
.mock-dots span:first-child{background:#ff5f57}
.mock-dots span:nth-child(2){background:#ffbd2e}
.mock-dots span:last-child{background:#28c840}
.mock-url{font-family:'Inter',sans-serif;font-size:11px;color:#555;background:#1a1a1a;padding:4px 10px;flex:1;border:1px solid #2a2a2a}
.mock-url--live{display:flex;align-items:center;gap:6px;color:#34d399}

/* Mock body variants */
.mock-body{padding:0;min-height:200px;overflow:hidden;position:relative}

/* Image-based mockup (Steps 1, 2, 4) */
.mock-body--img{padding:0;line-height:0}
.mock-body--img img{width:100%;height:auto;display:block;object-fit:cover;max-height:280px}

/* Slow-scroll walkthrough (Step 3) */
.mock-body--scroll{padding:0;height:240px;overflow:hidden;position:relative}
.mock-scroll-img{width:100%;height:auto;display:block;position:absolute;top:0;left:0;animation:mock-scroll 8s ease-in-out infinite}
@keyframes mock-scroll{0%,15%{transform:translateY(0)}45%,55%{transform:translateY(calc(-100% + 240px))}85%,100%{transform:translateY(0)}}

/* Launch mockup glow */
.mock-body--launch{position:relative}
.mock-body--launch::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,rgba(52,211,153,.08) 0%,transparent 60%);pointer-events:none}

/* Launched — static image with animated checkmark */
.mock-body--launched{position:relative}
.mock-body--launched img{filter:brightness(.55)}
.mock-check-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.35);pointer-events:none}
.mock-check-icon{width:72px;height:72px;filter:drop-shadow(0 0 20px rgba(52,211,153,.5));transform:scale(0);opacity:0;transition:transform .6s cubic-bezier(.2,.8,.2,1) .4s,opacity .4s .4s}
.step.visible .mock-check-icon{transform:scale(1);opacity:1}


/* Floating badges */
.step-float{position:absolute;display:flex;align-items:center;gap:6px;padding:8px 14px;background:#1a1a1a;border:1px solid #2a2a2a;font-family:'Inter',sans-serif;font-weight:600;font-size:12px;color:#ccc;z-index:3;opacity:0;transform:translateY(10px);transition:opacity .5s,transform .5s cubic-bezier(.2,.8,.2,1);box-shadow:0 4px 16px rgba(0,0,0,.4)}
.step.visible .step-float{opacity:1;transform:translateY(0)}
.step-float--1{top:20px;right:-16px;transition-delay:.6s}
.step-float--2{bottom:30px;right:-10px;transition-delay:.8s}
.step-float--3{top:20px;left:-16px;transition-delay:.6s}
.step-float--4{bottom:30px;left:-10px;transition-delay:.8s}
.step-float--5{top:20px;right:-16px;transition-delay:.6s}
.step-float--6{bottom:30px;right:-16px;transition-delay:.6s}

/* ===== CTA SECTION ===== */
.cta-section{position:relative;padding:120px 20px;overflow:hidden}
.cta-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(52,211,153,.05) 0%,transparent 50%);pointer-events:none}
.cta-section .wrap{max-width:1200px}
.cta-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.cta-eyebrow{font-family:'Inter',sans-serif;font-weight:600;font-size:12px;letter-spacing:.15em;text-transform:uppercase;color:#34d399;margin-bottom:16px;display:block}
.cta-heading{font-family:'Inter Tight',sans-serif;font-weight:700;font-size:clamp(32px,4.5vw,60px);line-height:1.05;color:#fff;margin:0;letter-spacing:-.03em}
.cta-heading em{font-style:italic;color:#34d399}
.cta-desc{font-family:'Inter',sans-serif;font-weight:400;font-size:16px;line-height:1.7;color:#999;margin:0 0 28px}
.cta-btn-primary{display:inline-flex;align-items:center;gap:10px;padding:18px 36px;background:#34d399;color:#111;font-family:'Inter',sans-serif;font-weight:700;font-size:16px;text-decoration:none;border:none;cursor:pointer;transition:transform .2s,box-shadow .3s}
.cta-btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(52,211,153,.35)}
.cta-btn-primary svg{width:18px;height:18px;transition:transform .2s}
.cta-btn-primary:hover svg{transform:translateX(4px)}
.cta-trust{display:flex;gap:20px;margin-top:24px}
.cta-trust-item{display:flex;align-items:center;gap:6px;font-family:'Inter',sans-serif;font-weight:500;font-size:13px;color:#777}

/* ===== FOOTER ===== */
.footer{padding:0 20px;position:relative}
.footer .wrap{max-width:1200px}
.footer-line{height:1px;background:linear-gradient(to right,transparent,#2a2a2a 20%,#2a2a2a 80%,transparent)}
.footer-row{display:flex;align-items:center;justify-content:space-between;padding:32px 0 20px}
.footer-logo{font-family:'Inter Tight',sans-serif;font-weight:700;font-size:18px;color:#fff;text-decoration:none;transition:color .2s}
.footer-logo:hover{color:#34d399}
.footer-nav{display:flex;gap:24px}
.footer-nav a{font-family:'Inter',sans-serif;font-weight:500;font-size:14px;color:#555;text-decoration:none;padding:6px 14px;border:1px solid rgba(52,211,153,.35);box-shadow:0 0 14px rgba(52,211,153,.25),inset 0 0 6px rgba(52,211,153,.06);text-shadow:0 0 10px rgba(52,211,153,.25);transition:color .2s,border-color .2s,box-shadow .3s}
.footer-nav a:hover{color:var(--g);border-color:var(--g);box-shadow:0 0 24px rgba(52,211,153,.45),inset 0 0 10px rgba(52,211,153,.1);text-shadow:0 0 16px rgba(52,211,153,.4)}
.footer-bottom-row{display:flex;align-items:center;justify-content:space-between;padding:16px 0 24px;border-top:1px solid #1a1a1a}
.footer-bottom-row span{font-family:'Inter',sans-serif;font-weight:400;font-size:12px;color:#444}
.back-to-top{width:32px;height:32px;border:1px solid #2a2a2a;background:transparent;color:#555;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .3s,color .3s,transform .2s}
.back-to-top:hover{border-color:#34d399;color:#34d399;transform:translateY(-2px)}
.back-to-top svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2}

/* ===== LIGHTBOX ===== */
.lightbox{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,0.96);display:flex;align-items:flex-start;justify-content:center;opacity:0;pointer-events:none;transition:opacity .35s cubic-bezier(.2,.8,.2,1);overflow-y:auto;overflow-x:hidden;scrollbar-width:none;-ms-overflow-style:none}
.lightbox::-webkit-scrollbar{display:none}
.lightbox.open{opacity:1;pointer-events:auto}
.lightbox-close{position:fixed;top:24px;right:24px;z-index:10001;width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.15);color:#fff;font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(0.8);transition:opacity .35s .1s cubic-bezier(.2,.8,.2,1),transform .35s .1s cubic-bezier(.2,.8,.2,1),background .2s;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);font-family:'Inter',sans-serif;line-height:1}
.lightbox.open .lightbox-close{opacity:1;transform:scale(1)}
.lightbox-close:hover{background:rgba(255,255,255,0.18)}
.lightbox-inner{width:100%;max-width:1400px;padding:80px 24px 60px}
.lightbox-img-wrap{width:100%;line-height:0}
.lightbox-img{width:100%;height:auto;display:block;border-radius:2px;box-shadow:0 4px 40px rgba(0,0,0,.5)}
.lightbox-meta{text-align:center;margin-top:24px;padding-bottom:20px}
.lightbox-meta h2{font-family:'Inter Tight',sans-serif;font-weight:700;font-size:clamp(20px,3vw,32px);color:#fff;margin:0 0 6px}
.lightbox-meta p{font-family:'Inter',sans-serif;font-weight:500;font-size:14px;color:#888;margin:0}

/* ===== RESPONSIVE BREAKPOINTS ===== */
.mobile-break{display:none}
@media(max-width:768px){.mobile-break{display:inline}.mobile-hide{display:none!important}}
@media(max-width:1599.98px){
  .intro h2{font-size:24px}
}
@media(max-width:1199.98px){
  .topbar-inner{height:60px;padding:15px}
  .intro h2{font-size:20px}
  .portfolio{flex-flow:column;gap:20px}
  .portfolio-row{flex-flow:column}
  .column-1,.column-2,.column-3,.column-4{padding-top:0}
  .column{flex-flow:row;flex-wrap:wrap;gap:15px}
  .card{flex:1 1 calc(50% - 8px);min-width:140px}
  .step{gap:40px}
  .step-float{display:none}
}
@media(max-width:999.98px){
  .intro{padding:20px 20px 60px}
  .topbar-inner{padding:10px 15px;height:50px}
  .card{flex:1 1 100%}
  .intro h2{font-size:18px}
  .portfolio{padding:0 10px}
  .column{gap:10px}
  .card{padding:0;gap:0}
  .client-marquee{width:300px}
  .case-row{grid-template-columns:1fr}
  .case-hero-visual{height:220px}
  .step{grid-template-columns:1fr;gap:32px}
  .step--reverse{direction:ltr}
  .step-visual{order:2}
  .cta-inner{grid-template-columns:1fr;gap:40px;text-align:center}
  .cta-trust{justify-content:center;flex-wrap:wrap}
  .cta-btn-primary{width:auto;justify-content:center}
  .video-section{height:60vh}
  .footer-row{flex-flow:column;gap:20px;text-align:center}
  .footer-nav{justify-content:center}
  .footer-bottom-row{justify-content:center;gap:16px}
}
@media(max-width:768px){
  .topbar-inner{height:auto;padding:12px 15px 10px;flex-flow:row wrap;gap:8px}
  .topbar-email-group{gap:6px;flex-wrap:wrap}
  .topbar-cta,.topbar-email{font-size:12px;padding:0 12px;height:34px}
  .topbar-social{gap:6px}
  .social-btn{width:34px;height:34px}
  .social-btn svg{width:20px;height:20px}
  .stat-number-box{font-size:clamp(42px,14vw,75px);margin-bottom:0}
  .service-row-item{font-size:clamp(16px,4vw,22px)}
  .stats-grid-row{grid-template-columns:1fr;gap:50px}
  .stats-footer-row{grid-template-columns:1fr;gap:40px}
  .sectors-card-box{height:auto}
  .case-hero-content{padding:20px 20px 24px}
  .case-hero-quote{font-size:15px}
  .case-card-body{padding:20px 20px 24px}
  .step{margin-bottom:60px}
  .step-heading{font-size:20px}
  .cta-heading{font-size:clamp(28px,8vw,44px)}
  .cta-trust{flex-flow:column;align-items:center}
  .video-section{height:50vh}
  .video-content{max-width:100%}
  .video-heading{font-size:clamp(28px,8vw,48px)}
  .video-sub{font-size:16px;max-width:100%}
  .video-label{font-size:14px}
}
@media(max-width:480px){
  .topbar-inner{flex-flow:row wrap;gap:6px;height:auto;padding:8px 10px;justify-content:center}
  .topbar-email-group{display:flex;gap:5px;flex-shrink:0;flex-wrap:wrap;justify-content:center}
  .topbar-cta,.topbar-email{font-size:11px;padding:0 10px;height:30px}
  .topbar-social{display:flex;gap:5px;flex-shrink:0;flex-wrap:wrap;justify-content:center}
  .social-btn{width:30px;height:30px}
  .social-btn svg{width:18px;height:18px}
  .intro h2{font-size:16px}
  .portfolio-wrap{margin-bottom:-250px}
  .video-section{height:55vh}
  .video-heading{font-size:clamp(24px,7vw,32px);white-space:nowrap;font-weight:800}
  .video-sub{font-size:13px;max-width:90%}
  .video-label{font-size:12px}
  .video-content{max-width:100%;padding:0 12px}
  .card{flex:1 1 100%}
  .column{gap:8px}
  .portfolio{padding:0 6px;gap:12px}
  .case-hero-visual{height:180px}
  .case-card-visual{height:160px}
  .case-hero-quote{font-size:14px}
  .case-card-quote{font-size:13px}
  .cta-section{padding:80px 16px}
  .cta-heading{font-size:clamp(24px,9vw,36px)}
  .cta-btn-primary{font-size:14px;padding:14px 24px}
  .stats-section{padding:80px 16px 60px}
  .services-list-container,.sectors-card-box{padding-left:8px}
  .sectors-card-box{padding:14px 16px}
  .process-section{padding:60px 12px 40px}
  .step-heading{font-size:clamp(18px,5vw,24px)}
  .step-desc{font-size:14px}
  .step-label{font-size:11px;padding:4px 12px}
  .step-chips{flex-wrap:nowrap;overflow-x:auto;gap:6px;justify-content:center;padding-bottom:4px}
  .step-chip{font-size:10px;padding:4px 10px;white-space:nowrap;flex-shrink:0}
  .footer-row{flex-flow:column;gap:16px}
  .footer-nav{gap:16px}
  .footer-nav a{font-size:13px}
}
.hero-geo{font-family:'Inter',sans-serif;font-size:14px;color:#888;text-align:center;margin-top:12px}
.intro-geo{font-family:'Inter',sans-serif;font-size:14px;color:#666;text-align:center;margin-top:8px}
.footer-geo{display:block;font-size:13px;color:#555;margin-top:4px}
@media(max-width:380px){
  .topbar-inner{flex-flow:column;gap:6px;padding:8px 6px}
  .topbar-email-group{gap:4px;width:100%;justify-content:center}
  .topbar-cta,.topbar-email{font-size:11px;padding:0 8px;height:28px}
  .topbar-social{gap:4px}
  .social-btn{width:28px;height:28px}
  .social-btn svg{width:16px;height:16px}
}
