/* ===================================================
   LUMA RAY â€” Premium Dark Tech UI v3.0
   Complete overhaul â€” holographic hero, polished UI
   =================================================== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
::selection{background:rgba(0,212,255,.25);color:#fff}

:root{
    /* Backgrounds â€” lifted from pitch-black to deep navy */
    --bg:#0d0d1f;--bg2:#12122a;--bg3:#171733;
    /* Glassmorphism â€” more visible panels */
    --glass:rgba(255,255,255,0.055);
    --glass2:rgba(255,255,255,0.09);
    --glass3:rgba(255,255,255,0.13);
    --glass-border:rgba(255,255,255,0.10);
    --glass-border2:rgba(255,255,255,0.16);
    --glass-border3:rgba(255,255,255,0.22);
    /* Brand Colors */
    --teal:#00d4ff;--purple:#a855f7;--pink:#ec4899;
    --violet:#7c3aed;--indigo:#6366f1;--cyan:#22d3ee;
    --orange:#f97316;--yellow:#eab308;
    /* Gradients */
    --gd:linear-gradient(135deg,var(--teal) 0%,var(--purple) 100%);
    --gd2:linear-gradient(135deg,var(--pink) 0%,var(--orange) 100%);
    --gd3:linear-gradient(135deg,var(--indigo) 0%,var(--cyan) 100%);
    --gd-vert:linear-gradient(180deg,var(--teal),var(--purple));
    --gd-holo:linear-gradient(135deg,#00d4ff,#a855f7,#ec4899,#f97316,#22d3ee);
    /* Typography */
    --ff:'Unbounded',sans-serif;--fb:'Inter',sans-serif;
    /* UI */
    --r:18px;--rs:12px;--ease:cubic-bezier(.4,0,.2,1);
    --shadow-sm:0 4px 20px rgba(0,0,0,.3);
    --shadow-md:0 8px 40px rgba(0,0,0,.4);
    --shadow-lg:0 20px 60px rgba(0,0,0,.5);
    --glow-teal:0 0 30px rgba(0,212,255,.18),0 0 60px rgba(0,212,255,.08);
    --glow-purple:0 0 30px rgba(168,85,247,.18),0 0 60px rgba(168,85,247,.08);
}

html{scroll-behavior:smooth;scroll-padding-top:80px}
body{font-family:var(--fb);background:var(--bg);color:#f0f2ff;line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased}

/* ===== CURSOR GLOW ===== */
.cursor-glow{
    position:fixed;width:600px;height:600px;border-radius:50%;
    background:radial-gradient(circle,rgba(0,212,255,.06) 0%,rgba(168,85,247,.03) 30%,transparent 60%);
    pointer-events:none;z-index:9998;transform:translate(-50%,-50%);
    transition:opacity .3s;opacity:0;mix-blend-mode:screen
}
.cursor-glow.active{opacity:1}

/* ===== TEXT SHIMMER ===== */
@keyframes textShimmer{
    0%{background-position:200% center}
    100%{background-position:-200% center}
}
.shimmer-text{
    background:linear-gradient(90deg,var(--teal),var(--purple),var(--pink),var(--teal),var(--purple));
    background-size:200% auto;
    -webkit-background-clip:text;background-clip:text;color:transparent;
    animation:textShimmer 6s linear infinite
}

/* ===== MAGNETIC GLOW ON CARDS ===== */
.card-glow{
    position:absolute;inset:-1px;border-radius:inherit;
    background:conic-gradient(from var(--glow-angle,0deg),transparent 60%,rgba(0,212,255,.3) 75%,transparent 90%);
    opacity:0;transition:opacity .4s;z-index:-1;filter:blur(6px)
}
.svc-card:hover .card-glow,.why-card:hover .card-glow,.blog-card:hover .card-glow,.process-step:hover .card-glow{opacity:1}

/* ===== STAGGER REVEAL ===== */
.stagger-1{transition-delay:.05s}
.stagger-2{transition-delay:.1s}
.stagger-3{transition-delay:.15s}
.stagger-4{transition-delay:.2s}
.stagger-5{transition-delay:.25s}
.stagger-6{transition-delay:.3s}

/* ===== FLOATING BADGE ===== */
@keyframes floatBadge{
    0%,100%{transform:translateY(0)}
    50%{transform:translateY(-8px)}
}
.float-anim{animation:floatBadge 4s ease-in-out infinite}

/* ===== GRADIENT LINE ACCENT ===== */
.glow-line{
    height:2px;background:var(--gd);border-radius:2px;
    box-shadow:0 0 12px rgba(0,212,255,.3),0 0 24px rgba(0,212,255,.15);
    margin:32px auto 0;width:80px
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
ul{list-style:none}
.container{max-width:1280px;margin:0 auto;padding:0 32px}
.gradient-text{background:var(--gd);-webkit-background-clip:text;background-clip:text;color:transparent}
.gradient-text-2{background:var(--gd2);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ===== PRELOADER ===== */
#preloader{
    position:fixed;inset:0;z-index:9999;background:var(--bg);
    display:flex;align-items:center;justify-content:center;
    transition:opacity .6s ease,visibility .6s ease
}
#preloader.done{opacity:0;visibility:hidden;pointer-events:none}
.preloader-inner{text-align:center}
.preloader-logo{
    font-family:var(--ff);font-size:2.2rem;font-weight:900;
    letter-spacing:3px;margin-bottom:24px
}
.preloader-logo span{background:var(--gd);-webkit-background-clip:text;background-clip:text;color:transparent}
.preloader-track{width:200px;height:2px;background:rgba(255,255,255,.06);border-radius:4px;overflow:hidden;margin:0 auto}
.preloader-fill{height:100%;width:0;background:var(--gd);animation:preload 1.8s var(--ease) forwards}
@keyframes preload{to{width:100%}}
.preloader-dots{display:flex;gap:8px;justify-content:center;margin-top:28px}
.preloader-dots span{
    width:6px;height:6px;border-radius:50%;background:var(--glass2);
    animation:dotPulse 1.4s ease-in-out infinite
}
.preloader-dots span:nth-child(2){animation-delay:.2s;background:var(--teal)}
.preloader-dots span:nth-child(3){animation-delay:.4s;background:var(--purple)}
.preloader-dots span:nth-child(4){animation-delay:.6s;background:var(--pink)}
@keyframes dotPulse{0%,80%,100%{transform:scale(.5);opacity:.3}40%{transform:scale(1);opacity:1}}

/* ===== SCROLL TOP ===== */
.scroll-top{
    position:fixed;bottom:32px;right:32px;width:46px;height:46px;
    border-radius:50%;background:var(--gd);display:flex;align-items:center;
    justify-content:center;cursor:pointer;z-index:900;
    opacity:0;transform:translateY(20px);transition:.3s var(--ease);
    box-shadow:0 4px 24px rgba(0,212,255,.3)
}
.scroll-top.show{opacity:1;transform:translateY(0)}
.scroll-top:hover{transform:translateY(-4px);box-shadow:0 8px 40px rgba(0,212,255,.5)}
.scroll-top i{width:20px;height:20px;color:#fff}

/* ===== BUTTONS ===== */
.btn{
    display:inline-flex;align-items:center;gap:9px;
    padding:14px 32px;border-radius:50px;
    font-family:var(--fb);font-weight:600;font-size:.9rem;
    cursor:pointer;border:none;transition:.35s var(--ease);
    position:relative;overflow:hidden
}
.btn i{width:17px;height:17px}
.btn-glow{
    background:var(--gd);color:#fff;
    box-shadow:0 4px 28px rgba(0,212,255,.28)
}
.btn-glow::before{
    content:'';position:absolute;top:0;left:-100%;
    width:60%;height:100%;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);
    transition:.6s var(--ease)
}
.btn-glow:hover::before{left:150%}
.btn-glow:hover{box-shadow:0 10px 48px rgba(0,212,255,.55);transform:translateY(-3px)}
.btn-outline{
    background:transparent;color:#fff;
    border:1px solid var(--glass-border2);
    backdrop-filter:blur(8px)
}
.btn-outline:hover{background:var(--glass2);border-color:var(--teal);color:var(--teal)}
.btn-full{width:100%;justify-content:center}
.btn-purple{
    background:linear-gradient(135deg,var(--violet),var(--purple));
    color:#fff;box-shadow:0 4px 28px rgba(168,85,247,.3)
}
.btn-purple:hover{box-shadow:0 10px 48px rgba(168,85,247,.55);transform:translateY(-3px)}

/* ===== HEADER ===== */
.header{
    position:fixed;top:0;left:0;right:0;z-index:1000;
    padding:20px 0;transition:.4s var(--ease)
}
.header.scrolled{
    background:rgba(13,13,31,.92);backdrop-filter:blur(24px) saturate(1.2);
    border-bottom:1px solid var(--glass-border);padding:13px 0;
    box-shadow:0 4px 30px rgba(0,0,0,.3)
}
.header-inner{display:flex;align-items:center;justify-content:space-between}

/* Logo SVG Neon Style */
.logo {
    display: flex;
    align-items: center;
    gap: 12px;
    font-family: var(--ff);
    font-weight: 900;
    font-size: 1.3rem;
    letter-spacing: 2px;
    color: #f0f2ff;
    text-decoration: none;
    transition: opacity 0.3s;
}
.logo:hover {
    color: #fff;
    opacity: 0.95;
}
.logo-icon-svg {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.logo-svg {
    width: 100%;
    height: 100%;
    overflow: visible;
}
.logo-l {
    stroke: #00d4ff;
    filter: drop-shadow(0 0 3px #00d4ff) drop-shadow(0 0 8px rgba(0,212,255,0.4));
}
.logo-r {
    stroke: #ff007c;
    filter: drop-shadow(0 0 3px #ff007c) drop-shadow(0 0 8px rgba(255,0,124,0.4));
}
.logo-slash {
    stroke: #ffffff;
    filter: drop-shadow(0 0 2px #ffffff) drop-shadow(0 0 6px rgba(0,212,255,0.5)) drop-shadow(0 0 10px rgba(255,0,124,0.5));
}
.logo-text {
    font-family: var(--ff);
    font-weight: 900;
    font-size: 1.25rem;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    background: linear-gradient(to right, #f0f2ff 60%, var(--teal));
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    transition: 0.3s;
}
.logo:hover .logo-text {
    background: linear-gradient(to right, #ffffff 50%, var(--purple));
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}
.logo-accent {
    background: var(--gd);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

/* Nav */
.nav{display:flex;gap:34px;align-items:center}
.nav-link{
    font-size:.86rem;font-weight:500;color:rgba(240,242,255,.75);
    transition:.3s var(--ease);position:relative;padding:4px 0
}
.nav-link::after{
    content:'';position:absolute;bottom:-2px;left:0;
    width:0;height:1.5px;background:var(--gd);transition:.3s var(--ease)
}
.nav-link:hover,.nav-link.active{color:#f0f2ff}
.nav-link:hover::after,.nav-link.active::after{width:100%}

.header-cta{
    font-size:.82rem;padding:10px 24px;
    background:linear-gradient(135deg,var(--violet),var(--teal));
    color:#fff;border-radius:50px;
    box-shadow:0 4px 20px rgba(168,85,247,.3);
    transition:.3s var(--ease);display:flex;align-items:center;gap:8px;
    position:relative;overflow:hidden
}
.header-cta::before{
    content:'';position:absolute;top:0;left:-100%;
    width:60%;height:100%;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);
    transition:.6s var(--ease)
}
.header-cta:hover::before{left:150%}
.header-cta:hover{transform:translateY(-2px);box-shadow:0 8px 36px rgba(168,85,247,.5)}
.header-cta i{width:15px;height:15px}

.mobile-toggle{
    display:none;flex-direction:column;gap:5px;
    background:none;border:none;cursor:pointer;padding:4px;z-index:1001
}
.mobile-toggle span{
    width:26px;height:2px;background:#f0f2ff;
    transition:.3s var(--ease);border-radius:2px
}
.mobile-toggle.active span:first-child{transform:rotate(45deg) translate(4px,5px)}
.mobile-toggle.active span:last-child{transform:rotate(-45deg) translate(4px,-5px)}

/* ===== HERO ===== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden}

/* Background */
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img, .hero-bg video{width:100%;height:100%;object-fit:cover;filter:brightness(.38) saturate(1.15);transform:scale(1.1);transform-origin:center center}
.hero-overlay{
    position:absolute;inset:0;z-index:1;
    background:
        radial-gradient(ellipse 70% 80% at 0% 50%,rgba(124,58,237,.28) 0%,transparent 60%),
        radial-gradient(ellipse 50% 50% at 80% 20%,rgba(0,212,255,.12) 0%,transparent 50%),
        radial-gradient(ellipse 40% 40% at 70% 70%,rgba(236,72,153,.06) 0%,transparent 50%),
        linear-gradient(135deg,rgba(13,13,31,.85) 0%,rgba(13,13,31,.5) 50%,rgba(13,13,31,.88) 100%)
}

/* Grid Lines background effect */
.hero-grid{
    position:absolute;inset:0;z-index:1;
    background-image:
        linear-gradient(rgba(0,212,255,.035) 1px,transparent 1px),
        linear-gradient(90deg,rgba(0,212,255,.035) 1px,transparent 1px);
    background-size:60px 60px;
    mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 0%,transparent 100%);
    animation:gridShift 20s linear infinite
}
@keyframes gridShift{
    0%{background-position:0 0}
    100%{background-position:60px 60px}
}

/* ===== HERO â€” Geometric Visual (CSS-only) ===== */
.hero-geo{
    position:absolute;
    top:50%;right:6%;
    transform:translateY(-50%);
    width:480px;height:480px;
    z-index:2;pointer-events:none;
    display:flex;align-items:center;justify-content:center
}

/* Rotating gradient rings */
.geo-ring{
    position:absolute;border-radius:50%;
    border:1.5px solid transparent;
    background:conic-gradient(from 0deg,var(--teal),var(--purple),var(--pink),var(--teal)) border-box;
    -webkit-mask:linear-gradient(#fff 0 0) padding-box,linear-gradient(#fff 0 0);
    -webkit-mask-composite:xor;mask-composite:exclude
}
.geo-ring-1{
    inset:0;
    animation:geoSpin 20s linear infinite;
    opacity:.35
}
.geo-ring-2{
    inset:40px;
    animation:geoSpin 15s linear infinite reverse;
    opacity:.25;
    border-width:1px;
    border-style:dashed
}
.geo-ring-3{
    inset:90px;
    animation:geoSpin 25s linear infinite;
    opacity:.4;
    border-width:2px
}
@keyframes geoSpin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}

/* Central hexagon */
.geo-hex{
    width:120px;height:120px;
    position:absolute;top:50%;left:50%;
    transform:translate(-50%,-50%) rotate(30deg);
    background:linear-gradient(135deg,rgba(0,212,255,.08),rgba(168,85,247,.12));
    clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);
    border:1px solid rgba(0,212,255,.2);
    animation:hexPulse 4s ease-in-out infinite;
    box-shadow:0 0 60px rgba(0,212,255,.15),inset 0 0 40px rgba(168,85,247,.08)
}
@keyframes hexPulse{
    0%,100%{transform:translate(-50%,-50%) rotate(30deg) scale(1);opacity:.7}
    50%{transform:translate(-50%,-50%) rotate(30deg) scale(1.08);opacity:1}
}

/* Orbiting glowing orbs */
.geo-orb{
    position:absolute;border-radius:50%;
    filter:blur(1px)
}
.geo-orb-1{
    width:12px;height:12px;
    background:var(--teal);
    box-shadow:0 0 20px var(--teal),0 0 40px rgba(0,212,255,.4);
    top:50%;left:50%;
    animation:orbit1 8s linear infinite
}
.geo-orb-2{
    width:8px;height:8px;
    background:var(--purple);
    box-shadow:0 0 16px var(--purple),0 0 32px rgba(168,85,247,.4);
    top:50%;left:50%;
    animation:orbit2 12s linear infinite
}
.geo-orb-3{
    width:10px;height:10px;
    background:var(--pink);
    box-shadow:0 0 18px var(--pink),0 0 36px rgba(236,72,153,.3);
    top:50%;left:50%;
    animation:orbit3 10s linear infinite reverse
}
.geo-orb-4{
    width:6px;height:6px;
    background:var(--cyan);
    box-shadow:0 0 14px var(--cyan),0 0 28px rgba(34,211,238,.4);
    top:50%;left:50%;
    animation:orbit4 14s linear infinite
}
@keyframes orbit1{0%{transform:translate(-50%,-50%) rotate(0deg) translateX(200px) rotate(0deg)}100%{transform:translate(-50%,-50%) rotate(360deg) translateX(200px) rotate(-360deg)}}
@keyframes orbit2{0%{transform:translate(-50%,-50%) rotate(0deg) translateX(150px) rotate(0deg)}100%{transform:translate(-50%,-50%) rotate(360deg) translateX(150px) rotate(-360deg)}}
@keyframes orbit3{0%{transform:translate(-50%,-50%) rotate(0deg) translateX(230px) rotate(0deg)}100%{transform:translate(-50%,-50%) rotate(360deg) translateX(230px) rotate(-360deg)}}
@keyframes orbit4{0%{transform:translate(-50%,-50%) rotate(45deg) translateX(170px) rotate(-45deg)}100%{transform:translate(-50%,-50%) rotate(405deg) translateX(170px) rotate(-405deg)}}

/* Central pulse ring */
.geo-pulse{
    position:absolute;top:50%;left:50%;
    transform:translate(-50%,-50%);
    width:80px;height:80px;border-radius:50%;
    border:1px solid rgba(0,212,255,.3);
    animation:geoPulse 3s ease-in-out infinite;
    box-shadow:0 0 30px rgba(0,212,255,.1)
}
@keyframes geoPulse{
    0%{transform:translate(-50%,-50%) scale(1);opacity:.6}
    50%{transform:translate(-50%,-50%) scale(2.5);opacity:0}
    100%{transform:translate(-50%,-50%) scale(1);opacity:0}
}

/* Ambient Glows behind the visual */
.hero-ambient{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden}
.ambient-glow{
    position:absolute;border-radius:50%;
    filter:blur(100px);opacity:.3
}
.ambient-1{
    width:400px;height:400px;
    background:rgba(0,212,255,.35);
    top:15%;right:10%;
    animation:ambientDrift1 15s ease-in-out infinite
}
.ambient-2{
    width:350px;height:350px;
    background:rgba(168,85,247,.3);
    bottom:10%;right:20%;
    animation:ambientDrift2 18s ease-in-out infinite
}
@keyframes ambientDrift1{
    0%,100%{transform:translate(0,0)}
    50%{transform:translate(-30px,20px)}
}
@keyframes ambientDrift2{
    0%,100%{transform:translate(0,0)}
    50%{transform:translate(20px,-30px)}
}

/* ===== HERO â€” Light Beams ===== */
.hero-beams{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden}
.beam{
    position:absolute;width:1px;
    background:linear-gradient(to bottom,transparent,rgba(0,212,255,.15),rgba(168,85,247,.08),transparent);
    opacity:0;animation:beamFade 6s ease-in-out infinite
}
.beam-1{height:100%;left:25%;animation-delay:0s}
.beam-2{height:80%;top:10%;left:40%;animation-delay:1.5s}
.beam-3{height:100%;left:55%;animation-delay:3s}
.beam-4{height:70%;top:15%;left:68%;animation-delay:0.8s}
.beam-5{height:90%;top:5%;left:82%;animation-delay:2.3s}
@keyframes beamFade{
    0%,100%{opacity:0;transform:scaleY(.8)}
    15%{opacity:.6;transform:scaleY(1)}
    30%{opacity:0;transform:scaleY(.9)}
}

/* Particles */
.hero-particles{position:absolute;inset:0;pointer-events:none;z-index:1}
.hdot{position:absolute;border-radius:50%;animation:dotFloat 10s ease-in-out infinite}
.hd1{width:5px;height:5px;background:var(--teal);top:18%;left:12%;opacity:.6;box-shadow:0 0 12px var(--teal)}
.hd2{width:3px;height:3px;background:var(--purple);top:38%;left:6%;opacity:.4;animation-delay:2s;box-shadow:0 0 8px var(--purple)}
.hd3{width:4px;height:4px;background:var(--pink);top:72%;left:18%;opacity:.35;animation-delay:4s;box-shadow:0 0 8px var(--pink)}
.hd4{width:3px;height:3px;background:var(--cyan);top:82%;left:9%;opacity:.5;animation-delay:6s;box-shadow:0 0 10px var(--cyan)}
.hd5{width:4px;height:4px;background:var(--orange);top:52%;left:22%;opacity:.3;animation-delay:1s;box-shadow:0 0 8px var(--orange)}
.hd6{width:3px;height:3px;background:var(--violet);top:25%;left:20%;opacity:.4;animation-delay:3s;box-shadow:0 0 8px var(--violet)}
.hline{position:absolute;width:1px;background:linear-gradient(to bottom,transparent,var(--teal),transparent);opacity:.08}
.hl1{height:220px;top:8%;left:32%;animation:linePulse 7s ease-in-out infinite}
.hl2{height:160px;top:42%;left:48%;animation:linePulse 9s ease-in-out infinite 2s}
.hl3{height:280px;top:3%;left:58%;animation:linePulse 8s ease-in-out infinite 4s}

@keyframes dotFloat{0%,100%{transform:translateY(0) translateX(0)}33%{transform:translateY(-22px) translateX(12px)}66%{transform:translateY(-38px) translateX(-9px)}}
@keyframes linePulse{0%,100%{opacity:.04;transform:scaleY(1)}50%{opacity:.15;transform:scaleY(1.25)}}

/* Hero Content */
.hero-container{position:relative;z-index:3;width:100%}
.hero-content{max-width:700px;padding:160px 0 100px}

/* Hero title letter animation */
.hero-title .hl-mid{
    position:relative;
    background:linear-gradient(90deg,var(--teal),var(--purple),var(--pink),var(--teal));
    background-size:300% 100%;
    -webkit-background-clip:text;background-clip:text;color:transparent;
    animation:heroGradient 4s ease infinite
}
@keyframes heroGradient{
    0%{background-position:0% 50%}
    50%{background-position:100% 50%}
    100%{background-position:0% 50%}
}

.hero-eyebrow{
    display:inline-flex;align-items:center;gap:10px;
    background:rgba(0,212,255,.08);border:1px solid rgba(0,212,255,.2);
    border-radius:50px;padding:6px 18px;margin-bottom:28px;
    font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:3px;
    color:var(--cyan);
    backdrop-filter:blur(8px)
}
.hero-eyebrow span{
    width:6px;height:6px;background:var(--teal);border-radius:50%;
    box-shadow:0 0 8px var(--teal);animation:dotPulse2 2s ease-in-out infinite
}
@keyframes dotPulse2{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(0.7)}}

.hero-title{
    font-family:var(--ff);font-weight:900;line-height:1.08;
    margin-bottom:30px;text-transform:uppercase;
    font-size:clamp(2.2rem,4.5vw,4rem)
}
.hl-top{display:block;color:#f0f2ff}
.hl-mid{display:block;background:var(--gd);-webkit-background-clip:text;background-clip:text;color:transparent}
.hl-bot{display:block;color:#f0f2ff}

.hero-desc{
    font-size:1.05rem;color:rgba(240,242,255,.75);
    margin-bottom:40px;max-width:580px;line-height:1.85
}
.hero-desc strong{color:rgba(240,242,255,.95);font-weight:600}

.hero-features{display:flex;flex-direction:column;gap:10px;margin-bottom:44px}
.hero-feature{
    display:flex;align-items:center;gap:12px;
    font-size:.88rem;color:rgba(240,242,255,.7)
}
.hf-dot{
    width:7px;height:7px;border-radius:50%;flex-shrink:0;
    box-shadow:0 0 10px currentColor
}

.hero-actions{display:flex;gap:16px;flex-wrap:wrap}

/* Social Sidebar â€” right rail */
.hero-social{
    position:absolute;right:32px;top:50%;transform:translateY(-50%);
    display:flex;flex-direction:column;align-items:center;gap:16px;z-index:4
}
.social-link{
    width:38px;height:38px;border-radius:50%;
    border:1px solid var(--glass-border);
    display:flex;align-items:center;justify-content:center;
    transition:.3s var(--ease);color:rgba(240,242,255,.5);
    backdrop-filter:blur(8px)
}
.social-link i{width:16px;height:16px}
.social-link:hover{border-color:var(--teal);color:var(--teal);background:rgba(0,212,255,.1);box-shadow:0 0 20px rgba(0,212,255,.25)}
.social-label{
    writing-mode:vertical-rl;font-size:.7rem;
    letter-spacing:4px;text-transform:uppercase;
    color:rgba(240,242,255,.3);padding:14px 0
}

/* ===== TICKER / MARQUEE ===== */
.ticker-wrap{
    position:relative;
    padding:18px 0;overflow:hidden;white-space:nowrap;
    background:linear-gradient(135deg,rgba(13,13,31,.98) 0%,rgba(18,18,42,.95) 50%,rgba(13,13,31,.98) 100%);
    border-top:1px solid rgba(0,212,255,.1);
    border-bottom:1px solid rgba(168,85,247,.1);
    box-shadow:0 4px 30px rgba(0,0,0,.2),inset 0 0 60px rgba(0,212,255,.02)
}
.ticker-track{
    display:inline-flex;width:max-content
}
.ticker-inner{
    display:inline-flex;gap:14px;
    animation:ticker 35s linear infinite;
    padding-right:14px
}
.ticker-chip{
    display:inline-flex;align-items:center;gap:8px;
    padding:8px 20px;border-radius:50px;
    font-family:var(--fb);font-size:.78rem;font-weight:600;
    letter-spacing:1px;color:#fff;
    border:1px solid transparent;
    backdrop-filter:blur(8px);
    transition:.3s var(--ease);
    white-space:nowrap;
    position:relative;overflow:hidden
}
.ticker-chip i{width:14px;height:14px;flex-shrink:0}
.ticker-chip::before{
    content:'';position:absolute;inset:0;
    border-radius:50px;opacity:.15;
    transition:opacity .3s
}
.ticker-chip--teal{border-color:rgba(0,212,255,.3);color:var(--teal)}
.ticker-chip--teal::before{background:linear-gradient(135deg,rgba(0,212,255,.2),rgba(0,212,255,.05))}
.ticker-chip--purple{border-color:rgba(168,85,247,.3);color:var(--purple)}
.ticker-chip--purple::before{background:linear-gradient(135deg,rgba(168,85,247,.2),rgba(168,85,247,.05))}
.ticker-chip--cyan{border-color:rgba(34,211,238,.3);color:var(--cyan)}
.ticker-chip--cyan::before{background:linear-gradient(135deg,rgba(34,211,238,.2),rgba(34,211,238,.05))}
.ticker-chip--pink{border-color:rgba(236,72,153,.3);color:var(--pink)}
.ticker-chip--pink::before{background:linear-gradient(135deg,rgba(236,72,153,.2),rgba(236,72,153,.05))}
.ticker-chip--orange{border-color:rgba(249,115,22,.3);color:var(--orange)}
.ticker-chip--orange::before{background:linear-gradient(135deg,rgba(249,115,22,.2),rgba(249,115,22,.05))}
.ticker-chip--violet{border-color:rgba(124,58,237,.3);color:var(--violet)}
.ticker-chip--violet::before{background:linear-gradient(135deg,rgba(124,58,237,.2),rgba(124,58,237,.05))}
.ticker-chip--indigo{border-color:rgba(99,102,241,.3);color:var(--indigo)}
.ticker-chip--indigo::before{background:linear-gradient(135deg,rgba(99,102,241,.2),rgba(99,102,241,.05))}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ===== STATS STRIP ===== */
.stats-strip{
    padding:60px 0;background:var(--bg2);
    border-top:1px solid var(--glass-border);
    border-bottom:1px solid var(--glass-border);
    position:relative
}
.stats-strip::before{
    content:'';position:absolute;inset:0;
    background:
        radial-gradient(ellipse 30% 80% at 0% 50%,rgba(0,212,255,.06),transparent),
        radial-gradient(ellipse 30% 80% at 100% 50%,rgba(168,85,247,.06),transparent)
}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative}
.stat-block{
    text-align:center;position:relative;
    padding:30px 20px;border-radius:var(--r);
    background:var(--glass);border:1px solid var(--glass-border);
    transition:.45s var(--ease);
    backdrop-filter:blur(8px)
}
.stat-block::before{
    content:'';position:absolute;top:0;left:50%;
    transform:translateX(-50%);width:60%;height:2px;
    background:var(--gd);border-radius:0 0 4px 4px;
    transition:.3s
}
.stat-block:hover{
    background:var(--glass2);transform:translateY(-6px);
    box-shadow:var(--shadow-md),var(--glow-teal);
    border-color:var(--glass-border2)
}
.stat-block:hover::before{width:100%}
.stat-block:hover .stat-icon{
    transform:scale(1.15) rotate(5deg);
    box-shadow:0 0 24px rgba(0,212,255,.3)
}
.stat-icon{transition:.4s var(--ease)}
.stat-icon{
    width:42px;height:42px;border-radius:12px;
    display:flex;align-items:center;justify-content:center;
    margin:0 auto 14px;background:rgba(0,212,255,.08);
    border:1px solid rgba(0,212,255,.1)
}
.stat-icon i{width:20px;height:20px;color:var(--teal)}
.stat-num{
    font-family:var(--ff);font-size:2.4rem;font-weight:900;
    background:var(--gd);-webkit-background-clip:text;background-clip:text;color:transparent;
    line-height:1
}
.stat-suffix{font-family:var(--ff);font-size:1.4rem;font-weight:900;background:var(--gd);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat-label{display:block;font-size:.72rem;color:rgba(240,242,255,.4);text-transform:uppercase;letter-spacing:2px;margin-top:6px}

/* ===== SECTION COMMONS ===== */
.section-eyebrow{
    display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:16px
}
.ey-line{width:36px;height:1px;background:var(--gd)}
.ey-text{
    font-size:.72rem;font-weight:700;text-transform:uppercase;
    letter-spacing:4px;background:var(--gd);
    -webkit-background-clip:text;background-clip:text;color:transparent
}
.section-eyebrow i, .section-eyebrow svg{
    width:13px;height:13px;
    vertical-align:middle;
    margin-right:6px;
    color:var(--teal) !important;
    -webkit-text-fill-color:var(--teal) !important;
    display:inline-block
}
.section-title{
    font-family:var(--ff);font-weight:800;text-transform:uppercase;
    font-size:clamp(1.6rem,3vw,2.6rem);text-align:center;margin-bottom:16px;line-height:1.2
}
.section-desc{
    text-align:center;color:rgba(240,242,255,.68);
    max-width:640px;margin:0 auto 64px;font-size:.95rem;line-height:1.8
}

/* ===== ABOUT ===== */
.about{
    padding:120px 0;background:var(--bg);
    position:relative;overflow:hidden
}

/* Subtle video background â€” barely visible depth layer */
.svbg{
    position:absolute;inset:0;z-index:0;overflow:hidden;
    pointer-events:none
}
.svbg video{
    width:100%;height:100%;object-fit:cover;
    filter:brightness(.15) saturate(.6) blur(2px);
    transform:scale(1.05);
    opacity:.55
}
.svbg::after{
    content:'';position:absolute;inset:0;
    background:
        radial-gradient(ellipse 80% 60% at 50% 50%, rgba(13,13,31,.55) 0%, rgba(13,13,31,.9) 70%),
        linear-gradient(to bottom, rgba(13,13,31,.97) 0%, rgba(13,13,31,.82) 40%, rgba(13,13,31,.82) 60%, rgba(13,13,31,.97) 100%);
    z-index:1
}
.about .container,
.contact .container{
    position:relative;z-index:2
}
.about::before{
    content:'';position:absolute;
    top:20%;right:-10%;
    width:500px;height:500px;
    background:radial-gradient(circle,rgba(168,85,247,.06),transparent 70%);
    border-radius:50%;pointer-events:none
}
/* About â€” top row: portrait + text */
.about-top{display:grid;grid-template-columns:1fr 1.2fr;gap:60px;align-items:center}

/* â”€â”€ Portrait Frame â”€â”€ */
.about-portrait{display:flex;justify-content:center;position:relative}
.portrait-ambient{
    position:absolute;inset:-40px;z-index:0;pointer-events:none;
    display:flex;justify-content:center;align-items:center
}
.orb{
    position:absolute;border-radius:50%;filter:blur(40px);opacity:.4;
    animation:floatOrb 10s ease-in-out infinite alternate
}
.orb-1{
    width:250px;height:250px;background:var(--teal);
    top:0;left:-20px;animation-delay:0s
}
.orb-2{
    width:220px;height:220px;background:var(--purple);
    bottom:-20px;right:-20px;animation-delay:-5s
}
@keyframes floatOrb{
    0%{transform:translate(0,0) scale(1)}
    100%{transform:translate(30px,-30px) scale(1.1)}
}

.portrait-frame{position:relative;width:100%;max-width:460px;text-align:center;z-index:1}
.portrait-ring{display:none} /* removed */
.portrait-img{
    position:relative;z-index:1;border-radius:24px;overflow:hidden;
    border:1px solid rgba(255,255,255,.05);
    box-shadow:
        0 24px 70px rgba(0,0,0,.6),
        inset 0 0 60px rgba(255,255,255,.05);
    transition:.5s var(--ease);
    background:var(--bg)
}
.portrait-img:hover{
    border-color:rgba(255,255,255,.15);
    transform:translateY(-5px);
    box-shadow:
        0 30px 80px rgba(0,0,0,.7),
        0 0 80px rgba(0,212,255,.15),
        inset 0 0 60px rgba(255,255,255,.1)
}
/* Subtle edge glow */
.portrait-img::after{
    content:'';position:absolute;inset:0;
    border:2px solid transparent;border-radius:24px;
    background:linear-gradient(135deg,var(--teal),var(--purple),transparent) border-box;
    -webkit-mask:linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite:destination-out;mask-composite:exclude;
    pointer-events:none;opacity:0.5;transition:.5s
}
.portrait-img:hover::after{opacity:1}

.portrait-img img{
    width:100%;height:520px;object-fit:cover;object-position:center 18%;
    filter:brightness(.85) saturate(.85) contrast(1.1);transition:.6s var(--ease)
}
.portrait-img:hover img{filter:brightness(1) saturate(1) contrast(1.1);transform:scale(1.05)}
.portrait-img .img-overlay{
    position:absolute;inset:0;z-index:1;pointer-events:none;
    background:
        linear-gradient(135deg,rgba(0,212,255,.1) 0%,transparent 45%),
        linear-gradient(to bottom,transparent 40%,rgba(13,13,31,.8) 100%),
        linear-gradient(to right,rgba(168,85,247,.08) 0%,transparent 55%)
}
.portrait-name{
    position:absolute;bottom:0;left:0;right:0;z-index:2;
    padding:28px 32px;text-align:left;
    background:linear-gradient(to top,rgba(13,13,31,.95) 40%,transparent)
}
.portrait-name strong{display:block;font-family:var(--ff);font-size:1.4rem;font-weight:900;color:#fff;margin-bottom:4px;letter-spacing:-0.5px}
.portrait-name span{font-size:.75rem;color:var(--teal);text-transform:uppercase;letter-spacing:3px;font-weight:700}

.about-text-side{padding-left:0}
.about-label-wrap{
    display:inline-flex;align-items:center;gap:8px;
    background:rgba(124,58,237,.1);border:1px solid rgba(124,58,237,.3);
    border-radius:50px;padding:6px 16px;margin-bottom:22px;
    font-size:.72rem;font-weight:700;text-transform:uppercase;
    letter-spacing:3px;color:var(--purple);backdrop-filter:blur(4px)
}
.about-label-wrap i{width:13px;height:13px}
.about-heading{
    font-family:var(--ff);font-size:clamp(2rem,4vw,3.2rem);
    font-weight:900;line-height:1.1;margin-bottom:24px;
    text-transform:uppercase;letter-spacing:-1px
}
.grd{background:var(--gd);-webkit-background-clip:text;background-clip:text;color:transparent}
.about-lead{color:rgba(240,242,255,.75);line-height:1.85;margin-bottom:14px;font-size:1rem}
.about-lead strong{color:rgba(240,242,255,.95);font-weight:600}

/* â”€â”€ About stats row â”€â”€ */
.about-stats-row{
    display:flex;gap:24px;margin:24px 0 28px;flex-wrap:wrap
}
.astat{
    display:flex;flex-direction:column;gap:2px;
    background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);
    border-radius:16px;padding:14px 20px;flex:1;min-width:100px;
    transition:.3s var(--ease)
}
.astat:hover{background:rgba(0,212,255,.05);border-color:rgba(0,212,255,.15);transform:translateY(-2px)}
.astat-num{
    font-family:var(--ff);font-size:1.6rem;font-weight:900;line-height:1;
    background:var(--gd);-webkit-background-clip:text;background-clip:text;color:transparent
}
.astat-label{font-size:.68rem;color:rgba(240,242,255,.58);text-transform:uppercase;letter-spacing:1.5px;font-weight:600}

/* Ă˘â€˘ÂĂ˘â€˘ÂĂ˘â€˘Â CREDENTIALS â€” zawsze widoczne Ă˘â€˘ÂĂ˘â€˘ÂĂ˘â€˘Â */
.creds-wrap{margin-top:70px}

/* Eyebrow divider */
.creds-eyebrow{
    display:flex;align-items:center;gap:20px;
    margin-bottom:48px
}
.creds-line{
    flex:1;height:1px;
    background:linear-gradient(to right,transparent,rgba(255,255,255,.08),transparent)
}
.creds-label{
    display:flex;align-items:center;gap:8px;white-space:nowrap;
    font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:3px;
    color:rgba(240,242,255,.55)
}
.creds-label i{width:14px;height:14px;color:var(--teal);filter:drop-shadow(0 0 6px rgba(0,212,255,.5))}

/* â”€â”€ ROW 1: Experience step cards â”€â”€ */
.exp-cards-row{
    display:grid;grid-template-columns:repeat(4,1fr);
    gap:0;position:relative;margin-bottom:36px
}
/* Gradient connecting track */
.exp-track{
    position:absolute;top:36px;left:calc(12.5% + 8px);right:calc(12.5% + 8px);height:2px;
    background:linear-gradient(to right,
        var(--teal) 0%,
        var(--purple) 50%,
        rgba(255,255,255,.06) 100%
    );z-index:0
}
.exp-step{
    position:relative;z-index:1;
    padding:0 16px 0 0;
    display:flex;flex-direction:column;
    transition:.3s var(--ease)
}
.exp-step:hover .exp-step-body{
    border-color:rgba(255,255,255,.1);
    background:rgba(255,255,255,.04);
    transform:translateY(-4px)
}
/* Big step number */
.exp-step-num{
    font-family:var(--ff);font-size:2.8rem;font-weight:900;
    color:rgba(255,255,255,.04);line-height:1;
    margin-bottom:4px;transition:.3s;
    letter-spacing:-2px
}
.exp-step--active .exp-step-num,
.exp-step:hover .exp-step-num{
    color:rgba(0,212,255,.25);
    text-shadow:0 0 20px rgba(0,212,255,.15)
}
/* Timeline dot */
.exp-step-dot{
    width:16px;height:16px;border-radius:50%;flex-shrink:0;
    background:rgba(240,242,255,.1);border:2px solid rgba(240,242,255,.08);
    margin-bottom:16px;position:relative;z-index:2;
    transition:.3s var(--ease)
}
.exp-step--active .exp-step-dot{
    background:var(--teal);border-color:rgba(0,212,255,.3);
    box-shadow:0 0 0 4px rgba(0,212,255,.1),0 0 20px rgba(0,212,255,.4)
}
.exp-step:hover .exp-step-dot{
    border-color:var(--teal);
    box-shadow:0 0 12px rgba(0,212,255,.4)
}
/* Step body card */
.exp-step-body{
    flex:1;padding:18px 20px;border-radius:16px;
    background:rgba(255,255,255,.02);
    border:1px solid rgba(255,255,255,.04);
    transition:.3s var(--ease)
}
.exp-step--active .exp-step-body{
    background:linear-gradient(135deg,rgba(0,212,255,.06),rgba(124,58,237,.04));
    border-color:rgba(0,212,255,.15)
}
.exp-step-tag{
    display:inline-block;font-size:.6rem;font-weight:800;
    text-transform:uppercase;letter-spacing:2px;
    padding:3px 10px;border-radius:20px;margin-bottom:10px;
    background:rgba(124,58,237,.1);color:rgba(168,85,247,.9)
}
.exp-step-tag.now{
    background:rgba(0,212,255,.1);color:var(--teal)
}
.exp-step-body h4{
    font-family:var(--ff);font-size:.9rem;font-weight:800;
    color:#fff;margin-bottom:6px;line-height:1.3
}
.exp-step-body p{font-size:.76rem;color:rgba(240,242,255,.58);line-height:1.6}

/* â”€â”€ ROW 2: Edu + Cert side by side â”€â”€ */
.edu-cert-row{
    display:grid;grid-template-columns:1fr 1fr;
    gap:28px;align-items:start
}

/* Shared block header */
.block-header{display:flex;align-items:center;gap:14px;margin-bottom:22px}
.block-icon{
    width:42px;height:42px;border-radius:12px;flex-shrink:0;
    display:flex;align-items:center;justify-content:center;
    box-shadow:0 6px 24px rgba(0,0,0,.3),0 0 20px var(--block-glow,rgba(168,85,247,.3))
}
.block-icon i{width:20px;height:20px;color:#fff;filter:drop-shadow(0 0 4px rgba(255,255,255,.4))}
.block-icon--purple{background:linear-gradient(135deg,var(--purple),var(--violet));--block-glow:rgba(168,85,247,.35)}
.block-icon--teal{background:linear-gradient(135deg,var(--teal),var(--cyan));--block-glow:rgba(0,212,255,.35)}
.block-header h3{
    font-family:var(--ff);font-size:.9rem;font-weight:900;
    text-transform:uppercase;letter-spacing:2.5px;color:#fff
}

/* Education block */
.edu-block,.cert-block{
    background:linear-gradient(145deg,rgba(124,58,237,.04) 0%,rgba(255,255,255,.015) 50%,rgba(0,212,255,.03) 100%);
    border:1px solid rgba(255,255,255,.07);
    border-radius:22px;padding:28px;
    backdrop-filter:blur(12px);
    position:relative;overflow:hidden
}
.edu-block::before,.cert-block::before{
    content:'';position:absolute;top:0;left:0;right:0;height:1px;
    background:linear-gradient(to right,transparent,rgba(168,85,247,.3),rgba(0,212,255,.3),transparent)
}
.edu-items{display:flex;flex-direction:column;gap:10px}
.edu-item{
    display:flex;align-items:center;gap:14px;
    padding:12px 16px;border-radius:14px;
    border-left:3px solid rgba(124,58,237,.5);
    background:rgba(124,58,237,.04);
    transition:.3s var(--ease)
}
.edu-item:hover{
    background:rgba(124,58,237,.1);
    border-left-color:var(--purple);
    transform:translateX(5px);
    box-shadow:0 6px 24px rgba(124,58,237,.15),inset 0 0 30px rgba(124,58,237,.03)
}
.edu-item--teal{border-left-color:rgba(0,212,255,.5);background:rgba(0,212,255,.04)}
.edu-item--teal:hover{background:rgba(0,212,255,.1);border-left-color:var(--teal);box-shadow:0 6px 24px rgba(0,212,255,.15)}
.edu-item--pink{border-left-color:rgba(236,72,153,.5);background:rgba(236,72,153,.04)}
.edu-item--pink:hover{background:rgba(236,72,153,.1);border-left-color:var(--pink);box-shadow:0 6px 24px rgba(236,72,153,.15)}
.edu-item-icon{
    width:34px;height:34px;border-radius:10px;flex-shrink:0;
    display:flex;align-items:center;justify-content:center;
    background:rgba(124,58,237,.28);box-shadow:0 0 16px rgba(124,58,237,.25);
    border:1px solid rgba(124,58,237,.2)
}
.edu-item--teal .edu-item-icon{background:rgba(0,212,255,.28);box-shadow:0 0 16px rgba(0,212,255,.25);border-color:rgba(0,212,255,.2)}
.edu-item--pink .edu-item-icon{background:rgba(236,72,153,.28);box-shadow:0 0 16px rgba(236,72,153,.25);border-color:rgba(236,72,153,.2)}
.edu-item-icon i{width:17px;height:17px;color:#c084fc;filter:drop-shadow(0 0 6px rgba(168,85,247,.6))}
.edu-item--teal .edu-item-icon i{color:#67e8f9;filter:drop-shadow(0 0 6px rgba(0,212,255,.6))}
.edu-item--pink .edu-item-icon i{color:#f472b6;filter:drop-shadow(0 0 6px rgba(236,72,153,.6))}
.edu-item strong{display:block;font-size:.83rem;font-weight:700;color:#fff;line-height:1.3}
.edu-item span{display:block;font-size:.68rem;color:rgba(240,242,255,.55);margin-top:1px}

/* Cert block */
.cert-items{display:flex;flex-direction:column;gap:10px}
.cert-item{
    display:flex;align-items:center;gap:14px;
    padding:12px 16px;border-radius:14px;
    background:rgba(255,255,255,.03);
    border:1px solid rgba(255,255,255,.06);
    transition:.3s var(--ease)
}
.cert-item:hover{
    background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.12);
    transform:translateX(5px);
    box-shadow:0 6px 24px rgba(0,0,0,.3),0 0 20px rgba(0,212,255,.05)
}
.cert-item-icon{
    width:36px;height:36px;border-radius:10px;flex-shrink:0;
    display:flex;align-items:center;justify-content:center;
    border:1px solid transparent
}
.cert-item-icon i{width:17px;height:17px}
.ci-cyan{background:rgba(0,212,255,.25);box-shadow:0 0 14px rgba(0,212,255,.2);border-color:rgba(0,212,255,.15)} .ci-cyan i{color:#67e8f9;filter:drop-shadow(0 0 6px rgba(0,212,255,.6))}
.ci-violet{background:rgba(168,85,247,.25);box-shadow:0 0 14px rgba(168,85,247,.2);border-color:rgba(168,85,247,.15)} .ci-violet i{color:#c084fc;filter:drop-shadow(0 0 6px rgba(168,85,247,.6))}
.ci-pink{background:rgba(236,72,153,.25);box-shadow:0 0 14px rgba(236,72,153,.2);border-color:rgba(236,72,153,.15)} .ci-pink i{color:#f472b6;filter:drop-shadow(0 0 6px rgba(236,72,153,.6))}
.ci-orange{background:rgba(251,146,60,.25);box-shadow:0 0 14px rgba(251,146,60,.2);border-color:rgba(251,146,60,.15)} .ci-orange i{color:#fdba74;filter:drop-shadow(0 0 6px rgba(251,146,60,.6))}
.ci-green{background:rgba(34,197,94,.25);box-shadow:0 0 14px rgba(34,197,94,.2);border-color:rgba(34,197,94,.15)} .ci-green i{color:#4ade80;filter:drop-shadow(0 0 6px rgba(34,197,94,.6))}
.cert-item-body{flex:1}
.cert-item-body strong{display:block;font-size:.83rem;font-weight:700;color:#fff}
.cert-item-body span{font-size:.68rem;color:rgba(240,242,255,.55)}
.cert-item-year{
    font-family:var(--ff);font-size:.68rem;font-weight:800;
    color:#67e8f9;background:rgba(0,212,255,.12);
    padding:3px 10px;border-radius:20px;white-space:nowrap;
    border:1px solid rgba(0,212,255,.2);
    text-shadow:0 0 8px rgba(0,212,255,.3)
}

/* Ă˘â€˘ÂĂ˘â€˘ÂĂ˘â€˘Â CREDENTIALS GRID Ă˘â€˘ÂĂ˘â€˘ÂĂ˘â€˘Â */
.credentials-grid{
    display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
    margin-top:64px
}
.cred-card{
    background:var(--glass);border:1px solid var(--glass-border);
    border-radius:20px;padding:28px 24px;
    backdrop-filter:blur(12px);
    transition:.4s var(--ease);position:relative;overflow:hidden
}
.cred-card::before{
    content:'';position:absolute;top:0;left:0;right:0;height:3px;
    background:var(--gd);opacity:.4;transition:.3s
}
.cred-card:hover{
    border-color:var(--glass-border2);
    box-shadow:var(--shadow-md),0 0 30px rgba(0,212,255,.06);
    transform:translateY(-4px)
}
.cred-card:hover::before{opacity:1}

.cred-header{display:flex;align-items:center;gap:14px;margin-bottom:24px}
.cred-icon{
    width:44px;height:44px;border-radius:12px;
    display:flex;align-items:center;justify-content:center;flex-shrink:0;
    box-shadow:0 4px 16px rgba(0,0,0,.3)
}
.cred-icon i{width:22px;height:22px;color:#fff}
.cred-title{
    font-family:var(--ff);font-size:1.1rem;font-weight:800;
    text-transform:uppercase;letter-spacing:2px;color:#fff
}

/* Timeline â€” DoĹ›wiadczenie */
.cred-timeline{position:relative;padding-left:20px}
.cred-timeline::before{
    content:'';position:absolute;left:5px;top:8px;bottom:8px;
    width:2px;background:linear-gradient(to bottom,var(--teal),var(--purple),transparent);
    border-radius:2px
}
.tl-item{position:relative;padding:0 0 20px 20px}
.tl-item:last-child{padding-bottom:0}
.tl-item::before{
    content:'';position:absolute;left:-18px;top:8px;
    width:10px;height:10px;border-radius:50%;
    background:rgba(240,242,255,.3);border:2px solid rgba(240,242,255,.15)
}
.tl-active::before{
    background:var(--teal);border-color:rgba(0,212,255,.4);
    box-shadow:0 0 12px rgba(0,212,255,.4),0 0 24px rgba(0,212,255,.15)
}
.tl-badge{
    display:inline-block;font-size:.65rem;font-weight:700;
    text-transform:uppercase;letter-spacing:2px;
    color:var(--purple);margin-bottom:4px
}
.tl-now{color:var(--teal)}
.tl-item h4{
    font-family:var(--ff);font-size:.92rem;font-weight:700;color:#fff;
    margin-bottom:2px;line-height:1.3
}
.tl-item p{font-size:.78rem;color:rgba(240,242,255,.5);line-height:1.5}

/* List â€” Edukacja & Certyfikaty */
.cred-list{display:flex;flex-direction:column;gap:14px}
.cred-item{
    display:flex;align-items:center;gap:14px;
    padding:10px 14px;border-radius:12px;
    background:rgba(255,255,255,.02);
    border:1px solid rgba(255,255,255,.04);
    transition:.3s var(--ease)
}
.cred-item:hover{
    background:rgba(0,212,255,.04);
    border-color:rgba(0,212,255,.1);
    transform:translateX(4px)
}
.cred-item-icon,.cred-check{
    width:36px;height:36px;border-radius:10px;
    display:flex;align-items:center;justify-content:center;flex-shrink:0;
    background:rgba(124,58,237,.1);border:1px solid rgba(124,58,237,.2)
}
.cred-item-icon i,.cred-check i{width:18px;height:18px;color:var(--purple)}
.cred-check{background:rgba(0,212,255,.08);border-color:rgba(0,212,255,.15)}
.cred-check i{color:var(--teal)}
.cred-item strong{display:block;font-size:.85rem;font-weight:600;color:#fff;line-height:1.3}
.cred-item span{display:block;font-size:.72rem;color:rgba(240,242,255,.58)}

/* ===== GENERAL SECTION VIDEO BG ===== */
.section-bg{position:absolute;inset:0;z-index:0}
.section-bg .bg-vid{width:100%;height:100%;object-fit:cover;filter:brightness(.4) saturate(1.2)}
.section-bg-overlay{
    position:absolute;inset:0;
    background:linear-gradient(135deg,rgba(13,13,31,.95) 0%,rgba(13,13,31,.7) 50%,rgba(13,13,31,.95) 100%);
    z-index:1;
}

/* ===== SERVICES ===== */
.services{padding:120px 0;position:relative;overflow:hidden;background:var(--bg2)}
/* subtle animated circuit pattern */
.services::before{
    content:'';position:absolute;inset:0;
    background-image:
        linear-gradient(rgba(0,212,255,.025) 1px,transparent 1px),
        linear-gradient(90deg,rgba(0,212,255,.025) 1px,transparent 1px);
    background-size:80px 80px;pointer-events:none
}
.services::after{
    content:'';position:absolute;
    bottom:-20%;left:-10%;
    width:600px;height:600px;
    background:radial-gradient(circle,rgba(0,212,255,.06),transparent 65%);
    border-radius:50%;pointer-events:none
}

.services-header{
    display:flex;justify-content:space-between;align-items:flex-end;
    gap:40px;margin-bottom:64px;position:relative;z-index:1
}
.services-header-left .section-eyebrow{justify-content:flex-start}
.services-header-left .section-title{text-align:left;margin-bottom:0}
.services-header-right{max-width:380px;color:rgba(240,242,255,.6);font-size:.92rem;line-height:1.75;text-align:right}

/* Service Cards */
.services-grid{display:flex;gap:28px;position:relative;z-index:1}
.svc-col{flex:1;display:flex;flex-direction:column;gap:28px}
.svc-col-right{margin-top:56px}

.svc-card{
    position:relative;border-radius:var(--r);overflow:hidden;
    border:1px solid var(--glass-border);
    background:var(--glass);
    transition:.45s var(--ease);cursor:pointer;
    backdrop-filter:blur(4px)
}
.svc-card:hover{
    border-color:rgba(0,212,255,.2);
    transform:translateY(-10px);
    box-shadow:var(--shadow-lg),var(--glow-teal);
    background:rgba(0,212,255,.03)
}
/* Top accent line */
.svc-card::before{
    content:'';position:absolute;top:0;left:0;right:0;
    height:2px;background:var(--gd);
    transform:scaleX(0);transform-origin:left;
    transition:.4s var(--ease);z-index:1
}
.svc-card:hover::before{transform:scaleX(1)}

.svc-card-inner{display:block;position:relative}
.svc-img-wrap{height:190px;overflow:hidden;position:relative}
.svc-img-wrap img, .svc-img-wrap video{
    display:block;width:100%;height:100%;object-fit:cover;
    transition:.6s var(--ease);filter:brightness(.65) saturate(.85)
}
.svc-card:hover .svc-img-wrap img, .svc-card:hover .svc-img-wrap video{transform:scale(1.12);filter:brightness(.8) saturate(1.1)}

/* gradient overlay on image/video */
.svc-img-wrap::after{
    content:'';position:absolute;bottom:0;left:0;right:0;
    height:60%;background:linear-gradient(to top,var(--bg2),transparent);
    pointer-events:none
}

.svc-body{padding:24px}
.svc-num-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.svc-num{
    font-family:var(--ff);font-size:.7rem;font-weight:700;
    color:var(--teal);letter-spacing:2px
}
.svc-icon{
    width:40px;height:40px;border-radius:10px;
    display:flex;align-items:center;justify-content:center;
    background:rgba(0,212,255,.1);color:var(--teal);
    border:1px solid rgba(0,212,255,.15);
    transition:.3s var(--ease)
}
.svc-icon i{width:19px;height:19px}
.svc-card:hover .svc-icon{
    background:rgba(0,212,255,.18);
    box-shadow:0 0 24px rgba(0,212,255,.25);
    border-color:rgba(0,212,255,.3)
}

.svc-body h4{
    font-family:var(--ff);font-size:.88rem;font-weight:700;
    text-transform:uppercase;margin-bottom:10px;line-height:1.35
}
.svc-body p{font-size:.82rem;color:rgba(240,242,255,.6);line-height:1.65}
.svc-arrow{
    display:inline-flex;align-items:center;gap:6px;
    font-size:.78rem;font-weight:700;color:var(--teal);
    margin-top:14px;opacity:0;transform:translateX(-8px);
    transition:.3s var(--ease)
}
.svc-arrow i{width:14px;height:14px}
.svc-card:hover .svc-arrow{opacity:1;transform:translateX(0)}

.services-cta{
    text-align:center;margin-top:56px;
    color:rgba(240,242,255,.5);font-size:.9rem;position:relative;z-index:1
}
.services-cta a{
    display:inline-flex;align-items:center;gap:6px;
    font-weight:700;font-size:1rem;margin-left:8px;
    background:var(--gd);-webkit-background-clip:text;background-clip:text;color:transparent;
    transition:.3s
}
.services-cta a:hover{filter:brightness(1.3)}
.services-cta a i{width:18px;height:18px;color:var(--teal)}

/* ===== VIDEO REEL ===== */
.vreel{
    background:var(--bg2);
    position:relative
}

/* Eyebrow label */
.vreel-head{
    display:flex;align-items:center;gap:20px;
    padding:40px 60px 24px
}
.vr-line{
    flex:1;height:1px;
    background:linear-gradient(to right,transparent,rgba(255,255,255,.08),transparent)
}
.vr-text{
    display:flex;align-items:center;gap:8px;white-space:nowrap;
    font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:3px;
    color:rgba(240,242,255,.3)
}
.vr-text i{width:14px;height:14px;color:var(--teal)}

/* Mosaic grid â€” 3 cols, 2 rows */
.vreel-mosaic{
    display:grid;
    grid-template-columns:2fr 1.2fr 1fr;
    grid-template-rows:260px 260px;
    gap:3px
}

/* Cell placement */
.vr-a{grid-column:1;grid-row:1}
.vr-b{grid-column:2;grid-row:1}
.vr-c{grid-column:3;grid-row:1 / 3} /* spans both rows â€” tall right */
.vr-d{grid-column:1;grid-row:2}
.vr-e{grid-column:2;grid-row:2}

/* Base cell styles */
.vr-cell{
    position:relative;overflow:hidden;
    background:var(--bg);cursor:pointer
}

/* Video inside cell */
.vr-cell video{
    position:absolute;inset:0;
    width:100%;height:100%;
    object-fit:cover;display:block;
    filter:brightness(.78) saturate(.85);
    transform:scale(1.04);
    transition:filter .7s ease, transform .7s ease
}
.vr-cell:hover video{
    filter:brightness(.95) saturate(1.2);
    transform:scale(1.09)
}


/* Dark vignette over video */
.vr-cell::before{
    content:'';position:absolute;inset:0;
    background:linear-gradient(
        135deg,
        rgba(13,13,31,.5) 0%,
        rgba(13,13,31,.15) 50%,
        rgba(13,13,31,.4) 100%
    );
    z-index:1;
    transition:.55s ease
}
.vr-cell:hover::before{
    background:linear-gradient(
        135deg,
        rgba(13,13,31,.2) 0%,
        rgba(13,13,31,.04) 50%,
        rgba(13,13,31,.12) 100%
    )
}

/* Per-cell color tint on hover â€” shows as bottom glow */
.vr-tint-teal::after  {content:'';position:absolute;inset:0;z-index:2;pointer-events:none;
    background:linear-gradient(to top,rgba(0,212,255,.18) 0%,transparent 55%);
    opacity:0;transition:opacity .5s ease}
.vr-tint-purple::after{content:'';position:absolute;inset:0;z-index:2;pointer-events:none;
    background:linear-gradient(to top,rgba(168,85,247,.2) 0%,transparent 55%);
    opacity:0;transition:opacity .5s ease}
.vr-tint-pink::after  {content:'';position:absolute;inset:0;z-index:2;pointer-events:none;
    background:linear-gradient(to top,rgba(236,72,153,.2) 0%,transparent 55%);
    opacity:0;transition:opacity .5s ease}
.vr-tint-orange::after{content:'';position:absolute;inset:0;z-index:2;pointer-events:none;
    background:linear-gradient(to top,rgba(249,115,22,.2) 0%,transparent 55%);
    opacity:0;transition:opacity .5s ease}
.vr-tint-violet::after{content:'';position:absolute;inset:0;z-index:2;pointer-events:none;
    background:linear-gradient(to top,rgba(124,58,237,.2) 0%,transparent 55%);
    opacity:0;transition:opacity .5s ease}
.vr-cell:hover::after{opacity:1}

/* Inset border on hover - overrides the ::after above where needed */
/* Border handled inside ::after â€” we stack it via box-shadow on cell */
.vr-cell:hover{
    box-shadow:inset 0 0 0 2px rgba(255,255,255,.12),
               0 0 40px rgba(0,0,0,.5)
}

/* Large number top-left in each cell */
.vr-num{
    position:absolute;top:16px;left:20px;z-index:4;
    font-family:var(--ff);font-size:2rem;font-weight:900;
    color:rgba(255,255,255,.06);letter-spacing:-2px;
    line-height:1;
    transition:color .4s ease, transform .4s ease
}
.vr-cell:hover .vr-num{
    color:rgba(255,255,255,.18);
    transform:scale(1.08) translateY(-2px)
}

/* Bottom label â€” slides up on hover */
.vr-label{
    position:absolute;bottom:0;left:0;right:0;
    padding:18px 20px 20px;
    background:linear-gradient(to top,rgba(13,13,31,.95) 0%,transparent 100%);
    z-index:5;
    transform:translateY(100%);
    transition:transform .45s cubic-bezier(.4,0,.2,1)
}
.vr-cell:hover .vr-label{transform:translateY(0)}
.vr-label span{
    font-family:var(--ff);font-size:.65rem;font-weight:800;
    text-transform:uppercase;letter-spacing:4px;
    background:var(--gd);-webkit-background-clip:text;background-clip:text;color:transparent
}

/* CTA below mosaic */
.vreel-cta{
    display:flex;justify-content:center;
    padding:32px 0 48px
}
.vreel-cta .btn-outline{
    border-color:rgba(255,255,255,.15);
    backdrop-filter:blur(10px);
    font-size:.82rem
}
.vreel-cta .btn-outline:hover{
    border-color:var(--teal);color:var(--teal);
    box-shadow:0 0 30px rgba(0,212,255,.2)
}

/* ===== WHY / CHOOSE US ===== */
.why{
    padding:120px 0;background:var(--bg);overflow:hidden;
    position:relative
}
.why::before{
    content:'';position:absolute;
    top:30%;left:-10%;
    width:500px;height:500px;
    background:radial-gradient(circle,rgba(0,212,255,.05),transparent 65%);
    border-radius:50%;pointer-events:none
}

.why-grid{
    display:grid;grid-template-columns:1fr 1fr;
    gap:80px;align-items:start;position:relative
}

/* Left: heading + image collage */
.why-left{}
.why-collage{position:relative;margin-top:40px;height:360px}
.collage-back{
    position:absolute;top:0;left:0;right:40px;
    border-radius:20px;overflow:hidden;
    border:1px solid var(--glass-border2);
    box-shadow:var(--shadow-lg);
    height:300px
}
.collage-back img, .collage-back video{
    display:block;width:100%;height:100%;object-fit:cover;filter:brightness(.82)
}
.collage-back::after{
    content:'';position:absolute;inset:0;
    background:linear-gradient(to top,rgba(13,13,31,.5),transparent 40%);
    pointer-events:none
}
.collage-front{
    position:absolute;
    bottom:0;right:0;
    width:210px;border-radius:18px;overflow:hidden;
    border:3px solid var(--bg);
    box-shadow:0 20px 60px rgba(0,0,0,.6),0 0 30px rgba(0,212,255,.15);
    z-index:2
}
.collage-front img, .collage-front video{
    display:block;width:100%;height:180px;object-fit:cover;filter:brightness(.88)
}
.collage-front::after{
    content:'';position:absolute;inset:0;
    background:linear-gradient(135deg,rgba(0,212,255,.1),transparent);
    pointer-events:none
}

/* Right: cards */
.why-cards{display:flex;flex-direction:column;gap:20px}
.why-card{
    display:flex;gap:18px;
    background:var(--glass);border:1px solid var(--glass-border);
    border-radius:var(--r);padding:22px 24px;
    transition:.4s var(--ease);position:relative;overflow:hidden;
    backdrop-filter:blur(4px)
}
.why-card::before{
    content:'';position:absolute;left:0;top:0;bottom:0;
    width:3px;transition:.3s
}
.why-card[data-c="teal"]::before{background:var(--gd)}
.why-card[data-c="purple"]::before{background:linear-gradient(var(--purple),var(--violet))}
.why-card[data-c="pink"]::before{background:var(--gd2)}
.why-card[data-c="orange"]::before{background:linear-gradient(var(--orange),var(--yellow))}
.why-card[data-c="blue"]::before{background:var(--gd3)}
.why-card[data-c="indigo"]::before{background:linear-gradient(var(--indigo),var(--violet))}

.why-card:hover{
    background:var(--glass2);border-color:var(--glass-border2);
    transform:translateX(6px) scale(1.01);box-shadow:var(--shadow-sm),0 0 30px rgba(0,212,255,.06)
}

.why-card-icon{
    width:46px;height:46px;border-radius:12px;flex-shrink:0;
    display:flex;align-items:center;justify-content:center;
    transition:.3s var(--ease)
}
.why-card:hover .why-card-icon{transform:scale(1.1)}
.why-card[data-c="teal"] .why-card-icon{background:rgba(0,212,255,.1);color:var(--teal)}
.why-card[data-c="purple"] .why-card-icon{background:rgba(168,85,247,.1);color:var(--purple)}
.why-card[data-c="pink"] .why-card-icon{background:rgba(236,72,153,.1);color:var(--pink)}
.why-card[data-c="orange"] .why-card-icon{background:rgba(249,115,22,.1);color:var(--orange)}
.why-card[data-c="blue"] .why-card-icon{background:rgba(34,211,238,.1);color:var(--cyan)}
.why-card[data-c="indigo"] .why-card-icon{background:rgba(99,102,241,.1);color:var(--indigo)}
.why-card-icon i{width:22px;height:22px}

.why-card-text h4{
    font-family:var(--ff);font-size:.78rem;font-weight:700;
    text-transform:uppercase;margin-bottom:7px
}
.why-card-text p{font-size:.83rem;color:rgba(240,242,255,.6);line-height:1.6}

/* ===== PROCESS ===== */
.process{
    padding:120px 0;background:var(--bg2);overflow:hidden;
    position:relative
}
.process::before{
    content:'';position:absolute;inset:0;
    background-image:
        linear-gradient(rgba(0,212,255,.02) 1px,transparent 1px),
        linear-gradient(90deg,rgba(0,212,255,.02) 1px,transparent 1px);
    background-size:80px 80px;pointer-events:none
}
.process-grid{
    display:grid;
    grid-template-columns:1fr 1fr 2fr;
    gap:24px;margin-top:64px;position:relative;z-index:1
}
.process-step{
    background:var(--glass);border:1px solid var(--glass-border);
    border-radius:var(--r);padding:28px;position:relative;
    overflow:hidden;transition:.4s var(--ease);
    backdrop-filter:blur(4px)
}
.process-step:hover{
    background:var(--glass2);border-color:var(--glass-border2);
    transform:translateY(-6px);
    box-shadow:var(--shadow-md)
}
.step-num{
    font-family:var(--ff);font-size:.65rem;font-weight:700;
    color:var(--teal);letter-spacing:3px;margin-bottom:14px;
    display:flex;align-items:center;gap:8px
}
.step-num::before{
    content:'';width:24px;height:1px;background:var(--gd)
}
.process-step h4{
    font-family:var(--ff);font-size:.9rem;font-weight:700;
    text-transform:uppercase;margin-bottom:10px
}
.process-step p{font-size:.82rem;color:rgba(240,242,255,.68);line-height:1.65}
.step-img{margin-top:18px;border-radius:10px;overflow:hidden;height:130px;position:relative}
.step-img img, .step-img video{display:block;width:100%;height:100%;object-fit:cover;filter:brightness(.75);transition:.5s var(--ease)}
.step-img::after{
    content:'';position:absolute;inset:0;
    background:linear-gradient(to top,rgba(13,13,31,.3),transparent 50%);
    pointer-events:none
}
.process-step:hover .step-img img, .process-step:hover .step-img video{filter:brightness(.9);transform:scale(1.05)}

/* Big "brand" card */
.process-brand{
    background:var(--gd);border-radius:var(--r);
    padding:36px;display:flex;flex-direction:column;justify-content:center;
    grid-row:1/3;position:relative;overflow:hidden
}
.process-brand::before{
    content:'';position:absolute;inset:0;
    background:radial-gradient(circle at 30% 70%,rgba(255,255,255,.1),transparent 50%),
                radial-gradient(circle at 80% 20%,rgba(255,255,255,.08),transparent 40%);
    pointer-events:none
}
.process-brand h3{
    font-family:var(--ff);font-size:1.4rem;font-weight:800;
    text-transform:uppercase;color:#fff;line-height:1.25;margin-bottom:16px;
    position:relative
}
.process-brand p{color:rgba(255,255,255,.8);font-size:.92rem;line-height:1.75;margin-bottom:28px;position:relative}
.brand-tags{display:flex;flex-wrap:wrap;gap:10px;position:relative}
.brand-tag{
    padding:6px 14px;border-radius:50px;
    background:rgba(255,255,255,.15);
    font-size:.73rem;font-weight:600;color:#fff;
    border:1px solid rgba(255,255,255,.25);
    transition:.3s var(--ease);
    backdrop-filter:blur(4px)
}
.brand-tag:hover{background:rgba(255,255,255,.25);transform:translateY(-2px)}

/* ===== BLOG ===== */
.blog{
    padding:120px 0;background:var(--bg);
    position:relative;overflow:hidden
}
.blog::before{
    content:'';position:absolute;
    bottom:10%;right:-5%;
    width:400px;height:400px;
    background:radial-gradient(circle,rgba(236,72,153,.05),transparent 65%);
    border-radius:50%;pointer-events:none
}
.blog-grid{display:grid;grid-template-columns:1fr 2fr;gap:60px;align-items:start;margin-top:64px;position:relative}
.blog-left{}
.blog-left h2{
    font-family:var(--ff);font-size:clamp(1.5rem,2.5vw,2.1rem);
    font-weight:800;text-transform:uppercase;margin-bottom:16px
}
.blog-left p{color:rgba(240,242,255,.6);line-height:1.8;margin-bottom:32px;font-size:.9rem}

.blog-posts{display:flex;flex-direction:column;gap:20px}
.blog-card{
    display:flex;gap:18px;
    background:var(--glass);border:1px solid var(--glass-border);
    border-radius:var(--r);padding:20px;
    transition:.4s var(--ease);
    backdrop-filter:blur(4px)
}
.blog-card:hover{
    background:var(--glass2);border-color:var(--glass-border2);
    transform:translateX(6px);
    box-shadow:var(--shadow-sm)
}
.blog-card-img{
    width:100px;height:80px;border-radius:10px;
    overflow:hidden;flex-shrink:0
}
.blog-card-img img{width:100%;height:100%;object-fit:cover;filter:brightness(.8);transition:.4s var(--ease)}
.blog-card:hover .blog-card-img img{filter:brightness(1);transform:scale(1.08)}
.blog-meta{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.blog-author{font-size:.72rem;font-weight:700;color:var(--teal)}
.blog-date{font-size:.72rem;color:rgba(240,242,255,.4)}
.blog-card h4{font-size:.88rem;font-weight:700;margin-bottom:6px;line-height:1.4}
.blog-card p{font-size:.78rem;color:rgba(240,242,255,.68);line-height:1.6}

/* ===== CONTACT ===== */
.contact{padding:120px 0;position:relative;overflow:hidden;background:var(--bg2)}
.contact::before{
    content:'';position:absolute;inset:0;
    background:
        radial-gradient(ellipse 60% 60% at 10% 90%,rgba(124,58,237,.12),transparent 60%),
        radial-gradient(ellipse 50% 50% at 90% 10%,rgba(0,212,255,.1),transparent 55%)
}
.contact::after{
    content:'';position:absolute;inset:0;
    background-image:
        linear-gradient(rgba(0,212,255,.015) 1px,transparent 1px),
        linear-gradient(90deg,rgba(0,212,255,.015) 1px,transparent 1px);
    background-size:80px 80px;pointer-events:none
}
.contact .container{position:relative;z-index:1}

.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}

.contact-info-heading{
    font-family:var(--ff);font-size:clamp(1.4rem,2.5vw,2rem);
    font-weight:800;text-transform:uppercase;margin:18px 0 20px;line-height:1.25
}
.contact-desc{color:rgba(240,242,255,.6);margin-bottom:40px;line-height:1.8}

.contact-details{display:flex;flex-direction:column;gap:18px}
.contact-item{display:flex;align-items:center;gap:16px;transition:.3s var(--ease)}
.contact-item:hover{transform:translateX(4px)}
.ci-icon{
    width:46px;height:46px;border-radius:12px;
    background:rgba(0,212,255,.08);
    display:flex;align-items:center;justify-content:center;
    color:var(--teal);flex-shrink:0;
    border:1px solid rgba(0,212,255,.12);
    transition:.3s var(--ease)
}
.contact-item:hover .ci-icon{
    box-shadow:0 0 20px rgba(0,212,255,.2);
    background:rgba(0,212,255,.12)
}
.ci-icon i{width:20px;height:20px}
.contact-item small{display:block;font-size:.7rem;color:rgba(240,242,255,.35);text-transform:uppercase;letter-spacing:2px;margin-bottom:3px}
.contact-item a,.contact-item span{font-size:.9rem;transition:.3s}
.contact-item a:hover{color:var(--teal)}

/* Form */
.contact-form-card{
    background:var(--glass);border:1px solid var(--glass-border);
    border-radius:var(--r);padding:38px;backdrop-filter:blur(16px);
    position:relative;overflow:hidden
}
.contact-form-card::before{
    content:'';position:absolute;top:0;left:0;right:0;
    height:2px;background:var(--gd);opacity:.5
}
.form-title{
    font-family:var(--ff);font-size:.82rem;font-weight:700;
    text-transform:uppercase;display:flex;align-items:center;gap:10px;
    margin-bottom:26px
}
.form-title i{width:18px;height:18px;color:var(--teal)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-group{margin-bottom:14px}
.form-group input,.form-group select,.form-group textarea{
    width:100%;padding:13px 16px;border-radius:var(--rs);
    border:1px solid var(--glass-border);
    background:rgba(255,255,255,.03);color:#f0f2ff;
    font-family:var(--fb);font-size:.88rem;
    transition:.3s var(--ease);outline:none
}
.form-group input::placeholder,.form-group textarea::placeholder{color:rgba(240,242,255,.3)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
    border-color:var(--teal);
    background:rgba(0,212,255,.04);
    box-shadow:0 0 0 3px rgba(0,212,255,.1),0 0 20px rgba(0,212,255,.05)
}
.form-group select{appearance:none;cursor:pointer}
.form-group option{background:var(--bg2)}
.form-group textarea{resize:vertical;min-height:120px}

/* ===== FOOTER ===== */
.footer{
    padding:70px 0 24px;
    background:var(--bg);
    border-top:1px solid var(--glass-border);
    position:relative
}
.footer::before{
    content:'';position:absolute;top:0;left:50%;
    transform:translateX(-50%);
    width:200px;height:1px;
    background:var(--gd);
    box-shadow:0 0 20px rgba(0,212,255,.3)
}
.footer-top{
    display:grid;
    grid-template-columns:1.8fr 1fr 1fr 1fr;
    gap:48px;margin-bottom:50px
}
.footer-brand{}
.footer-brand p{font-size:.84rem;color:rgba(240,242,255,.58);margin-top:16px;max-width:260px;line-height:1.7}
.footer-social{display:flex;gap:10px;margin-top:20px}
.footer-social a{
    width:36px;height:36px;border-radius:50%;
    border:1px solid var(--glass-border);
    display:flex;align-items:center;justify-content:center;
    color:rgba(240,242,255,.5);transition:.3s
}
.footer-social a:hover{border-color:var(--teal);color:var(--teal);box-shadow:0 0 14px rgba(0,212,255,.2)}
.footer-social a i{width:15px;height:15px}
.footer-col h4{
    font-family:var(--ff);font-size:.68rem;font-weight:700;
    text-transform:uppercase;letter-spacing:3px;margin-bottom:20px;
    color:rgba(240,242,255,.9)
}
.footer-col a,.footer-col span{
    display:block;font-size:.83rem;
    color:rgba(240,242,255,.58);margin-bottom:11px;transition:.3s
}
.footer-col a:hover{color:var(--teal);transform:translateX(3px)}
.footer-bottom{
    border-top:1px solid var(--glass-border);padding-top:22px;
    display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px
}
.footer-bottom p{font-size:.78rem;color:rgba(240,242,255,.3)}
.footer-bottom-link{
    font-size:.78rem;color:rgba(240,242,255,.3);
    background:var(--gd);-webkit-background-clip:text;background-clip:text;color:transparent
}

/* ===== ABOUT â€” personal photo (circular portrait) ===== */
.about-img-third{
    position:absolute;
    top:-20px;left:-20px;
    width:130px;height:130px;border-radius:50%;overflow:hidden;
    border:4px solid var(--bg);
    box-shadow:0 16px 48px rgba(0,0,0,.5),0 0 30px rgba(0,212,255,.2),
               inset 0 0 30px rgba(0,0,0,.2);
    z-index:5;
    transition:.4s var(--ease)
}
.about-img-third:hover{
    transform:scale(1.08);
    box-shadow:0 16px 48px rgba(0,0,0,.5),0 0 40px rgba(0,212,255,.35)
}
.about-img-third img{
    width:100%;height:100%;object-fit:cover;
    object-position:center 15%;
    filter:brightness(.95) saturate(1.1);
    transition:.4s
}
.about-img-third:hover img{filter:brightness(1) saturate(1.2)}
.about-img-third::before{
    content:'';position:absolute;inset:-4px;
    border-radius:50%;
    background:conic-gradient(from 0deg,var(--teal),var(--purple),var(--pink),var(--teal));
    z-index:-1;opacity:.6;
    animation:geoSpin 8s linear infinite
}
.about-img-third::after{
    content:'';position:absolute;inset:0;border-radius:50%;
    background:linear-gradient(135deg,rgba(0,212,255,.1),transparent);
    pointer-events:none
}

/* ===== WHY â€” collage mini ===== */
.collage-mini{
    position:absolute;
    top:-20px;right:-20px;
    width:110px;border-radius:14px;overflow:hidden;
    border:2px solid var(--bg);
    box-shadow:0 10px 30px rgba(0,0,0,.5),0 0 20px rgba(168,85,247,.15);
    z-index:3
}
.collage-mini img{width:100%;height:90px;object-fit:cover;filter:brightness(.85)}

/* ===== PORTFOLIO / SHOWCASE ===== */
.portfolio{
    padding:80px 0;background:var(--bg);
    position:relative;overflow:hidden
}
.portfolio::before{
    content:'';position:absolute;
    top:50%;left:-10%;
    width:600px;height:600px;
    background:radial-gradient(circle,rgba(168,85,247,.06),transparent 65%);
    border-radius:50%;pointer-events:none;transform:translateY(-50%)
}
.portfolio::after{
    content:'';position:absolute;
    bottom:10%;right:-5%;
    width:400px;height:400px;
    background:radial-gradient(circle,rgba(0,212,255,.05),transparent 65%);
    border-radius:50%;pointer-events:none
}

/* Bento Grid */
.portfolio-bento{
    display:grid;
    grid-template-columns:repeat(6,1fr);
    grid-template-rows:auto;
    gap:14px;
    margin-top:64px;
    position:relative;z-index:1
}
.pb-item{
    position:relative;border-radius:18px;overflow:hidden;
    border:1px solid var(--glass-border);cursor:pointer;
    transition:.45s var(--ease)
}
.pb-item:hover{
    border-color:var(--glass-border2);
    transform:scale(1.02);
    box-shadow:var(--shadow-lg),0 0 40px rgba(0,212,255,.12);
    z-index:2
}
.pb-item img{
    width:100%;height:100%;object-fit:cover;
    filter:brightness(.7) saturate(1.1);
    transition:.6s var(--ease);display:block
}
.pb-item:hover img{filter:brightness(.85) saturate(1.2);transform:scale(1.06)}

/* Bento cell sizes */
.pb-large{
    grid-column:span 3;grid-row:span 2;height:340px
}
.pb-medium{
    grid-column:span 2;height:160px
}
.pb-small{
    grid-column:span 1;height:160px
}

/* Overlay */
.pb-overlay{
    position:absolute;bottom:0;left:0;right:0;
    padding:16px 20px;
    background:linear-gradient(to top,rgba(13,13,31,.85) 0%,transparent 100%);
    transform:translateY(8px);opacity:0;
    transition:.35s var(--ease)
}
.pb-item:hover .pb-overlay{opacity:1;transform:translateY(0)}
.pb-tag{
    display:inline-block;
    padding:3px 10px;border-radius:50px;
    background:rgba(0,212,255,.2);border:1px solid rgba(0,212,255,.3);
    font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;
    color:var(--teal);margin-bottom:6px
}
.pb-overlay h4{
    font-family:var(--ff);font-size:.8rem;font-weight:700;
    text-transform:uppercase;color:#fff;line-height:1.3
}

/* ===== CONTACT VISUAL ===== */
.contact-visual{
    position:relative;margin-bottom:32px;height:220px
}
.contact-visual-main{
    position:absolute;top:0;left:0;right:60px;
    border-radius:18px;overflow:hidden;
    border:1px solid var(--glass-border2);
    box-shadow:var(--shadow-lg);
    height:180px
}
.contact-visual-main img{width:100%;height:100%;object-fit:cover;filter:brightness(.7);transition:.5s var(--ease)}
.contact-visual-main:hover img{filter:brightness(.85);transform:scale(1.05)}
.contact-visual-main::after{
    content:'';position:absolute;inset:0;
    background:linear-gradient(135deg,rgba(0,212,255,.08),rgba(168,85,247,.08));
    pointer-events:none
}
.contact-visual-accent{
    position:absolute;bottom:0;right:0;
    width:160px;border-radius:14px;overflow:hidden;
    border:3px solid var(--bg);
    box-shadow:0 12px 40px rgba(0,0,0,.5),0 0 24px rgba(168,85,247,.2);
    z-index:2
}
.contact-visual-accent img{width:100%;height:120px;object-fit:cover;filter:brightness(.82)}
.contact-visual-accent::after{
    content:'';position:absolute;inset:0;
    background:linear-gradient(135deg,rgba(168,85,247,.12),transparent);
    pointer-events:none
}

/* ===== REVEAL ANIMATION ===== */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .75s ease,transform .75s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-40px);transition:opacity .75s ease,transform .75s ease}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(40px);transition:opacity .75s ease,transform .75s ease}
.reveal-right.visible{opacity:1;transform:translateX(0)}

/* ===== SUCCESS TOAST ===== */
.toast{
    position:fixed;bottom:80px;right:32px;z-index:9000;
    background:rgba(0,212,255,.12);border:1px solid rgba(0,212,255,.3);
    border-radius:12px;padding:14px 22px;
    font-size:.88rem;font-weight:600;color:var(--teal);
    backdrop-filter:blur(16px);
    transform:translateY(20px);opacity:0;
    transition:.4s var(--ease);pointer-events:none
}
.toast.show{transform:translateY(0);opacity:1}

/* ===== RESPONSIVE ===== */
/* Legacy media queries removed; responsive rules consolidated in responsive.css */

/* ============================================================
   PREMIUM GLOBAL UPGRADES â€” v3.1
   ============================================================ */

/* â”€â”€ Scrollbar â”€â”€ */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{
    background:linear-gradient(to bottom,var(--teal),var(--purple));
    border-radius:3px
}
::-webkit-scrollbar-thumb:hover{opacity:.8}

/* â”€â”€ Section fade separators (gradient top edge) â”€â”€ */
.services::after,
.why::after,
.process::after{
    content:'';position:absolute;
    top:0;left:0;right:0;height:1px;
    background:linear-gradient(to right,transparent,rgba(255,255,255,.06),transparent);
    pointer-events:none;z-index:2
}

/* â”€â”€ Why-cards â€” animated gradient border on hover â”€â”€ */
.why-card{
    position:relative;overflow:hidden
}
.why-card::before{
    content:'';position:absolute;inset:-2px;
    background:conic-gradient(from 0deg,var(--teal),var(--purple),var(--pink),var(--teal));
    border-radius:calc(var(--r) + 2px);
    opacity:0;transition:opacity .4s ease;z-index:0
}
.why-card:hover::before{opacity:1}
.why-card-icon,.why-card-text{position:relative;z-index:1}
.why-card > *{position:relative;z-index:1}

/* â”€â”€ Stats â€” number glow â”€â”€ */
.stat-num,.stat-suffix{
    text-shadow:0 0 30px rgba(0,212,255,.25)
}
.stat-block:hover .stat-num,.stat-block:hover .stat-suffix{
    text-shadow:0 0 40px rgba(0,212,255,.45)
}

/* â”€â”€ Process steps â€” top line on active/hover â”€â”€ */
.process-step::before{
    content:'';position:absolute;top:0;left:0;right:0;height:2px;
    background:var(--gd);transform:scaleX(0);transform-origin:left;
    transition:.4s var(--ease);z-index:1
}
.process-step:hover::before{transform:scaleX(1)}

/* â”€â”€ Blog cards â€” left accent bar â”€â”€ */
.blog-card{
    border-left:3px solid transparent;
    transition:border-color .3s ease, background .3s ease, transform .3s ease, box-shadow .3s ease
}
.blog-card:hover{
    border-left-color:var(--teal)
}

/* â”€â”€ Contact form â€” improved input group â”€â”€ */
.form-group{position:relative}
.form-group label{
    display:block;font-size:.7rem;font-weight:700;
    text-transform:uppercase;letter-spacing:2px;
    color:rgba(240,242,255,.4);margin-bottom:6px
}
.form-group input:focus ~ label,
.form-group textarea:focus ~ label{
    color:var(--teal)
}
.contact-form-card{
    border-top:2px solid transparent;
    background-image:
        linear-gradient(var(--bg2),var(--bg2)),
        linear-gradient(135deg,var(--teal),var(--purple));
    background-origin:border-box;
    background-clip:padding-box,border-box
}
.contact-form-card::before{display:none}

/* â”€â”€ Eyebrow lines â€” slightly longer â”€â”€ */
.ey-line{width:48px}

/* â”€â”€ Glow line â€” animated pulse â”€â”€ */
.glow-line{
    animation:glowPulse 3s ease-in-out infinite
}
@keyframes glowPulse{
    0%,100%{box-shadow:0 0 12px rgba(0,212,255,.3),0 0 24px rgba(0,212,255,.1)}
    50%{box-shadow:0 0 20px rgba(0,212,255,.5),0 0 40px rgba(168,85,247,.2),0 0 60px rgba(0,212,255,.1)}
}

/* â”€â”€ Footer brand gradient text â”€â”€ */
.footer-brand .logo-accent{
    font-size:1.4rem
}

/* â”€â”€ Section title â€” subtle text shadow â”€â”€ */
.section-title{
    text-shadow:0 0 60px rgba(168,85,247,.08)
}

/* â”€â”€ Reveal animation improved â€” smoother â”€â”€ */
.reveal,.reveal-left,.reveal-right{
    opacity:0;transition:opacity .7s var(--ease),transform .7s var(--ease)
}
.reveal{transform:translateY(36px)}
.reveal-left{transform:translateX(-36px)}
.reveal-right{transform:translateX(36px)}
.reveal.visible,.reveal-left.visible,.reveal-right.visible{
    opacity:1;transform:translate(0)
}

/* â”€â”€ Ticker â€” fade edges â”€â”€ */
.ticker-wrap{
    -webkit-mask:linear-gradient(to right,transparent 0%,black 8%,black 92%,transparent 100%);
    mask:linear-gradient(to right,transparent 0%,black 8%,black 92%,transparent 100%)
}

/* â”€â”€ Hero desc strong highlight â”€â”€ */
.hero-desc strong{
    background:linear-gradient(135deg,var(--teal),var(--purple));
    -webkit-background-clip:text;background-clip:text;color:transparent
}

/* â”€â”€ Why cards â€” tighter inner padding if color accent visible â”€â”€ */
.why-card{
    background:var(--glass);position:relative;z-index:0
}

/* ============================================================
   PREMIUM POLISH v3.2 â€” Final touches
   ============================================================ */

/* Image lazy-load fade-in */
img[loading="lazy"]{opacity:0;transition:opacity .5s ease}
img.loaded{opacity:1}

/* Blog card image hover zoom */
.blog-card-img{overflow:hidden}
.blog-card-img img{
    transition:transform .5s cubic-bezier(.4,0,.2,1),filter .5s cubic-bezier(.4,0,.2,1);
    filter:brightness(.8) saturate(.9)
}
.blog-card:hover .blog-card-img img{
    transform:scale(1.06);filter:brightness(.95) saturate(1.05)
}

/* Footer gradient top border */
.footer{position:relative}
.footer::before{
    content:'';position:absolute;top:0;left:0;right:0;height:1px;
    background:linear-gradient(to right,transparent,rgba(0,212,255,.2),rgba(168,85,247,.15),transparent)
}

/* Nav active indicator dot */
.nav-link.active::before{
    content:'';position:absolute;
    bottom:-7px;left:50%;transform:translateX(-50%);
    width:4px;height:4px;border-radius:50%;
    background:#00d4ff;box-shadow:0 0 8px #00d4ff
}

/* Stats hover scale */
.stat-block{cursor:default;transition:transform .3s cubic-bezier(.4,0,.2,1)}
.stat-block:hover{transform:translateY(-4px)}
.stat-block:hover .stat-num,.stat-block:hover .stat-suffix{text-shadow:0 0 40px rgba(0,212,255,.5)}

/* Contact inputs premium focus glow */
.contact-form input:focus,.contact-form textarea:focus{
    outline:none;
    border-color:rgba(0,212,255,.5) !important;
    box-shadow:0 0 0 3px rgba(0,212,255,.1),0 0 20px rgba(0,212,255,.08) !important;
    background:rgba(0,212,255,.03) !important
}

/* Process step number hover */
.step-num{transition:transform .3s cubic-bezier(.4,0,.2,1),color .3s ease}
.process-step:hover .step-num{transform:scale(1.12);color:#00d4ff}

/* Services, blog, etc: position relative */
.services,.why,.process,.portfolio,.blog,.contact,.vreel{position:relative}

/* Ticker items hover */
.ticker-item{transition:opacity .3s ease;cursor:default}
.ticker-item:hover{opacity:.6}

/* Hero title tighter kerning */
.hero-title{letter-spacing:-1px}

/* Eyebrow lines colored */
.ey-line{background:linear-gradient(to right,#00d4ff,#a855f7) !important;opacity:.35}

/* CTA strip glow */
.bp-cta-strip{position:relative;overflow:hidden}
.bp-cta-strip::after{
    content:'';position:absolute;inset:0;
    background:radial-gradient(ellipse 60% 120% at 100% 50%,rgba(0,212,255,.05),transparent);
    pointer-events:none
}

/* Newsletter removed */

/* Bento cards subtle gradient bg */
.bp-bento-card{
    background:linear-gradient(160deg,rgba(255,255,255,.04) 0%,rgba(255,255,255,.015) 100%)
}






/* ===== LOCAL SEO SECTION ===== */
.local-seo-section{padding:80px 0;background:var(--bg3);position:relative}
.local-seo-section::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,rgba(0,212,255,.15),transparent)}
.local-cities-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin:44px 0 32px}
.local-city-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:22px 16px;border-radius:16px;background:var(--glass);border:1px solid var(--glass-border);text-decoration:none;color:inherit;text-align:center;transition:.3s var(--ease)}
.local-city-card:hover{border-color:rgba(0,212,255,.25);background:rgba(0,212,255,.04);transform:translateY(-3px)}
.local-city-card i{width:22px;height:22px;color:var(--teal)}
.local-city-card strong{font-family:var(--ff);font-size:.78rem;font-weight:800;text-transform:uppercase;color:#f0f2ff}
.local-city-card span{font-size:.7rem;color:rgba(240,242,255,.45);text-align:center;line-height:1.4}
.local-city-main{background:linear-gradient(135deg,rgba(0,212,255,.08),rgba(168,85,247,.05));border-color:rgba(0,212,255,.2)}
.local-seo-note{font-size:.88rem;color:rgba(240,242,255,.5);text-align:center;line-height:1.85;max-width:680px;margin:0 auto}
.local-seo-note strong{color:rgba(240,242,255,.75)}
.local-seo-note a{color:var(--teal);text-decoration:underline;text-decoration-color:rgba(0,212,255,.3)}


/* ===== ENHANCED CONTACT FORM ===== */
.form-error{
    display:none;font-size:.72rem;color:#f87171;margin-top:4px;
    padding-left:2px;font-weight:500
}
.form-group.has-error input,
.form-group.has-error textarea,
.form-group.has-error select{
    border-color:rgba(248,113,113,.5) !important;
    box-shadow:0 0 0 3px rgba(248,113,113,.08) !important
}
.form-group.has-error .form-error,
.form-consent.has-error .form-error{display:block}
.form-optional{font-weight:400;color:rgba(240,242,255,.25);font-size:.65rem}
.form-consent{margin-bottom:18px}
.form-checkbox-label{
    display:flex;align-items:flex-start;gap:12px;
    font-size:.78rem;color:rgba(240,242,255,.55);cursor:pointer;
    line-height:1.5
}
.form-checkbox-label input[type="checkbox"]{display:none}
.form-checkmark{
    width:20px;height:20px;min-width:20px;border-radius:6px;
    border:1.5px solid var(--glass-border2);
    background:rgba(255,255,255,.03);
    display:flex;align-items:center;justify-content:center;
    transition:.3s var(--ease);margin-top:1px;position:relative
}
.form-checkbox-label input:checked + .form-checkmark{
    background:var(--gd);border-color:var(--teal)
}
.form-checkbox-label input:checked + .form-checkmark::after{
    content:'\2713';color:#fff;font-size:.7rem;font-weight:900
}
.form-consent.has-error .form-checkmark{
    border-color:rgba(248,113,113,.5)
}
.form-note{
    display:flex;align-items:center;gap:8px;justify-content:center;
    font-size:.75rem;color:rgba(240,242,255,.35);margin-top:16px
}
.form-note i{width:14px;height:14px;color:var(--teal);flex-shrink:0}
.btn-loader{display:inline-flex;align-items:center;gap:8px}
.spinner{
    width:16px;height:16px;border:2px solid rgba(255,255,255,.3);
    border-top-color:#fff;border-radius:50%;
    animation:spin .6s linear infinite;display:inline-block
}
@keyframes spin{to{transform:rotate(360deg)}}
.btn-text,.btn-loader{pointer-events:none}

/* ===== TICKER MASK ===== */
.ticker-wrap{
    -webkit-mask:linear-gradient(to right,transparent 0%,black 5%,black 95%,transparent 100%);
    mask:linear-gradient(to right,transparent 0%,black 5%,black 95%,transparent 100%)
}

/* ===== PREMIUM PORTFOLIO LIST ===== */
.portfolio-list-wrapper {
    display: flex;
    gap: 40px;
    margin-top: 36px;
    align-items: flex-start;
    position: relative;
    z-index: 1;
}
.pl-list {
    flex: 1;
    display: flex;
    flex-direction: column;
}
.pl-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 16px 14px 20px;
    border-bottom: 1px solid rgba(255,255,255,0.06);
    text-decoration: none !important;
    transition: all 0.4s cubic-bezier(.4,0,.2,1);
    cursor: pointer;
    position: relative;
    border-radius: 10px;
    margin: 0 -16px;
    gap: 12px;
}
.pl-row:first-child { border-top: 1px solid rgba(255,255,255,0.06); }

/* Animated left accent bar */
.pl-row::before {
    content: '';
    position: absolute;
    left: 0; top: 50%;
    width: 3px; height: 0;
    border-radius: 3px;
    background: var(--gd);
    transition: height 0.4s cubic-bezier(.4,0,.2,1), top 0.4s cubic-bezier(.4,0,.2,1);
    box-shadow: 0 0 12px rgba(0,212,255,0.4);
    opacity: 0;
}
.pl-row:hover::before {
    height: 60%;
    top: 20%;
    opacity: 1;
}

/* Ambient hover glow */
.pl-row::after {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 10px;
    background: linear-gradient(135deg, rgba(0,212,255,0.04) 0%, rgba(168,85,247,0.03) 50%, rgba(0,212,255,0.02) 100%);
    opacity: 0;
    transition: opacity 0.4s ease;
    pointer-events: none;
    z-index: -1;
}
.pl-row:hover::after {
    opacity: 1;
}
.pl-row:hover {
    border-color: transparent;
    transform: translateX(4px);
}

.pl-title { display: flex; align-items: center; gap: 16px; flex: 1; min-width: 0; }
.pl-text {
    display: flex;
    flex-direction: column;
    gap: 2px;
    transition: transform 0.4s cubic-bezier(.4,0,.2,1);
    min-width: 0;
}
.pl-num {
    font-size: 0.78rem;
    font-weight: 800;
    color: rgba(255,255,255,0.15);
    font-family: var(--ff);
    transition: all 0.4s ease;
    letter-spacing: 1px;
    flex-shrink: 0;
    min-width: 24px;
}
.pl-row:hover .pl-num {
    background: var(--gd);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    text-shadow: none;
    filter: brightness(1.2);
}
.pl-title h3 {
    font-size: clamp(1rem, 1.8vw, 1.4rem);
    font-weight: 800;
    color: rgba(255,255,255,0.4);
    font-family: var(--ff);
    text-transform: uppercase;
    transition: all 0.4s cubic-bezier(.4,0,.2,1);
    margin: 0;
    letter-spacing: -0.3px;
    line-height: 1.15;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.pl-scope {
    font-size: 0.72rem;
    color: rgba(255,255,255,0.28);
    font-weight: 400;
    margin: 0;
    transition: all 0.4s ease;
    line-height: 1.35;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Category tag — pill badge always visible */
.pl-cat {
    font-size: 0.6rem;
    color: var(--teal);
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    padding: 4px 11px;
    border-radius: 50px;
    background: rgba(0,212,255,0.06);
    border: 1px solid rgba(0,212,255,0.12);
    white-space: nowrap;
    flex-shrink: 0;
    transition: all 0.4s ease;
    backdrop-filter: blur(4px);
}
.pl-row:hover .pl-cat {
    background: rgba(0,212,255,0.12);
    border-color: rgba(0,212,255,0.25);
    box-shadow: 0 0 16px rgba(0,212,255,0.15);
    color: #fff;
}

.pl-arrow {
    width: 38px; height: 38px; border-radius: 50%;
    border: 1px solid rgba(255,255,255,0.08);
    display: flex; align-items: center; justify-content: center;
    color: rgba(255,255,255,0.4); transition: all 0.4s cubic-bezier(.4,0,.2,1);
    flex-shrink: 0;
    position: relative;
    overflow: hidden;
}
.pl-arrow::before {
    content: '';
    position: absolute; inset: 0;
    border-radius: 50%;
    background: var(--gd);
    opacity: 0;
    transition: opacity 0.4s ease;
}
.pl-arrow i { width: 16px; height: 16px; position: relative; z-index: 1; }

.pl-row:hover .pl-title .pl-text { transform: translateX(8px); }
.pl-row:hover .pl-title h3 { color: #fff; text-shadow: 0 0 30px rgba(0,212,255,0.15); }
.pl-row:hover .pl-scope { color: rgba(255,255,255,0.65); }
.pl-row:hover .pl-arrow {
    border-color: transparent;
    color: #fff;
    transform: rotate(0deg) scale(1.08);
    box-shadow: 0 0 24px rgba(0,212,255,0.35), 0 4px 16px rgba(0,0,0,0.3);
}
.pl-row:hover .pl-arrow::before { opacity: 1; }

/* ── Preview Card — Device Frame Style ── */
.pl-preview {
    position: sticky;
    top: 120px;
    width: 340px;
    flex-shrink: 0;
    border-radius: 18px;
    padding: 2px;
    background: linear-gradient(160deg, rgba(0,212,255,0.25), rgba(168,85,247,0.2), rgba(236,72,153,0.15), rgba(0,212,255,0.1));
    box-shadow:
        0 20px 60px rgba(0,0,0,0.55),
        0 0 30px rgba(0,212,255,0.08),
        0 0 60px rgba(168,85,247,0.05);
    animation: previewGlow 6s ease-in-out infinite;
}
@keyframes previewGlow {
    0%, 100% { box-shadow: 0 20px 60px rgba(0,0,0,0.55), 0 0 30px rgba(0,212,255,0.08), 0 0 60px rgba(168,85,247,0.05); }
    50% { box-shadow: 0 20px 60px rgba(0,0,0,0.55), 0 0 40px rgba(0,212,255,0.12), 0 0 80px rgba(168,85,247,0.08); }
}
.pl-preview-inner {
    border-radius: 16px;
    overflow: hidden;
    height: 380px;
    background: var(--bg);
    position: relative;
}
/* Top bar mimicking a device/browser frame */
.pl-preview-bar {
    height: 28px;
    background: rgba(255,255,255,0.04);
    border-bottom: 1px solid rgba(255,255,255,0.06);
    display: flex;
    align-items: center;
    padding: 0 12px;
    gap: 6px;
    flex-shrink: 0;
}
.pl-preview-dot {
    width: 7px; height: 7px;
    border-radius: 50%;
    background: rgba(255,255,255,0.12);
    transition: background 0.3s;
}
.pl-preview-dot:nth-child(1) { background: rgba(248,113,113,0.5); }
.pl-preview-dot:nth-child(2) { background: rgba(251,191,36,0.5); }
.pl-preview-dot:nth-child(3) { background: rgba(52,211,153,0.5); }
.pl-preview-url {
    margin-left: 10px;
    font-size: 0.6rem;
    color: rgba(255,255,255,0.25);
    font-family: var(--fb);
    letter-spacing: 0.5px;
    background: rgba(255,255,255,0.04);
    padding: 3px 10px;
    border-radius: 6px;
    flex: 1;
    text-align: center;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    transition: color 0.3s;
}
.pl-preview img {
    width: 100%; height: calc(100% - 28px); object-fit: cover; object-position: top;
    transition: opacity 0.35s ease, transform 0.7s cubic-bezier(0.25, 1, 0.5, 1);
    display: block;
}

/* Staggered entrance for rows */
.pl-row {
    opacity: 0;
    transform: translateY(16px) translateX(0);
}
.pl-row.pl-visible {
    opacity: 1;
    transform: translateY(0) translateX(0);
    transition: opacity 0.6s cubic-bezier(.4,0,.2,1), transform 0.6s cubic-bezier(.4,0,.2,1);
}

/* ── Tablet ≤ 1100px ── */
@media (max-width: 1100px) {
    .portfolio-list-wrapper {
        flex-direction: column-reverse;
        gap: 28px;
        margin-top: 32px;
    }
    .pl-preview {
        width: 100%;
        border-radius: 16px;
        padding: 2px;
    }
    .pl-preview-inner {
        height: 300px;
        border-radius: 14px;
    }
    .pl-row {
        padding: 13px 14px 13px 18px;
        margin: 0 -14px;
        border-radius: 10px;
    }
    .pl-title { gap: 14px; }
    .pl-title h3 { font-size: clamp(1rem, 2.5vw, 1.35rem); }
    .pl-num { font-size: 0.75rem; }
    .pl-cat { font-size: 0.55rem; letter-spacing: 1px; padding: 3px 9px; }
    .pl-arrow { width: 36px; height: 36px; }
    .pl-arrow i { width: 14px; height: 14px; }
    .pl-scope { font-size: 0.68rem; }
}

/* ── Phone ≤ 768px ── */
@media (max-width: 768px) {
    .portfolio-list-wrapper {
        gap: 20px;
        margin-top: 24px;
    }
    .pl-preview-inner { height: 240px; border-radius: 12px; }
    .pl-preview { border-radius: 14px; }
    .pl-preview-bar { height: 24px; padding: 0 10px; gap: 5px; }
    .pl-preview-dot { width: 6px; height: 6px; }
    .pl-preview-url { font-size: 0.55rem; padding: 2px 8px; }
    .pl-preview img { height: calc(100% - 24px); }

    .pl-row {
        padding: 12px 12px 12px 14px;
        margin: 0 -8px;
        border-radius: 10px;
        gap: 10px;
        flex-wrap: nowrap;
    }
    .pl-row::before { display: none; } /* hide accent bar on touch */
    .pl-title { gap: 10px; }
    .pl-title h3 {
        font-size: clamp(0.9rem, 3.5vw, 1.2rem);
        white-space: normal;
        line-height: 1.2;
    }
    .pl-scope {
        font-size: 0.65rem;
        white-space: normal;
        display: -webkit-box;
        -webkit-line-clamp: 1;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }
    .pl-num { font-size: 0.7rem; min-width: 22px; }
    .pl-cat { display: none; } /* hide tag on phone — saves space */
    .pl-arrow { width: 34px; height: 34px; }
    .pl-arrow i { width: 14px; height: 14px; }

    /* Make rows always visible on touch (no hover) */
    .pl-row:hover { transform: none; }
    .pl-row:hover::after { opacity: 0; }
}

/* ── Small phone ≤ 480px ── */
@media (max-width: 480px) {
    .portfolio { padding: 56px 0; }
    .portfolio-list-wrapper { gap: 16px; margin-top: 20px; }

    .pl-preview-inner { height: 200px; border-radius: 10px; }
    .pl-preview { border-radius: 12px; }
    .pl-preview-bar { display: none; } /* hide browser bar */
    .pl-preview img { height: 100%; }

    .pl-row {
        padding: 11px 10px 11px 12px;
        margin: 0 -6px;
        border-radius: 8px;
        gap: 8px;
    }
    .pl-title { gap: 8px; }
    .pl-title h3 { font-size: clamp(0.85rem, 4vw, 1.05rem); }
    .pl-num { font-size: 0.65rem; min-width: 20px; }
    .pl-scope { display: none; } /* hide scope on very small screens */
    .pl-arrow { width: 30px; height: 30px; }
    .pl-arrow i { width: 12px; height: 12px; }
    .pl-text { gap: 0; }
}

/* ── Tiny ≤ 360px ── */
@media (max-width: 360px) {
    .pl-preview-inner { height: 170px; }
    .pl-row { padding: 10px 8px 10px 10px; margin: 0 -4px; }
    .pl-title h3 { font-size: 0.82rem; }
    .pl-num { font-size: 0.6rem; }
    .pl-arrow { width: 28px; height: 28px; }
}
