:root{--bg-primary:#0a0a0a;--bg-secondary:#111;--bg-panel:#111;--bg-elevated:#1a1a1a;--bg-code:#0d0d0d;--text-primary:#fff;--text-secondary:#9ca3af;--border:#2d2d2d;--white:#fff;--white-a75:#ffffffbf;--white-a70:#ffffffb3;--white-a50:#ffffff80;--white-a40:#fff6;--white-a35:#ffffff59;--white-a30:#ffffff4d;--white-a28:#ffffff47;--white-a25:#ffffff40;--white-a20:#fff3;--white-a18:#ffffff2e;--white-a14:#ffffff24;--white-a12:#ffffff1f;--white-a10:#ffffff1a;--white-a09:#ffffff17;--white-a08:#ffffff14;--white-a07:#ffffff12;--white-a06:#ffffff0f;--white-a05:#ffffff0d;--white-a04:#ffffff0a;--black-a35:#00000059;--brand-green:#1d9e75;--accent-green:#21d0a1;--accent-green-a40:#21d0a166;--accent-green-a22:#21d0a138;--accent-green-a18:#21d0a12e;--accent-green-a12:#1d9e751f;--accent-shell-grad-start:#10342799;--accent-shell-grad-end:#0a1c16e6;--accent-purple:#a78bfa;--accent-purple-a10:#a78bfa1a;--accent-pink:#ec4899;--accent-mint:#5dcaa5;--accent-orange:#fb923c;--accent-rose:#f472b6;--project-1-grad-start:#1a1040;--project-1-grad-end:#2d1b69;--project-1-accent-bg:#a78bfa1f;--project-1-accent-border:#a78bfa26;--project-2-grad-start:#0d2318;--project-2-grad-end:#0a3d2b;--project-2-accent-bg:#1d9e751a;--project-2-accent-border:#1d9e7526;--project-3-grad-start:#1c1010;--project-3-grad-end:#3d1a1a;--project-3-accent-bg:#f472261a;--project-3-accent-border:#f4722626;--contrib-level-0:#161616;--contrib-level-1:#0c1c14;--contrib-level-2:#0d2e1e;--contrib-level-3:var(--brand-green);--contrib-level-4:var(--accent-mint);--glow-cursor:#a78bfa12;--photo-print-bg:#ddd9d3;--photo-print-text:#2a2520;--tape-bg:#c8c8c838;--sticky-yellow-bg:#2a2400;--sticky-yellow-text:#fcd34d;--sticky-pink-bg:#1f0a14;--sticky-pink-text:#f9a8d4;--sticky-teal-bg:#0a2218;--sticky-teal-text:var(--accent-mint);--sticky-purple-bg:#1a1030;--sticky-purple-text:var(--accent-purple);--font-family-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-family-mono:"Monaco", "Menlo", monospace;--font-family-hand:"Caveat", cursive;--fs-2xs:11px;--fs-xs:12px;--fs-sm:13px;--fs-md:14px;--fs-body:15px;--fs-base:16px;--fs-lg:24px;--fs-2xl:32px;--fs-hero:64px;--type-title-family:var(--font-family-sans);--type-title-size:var(--fs-base);--type-title-weight:500;--type-title-line:1.3;--type-title-tracking:-.2px;--type-h1-family:var(--font-family-sans);--type-h1-size:var(--fs-hero);--type-h1-weight:700;--type-h1-line:1.08;--type-h1-tracking:-1.8px;--type-heading-family:var(--font-family-sans);--type-heading-size:var(--fs-2xl);--type-heading-weight:600;--type-heading-line:1.25;--type-heading-tracking:-.6px;--type-body-family:var(--font-family-sans);--type-body-size:var(--fs-base);--type-body-weight:400;--type-body-line:1.6;--type-body-lg-family:var(--font-family-sans);--type-body-lg-size:var(--fs-lg);--type-body-lg-weight:400;--type-body-lg-line:1.4;--type-label-family:var(--font-family-sans);--type-label-size:var(--fs-md);--type-label-weight:500;--type-label-line:1.4;--type-caption-family:var(--font-family-sans);--type-caption-size:var(--fs-sm);--type-caption-weight:400;--type-caption-line:1.45;--type-meta-family:var(--font-family-sans);--type-meta-size:var(--fs-xs);--type-meta-weight:400;--type-meta-line:1.4;--type-small-family:var(--font-family-sans);--type-small-size:var(--fs-2xs);--type-small-weight:400;--type-small-line:1.4;--type-code-family:var(--font-family-mono);--type-code-size:var(--fs-xs);--type-code-weight:400;--type-code-line:1.8;font-family:var(--font-family-sans);--lightningcss-light: ;--lightningcss-dark:initial;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-weight:400;line-height:1.5}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-family-sans);line-height:var(--type-body-line);overflow:hidden}#root{flex-direction:column;width:100%;height:100vh;display:flex}button{cursor:pointer;font-family:inherit}a{color:inherit;text-decoration:none}.portfolio-container{background:var(--bg-primary);flex-direction:column;height:100vh;min-height:100dvh;display:flex}.main-content{flex:1;display:flex;overflow:hidden}.main-content.is-resizing{cursor:col-resize;-webkit-user-select:none;user-select:none}.canvas{flex:1;padding-top:56px;position:relative;overflow:hidden auto}.canvas.inspect-active{cursor:crosshair}.canvas-body{width:100%;max-width:1320px;margin:0 auto;padding:0 72px}@media (width<=1200px){.canvas-body{padding:0 48px}}@media (width<=900px){.canvas{padding-top:36px}.canvas-body{padding:0 24px}}@media (width<=640px){.canvas-body{padding:0 16px}}.topbar{border-bottom:.5px solid var(--white-a07);background:var(--bg-primary);z-index:100;flex-shrink:0;justify-content:space-between;align-items:center;height:56px;padding:0 24px;display:flex}.topbar-left{align-items:center;gap:28px;display:flex;position:relative}.portfolio-name{font-family:var(--type-title-family);font-size:var(--type-title-size);font-weight:var(--type-title-weight);line-height:var(--type-title-line);letter-spacing:var(--type-title-tracking)}.nav-links{align-items:center;gap:2px;display:flex}.nav-links a{font-family:var(--type-body-family);font-size:var(--type-body-size);font-weight:var(--type-body-weight);line-height:var(--type-body-line);color:var(--white-a35);border-radius:7px;padding:6px 12px;text-decoration:none;transition:color .15s,background .15s}.nav-links a:hover{color:var(--white-a70)}.nav-links a.active{background:var(--white-a08);color:var(--white)}.resume-nav-link{align-items:center;gap:6px;display:inline-flex}.topbar-actions{align-items:center;gap:10px;display:flex}.resume-arrow{font-size:var(--type-label-size);color:var(--white-a50);line-height:1}.resume-nav-link:hover .resume-arrow,.mobile-menu a:hover .resume-arrow{color:var(--white-a70)}.hamburger-button,.mobile-menu{display:none}.hamburger-button{border:.5px solid var(--white-a14);background:var(--white-a05);width:34px;height:34px;color:var(--white-a70);cursor:pointer;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:0}.hamburger-button span{background:currentColor;border-radius:999px;width:14px;height:2px;display:block}.edit-button{background:var(--white-a05);border:.5px solid var(--white-a14);color:var(--white-a70);cursor:pointer;font-size:var(--type-body-size);font-weight:var(--type-body-weight);line-height:var(--type-body-line);border-radius:8px;align-items:center;gap:8px;padding:7px 14px;font-family:inherit;transition:all .15s;display:flex}.edit-button:hover{background:var(--white-a09);color:var(--white)}@media (width<=900px){.topbar{height:auto;min-height:56px;padding:10px 16px}.topbar-left{flex:1;justify-content:space-between;gap:14px;min-width:0}.nav-links a{padding:5px 10px}.topbar-actions{margin-left:auto}}@media (width<=640px){.portfolio-name{font-size:15px}.nav-links a{padding:5px 9px;font-size:15px}}@media (width<=375px){.topbar{padding:9px 10px}.portfolio-name{font-size:14px}.topbar-left{gap:8px}.nav-links{display:none}.hamburger-button{display:inline-flex}.topbar-actions{display:none}.mobile-menu{border:.5px solid var(--white-a10);background:var(--bg-secondary);z-index:120;border-radius:10px;flex-direction:column;gap:2px;width:min(200px,100vw - 20px);padding:8px;position:absolute;top:calc(100% + 8px);right:0}.mobile-menu.open{display:flex}.mobile-menu a{font-family:var(--type-body-family);font-size:var(--type-body-size);font-weight:var(--type-body-weight);line-height:var(--type-body-line);color:var(--white-a40);border-radius:7px;align-items:center;gap:6px;padding:8px 10px;text-decoration:none;transition:color .15s,background .15s;display:inline-flex}.mobile-menu a.active{color:var(--white);background:var(--white-a08)}.mobile-menu a:hover{color:var(--white-a70)}}.hero-section{flex-direction:column;align-items:center;margin-bottom:76px;display:flex}.hero-profile{border:.5px solid var(--white-a07);border-radius:50%;flex-shrink:0;width:160px;height:160px;margin-bottom:24px;overflow:hidden}.profile-image{object-fit:cover;object-position:center;width:100%;height:100%;display:block}.hero-eyebrow{font-family:var(--type-label-family);font-size:var(--type-body-lg-size);font-weight:var(--type-label-weight);line-height:var(--type-label-line);letter-spacing:.06em;text-transform:uppercase;color:var(--white-a30);text-align:center;margin-bottom:16px}.hero-badge{font-family:var(--type-label-family);font-size:var(--type-label-size);font-weight:var(--type-label-weight);line-height:var(--type-label-line);letter-spacing:.06em;text-transform:uppercase;color:var(--white-a30);justify-content:center;align-items:center;gap:7px;margin-top:28px;display:flex}.hero-badge-items{flex-wrap:nowrap;justify-content:center;align-items:center;gap:4px;display:flex}.hero-badge-item{white-space:nowrap;align-items:center;display:inline-flex}.hero-badge-separator{color:var(--white-a25);margin:0 7px}.g-dot{background:var(--brand-green);border-radius:50%;flex-shrink:0;width:6px;height:6px;animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}.hero-headline{font-family:var(--type-h1-family);font-size:var(--type-h1-size);font-weight:var(--type-h1-weight);line-height:var(--type-h1-line);letter-spacing:var(--type-h1-tracking);text-align:center;max-width:720px;margin-bottom:22px}.accent{background:linear-gradient(90deg, var(--accent-purple), var(--accent-pink));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-subline{font-family:var(--type-body-lg-family);font-size:var(--type-body-lg-size);font-weight:var(--type-body-lg-weight);line-height:var(--type-body-lg-line);color:var(--white-a30);text-align:center;max-width:720px}@media (width<=1200px){.hero-headline{font-size:clamp(42px,6.5vw,56px)}.hero-subline{font-size:20px}}@media (width<=900px){.hero-section{margin-bottom:56px}.hero-profile{width:132px;height:132px;margin-bottom:20px}.hero-eyebrow{font-size:var(--type-label-size);margin-bottom:14px}.hero-headline{margin-bottom:16px;font-size:clamp(34px,9vw,46px)}.hero-subline{font-size:var(--type-body-size);line-height:var(--type-body-line)}.hero-badge{font-size:var(--type-meta-size);letter-spacing:.04em;align-items:center;margin-top:20px;line-height:1.5}.hero-badge .g-dot{display:none}.hero-badge-items{gap:8px;max-width:320px}.hero-badge-item{border:.5px solid var(--white-a10);background:var(--white-a05);border-radius:999px;padding:4px 10px}.hero-badge-separator{display:none}}@media (width<=640px){.hero-section{margin-bottom:44px}.hero-headline{font-size:clamp(30px,10.5vw,40px)}}@media (width<=375px){.hero-profile{width:116px;height:116px}.hero-eyebrow{font-size:var(--type-meta-size);margin-bottom:10px}.hero-headline{letter-spacing:-1px;font-size:30px;line-height:1.12}.hero-subline{font-size:15px}.hero-badge{font-size:var(--type-meta-size);margin-top:16px}.hero-badge-items{justify-content:center;gap:6px;max-width:260px}.hero-badge-item{padding:4px 8px}}.project-card{cursor:pointer;color:inherit;border:.5px solid;border-radius:16px;align-items:stretch;gap:36px;padding:56px;text-decoration:none;transition:transform .25s,box-shadow .25s;display:flex;position:relative}.project-card:hover{box-shadow:0 20px 40px var(--black-a35);transform:translateY(-4px)}.project-card:focus-visible{outline:1px solid var(--white-a30);outline-offset:2px}.project-content{flex:1;min-width:0}.project-company-row{align-items:center;gap:0;margin-bottom:26px;display:flex}.project-company-mark{font-family:var(--type-label-family);font-size:var(--type-label-size);font-weight:var(--type-label-weight);line-height:var(--type-label-line);text-transform:uppercase;justify-content:center;align-items:center;width:24px;height:24px;display:inline-flex}.project-company-logo{object-fit:contain;opacity:.6;width:auto;height:26px;transition:opacity .2s;display:block}.project-card:hover .project-company-logo{opacity:1}.project-title{font-family:var(--type-heading-family);font-size:var(--type-heading-size);font-weight:var(--type-heading-weight);letter-spacing:var(--type-heading-tracking);line-height:var(--type-heading-line);max-width:520px;margin-bottom:18px}.project-description{font-family:var(--type-body-family);font-size:var(--type-body-size);font-weight:var(--type-body-weight);line-height:var(--type-body-line);color:var(--white-a40);max-width:560px;margin-bottom:28px}.project-labels{flex-direction:column;gap:16px;margin-bottom:30px;display:flex}.project-label-block{flex-direction:column;gap:6px;display:flex}.project-label{font-family:var(--type-body-family);font-size:var(--type-body-size);font-weight:var(--type-body-weight);line-height:var(--type-body-line);color:var(--white-a35)}.project-value{font-family:var(--type-body-family);font-size:var(--type-body-size);font-weight:600;line-height:var(--type-body-line);color:var(--white-a70)}.project-view-button{font-family:var(--type-body-family);font-size:var(--type-body-size);font-weight:600;line-height:var(--type-body-line);cursor:pointer;border:.5px solid;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:10px 18px;text-decoration:none;transition:opacity .15s;display:inline-flex}.project-view-arrow{font-size:var(--type-label-size);opacity:.7;line-height:1;transition:opacity .15s}.project-view-button:hover{opacity:.85}.project-view-button:hover .project-view-arrow{opacity:1}.project-image{width:52%;min-width:420px;min-height:340px;font-family:var(--type-body-family);font-size:var(--type-body-size);font-weight:600;line-height:var(--type-body-line);color:var(--white-a25);text-transform:uppercase;letter-spacing:.04em;background:0 0;border:none;border-radius:0;flex-shrink:0;justify-content:center;align-items:center;display:flex;overflow:hidden}.project-image-asset{object-fit:cover;border-radius:12px;width:100%;height:100%;display:block}@media (width<=1200px){.project-card{flex-direction:column;align-items:stretch;padding:40px}.project-image{width:100%;min-width:0;min-height:240px}}@media (width<=720px){.project-card{padding:28px}}@media (width<=375px){.project-card{border-radius:14px;gap:20px;padding:20px}.project-company-row{margin-bottom:18px}.project-title{margin-bottom:12px;font-size:26px}.project-description{margin-bottom:20px;font-size:15px}.project-labels{gap:12px;margin-bottom:22px}.project-image{min-height:190px}.project-view-button{text-align:center;width:100%}}.projects-section{flex-direction:column;gap:20px;padding:40px 0;display:flex}.projects-heading{font-family:var(--type-label-family);font-size:var(--type-body-lg-size);font-weight:var(--type-label-weight);line-height:var(--type-label-line);letter-spacing:.06em;text-transform:uppercase;color:var(--white-a30);text-align:center;margin:24px 0}.projects-section>.project-card+.project-card{margin-top:20px}@media (width<=900px){.projects-section{gap:16px;padding:28px 0}.projects-heading{font-size:var(--type-label-size);margin:16px 0}.projects-section>.project-card+.project-card{margin-top:16px}}.floating-toolbar{background:var(--bg-secondary);border:.5px solid var(--white-a10);z-index:50;border-radius:12px;align-items:center;gap:6px;padding:8px;display:flex;position:fixed;bottom:32px;left:50%;transform:translate(-50%)}.toolbar-btn{width:38px;height:38px;color:var(--white-a40);font-size:var(--type-body-size);cursor:pointer;background:0 0;border:none;border-radius:9px;justify-content:center;align-items:center;padding:0;font-family:inherit;transition:color .15s,background .15s,box-shadow .15s;display:inline-flex}.toolbar-btn:hover{color:var(--white-a70);background:var(--white-a06)}.toolbar-btn.active{background:var(--accent-green-a12);color:var(--accent-green);box-shadow:inset 0 0 0 .5px var(--accent-green-a18)}.toolbar-icon{width:22px;height:22px;display:block}.toolbar-separator{background:var(--white-a12);width:.5px;height:22px}@media (width<=900px){.floating-toolbar{gap:4px;padding:6px;bottom:18px}.toolbar-btn{border-radius:8px;width:34px;height:34px}.toolbar-icon{width:20px;height:20px}.toolbar-separator{height:18px}}.inspect-panel{--inspect-title-family:var(--type-label-family);--inspect-title-size:var(--type-label-size);--inspect-title-weight:var(--type-label-weight);--inspect-title-line:var(--type-label-line);--inspect-control-family:var(--type-caption-family);--inspect-control-size:var(--type-caption-size);--inspect-control-weight:var(--type-label-weight);--inspect-control-line:var(--type-caption-line);--inspect-field-family:var(--type-caption-family);--inspect-field-size:var(--type-label-size);--inspect-field-weight:var(--type-label-weight);--inspect-field-line:var(--type-caption-line);--inspect-field-color:var(--white);--inspect-label-family:var(--type-small-family);--inspect-label-size:var(--type-small-size);--inspect-label-weight:var(--type-label-weight);--inspect-label-line:var(--type-small-line);background:var(--bg-panel);border-left:.5px solid var(--white-a07);font-family:var(--type-body-family);font-size:var(--type-body-size);font-weight:var(--type-body-weight);line-height:var(--type-body-line);flex-direction:column;display:flex;position:relative;overflow:hidden}.inspect-panel-resize-handle{cursor:col-resize;z-index:2;background:0 0;border:none;width:10px;height:100%;margin-left:-5px;padding:0;position:absolute;top:0;left:0}.inspect-panel-resize-handle:after{content:"";background:var(--white-a08);border-radius:999px;width:2px;height:36px;transition:background .15s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.inspect-panel-resize-handle:hover:after,.inspect-panel-resize-handle:focus-visible:after{background:var(--accent-green-a40)}.panel-head{border-bottom:.5px solid var(--white-a06);padding:12px 14px 0}.panel-title-row{font-size:var(--type-label-size);font-weight:var(--type-label-weight);color:var(--white);justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.panel-ver{font-family:var(--type-meta-family);font-size:var(--type-meta-size);font-weight:var(--type-meta-weight);line-height:var(--type-meta-line);color:var(--white-a25);background:var(--white-a06);border-radius:4px;padding:3px 8px}.panel-tabs{display:flex}.tab{font-size:var(--type-label-size);font-weight:var(--type-small-weight);line-height:var(--type-label-line);color:var(--white-a28);cursor:pointer;background:0 0;border:none;border-bottom:1.5px solid #0000;padding:9px 14px;font-family:inherit;transition:color .15s}.tab.active{color:var(--white);border-bottom-color:var(--white)}.tab:hover{color:var(--white-a70)}.edit-tab{flex:1;padding:14px 12px;overflow-y:auto}.sel-tag{font-size:var(--type-caption-size);font-family:var(--type-code-family);font-weight:var(--type-code-weight);line-height:var(--type-code-line);background:var(--accent-purple-a10);color:var(--accent-purple);border-radius:8px;margin-bottom:14px;padding:3px 10px;display:inline-block}.ps{margin-bottom:14px}.layout-card{background:var(--bg-elevated);border:.5px solid var(--white-a06);border-radius:8px;margin-bottom:14px;padding:10px}.inspector-card{background:var(--bg-elevated);border:.5px solid var(--white-a06);border-radius:10px;margin-bottom:14px;padding:12px}.card-header{align-items:center;margin-bottom:10px;display:flex}.card-title{font-family:var(--inspect-title-family);font-size:var(--inspect-title-size);font-weight:var(--inspect-title-weight);line-height:var(--inspect-title-line);color:var(--white);letter-spacing:-.02em}.type-preview{border:.5px solid var(--white-a06);background:color-mix(in srgb, var(--bg-code) 76%, transparent);min-height:104px;font-size:var(--type-body-size);font-weight:var(--type-heading-weight);line-height:var(--inspect-field-line);letter-spacing:-.03em;color:var(--inspect-field-color);white-space:pre-wrap;border-radius:10px;margin-bottom:12px;padding:16px;overflow:hidden}.type-toolbar-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:12px;display:grid}.segmented-row,.mode-switch{border:.5px solid var(--white-a08);background:color-mix(in srgb, var(--bg-code) 82%, transparent);border-radius:9px;padding:2px;display:grid}.segmented-row{grid-template-columns:repeat(3,minmax(0,1fr))}.segmented-btn,.mode-pill{height:44px;color:var(--white-a30);font-family:var(--inspect-control-family);font-size:var(--inspect-control-size);font-weight:var(--inspect-control-weight);line-height:var(--inspect-control-line);text-align:center;background:0 0;border-radius:7px;justify-content:center;align-items:center;display:flex}.segmented-btn{border:none}.segmented-btn.active,.mode-pill.active{color:var(--white);background:color-mix(in srgb, var(--white) 7%, transparent)}.select-field-wrap{margin-bottom:12px}.field-caption{font-family:var(--inspect-label-family);font-size:var(--inspect-label-size);font-weight:var(--inspect-label-weight);line-height:var(--inspect-label-line);letter-spacing:.06em;text-transform:uppercase;color:var(--white-a20);margin-bottom:8px}.select-field{border:.5px solid var(--white-a08);background:color-mix(in srgb, var(--bg-code) 76%, transparent);min-height:46px;font-family:var(--inspect-field-family);font-size:var(--inspect-field-size);font-weight:var(--inspect-field-weight);line-height:var(--inspect-field-line);color:var(--inspect-field-color);border-radius:10px;justify-content:space-between;align-items:center;gap:10px;padding:0 16px;display:flex}.select-chevron{color:var(--white-a30);justify-content:center;align-items:center;display:inline-flex}.select-chevron-icon{width:12px;height:12px;display:block}.inline-metrics-grid,.appearance-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.appearance-grid{grid-template-columns:repeat(2,minmax(0,1fr));margin-bottom:14px}.typography-card .inline-metrics-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.inline-metric{border:.5px solid var(--white-a08);background:color-mix(in srgb, var(--bg-code) 76%, transparent);border-radius:10px;align-items:center;gap:8px;min-height:56px;padding:12px 14px;display:flex}.inline-metric-icon{font-family:var(--inspect-label-family);font-size:var(--inspect-label-size);font-weight:var(--inspect-label-weight);line-height:var(--inspect-label-line);text-transform:uppercase;color:var(--white-a25)}.inline-metric-value{font-family:var(--inspect-field-family);font-size:var(--inspect-field-size);font-weight:var(--inspect-field-weight);line-height:var(--inspect-field-line);color:var(--inspect-field-color)}.inline-metric-suffix{color:var(--inspect-field-color);font-family:var(--inspect-field-family);font-size:var(--inspect-field-size);font-weight:var(--inspect-field-weight);line-height:var(--inspect-field-line);margin-left:auto}.fill-block{border-top:.5px solid var(--white-a06);padding-top:14px}.fill-header-row{justify-content:space-between;align-items:flex-end;gap:12px;margin-bottom:12px;display:flex}.mode-switch.compact{width:190px;margin-bottom:0}.color-field{border:.5px solid var(--white-a08);background:color-mix(in srgb, var(--bg-code) 76%, transparent);border-radius:10px;align-items:center;gap:12px;min-height:54px;padding:0 16px;display:flex}.color-chip{border:1px solid var(--white-a12);border-radius:999px;flex-shrink:0;width:24px;height:24px}.gradient-chip{border-radius:8px}.color-value{font-family:var(--inspect-field-family);font-size:var(--inspect-field-size);font-weight:var(--inspect-field-weight);line-height:var(--inspect-field-line);color:var(--inspect-field-color)}.color-opacity{font-family:var(--inspect-field-family);font-size:var(--inspect-field-size);font-weight:var(--inspect-field-weight);line-height:var(--inspect-field-line);color:var(--inspect-field-color);margin-left:auto}.surface-field{justify-content:flex-start}.layout-section-title,.layout-subsection-title{font-family:var(--inspect-label-family);font-size:var(--inspect-label-size);font-weight:var(--inspect-label-weight);line-height:var(--inspect-label-line);letter-spacing:.06em;text-transform:uppercase;color:var(--white-a20)}.layout-section-title{margin-bottom:8px}.layout-subsection-title{margin:12px 0 8px}.position-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;margin-bottom:12px;display:grid}.metric-field{border:.5px solid var(--white-a08);background:color-mix(in srgb, var(--bg-code) 78%, transparent);border-radius:6px;justify-content:space-between;align-items:center;gap:6px;min-height:38px;padding:7px 8px;display:flex}.metric-label{font-family:var(--inspect-label-family);font-size:var(--inspect-label-size);font-weight:var(--inspect-label-weight);line-height:var(--inspect-label-line);text-transform:uppercase;color:var(--white-a25)}.metric-value{font-family:var(--inspect-field-family);font-size:var(--inspect-field-size);font-weight:var(--inspect-field-weight);line-height:var(--inspect-field-line);color:var(--inspect-field-color)}.mode-switch{grid-template-columns:repeat(2,minmax(0,1fr));margin-bottom:12px}.mode-pill{font-family:var(--inspect-control-family);font-size:var(--inspect-control-size);font-weight:var(--inspect-control-weight);line-height:var(--inspect-control-line);color:var(--white-a30);padding:0 8px}.box-quad{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;display:grid}.ps-label{font-family:var(--inspect-label-family);font-size:var(--inspect-label-size);font-weight:var(--inspect-label-weight);line-height:var(--inspect-label-line);letter-spacing:.07em;text-transform:uppercase;color:var(--white-a20);margin-bottom:6px}.pb{background:var(--bg-elevated);border:.5px solid var(--white-a06);border-radius:5px;overflow:hidden}.pr{border-bottom:.5px solid var(--white-a04);justify-content:space-between;align-items:center;padding:8px 10px;display:flex}.pr:last-child{border-bottom:none}.pk{font-family:var(--type-caption-family);font-size:var(--type-meta-size);font-weight:var(--type-caption-weight);line-height:var(--type-caption-line);color:var(--white-a25)}.pv{font-size:var(--type-caption-size);color:var(--white-a75);font-family:var(--type-caption-family);font-weight:var(--type-label-weight);line-height:var(--type-caption-line);align-items:center;gap:4px;display:flex}.swatch{border:.5px solid var(--white-a12);border-radius:2px;flex-shrink:0;width:9px;height:9px;display:inline-block}.inspect-empty{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:22px;padding:32px 20px;display:flex}.inspect-empty-icon-shell{background:linear-gradient(180deg, var(--accent-shell-grad-start), var(--accent-shell-grad-end));border:.5px solid var(--accent-green-a22);width:64px;height:64px;box-shadow:inset 0 1px 0 var(--white-a04);border-radius:18px;justify-content:center;align-items:center;display:flex}.inspect-empty-icon{width:24px;height:24px;color:var(--accent-green);display:block}.inspect-empty p{max-width:280px;font-size:var(--type-body-size);font-weight:var(--type-label-weight);color:var(--white-a18);line-height:var(--type-body-line);letter-spacing:-.02em}.code-tab{flex-direction:column;flex:1;display:flex;overflow:hidden}.code-file-header{border-bottom:.5px solid var(--white-a06);justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.code-filename{font-size:var(--type-code-size);font-family:var(--type-code-family);font-weight:var(--type-code-weight);line-height:var(--type-code-line);color:var(--white-a40)}.copy-btn{font-size:var(--type-small-size);background:var(--white-a06);border:.5px solid var(--white-a10);color:var(--white-a50);cursor:pointer;border-radius:4px;padding:3px 10px;font-family:inherit;transition:color .15s,background .15s}.copy-btn:hover{color:var(--white);background:var(--white-a10)}.code-viewer{background:var(--bg-code);flex:1;padding:12px;overflow:auto}.code-viewer pre{margin:0}.code-viewer code{font-family:var(--type-code-family);font-size:var(--type-code-size);font-weight:var(--type-code-weight);line-height:var(--type-code-line);white-space:pre}@media (width<=640px){.position-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.type-toolbar-grid,.inline-metrics-grid,.appearance-grid,.fill-header-row{grid-template-columns:1fr;display:grid}.mode-switch.compact{width:100%}}.token.keyword{color:var(--accent-purple)}.token.function{color:var(--accent-mint)}.token.string{color:var(--accent-orange)}.token.comment{color:var(--white-a20);font-style:italic}.token.number{color:var(--accent-rose)}.token.operator{color:var(--white-a50)}.token.punctuation{color:var(--white-a30)}.token.class-name{color:var(--accent-mint)}.token.tag{color:var(--accent-purple)}.token.attr-name{color:var(--accent-mint)}.token.attr-value{color:var(--accent-orange)}.el-tag{font-size:var(--type-code-size);font-family:var(--type-code-family);background:var(--brand-green);color:var(--white);pointer-events:none;z-index:999;white-space:nowrap;border-radius:3px;padding:2px 6px;position:fixed}.contrib-footer{border-top:.5px solid var(--white-a07);margin-top:80px;padding:40px 64px 120px}.contact-cta{text-align:center;flex-direction:column;align-items:center;max-width:920px;margin:0 auto 64px;display:flex}.contact-eyebrow{font-family:var(--type-label-family);font-size:var(--type-body-lg-size);font-weight:var(--type-label-weight);line-height:var(--type-label-line);text-transform:uppercase;letter-spacing:.06em;color:var(--white-a30);margin-bottom:24px}.contact-heading{font-family:var(--type-h1-family);font-size:var(--type-h1-size);font-weight:var(--type-h1-weight);line-height:var(--type-h1-line);letter-spacing:var(--type-h1-tracking);color:var(--white);margin-bottom:24px}.contact-accent{background:linear-gradient(90deg, var(--accent-purple), var(--accent-pink));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.contact-subheading{font-family:var(--type-body-lg-family);font-size:var(--type-body-lg-size);font-weight:var(--type-body-lg-weight);line-height:var(--type-body-lg-line);color:var(--white-a40);max-width:860px}.contact-actions{align-items:center;gap:12px;margin-top:28px;display:flex}.contact-action{min-width:140px;height:44px;font-family:var(--type-body-family);font-size:var(--type-body-size);font-weight:600;line-height:var(--type-body-line);border:.5px solid;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:0 18px;text-decoration:none;transition:opacity .15s,background .15s,color .15s;display:inline-flex}.contact-action:hover{opacity:.9}.contact-action.primary{background:var(--white);color:var(--bg-primary);border-color:var(--white-a18)}.contact-action.secondary{background:var(--white-a05);color:var(--white-a70);border-color:var(--white-a14)}.contact-action.secondary:hover{background:var(--white-a09);color:var(--white)}.contact-action-icon{font-size:var(--type-label-size);color:var(--white-a50);line-height:1}.contact-action.secondary:hover .contact-action-icon{color:var(--white-a70)}.contrib-label{font-family:var(--type-small-family);font-size:var(--type-small-size);font-weight:var(--type-small-weight);line-height:var(--type-small-line);text-transform:uppercase;letter-spacing:.07em;color:var(--white-a20);margin-bottom:16px}.contrib-graph{flex-direction:column;align-items:flex-start;width:max-content;margin:0 auto;display:flex}.contrib-grid{grid-template-rows:repeat(9,12px);gap:2px;display:grid}.contrib-cell{border-radius:3px}.contrib-meta{justify-content:space-between;align-items:center;width:100%;margin-top:10px;display:flex}.contrib-count{font-family:var(--type-small-family);font-size:var(--type-small-size);font-weight:var(--type-small-weight);line-height:var(--type-small-line);color:var(--white-a25)}.contrib-legend{align-items:center;gap:4px;display:flex}.contrib-legend-label{font-family:var(--type-small-family);font-size:var(--type-small-size);font-weight:var(--type-small-weight);line-height:var(--type-small-line);color:var(--white-a25)}.contrib-legend-swatch{border-radius:3px;width:12px;height:12px}.footer-socials{flex-wrap:wrap;justify-content:center;align-items:center;gap:16px;margin-top:28px;display:flex}.footer-social-link{color:var(--white-a50);justify-content:flex-start;align-items:center;gap:8px;text-decoration:none;transition:color .15s;display:inline-flex}.footer-social-link:hover{color:var(--white)}.footer-social-icon{width:16px;height:16px;display:inline-flex}.footer-social-icon svg{width:16px;height:16px}.footer-social-text{font-family:var(--type-body-family);font-size:var(--type-body-size);font-weight:var(--type-body-weight);line-height:var(--type-body-line)}.footer-signature{border-top:.5px solid var(--white-a07);justify-content:center;align-items:center;gap:10px;margin-top:52px;padding-top:24px;display:flex}.footer-signature-mark{width:28px;height:28px;font-family:var(--type-label-family);font-size:var(--type-label-size);font-weight:600;line-height:var(--type-label-line);color:var(--white);background:linear-gradient(140deg, var(--accent-purple), var(--accent-pink));border-radius:8px;justify-content:center;align-items:center;display:inline-flex}.footer-signature-text{font-family:var(--type-label-family);font-size:var(--type-label-size);font-weight:var(--type-label-weight);line-height:var(--type-label-line);letter-spacing:.06em;text-transform:uppercase;color:var(--white-a30)}@media (width<=900px){.contrib-footer{margin-top:56px;padding:32px 24px 96px}.contact-eyebrow{font-size:var(--type-label-size);margin-bottom:16px}.contrib-graph{display:none}.contact-heading{font-size:var(--type-heading-size);line-height:var(--type-heading-line);letter-spacing:var(--type-heading-tracking)}.contact-subheading{font-size:var(--type-body-size);line-height:var(--type-body-line)}.contact-actions{flex-direction:column;width:100%}.contact-action{width:100%;max-width:320px}.footer-socials{justify-content:center;margin-top:0}.footer-signature{justify-content:center;margin-top:32px}}@media (width<=640px){.contrib-footer{padding:28px 16px 92px}.contact-cta{margin-bottom:44px}.contact-actions{margin-top:22px}.contrib-meta{flex-direction:column;align-items:flex-start;gap:12px}.footer-socials{justify-content:center;gap:12px;margin-top:24px}.footer-signature{text-align:center;flex-direction:column;align-items:center;gap:10px}.footer-signature-text{max-width:360px;font-size:var(--type-meta-size);line-height:var(--type-meta-line);letter-spacing:.05em}}@media (width<=375px){.contrib-footer{padding:24px 12px 80px}.contact-eyebrow{font-size:var(--type-label-size);margin-bottom:16px}.contact-heading{letter-spacing:-.8px;margin-bottom:14px;font-size:30px;line-height:1.18}.contact-subheading{font-size:15px}.contact-action{height:40px}.footer-signature{gap:8px;margin-top:36px}.footer-signature-mark{border-radius:7px;width:24px;height:24px}.footer-signature-text{font-size:var(--type-meta-size);letter-spacing:.04em;max-width:280px}}.cursor-glow{pointer-events:none;z-index:0;background:radial-gradient(700px circle at var(--cursor-x,-1000px) var(--cursor-y,-1000px), var(--glow-cursor) 0%, transparent 70%);position:fixed;inset:0}@media (width<=900px){.cursor-glow{display:none}}.about-page{flex-direction:column;gap:84px;padding:48px 0;display:flex}.about-hero-section{text-align:center;flex-direction:column;align-items:center;gap:18px;margin-bottom:-12px;display:flex}.about-hero-eyebrow,.about-section-eyebrow{font-family:var(--type-label-family);font-size:var(--type-body-lg-size);font-weight:var(--type-label-weight);line-height:var(--type-label-line);letter-spacing:.06em;text-transform:uppercase;color:var(--white-a30)}.about-panel-label{font-family:var(--type-label-family);font-size:var(--type-label-size);font-weight:var(--type-label-weight);line-height:var(--type-label-line);letter-spacing:.06em;text-transform:uppercase;color:var(--white-a30)}.about-hero-title{font-family:var(--type-h1-family);font-size:var(--type-h1-size);font-weight:var(--type-h1-weight);line-height:var(--type-h1-line);letter-spacing:var(--type-h1-tracking);color:var(--text-primary);max-width:760px}.about-hero-accent{background:linear-gradient(90deg, var(--accent-purple), var(--accent-pink));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.about-hero-subline{font-family:var(--type-body-lg-family);font-size:var(--type-body-lg-size);font-weight:var(--type-body-lg-weight);line-height:var(--type-body-lg-line);color:var(--white-a35);white-space:pre-line;max-width:720px}.about-hero-meta{font-family:var(--type-label-family);font-size:var(--type-label-size);font-weight:var(--type-label-weight);line-height:var(--type-label-line);letter-spacing:.06em;text-transform:uppercase;color:var(--white-a30);flex-wrap:wrap;justify-content:center;align-items:center;gap:4px;margin-top:10px;margin-bottom:14px;display:flex}.about-hero-meta-item{align-items:center;display:inline-flex}.about-hero-meta-separator{color:var(--white-a25);margin:0 10px}.about-photo-row{flex-wrap:wrap;justify-content:center;align-items:start;gap:14px;display:flex}.about-photo-section{flex-direction:column;gap:22px;margin-top:-4px;display:flex}.about-photo-row-secondary{align-items:center}.about-sticky-shell{z-index:12;width:180px;min-height:180px;box-shadow:2px 3px 12px var(--black-a35);border:.5px solid var(--white-a10);border-radius:4px;padding:12px 14px;position:relative}.about-sticky-shell:after,.about-sticky-shell:before{content:none}.about-sticky-shell-currently{background:var(--sticky-teal-bg);color:var(--sticky-teal-text);transform:rotate(-6deg)translate(18px,-58px)}.about-sticky-shell-bring{background:var(--sticky-purple-bg);color:var(--sticky-purple-text);transform:rotate(4.5deg)translate(-20px,64px)}.about-sticky-shell-currently .currently-label{font-family:var(--font-family-hand);font-size:var(--type-body-size);letter-spacing:.04em;text-transform:uppercase;color:inherit;opacity:.7;margin-bottom:8px;font-weight:700}.about-sticky-shell-currently .currently-item{margin-bottom:8px;display:block}.about-sticky-shell-currently .currently-key,.about-sticky-shell-currently .currently-val{width:auto;color:inherit;opacity:1;font-family:var(--font-family-hand);font-size:var(--type-body-size);line-height:1.45;display:block}.about-sticky-shell-currently .currently-key{opacity:.72;font-weight:700}.about-sticky-shell-bring .bring-card{width:100%;color:inherit;box-shadow:none;background:0 0;border:none;padding:0}.about-sticky-shell-bring .bring-title{opacity:.72}.about-sticky-shell-bring .bring-item{border-bottom-color:var(--white-a10)}.about-detail-section{flex-direction:column;gap:28px;display:flex}.about-section-intro{text-align:center;flex-direction:column;align-items:center;gap:8px;display:flex}.about-section-title{font-family:var(--type-heading-family);font-size:var(--type-heading-size);font-weight:var(--type-heading-weight);line-height:var(--type-heading-line);letter-spacing:var(--type-heading-tracking);color:var(--text-primary)}.about-detail-card{border:.5px solid var(--white-a08);background:var(--bg-secondary);border-radius:16px;padding:44px}.about-work-grid,.about-skills-grid{grid-template-columns:repeat(2,minmax(0,1fr));align-items:start;gap:24px;display:grid}.about-panel,.about-skills-side{flex-direction:column;gap:18px;display:flex}.about-sticky-row{flex-wrap:wrap;gap:16px;display:flex}@media (width<=1200px){.about-page{gap:68px;padding:32px 0 36px}.about-detail-section{gap:22px}.about-detail-card{padding:36px}.about-work-grid,.about-skills-grid{gap:20px}}@media (width<=900px){.about-page{gap:52px;padding:20px 0 24px}.about-hero-title{font-size:clamp(34px,9vw,46px)}.about-hero-meta{font-size:var(--type-meta-size);line-height:var(--type-label-line)}.about-hero-subline{font-size:var(--type-body-size);line-height:var(--type-body-line)}.about-hero-eyebrow,.about-section-eyebrow{font-size:var(--type-label-size)}.about-section-title{font-size:26px;line-height:1.2}.about-work-grid,.about-skills-grid{grid-template-columns:1fr}.about-detail-card{padding:32px}.about-sticky-shell{width:160px;min-height:170px}}@media (width<=640px){.about-page{gap:44px}.about-photo-row{justify-content:center}.about-photo-section{gap:18px}.about-sticky-shell{width:140px;min-height:150px;padding:10px 12px}.about-sticky-shell-currently,.about-sticky-shell-bring{transform:none}.about-section-title{font-size:var(--type-body-lg-size);line-height:var(--type-body-lg-line)}.about-detail-card{padding:24px}}.photo-frame{background:var(--photo-print-bg);box-shadow:4px 8px 28px var(--black-a35);border-radius:2px;flex-shrink:0;width:304px;padding:7px;position:relative}.photo-tape{background:var(--tape-bg);z-index:3;width:56%;height:22px;box-shadow:0 1px 3px var(--black-a35);border-radius:1px;position:absolute;top:-11px;left:50%;transform:translate(-50%)}.photo-img-wrap{aspect-ratio:1;background:var(--bg-elevated);width:100%;overflow:hidden}.photo-img{object-fit:cover;width:100%;height:100%;display:block}.photo-cap{font-size:var(--type-body-size);font-weight:600;font-family:var(--font-family-hand);color:var(--photo-print-text);text-align:center;padding-top:8px;line-height:1.3}@media (width<=900px){.photo-frame{width:240px}}@media (width<=640px){.photo-frame{width:180px}}.sticky-note{z-index:12;font-size:var(--type-body-size);font-family:var(--font-family-hand);width:140px;height:180px;box-shadow:2px 3px 12px var(--black-a35);border:.5px solid var(--white-a10);border-radius:4px;align-items:center;padding:10px 12px;font-weight:600;line-height:1.5;display:flex;position:relative}.sticky-note:after,.sticky-note:before{content:none}.bring-card{box-shadow:2px 3px 12px var(--black-a35);border:.5px solid var(--white-a10);background:var(--sticky-purple-bg);width:100%;color:var(--sticky-purple-text);border-radius:4px;padding:10px 12px}.bring-title{font-family:var(--font-family-hand);font-size:var(--type-body-size);letter-spacing:.04em;text-transform:uppercase;opacity:.7;margin-bottom:8px;font-weight:700}.bring-item{font-size:var(--type-body-size);font-family:var(--font-family-hand);border-bottom:.5px solid var(--white-a06);align-items:center;gap:6px;padding:4px 0;display:flex}.bring-item:last-child{border-bottom:none}.bring-icon{font-family:var(--font-family-hand);font-size:var(--type-body-size);opacity:.7;font-weight:700;line-height:1}.currently{width:100%}.currently-label{font-family:var(--type-label-family);font-size:var(--type-label-size);font-weight:var(--type-label-weight);letter-spacing:.06em;text-transform:uppercase;color:var(--text-secondary);opacity:.5;margin-bottom:6px}.currently-item{align-items:flex-start;gap:6px;margin-bottom:5px;display:flex}.currently-key{font-size:var(--type-caption-size);font-family:var(--type-label-family);color:var(--text-secondary);opacity:.6;flex-shrink:0;width:52px}.currently-val{font-size:var(--type-caption-size);font-family:var(--type-caption-family);color:var(--text-secondary);line-height:1.4}
