/* ============================================================
   INDIIBOT THEME — MAIN STYLESHEET
   Variables match the working index.html exactly
============================================================ */

/* ─── RESET ────────────────────────────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
:root{
  --bg:#0a0a0a;
  --white:#f5f5f7;
  --blue:#074ce5;
  --muted:#555;
  --border:rgba(255,255,255,0.07);
  --fh:'Bebas Neue',sans-serif;
  --fb:'DM Sans',sans-serif;
}
html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--white);font-family:var(--fb);font-size:16px;line-height:1.6;overflow-x:hidden;cursor:none;}
a{color:inherit;text-decoration:none;cursor:none;}
img{display:block;max-width:100%;}
ul{list-style:none;}
button{background:none;border:none;cursor:none;}

/* ─── CUSTOM CURSOR ────────────────────────────────────── */
#c-dot{position:fixed;top:0;left:0;width:10px;height:10px;background:var(--white);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .2s,height .2s,background .2s;}
#c-ring{position:fixed;top:0;left:0;width:44px;height:44px;border:1.5px solid rgba(255,255,255,0.35);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .4s,height .4s,border-color .3s,background .3s;}
body.ch #c-dot{width:12px;height:12px;background:var(--blue);}
body.ch #c-ring{width:64px;height:64px;border-color:var(--blue);background:rgba(7,76,229,0.08);}
body.cc #c-dot{width:6px;height:6px;}
body.cc #c-ring{width:28px;height:28px;}
body.cursor-dark #c-dot{background:#0a0a0a !important;box-shadow:0 0 0 1.5px rgba(255,255,255,0.25);}
body.cursor-dark #c-ring{border-color:rgba(0,0,0,0.5) !important;background:rgba(0,0,0,0.08) !important;}

/* ─── PRELOADER ─────────────────────────────────────────── */
#preloader{position:fixed;inset:0;background:var(--bg);z-index:10000;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;}
.pl-logo{display:flex;gap:2px;overflow:hidden;}
.pl-letter{font-family:var(--fh);font-size:clamp(48px,10vw,120px);letter-spacing:0.08em;transform:translateY(110%);opacity:0;}
.pl-bar-wrap{width:180px;height:1px;background:rgba(255,255,255,0.1);}
.pl-bar{height:100%;width:0%;background:var(--blue);transition:width .05s linear;}
.pl-count{font-size:11px;letter-spacing:0.3em;color:var(--muted);}

/* ─── NAV ───────────────────────────────────────────────── */
#nav{position:fixed;top:0;left:0;width:100%;z-index:900;padding:20px 48px;display:flex;align-items:center;justify-content:space-between;transition:background .4s,padding .4s;}
#nav.scrolled{background:rgba(10,10,10,0.92);backdrop-filter:blur(20px);padding:14px 48px;border-bottom:1px solid var(--border);}
.nav-logo-img{height:36px;width:auto;display:block;}
.nav-links{display:flex;gap:32px;align-items:center;}
.nav-links ul,.nav-links .menu{display:flex;gap:32px;align-items:center;list-style:none;}
.nav-links li{position:relative;}
.nav-link{font-size:12px;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,0.55);position:relative;transition:color .3s;}
.nav-link::after{content:'';position:absolute;bottom:-3px;left:0;width:0;height:1px;background:var(--blue);transition:width .35s cubic-bezier(.4,0,.2,1);}
.nav-link:hover,.nav-link.active{color:var(--white);}
.nav-link:hover::after,.nav-link.active::after{width:100%;}
.nav-links a{font-size:12px;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,0.55);position:relative;transition:color .3s;}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;width:0;height:1px;background:var(--blue);transition:width .35s cubic-bezier(.4,0,.2,1);}
.nav-links a:hover{color:var(--white);}
.nav-links a:hover::after{width:100%;}
.nav-cta{font-size:11px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;padding:13px 30px;border:1px solid rgba(255,255,255,0.3);color:var(--white);position:relative;overflow:hidden;transition:border-color .3s;}
.nav-cta::before{content:'';position:absolute;inset:0;background:var(--blue);transform:translateX(-101%);transition:transform .4s cubic-bezier(.4,0,.2,1);}
.nav-cta:hover{border-color:var(--blue);}
.nav-cta:hover::before{transform:translateX(0);}
.nav-cta span{position:relative;z-index:1;}
.nav-ham{display:none;flex-direction:column;gap:6px;padding:4px;}
.nav-ham span{display:block;width:26px;height:1.5px;background:var(--white);transition:transform .4s,opacity .3s;}
#mob-menu{position:fixed;inset:0;background:var(--bg);z-index:800;display:flex;flex-direction:column;justify-content:center;padding:48px;transform:translateX(-100%);transition:transform .55s cubic-bezier(.4,0,.2,1);}
#mob-menu.open{transform:translateX(0);}
.mob-link{font-family:var(--fh);font-size:clamp(44px,9vw,88px);letter-spacing:0.04em;color:rgba(255,255,255,0.35);display:block;padding:10px 0;border-bottom:1px solid var(--border);transition:color .3s;}
.mob-link:hover{color:var(--white);}

/* ─── HOMEPAGE HERO ─────────────────────────────────────── */
#hero{min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;padding:0 48px 80px;position:relative;overflow:hidden;}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:72px 72px;pointer-events:none;}
.hero-glow{position:absolute;top:10%;right:-5%;width:55%;height:80%;background:radial-gradient(ellipse at top right,rgba(7,76,229,0.14) 0%,transparent 65%);pointer-events:none;}
.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:10px;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;color:rgba(255,255,255,.45);border:1px solid var(--border);padding:8px 18px;border-radius:999px;margin-bottom:36px;width:fit-content;opacity:0;}
.hero-pulse{width:6px;height:6px;background:var(--blue);border-radius:50%;animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.5;transform:scale(1.6);}}
.hero-h{font-family:var(--fh);font-size:clamp(70px,13vw,210px);line-height:0.88;letter-spacing:-0.01em;overflow:visible;}
.hero-line{display:block;overflow:hidden;}
.hero-inner{display:block;opacity:0;}
.hero-accent{color:var(--blue);}
.rotating-wrap{display:inline-block;vertical-align:bottom;overflow:hidden;height:0.88em;}
.rotating-words{display:flex;flex-direction:column;animation:rotWords 6s cubic-bezier(.4,0,.2,1) infinite;}
.rotating-word{font-family:var(--fh);font-size:inherit;line-height:0.88;color:var(--blue);display:block;white-space:nowrap;}
@keyframes rotWords{
  0%,18%{transform:translateY(0);}
  22%,38%{transform:translateY(-20%);}
  42%,58%{transform:translateY(-40%);}
  62%,78%{transform:translateY(-60%);}
  82%,98%{transform:translateY(-80%);}
  100%{transform:translateY(-80%);}
}
.hero-sub{display:flex;align-items:flex-end;justify-content:space-between;margin-top:48px;gap:32px;flex-wrap:wrap;}
.hero-desc{font-size:clamp(14px,1.4vw,17px);color:var(--muted);max-width:360px;line-height:1.75;font-weight:300;opacity:0;}
.hero-actions{display:flex;gap:16px;align-items:center;opacity:0;flex-wrap:wrap;}
.btn-p{display:inline-flex;align-items:center;gap:12px;font-size:11px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;padding:18px 40px;background:var(--blue);color:var(--white);position:relative;overflow:hidden;transition:transform .25s;}
.btn-p::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,.12);transform:translateX(-101%);transition:transform .4s cubic-bezier(.4,0,.2,1);}
.btn-p:hover::after{transform:translateX(0);}
.arr{width:18px;height:18px;border-top:1.5px solid currentColor;border-right:1.5px solid currentColor;transform:rotate(45deg);flex-shrink:0;transition:transform .3s;}
.btn-p:hover .arr{transform:rotate(45deg) translate(3px,-3px);}
.btn-g{font-size:12px;font-weight:500;color:rgba(255,255,255,.4);letter-spacing:0.06em;transition:color .3s;display:flex;align-items:center;gap:8px;}
.btn-g:hover{color:var(--white);}
.hero-scroll{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:10px;opacity:0;}
.scroll-ln{width:1px;height:56px;background:linear-gradient(to bottom,transparent,rgba(255,255,255,.3));animation:scLn 2s ease-in-out infinite;}
@keyframes scLn{0%{transform:scaleY(0);transform-origin:top;}50%{transform:scaleY(1);transform-origin:top;}51%{transform:scaleY(1);transform-origin:bottom;}100%{transform:scaleY(0);transform-origin:bottom;}}
.scroll-txt{font-size:9px;letter-spacing:0.25em;color:var(--muted);text-transform:uppercase;writing-mode:vertical-rl;}

/* ─── MARQUEE ───────────────────────────────────────────── */
.marquee{padding:28px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);overflow:hidden;}
.marquee-t{display:flex;white-space:nowrap;animation:mq 22s linear infinite;}
.marquee:hover .marquee-t{animation-play-state:paused;}
@keyframes mq{from{transform:translateX(0);}to{transform:translateX(-50%);}}
.mq-item{display:inline-flex;align-items:center;gap:20px;font-family:var(--fh);font-size:clamp(14px,2vw,20px);letter-spacing:0.12em;color:rgba(255,255,255,.3);padding:0 28px;transition:color .3s;}
.mq-item:hover{color:var(--white);}
.mq-dot{width:5px;height:5px;background:var(--blue);border-radius:50%;flex-shrink:0;}

/* ─── STATEMENT ─────────────────────────────────────────── */
#statement{padding:100px 48px;border-bottom:1px solid var(--border);}
.st-label{font-size:10px;font-weight:600;letter-spacing:0.25em;text-transform:uppercase;color:var(--blue);display:flex;align-items:center;gap:12px;margin-bottom:48px;}
.st-label::before{content:'';width:28px;height:1px;background:var(--blue);}
.st-text{font-family:var(--fh);font-size:clamp(36px,6.5vw,104px);line-height:0.95;letter-spacing:0.01em;max-width:1200px;}
.st-text .hl{color:var(--blue);}
.st-text .dim{color:rgba(255,255,255,.2);}
.st-bottom{display:flex;align-items:flex-end;justify-content:space-between;margin-top:64px;gap:32px;flex-wrap:wrap;}
.st-desc{font-size:15px;color:var(--muted);max-width:420px;line-height:1.8;font-weight:300;}
.st-link{font-size:11px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--blue);display:inline-flex;align-items:center;gap:10px;position:relative;}
.st-link::after{content:'';position:absolute;bottom:-2px;left:0;width:100%;height:1px;background:var(--blue);transform:scaleX(0);transform-origin:left;transition:transform .35s;}
.st-link:hover::after{transform:scaleX(1);}

/* ─── SERVICES HOMEPAGE GRID ────────────────────────────── */
#services{padding:100px 48px;border-bottom:1px solid var(--border);}
.sec-hd{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:64px;flex-wrap:wrap;gap:24px;}
.sec-label{font-size:10px;font-weight:600;letter-spacing:0.25em;text-transform:uppercase;color:var(--blue);display:flex;align-items:center;gap:12px;margin-bottom:20px;}
.sec-label::before{content:'';width:28px;height:1px;background:var(--blue);}
.sec-title{font-family:var(--fh);font-size:clamp(40px,6vw,88px);line-height:0.92;letter-spacing:0.01em;}
.sec-title .bl{color:var(--blue);}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);}
.svc-card{background:var(--bg);padding:44px 36px;position:relative;overflow:hidden;transition:background .5s;}
.svc-card::before{content:'';position:absolute;bottom:0;left:0;width:100%;height:0;background:var(--blue);transition:height .5s cubic-bezier(.4,0,.2,1);z-index:0;}
.svc-card:hover::before{height:100%;}
.svc-card>*{position:relative;z-index:1;}
.svc-n{font-family:var(--fh);font-size:12px;color:rgba(255,255,255,.25);letter-spacing:0.12em;margin-bottom:28px;transition:color .3s .05s;}
.svc-card:hover .svc-n{color:rgba(255,255,255,.5);}
.svc-ico{width:48px;height:48px;margin-bottom:20px;transition:transform .4s;}
.svc-card:hover .svc-ico{transform:scale(1.1) rotate(-6deg);}
.svc-ico svg{width:100%;height:100%;}
.svc-name{font-family:var(--fh);font-size:clamp(20px,2.2vw,30px);letter-spacing:0.03em;margin-bottom:14px;line-height:1.05;transition:color .3s .05s;}
.svc-tags{display:flex;flex-direction:column;gap:6px;max-height:0;overflow:hidden;opacity:0;transition:max-height .5s ease,opacity .4s .1s;}
.svc-card:hover .svc-tags{max-height:160px;opacity:1;}
.svc-tag{font-size:10px;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,255,255,.6);display:flex;align-items:center;gap:8px;}
.svc-tag::before{content:'→';font-size:9px;}
.svc-arr{position:absolute;bottom:36px;right:36px;width:36px;height:36px;border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(0.7);transition:opacity .4s .15s,transform .4s .15s;z-index:1;}
.svc-card:hover .svc-arr{opacity:1;transform:scale(1);}

/* ─── STATS ─────────────────────────────────────────────── */
#stats{padding:0;background:var(--bg);display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background-color:var(--border);}
.stat-b{background:var(--bg);padding:64px 48px;position:relative;overflow:hidden;transition:background .4s;}
.stat-b::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--blue);transition:width .5s cubic-bezier(.4,0,.2,1);}
.stat-b:hover{background:rgba(7,76,229,0.04);}
.stat-b:hover::after{width:100%;}
.stat-n{font-family:var(--fh);font-size:clamp(56px,7vw,110px);color:var(--white);line-height:1;display:flex;align-items:baseline;gap:4px;}
.stat-n .cnt{color:var(--blue);}
.stat-n .suf{font-size:.45em;color:var(--muted);font-family:var(--fb);font-weight:300;margin-left:4px;}
.stat-lbl{font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);margin-top:12px;}

/* ─── HOW WE WORK (Process) ─────────────────────────────── */
#process{padding:100px 48px;border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.proc-steps{display:flex;flex-direction:column;margin-top:64px;}
.proc-step{display:grid;grid-template-columns:80px 1fr 1.2fr;gap:48px;align-items:start;padding:48px 0;border-bottom:1px solid var(--border);position:relative;overflow:hidden;transition:background .3s;}
.proc-step::after{content:'';position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--blue);transition:width .55s cubic-bezier(.4,0,.2,1);}
.proc-step:hover::after{width:100%;}
.proc-step:hover{background:rgba(7,76,229,.025);}
.p-num{font-family:var(--fh);font-size:60px;color:var(--border);line-height:1;transition:color .4s;}
.proc-step:hover .p-num{color:var(--blue);}
.p-title{font-family:var(--fh);font-size:clamp(26px,3vw,48px);letter-spacing:0.02em;line-height:1;padding-top:6px;}
.p-desc{font-size:15px;color:var(--muted);line-height:1.75;font-weight:300;padding-top:10px;}

/* ─── PORTFOLIO HOMEPAGE ────────────────────────────────── */
#portfolio{padding:100px 48px;border-bottom:1px solid var(--border);}
.pf-hd{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:64px;flex-wrap:wrap;gap:24px;}
.pf-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:16px;}
.pf-item{position:relative;overflow:hidden;cursor:none;}
.pf-item:nth-child(1){grid-column:span 7;}
.pf-item:nth-child(2){grid-column:span 5;}
.pf-item:nth-child(3){grid-column:span 5;}
.pf-item:nth-child(4){grid-column:span 7;}
.pf-img{background:rgba(255,255,255,.04);overflow:hidden;}
.pf-item:nth-child(1) .pf-img,.pf-item:nth-child(4) .pf-img{aspect-ratio:16/9;}
.pf-item:nth-child(2) .pf-img,.pf-item:nth-child(3) .pf-img{aspect-ratio:4/5;}
.pf-img img{width:100%;height:100%;object-fit:cover;transform:scale(1.06);filter:grayscale(30%);transition:transform .8s cubic-bezier(.4,0,.2,1),filter .6s;}
.pf-item:hover .pf-img img{transform:scale(1.13);filter:grayscale(0);}
.pf-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,10,.95) 0%,rgba(10,10,10,.2) 50%,transparent 100%);opacity:0;transition:opacity .5s;display:flex;flex-direction:column;justify-content:flex-end;padding:28px;}
.pf-item:hover .pf-ov{opacity:1;}
.pf-cat{font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--blue);margin-bottom:7px;transform:translateY(16px);transition:transform .4s .05s;}
.pf-item:hover .pf-cat{transform:translateY(0);}
.pf-ttl{font-family:var(--fh);font-size:clamp(18px,2vw,30px);letter-spacing:.03em;transform:translateY(16px);transition:transform .4s .1s;}
.pf-item:hover .pf-ttl{transform:translateY(0);}

/* ─── TESTIMONIALS ──────────────────────────────────────── */
#testi{padding:100px 48px;border-bottom:1px solid var(--border);}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);margin-top:64px;}
.testi-c{background:var(--bg);padding:44px 36px;position:relative;overflow:hidden;transition:background .4s;}
.testi-c::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(7,76,229,.05) 0%,transparent 60%);opacity:0;transition:opacity .4s;}
.testi-c:hover{background:rgba(255,255,255,.02);}
.testi-c:hover::before{opacity:1;}
.testi-q{font-family:var(--fh);font-size:72px;color:var(--blue);line-height:.7;margin-bottom:20px;opacity:.35;}
.testi-txt{font-size:15px;font-weight:300;line-height:1.8;color:rgba(255,255,255,.75);font-style:italic;margin-bottom:28px;}
.testi-auth{font-size:13px;font-weight:600;letter-spacing:.04em;color:var(--white);}
.testi-role{font-size:11px;color:var(--muted);margin-top:4px;letter-spacing:.05em;}
.testi-ind{display:inline-block;font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:var(--blue);border:1px solid rgba(7,76,229,.3);padding:4px 10px;margin-top:12px;}

/* ─── CTA ───────────────────────────────────────────────── */
#cta{padding:120px 48px;text-align:center;position:relative;overflow:hidden;border-bottom:1px solid var(--border);}
.cta-glow-c{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:700px;height:400px;background:radial-gradient(ellipse,rgba(7,76,229,.13) 0%,transparent 65%);pointer-events:none;}
.cta-lbl{font-size:10px;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--blue);display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:32px;}
.cta-lbl::before{content:'';width:28px;height:1px;background:var(--blue);}
.cta-h{font-family:var(--fh);font-size:clamp(56px,10vw,160px);line-height:.9;letter-spacing:.01em;margin-bottom:48px;position:relative;}
.cta-h .bl{color:var(--blue);}
.cta-sub{font-size:15px;color:var(--muted);max-width:440px;margin:0 auto 56px;line-height:1.75;font-weight:300;}
.cta-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}
.btn-lg{padding:22px 56px;font-size:13px;}

/* ─── FOOTER ────────────────────────────────────────────── */
footer{border-top:1px solid var(--border);padding:80px 48px 40px;}
.ft-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:60px;padding-bottom:60px;border-bottom:1px solid var(--border);}
.ft-brand-logo{height:40px;width:auto;margin-bottom:20px;}
.ft-tag{color:var(--muted);font-size:13px;line-height:1.75;font-weight:300;max-width:240px;margin-bottom:32px;}
.ft-soc{display:flex;gap:12px;}
.soc-lk{width:38px;height:38px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--muted);transition:border-color .3s,background .3s,color .3s;}
.soc-lk:hover{border-color:var(--blue);background:var(--blue);color:var(--white);}
.ft-col h4{font-size:10px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:22px;}
.ft-col ul{display:flex;flex-direction:column;gap:11px;}
.ft-col ul li a{font-size:13px;color:rgba(255,255,255,.3);font-weight:300;transition:color .3s;}
.ft-col ul li a:hover{color:var(--white);}
.ft-bot{padding-top:28px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;}
.ft-copy{font-size:11px;color:var(--muted);letter-spacing:.05em;}
.ft-copy a{color:var(--blue);}
.ft-leg{display:flex;gap:20px;}
.ft-leg a{font-size:11px;color:rgba(255,255,255,.25);letter-spacing:.05em;transition:color .3s;}
.ft-leg a:hover{color:var(--white);}

/* ─── SCROLL REVEALS ────────────────────────────────────── */
.rv{opacity:0;transform:translateY(36px);}
.rv-l{opacity:0;transform:translateX(-36px);}
.rv-r{opacity:0;transform:translateX(36px);}

/* ─── INNER PAGE HERO ───────────────────────────────────── */
.page-hero{min-height:65vh;display:flex;flex-direction:column;justify-content:flex-end;padding:160px 48px 80px;position:relative;overflow:hidden;border-bottom:1px solid var(--border);}
.hero-bg-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:72px 72px;pointer-events:none;}
.hero-bg-glow{position:absolute;top:10%;right:-5%;width:55%;height:80%;background:radial-gradient(ellipse at top right,rgba(7,76,229,0.14) 0%,transparent 65%);pointer-events:none;}
.page-hero-label{font-size:11px;font-weight:600;letter-spacing:0.25em;text-transform:uppercase;color:var(--blue);display:flex;align-items:center;gap:12px;margin-bottom:28px;opacity:0;}
.page-hero-label::before{content:'';width:32px;height:1px;background:var(--blue);}
.page-hero-title{font-family:var(--fh);font-size:clamp(64px,11vw,180px);line-height:0.9;letter-spacing:-0.01em;color:var(--white);overflow:hidden;}
.page-hero-line{display:block;overflow:hidden;}
.hero-headline-inner{display:block;transform:translateY(110%);}
.page-hero-desc{font-size:clamp(15px,1.5vw,19px);color:var(--muted);max-width:520px;line-height:1.7;font-weight:300;margin-top:36px;opacity:0;}
.accent{color:var(--blue);}
.breadcrumb{position:absolute;top:110px;left:48px;display:flex;align-items:center;gap:12px;font-size:12px;color:var(--muted);letter-spacing:0.06em;}
.breadcrumb a{transition:color .3s;}
.breadcrumb a:hover{color:var(--white);}
.breadcrumb-sep{color:var(--border);}

/* ─── SHARED SECTION STYLES ─────────────────────────────── */
section{padding:100px 48px;}
.section-label{font-size:10px;font-weight:600;letter-spacing:0.25em;text-transform:uppercase;color:var(--blue);display:flex;align-items:center;gap:12px;margin-bottom:28px;}
.section-label::before{content:'';width:28px;height:1px;background:var(--blue);}
.section-title{font-family:var(--fh);font-size:clamp(40px,6vw,88px);line-height:0.92;letter-spacing:0.01em;margin-bottom:64px;}
.section-title-line{display:block;overflow:hidden;}
.title-inner{display:block;transform:translateY(110%);}
.line-blue{color:var(--blue);}

/* ─── SERVICES PAGE ─────────────────────────────────────── */
.services-full-grid{display:flex;flex-direction:column;gap:1px;background:var(--border);}
.service-row{display:grid;grid-template-columns:80px 280px 1fr auto;gap:48px;align-items:start;padding:56px 48px;background:var(--bg);position:relative;overflow:hidden;cursor:none;transition:background .4s;}
.service-row::before{content:'';position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--blue);transition:width .6s cubic-bezier(.4,0,.2,1);}
.service-row:hover{background:rgba(7,76,229,0.04);}
.service-row:hover::before{width:100%;}
.service-num{font-family:var(--fh);font-size:14px;color:var(--muted);letter-spacing:0.1em;padding-top:6px;}
.service-row-name{font-family:var(--fh);font-size:clamp(24px,2.5vw,40px);letter-spacing:0.02em;line-height:1.05;padding-top:4px;}
.service-row-detail{font-size:15px;color:var(--muted);line-height:1.7;font-weight:300;padding-top:8px;}
.service-row-tags{display:flex;flex-direction:column;gap:8px;padding-top:8px;}
.service-tag{font-size:10px;letter-spacing:0.15em;text-transform:uppercase;color:var(--muted);border:1px solid var(--border);padding:5px 12px;white-space:nowrap;transition:border-color .3s,color .3s;}
.service-row:hover .service-tag{border-color:rgba(7,76,229,0.4);color:var(--blue);}

/* Process on services/inner pages */
.process-header{padding-bottom:64px;}
.process-steps{display:flex;flex-direction:column;}
.process-step{display:grid;grid-template-columns:80px 1fr 1.2fr;gap:48px;align-items:start;padding:48px 0;border-bottom:1px solid var(--border);position:relative;overflow:hidden;transition:background .3s;}
.process-step::after{content:'';position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--blue);transition:width .55s cubic-bezier(.4,0,.2,1);}
.process-step:hover::after{width:100%;}
.process-step:hover{background:rgba(7,76,229,.025);}
.step-num{font-family:var(--fh);font-size:60px;color:var(--border);line-height:1;}
.step-title{font-family:var(--fh);font-size:clamp(26px,3vw,48px);letter-spacing:0.02em;line-height:1;padding-top:6px;}
.step-desc{font-size:15px;color:var(--muted);line-height:1.75;font-weight:300;padding-top:10px;}

/* Services CTA (inner pages) */
.cta-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:700px;height:400px;background:radial-gradient(ellipse,rgba(7,76,229,.13) 0%,transparent 65%);pointer-events:none;}
.cta-headline{font-family:var(--fh);font-size:clamp(56px,10vw,160px);line-height:.9;letter-spacing:.01em;margin-bottom:48px;}
.cta-subtext{font-size:15px;color:var(--muted);max-width:480px;margin:0 auto 56px;line-height:1.75;font-weight:300;}
.cta-btn-group{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}
.btn-primary{display:inline-flex;align-items:center;gap:12px;font-size:11px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;padding:18px 40px;background:var(--blue);color:var(--white);position:relative;overflow:hidden;transition:transform .25s;}
.btn-primary::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,.12);transform:translateX(-101%);transition:transform .4s cubic-bezier(.4,0,.2,1);}
.btn-primary:hover::after{transform:translateX(0);}
.btn-large{padding:22px 56px;font-size:13px;}
.btn-arrow{width:18px;height:18px;border-top:1.5px solid currentColor;border-right:1.5px solid currentColor;transform:rotate(45deg);flex-shrink:0;}
.btn-ghost{font-size:12px;font-weight:500;color:rgba(255,255,255,.4);letter-spacing:0.06em;transition:color .3s;display:flex;align-items:center;gap:8px;}
.btn-ghost:hover{color:var(--white);}
#cta{position:relative;text-align:center;overflow:hidden;}
.cta-label{justify-content:center;}

/* ─── PORTFOLIO PAGE ────────────────────────────────────── */
.blog-filter{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:64px;margin-top:40px;}
.filter-btn{font-size:11px;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;padding:10px 22px;border:1px solid var(--border);color:var(--muted);background:transparent;cursor:none;transition:border-color .3s,color .3s,background .3s;}
.filter-btn:hover,.filter-btn.active{border-color:var(--blue);color:var(--white);background:var(--blue);}
.portfolio-full-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}
.portfolio-full-item{position:relative;overflow:hidden;cursor:none;}
.portfolio-full-item .portfolio-img{aspect-ratio:16/10;overflow:hidden;background:rgba(255,255,255,.04);}
.portfolio-full-item .portfolio-img img{width:100%;height:100%;object-fit:cover;transform:scale(1.06);filter:grayscale(20%);transition:transform .8s cubic-bezier(.4,0,.2,1),filter .6s;}
.portfolio-full-item:hover .portfolio-img img{transform:scale(1.12);filter:grayscale(0);}
.portfolio-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,10,.95) 0%,rgba(10,10,10,.2) 50%,transparent 100%);opacity:0;transition:opacity .5s;display:flex;flex-direction:column;justify-content:flex-end;padding:32px;}
.portfolio-full-item:hover .portfolio-overlay{opacity:1;}
.portfolio-tag{font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--blue);margin-bottom:10px;}
.portfolio-title{font-family:var(--fh);font-size:clamp(22px,2.5vw,40px);letter-spacing:.03em;}
/* Testimonial on portfolio page */
.testimonial-quote-mark{font-family:var(--fh);font-size:80px;color:var(--blue);line-height:.7;opacity:.35;margin-bottom:16px;}
.testimonial-text{font-size:16px;font-weight:300;line-height:1.8;color:rgba(255,255,255,.75);font-style:italic;}
.testimonial-author{font-size:14px;font-weight:600;letter-spacing:.04em;color:var(--white);}
.testimonial-role{font-size:12px;color:var(--muted);margin-top:4px;}

/* ─── ABOUT PAGE ────────────────────────────────────────── */
#about{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;padding:100px 48px;border-bottom:1px solid var(--border);}
.about-statement{font-family:var(--fh);font-size:clamp(22px,2.5vw,36px);letter-spacing:0.02em;line-height:1.2;margin-bottom:28px;color:var(--white);}
.about-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}
.stat-item{padding:24px;border:1px solid var(--border);}
.stat-number{font-family:var(--fh);font-size:clamp(40px,5vw,72px);color:var(--white);line-height:1;display:flex;align-items:baseline;gap:4px;}
.stat-number .count{color:var(--blue);}
.stat-suffix{font-size:.45em;color:var(--muted);font-family:var(--fb);font-weight:300;margin-left:4px;}
.stat-label{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:8px;}
.about-image-wrap{position:relative;overflow:hidden;}
.about-image-wrap img{width:100%;aspect-ratio:3/4;object-fit:cover;}
.about-image-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,10,.7) 0%,transparent 60%);}
.about-image-caption{position:absolute;bottom:24px;left:24px;font-size:13px;color:rgba(255,255,255,.6);font-weight:300;line-height:1.5;}
.about-image-caption strong{display:block;color:var(--white);font-weight:600;margin-bottom:4px;}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);margin-top:80px;}
.value-card{background:var(--bg);padding:48px 40px;position:relative;overflow:hidden;transition:background .4s;}
.value-card::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--blue);transition:width .5s cubic-bezier(.4,0,.2,1);}
.value-card:hover{background:rgba(7,76,229,0.04);}
.value-card:hover::after{width:100%;}
.value-num{font-family:var(--fh);font-size:13px;color:var(--blue);letter-spacing:0.1em;margin-bottom:24px;}
.value-title{font-family:var(--fh);font-size:clamp(22px,2vw,32px);margin-bottom:16px;letter-spacing:0.03em;}
.value-desc{font-size:14px;color:var(--muted);line-height:1.65;font-weight:300;}
.industry-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);margin-top:80px;}
.industry-item{background:var(--bg);padding:36px;border-left:0;transition:background .3s;}
.industry-item:hover{background:rgba(7,76,229,0.03);}
.industry-item h3{font-family:var(--fh);font-size:clamp(20px,2vw,28px);letter-spacing:0.03em;margin-bottom:12px;}
.industry-item p{font-size:13px;color:var(--muted);line-height:1.6;font-weight:300;}

/* ─── CONTACT PAGE ──────────────────────────────────────── */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;padding:100px 48px;}
.contact-form{display:flex;flex-direction:column;gap:24px;}
.form-group{display:flex;flex-direction:column;gap:8px;}
.form-group label{font-size:11px;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;color:var(--muted);}
.form-group input,.form-group select,.form-group textarea{background:transparent;border:1px solid var(--border);border-bottom:1px solid rgba(245,245,247,0.2);color:var(--white);font-family:var(--fb);font-size:15px;font-weight:300;padding:16px 20px;outline:none;transition:border-color .3s,background .3s;width:100%;appearance:none;}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--blue);background:rgba(7,76,229,0.04);}
.form-group textarea{resize:vertical;min-height:120px;}
.form-group select option{background:var(--bg);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.contact-info{display:flex;flex-direction:column;gap:48px;}
.contact-info-label{font-size:10px;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;color:var(--blue);margin-bottom:12px;}
.contact-info-value{font-family:var(--fh);font-size:clamp(22px,2.5vw,36px);letter-spacing:0.02em;color:var(--white);line-height:1.1;}
.contact-info-sub{font-size:14px;color:var(--muted);margin-top:8px;font-weight:300;}
.contact-divider{width:100%;height:1px;background:var(--border);}
/* social links in footer / contact */
.footer-social,.ft-soc{display:flex;gap:12px;flex-wrap:wrap;}
.social-link{width:38px;height:38px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--muted);transition:border-color .3s,background .3s,color .3s;}
.social-link:hover{border-color:var(--blue);background:var(--blue);color:var(--white);}

/* ─── BLOG PAGE ─────────────────────────────────────────── */
.posts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;}
.post-card{background:transparent;border:1px solid var(--border);transition:border-color .3s;}
.post-card:hover{border-color:rgba(7,76,229,0.4);}
.post-card-thumb{aspect-ratio:16/10;overflow:hidden;background:rgba(255,255,255,.04);}
.post-card-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s;}
.post-card:hover .post-card-thumb img{transform:scale(1.05);}
.post-card-body{padding:28px;}
.post-card-cat{font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--blue);display:block;margin-bottom:12px;}
.post-card-title{font-family:var(--fh);font-size:clamp(18px,1.8vw,26px);letter-spacing:0.02em;line-height:1.1;margin-bottom:12px;}
.post-card-excerpt{font-size:14px;color:var(--muted);line-height:1.65;font-weight:300;margin-bottom:16px;}
.post-card-meta{font-size:11px;color:rgba(255,255,255,.25);letter-spacing:.05em;}

/* ─── SINGLE POST ───────────────────────────────────────── */
.post-hero{min-height:55vh;display:flex;flex-direction:column;justify-content:flex-end;padding:160px 48px 64px;position:relative;overflow:hidden;border-bottom:1px solid var(--border);}
.post-content{max-width:780px;margin:0 auto;padding:80px 48px;}
.post-content h2{font-family:var(--fh);font-size:clamp(28px,3vw,48px);margin:48px 0 20px;}
.post-content h3{font-family:var(--fh);font-size:clamp(22px,2.2vw,36px);margin:36px 0 16px;}
.post-content p{font-size:16px;color:rgba(255,255,255,.7);line-height:1.8;font-weight:300;margin-bottom:24px;}
.post-content ul,.post-content ol{padding-left:24px;margin-bottom:24px;}
.post-content li{font-size:15px;color:rgba(255,255,255,.6);line-height:1.7;font-weight:300;margin-bottom:8px;}
.post-content blockquote{border-left:3px solid var(--blue);padding:16px 24px;margin:32px 0;font-style:italic;color:rgba(255,255,255,.55);}
.post-content img{margin:32px 0;width:100%;}
.post-meta-bar{display:flex;align-items:center;gap:20px;font-size:12px;color:var(--muted);margin-top:20px;flex-wrap:wrap;}

/* ─── RESPONSIVE ────────────────────────────────────────── */
@media(max-width:1024px){
  #nav{padding:18px 32px;}
  #nav.scrolled{padding:13px 32px;}
  #hero{padding:0 32px 64px;}
  #statement,#services,#process,#portfolio,#testi,#cta{padding:80px 32px;}
  .svc-grid{grid-template-columns:repeat(2,1fr);}
  .testi-grid{grid-template-columns:repeat(2,1fr);}
  #stats{grid-template-columns:repeat(2,1fr);}
  .stat-b{padding:48px 36px;}
  .proc-step{grid-template-columns:60px 1fr;gap:24px;}
  .proc-step .p-desc{grid-column:2;}
  .pf-item:nth-child(1){grid-column:span 12;}
  .pf-item:nth-child(2){grid-column:span 6;}
  .pf-item:nth-child(3){grid-column:span 6;}
  .pf-item:nth-child(4){grid-column:span 12;}
  .ft-top{grid-template-columns:1fr 1fr;gap:40px;}
  .page-hero{padding:140px 32px 64px;}
  .breadcrumb{left:32px;}
  .contact-grid{grid-template-columns:1fr;gap:48px;padding:80px 32px;}
  .service-row{grid-template-columns:60px 1fr;gap:24px;padding:40px 32px;}
  .service-row-detail{grid-column:2;}
  .service-row-tags{grid-column:2;flex-direction:row;flex-wrap:wrap;}
  .portfolio-full-grid{grid-template-columns:1fr;}
  .values-grid{grid-template-columns:repeat(2,1fr);}
  .industry-grid{grid-template-columns:repeat(2,1fr);}
  #about{grid-template-columns:1fr;gap:48px;padding:80px 32px;}
  .process-step{grid-template-columns:60px 1fr;gap:24px;}
  .posts-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:768px){
  #nav{padding:18px 24px;}
  #nav.scrolled{padding:13px 24px;}
  #hero{padding:0 24px 56px;}
  #statement,#services,#process,#portfolio,#testi,#cta{padding:64px 24px;}
  footer{padding:60px 24px 32px;}
  .nav-links{display:none;}
  .nav-ham{display:flex;}
  .svc-grid{grid-template-columns:1fr;}
  .testi-grid{grid-template-columns:1fr;}
  #stats{grid-template-columns:repeat(2,1fr);}
  .stat-b{padding:40px 28px;}
  .proc-step{grid-template-columns:1fr;}
  .p-num{font-size:40px;}
  .pf-grid{grid-template-columns:1fr;}
  .pf-item:nth-child(n){grid-column:span 1;}
  .pf-img{aspect-ratio:16/10!important;}
  .ft-top{grid-template-columns:1fr;gap:36px;}
  .ft-bot{flex-direction:column;text-align:center;}
  .hero-sub{flex-direction:column;align-items:flex-start;}
  .cta-h{font-size:clamp(48px,14vw,80px);}
  .page-hero{padding:120px 24px 48px;min-height:55vh;}
  .breadcrumb{left:24px;top:90px;}
  .service-row{grid-template-columns:1fr;padding:32px 24px;}
  .form-row{grid-template-columns:1fr;}
  .values-grid{grid-template-columns:1fr;}
  .industry-grid{grid-template-columns:1fr;}
  .blog-filter{gap:8px;}
  .posts-grid{grid-template-columns:1fr;}
  .contact-grid{padding:60px 24px;}
  #about{padding:60px 24px;}
  .about-stats{grid-template-columns:1fr 1fr;}
  .process-step{grid-template-columns:1fr;}
  section{padding:64px 24px;}
}
