:root {
  --bg:#07070f;--bg2:#0c0c1c;
  --glass:rgba(255,255,255,.045);--glass-b:rgba(255,255,255,.09);--glass-h:rgba(255,255,255,.08);
  --text:#eaeaf4;--muted:rgba(234,234,244,.45);
  --p:#a855f7;--c:#06b6d4;--o:#f97316;--pk:#ec4899;--gr:#22c55e;
  --g1:linear-gradient(135deg,#a855f7,#6366f1);
  --g2:linear-gradient(135deg,#06b6d4,#3b82f6);
  --g3:linear-gradient(135deg,#f97316,#ec4899);
  --g4:linear-gradient(135deg,#22c55e,#06b6d4);
  --g5:linear-gradient(135deg,#ec4899,#a855f7);
  --fd:'Syne',sans-serif;--fb:'DM Sans',sans-serif;
  --r:16px;--rl:24px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--fb);font-size:16px;line-height:1.6;overflow-x:hidden;cursor:none}

/* cursor */
#cur{position:fixed;top:0;left:0;z-index:9999;pointer-events:none;mix-blend-mode:difference}
#cd{width:8px;height:8px;border-radius:50%;background:#fff;position:absolute;transform:translate(-50%,-50%);transition:width .15s,height .15s}
#cr{width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,.5);position:absolute;transform:translate(-50%,-50%);transition:width .3s cubic-bezier(.25,.46,.45,.94),height .3s cubic-bezier(.25,.46,.45,.94),border-color .3s}
body.hov #cd{width:12px;height:12px}
body.hov #cr{width:52px;height:52px;border-color:var(--p)}

/* noise */
body::before{content:'';position:fixed;inset:0;z-index:0;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");opacity:.55}

/* orbs */
.orb{position:fixed;border-radius:50%;filter:blur(110px);pointer-events:none;z-index:0;opacity:.16;animation:drift 22s ease-in-out infinite alternate}
.o1{width:640px;height:640px;background:var(--p);top:-220px;left:-180px}
.o2{width:480px;height:480px;background:var(--c);bottom:-120px;right:-80px;animation-delay:-8s}
.o3{width:320px;height:320px;background:var(--pk);top:45%;left:52%;animation-delay:-15s}
@keyframes drift{0%{transform:translate(0,0) scale(1)}100%{transform:translate(36px,52px) scale(1.08)}}

.wrap{max-width:1200px;margin:0 auto;padding:0 36px;position:relative;z-index:1}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:20px 0;transition:background .4s,backdrop-filter .4s}
nav.sc{background:rgba(7,7,15,.72);backdrop-filter:blur(28px);border-bottom:1px solid var(--glass-b)}
.ni{display:flex;align-items:center;justify-content:space-between}
.logo{font-family:var(--fd);font-size:21px;font-weight:800;letter-spacing:-.03em;background:var(--g1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;text-decoration:none}
.nl{display:flex;gap:32px;list-style:none}
.nl a{font-family:var(--fd);font-size:12px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:var(--muted);text-decoration:none;transition:color .25s;position:relative}
.nl a::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:1px;background:var(--g1);transform:scaleX(0);transform-origin:left;transition:transform .3s cubic-bezier(.25,.46,.45,.94)}
.nl a:hover{color:var(--text)}
.nl a:hover::after{transform:scaleX(1)}
.ncta{background:var(--glass)!important;border:1px solid var(--glass-b)!important;color:var(--text)!important;padding:8px 20px!important;border-radius:100px!important;backdrop-filter:blur(12px);transition:background .25s,border-color .25s!important}
.ncta:hover{background:var(--glass-h)!important;border-color:var(--p)!important}
.ncta::after{display:none!important}

/* HERO */
#hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:130px 0 90px;position:relative}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--fd);font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--c);margin-bottom:26px;animation:fup .8s .1s both}
.eyebrow::before{content:'';display:block;width:28px;height:1px;background:var(--c)}
.htitle{font-family:var(--fd);font-size:clamp(50px,7.5vw,106px);font-weight:800;line-height:.95;letter-spacing:-.04em;margin-bottom:30px;animation:fup .8s .2s both}
.htitle .l1{display:block;color:var(--text)}
.htitle .l2{display:block;background:var(--g3);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.htitle .l3{display:block;color:var(--text)}
.hsub{font-size:17px;color:var(--muted);max-width:480px;font-weight:300;line-height:1.75;margin-bottom:48px;animation:fup .8s .3s both}
.hacts{display:flex;align-items:center;gap:20px;animation:fup .8s .4s both}
.btnp{background:var(--g1);color:#fff;font-family:var(--fd);font-size:14px;font-weight:700;letter-spacing:.04em;padding:14px 34px;border-radius:100px;text-decoration:none;border:none;cursor:pointer;position:relative;overflow:hidden;transition:transform .25s,box-shadow .25s;box-shadow:0 8px 32px rgba(168,85,247,.35)}
.btnp::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,.15);opacity:0;transition:opacity .25s}
.btnp:hover{transform:translateY(-2px);box-shadow:0 16px 48px rgba(168,85,247,.45)}
.btnp:hover::after{opacity:1}
.btng{color:var(--muted);font-family:var(--fd);font-size:14px;font-weight:600;letter-spacing:.04em;text-decoration:none;display:flex;align-items:center;gap:8px;transition:color .25s,gap .25s}
.btng:hover{color:var(--text);gap:14px}

/* hero floating tag cloud */
.htags{position:absolute;right:0;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:14px;animation:fleft .8s .5s both}
.htag{background:var(--glass);border:1px solid var(--glass-b);backdrop-filter:blur(20px);padding:12px 20px;border-radius:var(--r);font-family:var(--fd);font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;transition:transform .3s,border-color .3s;display:flex;align-items:center;gap:10px}
.htag:hover{transform:translateX(-6px);border-color:var(--p)}
.htag-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.scroll-ind{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;animation:fup .8s .9s both}
.scroll-txt{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.scroll-ln{width:1px;height:44px;background:linear-gradient(to bottom,var(--p),transparent);animation:spulse 2s ease-in-out infinite}
@keyframes spulse{0%,100%{opacity:.3;transform:scaleY(.8)}50%{opacity:1;transform:scaleY(1)}}

/* SHARED */
section{padding:120px 0}
.stag{font-family:var(--fd);font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--p);margin-bottom:14px;display:flex;align-items:center;gap:10px}
.stag::before{content:'◆';font-size:8px}
.stitle{font-family:var(--fd);font-size:clamp(34px,4.2vw,58px);font-weight:800;letter-spacing:-.03em;line-height:1.05;color:var(--text);margin-bottom:14px}
.stitle span{background:var(--g2);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.ssub{font-size:17px;color:var(--muted);max-width:520px;line-height:1.75;font-weight:300}

/* ABOUT */
.ag{display:grid;grid-template-columns:1fr 1.15fr;gap:72px;align-items:center;margin-top:72px}
.pframe{width:100%;aspect-ratio:3/4;border-radius:var(--rl);overflow:hidden;position:relative;background:linear-gradient(160deg,#1a0a2e,#0a1a2e)}
.pinner{width:100%;height:100%;background:linear-gradient(160deg,rgba(168,85,247,.28),rgba(6,182,212,.18),rgba(236,72,153,.14));display:flex;align-items:center;justify-content:center;font-size:110px;position:relative}
.pinner::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(7,7,15,.75),transparent 60%)}
.pglow{position:absolute;bottom:-28px;left:50%;transform:translateX(-50%);width:80%;height:80px;background:var(--p);filter:blur(60px);opacity:.28}
.pbadge{position:absolute;bottom:28px;left:-22px;background:var(--glass);backdrop-filter:blur(20px);border:1px solid var(--glass-b);padding:13px 18px;border-radius:var(--r);font-family:var(--fd);font-size:13px;font-weight:700;color:var(--text)}
.bdot{width:8px;height:8px;border-radius:50%;background:#22c55e;display:inline-block;margin-right:8px;box-shadow:0 0 0 3px rgba(34,197,94,.25);animation:bpulse 2s ease-in-out infinite}
@keyframes bpulse{0%,100%{box-shadow:0 0 0 3px rgba(34,197,94,.2)}50%{box-shadow:0 0 0 6px rgba(34,197,94,.1)}}
.abio{font-size:16.5px;color:var(--muted);line-height:1.85;font-weight:300;margin-bottom:28px}
.abio strong{color:var(--text);font-weight:500}
.astat-row{display:flex;border:1px solid var(--glass-b);border-radius:var(--r);overflow:hidden;margin-bottom:36px}
.astat{flex:1;padding:20px 22px;text-align:center;border-right:1px solid var(--glass-b);background:var(--glass)}
.astat:last-child{border-right:none}
.astat-num{font-family:var(--fd);font-size:28px;font-weight:800;line-height:1}
.astat-lbl{font-size:11px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-top:4px}

/* SKILLS PILLARS */
#skills{background:linear-gradient(180deg,var(--bg) 0%,var(--bg2) 50%,var(--bg) 100%)}
.pillars{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:72px}
.pillar{background:var(--glass);border:1px solid var(--glass-b);backdrop-filter:blur(20px);border-radius:var(--rl);padding:36px 32px;position:relative;overflow:hidden;transition:transform .35s,box-shadow .35s,border-color .35s}
.pillar::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;opacity:0;transition:opacity .35s}
.pillar:hover{transform:translateY(-6px);box-shadow:0 28px 64px rgba(0,0,0,.45);border-color:rgba(168,85,247,.28)}
.pillar:hover::before{opacity:1}
.pillar:nth-child(1)::before{background:var(--g1)}
.pillar:nth-child(2)::before{background:var(--g2)}
.pillar:nth-child(3)::before{background:var(--g3)}
.pillar:nth-child(4)::before{background:var(--g4)}
.pillar-head{display:flex;align-items:center;gap:16px;margin-bottom:10px}
.pillar-icon{width:54px;height:54px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:26px;flex-shrink:0}
.pillar-title{font-family:var(--fd);font-size:18px;font-weight:800;color:var(--text)}
.pillar-sub{font-size:13.5px;color:var(--muted);font-weight:300;margin-bottom:24px;line-height:1.6}
.skill-list{display:flex;flex-direction:column;gap:10px}
.sk{display:flex;align-items:flex-start;gap:12px;padding:10px 14px;border-radius:10px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);transition:border-color .25s,background .25s}
.sk:hover{border-color:rgba(255,255,255,.12);background:rgba(255,255,255,.05)}
.sk-icon{font-size:15px;flex-shrink:0;margin-top:2px}
.sk-name{font-family:var(--fd);font-size:13px;font-weight:700;color:var(--text);margin-bottom:2px}
.sk-desc{font-size:12px;color:var(--muted);line-height:1.55}

/* GALLERY */
.gall-hd{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:60px}
.gfilt{display:flex;gap:8px;flex-wrap:wrap}
.fb{background:var(--glass);border:1px solid var(--glass-b);backdrop-filter:blur(12px);color:var(--muted);font-family:var(--fd);font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:8px 18px;border-radius:100px;cursor:pointer;transition:all .25s}
.fb:hover,.fb.act{background:var(--g1);border-color:transparent;color:#fff}
.gg{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:76px;gap:14px}
.gi{border-radius:var(--r);overflow:hidden;position:relative;cursor:pointer;transition:transform .4s cubic-bezier(.25,.46,.45,.94),box-shadow .4s;animation:fup .6s both}
.gi:nth-child(1){grid-column:span 5;grid-row:span 4}
.gi:nth-child(2){grid-column:span 4;grid-row:span 3}
.gi:nth-child(3){grid-column:span 3;grid-row:span 3}
.gi:nth-child(4){grid-column:span 4;grid-row:span 3}
.gi:nth-child(5){grid-column:span 3;grid-row:span 4}
.gi:nth-child(6){grid-column:span 5;grid-row:span 4}
.gi:nth-child(7){grid-column:span 4;grid-row:span 3}
.gi:nth-child(8){grid-column:span 4;grid-row:span 4}
.gi:nth-child(9){grid-column:span 3;grid-row:span 3}
.gi:nth-child(10){grid-column:span 5;grid-row:span 3}
.gi:hover{transform:scale(1.025) translateY(-4px);box-shadow:0 24px 60px rgba(0,0,0,.55)}
.gthumb{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:50px;position:relative;overflow:hidden;transition:transform .5s cubic-bezier(.25,.46,.45,.94)}
.gi:hover .gthumb{transform:scale(1.06)}
.gov{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.88) 0%,transparent 55%);display:flex;flex-direction:column;justify-content:flex-end;padding:18px;opacity:0;transition:opacity .35s}
.gi:hover .gov{opacity:1}
.gcat{font-family:var(--fd);font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;margin-bottom:3px;color:var(--c)}
.gname{font-family:var(--fd);font-size:14px;font-weight:700;color:#fff;line-height:1.25}
.garr{position:absolute;top:14px;right:14px;width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.15);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;font-size:13px;color:#fff;opacity:0;transform:scale(.7);transition:opacity .3s,transform .3s}
.gi:hover .garr{opacity:1;transform:scale(1)}
.gb1{background:linear-gradient(135deg,#1a0533,#2d1b69,#0e0e3f)}
.gb2{background:linear-gradient(160deg,#0a2a3a,#064e3b,#0c1a2e)}
.gb3{background:linear-gradient(145deg,#2d0a2e,#1a0533,#3d1b69)}
.gb4{background:linear-gradient(130deg,#1e0a00,#3d1707,#1a0a2e)}
.gb5{background:linear-gradient(155deg,#021428,#0a1f3a,#0d2b4a)}
.gb6{background:linear-gradient(140deg,#2d0a2e,#4a1042,#1a0533)}
.gb7{background:linear-gradient(150deg,#021428,#0e2a1e,#041428)}
.gb8{background:linear-gradient(125deg,#1e1a00,#3d3107,#2d1800)}
.gb9{background:linear-gradient(145deg,#1a0533,#0a1f3a,#2d0a2e)}
.gb10{background:linear-gradient(160deg,#0c2a1e,#0a1f3a,#1a0533)}

/* TESTIMONIALS */
.tg{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:72px}
.tc{background:var(--glass);border:1px solid var(--glass-b);backdrop-filter:blur(20px);border-radius:var(--rl);padding:32px;transition:border-color .3s}
.tc:hover{border-color:rgba(6,182,212,.3)}
.tstar{color:var(--o);font-size:13px;letter-spacing:2px;margin-bottom:14px}
.tq{font-size:15.5px;color:var(--text);line-height:1.78;font-weight:300;font-style:italic;margin-bottom:22px}
.ta{display:flex;align-items:center;gap:14px}
.tav{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:700;font-family:var(--fd);color:#fff;flex-shrink:0}
.tn{font-family:var(--fd);font-size:14px;font-weight:700;color:var(--text)}
.tr{font-size:12px;color:var(--muted)}

/* CONTACT */
#contact{background:radial-gradient(ellipse at 50% 0%,rgba(168,85,247,.12) 0%,transparent 72%)}
.ci{max-width:680px;margin:0 auto;text-align:center}
.ci .stag{justify-content:center}
.ci .ssub{margin:0 auto 48px}
.cf{background:var(--glass);border:1px solid var(--glass-b);backdrop-filter:blur(24px);border-radius:var(--rl);padding:48px;text-align:left}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.fg{margin-bottom:14px}
.fl{font-family:var(--fd);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;display:block}
.fi,.ft{width:100%;background:rgba(255,255,255,.04);border:1px solid var(--glass-b);border-radius:10px;padding:13px 16px;color:var(--text);font-family:var(--fb);font-size:15px;outline:none;resize:none;transition:border-color .25s,box-shadow .25s}
.fi:focus,.ft:focus{border-color:var(--p);box-shadow:0 0 0 3px rgba(168,85,247,.15)}
.ft{min-height:118px}
.fs{width:100%;background:var(--g1);color:#fff;font-family:var(--fd);font-size:15px;font-weight:700;letter-spacing:.04em;padding:16px 32px;border-radius:100px;border:none;cursor:pointer;transition:opacity .25s,transform .25s,box-shadow .25s;box-shadow:0 8px 32px rgba(168,85,247,.35);margin-top:8px}
.fs:hover{opacity:.9;transform:translateY(-2px);box-shadow:0 16px 48px rgba(168,85,247,.45)}

/* FOOTER */
footer{border-top:1px solid var(--glass-b);padding:44px 0;position:relative;z-index:1}
.fi2{display:flex;justify-content:space-between;align-items:center}
.fcopy{font-size:13px;color:var(--muted)}
.fsoc{display:flex;gap:12px}
.sb{width:40px;height:40px;border-radius:50%;background:var(--glass);border:1px solid var(--glass-b);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;font-size:16px;text-decoration:none;transition:border-color .25s,transform .25s}
.sb:hover{border-color:var(--p);transform:translateY(-3px)}

/* ANIMS */
@keyframes fup{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes fleft{from{opacity:0;transform:translateX(44px)}to{opacity:1;transform:translateX(0)}}
.rv{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.25,.46,.45,.94),transform .7s cubic-bezier(.25,.46,.45,.94)}
.rv.vis{opacity:1;transform:none}
.rv.d1{transition-delay:.1s}.rv.d2{transition-delay:.2s}.rv.d3{transition-delay:.3s}.rv.d4{transition-delay:.4s}

/* RESPONSIVE */
@media(max-width:1024px){.htags{display:none}.pillars{grid-template-columns:1fr}}
@media(max-width:768px){
  .nl{display:none}
  .ag{grid-template-columns:1fr;gap:48px}
  .gg{grid-template-columns:1fr 1fr;grid-auto-rows:150px}
  .gi:nth-child(n){grid-column:span 1;grid-row:span 1}
  .gi:nth-child(1),.gi:nth-child(6){grid-column:span 2}
  .tg{grid-template-columns:1fr}
  .frow{grid-template-columns:1fr}
}