
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;font-size:16px;}
img,svg{display:block;max-width:100%;}
button{font-family:inherit;border:none;background:none;cursor:pointer;}
a{text-decoration:none;color:inherit;}
ul{list-style:none;}
:root{
  --ink:#080810;--ink2:#0e0e1a;--ink3:#141424;
  --line:rgba(255,255,255,0.07);--line2:rgba(255,255,255,0.13);
  --white:#fff;--off:#eeeef5;--muted:#8a8aa8;--dim:#44445a;
  --v:#8b5cf6;--vl:#a78bfa;--vd:#6d28d9;
  --b:#38bdf8;--bl:#7dd3fc;
  --g:#34d399;--gold:#fbbf24;
  --grad:linear-gradient(135deg,#8b5cf6 0%,#38bdf8 100%);
  --grad2:linear-gradient(135deg,#6d28d9 0%,#0ea5e9 100%);
  --glow:0 0 40px rgba(139,92,246,0.4);
  --fh:'Cabinet Grotesk',sans-serif;
  --fb:'Instrument Sans',sans-serif;
  --fm:'JetBrains Mono',monospace;
  --nav:68px;--max:1120px;--pad:clamp(1.25rem,5vw,4rem);
  --r8:8px;--r12:12px;--r16:16px;--r24:24px;--r32:32px;--pill:999px;
}
body{font-family:var(--fb);background:var(--ink);color:var(--white);overflow-x:hidden;-webkit-font-smoothing:antialiased;}
::-webkit-scrollbar{width:3px;}
::-webkit-scrollbar-track{background:var(--ink);}
::-webkit-scrollbar-thumb{background:var(--v);border-radius:2px;}
::selection{background:rgba(139,92,246,0.35);color:#fff;}
.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--pad);}
.gt{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}

/* ── NAV ── */
#nav{position:fixed;top:0;left:0;right:0;z-index:900;height:var(--nav);display:flex;align-items:center;transition:background .3s,border-color .3s;}
#nav.stuck{background:rgba(8,8,16,0.9);backdrop-filter:blur(20px);border-bottom:1px solid var(--line);}
.nav-inner{width:100%;max-width:var(--max);margin:0 auto;padding:0 var(--pad);display:flex;align-items:center;justify-content:space-between;gap:1rem;}
.nav-logo{font-family:var(--fh);font-weight:900;font-size:1.3rem;letter-spacing:-0.04em;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.nav-links{display:flex;align-items:center;gap:2.2rem;}
.nav-links a{font-size:0.85rem;font-weight:500;color:var(--muted);transition:color .25s;}
.nav-links a:hover{color:var(--white);}
.nav-right{display:flex;align-items:center;gap:.75rem;flex-shrink:0;}
.nav-avail{font-family:var(--fm);font-size:0.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--g);border:1px solid rgba(52,211,153,.3);background:rgba(52,211,153,.06);padding:5px 12px;border-radius:var(--pill);display:flex;align-items:center;gap:6px;}
.avail-dot{width:5px;height:5px;border-radius:50%;background:var(--g);animation:pulse 2s infinite;}
.nav-btn{font-family:var(--fh);font-weight:700;font-size:.82rem;padding:9px 22px;border-radius:var(--pill);background:var(--grad);color:#fff;letter-spacing:-.01em;transition:opacity .2s,transform .2s,box-shadow .3s;}
.nav-btn:hover{opacity:.88;transform:translateY(-1px);box-shadow:var(--glow);}
#hbg{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;padding:7px;}
#hbg span{display:block;height:1.5px;background:var(--white);border-radius:2px;transition:all .3s;}
#hbg.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
#hbg.open span:nth-child(2){opacity:0;}
#hbg.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}
#mmenu{display:none;position:fixed;top:var(--nav);left:0;right:0;bottom:0;background:rgba(8,8,16,.97);backdrop-filter:blur(20px);z-index:800;flex-direction:column;align-items:center;justify-content:center;gap:2.5rem;}
#mmenu.open{display:flex;}
#mmenu a{font-family:var(--fh);font-size:clamp(1.8rem,7vw,2.5rem);font-weight:900;letter-spacing:-.04em;color:rgba(255,255,255,.7);transition:color .2s,opacity .2s;}
#mmenu a:hover{color:var(--vl);}
.mm-cta{font-family:var(--fh);font-weight:700;font-size:1rem;padding:14px 36px;border-radius:var(--pill);background:var(--grad);color:#fff;margin-top:.5rem;}

/* ── HERO ── */
#hero{min-height:100svh;display:flex;flex-direction:column;justify-content:center;padding:calc(var(--nav) + 3.5rem) var(--pad) 4rem;position:relative;overflow:hidden;}
.hbg{position:absolute;inset:0;pointer-events:none;}
.hblob{position:absolute;border-radius:50%;filter:blur(90px);opacity:.16;}
.hb1{width:min(560px,80vw);height:min(560px,80vw);background:var(--v);top:-8%;right:-12%;animation:drift1 14s ease-in-out infinite;}
.hb2{width:min(380px,60vw);height:min(380px,60vw);background:var(--b);bottom:5%;left:-8%;animation:drift2 18s ease-in-out infinite;}
.hb3{width:min(260px,50vw);height:min(260px,50vw);background:#ec4899;opacity:.07;top:40%;left:32%;animation:drift3 22s ease-in-out infinite;}
.hgrid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.022) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.022) 1px,transparent 1px);background-size:80px 80px;mask-image:radial-gradient(ellipse 70% 70% at 50% 50%,black 20%,transparent 80%);}
.hcontent{position:relative;z-index:2;max-width:var(--max);margin:0 auto;width:100%;}
.hkicker{display:inline-flex;align-items:center;gap:8px;font-family:var(--fm);font-size:.7rem;color:var(--vl);letter-spacing:.12em;text-transform:uppercase;margin-bottom:1.75rem;opacity:0;animation:up .7s .1s forwards;}
.hkicker-line{width:26px;height:1px;background:var(--vl);}
.hh1{font-family:var(--fh);font-size:clamp(2.8rem,8vw,7.5rem);font-weight:900;line-height:.96;letter-spacing:-.04em;margin-bottom:1.75rem;}
.hh1 .row{display:block;overflow:hidden;}
.hh1 .row span{display:block;opacity:0;transform:translateY(60px);animation:rowup .9s cubic-bezier(.16,1,.3,1) forwards;}
.hh1 .row:nth-child(1) span{animation-delay:.2s;}
.hh1 .row:nth-child(2) span{animation-delay:.32s;}
.hh1 .row:nth-child(3) span{animation-delay:.44s;}
.hdesc{font-size:clamp(.9rem,2vw,1.1rem);color:var(--muted);line-height:1.8;max-width:500px;margin-bottom:2.25rem;opacity:0;animation:up .7s .6s forwards;}
.hctas{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;margin-bottom:3.5rem;opacity:0;animation:up .7s .72s forwards;}
.btn-p{font-family:var(--fh);font-weight:700;font-size:.95rem;padding:14px 28px;border-radius:var(--pill);background:var(--grad);color:#fff;letter-spacing:-.01em;display:inline-flex;align-items:center;gap:8px;transition:transform .25s,box-shadow .3s,opacity .2s;position:relative;overflow:hidden;}
.btn-p::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,.12);transform:translateX(-110%) skewX(-12deg);transition:transform .5s;}
.btn-p:hover::after{transform:translateX(110%) skewX(-12deg);}
.btn-p:hover{transform:translateY(-2px);box-shadow:0 12px 40px rgba(139,92,246,.45);}
.btn-o{font-family:var(--fh);font-weight:600;font-size:.95rem;padding:13px 26px;border-radius:var(--pill);border:1px solid var(--line2);color:var(--off);display:inline-flex;align-items:center;gap:8px;transition:all .25s;}
.btn-o:hover{border-color:rgba(139,92,246,.5);background:rgba(139,92,246,.08);color:#fff;transform:translateY(-2px);}
.hstats{display:flex;flex-wrap:wrap;gap:1px;border:1px solid var(--line);border-radius:var(--r16);overflow:hidden;width:fit-content;opacity:0;animation:up .7s .88s forwards;}
.hs{padding:1rem 1.75rem;background:rgba(255,255,255,.025);border-right:1px solid var(--line);transition:background .25s;}
.hs:last-child{border-right:none;}
.hs:hover{background:rgba(139,92,246,.07);}
.hs-n{font-family:var(--fh);font-size:1.7rem;font-weight:900;letter-spacing:-.04em;line-height:1;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.hs-l{font-size:.7rem;color:var(--dim);margin-top:3px;white-space:nowrap;}

/* ── MARQUEE ── */
.mq{padding:2.25rem 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:rgba(255,255,255,.015);overflow:hidden;}
.mq-t{display:flex;gap:4rem;width:max-content;animation:mq 30s linear infinite;}
.mq-i{font-family:var(--fm);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--dim);white-space:nowrap;display:flex;align-items:center;gap:.7rem;}
.mq-i b{color:var(--muted);font-weight:400;}
.mqd{width:3px;height:3px;border-radius:50%;background:var(--v);}

/* ── SECTION COMMON ── */
.sec{padding:clamp(4.5rem,9vw,8rem) 0;}
.stag{display:inline-flex;align-items:center;gap:8px;font-family:var(--fm);font-size:.68rem;color:var(--vl);letter-spacing:.12em;text-transform:uppercase;margin-bottom:1.1rem;}
.stag::before{content:'';width:18px;height:1px;background:var(--vl);}
.sh2{font-family:var(--fh);font-size:clamp(1.9rem,4.5vw,3.5rem);font-weight:900;letter-spacing:-.04em;line-height:1.05;margin-bottom:.9rem;}
.slead{font-size:clamp(.88rem,2vw,1.02rem);color:var(--muted);line-height:1.8;max-width:460px;}

/* ── WHY ── */
#why{background:var(--ink2);}
.wcards{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid var(--line);border-radius:var(--r24);overflow:hidden;margin-top:3.5rem;}
.wc{padding:2.5rem;background:var(--ink2);position:relative;overflow:hidden;transition:background .4s;}
.wc::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% -20%,var(--wglow,rgba(139,92,246,.15)) 0%,transparent 65%);opacity:0;transition:opacity .5s;}
.wc:hover::before{opacity:1;}
.wc:hover{background:rgba(255,255,255,.02);}
.wc+.wc{border-left:1px solid var(--line);}
.wci{width:52px;height:52px;border-radius:var(--r12);border:1px solid var(--line2);display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:1.5rem;position:relative;z-index:1;transition:transform .4s,border-color .4s;}
.wc:hover .wci{transform:scale(1.1) rotate(-6deg);}
.wc1{--wglow:rgba(139,92,246,.18);}
.wc2{--wglow:rgba(56,189,248,.14);}
.wc3{--wglow:rgba(52,211,153,.12);}
.wc1 .wci{border-color:rgba(139,92,246,.3);}
.wc2 .wci{border-color:rgba(56,189,248,.25);}
.wc3 .wci{border-color:rgba(52,211,153,.25);}
.wc h3{font-family:var(--fh);font-size:1.2rem;font-weight:800;letter-spacing:-.03em;margin-bottom:.7rem;position:relative;z-index:1;}
.wc p{font-size:.87rem;color:var(--muted);line-height:1.75;position:relative;z-index:1;}
.wcs{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--line);position:relative;z-index:1;}
.wcs-n{font-family:var(--fh);font-size:1.9rem;font-weight:900;letter-spacing:-.04em;line-height:1;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.wcs-l{font-size:.7rem;color:var(--dim);margin-top:4px;letter-spacing:.04em;text-transform:uppercase;}

/* ── SERVICES ── */
#services{background:var(--ink);}
.sg{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:260px;gap:12px;margin-top:3.5rem;}
.si{border:1px solid var(--line);border-radius:var(--r16);background:var(--ink2);padding:2rem;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;transition:border-color .3s,transform .3s;cursor:default;}
.si:hover{border-color:var(--line2);transform:translateY(-3px);}
.si::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--grad);transform:scaleX(0);transform-origin:left;transition:transform .4s;}
.si:hover::after{transform:scaleX(1);}
.si1{grid-column:span 7;}
.si2{grid-column:span 5;}
.si3,.si4,.si5{grid-column:span 4;}
.sinum{font-family:var(--fm);font-size:.63rem;color:var(--dim);letter-spacing:.1em;margin-bottom:auto;}
.siico{font-size:2.4rem;position:absolute;top:1.75rem;right:1.75rem;opacity:.55;transition:opacity .3s,transform .3s;}
.si:hover .siico{opacity:1;transform:scale(1.1);}
.si h3{font-family:var(--fh);font-weight:800;letter-spacing:-.03em;margin-bottom:.5rem;}
.si1 h3{font-size:1.55rem;}
.si2 h3,.si3 h3,.si4 h3,.si5 h3{font-size:1.05rem;}
.si p{font-size:.82rem;color:var(--muted);line-height:1.65;}
.sitags{display:flex;gap:6px;flex-wrap:wrap;margin-top:.9rem;}
.sitag{font-family:var(--fm);font-size:.6rem;padding:3px 9px;border-radius:var(--pill);border:1px solid var(--line2);color:var(--dim);}
.sibg{position:absolute;top:50%;right:-10px;transform:translateY(-50%);font-family:var(--fh);font-size:8rem;font-weight:900;color:rgba(255,255,255,.022);line-height:1;pointer-events:none;letter-spacing:-.06em;user-select:none;}

/* ── PROCESS ── */
#process{background:var(--ink2);}
.psteps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:3.5rem;position:relative;}
.psteps::before{content:'';position:absolute;top:27px;left:calc(12.5% + 14px);right:calc(12.5% + 14px);height:1px;background:linear-gradient(90deg,transparent,var(--line2),var(--line2),transparent);}
.psi{padding:0 1.5rem 0 0;}
.psn{width:54px;height:54px;border-radius:var(--r12);border:1px solid var(--line2);display:flex;align-items:center;justify-content:center;background:var(--ink2);position:relative;z-index:1;margin-bottom:1.5rem;transition:all .3s;}
.psi:hover .psn{background:var(--v);border-color:var(--v);box-shadow:var(--glow);}
.psnum{font-family:var(--fh);font-size:1rem;font-weight:900;color:var(--muted);transition:color .3s;}
.psi:hover .psnum{color:#fff;}
.psi h3{font-family:var(--fh);font-size:1rem;font-weight:800;letter-spacing:-.02em;margin-bottom:.45rem;}
.psi p{font-size:.82rem;color:var(--muted);line-height:1.65;}

/* ── PORTFOLIO ── */
/* #portfolio{background:var(--ink);}
.pgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:3.5rem;}
.pc{border-radius:var(--r16);overflow:hidden;border:1px solid var(--line);background:var(--ink2);position:relative;cursor:pointer;transition:border-color .3s,transform .35s;}
.pc:hover{border-color:var(--line2);transform:translateY(-4px);}
.pt{overflow:hidden;display:flex;align-items:center;justify-content:center;transition:transform .5s cubic-bezier(.2,0,0,1);}
.pc:hover .pt{transform:scale(1.03);}
.pt-in{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:.5rem;}
.pc.tall .pt{height:340px;}
.pt{height:240px;position:relative;}
.pov{position:absolute;inset:0;background:linear-gradient(to top,rgba(8,8,16,.95) 0%,rgba(8,8,16,.2) 60%,transparent 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:1.5rem;opacity:0;transition:opacity .35s;}
.pc:hover .pov{opacity:1;}
.pov-cat{font-family:var(--fm);font-size:.63rem;color:var(--vl);letter-spacing:.1em;text-transform:uppercase;margin-bottom:4px;}
.pov-title{font-family:var(--fh);font-size:1.2rem;font-weight:800;letter-spacing:-.03em;margin-bottom:.75rem;}
.pov-btn{display:inline-flex;align-items:center;gap:6px;font-family:var(--fh);font-size:.8rem;font-weight:700;background:var(--grad);padding:8px 18px;border-radius:var(--pill);color:#fff;width:fit-content;transition:transform .2s;}
.pov-btn:hover{transform:scale(1.04);}
.pmeta{padding:1.25rem 1.5rem;display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--line);}
.pcat{font-family:var(--fm);font-size:.63rem;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;}
.ptitle{font-family:var(--fh);font-size:.9rem;font-weight:700;letter-spacing:-.02em;margin-top:2px;}
.pyr{font-family:var(--fm);font-size:.67rem;color:var(--dim);} */

/* ── TESTIMONIALS ── */
#testi{background:var(--ink2);}
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:3.5rem;}
.tc{border:1px solid var(--line);border-radius:var(--r16);padding:2rem;background:var(--ink);transition:border-color .3s,transform .3s;}
.tc:hover{border-color:var(--line2);transform:translateY(-4px);}
.tcq{font-size:2.5rem;line-height:1;color:var(--v);opacity:.35;margin-bottom:.5rem;font-family:Georgia,serif;}
.tcs{display:flex;gap:3px;margin-bottom:.9rem;}
.tcs span{color:var(--gold);font-size:.82rem;}
.tct{font-size:.87rem;color:var(--muted);line-height:1.8;margin-bottom:1.75rem;font-style:italic;}
.tca{display:flex;align-items:center;gap:.75rem;}
.tcav{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:.82rem;font-weight:800;flex-shrink:0;color:#fff;}
.av1{background:linear-gradient(135deg,#7c3aed,#a78bfa);}
.av2{background:linear-gradient(135deg,#0284c7,#38bdf8);}
.av3{background:linear-gradient(135deg,#059669,#34d399);}
.tcn{font-family:var(--fh);font-size:.9rem;font-weight:800;letter-spacing:-.02em;}
.tcr{font-size:.73rem;color:var(--dim);margin-top:1px;}

/* ── CTA ── */
#cta{background:var(--ink);padding:clamp(3.5rem,7vw,6rem) 0;}
.ctabox{border-radius:var(--r32);background:var(--ink2);border:1px solid var(--line);padding:clamp(3rem,6vw,5rem) clamp(2rem,5vw,4rem);text-align:center;position:relative;overflow:hidden;}
.ctabox::before{content:'';position:absolute;width:500px;height:500px;border-radius:50%;background:var(--v);filter:blur(120px);opacity:.08;top:-200px;left:50%;transform:translateX(-50%);pointer-events:none;}
.ctabox h2{font-family:var(--fh);font-size:clamp(1.9rem,4.5vw,3.4rem);font-weight:900;letter-spacing:-.04em;line-height:1.05;margin-bottom:.9rem;position:relative;z-index:1;}
.ctabox p{color:var(--muted);font-size:1rem;margin-bottom:2.25rem;position:relative;z-index:1;}
.ctaacts{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;position:relative;z-index:1;}

/* ── CONTACT ── */
#contact{background:var(--ink2);}
.clayout{display:grid;grid-template-columns:1fr 1.5fr;gap:clamp(2rem,5vw,5rem);align-items:start;margin-top:3.5rem;}
.cii{display:flex;align-items:flex-start;gap:1rem;padding:1.2rem 0;border-bottom:1px solid var(--line);}
.cii:first-child{border-top:1px solid var(--line);}
.ciico{width:40px;height:40px;border-radius:var(--r8);border:1px solid var(--line2);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0;margin-top:2px;transition:all .3s;}
.cii:hover .ciico{background:var(--v);border-color:var(--v);}
.cil{font-family:var(--fm);font-size:.63rem;color:var(--dim);letter-spacing:.1em;text-transform:uppercase;margin-bottom:3px;}
.civ{font-size:.9rem;color:var(--off);font-weight:500;}
.wabtn{display:inline-flex;align-items:center;gap:8px;font-family:var(--fh);font-size:.9rem;font-weight:700;background:linear-gradient(135deg,#25d366,#128c7e);padding:12px 24px;border-radius:var(--pill);color:#fff;margin-top:1.75rem;transition:transform .25s,box-shadow .3s;}
.wabtn:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(37,211,102,.35);}
.fcard{border:1px solid var(--line);border-radius:var(--r24);background:var(--ink);padding:clamp(1.5rem,3vw,2.5rem);}
.f2{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.fg{margin-bottom:13px;}
.fl{display:block;font-family:var(--fm);font-size:.63rem;letter-spacing:.1em;text-transform:uppercase;color:var(--dim);margin-bottom:7px;}
.fi,.fta,.fsel{width:100%;background:var(--ink2);border:1px solid var(--line);border-radius:var(--r8);padding:11px 14px;color:var(--white);font-family:var(--fb);font-size:.88rem;outline:none;transition:border-color .25s,box-shadow .25s;appearance:none;resize:vertical;}
.fi::placeholder,.fta::placeholder{color:var(--dim);}
.fi:focus,.fta:focus,.fsel:focus{border-color:rgba(139,92,246,.5);box-shadow:0 0 0 3px rgba(139,92,246,.1);}
.fsel{cursor:pointer;}
.fsel option{background:var(--ink2);}
.fsub{width:100%;font-family:var(--fh);font-size:.95rem;font-weight:800;padding:14px;border-radius:var(--r8);background:var(--grad);color:#fff;letter-spacing:-.01em;transition:opacity .2s,transform .2s,box-shadow .3s;margin-top:4px;}
.fsub:hover{opacity:.9;transform:translateY(-2px);box-shadow:var(--glow);}

/* ── FOOTER ── */
/* ===== PREMIUM FOOTER OVERRIDE ===== */

footer {
  background: linear-gradient(180deg, #0b0b16 0%, #080810 100%);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  margin-top: 2rem;
}

/* Top Footer */
.ftop {
  max-width: var(--max);
  margin: 0 auto;
  padding: clamp(3.5rem, 6vw, 5rem) var(--pad) 2.5rem;
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: clamp(2rem, 4vw, 4rem);
  align-items: start;
}

/* Logo */
.flogo {
  display: inline-block;
  margin-bottom: 1rem;
}

.flogo img {
  height: 95px;
  width: auto;
  display: block;
  object-fit: contain;
}

/* Description */
.fdesc {
  font-size: 0.92rem;
  color: var(--muted);
  line-height: 1.8;
  max-width: 350px;
}

/* Footer Headings */
.fcol h4 {
  font-family: var(--fm);
  font-size: 0.72rem;
  font-weight: 500;
  color: var(--vl);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin-bottom: 1.4rem;
}

/* Links */
.fcol li {
  margin-bottom: 0.85rem;
}

.fcol a {
  font-size: 0.92rem;
  color: var(--muted);
  transition: all 0.25s ease;
}

.fcol a:hover {
  color: var(--white);
  transform: translateX(4px);
  display: inline-block;
}

/* Bottom Footer */
.fbot {
  max-width: var(--max);
  margin: 0 auto;
  padding: 1.4rem var(--pad);
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  display: flex;
  justify-content: center;
  align-items: center;
}

.fcopy {
  font-size: 0.85rem;
  color: var(--dim);
  letter-spacing: 0.02em;
  text-align: center;
}

/* Tablet */
@media (max-width: 1024px) {
  .ftop {
    grid-template-columns: 1fr 1fr;
    gap: 2.5rem;
  }

  .flogo img {
    height: 80px;
  }
}

/* Mobile */
@media (max-width: 640px) {
  .ftop {
    grid-template-columns: 1fr;
    gap: 2rem;
    text-align: left;
    padding: 3rem 1.25rem 2rem;
  }

  .flogo img {
    height: 70px;
  }

  .fdesc {
    max-width: 100%;
  }

  .fbot {
    padding: 1.2rem;
    text-align: center;
  }

  .fcopy {
    font-size: 0.8rem;
  }
}

/* ── REVEAL ── */
[data-r]{opacity:0;transform:translateY(28px);transition:opacity .75s cubic-bezier(.16,1,.3,1),transform .75s cubic-bezier(.16,1,.3,1);}
[data-r].vis{opacity:1;transform:none;}
[data-r][data-d="1"]{transition-delay:.1s;}
[data-r][data-d="2"]{transition-delay:.2s;}
[data-r][data-d="3"]{transition-delay:.3s;}
[data-r][data-d="4"]{transition-delay:.4s;}

/* ── KEYFRAMES ── */
@keyframes up{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:none;}}
@keyframes rowup{from{opacity:0;transform:translateY(60px);}to{opacity:1;transform:none;}}
@keyframes drift1{0%,100%{transform:translate(0,0);}33%{transform:translate(-4%,5%);}66%{transform:translate(3%,-3%);}}
@keyframes drift2{0%,100%{transform:translate(0,0);}40%{transform:translate(5%,-4%);}75%{transform:translate(-3%,3%);}}
@keyframes drift3{0%,100%{transform:translate(0,0);}50%{transform:translate(4%,5%);}}
@keyframes mq{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:.4;}}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .nav-links{display:none;}
  #hbg{display:flex;}
  .nav-avail{display:none;}
  .wcards{grid-template-columns:1fr;}
  .wc+.wc{border-left:none;border-top:1px solid var(--line);}
  .sg{grid-template-columns:repeat(2,1fr);grid-auto-rows:auto;}
  .si1,.si2,.si3,.si4,.si5{grid-column:span 1;}
  .si1{grid-column:span 2;}
  .psteps{grid-template-columns:repeat(2,1fr);gap:2.5rem;}
  .psteps::before{display:none;}
  .tgrid{grid-template-columns:1fr 1fr;}
  .clayout{grid-template-columns:1fr;}
  .ftop{grid-template-columns:1fr 1fr;}
}
@media (max-width: 640px) {
  :root {
    --nav: 60px;
  }

  #hero {
    padding-top: calc(var(--nav) + 2.5rem);
  }

  /* HERO STATS - Better mobile design */
  .hstats {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    width: 100%;
    border: none;
    background: transparent;
    border-radius: 0;
    margin-top: 2rem;
  }
    .nav-btn {
    display: none;
  }

  .hs {
    padding: 1rem;
    border: 1px solid var(--line);
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.04);
    text-align: center;
    border-right: none;
    border-bottom: none;
  }

  .hs:last-child {
    border-bottom: none;
  }

  .hs-n {
    font-size: 1.4rem;
  }

  .hs-l {
    font-size: 0.7rem;
    white-space: normal;
    line-height: 1.4;
  }

  /* BUTTONS */
  .hctas {
    flex-direction: column;
  }

  .btn-p,
  .btn-o {
    width: 100%;
    justify-content: center;
  }

  /* OTHER SECTIONS */
  .wcards {
    border-radius: var(--r16);
  }

  .sg {
    display: flex;
    flex-direction: column;
    gap: 10px;
  }

  .sibg {
    display: none;
  }

  .psteps {
    grid-template-columns: 1fr;
    gap: 2rem;
  }

  .pgrid {
    grid-template-columns: 1fr;
  }

  .pc.tall .pt {
    height: 240px;
  }

  .tgrid {
    grid-template-columns: 1fr;
  }

  .ctaacts {
    flex-direction: column;
    align-items: center;
  }

  .f2 {
    grid-template-columns: 1fr;
  }

  .ftop {
    grid-template-columns: 1fr;
    gap: 2rem;
  }

  .fbot {
    flex-direction: column;
    text-align: center;
  }
}
@media(max-width:380px){
  .hh1{font-size:clamp(2.4rem,12vw,3rem);}
}

.wa-wrapper {
  position: fixed;
  bottom: 40px;
  right: 45px;
  z-index: 9999;
}

.wa-float {
  width: 58px;
  height: 58px;
  background: #25d366;
  color: white;
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 30px;
  box-shadow: 0 8px 25px rgba(37, 211, 102, 0.4);
  text-decoration: none;
  transition: all 0.3s ease;
  animation: pulseWA 2s infinite;
}

.wa-float:hover {
  transform: scale(1.1);
  background: #1ebe5d;
}

.wa-close {
  position: absolute;
  top: -8px;
  right: -8px;
  width: 22px;
  height: 22px;
  border: none;
  border-radius: 50%;
  background: #111;
  color: white;
  font-size: 12px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10000;
}



@keyframes pulseWA {
  0% {
    box-shadow: 0 0 0 0 rgba(37, 211, 102, 0.6);
  }
  70% {
    box-shadow: 0 0 0 18px rgba(37, 211, 102, 0);
  }
  100% {
    box-shadow: 0 0 0 0 rgba(37, 211, 102, 0);
  }
}
.nav-logo img {
  height: 75px;
  width: auto;
  display: block;
  margin-top: 3px;
}

/* Tablet */
@media (max-width: 1024px) {
  .nav-logo img {
    height: 70px;
    margin-top: 15px;
  }
}
@media (max-width: 640px) {
  #nav {
    padding: 0;
  }

  .nav-inner {
    padding: 0 12px !important;
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
  }

  .nav-logo {
    margin: 0 !important;
    padding: 0 !important;
    display: flex;
    align-items: center;
    justify-content: flex-start;
  }

  .nav-logo img {
    max-height: 60px;   /* bigger logo */
    max-width: 240px;
    display: block;
    margin-top: 10px;
  }

  .nav-btn {
    display: none;
  }
}

.flogo img {
  height: 75px;
  width: auto;
  display: block;
}

/* Tablet */
@media (max-width: 1024px) {
  .flogo img {
    height: 60px;
  }
}

/* Mobile */
@media (max-width: 640px) {
  .flogo img {
    height: 55px;
  }
}

.flogo img {
  height: 70px;
}
/* ===== PORTFOLIO SAME AS SCREENSHOT ===== */
/* ===== FINAL PORTFOLIO PERFECT FIX ===== */
/* ===== PORTFOLIO: LESS IMAGE CROP / MORE WIDTH ===== */

#portfolio .wrap {
  max-width: 1500px; /* wider section */
}

.portfolio-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 3.5rem;
}

/* Card */
.project-card {
  background: #05050c;
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 12px;
  overflow: hidden;
}

/* Main fix: lower height = more image width visible */
.project-card img {
  width: 100%;
  height: 170px;               /* lower height shows more full width */
  object-fit: cover;
  object-position: center top;
  display: block;
}

/* Content */
.project-content {
  padding: 1.3rem;
}

/* Tablet */
@media (max-width: 1024px) {
  .portfolio-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .project-card img {
    height: 180px;
  }
}

/* Mobile */
@media (max-width: 768px) {
  .portfolio-grid {
    grid-template-columns: 1fr;
  }

  .project-card img {
    height: auto;
    max-height: 260px;
    object-fit: contain;
    background: #111;
  }
}