@import "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@400;500;600&family=JetBrains+Mono:wght@400;500;600&display=swap";:root{--bg:#0a0e14;--surface-1:#0d1117;--surface-2:#111722;--surface-3:#161d2b;--surface-4:#1c2436;--border-subtle:#ffffff12;--border-default:#ffffff1f;--border-amber:#f2b84b66;--amber-300:#f2b84b;--amber-glow:#f2b84b1a;--green-300:#5fd9a4;--blue-300:#5b9cf2;--coral-300:#f2725b;--text-primary:#eef1f6;--text-secondary:#9aa3b5;--text-muted:#5e6878;--ink-900:#06080c;--font-display:"Space Grotesk", sans-serif;--font-body:"Inter", sans-serif;--font-mono:"JetBrains Mono", monospace}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text-primary);font-family:var(--font-body);-webkit-font-smoothing:antialiased;overflow-x:hidden}a{color:inherit;text-decoration:none}ul{list-style:none}button{font-family:inherit}@media (prefers-reduced-motion:reduce){*{transition-duration:.001ms!important;animation-duration:.001ms!important}}.bg-noise{z-index:0;pointer-events:none;background:radial-gradient(circle at 12% 18%,#f2b84b0f,#0000 40%),radial-gradient(circle at 88% 78%,#5fd9a40d,#0000 45%);position:fixed;inset:0}.bg-grid{z-index:0;pointer-events:none;opacity:.5;background-image:linear-gradient(#ffffff0a 1px,#0000 1px),linear-gradient(90deg,#ffffff0a 1px,#0000 1px);background-size:48px 48px;position:fixed;inset:0;-webkit-mask-image:radial-gradient(circle at 50% 0,#000,#0000 78%);mask-image:radial-gradient(circle at 50% 0,#000,#0000 78%)}nav.main-nav{z-index:100;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#0a0e1466;border-bottom:1px solid #0000;justify-content:space-between;align-items:center;padding:18px 4vw;transition:background .28s,border-color .28s;display:flex;position:fixed;top:0;left:0;right:0}nav.main-nav.scrolled{border-bottom-color:var(--border-subtle);background:#0a0e14d9}.nav-logo{font-family:var(--font-display);letter-spacing:-.02em;color:var(--text-primary);font-size:18px;font-weight:700}.nav-logo span{color:var(--amber-300)}.nav-links{align-items:center;gap:34px;display:flex}.nav-links a{font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;color:var(--text-secondary);font-size:12px;transition:color .2s;position:relative}.nav-links a:hover{color:var(--text-primary)}.nav-links a.active{color:var(--amber-300)}.nav-cta{border-radius:999px;padding:7px 16px;border:1px solid var(--border-amber)!important;color:var(--amber-300)!important}.nav-hamburger{cursor:pointer;z-index:101;background:0 0;border:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:38px;height:38px;display:none;position:relative}.nav-hamburger span{background:var(--text-primary);transform-origin:50%;border-radius:2px;width:22px;height:2px;transition:transform .28s cubic-bezier(.4,0,.2,1),opacity .28s,background .28s}.nav-hamburger.is-open span:first-child{transform:translateY(7px)rotate(45deg)}.nav-hamburger.is-open span:nth-child(2){opacity:0}.nav-hamburger.is-open span:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.mobile-nav{z-index:98;background:var(--ink-900);visibility:hidden;flex-direction:column;padding:110px 8vw 40px;transition:transform .35s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;inset:0;transform:translate(100%)}.mobile-nav.open{visibility:visible;transform:translate(0)}.mobile-nav a{font-family:var(--font-display);color:var(--text-primary);border-bottom:1px solid var(--border-subtle);padding:14px 0;font-size:32px;font-weight:600;display:block}.mobile-nav a.active{color:var(--amber-300)}.hero{z-index:1;align-items:center;min-height:100vh;padding:120px 4vw 60px;display:flex;position:relative}.hero-content{grid-template-columns:1fr 1fr;align-items:center;gap:40px;width:100%;max-width:1360px;margin:0 auto;display:grid}.hero-eyebrow{font-family:var(--font-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--amber-300);align-items:center;gap:10px;margin-bottom:18px;font-size:12px;display:flex}.hero-eyebrow:before{content:"";background:var(--green-300);width:8px;height:8px;box-shadow:0 0 8px var(--green-300);border-radius:50%;animation:2s infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.3}}.hero-title{font-family:var(--font-display);letter-spacing:-.03em;margin-bottom:22px;font-size:clamp(40px,6.4vw,78px);font-weight:700;line-height:.98}.hero-title .first{color:var(--text-primary);display:block}.hero-title .last{color:#0000;-webkit-text-stroke:1.5px var(--text-primary);display:block}.hero-role{color:var(--text-secondary);max-width:480px;margin-bottom:14px;font-size:16px;line-height:1.7}.hero-role b{color:var(--text-primary);font-weight:600}.terminal{font-family:var(--font-mono);background:var(--surface-2);border:1px solid var(--border-subtle);max-width:480px;color:var(--text-secondary);border-radius:10px;min-height:84px;margin:22px 0 28px;padding:14px 18px;font-size:13px}.terminal .line{color:var(--text-muted)}.terminal .prompt{color:var(--green-300);margin-right:8px}.terminal .cursor{background:var(--amber-300);vertical-align:middle;width:7px;height:14px;margin-left:2px;animation:1s step-end infinite blink;display:inline-block}@keyframes blink{50%{opacity:0}}.hero-actions{flex-wrap:wrap;gap:14px;margin-bottom:42px;display:flex}.btn{letter-spacing:.01em;cursor:pointer;border:1px solid #0000;border-radius:8px;align-items:center;gap:9px;padding:13px 26px;font-size:13px;font-weight:600;transition:transform .22s,box-shadow .22s,background .22s,border-color .22s;display:inline-flex}.btn-primary{background:var(--amber-300);color:var(--ink-900)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 30px -8px #f2b84b80}.btn-ghost{border-color:var(--border-default);color:var(--text-primary)}.btn-ghost:hover{border-color:var(--border-amber);color:var(--amber-300);transform:translateY(-2px)}.hero-stats{gap:42px;display:flex}.stat-value{font-family:var(--font-display);color:var(--text-primary);font-size:30px;font-weight:700}.stat-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-top:2px;font-size:11px}.hero-right{flex-direction:column;justify-content:center;align-items:center;gap:28px;padding-top:10px;display:flex;position:relative}.hero-portrait-stage{width:400px;height:480px;position:relative}.hero-portrait-frame{border:1px solid var(--border-subtle);z-index:1;border-radius:20px;position:absolute;inset:0;overflow:hidden;box-shadow:0 30px 60px -20px #0009}.hero-portrait-img{object-fit:cover;filter:grayscale()contrast(1.1)brightness(.95);width:100%;height:100%;display:block}.hero-portrait-frame:after{content:"";background:linear-gradient(#0a0e140d 0%,#0a0e14bf 100%),linear-gradient(150deg,#f2b84b38,#0000 60%);position:absolute;inset:0}.hero-portrait-badge{z-index:2;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid var(--border-amber);font-family:var(--font-mono);color:var(--amber-300);letter-spacing:.04em;background:#0a0e14bf;border-radius:10px;padding:8px 14px;font-size:11px;position:absolute;bottom:14px;left:14px}.square-track{z-index:2;pointer-events:none;position:absolute;inset:0}.square-track .orbit-node{background:var(--surface-3);border:1px solid var(--border-default);width:42px;height:42px;color:var(--text-secondary);offset-path:path("M -18 -18 L 418 -18 L 418 498 L -18 498 Z");offset-rotate:0deg;border-radius:12px;justify-content:center;align-items:center;font-size:16px;animation:16s linear infinite travel-square;display:flex;position:absolute;top:0;left:0;box-shadow:0 6px 18px -6px #00000080}@keyframes travel-square{0%{offset-distance:0%}to{offset-distance:100%}}.square-track .orbit-node:first-child{animation-delay:0s}.square-track .orbit-node:nth-child(2){animation-delay:-2.66s}.square-track .orbit-node:nth-child(3){animation-delay:-5.33s}.square-track .orbit-node:nth-child(4){animation-delay:-8s}.square-track .orbit-node:nth-child(5){animation-delay:-10.66s}.square-track .orbit-node:nth-child(6){animation-delay:-13.33s}.skill-marquee{border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle);width:400px;padding:14px 0;position:relative;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,#0000,#000 12% 88%,#0000);mask-image:linear-gradient(90deg,#0000,#000 12% 88%,#0000)}.skill-marquee-track{gap:14px;width:max-content;animation:18s linear infinite marquee-scroll;display:flex}.skill-marquee-chip{background:var(--surface-3);border:1px solid var(--border-default);font-family:var(--font-mono);color:var(--text-secondary);white-space:nowrap;border-radius:999px;align-items:center;gap:8px;padding:9px 16px;font-size:12px;display:flex}.skill-marquee-chip i{color:var(--amber-300)}@keyframes marquee-scroll{0%{transform:translate(0)}to{transform:translate(-50%)}}@media (prefers-reduced-motion:reduce){.square-track .orbit-node{offset-distance:0%;animation:none}.skill-marquee-track{animation:none}}.hero-scroll{font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);flex-direction:column;align-items:center;gap:8px;font-size:10px;display:flex;position:absolute;bottom:36px;left:50%;transform:translate(-50%)}.scroll-line{background:linear-gradient(var(--text-muted), transparent);width:1px;height:30px;animation:2s infinite scroll-fade}@keyframes scroll-fade{0%{opacity:.2}50%{opacity:1}to{opacity:.2}}.section{z-index:1;max-width:1280px;margin:0 auto;padding:120px 4vw;position:relative}.section--about{--accent:var(--amber-300);--accent-glow:#f2b84b1f}.section--skills{--accent:var(--green-300);--accent-glow:#5fd9a41f}.section--projects{--accent:var(--blue-300);--accent-glow:#5b9cf21f}.section--contact{--accent:var(--coral-300);--accent-glow:#f27b5b1f}.section-eyebrow{font-family:var(--font-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--accent,var(--amber-300));align-items:center;gap:10px;margin-bottom:14px;font-size:11px;display:flex}.section-eyebrow:before{content:"";background:var(--accent,var(--amber-300));border-radius:2px;width:22px;height:2px}.section-title{font-family:var(--font-display);letter-spacing:-.02em;color:var(--text-primary);font-size:clamp(30px,4vw,46px);font-weight:700;line-height:1.08}.section-subtitle{color:var(--text-secondary);max-width:560px;margin-top:14px;font-size:15px;line-height:1.7}.reveal{opacity:0;transition:opacity .7s cubic-bezier(.2,.6,.2,1),transform .7s cubic-bezier(.2,.6,.2,1);transform:translateY(28px)}.reveal.visible{opacity:1;transform:translateY(0)}.about-grid{grid-template-columns:1fr 1fr;align-items:start;gap:60px;margin-top:48px;display:grid}.about-text p{color:var(--text-secondary);margin-bottom:18px;font-size:15px;line-height:1.85}.about-text p b{color:var(--text-primary)}.about-traits{flex-wrap:wrap;gap:10px;margin-top:22px;display:flex}.trait-chip{font-family:var(--font-mono);border:1px solid var(--border-default);color:var(--text-secondary);border-radius:999px;padding:7px 14px;font-size:11px}.about-card{background:var(--surface-2);border:1px solid var(--border-subtle);font-family:var(--font-mono);border-radius:14px;padding:26px;font-size:12.5px;line-height:1.9}.about-card .file-tab{border-bottom:1px solid var(--border-subtle);gap:8px;margin-bottom:18px;padding-bottom:14px;display:flex}.file-tab span{border-radius:50%;width:11px;height:11px}.about-card .k{color:var(--amber-300)}.about-card .s{color:var(--green-300)}.about-card .c{color:var(--text-muted)}.skills-grid{grid-template-columns:repeat(2,1fr);gap:22px;margin-top:48px;display:grid}.skill-group{background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:16px;padding:28px;transition:border-color .28s,transform .28s}.skill-group:hover{border-color:var(--accent,var(--border-amber));transform:translateY(-3px)}.skill-group-head{align-items:center;gap:12px;margin-bottom:18px;display:flex}.skill-group-icon{background:var(--accent-glow,var(--amber-glow));width:38px;height:38px;color:var(--accent,var(--amber-300));border-radius:10px;justify-content:center;align-items:center;font-size:16px;display:flex}.skill-group-title{font-family:var(--font-display);color:var(--text-primary);font-size:16px;font-weight:700}.skill-tags{flex-wrap:wrap;gap:8px;display:flex}.skill-tag{font-family:var(--font-mono);background:var(--surface-3);border:1px solid var(--border-subtle);color:var(--text-secondary);border-radius:7px;padding:6px 12px;font-size:11.5px}.projects-grid{grid-template-columns:repeat(2,1fr);gap:24px;margin-top:48px;display:grid}.project-card{background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:16px;flex-direction:column;gap:14px;transition:border-color .28s,transform .28s;display:flex;position:relative;overflow:hidden}.project-card-media{background:var(--surface-1);height:170px;margin:-1px -1px 0;overflow:hidden}.project-card-media img{object-fit:cover;width:100%;height:100%;transition:transform .5s}.project-card:hover .project-card-media img{transform:scale(1.06)}.project-card-body{flex-direction:column;flex:1;gap:14px;padding:24px 26px 28px;display:flex}.project-card:hover{border-color:var(--accent,var(--border-amber));transform:translateY(-4px)}.project-card .pc-top{justify-content:space-between;align-items:flex-start;display:flex}.project-num{font-family:var(--font-mono);color:var(--text-muted);font-size:11px}.project-link-icon{border:1px solid var(--border-default);width:34px;height:34px;color:var(--text-secondary);border-radius:50%;justify-content:center;align-items:center;transition:all .22s;display:flex}.project-card:hover .project-link-icon{border-color:var(--accent,var(--amber-300));color:var(--accent,var(--amber-300));transform:rotate(45deg)}.project-title{font-family:var(--font-display);color:var(--text-primary);font-size:21px;font-weight:700}.project-desc{color:var(--text-secondary);font-size:13.5px;line-height:1.7}.project-points{color:var(--text-muted);margin:4px 0;font-size:12.5px;line-height:1.8}.project-points li{gap:8px;margin-bottom:4px;display:flex}.project-points li:before{content:"›";color:var(--amber-300)}.project-tags{flex-wrap:wrap;gap:7px;margin-top:auto;padding-top:14px;display:flex}.contact-inner{grid-template-columns:1fr 1.1fr;gap:60px;margin-top:48px;display:grid}.contact-links-grid{flex-direction:column;gap:14px;margin-top:24px;display:flex}.contact-link{color:var(--text-secondary);border:1px solid var(--border-subtle);border-radius:10px;align-items:center;gap:12px;padding:14px 18px;font-size:14px;transition:all .22s;display:flex}.contact-link:hover{border-color:var(--accent,var(--border-amber));color:var(--accent,var(--amber-300));transform:translate(4px)}.contact-form{background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:16px;flex-direction:column;gap:18px;padding:32px;display:flex}.form-title{font-family:var(--font-display);margin-bottom:6px;font-size:18px;font-weight:700}.form-label{font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);margin-bottom:7px;font-size:11px;display:block}.contact-form input,.contact-form textarea{background:var(--surface-3);border:1px solid var(--border-subtle);width:100%;color:var(--text-primary);font-size:13.5px;font-family:var(--font-body);border-radius:8px;padding:12px 14px;transition:border-color .2s}.contact-form input:focus,.contact-form textarea:focus{border-color:var(--accent,var(--border-amber));outline:none}.contact-form textarea{resize:vertical;min-height:110px}.form-submit{background:var(--accent,var(--amber-300));color:var(--ink-900);cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:13px;font-size:13.5px;font-weight:700;transition:transform .2s;display:flex}.form-submit:hover{transform:translateY(-2px)}.form-status{color:var(--green-300);font-size:12.5px;font-family:var(--font-mono)}.blog-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:24px;display:grid}.blog-card{background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:16px;flex-direction:column;transition:border-color .28s,transform .28s;display:flex;overflow:hidden}.blog-card:hover{border-color:var(--border-amber);transform:translateY(-4px)}.blog-card-media{background:var(--surface-1);height:190px;overflow:hidden}.blog-card-media img{object-fit:cover;width:100%;height:100%;transition:transform .5s}.blog-card:hover .blog-card-media img{transform:scale(1.06)}.blog-card-body{flex-direction:column;gap:10px;padding:24px 26px 28px;display:flex}.blog-card-meta{align-items:center;gap:10px;display:flex}.blog-card-category{letter-spacing:.1em;text-transform:uppercase;color:var(--amber-300);background:var(--amber-glow);border:1px solid var(--border-amber);border-radius:4px;padding:3px 9px;font-size:10px;font-weight:700}.blog-card-date{font-family:var(--font-mono);color:var(--text-muted);font-size:11px}.blog-card-title{font-family:var(--font-display);color:var(--text-primary);letter-spacing:-.01em;font-size:19px;font-weight:700;line-height:1.35}.blog-card-excerpt{color:var(--text-secondary);font-size:13.5px;line-height:1.7}.blog-card-readmore{color:var(--amber-300);border-top:1px solid var(--border-subtle);align-items:center;gap:6px;margin-top:6px;padding-top:14px;font-size:12.5px;font-weight:600;display:flex}.blog-card-link{color:inherit;height:100%;text-decoration:none;display:block}.blog-post-content{max-width:840px;margin:0 auto}.blog-post-image{background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:16px;width:100%;height:400px;margin-bottom:32px;overflow:hidden}.blog-post-image img{object-fit:cover;width:100%;height:100%}.blog-post-meta{flex-wrap:wrap;align-items:center;gap:16px;margin-top:18px;display:flex}.blog-post-date{font-family:var(--font-mono);color:var(--text-muted);font-size:12px}.blog-post-body{color:var(--text-secondary);font-size:16px;line-height:1.85}.blog-post-body h2{font-family:var(--font-display);color:var(--text-primary);letter-spacing:-.01em;margin-top:36px;margin-bottom:16px;font-size:24px;font-weight:700}.blog-post-body p{margin-bottom:18px}.blog-post-body ul{margin:18px 0;padding-left:20px}.blog-post-body li{color:var(--text-secondary);margin-bottom:8px;line-height:1.7}.blog-post-body strong{color:var(--text-primary);font-weight:600}.project-card-link{color:inherit;height:100%;text-decoration:none;display:block}.project-detail-content{max-width:840px;margin:0 auto}.project-detail-image{background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:16px;width:100%;height:320px;margin-bottom:32px;overflow:hidden}.project-detail-image img{object-fit:cover;width:100%;height:100%}.project-detail-header{background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:16px;margin-bottom:32px;padding:32px}.project-detail-title{font-family:var(--font-display);color:var(--text-primary);letter-spacing:-.02em;margin-bottom:12px;font-size:28px;font-weight:700}.project-detail-desc{color:var(--text-secondary);margin-bottom:20px;font-size:15px;line-height:1.7}.project-detail-link{background:var(--amber-300);color:var(--ink-900);border-radius:8px;align-items:center;gap:8px;padding:12px 24px;font-size:13px;font-weight:600;transition:transform .22s;display:inline-flex}.project-detail-link:hover{transform:translateY(-2px)}.project-detail-points{background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:16px;margin-bottom:32px;padding:28px}.project-detail-points h3{font-family:var(--font-display);color:var(--text-primary);margin-bottom:16px;font-size:18px;font-weight:700}.project-detail-points ul{padding-left:20px}.project-detail-points li{color:var(--text-secondary);margin-bottom:10px;font-size:14px;line-height:1.7}.project-detail-points li:before{content:"›";color:var(--amber-300);margin-right:8px}.project-detail-description{background:var(--surface-2);border:1px solid var(--border-subtle);color:var(--text-secondary);border-radius:16px;padding:32px;font-size:15px;line-height:1.85}.project-detail-description h2{font-family:var(--font-display);color:var(--text-primary);letter-spacing:-.01em;margin-top:28px;margin-bottom:14px;font-size:22px;font-weight:700}.project-detail-description p{margin-bottom:16px}.project-detail-description ul{margin:16px 0;padding-left:20px}.project-detail-description li{margin-bottom:8px;line-height:1.7}.project-detail-description strong{color:var(--text-primary);font-weight:600}footer{z-index:1;border-top:1px solid var(--border-subtle);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:36px 4vw;display:flex;position:relative}.footer-brand{font-family:var(--font-display);font-size:16px;font-weight:700}.footer-brand span{color:var(--amber-300)}.footer-copy{color:var(--text-muted);font-size:12px;font-family:var(--font-mono)}.footer-links{color:var(--text-secondary);gap:22px;font-size:12.5px;display:flex}.footer-links a:hover{color:var(--amber-300)}.page-hero{border-bottom:1px solid var(--border-subtle);z-index:1;max-width:1280px;margin:0 auto;padding:150px 4vw 50px;position:relative}.back-link{font-family:var(--font-mono);color:var(--text-secondary);align-items:center;gap:8px;margin-bottom:20px;font-size:12px;transition:color .2s;display:inline-flex}.back-link:hover{color:var(--amber-300)}.blog-page-grid{z-index:1;max-width:1280px;margin:0 auto;padding:48px 4vw 100px;position:relative}.empty-state{text-align:center;color:var(--text-muted);padding:100px 20px}.empty-state i{opacity:.25;margin-bottom:16px;font-size:40px;display:block}@media (width<=980px){.hero-content{grid-template-columns:1fr}.orbit-wrapper{width:300px;height:300px}.hero-portrait-stage{width:280px;height:340px}.skill-marquee{width:280px}.square-track .orbit-node{offset-path:path("M -16 -16 L 298 -16 L 298 358 L -16 358 Z")}.about-grid,.contact-inner,.skills-grid,.projects-grid{grid-template-columns:1fr}.nav-links{display:none}.nav-hamburger{display:flex}}
