:root{--bg:#fafbfd;--bg-elevated:#f2f5fa;--surface:#fff;--border:#e3e8f0;--border-strong:#c9d2e0;--text:#0a1020;--text-muted:#48566e;--text-faint:#94a3b8;--accent:#2563eb;--accent-strong:#1d4ed8;--accent-2:#7c3aed;--accent-soft:#eff4ff;--gradient:linear-gradient(92deg, #2563eb 0%, #7c3aed 100%);--success:#047857;--danger:#b91c1c;--ink:#0f172a;--shadow-sm:0 1px 3px #0a10200f;--shadow-md:0 10px 30px #0a10201a;--radius:10px;--radius-lg:14px;--font-sans:"Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;--font-display:"Space Grotesk", "Inter", ui-sans-serif, system-ui, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, "Cascadia Code", Consolas, monospace;--container:1180px}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth;scroll-padding-top:72px}body{background:var(--bg);color:var(--text);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;margin:0;font-size:15.5px;line-height:1.55}::selection{color:var(--ink);background:#dbe6ff}img{max-width:100%;display:block}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3,h4{font-family:var(--font-display);color:var(--text);letter-spacing:-.02em;margin:0 0 .5em;font-weight:700;line-height:1.15}p{margin:0 0 1em}.container{max-width:var(--container);margin:0 auto;padding:0 24px}.section{padding:52px 0}.section-alt{background:var(--bg-elevated);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.accent-gradient{background:var(--gradient);color:#0000;-webkit-background-clip:text;background-clip:text}.section-eyebrow{font-family:var(--font-mono);letter-spacing:.1em;text-transform:lowercase;color:var(--accent);align-items:center;gap:10px;margin:0 0 10px;font-size:.76rem;font-weight:600;display:flex}.eyebrow-num{color:var(--text-faint)}.section-eyebrow:after{content:"";background:var(--border-strong);width:42px;height:1px}.section-title{max-width:900px;margin-bottom:8px;font-size:clamp(1.5rem,2.5vw,1.95rem)}.section-lead{color:var(--text-muted);max-width:720px;margin-bottom:26px;font-size:.98rem}[data-reveal]{opacity:0;transition:opacity .5s,transform .5s;transform:translateY(14px)}[data-reveal].revealed{opacity:1;transform:none}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}[data-reveal]{opacity:1;transition:none;transform:none}}.btn{border-radius:var(--radius);border:1px solid var(--border-strong);background:var(--surface);color:var(--text);font-size:.9rem;font-weight:600;font-family:var(--font-sans);cursor:pointer;white-space:nowrap;justify-content:center;align-items:center;gap:8px;padding:10px 18px;transition:all .15s;display:inline-flex}.btn:hover{border-color:var(--accent);color:var(--accent-strong);background:var(--accent-soft);text-decoration:none}.btn-primary{background:var(--gradient);color:#fff;border:none;padding:11px 19px;box-shadow:0 4px 16px #2563eb4d}.btn-primary:hover{filter:brightness(1.08);color:#fff;box-shadow:0 6px 20px #2563eb61}.btn-sm{box-shadow:none;padding:7px 13px;font-size:.83rem;font-weight:500}.btn:disabled{opacity:.6;cursor:not-allowed}.chip{border:1px solid var(--border);background:var(--surface);color:var(--text-muted);white-space:nowrap;border-radius:999px;padding:3px 10px;font-size:.77rem;font-weight:500;line-height:1.5;display:inline-block}.chip-row{flex-wrap:wrap;gap:7px;display:flex}.navbar{z-index:50;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);background:#fafbfdd9;position:sticky;top:0}.navbar-inner{justify-content:space-between;align-items:center;height:58px;display:flex}.navbar-brand{color:var(--text);font-family:var(--font-display);letter-spacing:-.01em;align-items:center;gap:10px;font-size:.98rem;font-weight:700;display:flex}.navbar-brand:hover{text-decoration:none}.navbar-logo{background:var(--gradient);width:32px;height:32px;font-family:var(--font-mono);color:#fff;border-radius:9px;place-items:center;font-size:.72rem;font-weight:600;display:grid}.navbar-links{align-items:center;gap:26px;display:flex}.navbar-links a{color:var(--text-muted);font-size:.9rem;font-weight:500;transition:color .15s}.navbar-links a:hover{color:var(--text);text-decoration:none}.navbar-links .btn{margin-left:6px;padding:8px 16px}.navbar-links a.btn-primary,.navbar-links a.btn-primary:hover{color:#fff}.navbar-links a.btn-primary{font-weight:600;box-shadow:0 3px 12px #2563eb47}.navbar-links a.btn-primary:hover{filter:brightness(1.08);box-shadow:0 5px 16px #2563eb5c}.navbar-toggle{background:var(--surface);border:1px solid var(--border-strong);color:var(--text);cursor:pointer;border-radius:8px;padding:5px 9px;font-size:1.05rem;display:none}.hero{border-bottom:1px solid var(--border);background:radial-gradient(ellipse 50% 60% at 85% 10%, #7c3aed0f, transparent), radial-gradient(ellipse 45% 55% at 10% 90%, #2563eb0d, transparent), var(--bg);padding:44px 0 40px;position:relative;overflow:hidden}.hero:before{content:"";pointer-events:none;background-image:radial-gradient(circle,#ccd6e8 1px,#0000 1px);background-size:26px 26px;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#00000080,#0000 70%);mask-image:linear-gradient(#00000080,#0000 70%)}.hero .container{position:relative}.hero-grid{grid-template-columns:1.35fr 1fr;align-items:center;gap:52px;margin-bottom:30px;display:grid}.hero-badge{color:#15803d;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:999px;align-items:center;gap:8px;margin:0 0 14px;padding:4px 12px;font-size:.78rem;font-weight:600;display:inline-flex}.hero-badge-dot{background:#22c55e;border-radius:50%;width:7px;height:7px;animation:2.4s ease-in-out infinite pulse;box-shadow:0 0 0 3px #22c55e33}@keyframes pulse{0%,to{box-shadow:0 0 0 3px #22c55e33}50%{box-shadow:0 0 0 6px #22c55e14}}.hero-greeting{font-family:var(--font-mono);color:var(--text-muted);margin:0 0 8px;font-size:.92rem;font-weight:500}.hero h1{max-width:620px;margin-bottom:14px;font-size:clamp(1.9rem,3.3vw,2.7rem);font-weight:700}.hero-subtitle{color:var(--text-muted);max-width:600px;margin-bottom:22px;font-size:.98rem}.hero-actions{flex-wrap:wrap;align-items:center;gap:14px;display:flex}.hero-resume-link{color:var(--text-muted);font-size:.88rem;font-weight:600}.hero-resume-link:hover{color:var(--accent);text-decoration:none}.hero-terminal-wrap{justify-content:flex-end;display:flex}.terminal{border-radius:var(--radius-lg);background:#0d1526;border:1px solid #1e293b;width:100%;max-width:440px;overflow:hidden;transform:rotate(.6deg);box-shadow:0 18px 44px #0a102047}.terminal-bar{background:#111c33;border-bottom:1px solid #1e293b;align-items:center;gap:7px;padding:10px 14px;display:flex}.t-dot{border-radius:50%;width:11px;height:11px}.t-red{background:#f87171}.t-yellow{background:#fbbf24}.t-green{background:#34d399}.terminal-title{font-family:var(--font-mono);color:#64748b;margin-left:8px;font-size:.7rem}.terminal-body{font-family:var(--font-mono);color:#cbd5e1;padding:14px 18px 16px;font-size:.78rem;line-height:1.75}.t-line{white-space:normal;overflow-wrap:anywhere}.t-entry{align-items:baseline;padding-left:1.4em;display:flex}.t-entry-key{white-space:pre;flex-shrink:0}.t-entry-value{overflow-wrap:anywhere;min-width:0}.t-prompt{color:#34d399;font-weight:600}.t-cmd{color:#e2e8f0}.t-key{color:#7dd3fc}.t-punc{color:#64748b}.t-str,.t-arr{color:#a5b4fc}.t-bool{color:#fbbf24}.t-status{color:#34d399;font-weight:600}.t-brace{color:#64748b}.t-cursor{vertical-align:middle;background:#34d399;width:8px;height:14px;margin-left:6px;animation:1.1s step-end infinite blink;display:inline-block}@keyframes blink{0%,55%{opacity:1}56%,to{opacity:0}}@media (prefers-reduced-motion:reduce){.t-cursor,.hero-badge-dot{animation:none}}.hero-stats{grid-template-columns:repeat(4,1fr);gap:14px;display:grid}.stat-card{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);min-width:0;box-shadow:var(--shadow-sm);flex-direction:column;gap:4px;padding:12px 16px;display:flex}.stat-value{font-family:var(--font-display);letter-spacing:-.02em;background:var(--gradient);color:#0000;white-space:nowrap;-webkit-background-clip:text;background-clip:text;font-size:1.15rem;font-weight:700}.stat-label{color:var(--text-muted);overflow-wrap:break-word;font-size:.8rem;line-height:1.45}.about-grid{grid-template-columns:290px 1.35fr 1fr;align-items:start;gap:30px;display:grid}.about-photo-frame{border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-md);position:relative;overflow:hidden}.about-photo{aspect-ratio:4/5;object-fit:cover;object-position:50% 18%;width:100%}.about-photo-tag{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid var(--border);color:var(--ink);background:#ffffffeb;border-radius:9px;align-items:center;gap:8px;padding:7px 12px;font-size:.82rem;font-weight:600;display:flex;position:absolute;bottom:10px;left:10px;right:10px}.about-photo-placeholder{aspect-ratio:4/5;background:linear-gradient(160deg, var(--accent-soft), var(--bg-elevated));place-items:center;display:grid}.about-photo-placeholder span{font-family:var(--font-mono);color:var(--accent);border:2px solid var(--accent);background:var(--surface);border-radius:14px;padding:12px 18px;font-size:2.4rem;font-weight:600}.about-summary{color:var(--text-muted);margin:0;font-size:.96rem}.about-summary p{margin:0 0 14px}.about-summary p:last-child{margin-bottom:0}.about-panel{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-sm);padding:18px 22px}.about-panel h3{margin-bottom:10px;font-size:.95rem}.about-panel ul{margin:0;padding:0;list-style:none}.about-panel li{color:var(--text-muted);border-bottom:1px solid var(--border);gap:9px;padding:5px 0;font-size:.87rem;display:flex}.about-panel li:last-child{border-bottom:none}.about-panel li:before{content:"✓";color:var(--accent);flex-shrink:0;font-weight:700}.skills-rows{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-sm);overflow:hidden}.skills-row{border-bottom:1px solid var(--border);grid-template-columns:215px 1fr;align-items:start;gap:20px;padding:13px 22px;display:grid}.skills-row:last-child{border-bottom:none}.skills-row:nth-child(2n){background:var(--bg-elevated)}.skills-row h3{font-family:var(--font-sans);align-items:center;gap:9px;margin:3px 0 0;font-size:.9rem;font-weight:600;display:flex}.skills-row h3:before{content:"";background:var(--gradient);border-radius:3px;flex-shrink:0;width:8px;height:8px}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:16px;display:grid}.project-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-sm);color:var(--text);flex-direction:column;padding:20px;transition:box-shadow .15s,transform .15s,border-color .15s;display:flex;position:relative;overflow:hidden}.project-card:before{content:"";background:var(--gradient);opacity:0;height:3px;transition:opacity .15s;position:absolute;top:0;left:0;right:0}.project-card:hover{box-shadow:var(--shadow-md);border-color:#c7d7fe;text-decoration:none;transform:translateY(-3px)}.project-card:hover:before{opacity:1}.project-card-num{font-family:var(--font-display);color:var(--border);font-size:2.6rem;font-weight:700;line-height:1;transition:color .15s;position:absolute;top:6px;right:14px}.project-card:hover .project-card-num{color:#dbe6ff}.project-card-tags{margin-bottom:12px;padding-right:56px}.project-card .chip{background:var(--bg-elevated)}.project-card h3{margin-bottom:7px;font-size:1.02rem}.project-card:hover h3{color:var(--accent)}.project-role{font-family:var(--font-mono);color:var(--accent);margin-bottom:12px;font-size:.73rem}.project-desc{color:var(--text-muted);margin-bottom:14px;font-size:.88rem}.project-card-cta{color:var(--accent);margin-top:auto;font-size:.86rem;font-weight:600}.project-card-cta span{transition:transform .15s;display:inline-block}.project-card:hover .project-card-cta span{transform:translate(3px)}.timeline{grid-template-columns:repeat(4,1fr);gap:18px;padding-top:26px;display:grid;position:relative}.timeline:before{content:"";background:linear-gradient(90deg, var(--accent) 0%, var(--accent-2) 55%, var(--border) 100%);border-radius:2px;height:2px;position:absolute;top:6px;left:0;right:0}.timeline-item{display:flex;position:relative}.timeline-dot{background:var(--surface);border:3px solid var(--accent);width:13px;height:13px;box-shadow:0 0 0 4px var(--accent-soft);z-index:1;border-radius:50%;position:absolute;top:-26px;left:4px}.timeline-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-sm);padding:16px 18px;transition:box-shadow .15s}.timeline-card:hover{box-shadow:var(--shadow-md)}.timeline-card h3{margin:6px 0 2px;font-size:1rem}.experience-period{font-family:var(--font-mono);color:var(--accent);background:var(--accent-soft);white-space:nowrap;border:1px solid #c7d7fe;border-radius:999px;padding:2px 9px;font-size:.7rem;font-weight:600;display:inline-block}.experience-role{color:var(--accent);margin-bottom:7px;font-size:.85rem;font-weight:600}.experience-summary{color:var(--text-muted);margin:0;font-size:.88rem}.contact-grid{grid-template-columns:1fr 1.2fr;align-items:start;gap:36px;margin-top:6px;display:grid}.contact-meta{font-family:var(--font-mono);color:var(--text-faint);margin:14px 0 0;font-size:.78rem}.contact-channels{grid-template-columns:1fr 1fr;gap:10px;margin-top:18px;display:grid}.contact-channel{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow-sm);color:var(--text);align-items:center;gap:12px;padding:11px 14px;transition:border-color .15s,box-shadow .15s,transform .15s;display:flex}.contact-channel:hover{border-color:var(--accent);box-shadow:var(--shadow-md);text-decoration:none;transform:translateY(-1px)}.contact-channel-icon{background:var(--accent-soft);width:36px;height:36px;color:var(--accent);border-radius:9px;flex-shrink:0;place-items:center;font-weight:700;display:grid}.contact-channel-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint);font-size:.7rem;font-weight:600}.contact-channel-value{overflow-wrap:anywhere;font-size:.86rem;font-weight:600}.contact-form{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-sm);padding:22px 24px}.form-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}.form-field{margin-bottom:13px}.form-field label{color:var(--text);margin-bottom:5px;font-size:.84rem;font-weight:600;display:block}.form-field input,.form-field select,.form-field textarea{border:1px solid var(--border-strong);background:var(--surface);width:100%;color:var(--text);font-family:var(--font-sans);border-radius:9px;padding:9px 12px;font-size:.92rem;transition:border-color .15s,box-shadow .15s}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #2563eb24}.form-field textarea{resize:vertical;min-height:100px}.form-status{border-radius:9px;margin-top:14px;padding:11px 13px;font-size:.88rem}.form-status.success{color:var(--success);background:#ecfdf5;border:1px solid #a7f3d0}.form-status.error{color:var(--danger);background:#fef2f2;border:1px solid #fecaca}.footer{border-top:1px solid var(--border);background:var(--bg);padding:20px 0}.footer-inner{color:var(--text-faint);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;font-size:.84rem;display:flex}.footer-note{font-family:var(--font-mono);font-size:.78rem}.footer-links{gap:18px;display:flex}.footer-links a{color:var(--text-muted);font-weight:500}.detail-header{border-bottom:1px solid var(--border);background:radial-gradient(ellipse 55% 60% at 85% 0%, #7c3aed0d, transparent), var(--bg-elevated);padding:34px 0 28px}.back-link{color:var(--text-muted);align-items:center;gap:6px;margin-bottom:16px;font-size:.88rem;font-weight:500;display:inline-flex}.back-link:hover{color:var(--accent);text-decoration:none}.detail-header h1{max-width:860px;font-size:clamp(1.45rem,2.6vw,1.9rem)}.detail-body{padding:34px 0 52px}.detail-grid{grid-template-columns:2fr 1fr;align-items:start;gap:40px;display:grid}.detail-section{margin-bottom:28px}.detail-section h2{border-bottom:1px solid var(--border);margin-bottom:10px;padding-bottom:8px;font-size:1.1rem}.detail-section p{color:var(--text-muted)}.detail-section ul{margin:0;padding-left:0;list-style:none}.detail-section ul li{color:var(--text-muted);padding:5px 0 5px 22px;position:relative}.detail-section ul li:before{content:"▸";color:var(--accent);position:absolute;left:2px}.flow-steps{counter-reset:step;margin:0;padding:0;list-style:none}.flow-steps li{counter-increment:step;color:var(--text-muted);padding:8px 0 8px 46px;position:relative}.flow-steps li:before{content:counter(step, decimal-leading-zero);font-family:var(--font-mono);color:var(--accent);background:var(--accent-soft);border:1px solid #c7d7fe;border-radius:7px;padding:2px 7px;font-size:.72rem;font-weight:600;position:absolute;top:9px;left:0}.flow-steps li:not(:last-child):after{content:"";background:var(--border);width:1px;position:absolute;top:38px;bottom:-2px;left:16px}.detail-aside{flex-direction:column;gap:16px;display:flex;position:sticky;top:80px}.aside-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-sm);padding:18px 20px}.aside-card h3{font-family:var(--font-mono);text-transform:lowercase;letter-spacing:.1em;color:var(--text-faint);margin-bottom:12px;font-size:.72rem;font-weight:600}.aside-card .project-role{margin-bottom:0}.aside-card .chip{background:var(--bg-elevated)}.attachment-list{flex-direction:column;gap:9px;display:flex}.attachment-link{border:1px solid var(--border-strong);border-radius:var(--radius);color:var(--text);align-items:center;gap:11px;padding:10px 13px;font-size:.88rem;font-weight:600;transition:border-color .15s,background .15s;display:flex}.attachment-link:hover{border-color:var(--accent);background:var(--accent-soft);text-decoration:none}.attachment-kind{font-family:var(--font-mono);color:var(--accent);background:var(--accent-soft);border:1px solid #c7d7fe;border-radius:6px;flex-shrink:0;padding:2px 6px;font-size:.64rem;font-weight:600}.sanitization-note{color:var(--text-faint);border:1px dashed var(--border-strong);border-radius:var(--radius);margin:0;padding:12px 14px;font-size:.78rem}.detail-figure{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-elevated);margin:0 0 18px;overflow:hidden}.detail-figure img{width:100%}.detail-figure figcaption{color:var(--text-faint);border-top:1px solid var(--border);font-size:.76rem;font-family:var(--font-mono);padding:8px 14px}.not-found{text-align:center;padding:100px 0}@media (width<=1000px){.about-grid{grid-template-columns:220px 1fr}.about-panel{grid-column:1/-1}}@media (width<=900px){.hero-grid{grid-template-columns:1fr;gap:30px}.hero-terminal-wrap{justify-content:center}.terminal{transform:none}.hero-stats{grid-template-columns:repeat(2,1fr)}.about-grid,.contact-grid,.detail-grid{grid-template-columns:1fr}.about-photo-frame{max-width:250px}.detail-aside{position:static}.projects-grid{grid-template-columns:1fr}.skills-row{grid-template-columns:1fr;gap:12px;padding:16px 20px}.timeline{grid-template-columns:1fr;gap:14px;padding-top:0;padding-left:26px}.timeline:before{background:linear-gradient(180deg, var(--accent) 0%, var(--accent-2) 55%, var(--border) 100%);width:2px;height:auto;inset:0 auto 0 5px}.timeline-dot{top:18px;left:-26px}.contact-channels{grid-template-columns:1fr}}@media (width<=760px){.navbar-toggle{display:block}.navbar-links{background:var(--bg);border-bottom:1px solid var(--border);box-shadow:var(--shadow-md);flex-direction:column;align-items:stretch;gap:0;padding:8px 24px 16px;display:none;position:absolute;top:58px;left:0;right:0}.navbar-links.open{display:flex}.navbar-links a{border-bottom:1px solid var(--border);padding:12px 0}.navbar-links a:last-child{border-bottom:none}.navbar-links .btn{margin:12px 0 0}.section{padding:40px 0}.hero{padding:30px 0 36px}.hero-actions .btn{flex:1}.terminal{max-width:100%}.terminal-body{font-size:.72rem}}@media (width<=480px){.hero-stats,.form-row{grid-template-columns:1fr}}
