*{margin:0;padding:0;box-sizing:border-box}:root{--bg:#111110;--surface:#191917;--border:#252422;--border2:#333230;--text:#eeecea;--muted:#6b6965;--faint:#3d3c39;--p:#b07ee8;--p-bg:rgba(176,126,232,.07);--p-border:rgba(176,126,232,.18);--amber:#c8902a;--amber-bg:rgba(200,144,42,.07);--amber-border:rgba(200,144,42,.18);--teal:#2aa8a0;--teal-bg:rgba(42,168,160,.07);--teal-border:rgba(42,168,160,.18);--blue:#5a9cf5;--blue-bg:rgba(90,156,245,.07);--blue-border:rgba(90,156,245,.18);--serif:"DM Serif Display",serif;--sans:"DM Sans",sans-serif;--mono:"DM Mono",monospace}body{background:var(--bg);color:var(--text);font-family:var(--sans);min-height:100vh}nav{padding:1.25rem 2.5rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border)}.nav-logo{font-family:var(--serif);font-size:17px;color:var(--text);letter-spacing:-.01em;text-decoration:none}.nav-links{display:flex;gap:2.5rem}.nav-links a{font-size:13px;color:var(--muted);text-decoration:none;font-weight:400;letter-spacing:.01em;transition:color .15s}.nav-links a:hover{color:var(--text)}.container{max-width:880px;margin:0 auto;padding:0 2.5rem}.hero{padding:5rem 0 4.5rem;display:grid;grid-template-columns:1fr 200px;gap:4rem;align-items:start}.hero-eyebrow{font-size:12px;color:var(--muted);letter-spacing:.08em;font-weight:400;margin-bottom:1.75rem;font-family:var(--mono)}.hero h1{font-family:var(--serif);font-size:clamp(2.4rem,5vw,3.75rem);line-height:1.1;letter-spacing:-.01em;margin-bottom:1.5rem;font-weight:400}.hero h1 em{font-style:italic;color:var(--p)}.hero-sub{font-size:15px;color:var(--muted);line-height:1.75;max-width:420px;margin-bottom:2.25rem;font-weight:300}.btns{display:flex;gap:.75rem;flex-wrap:wrap}.btn-p{font-size:13px;padding:10px 24px;background:var(--p);color:#111110;border:none;cursor:pointer;font-weight:600;border-radius:4px;font-family:var(--sans);letter-spacing:.01em;transition:opacity .15s;text-decoration:none;display:inline-block}.btn-p:hover{opacity:.88}.btn-g{font-size:13px;padding:10px 24px;background:transparent;color:var(--muted);border:1px solid var(--border2);cursor:pointer;border-radius:4px;font-family:var(--sans);letter-spacing:.01em;transition:color .15s,border-color .15s;text-decoration:none;display:inline-block}.btn-g:hover{color:var(--text);border-color:var(--muted)}.hero-right{padding-top:1rem;display:flex;flex-direction:column;gap:1.5rem;align-items:flex-end}.photo-frame{width:180px;height:210px;background:var(--surface);border:1px solid var(--border2);overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}.photo-frame img{width:100%;height:100%;object-fit:cover}.photo-frame i{font-size:36px;color:var(--faint)}.photo-label{font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:.06em}.hero-note{font-family:var(--mono);font-size:11px;color:var(--muted);text-align:right;line-height:1.6;width:180px}.hero-note b{color:var(--p);font-weight:400}.divider{border:none;border-top:1px solid var(--border);margin:0}.section{padding:4rem 0}.sec-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:2.5rem}.sec-title{font-family:var(--serif);font-size:1.75rem;font-weight:400;letter-spacing:-.01em}.sec-label{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.1em}.skill-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border:1px solid var(--border)}.sk{padding:1.75rem;border-right:1px solid var(--border);border-bottom:1px solid var(--border);transition:background .15s}.sk:nth-child(2n){border-right:none}.sk:nth-child(n+3){border-bottom:none}.sk:hover{background:var(--surface)}.sk-area{font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:.12em;margin-bottom:.6rem}.sk-name{font-family:var(--serif);font-size:1.2rem;font-weight:400;margin-bottom:1rem}.tags{display:flex;flex-wrap:wrap;gap:6px}.tag{font-family:var(--mono);font-size:11px;padding:3px 10px;border-radius:2px;border:1px solid}.tag.p{background:var(--p-bg);color:var(--p);border-color:var(--p-border)}.tag.a{background:var(--amber-bg);color:var(--amber);border-color:var(--amber-border)}.tag.t{background:var(--teal-bg);color:var(--teal);border-color:var(--teal-border)}.tag.b{background:var(--blue-bg);color:var(--blue);border-color:var(--blue-border)}.proj-list{display:grid;gap:0;border:1px solid var(--border)}.proj{padding:2rem;border-bottom:1px solid var(--border);display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:start;transition:background .15s;cursor:pointer;text-decoration:none;color:inherit}.proj:last-child{border-bottom:none}.proj:hover{background:var(--surface)}.proj-area{font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:.12em;margin-bottom:.6rem}.proj-title{font-family:var(--serif);font-size:1.3rem;font-weight:400;margin-bottom:.6rem;color:var(--text)}.proj-desc{font-size:13px;color:var(--muted);line-height:1.75;font-weight:300;max-width:480px}.proj-tags{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:1rem}.ptag{font-family:var(--mono);font-size:10px;padding:2px 8px;border:1px solid;border-radius:2px}.ptag.p{background:var(--p-bg);color:var(--p);border-color:var(--p-border)}.ptag.b{background:var(--blue-bg);color:var(--blue);border-color:var(--blue-border)}.ptag.a{background:var(--amber-bg);color:var(--amber);border-color:var(--amber-border)}.ptag.t{background:var(--teal-bg);color:var(--teal);border-color:var(--teal-border)}.proj-arr{color:var(--faint);font-size:18px;align-self:center;transition:color .15s,transform .15s}.proj:hover .proj-arr.p{color:var(--p);transform:translate(3px,-3px)}.proj:hover .proj-arr.b{color:var(--blue);transform:translate(3px,-3px)}.proj:hover .proj-arr.a{color:var(--amber);transform:translate(3px,-3px)}.proj:hover .proj-arr.t{color:var(--teal);transform:translate(3px,-3px)}.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}.contact-intro{font-family:var(--serif);font-size:1.15rem;font-weight:400;line-height:1.6;color:var(--muted);font-style:italic}.contact-links{display:flex;flex-direction:column;gap:0;border:1px solid var(--border)}.cc{padding:.875rem 1.25rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);transition:background .15s;cursor:pointer;text-decoration:none;color:inherit}.cc:last-child{border-bottom:none}.cc:hover{background:var(--surface)}.cc-left{display:flex;align-items:center;gap:.875rem}.cc-icon{font-size:15px;color:var(--p);width:18px}.cc-label{font-size:13px;font-weight:500}.cc-sub{font-family:var(--mono);font-size:10px;color:var(--muted)}.cc-arr{font-size:14px;color:var(--faint);transition:color .15s}.cc:hover .cc-arr{color:var(--p)}footer{border-top:1px solid var(--border);padding:1.5rem 2.5rem;display:flex;justify-content:space-between;align-items:center}.foot-l{font-family:var(--serif);font-size:14px;color:var(--muted);font-style:italic}.foot-r{font-family:var(--mono);font-size:10px;color:var(--muted)}.detail-back{font-family:var(--mono);font-size:11px;color:var(--muted);text-decoration:none;display:inline-flex;align-items:center;gap:6px;margin-bottom:2rem;transition:color .15s}.detail-back:hover{color:var(--text)}.detail-header{padding:3rem 0 2.5rem}.detail-area{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.12em;margin-bottom:1rem}.detail-title{font-family:var(--serif);font-size:clamp(2rem,4vw,2.75rem);font-weight:400;letter-spacing:-.01em;margin-bottom:1.25rem}.detail-desc{font-size:14px;color:var(--muted);line-height:1.75;font-weight:300;max-width:560px;margin-bottom:1.5rem}.detail-body{padding-bottom:1rem}.detail-body p{font-size:14px;color:var(--muted);line-height:1.85;font-weight:300;max-width:640px;margin-bottom:1.25rem}.detail-links{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1rem}.reveal-ready{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}.reveal-ready.visible{opacity:1;transform:none}
