:root{--teal:oklch(0.82 0.18 185);--magenta:oklch(0.72 0.20 330);--green:oklch(0.84 0.22 140);--amber:oklch(0.82 0.18 75);--bg:#08080f;--surface:rgba(255,255,255,0.035);--surface2:rgba(255,255,255,0.07);--border:rgba(255,255,255,0.08);--border2:rgba(255,255,255,0.14);--text:oklch(0.88 0.02 200);--dim:oklch(0.52 0.05 200);--dimmer:oklch(0.38 0.04 200);--mono:"Space Mono",monospace;--sans:"DM Sans",sans-serif;--r:10px}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--sans);font-size:15px;line-height:1.7;min-height:100vh;overflow-x:hidden}body:before{background-image:linear-gradient(rgba(0,255,200,.025) 1px,transparent 0),linear-gradient(90deg,rgba(0,255,200,.025) 1px,transparent 0);background-size:40px 40px}body:after,body:before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none}body:after{background:radial-gradient(ellipse 80% 40% at 50% 0,rgba(180,0,200,.1) 0,transparent 65%),radial-gradient(ellipse 50% 30% at 100% 0,rgba(220,0,180,.12) 0,transparent 60%),radial-gradient(ellipse 60% 40% at 100% 80%,rgba(180,0,120,.05) 0,transparent 70%),radial-gradient(ellipse 40% 25% at 0 0,rgba(120,0,200,.08) 0,transparent 60%)}.top-bar{top:0;left:0;right:0;z-index:200;height:3px;background:linear-gradient(90deg,transparent,rgba(180,0,200,.6) 20%,rgba(255,80,200,.9) 45%,rgba(200,80,255,.9) 55%,rgba(180,0,200,.6) 80%,transparent);box-shadow:0 0 20px rgba(220,80,255,.7),0 0 60px rgba(180,0,200,.4)}.scanlines,.top-bar{position:fixed;pointer-events:none}.scanlines{inset:0;z-index:1;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.08) 0,rgba(0,0,0,.08) 4px)}.wrap{position:relative;z-index:2;max-width:960px;margin:0 auto;padding:0 24px}nav.portfolio-nav{position:-webkit-sticky;position:sticky;top:0;z-index:100;background:rgba(8,8,15,.88);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid rgba(200,80,255,.18);border-top:1px solid rgba(200,80,255,.12);padding:0 24px;box-shadow:0 1px 40px rgba(180,0,200,.12),inset 0 1px 0 rgba(220,80,255,.08)}.nav-inner{max-width:960px;margin:0 auto;justify-content:space-between;height:56px}.nav-dots,.nav-inner{display:flex;align-items:center}.nav-dots{gap:6px}.nav-dots span{width:12px;height:12px;border-radius:50%;box-shadow:0 0 8px currentColor}.nd-r{background:#ff5f57;color:#ff5f57}.nd-y{background:#febc2e;color:#febc2e}.nd-g{background:#28c840;color:#28c840}.nav-title{font-family:var(--mono);font-size:13px;color:var(--dim);margin-left:14px}.nav-links{display:flex;gap:28px}.nav-links a,.nav-links button{font-family:var(--mono);font-size:12px;color:var(--dim);text-decoration:none;transition:color .2s;cursor:pointer;background:none;border:none;padding:0}.nav-links a:before,.nav-links button:before{content:"./";color:var(--dimmer)}.nav-links a.active,.nav-links a:hover,.nav-links button.active,.nav-links button:hover{color:var(--teal)}section{padding:72px 0 0}.sec-label{font-size:12px;color:var(--magenta);margin-bottom:8px;letter-spacing:.05em}.sec-label,.sec-title{font-family:var(--mono)}.sec-title{font-size:22px;font-weight:700;color:var(--text);margin-bottom:36px;line-height:1.2}.sec-title span{color:var(--teal)}#hero{padding:80px 0 0}.hero-grid{display:grid;grid-template-columns:1fr auto;grid-gap:48px;gap:48px;align-items:center}.hero-eyebrow{font-family:var(--mono);font-size:13px;color:var(--green);margin-bottom:16px}.hero-eyebrow:before{content:"$ ";color:var(--dim)}.hero-name{font-family:var(--mono);font-size:clamp(32px,5vw,52px);font-weight:700;line-height:1.05;letter-spacing:-.02em;color:var(--text);margin-bottom:12px}.hero-name span{color:var(--teal);text-shadow:0 0 24px oklch(.82 .18 185/.5)}.hero-role{font-family:var(--mono);font-size:16px;color:var(--magenta);margin-bottom:20px}.hero-role:before{content:"// ";color:var(--dimmer)}.hero-bio{font-size:15px;color:var(--dim);max-width:500px;line-height:1.75;margin-bottom:28px}.hero-bio b{color:var(--text);font-weight:500}.hero-links{display:flex;gap:12px;flex-wrap:wrap}.hero-portrait-wrap{position:relative;display:flex;justify-content:center;align-items:flex-end}.hero-portrait-glow{position:absolute;top:10%;left:50%;transform:translateX(-50%);width:200px;height:200px;border-radius:50%;background:radial-gradient(ellipse,rgba(220,80,255,.35) 0,rgba(180,0,200,.15) 40%,transparent 70%);filter:blur(20px);pointer-events:none;z-index:0}.hero-portrait{width:240px;border-radius:0;border:none;background:none;filter:drop-shadow(0 0 24px rgba(220,80,255,.55)) drop-shadow(0 0 60px rgba(180,0,200,.35));animation:float 4s ease-in-out infinite;position:relative;z-index:1}@keyframes float{0%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-14px) rotate(1deg)}to{transform:translateY(0) rotate(-1deg)}}.boot-lines{margin:40px 0 0;padding:20px 24px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r)}.boot-line{font-family:var(--mono);font-size:13px;margin-bottom:4px}.boot-line.dim{color:var(--dim)}.boot-line.green{color:var(--green)}.boot-line.teal{color:var(--teal)}.cursor{display:inline-block;width:8px;height:14px;background:var(--teal);vertical-align:middle;animation:blink 1s step-end infinite}@keyframes blink{50%{opacity:0}}.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:12px;padding:8px 16px;border-radius:6px;border:1px solid var(--border2);background:var(--surface);color:var(--text);text-decoration:none;cursor:pointer;transition:all .2s;white-space:nowrap}.btn:hover{background:var(--surface2);border-color:var(--teal);color:var(--teal);box-shadow:0 0 16px oklch(.82 .18 185/.2)}.btn svg{width:14px;height:14px}.skill-tags{display:flex;flex-wrap:wrap;gap:6px}.tag{font-family:var(--mono);font-size:11px;padding:3px 8px;border-radius:4px;background:rgba(0,200,160,.08);border:1px solid rgba(0,200,160,.2);color:var(--teal)}.tag.secondary{background:rgba(200,0,120,.08);border-color:rgba(200,0,120,.2);color:var(--magenta)}.tag.neutral{background:rgba(255,255,255,.05);border-color:var(--border);color:var(--dim)}.tag.green{background:rgba(80,200,80,.08);border-color:rgba(80,200,80,.2);color:var(--green)}.tag.amber{background:rgba(220,160,40,.08);border-color:rgba(220,160,40,.2);color:var(--amber)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:24px;transition:all .25s;position:relative;overflow:hidden}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--teal),transparent);opacity:0;transition:opacity .25s}.card:hover{background:var(--surface2);border-color:var(--border2);transform:translateY(-2px);box-shadow:0 12px 40px rgba(0,0,0,.4)}.card:hover:before{opacity:1}.card-status{font-family:var(--mono);font-size:10px;padding:2px 8px;border-radius:4px;background:rgba(220,160,40,.1);border:1px solid rgba(220,160,40,.3);color:var(--amber);display:inline-block;margin-bottom:10px}.card-status.done{background:rgba(80,200,80,.08);border-color:rgba(80,200,80,.25);color:var(--green)}.card-status.tinkering{background:rgba(0,200,160,.08);border-color:rgba(0,200,160,.25);color:var(--teal)}.card-title{font-size:15px;font-weight:600;color:var(--text);margin-bottom:8px;line-height:1.3}.card-desc{font-size:14px;color:var(--dim);line-height:1.6;margin-bottom:16px}.card-footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}.lock-badge{font-family:var(--mono);font-size:10px;padding:2px 8px;border-radius:4px;border:1px solid var(--border);color:var(--dimmer);opacity:.6}.proj-card{padding:0;overflow:hidden}.proj-img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block;filter:grayscale(30%) brightness(.85);transition:filter .3s}.proj-card:hover .proj-img{filter:grayscale(0) brightness(1)}.proj-body{padding:20px}.grid2{grid-template-columns:repeat(auto-fill,minmax(400px,1fr));grid-gap:20px}.grid2,.grid3{display:grid;gap:20px}.grid3{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:20px}.grid-awards{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));grid-gap:20px;gap:20px}.profile-statbar{display:flex;gap:0;margin-bottom:32px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow:hidden}.profile-stat{flex:1 1;padding:18px 20px;border-right:1px solid var(--border);position:relative}.profile-stat:last-child{border-right:none}.profile-stat:before{content:"";position:absolute;top:0;left:0;right:0;height:2px}.profile-stat.s1:before{background:var(--teal);box-shadow:0 0 10px var(--teal)}.profile-stat.s2:before{background:var(--magenta);box-shadow:0 0 10px var(--magenta)}.profile-stat.s3:before{background:var(--green);box-shadow:0 0 10px var(--green)}.profile-stat.s4:before{background:var(--amber);box-shadow:0 0 10px var(--amber)}.ps-label{font-family:var(--mono);font-size:10px;color:var(--dimmer);text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px}.ps-value{font-size:14px;font-weight:600;color:var(--text);line-height:1.2}.ps-value.teal{color:var(--teal)}.ps-value.green{color:var(--green)}.ps-value.amber{color:var(--amber)}.skills-matrix{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:1px;gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--r);overflow:hidden}.sm-group{background:var(--bg);padding:20px;transition:background .2s}.sm-group:hover{background:var(--surface)}.sm-title{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid var(--border)}.sm-title.teal{color:var(--teal);border-color:rgba(0,200,160,.2)}.sm-title.magenta{color:var(--magenta);border-color:rgba(200,0,120,.2)}.sm-title.green{color:var(--green);border-color:rgba(80,200,80,.2)}.sm-title.amber{color:var(--amber);border-color:rgba(220,160,40,.2)}.sm-title.dim{color:var(--dim)}.timeline{display:flex;flex-direction:column;gap:0}.tl-item{display:grid;grid-template-columns:auto 1fr;grid-gap:0 24px;gap:0 24px}.tl-line{display:flex;flex-direction:column;align-items:center}.tl-dot{width:12px;height:12px;border-radius:50%;background:var(--teal);border:2px solid var(--bg);box-shadow:0 0 12px var(--teal);flex-shrink:0;margin-top:4px}.tl-connector{width:1px;flex:1 1;background:var(--border);margin:4px 0;min-height:32px}.tl-content{padding-bottom:40px}.tl-title{font-size:16px;font-weight:600;color:var(--text)}.tl-company{font-family:var(--mono);font-size:13px;color:var(--teal)}.tl-period{font-size:11px;margin-bottom:10px}.tl-period,.tl-type-badge{font-family:var(--mono);color:var(--dim)}.tl-type-badge{font-size:10px;padding:2px 8px;border-radius:4px;border:1px solid var(--border)}.tl-type-badge.intern{border-color:rgba(80,200,80,.3);color:var(--green);background:rgba(80,200,80,.06)}.tl-type-badge.org{border-color:rgba(0,200,160,.3);color:var(--teal);background:rgba(0,200,160,.06)}.tl-type-badge.fulltime{border-color:rgba(220,160,40,.3);color:var(--amber);background:rgba(220,160,40,.06)}.tl-type-badge.freelance{border-color:rgba(200,80,200,.3);color:var(--magenta);background:rgba(200,80,200,.06)}.tl-desc{font-size:14px;color:var(--dim);line-height:1.65;margin-bottom:12px}.award-icon{width:40px;height:40px;border-radius:8px;background:rgba(220,160,40,.1);border:1px solid rgba(220,160,40,.25);display:flex;align-items:center;justify-content:center;flex-shrink:0}.award-icon svg{width:18px;height:18px;color:var(--amber)}.award-header{display:flex;gap:14px;margin-bottom:10px}.award-info{flex:1 1}.award-title{font-size:14px;font-weight:600;color:var(--text);line-height:1.3;margin-bottom:4px}.award-org{font-family:var(--mono);font-size:11px;color:var(--amber)}.award-desc{font-size:13px;color:var(--dim);line-height:1.55;margin-bottom:8px}.award-date{font-family:var(--mono);font-size:11px;color:var(--dimmer)}.event-card{padding:0;display:grid;grid-template-columns:160px 1fr;overflow:hidden}.event-img{width:160px;height:100%;min-height:140px;object-fit:cover;filter:grayscale(30%) brightness(.8);transition:filter .3s}.event-card:hover .event-img{filter:grayscale(0) brightness(1)}.event-body{padding:20px}.event-badge{font-family:var(--mono);font-size:10px;padding:2px 8px;border-radius:4px;border:1px solid;display:inline-block;margin-bottom:8px}.badge-competition{border-color:rgba(220,160,40,.4);color:var(--amber);background:rgba(220,160,40,.08)}.badge-hackathon{border-color:rgba(0,160,255,.4);color:oklch(.78 .15 220);background:rgba(0,160,255,.08)}.badge-ctf{border-color:rgba(255,80,80,.4);color:oklch(.72 .2 15);background:rgba(255,80,80,.08)}.badge-conference{border-color:rgba(0,200,160,.4);color:var(--teal);background:rgba(0,200,160,.08)}.event-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:6px;line-height:1.3}.event-meta{font-family:var(--mono);font-size:11px;color:var(--dimmer);margin-bottom:8px}.event-desc{font-size:13px;color:var(--dim);line-height:1.55}footer.portfolio-footer{padding:60px 0 48px;margin-top:80px;border-top:1px solid var(--border);text-align:center}.footer-cmd{font-family:var(--mono);font-size:13px;color:var(--dim);margin-bottom:8px}.footer-cmd:before{content:"$ ";color:var(--dimmer)}.footer-msg{font-family:var(--mono);font-size:14px;color:var(--green);margin-bottom:8px}.footer-sub{font-family:var(--mono);font-size:11px;color:var(--dimmer)}@media (max-width:700px){.hero-grid{grid-template-columns:1fr}.hero-portrait{width:140px}.grid-awards,.grid2,.grid3{grid-template-columns:1fr}.profile-statbar{flex-wrap:wrap}.profile-stat{flex:1 1 45%;border-right:none;border-bottom:1px solid var(--border)}.skills-matrix{grid-template-columns:1fr 1fr}.event-card{grid-template-columns:1fr}.event-img{width:100%;height:160px}.nav-links{display:none}}@media (max-width:480px){.skills-matrix{grid-template-columns:1fr}}