:root {
    --bg:      #06080a;
    --bg1:     #0a0e12;
    --bg2:     #0e1419;
    --bg3:     #131b22;
    --lime:    #c6ff00;
    --cyan:    #00e5ff;
    --white:   #f0f4f8;
    --grey:    #4a6070;
    --border:  rgba(198,255,0,0.1);
    --border2: rgba(255,255,255,0.06);
    --r:       16px;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{
    background:var(--bg);
    color:var(--white);
    font-family:'Outfit',sans-serif;
    font-weight:400;
    line-height:1.7;
    overflow-x:hidden;
    cursor:none;
}

/* ── CUSTOM CURSOR ── */
#cur,#cur2{position:fixed;border-radius:50%;pointer-events:none;z-index:9999;transition:transform .15s}
#cur{width:10px;height:10px;background:var(--lime);transform:translate(-50%,-50%)}
#cur2{width:36px;height:36px;border:1.5px solid rgba(198,255,0,.4);transform:translate(-50%,-50%);transition:width .25s,height .25s,border-color .25s}
body:has(a:hover) #cur2,body:has(button:hover) #cur2{width:54px;height:54px;border-color:var(--lime)}

/* ── NOISE ── */
body::after{
    content:'';position:fixed;inset:0;z-index:1;pointer-events:none;
    background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");
    opacity:.6;
}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--lime);border-radius:2px}

/* ══════════════════════════════
   HEADER
══════════════════════════════ */
header{
    position:fixed;top:0;left:0;right:0;z-index:200;
    height:64px;padding:0 4%;
    display:flex;align-items:center;justify-content:space-between;
    background:rgba(6,8,10,.75);
    backdrop-filter:blur(24px);
    border-bottom:1px solid var(--border2);
    transition:background .3s;
}
header.solid{background:rgba(6,8,10,.97)}
.logo{
    font-family:'Bebas Neue',sans-serif;
    font-size:1.7rem;letter-spacing:2px;
    color:var(--white);text-decoration:none;
    display:flex;align-items:center;gap:10px;
    position:relative;z-index:201;
}
.logo-mark{
    width:28px;height:28px;border-radius:7px;
    background:var(--lime);
    display:flex;align-items:center;justify-content:center;
}
.logo-mark svg{width:16px;height:16px}
.logo em{color:var(--lime);font-style:normal}
.nav-center{display:flex;gap:2px}
.nav-center a{
    color:var(--grey);text-decoration:none;
    font-size:.82rem;font-weight:500;letter-spacing:.4px;
    padding:7px 15px;border-radius:8px;
    transition:all .2s;
}
.nav-center a:hover{color:var(--white);background:rgba(255,255,255,.05)}
.nav-right{display:flex;align-items:center;gap:10px}
.social-row{display:flex;gap:6px}
.soc{
    width:32px;height:32px;border-radius:8px;
    background:rgba(255,255,255,.04);
    border:1px solid var(--border2);
    display:flex;align-items:center;justify-content:center;
    color:var(--grey);text-decoration:none;font-size:14px;
    transition:all .22s;
}
.soc:hover{border-color:var(--lime);color:var(--lime);background:rgba(198,255,0,.07);transform:translateY(-2px)}
.lang-pill{
    display:flex;align-items:center;
    background:rgba(255,255,255,.04);
    border:1px solid var(--border2);
    border-radius:20px;padding:3px;
    margin-left:4px;
}
.lb{
    background:none;border:none;
    color:var(--grey);font-family:'Outfit',sans-serif;
    font-size:.72rem;font-weight:700;letter-spacing:.8px;
    padding:4px 11px;border-radius:16px;cursor:none;
    transition:all .2s;
}
.lb.on{background:var(--lime);color:#000}
.cta-btn{
    background:var(--lime);color:#000;
    border:none;padding:9px 20px;border-radius:10px;
    font-family:'Outfit',sans-serif;font-size:.8rem;font-weight:700;
    letter-spacing:.3px;cursor:none;
    transition:all .22s;white-space:nowrap;
    text-decoration:none;
}
.cta-btn:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(198,255,0,.3)}

/* ══════════════════════════════
   HAMBURGER BUTTON
══════════════════════════════ */
.hamburger{
    display:none;
    flex-direction:column;
    justify-content:center;
    align-items:center;
    width:44px;height:44px;
    background:rgba(255,255,255,.04);
    border:1px solid var(--border2);
    border-radius:12px;
    cursor:none;
    position:relative;z-index:201;
    transition:border-color .25s, background .25s;
    flex-shrink:0;
}
.hamburger:hover{border-color:rgba(198,255,0,.35);background:rgba(198,255,0,.06)}
.hamburger.open{border-color:rgba(198,255,0,.4);background:rgba(198,255,0,.08)}
.hb-bar{
    width:20px;height:1.5px;
    background:var(--white);
    border-radius:2px;
    transition:transform .35s cubic-bezier(.23,1,.32,1), opacity .25s, width .3s;
    transform-origin:center;
}
.hb-bar:nth-child(1){margin-bottom:5px}
.hb-bar:nth-child(3){margin-top:5px;width:13px}
.hamburger.open .hb-bar:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.hamburger.open .hb-bar:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open .hb-bar:nth-child(3){width:20px;transform:translateY(-6.5px) rotate(-45deg)}

/* ══════════════════════════════
   MOBILE NAV DRAWER
══════════════════════════════ */
.mobile-nav{
    display:none;
    position:fixed;
    top:0;left:0;right:0;bottom:0;
    z-index:190;
    background:var(--bg);
    pointer-events:none;
    opacity:0;
    transform:translateY(-12px);
    transition:opacity .38s cubic-bezier(.23,1,.32,1), transform .38s cubic-bezier(.23,1,.32,1);
}
.mobile-nav::before{
    content:'';position:absolute;inset:0;
    background-image:
        linear-gradient(rgba(198,255,0,.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(198,255,0,.03) 1px, transparent 1px);
    background-size:60px 60px;
    pointer-events:none;
}
.mobile-nav::after{
    content:'';position:absolute;
    bottom:0;left:0;right:0;height:1px;
    background:linear-gradient(90deg,transparent,var(--lime),transparent);
    opacity:.2;
}
.mobile-nav.open{
    opacity:1;
    transform:translateY(0);
    pointer-events:all;
}
.mn-inner{
    height:100%;
    display:flex;
    flex-direction:column;
    padding:88px 8% 40px;
}
.mn-links{
    display:flex;
    flex-direction:column;
    gap:4px;
    flex:1;
}
.mn-link{
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:16px 0;
    border-bottom:1px solid var(--border2);
    text-decoration:none;
    color:var(--white);
    font-family:'Bebas Neue',sans-serif;
    font-size:clamp(2rem,8vw,3rem);
    letter-spacing:2px;
    opacity:0;
    transform:translateY(22px);
    transition:
        color .22s,
        opacity .4s cubic-bezier(.23,1,.32,1),
        transform .4s cubic-bezier(.23,1,.32,1);
}
.mn-link:first-child{border-top:1px solid var(--border2)}
.mn-link:hover{color:var(--lime)}
.mn-link:hover .mn-link-arrow{border-color:var(--lime);color:var(--lime);transform:rotate(45deg)}
.mn-link-num{
    font-size:.65rem;font-family:'Outfit',sans-serif;
    color:var(--grey);letter-spacing:1px;
    align-self:flex-start;margin-top:8px;
}
.mn-link-arrow{
    width:36px;height:36px;border-radius:50%;
    border:1px solid var(--border2);
    display:flex;align-items:center;justify-content:center;
    color:var(--grey);font-size:16px;
    transition:all .25s;
    flex-shrink:0;
}
.mobile-nav.open .mn-link{opacity:1;transform:translateY(0)}
.mobile-nav.open .mn-link:nth-child(1){transition-delay:.07s}
.mobile-nav.open .mn-link:nth-child(2){transition-delay:.12s}
.mobile-nav.open .mn-link:nth-child(3){transition-delay:.17s}
.mobile-nav.open .mn-link:nth-child(4){transition-delay:.22s}
.mobile-nav.open .mn-link:nth-child(5){transition-delay:.27s}
.mn-foot{
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding-top:28px;
    opacity:0;
    transform:translateY(12px);
    transition:opacity .4s .32s, transform .4s .32s;
}
.mobile-nav.open .mn-foot{opacity:1;transform:translateY(0)}
.mn-cta{
    display:inline-flex;align-items:center;gap:8px;
    background:var(--lime);color:#000;
    padding:13px 26px;border-radius:12px;
    font-weight:700;font-size:.88rem;text-decoration:none;
    transition:all .25s;
    box-shadow:0 0 30px rgba(198,255,0,.2);
}
.mn-cta:hover{transform:translateY(-2px);box-shadow:0 0 50px rgba(198,255,0,.4)}
.mn-lang{
    display:flex;
    background:rgba(255,255,255,.04);
    border:1px solid var(--border2);
    border-radius:20px;padding:3px;
}

/* ══════════════════════════════
   HERO
══════════════════════════════ */
#hero{
    min-height:100vh;
    display:flex;flex-direction:column;
    justify-content:center;
    padding:100px 4% 60px;
    position:relative;overflow:hidden;
}
.hero-orb{
    position:absolute;border-radius:50%;filter:blur(120px);pointer-events:none;
}
.orb1{width:700px;height:700px;background:rgba(198,255,0,.06);top:-200px;right:-100px}
.orb2{width:500px;height:500px;background:rgba(0,229,255,.04);bottom:-100px;left:-100px}
.hero-grid-bg{
    position:absolute;inset:0;
    background-image:
        linear-gradient(rgba(198,255,0,.035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(198,255,0,.035) 1px, transparent 1px);
    background-size:80px 80px;
    animation:gridMove 20s linear infinite;
}
@keyframes gridMove{to{background-position:80px 80px}}
.hero-inner{position:relative;z-index:2;max-width:1100px}
.hero-eyebrow{
    display:inline-flex;align-items:center;gap:10px;
    border:1px solid var(--border);
    padding:7px 16px;border-radius:24px;
    font-size:.72rem;font-weight:700;letter-spacing:1.5px;
    text-transform:uppercase;color:var(--lime);
    margin-bottom:32px;
    animation:fadeUp .7s ease both;
}
.hero-eyebrow-dot{
    width:7px;height:7px;border-radius:50%;background:var(--lime);
    animation:blink 1.8s ease-in-out infinite;
}
@keyframes blink{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.6)}}
h1.display{
    font-family:'Bebas Neue',sans-serif;
    font-size:clamp(4rem,10vw,9.5rem);
    line-height:.92;letter-spacing:1px;
    margin-bottom:30px;
    animation:fadeUp .7s ease .1s both;
}
h1.display .lime{color:var(--lime)}
h1.display .stroke{
    -webkit-text-stroke:2px rgba(255,255,255,.25);
    color:transparent;
}
.hero-desc{
    max-width:520px;color:var(--grey);
    font-size:1rem;font-weight:300;line-height:1.85;
    margin-bottom:42px;
    animation:fadeUp .7s ease .2s both;
}
.hero-actions{
    display:flex;gap:14px;flex-wrap:wrap;
    animation:fadeUp .7s ease .3s both;
}
.btn-lime{
    display:inline-flex;align-items:center;gap:9px;
    background:var(--lime);color:#000;
    padding:14px 30px;border-radius:12px;
    font-weight:700;font-size:.9rem;text-decoration:none;
    transition:all .25s;box-shadow:0 0 40px rgba(198,255,0,.25);
    letter-spacing:.3px;
}
.btn-lime:hover{transform:translateY(-3px);box-shadow:0 0 60px rgba(198,255,0,.45)}
.btn-ghost{
    display:inline-flex;align-items:center;gap:9px;
    border:1px solid rgba(255,255,255,.12);color:var(--white);
    padding:14px 30px;border-radius:12px;
    font-weight:500;font-size:.9rem;text-decoration:none;
    transition:all .25s;background:rgba(255,255,255,.03);
}
.btn-ghost:hover{border-color:rgba(198,255,0,.4);color:var(--lime);background:rgba(198,255,0,.05)}
.hero-numbers{
    display:flex;gap:60px;
    margin-top:72px;padding-top:40px;
    border-top:1px solid var(--border2);
    animation:fadeUp .7s ease .4s both;
}
.hn-val{
    font-family:'Bebas Neue',sans-serif;
    font-size:3rem;letter-spacing:1px;color:var(--lime);
    line-height:1;
}
.hn-lbl{font-size:.78rem;color:var(--grey);margin-top:6px;letter-spacing:.3px}
.hero-scroll{
    position:absolute;bottom:32px;right:4%;
    display:flex;align-items:center;gap:10px;
    font-size:.72rem;color:var(--grey);letter-spacing:1px;text-transform:uppercase;
    animation:fadeUp .7s ease .5s both;
    z-index:2;
}
.scroll-line{
    width:40px;height:1px;background:var(--grey);
    position:relative;overflow:hidden;
}
.scroll-line::after{
    content:'';position:absolute;top:0;left:-100%;
    width:100%;height:100%;background:var(--lime);
    animation:scanLine 2s ease-in-out infinite;
}
@keyframes scanLine{to{left:100%}}

/* ══════════════════════════════
   SECTION COMMONS
══════════════════════════════ */
section{padding:110px 4%;position:relative}
.s-tag{
    font-size:.7rem;font-weight:700;letter-spacing:2.5px;
    text-transform:uppercase;color:var(--lime);
    display:flex;align-items:center;gap:10px;margin-bottom:14px;
}
.s-tag::before{content:'';width:28px;height:1.5px;background:var(--lime)}
h2.sh{
    font-family:'Bebas Neue',sans-serif;
    font-size:clamp(2.2rem,4.5vw,3.8rem);
    letter-spacing:1px;line-height:1.05;
    margin-bottom:12px;
}
h2.sh em{color:var(--lime);font-style:normal}
.s-sub{color:var(--grey);font-size:.95rem;font-weight:300;max-width:500px}
.rv{opacity:0;transform:translateY(36px);transition:opacity .7s ease,transform .7s ease}
.rv.in{opacity:1;transform:none}
.rv.d1{transition-delay:.1s}.rv.d2{transition-delay:.2s}.rv.d3{transition-delay:.3s}

/* ══════════════════════════════
   ABOUT
══════════════════════════════ */
#about{background:var(--bg1)}
.about-wrap{
    display:grid;grid-template-columns:1fr 1fr;
    gap:72px;align-items:center;margin-top:60px;
}
.about-visual{
    position:relative;height:420px;
    border-radius:24px;overflow:hidden;
    border:1px solid var(--border);
}
.about-vis-bg{
    position:absolute;inset:0;
    background:linear-gradient(135deg,rgba(198,255,0,.06) 0%,rgba(0,229,255,.04) 100%);
}
.terminal{
    position:absolute;top:50%;left:50%;
    transform:translate(-50%,-50%);
    width:86%;
    background:rgba(6,8,10,.9);
    border:1px solid rgba(198,255,0,.15);
    border-radius:14px;padding:20px 22px;
    font-family:'Courier New',monospace;font-size:.76rem;
    backdrop-filter:blur(20px);
}
.term-bar{display:flex;align-items:center;gap:7px;margin-bottom:16px}
.tb{width:11px;height:11px;border-radius:50%}
.term-line{margin:6px 0;display:flex;align-items:baseline;gap:6px}
.prompt{color:var(--lime);opacity:.7}
.kw{color:#79b8ff}.str{color:var(--lime)}.fn{color:#f97316}.cm{color:var(--grey)}
.cursor-blink{
    display:inline-block;width:7px;height:14px;
    background:var(--lime);margin-left:3px;
    animation:cur-blink 1.1s step-end infinite;
}
@keyframes cur-blink{0%,100%{opacity:1}50%{opacity:0}}
.about-text h3{
    font-family:'Bebas Neue',sans-serif;
    font-size:2rem;letter-spacing:1px;margin-bottom:16px;
}
.about-text p{color:var(--grey);font-weight:300;line-height:1.9;margin-bottom:14px;font-size:.95rem}
.about-text p strong{color:var(--white);font-weight:600}
.stack-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px}
.stk{
    background:rgba(255,255,255,.04);
    border:1px solid var(--border2);
    padding:6px 14px;border-radius:20px;
    font-size:.75rem;font-weight:600;color:var(--grey);
    letter-spacing:.3px;transition:all .2s;
}
.stk:hover{border-color:var(--lime);color:var(--lime)}

/* ══════════════════════════════
   SERVICES
══════════════════════════════ */
#services{background:var(--bg)}
.srv-grid{
    display:grid;grid-template-columns:repeat(3,1fr);
    gap:18px;margin-top:60px;
}
.srv{
    background:var(--bg2);
    border:1px solid var(--border2);
    border-radius:20px;padding:34px 28px;
    position:relative;overflow:hidden;
    transition:all .35s;cursor:none;
}
.srv::before{
    content:'';position:absolute;
    top:0;left:0;right:0;height:2px;
    background:linear-gradient(90deg,transparent,var(--lime),transparent);
    transform:scaleX(0);transition:transform .4s;
}
.srv:hover{border-color:rgba(198,255,0,.25);transform:translateY(-8px);box-shadow:0 24px 60px rgba(0,0,0,.4),0 0 40px rgba(198,255,0,.06)}
.srv:hover::before{transform:scaleX(1)}
.srv-ico{
    font-size:28px;margin-bottom:18px;
    display:flex;align-items:center;justify-content:center;
    width:52px;height:52px;border-radius:14px;
    background:rgba(198,255,0,.08);
    border:1px solid rgba(198,255,0,.15);
}
.srv h3{font-family:'Bebas Neue',sans-serif;font-size:1.3rem;letter-spacing:.5px;margin-bottom:10px;}
.srv p{color:var(--grey);font-size:.85rem;line-height:1.75;font-weight:300}
.srv-price{
    display:inline-flex;align-items:center;gap:6px;
    margin-top:18px;font-size:.75rem;font-weight:700;
    color:var(--lime);letter-spacing:.5px;
    background:rgba(198,255,0,.07);
    border:1px solid rgba(198,255,0,.15);
    padding:5px 12px;border-radius:20px;
}
.srv-arrow{
    position:absolute;bottom:28px;right:28px;
    width:32px;height:32px;border-radius:50%;
    background:rgba(255,255,255,.04);
    border:1px solid var(--border2);
    display:flex;align-items:center;justify-content:center;
    color:var(--grey);font-size:16px;
    transition:all .25s;
}
.srv:hover .srv-arrow{background:var(--lime);border-color:var(--lime);color:#000;transform:rotate(45deg)}

/* ══════════════════════════════
   PROJECTS
══════════════════════════════ */
#projects{background:var(--bg1)}
.proj-grid{
    display:grid;grid-template-columns:repeat(3,1fr);
    gap:18px;margin-top:60px;
}
.proj{
    border-radius:20px;overflow:hidden;
    border:1px solid var(--border2);
    background:var(--bg2);
    transition:all .35s;cursor:none;
}
.proj:hover{transform:translateY(-8px);border-color:rgba(198,255,0,.2);box-shadow:0 24px 60px rgba(0,0,0,.5)}
.proj-img{
    height:190px;position:relative;overflow:hidden;
    display:flex;align-items:center;justify-content:center;
}
/* image when provided */
.proj-img img.proj-cover{
    position:absolute;inset:0;
    width:100%;height:100%;
    object-fit:contain;object-position:center;
    padding:16px;
    transition:transform .5s ease;
    z-index:0;
}
.proj:hover .proj-img img.proj-cover{transform:scale(1.04)}
.proj-num{
    font-family:'Bebas Neue',sans-serif;
    font-size:5rem;color:rgba(255,255,255,.03);
    letter-spacing:-2px;user-select:none;transition:all .3s;
    position:relative;z-index:1;
}
/* when .proj-img contains an image, hide the number ghost */
.proj-img:has(img.proj-cover) .proj-num{display:none}
.proj:hover .proj-num{color:rgba(198,255,0,.06)}
.proj-overlay{
    position:absolute;inset:0;
    display:flex;align-items:center;justify-content:center;
    background:rgba(6,8,10,.7);
    opacity:0;transition:opacity .3s;
    backdrop-filter:blur(4px);
}
.proj:hover .proj-overlay{opacity:1}
.proj-overlay-btn{
    background:var(--lime);color:#000;
    padding:9px 22px;border-radius:20px;
    font-size:.78rem;font-weight:700;
    transform:translateY(10px);transition:transform .3s;
}
.proj:hover .proj-overlay-btn{transform:translateY(0)}
.proj-body{padding:22px}
.proj-cat{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--lime);margin-bottom:8px;}
.proj-body h3{font-family:'Bebas Neue',sans-serif;font-size:1.2rem;letter-spacing:.5px;margin-bottom:8px}
.proj-body p{color:var(--grey);font-size:.82rem;line-height:1.65}

/* ══════════════════════════════
   TEAM
══════════════════════════════ */
#team{background:var(--bg)}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:60px}
.tm{
    background:var(--bg2);border:1px solid var(--border2);
    border-radius:24px;padding:40px 28px;text-align:center;
    transition:all .35s;position:relative;cursor:none;
}
.tm::after{
    content:'';position:absolute;
    bottom:0;left:0;right:0;height:3px;
    background:linear-gradient(90deg,var(--lime),var(--cyan));
    transform:scaleX(0);transition:transform .35s;
}
.tm:hover{transform:translateY(-8px);border-color:rgba(198,255,0,.2);box-shadow:0 24px 60px rgba(0,0,0,.4)}
.tm:hover::after{transform:scaleX(1)}
.tm-av{
    width:84px;height:84px;border-radius:50%;
    margin:0 auto 22px;
    background:linear-gradient(135deg,rgba(198,255,0,.15),rgba(0,229,255,.1));
    border:2px solid rgba(198,255,0,.2);
    display:flex;align-items:center;justify-content:center;
    font-family:'Bebas Neue',sans-serif;font-size:1.8rem;
    letter-spacing:1px;color:var(--lime);position:relative;
    overflow:hidden;
}
.tm-av img{
    width:100%;height:100%;
    object-fit:cover;object-position:center top;
    border-radius:50%;
    display:block;
}
.tm-av::before{
    content:'';position:absolute;inset:-4px;border-radius:50%;
    border:1px dashed rgba(198,255,0,.15);
    animation:spin 12s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
.tm h3{font-family:'Bebas Neue',sans-serif;font-size:1.4rem;letter-spacing:.8px;margin-bottom:5px}
.tm-role{font-size:.75rem;font-weight:700;color:var(--lime);letter-spacing:.5px;margin-bottom:14px}
.tm-bio{color:var(--grey);font-size:.83rem;line-height:1.75;font-weight:300}
.tm-links{display:flex;justify-content:center;gap:8px;margin-top:22px}
.tm-links a{
    width:32px;height:32px;border-radius:9px;
    background:rgba(255,255,255,.04);border:1px solid var(--border2);
    display:flex;align-items:center;justify-content:center;
    color:var(--grey);text-decoration:none;font-size:13px;transition:all .2s;
}
.tm-links a:hover{border-color:var(--lime);color:var(--lime)}

/* ══════════════════════════════
   CONTACT
══════════════════════════════ */
#contact{background:var(--bg1)}
.contact-wrap{
    display:grid;grid-template-columns:1fr 1.2fr;
    gap:80px;margin-top:64px;align-items:start;
}
.cinfo h3{font-family:'Bebas Neue',sans-serif;font-size:2.2rem;letter-spacing:1px;margin-bottom:14px;}
.cinfo p{color:var(--grey);font-weight:300;line-height:1.9;margin-bottom:32px;font-size:.95rem}
.cm-card{
    display:flex;align-items:center;gap:14px;
    padding:16px 18px;border-radius:14px;
    border:1px solid var(--border2);background:rgba(255,255,255,.02);
    margin-bottom:12px;text-decoration:none;color:var(--white);transition:all .25s;
}
.cm-card:hover{border-color:rgba(198,255,0,.3);background:rgba(198,255,0,.04);transform:translateX(4px)}
.cm-ico{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:20px}
.cm-ico.g{background:rgba(37,211,102,.15)}
.cm-ico.e{background:rgba(0,229,255,.12)}
.cm-ico.l{background:rgba(198,255,0,.1)}
.cm-card strong{font-size:.95rem;font-weight:600;display:block}
.cm-card span{font-size:.78rem;color:var(--grey)}
.cform{display:flex;flex-direction:column;gap:14px}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fg{display:flex;flex-direction:column;gap:7px}
.fg label{font-size:.7rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--grey);}
.fg input,.fg textarea,.fg select{
    background:rgba(255,255,255,.03);
    border:1px solid var(--border2);
    border-radius:11px;padding:13px 16px;
    color:var(--white);font-family:'Outfit',sans-serif;font-size:.9rem;
    outline:none;transition:all .2s;
}
.fg input:focus,.fg textarea:focus,.fg select:focus{
    border-color:rgba(198,255,0,.4);
    background:rgba(198,255,0,.03);
    box-shadow:0 0 0 3px rgba(198,255,0,.06);
}
.fg textarea{resize:vertical;min-height:130px}
.fg select option{background:var(--bg2)}
.submit{
    background:var(--lime);color:#000;
    border:none;padding:15px 34px;border-radius:12px;
    font-family:'Outfit',sans-serif;font-weight:700;font-size:.92rem;
    cursor:none;transition:all .25s;letter-spacing:.3px;
    align-self:flex-start;
    box-shadow:0 0 36px rgba(198,255,0,.2);
}
.submit:hover{transform:translateY(-2px);box-shadow:0 0 56px rgba(198,255,0,.4)}

/* ══════════════════════════════
   FOOTER
══════════════════════════════ */
footer{
    background:var(--bg);
    border-top:1px solid var(--border2);
    padding:70px 4% 30px;
}
.ft-top{
    display:grid;grid-template-columns:2fr 1fr 1fr 1fr;
    gap:52px;padding-bottom:52px;
    border-bottom:1px solid var(--border2);
}
.ft-brand .logo{margin-bottom:14px;display:inline-flex}
.ft-brand p{color:var(--grey);font-size:.86rem;line-height:1.9;font-weight:300;max-width:270px;margin-bottom:24px}
.ft-soc{display:flex;gap:8px}
.ft-soc a{
    width:36px;height:36px;border-radius:9px;
    background:rgba(255,255,255,.03);border:1px solid var(--border2);
    display:flex;align-items:center;justify-content:center;
    color:var(--grey);text-decoration:none;font-size:15px;transition:all .22s;
}
.ft-soc a:hover{border-color:var(--lime);color:var(--lime);background:rgba(198,255,0,.07);transform:translateY(-3px)}
.ft-col h4{font-family:'Bebas Neue',sans-serif;font-size:1rem;letter-spacing:1.5px;color:var(--white);margin-bottom:18px;}
.ft-col ul{list-style:none}
.ft-col ul li{margin-bottom:10px}
.ft-col ul li a{color:var(--grey);text-decoration:none;font-size:.84rem;font-weight:300;transition:color .2s;}
.ft-col ul li a:hover{color:var(--lime)}
.ft-bot{
    display:flex;align-items:center;justify-content:space-between;
    padding-top:28px;font-size:.78rem;color:var(--grey);
}
.ft-bot a{color:var(--lime);text-decoration:none}
.ft-badge{
    display:flex;align-items:center;gap:8px;
    background:rgba(198,255,0,.06);border:1px solid rgba(198,255,0,.12);
    padding:6px 14px;border-radius:20px;font-size:.7rem;color:var(--lime);font-weight:700;letter-spacing:.5px;
}

/* ══════════════════════════════
   WA FLOAT
══════════════════════════════ */
.wa-btn{
    position:fixed;bottom:30px;right:30px;z-index:300;
    width:58px;height:58px;border-radius:50%;
    background:#25d366;color:#fff;
    display:flex;align-items:center;justify-content:center;
    text-decoration:none;font-size:28px;
    box-shadow:0 4px 24px rgba(37,211,102,.45);
    animation:waFloat 3s ease-in-out infinite;
    transition:transform .25s,box-shadow .25s;
}
.wa-btn:hover{transform:scale(1.1)!important;box-shadow:0 6px 36px rgba(37,211,102,.6)}
@keyframes waFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.wa-tip{
    position:absolute;right:70px;top:50%;transform:translateY(-50%);
    background:#25d366;color:#fff;
    padding:7px 14px;border-radius:9px;
    font-size:.75rem;font-weight:700;white-space:nowrap;
    opacity:0;pointer-events:none;transition:opacity .25s;
}
.wa-tip::after{
    content:'';position:absolute;left:100%;top:50%;transform:translateY(-50%);
    border:6px solid transparent;border-left-color:#25d366;
}
.wa-btn:hover .wa-tip{opacity:1}

/* ══════════════════════════════
   ANIMATIONS
══════════════════════════════ */
@keyframes fadeUp{
    from{opacity:0;transform:translateY(28px)}
    to{opacity:1;transform:translateY(0)}
}

/* ══════════════════════════════
   RESPONSIVE
══════════════════════════════ */
@media(max-width:960px){
    .srv-grid,.proj-grid,.team-grid{grid-template-columns:1fr 1fr}
    .about-wrap,.contact-wrap{grid-template-columns:1fr;gap:40px}
    .ft-top{grid-template-columns:1fr 1fr;gap:32px}
    .nav-center,.social-row,.cta-btn{display:none}
    .hamburger{display:flex}
    .mobile-nav{display:block}
    .hero-numbers{gap:32px}
}
@media(max-width:600px){
    .srv-grid,.proj-grid,.team-grid{grid-template-columns:1fr}
    .ft-top{grid-template-columns:1fr}
    .cf-row{grid-template-columns:1fr}
    h1.display{font-size:clamp(3rem,14vw,5rem)}
    #cur,#cur2{display:none}
    body{cursor:auto}
    .hero-numbers{flex-wrap:wrap;gap:24px}
    .hero-numbers > div{min-width:calc(50% - 12px)}
}

body.nav-open{overflow:hidden}