@import "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Sora:wght@400;500;600;700&family=Inter:wght@400;500;600&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg:#0a0c10;--bg-grad:#0c0f16;--surface:#11161f;--surface-2:#161d29;--surface-3:#1c2533;--border:#ffffff12;--border-strong:#ffffff21;--text:#e8edf4;--text-dim:#95a1b2;--text-faint:#5a6473;--accent:#3b82f6;--accent-2:#14b8a6;--accent-soft:#3b82f624;--font-head:"Space Grotesk", system-ui, sans-serif;--font-body:"Inter", system-ui, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, monospace;--reveal-dist:26px;--reveal-dur:.7s;--s-1:4px;--s-2:8px;--s-3:12px;--s-4:16px;--s-5:24px;--s-6:32px;--s-7:48px;--s-8:64px;--s-9:96px;--s-10:128px;--radius:14px;--radius-sm:9px;--maxw:1160px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--font-body);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;margin:0;font-size:17px;line-height:1.65;overflow-x:hidden}::selection{background:var(--accent);color:#fff}a{color:inherit;text-decoration:none}h1,h2,h3,h4{font-family:var(--font-head);letter-spacing:-.02em;text-wrap:balance;margin:0;font-weight:600;line-height:1.08}p{text-wrap:pretty;margin:0}.wrap{max-width:var(--maxw);padding:0 var(--s-6);margin:0 auto}.section{padding:var(--s-10) 0;position:relative}@media (width<=760px){.section{padding:var(--s-9) 0}}.eyebrow{font-family:var(--font-mono);letter-spacing:.16em;text-transform:uppercase;color:var(--accent-2);align-items:center;gap:var(--s-3);margin-bottom:var(--s-5);font-size:13px;display:inline-flex}.eyebrow:before{content:"";background:var(--accent-2);opacity:.6;width:26px;height:1px}.section-title{margin-bottom:var(--s-7);max-width:16ch;font-size:clamp(28px,4vw,44px)}.reveal{opacity:0;transform:translateY(var(--reveal-dist));transition:opacity var(--reveal-dur) cubic-bezier(.16,.84,.44,1), transform var(--reveal-dur) cubic-bezier(.16,.84,.44,1);transition-delay:var(--reveal-delay,0s)}.reveal.in{opacity:1;transform:none}@media (prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important}}.nav{z-index:50;padding:var(--s-4) var(--s-6);border-bottom:1px solid #0000;justify-content:space-between;align-items:center;transition:background .35s,border-color .35s,padding .35s;display:flex;position:fixed;top:0;left:0;right:0}.nav.scrolled{-webkit-backdrop-filter:blur(14px)saturate(140%);backdrop-filter:blur(14px)saturate(140%);border-bottom:1px solid var(--border);padding-top:var(--s-3);padding-bottom:var(--s-3);background:#0a0c10b8}.nav-logo{font-family:var(--font-head);letter-spacing:-.01em;align-items:center;gap:var(--s-3);font-size:18px;font-weight:600;display:flex}.nav-logo .dot{background:var(--accent);width:9px;height:9px;box-shadow:0 0 0 4px var(--accent-soft);border-radius:50%}.nav-links{align-items:center;gap:var(--s-6);display:flex}.nav-links a{color:var(--text-dim);font-size:14px;font-family:var(--font-mono);letter-spacing:.02em;transition:color .2s}.nav-links a span{color:var(--accent-2);margin-right:6px}.nav-links a:hover{color:var(--text)}.nav-cta{border:1px solid var(--border-strong);border-radius:100px;padding:9px 18px;transition:border-color .2s,background .2s,color .2s;font-family:var(--font-body)!important;color:var(--text)!important;font-size:14px!important}.nav-cta:hover{background:var(--accent);border-color:var(--accent);color:#fff!important}.nav-hamburger{cursor:pointer;background:0 0;border:none;flex-direction:column;gap:5px;padding:4px;display:none}.nav-hamburger span{background:var(--text-dim);border-radius:2px;width:22px;height:2px;transition:transform .2s,opacity .2s;display:block}@media (width<=720px){.nav-link,.nav-cta{display:none!important}.nav-hamburger{display:flex}}.mobile-menu{z-index:49;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);justify-content:center;align-items:center;gap:var(--s-7);opacity:0;pointer-events:none;background:#0a0c10f7;flex-direction:column;transition:opacity .3s;display:flex;position:fixed;inset:0}.mobile-menu.open{opacity:1;pointer-events:all}.mobile-menu a{font-family:var(--font-head);color:var(--text-dim);font-size:32px;font-weight:600;transition:color .2s}.mobile-menu a:hover{color:var(--text)}.btn{align-items:center;gap:var(--s-3);font-family:var(--font-body);cursor:pointer;border:1px solid #0000;border-radius:100px;padding:14px 26px;font-size:15px;font-weight:500;transition:transform .18s,background .2s,border-color .2s,box-shadow .25s,color .2s;display:inline-flex}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 6px 24px -8px var(--accent)}.btn-primary:hover{box-shadow:0 10px 34px -8px var(--accent);transform:translateY(-2px)}.btn-ghost{color:var(--text);border-color:var(--border-strong);background:0 0}.btn-ghost:hover{border-color:var(--accent-2);color:var(--accent-2);transform:translateY(-2px)}.btn .arrow{transition:transform .2s}.btn:hover .arrow{transform:translate(3px,-3px)}.hero{align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}#hero-canvas{z-index:0;width:100%;height:100%;position:absolute;inset:0}.hero-veil{z-index:1;pointer-events:none;background:radial-gradient(900px 600px at 72% 35%, #3b82f61a, transparent 60%), radial-gradient(700px 520px at 20% 80%, #14b8a614, transparent 60%), linear-gradient(180deg, transparent 55%, var(--bg) 100%);position:absolute;inset:0}.hero-inner{z-index:2;width:100%;position:relative}.hero-badge{font-family:var(--font-mono);color:var(--text-dim);border:1px solid var(--border);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);margin-bottom:var(--s-6);background:#11161f99;border-radius:100px;align-items:center;gap:10px;padding:7px 14px 7px 12px;font-size:13px;display:inline-flex}.hero-badge .pulse{background:var(--accent-2);border-radius:50%;flex-shrink:0;width:7px;height:7px;position:relative}.hero-badge .pulse:after{content:"";background:var(--accent-2);opacity:.4;border-radius:50%;animation:2.4s ease-out infinite pulse;position:absolute;inset:-4px}@keyframes pulse{0%{opacity:.5;transform:scale(.6)}to{opacity:0;transform:scale(2.4)}}.hero h1{letter-spacing:-.035em;margin-bottom:var(--s-5);font-size:clamp(46px,8.5vw,104px);font-weight:600}.hero h1 .grad{background:linear-gradient(100deg, var(--accent) 10%, var(--accent-2) 90%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-tag{color:var(--text-dim);max-width:22ch;font-size:clamp(19px,2.4vw,27px);font-family:var(--font-head);margin-bottom:var(--s-7);font-weight:400}.hero-ctas{gap:var(--s-4);flex-wrap:wrap;display:flex}.scroll-hint{z-index:2;font-family:var(--font-mono);letter-spacing:.2em;text-transform:uppercase;color:var(--text-faint);flex-direction:column;align-items:center;gap:10px;font-size:11px;display:flex;position:absolute;bottom:28px;left:50%;transform:translate(-50%)}.scroll-hint .line{background:linear-gradient(var(--text-faint), transparent);width:1px;height:38px;animation:2s ease-in-out infinite drop}@keyframes drop{0%,to{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}.about-grid{gap:var(--s-9);grid-template-columns:300px 1fr;align-items:start;display:grid}@media (width<=860px){.about-grid{gap:var(--s-7);grid-template-columns:1fr}.about-grid .photo{margin:0 auto}}.photo{border:1px solid var(--border-strong);border-radius:50%;justify-content:center;align-items:center;width:260px;height:260px;display:flex;position:relative;overflow:hidden;box-shadow:0 30px 80px -30px #000c}.photo img{object-fit:cover;width:100%;height:100%}.photo:after{content:"";background:radial-gradient(120% 120% at 70% 20%, var(--accent-soft), transparent 55%);pointer-events:none;border-radius:50%;position:absolute;inset:0;box-shadow:inset 0 0 0 1px #ffffff0a}.bio p{color:var(--text-dim);margin-bottom:var(--s-5);max-width:56ch;font-size:18px}.bio p strong{color:var(--text);font-weight:500}.bio .lead{color:var(--text);font-size:22px;font-family:var(--font-head);line-height:1.4}.skills-block{margin-top:var(--s-8)}.skills-head{font-family:var(--font-mono);color:var(--text-faint);letter-spacing:.14em;text-transform:uppercase;margin-bottom:var(--s-4);font-size:13px}.skills-grid{gap:var(--s-3);margin-bottom:var(--s-6);flex-wrap:wrap;display:flex}.skill-chip{background:var(--surface);border:1px solid var(--border);color:var(--text-dim);font-size:14.5px;font-family:var(--font-mono);cursor:default;border-radius:10px;align-items:center;gap:9px;padding:9px 15px;transition:transform .18s,border-color .2s,color .2s,background .2s;display:inline-flex}.skill-chip .sq{background:var(--accent);border-radius:2px;flex:none;width:7px;height:7px}.skill-chip:nth-child(2n) .sq{background:var(--accent-2)}.skill-chip:hover{border-color:var(--border-strong);color:var(--text);background:var(--surface-2);transform:translateY(-3px)}.timeline{margin-left:8px;position:relative}.timeline:before{content:"";background:linear-gradient(var(--border-strong), var(--border) 70%, transparent);width:2px;position:absolute;top:6px;bottom:6px;left:7px}.tl-item{padding-left:42px;padding-bottom:var(--s-7);cursor:pointer;position:relative}.tl-item:last-child{padding-bottom:0}.tl-dot{background:var(--surface-3);border:2px solid var(--border-strong);z-index:2;border-radius:50%;width:16px;height:16px;transition:all .25s;position:absolute;top:4px;left:0}.tl-item.current .tl-dot{background:var(--accent);border-color:var(--accent);box-shadow:0 0 0 5px var(--accent-soft)}.tl-item:hover .tl-dot{border-color:var(--accent-2);transform:scale(1.12)}.tl-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:var(--s-5) var(--s-6);transition:border-color .25s,transform .25s,background .25s}.tl-item:hover .tl-card{border-color:var(--border-strong);transform:translate(4px)}.tl-top{align-items:center;gap:var(--s-4);flex-wrap:wrap;margin-bottom:6px;display:flex}.tl-logo{background:var(--surface-3);border:1px solid var(--border-strong);width:40px;height:40px;font-family:var(--font-mono);color:var(--text-dim);letter-spacing:.02em;border-radius:9px;flex:none;justify-content:center;align-items:center;font-size:13px;font-weight:600;display:flex;overflow:hidden}.tl-logo img{object-fit:contain;filter:brightness(.9);width:100%;height:100%;padding:6px}.tl-role{font-family:var(--font-head);font-size:19px;font-weight:600}.tl-meta{flex-wrap:wrap;align-items:baseline;gap:10px;margin-top:3px;display:flex}.tl-company{color:var(--accent-2);font-size:14.5px;font-family:var(--font-mono)}.tl-location{font-family:var(--font-mono);color:var(--text-faint);font-size:13px}.tl-dates{font-family:var(--font-mono);color:var(--text-faint);white-space:nowrap;margin-left:auto;font-size:13px}.tl-badge-now{font-family:var(--font-mono);letter-spacing:.08em;color:var(--accent);border:1px solid var(--accent-soft);background:var(--accent-soft);text-transform:uppercase;border-radius:100px;padding:2px 8px;font-size:11px}.tl-desc{color:var(--text-dim);max-width:62ch;font-size:15.5px;transition:max-height .35s,opacity .3s,margin .3s;overflow:hidden}@media (width<=600px){.tl-dates{width:100%;margin-left:0}}.filters{gap:var(--s-2);margin-bottom:var(--s-7);flex-wrap:wrap;display:flex}.filter{font-family:var(--font-mono);cursor:pointer;border:1px solid var(--border);color:var(--text-dim);background:0 0;border-radius:100px;padding:9px 16px;font-size:13px;transition:all .2s}.filter:hover{color:var(--text);border-color:var(--border-strong)}.filter.active{background:var(--text);color:var(--bg);border-color:var(--text);font-weight:500}.filter .count{opacity:.55;margin-left:6px;font-size:11px}.proj-grid{gap:var(--s-5);grid-template-columns:repeat(3,1fr);display:grid}@media (width<=940px){.proj-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.proj-grid{grid-template-columns:1fr}}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:var(--s-6);gap:var(--s-4);flex-direction:column;transition:transform .26s cubic-bezier(.16,.84,.44,1),border-color .26s,box-shadow .26s,background .26s;animation:.45s cubic-bezier(.16,.84,.44,1) both cardIn;display:flex;position:relative;overflow:hidden}@keyframes cardIn{0%{opacity:0;transform:translateY(14px)scale(.98)}to{opacity:1;transform:none}}.card:before{content:"";background:linear-gradient(90deg, var(--accent), var(--accent-2));transform-origin:0;width:100%;height:2px;transition:transform .3s;position:absolute;top:0;left:0;transform:scaleX(0)}.card:hover{border-color:var(--border-strong);background:var(--surface-2);transform:translateY(-6px);box-shadow:0 24px 60px -28px #000000e6}.card:hover:before{transform:scaleX(1)}.card-img{width:calc(100% + var(--s-6) * 2);margin:calc(var(--s-6) * -1) calc(var(--s-6) * -1) 0;border-radius:var(--radius) var(--radius) 0 0;flex-shrink:0;height:180px;overflow:hidden}.card-img img{object-fit:cover;width:100%;height:100%;transition:transform .4s cubic-bezier(.16,.84,.44,1);display:block}.card:hover .card-img img{transform:scale(1.04)}.card-cat{font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--text-faint);font-size:11px}.card-name{font-family:var(--font-head);font-size:19px;font-weight:600;line-height:1.2}.card-desc{color:var(--text-dim);flex:1;font-size:14.5px}.card-tags{flex-wrap:wrap;gap:7px;display:flex}.tag{font-family:var(--font-mono);background:var(--surface-3);color:var(--text-dim);border:1px solid var(--border);border-radius:6px;padding:4px 9px;font-size:11.5px}.card-links{gap:var(--s-3);flex-wrap:wrap;margin-top:2px;display:flex}.card-link{white-space:nowrap;font-family:var(--font-mono);color:var(--text-dim);border:1px solid var(--border);border-radius:8px;align-items:center;gap:6px;padding:7px 13px;font-size:12.5px;transition:all .2s;display:inline-flex}.card-link:hover{color:var(--text);border-color:var(--accent);background:var(--accent-soft)}.card-link.live:hover{border-color:var(--accent-2);color:var(--accent-2);background:#14b8a61f}.contact-grid{gap:var(--s-9);grid-template-columns:1fr 1fr;align-items:start;display:grid}@media (width<=820px){.contact-grid{gap:var(--s-7);grid-template-columns:1fr}}.contact-lead{font-size:clamp(26px,3.2vw,40px);font-family:var(--font-head);margin-bottom:var(--s-5)}.contact-lead .grad{background:linear-gradient(100deg,var(--accent),var(--accent-2));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.contact-sub{color:var(--text-dim);max-width:42ch;margin-bottom:var(--s-7);font-size:18px}.socials{gap:var(--s-3);flex-direction:column;display:flex}.social{align-items:center;gap:var(--s-4);padding:var(--s-4) var(--s-5);border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);transition:all .2s;display:flex}.social:hover{border-color:var(--border-strong);background:var(--surface-2);transform:translate(4px)}.social .ic{background:var(--surface-3);width:38px;height:38px;color:var(--text);border:1px solid var(--border-strong);font-family:var(--font-mono);border-radius:9px;flex:none;place-items:center;font-size:17px;display:grid}.social .ic svg{width:18px;height:18px}.social .lbl{font-family:var(--font-mono);color:var(--text-faint);text-transform:uppercase;letter-spacing:.1em;font-size:12px}.social .val{color:var(--text);font-size:15px}.social .go{color:var(--text-faint);margin-left:auto;transition:transform .2s,color .2s}.social:hover .go{color:var(--accent-2);transform:translate(3px,-3px)}.form{gap:var(--s-4);flex-direction:column;display:flex}.field{flex-direction:column;gap:7px;display:flex}.field label{font-family:var(--font-mono);color:var(--text-faint);letter-spacing:.08em;text-transform:uppercase;font-size:12px}.field input,.field textarea{font-family:var(--font-body);color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);resize:vertical;outline:none;padding:13px 15px;font-size:15px;transition:border-color .2s,background .2s,box-shadow .2s}.field input::placeholder,.field textarea::placeholder{color:var(--text-faint)}.field input:focus,.field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:var(--surface-2)}.field.err input,.field.err textarea{border-color:#ef4444;box-shadow:0 0 0 3px #ef444424}.field .msg{font-family:var(--font-mono);color:#f87171;font-size:11.5px}.form-foot{align-items:center;gap:var(--s-5);flex-wrap:wrap;margin-top:4px;display:flex}.form-note{font-family:var(--font-mono);color:var(--text-faint);font-size:12px}.footer-wrap{border-top:1px solid var(--border)}.footer{padding:var(--s-7) 0;justify-content:space-between;align-items:center;gap:var(--s-5);flex-wrap:wrap;display:flex}.footer .f-name{font-family:var(--font-head);font-size:16px;font-weight:600}.footer .f-meta{font-family:var(--font-mono);color:var(--text-faint);font-size:12.5px}.footer .f-links{gap:var(--s-5);flex-wrap:wrap;display:flex}.footer .f-links a{font-family:var(--font-mono);color:var(--text-dim);font-size:13px;transition:color .2s}.footer .f-links a:hover{color:var(--accent-2)}@media (width<=600px){.footer{text-align:center;align-items:center;gap:var(--s-6);flex-direction:column}.footer .f-links{justify-content:center;gap:var(--s-4)}}
