@import "https://fonts.googleapis.com/css2?family=Archivo:wght@400;500;600;700;800&family=Space+Grotesk:wght@400;500;600;700&display=swap";:root{--font-heading:"Archivo", system-ui, sans-serif;--font-body:"Space Grotesk", system-ui, sans-serif;--background:#fafafa;--foreground:#09090b;--body-foreground:#3f3f46;--muted-foreground:#71717a;--surface:#fff;--surface-muted:#f4f4f5;--accent:#2563eb;--accent-foreground:#fff;--accent-soft:#eff6ff;--border:#e4e4e7;--border-strong:#d4d4d8;--shadow-soft:0 18px 45px #18181b0f;--shadow-lift:0 24px 60px #18181b1f;--radius-sm:6px;--radius-md:8px;--page-max:1180px;--page-gutter:32px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-7:32px;--space-8:40px;--space-9:48px;--space-10:56px;--space-11:64px;--space-12:88px;--duration-fast:.18s;--duration-med:.26s;--duration-slow:.52s;--ease-out:cubic-bezier(.16, 1, .3, 1);font-family:var(--font-body);color:var(--foreground);background:var(--background);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root[data-theme=dark]{--background:#111113;--foreground:#fafafa;--body-foreground:#d4d4d8;--muted-foreground:#a1a1aa;--surface:#18181b;--surface-muted:#202024;--accent:#60a5fa;--accent-foreground:#08111f;--accent-soft:#60a5fa1f;--border:#2f3037;--border-strong:#44454f;--shadow-soft:0 18px 45px #00000038;--shadow-lift:0 24px 60px #00000057}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth;background:var(--background)}body{background:linear-gradient(180deg, color-mix(in srgb, var(--accent) 5%, transparent), transparent 430px), var(--background);min-width:320px;min-height:100svh;margin:0}body,button,input,textarea,select{font-family:var(--font-body)}button,a{-webkit-tap-highlight-color:transparent}button{cursor:pointer}img,svg{display:block}a,button{outline:none}a:focus-visible,button:focus-visible{box-shadow:0 0 0 3px var(--background), 0 0 0 5px var(--accent)}::selection{background:var(--accent);color:var(--accent-foreground)}#root{min-height:100svh}@media (width<=760px){:root{--page-gutter:20px;--space-12:64px}}.site-shell{min-height:100svh}.skip-link{left:var(--space-4);top:var(--space-4);z-index:20;border-radius:var(--radius-sm);background:var(--foreground);color:var(--background);transition:transform var(--duration-fast) var(--ease-out);padding:.65rem .85rem;font-weight:700;text-decoration:none;position:fixed;transform:translateY(-140%)}.skip-link:focus{transform:translateY(0)}.site-header{z-index:10;align-items:center;gap:var(--space-4);width:min(100% - var(--page-gutter) * 2, var(--page-max));padding:var(--space-4) 0;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);grid-template-columns:auto 1fr auto;margin:0 auto;display:grid;position:sticky;top:0}.site-header:before{inset:0 calc(var(--page-gutter) * -1);z-index:-1;border-bottom:1px solid var(--border);background:color-mix(in srgb, var(--background) 84%, transparent);content:"";position:absolute}.brand-mark{border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface);width:44px;height:44px;color:var(--foreground);font-family:var(--font-heading);transition:border-color var(--duration-fast) var(--ease-out), color var(--duration-fast) var(--ease-out), transform var(--duration-fast) var(--ease-out);justify-content:center;align-items:center;font-size:.9rem;font-weight:800;text-decoration:none;display:inline-flex}.brand-mark:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}.site-nav{justify-content:center;gap:var(--space-1);display:flex}.site-nav a{border-radius:var(--radius-sm);min-height:44px;color:var(--muted-foreground);padding:0 var(--space-3);transition:background var(--duration-fast) var(--ease-out), color var(--duration-fast) var(--ease-out);align-items:center;font-size:.9rem;font-weight:650;text-decoration:none;display:inline-flex}.site-nav a:hover{background:var(--surface-muted);color:var(--foreground)}.icon-button{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);width:44px;height:44px;color:var(--foreground);transition:border-color var(--duration-fast) var(--ease-out), background var(--duration-fast) var(--ease-out), transform var(--duration-fast) var(--ease-out);justify-content:center;align-items:center;display:inline-flex}.icon-button svg{width:19px;height:19px}.icon-button:hover{border-color:var(--accent);background:var(--surface-muted);transform:translateY(-1px)}.hero-section{align-items:center;gap:var(--space-10);width:min(100% - var(--page-gutter) * 2, var(--page-max));min-height:76svh;padding:var(--space-12) 0 var(--space-10);grid-template-columns:minmax(0,1.15fr) minmax(280px,.85fr);margin:0 auto;display:grid}.hero-copy{max-width:780px}.eyebrow{margin:0 0 var(--space-4);color:var(--accent);letter-spacing:0;text-transform:uppercase;font-size:.78rem;font-weight:800}.hero-section h1{max-width:850px;color:var(--foreground);font-family:var(--font-heading);letter-spacing:0;overflow-wrap:anywhere;margin:0;font-size:5rem;line-height:.96}.hero-section h1 span{margin-top:var(--space-2);color:var(--muted-foreground);font-weight:500;display:block}.hero-intro{max-width:640px;margin:var(--space-6) 0 0;color:var(--body-foreground);font-size:1.18rem;line-height:1.65}.hero-actions,.contact-actions{gap:var(--space-3);margin-top:var(--space-7);flex-wrap:wrap;display:flex}.button{justify-content:center;align-items:center;gap:var(--space-2);border-radius:var(--radius-sm);min-height:46px;transition:background var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out), color var(--duration-fast) var(--ease-out), transform var(--duration-fast) var(--ease-out);border:1px solid #0000;padding:.72rem 1rem;font-weight:800;text-decoration:none;display:inline-flex}.button svg{width:18px;height:18px}.button:hover{transform:translateY(-1px)}.button-primary{background:var(--foreground);color:var(--background)}.button-primary:hover{background:var(--accent);color:var(--accent-foreground)}.button-secondary{border-color:var(--border-strong);background:var(--surface);color:var(--foreground)}.button-secondary:hover{border-color:var(--accent);color:var(--accent)}.hero-visual{justify-items:center;gap:var(--space-4);display:grid;position:relative}.portrait-frame{aspect-ratio:1;border:1px solid var(--border-strong);border-radius:var(--radius-md);background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 14%, transparent), transparent), var(--surface);width:min(100%,320px);overflow:hidden}.portrait-frame img{object-fit:cover;filter:saturate(.88)contrast(1.04);width:100%;height:100%}.signal-panel{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);width:min(100%,320px);padding:var(--space-4);box-shadow:var(--shadow-soft)}.signal-kicker,.signal-meta{color:var(--muted-foreground);font-size:.82rem;font-weight:700}.signal-panel strong{margin:var(--space-2) 0;color:var(--foreground);font-family:var(--font-heading);font-size:1.5rem;line-height:1.15;display:block}.signal-meta{align-items:center;gap:var(--space-2);display:inline-flex}.signal-meta svg{width:16px;height:16px}.section{width:min(100% - var(--page-gutter) * 2, var(--page-max));padding:var(--space-12) 0;margin:0 auto}.section-heading{gap:var(--space-8);margin-bottom:var(--space-6);grid-template-columns:minmax(0,.72fr) minmax(280px,.48fr);align-items:end;display:grid}.section-heading.compact{max-width:720px;display:block}.section-heading h2,.about-copy h2,.contact-section h2{color:var(--foreground);font-family:var(--font-heading);letter-spacing:0;margin:0;font-size:3rem;line-height:1}.section-heading p:not(.eyebrow),.contact-section p,.about-copy p{color:var(--body-foreground);margin:0;line-height:1.7}.filter-bar{gap:var(--space-2);margin-bottom:var(--space-5);flex-wrap:wrap;display:flex}.filter-bar button{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);min-height:44px;color:var(--muted-foreground);transition:background var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out), color var(--duration-fast) var(--ease-out);padding:.62rem .85rem;font-weight:800}.filter-bar button:hover,.filter-bar button.is-active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.project-count{margin:calc(var(--space-2) * -1) 0 var(--space-4);color:var(--muted-foreground);font-size:.9rem;font-weight:800}.project-grid{gap:var(--space-4);grid-template-columns:repeat(3,minmax(0,1fr));display:grid}.project-card{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);box-shadow:var(--shadow-soft);transition:border-color var(--duration-med) var(--ease-out), box-shadow var(--duration-med) var(--ease-out), transform var(--duration-med) var(--ease-out);overflow:hidden}.project-card:hover{border-color:color-mix(in srgb, var(--accent) 42%, var(--border));box-shadow:var(--shadow-lift);transform:translateY(-3px)}.project-preview{aspect-ratio:16/10;padding:var(--space-3);background:radial-gradient(circle at top right, color-mix(in srgb, var(--preview-accent) 28%, transparent), transparent 34%), linear-gradient(135deg, var(--preview-from), var(--preview-to));position:relative;overflow:hidden}.project-preview:after{border-bottom:1px solid color-mix(in srgb, var(--preview-accent) 22%, transparent);content:"";pointer-events:none;background:linear-gradient(#0000 70%,#0000001f);position:absolute;inset:0}.preview-bar{inset:var(--space-3) var(--space-3) auto;z-index:2;gap:var(--space-2);border-radius:var(--radius-sm) var(--radius-sm) 0 0;height:28px;padding:0 var(--space-3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffc7;border:1px solid #ffffff75;align-items:center;display:flex;position:absolute}.preview-bar span{background:var(--preview-accent);opacity:.74;border-radius:999px;width:7px;height:7px}.project-preview img{border-radius:var(--radius-sm);object-fit:cover;object-position:top center;width:100%;height:100%;transition:transform var(--duration-med) var(--ease-out);border:1px solid #ffffff6b;display:block;box-shadow:0 18px 45px #00000029}.project-card:hover .project-preview img{transform:scale(1.035)}.project-body{gap:var(--space-4);padding:var(--space-4);display:grid}.project-meta,.project-footer{justify-content:space-between;align-items:center;gap:var(--space-3);display:flex}.project-meta span,.project-footer span{color:var(--muted-foreground);font-size:.82rem;font-weight:800}.project-card h3{color:var(--foreground);font-family:var(--font-heading);overflow-wrap:anywhere;margin:0;font-size:1.45rem;line-height:1.08}.project-card p{color:var(--body-foreground);margin:0;line-height:1.62}.tag-list{gap:var(--space-2);flex-wrap:wrap;margin:0;padding:0;list-style:none;display:flex}.tag-list li{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-muted);color:var(--muted-foreground);padding:.38rem .56rem;font-size:.78rem;font-weight:800}.project-footer a{align-items:center;gap:var(--space-1);min-height:44px;color:var(--accent);font-size:.9rem;font-weight:850;text-decoration:none;display:inline-flex}.project-footer a svg{width:17px;height:17px}.skills-section{border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.skills-grid{gap:var(--space-3);margin-top:var(--space-6);grid-template-columns:repeat(3,minmax(0,1fr));display:grid}.skill-item{gap:var(--space-3);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);min-height:128px;padding:var(--space-4);display:flex}.skill-item svg{width:23px;height:23px;color:var(--accent);flex:none}.skill-item strong,.principle-item strong{margin-bottom:var(--space-2);color:var(--foreground);font-family:var(--font-heading);font-size:1.08rem;display:block}.skill-item span,.principle-item span{color:var(--body-foreground);line-height:1.6}.about-section{gap:var(--space-8);grid-template-columns:.5fr 1fr;align-items:start;display:grid}.about-kicker{align-items:center;gap:var(--space-3);color:var(--accent);font-weight:850;display:flex}.about-kicker svg{width:22px;height:22px}.about-copy{gap:var(--space-5);display:grid}.principles-grid{gap:var(--space-3);grid-column:2;grid-template-columns:repeat(3,minmax(0,1fr));display:grid}.principle-item{border-top:2px solid var(--accent);padding-top:var(--space-4)}.contact-section{width:min(100% - var(--page-gutter) * 2, var(--page-max));padding:var(--space-12) 0 var(--space-6);margin:0 auto}.contact-section>div:first-child{max-width:760px}.contact-section h2{margin-bottom:var(--space-4)}.footer-line{justify-content:space-between;gap:var(--space-4);margin-top:var(--space-9);border-top:1px solid var(--border);padding-top:var(--space-4);color:var(--muted-foreground);font-size:.88rem;font-weight:700;display:flex}[data-reveal]{opacity:0;transition:opacity var(--duration-slow) var(--ease-out), transform var(--duration-slow) var(--ease-out);transform:translateY(18px)}[data-reveal].is-visible{opacity:1;transform:translateY(0)}@media (width<=980px){.site-header{grid-template-columns:auto auto}.site-nav{padding-bottom:var(--space-1);grid-area:2/1/auto/-1;justify-content:flex-start;overflow-x:auto}.hero-section,.section-heading,.about-section{grid-template-columns:1fr}.hero-section{min-height:auto;padding-top:var(--space-8)}.hero-section h1{font-size:3.5rem}.hero-visual{justify-items:start}.project-grid,.skills-grid,.principles-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.principles-grid{grid-column:auto}}@media (width<=640px){.site-nav a{padding:0 var(--space-2)}.hero-section h1{font-size:2.32rem;line-height:1.02}.hero-intro{font-size:1rem}.section,.contact-section{padding:var(--space-9) 0}.section-heading h2,.about-copy h2,.contact-section h2{font-size:2.1rem;line-height:1.08}.hero-actions,.contact-actions,.button{width:100%}.project-grid,.skills-grid,.principles-grid{grid-template-columns:1fr}.project-preview{min-height:180px}.footer-line{flex-direction:column}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}[data-reveal]{opacity:1;transform:none}}
