:root{--bg:#07080a;--surface-100:#101111;--surface-card:#1b1c1e;--border:#ffffff0f;--border-strong:#ffffff1a;--text:#f9f9f9;--text-2:#cecece;--text-3:#9c9c9d;--text-4:#6a6b6c;--accent:#ff6363;--accent-glow:#ff616126;--info:#55b3ff;--success:#5fc992;--shadow-card:#1b1c1e 0px 0px 0px 1px, #07080a 0px 0px 0px 1px inset;--shadow-btn:#ffffff0d 0px 1px 0px 0px inset, #ffffff40 0px 0px 0px 1px, #0003 0px -1px 0px 0px inset;--shadow-key:#0006 0px 1.5px .5px 2.5px, #ffffff0f 0px 1px 0px 0px inset, #0009 0px -1px 0px 0px inset;--font-sans:"Inter", -apple-system, system-ui, sans-serif;--font-mono:"Geist Mono", "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace}[data-theme=light]{--bg:#f7f7f5;--surface-100:#fff;--surface-card:#f0f0ee;--border:#00000014;--border-strong:#00000024;--text:#0a0a0c;--text-2:#26272b;--text-3:#5a5b60;--text-4:#8a8b90;--shadow-card:#0000000f 0 0 0 1px, #fff9 0 0 0 1px inset;--shadow-btn:#00000014 0px 1px 0px 0px inset, #00000026 0px 0px 0px 1px, #0000000a 0px 1px 2px 0px;--shadow-key:#00000026 0px 1.5px .5px 2.5px, #fff 0px 1px 0px 0px inset, #0000001f 0px -1px 0px 0px inset}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg);color:var(--text);font-family:var(--font-sans);font-feature-settings:"calt", "kern", "liga", "ss03";letter-spacing:.2px;-webkit-font-smoothing:antialiased;scroll-behavior:smooth;transition:background-color .3s,color .3s}::selection{background:var(--accent);color:#fff}.shell{max-width:1180px;margin:0 auto;padding:0 32px}@media (width<=640px){.shell{padding:0 20px}}.nav{z-index:50;background:color-mix(in srgb, var(--bg) 85%, transparent);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);position:sticky;top:0}.nav-inner{justify-content:space-between;align-items:center;height:64px;display:flex}.nav-brand{font-family:var(--font-mono);letter-spacing:.3px;color:var(--text);align-items:center;gap:10px;font-size:13px;font-weight:500;text-decoration:none;display:flex}.nav-brand:before{content:"";background:var(--accent);width:8px;height:8px;box-shadow:0 0 12px var(--accent-glow);border-radius:2px}.nav-links{align-items:center;gap:4px;display:flex}.nav-link{color:var(--text-3);letter-spacing:.3px;border-radius:6px;align-items:center;gap:8px;padding:8px 12px;font-size:14px;font-weight:500;text-decoration:none;transition:color .15s,background .15s;display:inline-flex}.nav-link:hover{color:var(--text);background:var(--border)}.nav-link .kbd-hint{font-family:var(--font-mono);color:var(--text-4);border:1px solid var(--border-strong);border-radius:3px;padding:1px 5px;font-size:10px;line-height:1}.nav-tools{align-items:center;gap:8px;display:flex}@media (width<=780px){.nav-links{display:none}}.icon-btn{border:1px solid var(--border-strong);width:34px;height:34px;color:var(--text-3);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;transition:color .15s,background .15s,transform .15s;display:inline-flex}.icon-btn:hover{color:var(--text);background:var(--border)}.icon-btn:active{transform:scale(.95)}.icon-btn svg{width:16px;height:16px}.section-label{font-family:var(--font-mono);color:var(--text-3);letter-spacing:.4px;text-transform:uppercase;align-items:center;gap:10px;margin-bottom:24px;font-size:12px;display:flex}.section-label:before{content:"";background:var(--accent);width:6px;height:6px;box-shadow:0 0 8px var(--accent-glow);border-radius:50%}.section-label .idx{color:var(--text-4);align-items:center;gap:6px;margin-left:auto;display:flex}.section-label .idx .k{font-family:var(--font-mono);box-shadow:var(--shadow-key);color:var(--text-2);background:linear-gradient(#121212,#0d0d0d);border-radius:4px;padding:2px 6px;font-size:10px}[data-theme=light] .section-label .idx .k{background:linear-gradient(#fff,#ededed)}section{padding:45px 0;position:relative}@media (width<=780px){section{padding:72px 0}}.section-title{letter-spacing:-.2px;color:var(--text);margin-bottom:40px;font-size:40px;font-weight:500;line-height:1.1}@media (width<=640px){.section-title{font-size:32px}}.section-description{letter-spacing:0;color:var(--text-3);max-width:560px;margin-top:-24px;margin-bottom:40px;font-size:16px;font-weight:400;line-height:1.6}@media (width<=640px){.section-description{font-size:15px}}.hero{padding:96px 0 72px}.hero-grid{grid-template-columns:320px 1fr;align-items:center;gap:64px;display:grid}@media (width<=900px){.hero-grid{grid-template-columns:1fr;gap:40px}}.photo-frame{background:var(--surface-100);width:300px;height:360px;box-shadow:var(--shadow-card);border-radius:16px;position:relative;overflow:hidden}@media (width<=900px){.photo-frame{width:260px;height:312px;margin:0 auto}}.photo-frame img{object-fit:cover;object-position:center 15%;filter:saturate(.9)contrast(1.05);width:100%;height:100%}.photo-frame:before{content:"";background:repeating-linear-gradient(135deg, transparent 0, transparent 18px, color-mix(in srgb, var(--accent) 40%, transparent) 18px, color-mix(in srgb, var(--accent) 40%, transparent) 20px);mix-blend-mode:screen;opacity:0;pointer-events:none;transition:opacity .35s;position:absolute;inset:0}.photo-frame:hover:before{opacity:.35}.photo-frame:after{content:"";pointer-events:none;background:linear-gradient(#0000 60%,#00000059);position:absolute;inset:0}[data-theme=light] .photo-frame:after{background:linear-gradient(#0000 60%,#0000001a)}.photo-tag{font-family:var(--font-mono);color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#07080abf;border:1px solid #ffffff14;border-radius:4px;align-items:center;gap:6px;padding:4px 8px;font-size:11px;display:flex;position:absolute;bottom:12px;left:12px}.photo-tag .dot{background:var(--success);width:6px;height:6px;box-shadow:0 0 8px var(--success);border-radius:50%;animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.hero-eyebrow{font-family:var(--font-mono);color:var(--text-3);letter-spacing:.4px;text-transform:uppercase;align-items:center;gap:8px;margin-bottom:16px;font-size:12px;display:flex}.hero-eyebrow:before{content:"";background:var(--text-4);width:20px;height:1px}.hero-name{letter-spacing:-.5px;color:var(--text);font-feature-settings:"ss02", "ss08", "liga" 0;margin-bottom:24px;font-size:64px;font-weight:600;line-height:1.05}@media (width<=780px){.hero-name{font-size:48px}}@media (width<=480px){.hero-name{font-size:38px}}.hero-name .accent-dot{color:var(--accent)}.hero-intro{color:var(--text-2);max-width:560px;font-size:17px;font-weight:400;line-height:1.65}.hero-intro strong{color:var(--text);font-weight:500}.hero-intro .chip{background:var(--accent-glow);color:var(--accent);border:1px solid color-mix(in srgb, var(--accent) 20%, transparent);border-radius:4px;align-items:center;gap:4px;padding:1px 7px;font-size:14px;font-weight:500;display:inline-flex}.hero-meta{flex-wrap:wrap;gap:24px;margin-top:32px;display:flex}.hero-meta-item{flex-direction:column;gap:4px;display:flex}.hero-meta-item .label{font-family:var(--font-mono);color:var(--text-4);text-transform:uppercase;letter-spacing:.4px;font-size:11px}.hero-meta-item .value{color:var(--text-2);font-size:14px;font-weight:500}.stack-row{border-top:1px solid var(--border);grid-template-columns:180px 1fr;align-items:start;gap:32px;padding:20px 0;display:grid}.stack-row:last-child{border-bottom:1px solid var(--border)}@media (width<=680px){.stack-row{grid-template-columns:1fr;gap:12px}}.stack-category{font-family:var(--font-mono);color:var(--text-3);text-transform:uppercase;letter-spacing:.4px;padding-top:6px;font-size:13px}.stack-tags{flex-wrap:wrap;gap:8px;display:flex}.tech-tag{letter-spacing:.1px;background:var(--tag-bg,#ffffff0a);color:var(--tag-fg,var(--text));border:1px solid var(--tag-border,#ffffff14);cursor:default;border-radius:8px;align-items:center;gap:8px;padding:6px 12px 6px 8px;font-size:14px;font-weight:500;transition:transform .15s,background .2s,border-color .2s;display:inline-flex}.tech-tag:hover{background:var(--tag-bg-hover,var(--tag-bg));border-color:var(--tag-border-hover,var(--tag-border));transform:translateY(-1px)}.tech-tag-logo{width:18px;height:18px;color:var(--tag-fg);justify-content:center;align-items:center;display:inline-flex}.tech-tag-logo svg{width:100%;height:100%}.project-list{gap:20px;display:grid}.project-card{background:var(--surface-100);border:1px solid var(--border);border-radius:16px;grid-template-columns:1fr auto;align-items:start;gap:24px;padding:28px;transition:border-color .2s,transform .2s;display:grid;position:relative;overflow:hidden}.project-card:hover{border-color:var(--border-strong)}.project-card:before{content:"";background:var(--accent);opacity:0;width:2px;transition:opacity .2s;position:absolute;top:0;bottom:0;left:0}.project-card:hover:before{opacity:1}.project-card.placeholder{border-style:dashed;border-color:var(--border);background:0 0}.project-header{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:12px;display:flex}.project-title{color:var(--text);font-size:22px;font-weight:500;line-height:1.2}.project-placeholder-title{color:var(--text-4);font-style:italic}.project-tag{font-family:var(--font-mono);background:var(--surface-card);color:var(--text-3);text-transform:uppercase;letter-spacing:.3px;border:1px solid var(--border);border-radius:4px;padding:2px 8px;font-size:11px}.project-tag.live{color:var(--success);border-color:color-mix(in srgb, var(--success) 20%, transparent)}.project-desc{color:var(--text-2);max-width:620px;margin-bottom:16px;font-size:15px;line-height:1.6}.project-meta{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.project-meta .mini-tag{font-family:var(--font-mono);color:var(--text-3);border:1px solid var(--border);border-radius:4px;padding:2px 6px;font-size:11px}.viewable-img{cursor:zoom-in;transition:transform .2s,border-color .2s}img.viewable-img:hover{border-color:var(--border-strong);transform:scale(1.02)}.project-visual{background:linear-gradient(135deg, var(--surface-card), var(--surface-100));border:1px solid var(--border);object-fit:cover;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:200px;height:130px;display:flex;position:relative;overflow:hidden}.project-visual-wrap{flex-direction:column;flex-shrink:0;align-self:stretch;gap:12px;width:200px;display:flex}.project-visual-wrap .project-link{margin-top:auto}.project-visual-wrap .project-visual{width:100%}.project-link{width:100%;font-family:var(--font-sans);letter-spacing:.2px;color:var(--text-2);background:var(--surface-card);border:1px solid var(--border);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:9px 14px;font-size:13px;font-weight:500;text-decoration:none;transition:color .15s,border-color .15s,background .15s,transform .15s;display:inline-flex}.project-link:hover{color:var(--accent);border-color:color-mix(in srgb, var(--accent) 40%, transparent);background:var(--accent-glow)}.project-link:active{transform:translateY(1px)}.project-link svg{transition:transform .15s}.project-link:hover svg{transform:translate(1px,-1px)}.project-visual.stripe{background:repeating-linear-gradient(135deg, transparent 0, transparent 10px, color-mix(in srgb, var(--accent) 25%, transparent) 10px, color-mix(in srgb, var(--accent) 25%, transparent) 12px), linear-gradient(135deg, var(--surface-card), var(--surface-100))}.project-visual-label{font-family:var(--font-mono);color:var(--text-4);letter-spacing:.4px;font-size:10px;position:absolute;bottom:8px;left:10px}@media (width<=680px){.project-card{grid-template-columns:1fr}.project-visual{width:100%;height:100px}.project-visual-wrap{width:100%}}.contact-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (width<=680px){.contact-grid{grid-template-columns:1fr}}.contact-card{background:var(--surface-100);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:16px;align-items:center;gap:16px;padding:24px;text-decoration:none;transition:border-color .2s,transform .2s,background .2s;display:flex;position:relative}.contact-card:hover{border-color:var(--border-strong);transform:translateY(-2px)}.contact-icon{background:var(--surface-card);width:48px;height:48px;color:var(--contact-color,var(--text));border:1px solid var(--border);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.contact-icon svg{width:22px;height:22px}.contact-info{flex:1;min-width:0}.contact-label{font-family:var(--font-mono);color:var(--text-4);text-transform:uppercase;letter-spacing:.3px;margin-bottom:4px;font-size:11px}.contact-value{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:16px;font-weight:500;overflow:hidden}.contact-arrow{color:var(--text-4);transition:transform .2s,color .2s}.contact-card:hover .contact-arrow{color:var(--text);transform:translate(3px)}.contact-card:active{transform:translateY(0)}.contact-copied{font-family:var(--font-mono);color:var(--success);background:color-mix(in srgb, var(--success) 15%, transparent);border:1px solid color-mix(in srgb, var(--success) 30%, transparent);opacity:0;pointer-events:none;border-radius:4px;padding:2px 8px;font-size:11px;transition:opacity .2s,transform .2s;position:absolute;top:12px;right:12px;transform:translateY(-4px)}.contact-copied.show{opacity:1;transform:translateY(0)}footer{border-top:1px solid var(--border);margin-top:48px;padding:48px 0 64px}.footer-inner{font-family:var(--font-mono);color:var(--text-4);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;font-size:12px;display:flex}.tweaks{z-index:100;background:var(--surface-100);border:1px solid var(--border-strong);border-radius:14px;min-width:260px;padding:16px;display:none;position:fixed;bottom:24px;right:24px;box-shadow:0 0 0 2px #00000080,0 0 30px #ffffff14,0 20px 40px -10px #0006}.tweaks.open{display:block}.tweaks-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.tweaks-title{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.4px;color:var(--text-3);align-items:center;gap:8px;font-size:11px;display:flex}.tweaks-title:before{content:"";background:var(--accent);border-radius:50%;width:6px;height:6px}.tweaks-close{color:var(--text-4);cursor:pointer;background:0 0;border:none;padding:2px 6px;font-size:18px;line-height:1}.tweaks-close:hover{color:var(--text)}.tweak-row{margin-bottom:14px}.tweak-row:last-child{margin-bottom:0}.tweak-label{color:var(--text-3);justify-content:space-between;align-items:center;margin-bottom:8px;font-size:12px;display:flex}.swatch-row{gap:8px;display:flex}.swatch{cursor:pointer;border:2px solid #0000;border-radius:8px;width:28px;height:28px;transition:transform .15s,border-color .15s}.swatch:hover{transform:scale(1.08)}.swatch.active{border-color:var(--text)}.theme-toggle{background:var(--surface-card);border:1px solid var(--border);border-radius:8px;padding:2px;display:flex}.theme-toggle button{color:var(--text-3);cursor:pointer;font-size:12px;font-family:var(--font-sans);letter-spacing:.2px;background:0 0;border:none;border-radius:6px;flex:1;padding:6px 10px;transition:background .15s,color .15s}.theme-toggle button.active{background:var(--bg);color:var(--text);box-shadow:var(--shadow-card)}.reveal{opacity:0;transition:opacity .7s,transform .7s;transform:translateY(18px)}.reveal.visible{opacity:1;transform:translateY(0)}.hero-stripes{background:repeating-linear-gradient(135deg, transparent 0, transparent 8px, var(--accent) 8px, var(--accent) 10px);opacity:.08;pointer-events:none;border-radius:20px;width:200px;height:260px;position:absolute;top:20px;right:-40px;transform:rotate(-8deg);-webkit-mask:linear-gradient(#000,#0000 85%);mask:linear-gradient(#000,#0000 85%)}.cmd-hint{z-index:40;font-family:var(--font-mono);color:var(--text-4);background:color-mix(in srgb, var(--surface-100) 90%, transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border);-webkit-user-select:none;user-select:none;pointer-events:none;border-radius:8px;align-items:center;gap:8px;padding:8px 12px;font-size:11px;display:flex;position:fixed;bottom:24px;left:24px}.cmd-hint .k{font-family:var(--font-mono);box-shadow:var(--shadow-key);color:var(--text-2);background:linear-gradient(#121212,#0d0d0d);border-radius:3px;padding:1px 6px;font-size:10px}[data-theme=light] .cmd-hint .k{background:linear-gradient(#fff,#ededed)}@media (width<=640px){.cmd-hint{display:none}}.cursor-hint{pointer-events:none;z-index:200;background:var(--accent);width:10px;height:10px;box-shadow:0 0 16px var(--accent-glow), 0 0 32px var(--accent-glow);opacity:0;border-radius:50%;transition:opacity .2s;position:fixed;transform:translate(-50%,-50%)}body.has-cursor-hint .cursor-hint{opacity:.7}@media (hover:none){.cursor-hint{display:none}}.hide-md{display:initial}@media (width<=780px){.hide-md{display:none}}.lightbox-overlay{z-index:100;-webkit-backdrop-filter:blur(8px);cursor:zoom-out;background:#000000d1;justify-content:center;align-items:center;padding:48px;animation:.18s ease-out lightbox-fade;display:flex;position:fixed;inset:0}.lightbox-image{object-fit:contain;border:1px solid var(--border-strong);cursor:default;border-radius:12px;width:auto;max-width:100%;height:auto;max-height:100%;animation:.2s ease-out lightbox-pop;box-shadow:0 20px 60px #00000080}.lightbox-close{color:#fff;cursor:pointer;background:#ffffff14;border:1px solid #ffffff2e;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;transition:background .15s,border-color .15s,transform .15s,color .15s;display:inline-flex;position:absolute;top:20px;right:20px}.lightbox-close:hover{background:var(--accent-glow);border-color:color-mix(in srgb, var(--accent) 60%, transparent);color:var(--accent)}.lightbox-close:active{transform:scale(.95)}.lightbox-close:focus-visible{outline:2px solid var(--accent);outline-offset:2px}@keyframes lightbox-fade{0%{opacity:0}to{opacity:1}}@keyframes lightbox-pop{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@media (width<=680px){.lightbox-overlay{padding:16px}.lightbox-close{top:12px;right:12px}}
