/* ============================================================
   SAMIR MANGLAM PORTFOLIO — MAIN CSS (CLEAN FINAL)
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=Outfit:wght@300;400;500;600;700&family=Dancing+Script:wght@700;800&family=JetBrains+Mono:wght@400;500&display=swap');

:root {
  --bg:#080812; --bg2:#0f0f1e; --bg3:#13132a;
  --card:rgba(255,255,255,.04); --glass:rgba(255,255,255,.06); --border:rgba(255,255,255,.09);
  --cyan:#00e5ff; --gold:#f0a500; --purple:#7c3aed; --green:#00c864; --red:#ff4444;
  --grad:linear-gradient(135deg,#00e5ff,#7c3aed,#f0a500);
  --text:#f0f0f8; --text2:#8888aa; --text3:#444460;
  --fh:'Syne',sans-serif; --fb:'Outfit',sans-serif; --fm:'JetBrains Mono',monospace;
  --r1:8px; --r2:16px; --r3:24px; --r4:40px;
  --sh:0 8px 40px rgba(0,0,0,.6); --glow:0 0 40px rgba(0,229,255,.2);
  --tr:all .3s ease;
}
[data-theme="light"]{
  --bg:#f4f4fa; --bg2:#eaeaf5; --bg3:#e0e0f0;
  --card:rgba(255,255,255,.85); --glass:rgba(255,255,255,.75); --border:rgba(0,0,0,.08);
  --text:#0a0a18; --text2:#44445a; --text3:#8888a0; --sh:0 8px 40px rgba(0,0,0,.1);
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:90px;overflow-x:hidden}
body{font-family:var(--fb);background:var(--bg);color:var(--text);line-height:1.7;overflow-x:hidden;transition:background .3s,color .3s}
@media(pointer:coarse){body{cursor:auto!important}}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
::selection{background:rgba(0,229,255,.2);color:var(--text)}

/* ── Loader ── */
#loader{position:fixed;inset:0;background:var(--bg);z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;transition:opacity .5s ease,visibility .5s ease}
#loader.out{opacity:0;visibility:hidden;pointer-events:none}
.ld-logo{animation:ldPulse 1.2s ease-in-out infinite}
@keyframes ldPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.07)}}
.ld-bar{width:180px;height:3px;background:rgba(255,255,255,.1);border-radius:3px;overflow:hidden}
.ld-bar::after{content:'';display:block;height:100%;width:40%;background:var(--grad);animation:ldSlide 1s ease-in-out infinite}
@keyframes ldSlide{0%{transform:translateX(-100%)}100%{transform:translateX(350%)}}

/* ── Scroll progress ── */
#prog{position:fixed;top:0;left:0;height:2px;background:var(--grad);width:0%;z-index:9998;transition:width .1s}

/* ── Cursor (desktop only) ── */
#cur-dot{position:fixed;width:8px;height:8px;background:var(--cyan);border-radius:50%;pointer-events:none;z-index:9997;transform:translate(-50%,-50%)}
#cur-ring{position:fixed;width:36px;height:36px;border:1.5px solid rgba(0,229,255,.55);border-radius:50%;pointer-events:none;z-index:9997;transform:translate(-50%,-50%);transition:width .25s,height .25s}
#cur-ring.h{width:52px;height:52px;border-color:var(--gold)}
@media(pointer:coarse){#cur-dot,#cur-ring{display:none!important}}

/* ── PILL NAVBAR ── */
#nav{position:fixed;top:16px;left:50%;transform:translateX(-50%);width:calc(100% - 40px);max-width:980px;height:64px;padding:0 20px;display:flex;align-items:center;justify-content:space-between;z-index:900;background:rgba(10,10,22,.88);backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.1);border-radius:50px;box-shadow:0 8px 32px rgba(0,0,0,.5);transition:all .3s}
#nav.sc{background:rgba(6,6,18,.97)}
[data-theme="light"] #nav{background:rgba(255,255,255,.92);border-color:rgba(0,0,0,.1)}
.nav-logo{display:flex;align-items:center;flex-shrink:0}
.nav-logo img{height:46px;width:auto;filter:drop-shadow(0 2px 10px rgba(240,165,0,.4));transition:all .3s}
.nav-logo img:hover{transform:scale(1.06)}
.nav-links{display:flex;list-style:none;gap:.1rem;align-items:center;margin:0 8px}
.nav-links>li{position:relative}
.nav-links>li>a{font-size:.78rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:rgba(255,255,255,.7);padding:8px 13px;border-radius:50px;transition:all .25s;display:flex;align-items:center;gap:5px;white-space:nowrap;border:1px solid transparent;position:relative}
.nav-links>li>a:hover,.nav-links>li>a.active{color:#fff;background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.12);text-shadow:0 0 12px rgba(0,229,255,.4);box-shadow:0 0 14px rgba(0,229,255,.1)}
[data-theme="light"] .nav-links>li>a{color:rgba(0,0,0,.7)}
[data-theme="light"] .nav-links>li>a:hover,[data-theme="light"] .nav-links>li>a.active{color:#111;background:rgba(0,0,0,.07);text-shadow:none}
.dd-arrow{font-size:.55rem;opacity:.6;transition:transform .2s;display:inline-block}
.nav-links li:hover .dd-arrow{transform:rotate(180deg)}
.dd-menu{display:none;position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%);background:rgba(8,8,20,.98);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:8px;min-width:200px;z-index:999;box-shadow:0 16px 48px rgba(0,0,0,.6)}
[data-theme="light"] .dd-menu{background:rgba(255,255,255,.98);border-color:rgba(0,0,0,.1)}
.nav-links li:hover .dd-menu,.nav-links li:focus-within .dd-menu{display:block;animation:ddIn .2s ease}
@keyframes ddIn{from{opacity:0;transform:translateX(-50%) translateY(-8px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
.dd-menu a{display:flex;align-items:center;gap:9px;padding:9px 14px;border-radius:10px;font-size:.82rem;color:var(--text2);transition:all .18s}
.dd-menu a:hover{background:rgba(0,229,255,.1);color:var(--cyan);padding-left:18px}
.nav-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
#search-btn,#th-btn{width:38px;height:38px;border:1px solid var(--border);border-radius:50%;background:var(--glass);color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.95rem;transition:var(--tr)}
#search-btn:hover,#th-btn:hover{border-color:var(--cyan)}
.nav-cta{padding:10px 22px;border-radius:50px;background:linear-gradient(135deg,#00e5ff,#7c3aed,#f0a500);background-size:200% 200%;animation:ctaShift 3s ease infinite;border:none;color:#fff;font-family:var(--fb);font-size:.83rem;font-weight:700;cursor:pointer;text-decoration:none;transition:transform .25s,box-shadow .25s;white-space:nowrap}
.nav-cta:hover{transform:scale(1.07);box-shadow:0 8px 28px rgba(0,229,255,.35)}
@keyframes ctaShift{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
#ham{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
#ham span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:all .2s}

/* Mobile nav */
#mob-nav{position:fixed;inset:0;background:rgba(6,6,18,.98);backdrop-filter:blur(24px);z-index:950;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}
#mob-nav.open{opacity:1;visibility:visible}
#mob-nav a{font-family:var(--fh);font-size:1.5rem;font-weight:700;color:var(--text);transition:color .2s}
#mob-nav a:hover{color:var(--cyan)}
#mob-close{position:absolute;top:20px;right:20px;width:42px;height:42px;border:1px solid var(--border);border-radius:50%;background:none;color:var(--text);font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center}

/* ── SEARCH OVERLAY ── */
#search-overlay{position:fixed;inset:0;background:rgba(5,5,15,.93);backdrop-filter:blur(24px);z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding-top:120px;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}
#search-overlay.open{opacity:1;visibility:visible}
.search-box{width:100%;max-width:660px;padding:0 20px}
.search-inner{display:flex;align-items:center;gap:12px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);border-radius:50px;padding:14px 22px}
.search-inner input{flex:1;background:none;border:none;outline:none;font-family:var(--fb);font-size:1.1rem;color:var(--text)}
.search-inner input::placeholder{color:var(--text3)}
.search-close-btn{background:none;border:none;color:var(--text3);cursor:pointer;font-size:1.1rem;padding:4px 8px}
.search-results{margin-top:14px;display:flex;flex-direction:column;gap:8px}
.sr-item{padding:13px 20px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:14px;color:var(--text2);cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:12px;text-decoration:none}
.sr-item:hover{background:rgba(0,229,255,.08);border-color:rgba(0,229,255,.2);color:var(--text)}

/* ── BTT ── */
#btt{position:fixed;bottom:28px;right:28px;width:46px;height:46px;border-radius:50%;background:var(--grad);border:none;color:#fff;font-size:1.2rem;cursor:pointer;z-index:800;opacity:0;visibility:hidden;transform:translateY(20px);transition:all .3s;box-shadow:0 4px 20px rgba(0,229,255,.3)}
#btt.vis{opacity:1;visibility:visible;transform:translateY(0)}

/* ── PAGE HERO ── */
.page-hero{padding:140px 5% 60px;background:var(--bg);text-align:center;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 60% at 50% 50%,rgba(0,229,255,.05),transparent 70%);pointer-events:none}
.ph-tag{display:inline-flex;align-items:center;gap:8px;padding:5px 14px;border:1px solid var(--border);border-radius:50px;background:var(--glass);font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--cyan);margin-bottom:18px}
.ph-title{font-family:var(--fh);font-size:clamp(2rem,5vw,3.5rem);font-weight:800;margin-bottom:16px;line-height:1.15}
.ph-title span{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.ph-sub{font-size:1.05rem;color:var(--text2);max-width:560px;margin:0 auto}

/* ── SECTIONS ── */
section{padding:80px 5%}
.sec-tag{display:inline-flex;align-items:center;gap:8px;padding:5px 14px;border:1px solid var(--border);border-radius:50px;background:var(--glass);font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--cyan);margin-bottom:18px}
.tc{text-align:center}
.sec-title{font-family:var(--fh);font-size:clamp(1.8rem,4vw,3rem);font-weight:800;margin-bottom:16px;line-height:1.2}
.sec-title span{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.sec-sub{font-size:1rem;color:var(--text2);max-width:560px;margin:0 auto;line-height:1.7}
.mt8{margin-top:32px}
.mt12{margin-top:48px}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 28px;border-radius:50px;font-family:var(--fb);font-size:.92rem;font-weight:700;cursor:pointer;transition:all .25s;text-decoration:none;border:none}
.btn-p{background:var(--grad);color:#fff;box-shadow:0 4px 20px rgba(0,229,255,.25)}
.btn-p:hover{transform:translateY(-3px);box-shadow:0 8px 32px rgba(0,229,255,.4)}
.btn-o{border:1px solid var(--border);background:var(--glass);color:var(--text)}
.btn-o:hover{border-color:var(--cyan);box-shadow:var(--glow);transform:translateY(-2px)}

/* ── REVEAL ANIMATION (NO opacity:0 blocking!) ── */
.reveal{opacity:1;transform:none;transition:opacity .6s ease,transform .6s ease}
.reveal.animate{opacity:0;transform:translateY(28px)}
.reveal.in{opacity:1!important;transform:translateY(0)!important}

/* ── CARDS ── */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r3);transition:var(--tr)}
.card:hover{border-color:rgba(0,229,255,.2);box-shadow:var(--glow)}
.icon-box{width:52px;height:52px;border-radius:var(--r2);background:rgba(0,229,255,.1);border:1px solid rgba(0,229,255,.2);display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:18px}
.icon-box-sm{width:38px;height:38px;border-radius:10px;background:rgba(0,229,255,.08);border:1px solid rgba(0,229,255,.15);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.tag{padding:3px 10px;border-radius:50px;font-size:.68rem;font-weight:600;font-family:var(--fm)}
.tag-cyan{background:rgba(0,229,255,.12);color:var(--cyan);border:1px solid rgba(0,229,255,.2)}
.tag-gold{background:rgba(240,165,0,.12);color:var(--gold);border:1px solid rgba(240,165,0,.2)}
.tag-purple{background:rgba(124,58,237,.12);color:var(--purple);border:1px solid rgba(124,58,237,.2)}

/* ── HERO SECTION ── */
#hero{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:90px 5% 60px;position:relative;overflow:hidden;background:linear-gradient(135deg,#05050f 0%,#0a0a1e 50%,#060618 100%)}
.hero-grid-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(0,229,255,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(0,229,255,.018) 1px,transparent 1px);background-size:60px 60px;pointer-events:none}
.hero-glow{position:absolute;border-radius:50%;pointer-events:none}
.hero-glow-1{position:absolute;width:500px;height:500px;background:radial-gradient(circle,rgba(0,229,255,.06),transparent 70%);top:-120px;left:-80px;border-radius:50%;pointer-events:none}
.hero-glow-2{position:absolute;width:400px;height:400px;background:radial-gradient(circle,rgba(124,58,237,.06),transparent 70%);bottom:-80px;right:-60px;border-radius:50%;pointer-events:none}

/* Neon glass card */
.hero-glass-wrap{position:relative;z-index:10;display:flex;align-items:center;justify-content:space-between;gap:40px;width:100%;max-width:1200px;margin:0 auto;background:rgba(255,255,255,.03);backdrop-filter:blur(28px);border-radius:30px;padding:50px 52px;box-shadow:0 0 0 1px rgba(0,229,255,.2),0 32px 80px rgba(0,0,0,.7);animation:neonPulse 4s ease-in-out infinite}
@keyframes neonPulse{
  0%,100%{box-shadow:0 0 0 1px rgba(0,229,255,.25),0 32px 80px rgba(0,0,0,.7),0 0 50px rgba(0,229,255,.05)}
  33%{box-shadow:0 0 0 1px rgba(124,58,237,.35),0 32px 80px rgba(0,0,0,.7),0 0 50px rgba(124,58,237,.06)}
  66%{box-shadow:0 0 0 1px rgba(240,165,0,.3),0 32px 80px rgba(0,0,0,.7),0 0 50px rgba(240,165,0,.05)}
}
.hero-glass-wrap::before{content:'';position:absolute;inset:0;border-radius:30px;padding:1px;background:linear-gradient(135deg,rgba(0,229,255,.5),transparent 40%,rgba(124,58,237,.4) 65%,transparent 85%,rgba(240,165,0,.35));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}

/* Hero text */
.hero-left{flex:1;max-width:560px}
.hero-badge{display:inline-flex;align-items:center;gap:10px;padding:7px 18px 7px 7px;border:1px solid rgba(0,229,255,.28);border-radius:50px;background:rgba(0,229,255,.06);font-size:.8rem;color:#a0e8ff;margin-bottom:20px}
.badge-dot{width:28px;height:28px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:.78rem}

/* NEON NAME */
.neon-name-wrap{display:inline-block;margin-bottom:10px;position:relative}
.neon-name{font-family:'Dancing Script',cursive;font-size:clamp(2.8rem,6.5vw,5.4rem);font-weight:800;display:inline-block;background:linear-gradient(135deg,#00e5ff 0%,#fff 30%,#f0a500 55%,#fff 80%,#00e5ff 100%);background-size:300% 300%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 0 20px rgba(0,229,255,.45)) drop-shadow(0 0 40px rgba(240,165,0,.25));animation:nameShimmer 5s ease infinite;line-height:1.1}
@keyframes nameShimmer{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.hero-tagline{font-size:.95rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(240,165,0,.9);margin-bottom:12px;font-family:var(--fh);display:flex;align-items:center;gap:12px}
.tl-div{display:inline-block;width:28px;height:1px;background:rgba(240,165,0,.7)}
.hero-sub-lines{margin-bottom:18px}
.hero-sub-line{font-size:1.05rem;color:rgba(255,255,255,.7);font-weight:500;line-height:1.6}
.hero-desc{font-size:.95rem;color:rgba(255,255,255,.52);line-height:1.85;max-width:500px;margin-bottom:28px}
.hero-btns{display:flex;gap:13px;flex-wrap:wrap;margin-bottom:32px}
.hero-stats{display:flex;gap:26px;flex-wrap:wrap;padding-top:24px;border-top:1px solid rgba(255,255,255,.08)}
.hs-item{display:flex;flex-direction:column;gap:4px}
.hs-num{font-family:var(--fh);font-size:1.75rem;font-weight:800;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1}
.hs-lbl{font-size:.7rem;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.08em}

/* Hero right - Logo with neon frame */
.hero-right{flex-shrink:0;position:relative;width:300px;display:flex;align-items:center;justify-content:center}
.hero-logo-frame{position:relative;display:inline-block;animation:logoFloat 6s ease-in-out infinite}
@keyframes logoFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
.hero-logo-frame img{display:block;width:280px;height:auto;position:relative;z-index:3;filter:drop-shadow(0 0 30px rgba(240,165,0,.5)) drop-shadow(0 0 60px rgba(240,165,0,.25));animation:imgGlow 3s ease-in-out infinite}
@keyframes imgGlow{0%,100%{filter:drop-shadow(0 0 30px rgba(240,165,0,.5)) drop-shadow(0 0 60px rgba(240,165,0,.25))}50%{filter:drop-shadow(0 0 40px rgba(0,229,255,.45)) drop-shadow(0 0 80px rgba(0,229,255,.2))}}
.hero-logo-frame::before{content:'';position:absolute;inset:-10px;border-radius:20px;border:2px solid transparent;background:linear-gradient(rgba(10,10,30,0),rgba(10,10,30,0)) padding-box,linear-gradient(135deg,#00e5ff,#7c3aed,#f0a500,#00e5ff) border-box;background-clip:padding-box,border-box;z-index:2;animation:framePulse 3s ease-in-out infinite}
.hero-logo-frame::after{content:'';position:absolute;inset:-22px;border-radius:24px;border:1px solid rgba(240,165,0,.25);box-shadow:0 0 20px rgba(240,165,0,.15),0 0 40px rgba(0,229,255,.08);z-index:1;animation:framePulse 4s ease-in-out infinite reverse}
@keyframes framePulse{0%,100%{opacity:.8}50%{opacity:1}}
.neon-corner{position:absolute;width:16px;height:16px;z-index:4}
.neon-corner::before,.neon-corner::after{content:'';position:absolute;border-radius:2px}
.neon-corner::before{width:2px;height:16px}.neon-corner::after{width:16px;height:2px}
.nc-tl{top:-24px;left:-24px}.nc-tl::before,.nc-tl::after{top:0;left:0;background:#00e5ff;box-shadow:0 0 8px #00e5ff}
.nc-tr{top:-24px;right:-24px}.nc-tr::before{top:0;left:auto;right:0;background:#7c3aed;box-shadow:0 0 8px #7c3aed}.nc-tr::after{top:0;right:0;background:#7c3aed;box-shadow:0 0 8px #7c3aed}
.nc-bl{bottom:-24px;left:-24px}.nc-bl::before{bottom:0;top:auto;left:0;background:#f0a500;box-shadow:0 0 8px #f0a500}.nc-bl::after{bottom:0;top:auto;left:0;background:#f0a500;box-shadow:0 0 8px #f0a500}
.nc-br{bottom:-24px;right:-24px}.nc-br::before{bottom:0;top:auto;right:0;left:auto;background:#00e5ff;box-shadow:0 0 8px #00e5ff}.nc-br::after{bottom:0;top:auto;right:0;background:#00e5ff;box-shadow:0 0 8px #00e5ff}

/* ── SERVICE CARDS ── */
.grid-3{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
.grid-auto{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}
.service-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r3);padding:32px 28px;transition:var(--tr)}
.service-card:hover{border-color:rgba(0,229,255,.25);transform:translateY(-5px);box-shadow:var(--sh)}
.srv-mini-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:18px;margin-top:48px}
.srv-mini{background:var(--card);border:1px solid var(--border);border-radius:var(--r2);padding:22px 18px;display:flex;gap:14px;align-items:flex-start;transition:var(--tr)}
.srv-mini:hover{border-color:rgba(0,229,255,.25);transform:translateY(-3px)}
.srv-mini h3{font-family:var(--fh);font-size:.96rem;font-weight:700;margin-bottom:5px}
.srv-mini p{font-size:.82rem;color:var(--text2);line-height:1.65}

/* ── WHY CARDS ── */
.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px;margin-top:44px}
.why-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r2);padding:24px 18px;text-align:center;transition:var(--tr)}
.why-card:hover{border-color:rgba(0,229,255,.2);box-shadow:var(--glow)}
.why-icon{font-size:2rem;margin-bottom:14px}
.why-card h3{font-family:var(--fh);font-size:.96rem;font-weight:700;margin-bottom:8px}
.why-card p{font-size:.82rem;color:var(--text2);line-height:1.65}

/* ── STATS ── */
.stats-row{display:flex;gap:32px;flex-wrap:wrap;justify-content:center}
.stat-item{text-align:center}
.stat-num{font-family:var(--fh);font-size:2.2rem;font-weight:800;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;display:block}
.stat-lbl{font-size:.78rem;color:var(--text2);text-transform:uppercase;letter-spacing:.08em}

/* ── REVIEWS — 2 per row ── */
.rev-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:44px}
.rgc{background:#fff;border-radius:18px;overflow:hidden;box-shadow:0 4px 24px rgba(0,0,0,.1);transition:transform .3s,box-shadow .3s;display:flex;flex-direction:column}
[data-theme="dark"] .rgc{background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.09)}
.rgc:hover{transform:translateY(-6px);box-shadow:0 16px 48px rgba(0,0,0,.18)}
.rgc-top{height:88px;display:flex;align-items:center;justify-content:center;position:relative;flex-shrink:0}
.rgc-av{position:absolute;bottom:-32px;left:50%;transform:translateX(-50%);width:70px;height:70px;border-radius:50%;border:3px solid #fff;overflow:hidden;box-shadow:0 4px 14px rgba(0,0,0,.2)}
[data-theme="dark"] .rgc-av{border-color:rgba(255,255,255,.2)}
.rgc-av img{width:100%;height:100%;object-fit:cover;object-position:center top;border-radius:50%;display:block}
.rgc-av-inner{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.3rem;color:#fff}
.rgc-body{padding:44px 20px 22px;text-align:center;flex:1;display:flex;flex-direction:column}
.rgc-name{font-family:var(--fh);font-size:.96rem;font-weight:700;color:#1a1a2e;margin-bottom:2px}
[data-theme="dark"] .rgc-name{color:var(--text)}
.rgc-role{font-size:.74rem;color:#888;margin-bottom:8px}
[data-theme="dark"] .rgc-role{color:var(--text3)}
.rgc-stars{color:#f0a500;font-size:.92rem;margin-bottom:12px;letter-spacing:2px}
.rgc-title{font-size:.86rem;font-weight:700;color:#222;margin-bottom:9px}
[data-theme="dark"] .rgc-title{color:var(--text)}
.rgc-text{font-size:.82rem;color:#555;line-height:1.75;text-align:left;flex:1;padding-left:18px;position:relative}
[data-theme="dark"] .rgc-text{color:var(--text2)}
.rgc-text::before{content:'"';position:absolute;left:0;top:-4px;font-size:1.8rem;line-height:1;color:var(--cyan);opacity:.4;font-family:var(--fh)}
.rgc-badge{display:inline-block;margin-top:12px;padding:3px 11px;border-radius:50px;font-size:.68rem;color:var(--cyan);background:rgba(0,229,255,.08);border:1px solid rgba(0,229,255,.18)}
.rbc-0{background:#0096c7}.rbc-1{background:#f77f00}.rbc-2{background:#d62828}
.rbc-3{background:#2dc653}.rbc-4{background:#7209b7}.rbc-5{background:#e91e8c}
.rbc-6{background:#4361ee}.rbc-7{background:#3a0ca3}.rbc-8{background:#06d6a0}
.rev-pg{display:flex;align-items:center;justify-content:center;gap:9px;margin-top:36px;flex-wrap:wrap}
.rpb{width:38px;height:38px;border-radius:50%;border:1px solid var(--border);background:var(--glass);color:var(--text2);cursor:pointer;font-size:.82rem;display:flex;align-items:center;justify-content:center;transition:var(--tr);font-family:var(--fb)}
.rpb.active,.rpb:hover{background:var(--grad);border-color:transparent;color:#fff}
.rpb.arr{width:42px;height:42px;font-size:1rem}

/* ── PORTFOLIO ── */
.proj-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r3);overflow:hidden;transition:var(--tr);display:flex;flex-direction:column}
.proj-card:hover{border-color:rgba(0,229,255,.2);transform:translateY(-5px);box-shadow:var(--sh)}
.proj-img{height:180px;display:flex;align-items:center;justify-content:center;font-size:3rem;position:relative;overflow:hidden}
.proj-ov{position:absolute;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}
.proj-card:hover .proj-ov{opacity:1}
.ov-btn{padding:10px 22px;border-radius:50px;background:var(--grad);color:#fff;font-weight:700;font-size:.85rem}
.proj-body{padding:22px;flex:1;display:flex;flex-direction:column}
.proj-name{font-family:var(--fh);font-size:1rem;font-weight:700;margin:8px 0}
.proj-desc{font-size:.82rem;color:var(--text2);line-height:1.65;flex:1}
.filter-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:36px}
.filter-btn{padding:7px 18px;border-radius:50px;border:1px solid var(--border);background:var(--glass);color:var(--text2);cursor:pointer;font-family:var(--fb);font-size:.82rem;transition:var(--tr)}
.filter-btn.active,.filter-btn:hover{background:var(--grad);border-color:transparent;color:#fff}

/* ── FAQ ── */
.faq-item{border:1px solid var(--border);border-radius:var(--r2);margin-bottom:12px;overflow:hidden;transition:var(--tr)}
.faq-item.open{border-color:rgba(0,229,255,.2)}
.faq-q{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;cursor:pointer;font-weight:600;font-size:.96rem;user-select:none}
.faq-q::after{content:'▼';font-size:.65rem;color:var(--cyan);transition:transform .3s;flex-shrink:0;margin-left:10px}
.faq-item.open .faq-q::after{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease,padding .3s}
.faq-item.open .faq-a{max-height:300px;padding:0 22px 20px}
.faq-a p{font-size:.9rem;color:var(--text2);line-height:1.75}

/* ── ABOUT ── */
.about-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:60px;align-items:start}
.about-img-wrap{position:relative}
.about-img{border-radius:var(--r3);overflow:hidden;border:1px solid var(--border)}
.about-img img{width:100%;height:auto;display:block}
.about-badge{position:absolute;bottom:-20px;right:-20px;background:var(--card);border:1px solid var(--border);border-radius:var(--r2);padding:16px 20px;backdrop-filter:blur(12px)}
.about-badge-n{font-family:var(--fh);font-size:1.8rem;font-weight:800;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.about-badge-l{font-size:.7rem;color:var(--text3);text-transform:uppercase;letter-spacing:.08em}
.about-p{font-size:.96rem;color:var(--text2);line-height:1.9;margin-bottom:18px}
.skill-item{margin-bottom:16px}
.skill-label{display:flex;justify-content:space-between;font-size:.82rem;font-weight:600;margin-bottom:6px}
.skill-track{height:6px;background:rgba(255,255,255,.08);border-radius:6px;overflow:hidden}
.skill-fill{height:100%;border-radius:6px;background:var(--grad);width:0;transition:width 1.5s ease}

/* ── CONTACT ── */
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:48px;align-items:start}
.contact-info h3{font-family:var(--fh);font-size:1.6rem;font-weight:800;margin-bottom:16px}
.contact-info p{color:var(--text2);line-height:1.8;margin-bottom:24px}
.contact-item{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.ci-icon{width:44px;height:44px;border-radius:var(--r1);background:rgba(0,229,255,.08);border:1px solid rgba(0,229,255,.15);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.ci-text{font-size:.88rem;color:var(--text2)}
.ci-text strong{display:block;color:var(--text);font-size:.92rem;margin-bottom:2px}
.form-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r3);padding:36px 32px}
.form-group{margin-bottom:20px}
.form-group label{display:block;font-size:.82rem;font-weight:600;color:var(--text2);margin-bottom:8px;text-transform:uppercase;letter-spacing:.06em}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:13px 16px;background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:var(--r1);color:var(--text);font-family:var(--fb);font-size:.92rem;outline:none;transition:border-color .2s}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--cyan)}
.form-group textarea{resize:vertical;min-height:130px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}

/* ── PRICING ── */
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-top:48px}
.pricing-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r3);padding:36px 28px;transition:var(--tr);position:relative;overflow:hidden}
.pricing-card.featured{border-color:var(--cyan);box-shadow:0 0 40px rgba(0,229,255,.12)}
.pricing-card:hover{transform:translateY(-5px)}
.pc-badge{position:absolute;top:18px;right:18px;padding:4px 12px;border-radius:50px;background:var(--grad);color:#fff;font-size:.7rem;font-weight:700}
.pc-name{font-family:var(--fh);font-size:1.1rem;font-weight:700;margin-bottom:8px}
.pc-price{font-family:var(--fh);font-size:2.4rem;font-weight:800;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1;margin:16px 0 8px}
.pc-period{font-size:.78rem;color:var(--text3);margin-bottom:24px}
.pc-features{list-style:none;margin-bottom:28px}
.pc-features li{padding:8px 0;border-bottom:1px solid var(--border);font-size:.88rem;color:var(--text2);display:flex;align-items:center;gap:10px}
.pc-features li::before{content:'✓';color:var(--cyan);font-weight:700;flex-shrink:0}
.hidden{display:none}

/* ── BLOG ── */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;margin-top:44px}
.blog-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r3);overflow:hidden;transition:var(--tr)}
.blog-card:hover{border-color:rgba(0,229,255,.2);transform:translateY(-4px)}
.blog-img{height:180px;display:flex;align-items:center;justify-content:center;font-size:3rem}
.blog-body{padding:24px 22px}
.blog-meta{display:flex;gap:12px;margin-bottom:12px;font-size:.72rem;color:var(--text3)}
.blog-title{font-family:var(--fh);font-size:1.05rem;font-weight:700;margin-bottom:10px;line-height:1.4}
.blog-excerpt{font-size:.84rem;color:var(--text2);line-height:1.65}
.blog-link{display:inline-flex;align-items:center;gap:5px;margin-top:14px;font-size:.82rem;color:var(--cyan);font-weight:600}

/* ── TRADING ── */
.trading-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:22px;margin-top:44px}
.t-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r3);padding:28px 24px;transition:var(--tr)}
.t-card:hover{border-color:rgba(240,165,0,.25);transform:translateY(-4px)}
.t-tag{display:inline-block;padding:3px 10px;border-radius:50px;font-size:.68rem;font-weight:700;margin-bottom:12px}
.t-tag.bull{background:rgba(0,200,100,.12);color:var(--green);border:1px solid rgba(0,200,100,.2)}
.t-tag.bear{background:rgba(255,68,68,.1);color:var(--red);border:1px solid rgba(255,68,68,.2)}

/* ── MAP ── */
.map-wrap iframe{width:100%;height:340px;border:none;border-radius:var(--r2);filter:grayscale(.15) contrast(1.05);box-shadow:var(--sh)}

/* ── FOOTER ── */
#footer{background:#07071a;padding:0}
.ft-top-band{height:3px;background:linear-gradient(90deg,#00e5ff,#7c3aed,#f0a500,#00e5ff);background-size:200% 100%;animation:ftb 4s linear infinite}
@keyframes ftb{0%{background-position:0%}100%{background-position:200%}}
.ft-inner{padding:56px 5% 0}
.ft-grid{display:grid;grid-template-columns:1.7fr 1fr 1.3fr 1.4fr;gap:44px;margin-bottom:44px}
.ft-brand-logo{height:62px;width:auto;margin-bottom:14px;filter:drop-shadow(0 4px 16px rgba(240,165,0,.3))}
.ft-brand-tagline{font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:11px}
.ft-desc{font-size:.88rem;color:#8888aa;line-height:1.85;margin-bottom:18px}
.social-row{display:flex;gap:9px;flex-wrap:wrap}
.soc-a{width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.05);display:flex;align-items:center;justify-content:center;font-size:.85rem;cursor:pointer;transition:var(--tr);text-decoration:none;color:#8888aa}
.soc-a:hover{border-color:var(--cyan);color:var(--cyan);transform:translateY(-4px)}
.soc-a svg{width:16px;height:16px;fill:currentColor;display:block}
.ft-head{font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.13em;color:#f0f0f8;margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.07)}
.ft-links{list-style:none;display:flex;flex-direction:column;gap:11px}
.ft-links a{font-size:.9rem;color:#8888aa;transition:color .2s,padding-left .2s;display:flex;align-items:center;gap:8px}
.ft-links a::before{content:'›';color:var(--cyan);font-size:1rem;opacity:.6}
.ft-links a:hover{color:#f0f0f8;padding-left:6px}
.ft-ci{display:flex;align-items:flex-start;gap:11px;margin-bottom:14px;color:#8888aa;font-size:.87rem}
.ft-ci a{color:#8888aa;transition:color .2s}
.ft-ci a:hover{color:var(--cyan)}
.ft-cic{width:34px;height:34px;border-radius:8px;background:rgba(0,229,255,.08);border:1px solid rgba(0,229,255,.15);display:flex;align-items:center;justify-content:center;font-size:.88rem;flex-shrink:0;margin-top:1px}
.ft-nl-desc{font-size:.87rem;color:#8888aa;line-height:1.7;margin-bottom:16px}
.ft-nl-form{display:flex;border-radius:50px;overflow:hidden;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.05)}
.ft-nl-form input{flex:1;background:none;border:none;outline:none;padding:11px 16px;font-family:var(--fb);font-size:.84rem;color:#f0f0f8}
.ft-nl-form input::placeholder{color:#55557a}
.ft-nl-form button{width:44px;height:44px;flex-shrink:0;background:linear-gradient(135deg,#00e5ff,#7c3aed);border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;margin:3px;transition:transform .2s}
.ft-nl-form button:hover{transform:scale(1.1)}
.ft-divider{height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.07),transparent)}
.ft-bottom{padding:17px 5% 22px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.ft-bottom-left{display:flex;flex-direction:column;gap:4px}
.ft-copy{font-size:.82rem;color:#55557a}
.ft-legal{display:flex;gap:18px}
.ft-legal a{font-size:.77rem;color:#55557a;transition:color .2s}
.ft-legal a:hover{color:var(--cyan)}
.ft-bottom-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px}
.ft-credit{font-size:.8rem;color:#55557a}
.ft-credit span{color:var(--gold);font-weight:700}
.ft-tech-row{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end;margin-top:4px}
.ft-tech-badge{padding:2px 9px;border-radius:4px;font-size:.64rem;font-family:var(--fm);border:1px solid rgba(0,229,255,.2);color:var(--cyan);background:rgba(0,229,255,.05)}

/* ── FLEX UTILS ── */
.flex{display:flex}.gap2{gap:8px}.gap3{gap:12px}.mb4{margin-bottom:16px}.mb6{margin-bottom:24px}

/* ── SKILLS ── */
.skills-wrap{margin-top:28px}

/* ── NEWSLETTER ── */
.nl-wrap{background:var(--card);border:1px solid var(--border);border-radius:var(--r3);padding:48px 40px;text-align:center;position:relative;overflow:hidden}
#nl-form{display:flex;gap:12px;max-width:420px;margin:28px auto 0;flex-wrap:wrap}
#nl-form input{flex:1;min-width:200px;padding:13px 18px;background:rgba(255,255,255,.06);border:1px solid var(--border);border-radius:50px;color:var(--text);font-family:var(--fb);font-size:.9rem;outline:none}
#nl-form button{padding:13px 26px;border-radius:50px;background:var(--grad);border:none;color:#fff;font-family:var(--fb);font-size:.9rem;font-weight:700;cursor:pointer}

/* ── RESPONSIVE ── */
@media(max-width:1100px){
  .ft-grid{grid-template-columns:1fr 1fr;gap:30px}
  .about-grid,.contact-grid{grid-template-columns:1fr}
}
@media(max-width:900px){
  section{padding:60px 5%}
  .hero-glass-wrap{flex-direction:column-reverse;align-items:center;text-align:center;padding:36px 24px}
  .hero-right{width:100%;justify-content:center;margin-bottom:10px}
  .hero-logo-frame img{width:220px}
  .neon-name{white-space:normal;font-size:clamp(2.4rem,8vw,4rem)}
  .hero-tagline,.hero-btns,.hero-stats{justify-content:center}
}
@media(max-width:768px){
  #nav{top:10px;width:calc(100% - 20px);padding:0 14px;height:58px}
  .nav-links,.nav-cta{display:none}
  #ham{display:flex}
  .rev-grid{grid-template-columns:1fr}
  .ft-grid{grid-template-columns:1fr}
  .ft-bottom{flex-direction:column;align-items:flex-start}
  .ft-bottom-right{align-items:flex-start}
  .ft-tech-row{justify-content:flex-start}
  .form-row{grid-template-columns:1fr}
}
@media(max-width:600px){
  #hero{padding:80px 4% 50px}
  .hero-glass-wrap{padding:24px 18px;border-radius:22px}
  .hero-logo-frame img{width:180px}
  .ph-title{font-size:clamp(1.7rem,7vw,2.5rem)}
}

/* ── PORTFOLIO WEBSITE TYPE TABS ─────────────────────────────────── */
.wtype-section{margin-top:80px}
.wtype-tabs{display:flex;flex-wrap:wrap;gap:10px;margin:36px 0 0;justify-content:center}
.wtab{display:flex;align-items:center;gap:8px;padding:10px 20px;border-radius:50px;border:1px solid var(--border);background:var(--glass);color:var(--text2);cursor:pointer;font-family:var(--fb);font-size:.83rem;font-weight:600;transition:all .25s;white-space:nowrap}
.wtab .wtab-icon{font-size:1.1rem;line-height:1}
.wtab:hover{border-color:rgba(0,229,255,.3);color:var(--text);background:rgba(0,229,255,.07)}
.wtab.active{background:linear-gradient(135deg,rgba(0,229,255,.15),rgba(124,58,237,.12));border-color:var(--cyan);color:#fff;box-shadow:0 0 18px rgba(0,229,255,.15)}
.wtype-panels{margin-top:28px}
.wtype-panel{display:none;animation:wtFade .35s ease}
.wtype-panel.active{display:block}
@keyframes wtFade{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.wtype-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}
.wtype-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:16px 18px;display:flex;align-items:center;gap:12px;transition:all .25s;cursor:default}
.wtype-card:hover{border-color:rgba(0,229,255,.25);transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.3)}
.wtype-card-icon{font-size:1.5rem;flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:rgba(0,229,255,.07);border-radius:10px;border:1px solid rgba(0,229,255,.12)}
.wtype-card-name{font-size:.85rem;font-weight:600;color:var(--text);line-height:1.3}
@media(max-width:768px){
  .wtype-tabs{gap:7px}
  .wtab{padding:8px 14px;font-size:.76rem}
  .wtype-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
  .wtype-card{padding:12px 14px}
}
@media(max-width:480px){
  .wtype-grid{grid-template-columns:1fr 1fr}
}

/* ── GALLERY ── */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-top:28px}
.gallery-item{background:var(--card);border:1px solid var(--border);border-radius:16px;overflow:hidden;transition:transform .3s,box-shadow .3s}
.gallery-item:hover{transform:translateY(-4px);box-shadow:var(--sh)}
.gallery-item img{width:100%;height:200px;object-fit:cover;display:block}
.gallery-item p{padding:10px 14px;font-size:.8rem;color:var(--text2)}
.media-item{margin-bottom:24px}
