:root{--bg-base: #fafafa;--bg-surface: #ffffff;--bg-subtle: #f4f4f5;--text-primary: #09090b;--text-secondary: #52525b;--text-muted: #71717a;--border: #e4e4e7;--border-strong: #d4d4d8;--palette-lavender: #9FA1FF;--palette-periwinkle: #B5BAFF;--palette-sky: #AEE2FF;--palette-mint: #D9F9DF;--accent: #9FA1FF;--accent-light: #F0F1FF;--accent-hover: #B5BAFF;--accent-ink: #35309a;--success: #16a34a;--success-soft: #f0fdf4;--font-sans: "Plus Jakarta Sans", "Inter", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-5xl: 3rem;--text-6xl: 3.75rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--container-max: 1120px;--content-max: 720px;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-12: 3rem;--space-16: 4rem;--space-24: 6rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .07), 0 2px 4px -2px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -4px rgba(0, 0, 0, .05);--duration-fast: .15s;--duration-base: .25s;--duration-slow: .4s;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1)}*{box-sizing:border-box}html{scroll-behavior:smooth;scroll-padding-top:96px}body{margin:0;color:var(--text-primary);background:var(--bg-base);font-family:var(--font-sans);font-size:var(--text-base);line-height:1.7;letter-spacing:0;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}body:before{position:fixed;inset:0;z-index:-1;pointer-events:none;content:"";background:linear-gradient(90deg,rgba(159,161,255,.08) 1px,transparent 1px),linear-gradient(0deg,rgba(174,226,255,.08) 1px,transparent 1px);background-size:40px 40px;mask-image:linear-gradient(to bottom,rgba(0,0,0,.7),transparent 70%)}a{color:inherit;text-decoration:none}img,svg{display:block}img{max-width:100%;height:auto}button,input,textarea,select{font:inherit}button{cursor:pointer}:focus-visible{outline:3px solid rgba(159,161,255,.8);outline-offset:3px}.skip-link{position:fixed;top:12px;left:12px;z-index:100;padding:10px 14px;color:var(--text-primary);background:var(--palette-mint);border:1px solid rgba(22,163,74,.22);border-radius:var(--radius-md);transform:translateY(-150%);transition:transform var(--duration-fast) var(--ease-out)}.skip-link:focus{transform:translateY(0)}.container{width:min(100% - 32px,var(--container-max));margin-inline:auto}.content-container{width:min(100% - 32px,var(--content-max));margin-inline:auto}.section-band{padding:var(--space-16) 0}.section-band-muted{background:#ffffffad;border-block:1px solid rgba(228,228,231,.8)}.section-header{max-width:720px;margin-bottom:var(--space-8)}.section-header-center{margin-inline:auto;text-align:center}.section-label,.eyebrow{margin:0 0 var(--space-3);color:var(--accent-ink);font-family:var(--font-mono);font-size:var(--text-xs);font-weight:var(--font-semibold);line-height:1.4;letter-spacing:0;text-transform:uppercase}.section-header h2,.page-title,.detail-title{margin:0;color:var(--text-primary);font-size:var(--text-3xl);line-height:1.15;letter-spacing:0}.section-description,.lead{margin:var(--space-4) 0 0;color:var(--text-secondary);font-size:var(--text-lg);line-height:1.75}.site-nav{position:fixed;top:0;right:0;left:0;z-index:50;border-bottom:1px solid transparent;transition:background-color var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.site-nav.is-scrolled,.menu-is-open .site-nav{background:#ffffffeb;border-bottom-color:var(--border);box-shadow:var(--shadow-sm);backdrop-filter:blur(16px) saturate(180%)}.nav-inner{display:flex;align-items:center;justify-content:space-between;width:min(100% - 32px,var(--container-max));height:72px;margin-inline:auto}.brand{color:var(--text-primary);font-size:var(--text-xl);font-weight:800;line-height:1}.nav-links{display:none;align-items:center;gap:var(--space-6)}.nav-link{position:relative;color:var(--text-secondary);font-size:var(--text-sm);font-weight:var(--font-semibold);line-height:1.2;transition:color var(--duration-fast) var(--ease-out)}.nav-link:after{position:absolute;right:0;bottom:-10px;left:0;height:2px;content:"";background:var(--accent);border-radius:var(--radius-full);transform:scaleX(0);transform-origin:left;transition:transform var(--duration-fast) var(--ease-out)}.nav-link:hover,.nav-link.is-active{color:var(--accent-ink)}.nav-link:hover:after,.nav-link.is-active:after{transform:scaleX(1)}.menu-toggle{position:relative;display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;padding:0;color:var(--text-primary);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.menu-icon{width:20px;height:20px}.menu-close{position:absolute;opacity:0}.menu-toggle[aria-expanded=true] .menu-open{opacity:0}.menu-toggle[aria-expanded=true] .menu-close{opacity:1}.mobile-menu{position:fixed;inset:72px 0 auto;display:grid;gap:var(--space-2);padding:var(--space-6) 16px var(--space-8);background:#fffffffa;border-bottom:1px solid var(--border);box-shadow:var(--shadow-md);transform:translateY(-16px);opacity:0;visibility:hidden;transition:opacity var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out),visibility var(--duration-fast) var(--ease-out)}.mobile-menu[aria-hidden=false]{transform:translateY(0);opacity:1;visibility:visible}.mobile-link{display:flex;align-items:center;min-height:52px;padding:0 var(--space-4);color:var(--text-primary);font-weight:var(--font-semibold);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md)}.btn-row{display:flex;flex-wrap:wrap;gap:var(--space-3);align-items:center}.hero-actions{display:none}.about-mobile-actions{align-items:stretch;margin-top:var(--space-8)}.about-mobile-actions .btn,.about-mobile-actions .cv-selector,.about-mobile-actions .cv-selector-trigger{flex:1 1 100%}.about-mobile-actions .cv-selector-menu{right:0;left:0;width:100%;min-width:0}.cv-selector{position:relative;display:inline-flex}.cv-selector-trigger{gap:var(--space-2);list-style:none}.cv-selector-trigger::-webkit-details-marker{display:none}.cv-selector-chevron{transition:transform var(--duration-fast) var(--ease-out)}.cv-selector[open] .cv-selector-chevron{transform:rotate(180deg)}.cv-selector-menu{position:absolute;top:calc(100% + var(--space-2));left:0;z-index:20;display:grid;width:max-content;min-width:220px;padding:var(--space-2);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg)}.cv-selector-option{display:grid;grid-template-columns:28px minmax(0,1fr) auto;gap:var(--space-3);align-items:center;min-height:44px;padding:var(--space-2) var(--space-3);color:var(--text-primary);font-size:var(--text-sm);font-weight:var(--font-semibold);border-radius:var(--radius-sm);transition:background-color var(--duration-fast) var(--ease-out)}.cv-selector-option:hover,.cv-selector-option:focus-visible{background:var(--accent-light)}.cv-selector-option strong{color:var(--accent-ink);font-family:var(--font-mono);font-size:var(--text-xs)}.cv-selector-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;color:var(--accent-ink);background:var(--accent-light);border-radius:var(--radius-full)}.cv-selector-icon svg{width:16px;height:16px}.btn{display:inline-flex;gap:var(--space-2);align-items:center;justify-content:center;min-height:44px;padding:0 var(--space-4);color:var(--text-primary);font-size:var(--text-sm);font-weight:var(--font-bold);line-height:1.2;border:1px solid transparent;border-radius:var(--radius-md);transition:background-color var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out)}.btn svg,.inline-link svg,.contact-link svg,.back-link svg,.next-project svg{width:18px;height:18px;flex:0 0 auto}.btn-primary{background:var(--accent);border-color:#35309a1f;box-shadow:0 8px 20px #9fa1ff57}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--bg-surface);border-color:var(--border);box-shadow:var(--shadow-sm)}.btn-secondary:hover{background:var(--bg-subtle);border-color:var(--border-strong)}.btn-ghost{color:var(--accent-ink);background:transparent}.btn-ghost:hover{background:var(--accent-light)}.btn:active{transform:scale(.98)}.availability-badge,.tag,.project-tag,.skill-pill{display:inline-flex;align-items:center;width:fit-content;border-radius:var(--radius-full)}.availability-badge{gap:var(--space-2);padding:7px 12px;color:var(--success);font-size:var(--text-sm);font-weight:var(--font-semibold);background:var(--success-soft);border:1px solid #bbf7d0}.availability-badge:before{width:8px;height:8px;content:"";background:var(--success);border-radius:50%;animation:pulse 1.6s infinite}.tag{padding:5px 10px;color:var(--text-secondary);font-size:var(--text-xs);font-weight:var(--font-bold);background:var(--bg-subtle)}.skill-pill{padding:4px 10px;color:var(--accent-ink);font-size:var(--text-sm);font-weight:var(--font-semibold);background:var(--accent-light);border:1px solid rgba(159,161,255,.24)}.badge-list{display:flex;flex-wrap:wrap;gap:var(--space-2)}.hero-section{padding:96px 0 var(--space-12)}.hero-grid{display:grid;gap:var(--space-8);align-items:center}.hero-copy{display:grid;gap:var(--space-4);max-width:700px}.hero-copy h1{max-width:12ch;margin:0;color:var(--text-primary);font-size:var(--text-4xl);line-height:1.05;letter-spacing:0}.hero-copy h1 span{color:var(--accent-ink)}.hero-subhead{margin:0;color:var(--text-primary);font-size:var(--text-xl);font-weight:var(--font-bold);line-height:1.35}.hero-body{max-width:620px;margin:0;color:var(--text-secondary);font-size:var(--text-base)}.hero-visual{display:flex;justify-content:center}.hero-photo{position:relative;width:min(62vw,220px);aspect-ratio:4 / 5;margin:0;overflow:hidden;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg)}.hero-photo img{width:100%;height:100%;object-fit:cover;object-position:center top}.about-grid,.contact-grid,.resume-grid{display:grid;gap:var(--space-8)}.prose p{margin:0 0 var(--space-4);color:var(--text-secondary)}.prose p:last-child{margin-bottom:0}.highlight-panel,.resume-panel,.principles-panel,.skill-card,.impact-box{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm)}.highlight-panel,.resume-panel,.principles-panel,.impact-box{padding:var(--space-6)}.highlight-panel{align-self:start;border-color:#9fa1ff61}.highlight-panel h3,.principles-panel h3,.resume-panel h3,.skill-card h3,.detail-section h2{margin:0;color:var(--text-primary);font-size:var(--text-xl);line-height:1.3;letter-spacing:0}.highlight-panel p,.resume-panel p,.principles-panel p{margin:var(--space-2) 0 0;color:var(--text-secondary)}.highlight-list,.principle-list,.detail-list{display:grid;gap:var(--space-4);padding:0;margin:var(--space-6) 0 0;list-style:none}.highlight-list li,.principle-list li,.detail-list li{position:relative;padding-left:var(--space-6);color:var(--text-secondary)}.highlight-list li:before,.principle-list li:before,.detail-list li:before{position:absolute;top:.62em;left:0;width:10px;height:10px;content:"";background:var(--palette-mint);border:2px solid var(--success);border-radius:50%}.progress-stack{display:grid;gap:var(--space-4);margin-bottom:var(--space-8)}.progress-item{display:grid;gap:var(--space-2)}.progress-top{display:flex;justify-content:space-between;gap:var(--space-4);color:var(--text-secondary);font-size:var(--text-sm);font-weight:var(--font-semibold)}.progress-track{height:10px;overflow:hidden;background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius-full)}.progress-fill{width:var(--level);height:100%;background:linear-gradient(90deg,var(--palette-lavender),var(--palette-sky),var(--palette-mint));border-radius:inherit}.skills-grid{display:grid;gap:var(--space-4)}.skill-card{padding:var(--space-6)}.skill-card h3{margin-bottom:var(--space-4)}.projects-grid{display:grid;gap:var(--space-6)}.project-card{display:grid;overflow:hidden;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);transition:transform var(--duration-base) var(--ease-out),box-shadow var(--duration-base) var(--ease-out),border-color var(--duration-base) var(--ease-out)}.project-card:hover{border-color:#9fa1ff8a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.project-media{position:relative;aspect-ratio:16 / 9;overflow:hidden;background:var(--bg-subtle)}.project-media img{width:100%;height:100%;object-fit:cover;transition:transform var(--duration-base) var(--ease-out)}.project-card:hover .project-media img{transform:scale(1.02)}.project-tag{position:absolute;top:12px;left:12px;padding:5px 10px;color:var(--text-primary);font-family:var(--font-mono);font-size:var(--text-xs);font-weight:var(--font-semibold);background:#ffffffdb;border:1px solid rgba(255,255,255,.62);backdrop-filter:blur(12px)}.project-body{display:grid;gap:var(--space-4);padding:var(--space-6)}.project-meta,.detail-meta{display:flex;flex-wrap:wrap;gap:var(--space-2) var(--space-4);color:var(--text-muted);font-size:var(--text-sm);font-weight:var(--font-semibold)}.project-meta span+span,.detail-meta span+span{position:relative}.project-meta span+span:before,.detail-meta span+span:before{position:absolute;top:50%;left:calc(-1 * var(--space-2));width:4px;height:4px;content:"";background:var(--palette-lavender);border-radius:50%;transform:translate(-50%,-50%)}.project-body h3{margin:0;color:var(--text-primary);font-size:var(--text-2xl);line-height:1.2}.project-body p{margin:0;color:var(--text-secondary)}.inline-link,.back-link,.next-project,.contact-link{display:inline-flex;gap:var(--space-2);align-items:center;width:fit-content;color:var(--accent-ink);font-size:var(--text-sm);font-weight:var(--font-bold)}.inline-link:hover,.back-link:hover,.next-project:hover,.contact-link:hover{color:var(--text-primary)}.timeline{position:relative;display:grid;gap:var(--space-6);padding:0;margin:var(--space-6) 0 0;list-style:none}.timeline-item{position:relative;padding-left:var(--space-8)}.timeline-item:before{position:absolute;top:.7rem;bottom:calc(-1 * var(--space-6));left:4px;width:1px;content:"";background:var(--border)}.timeline-item:last-child:before{display:none}.timeline-dot{position:absolute;top:.48rem;left:0;width:9px;height:9px;background:var(--accent);border:2px solid var(--bg-surface);border-radius:50%;box-shadow:0 0 0 2px #9fa1ff47}.timeline-time{color:var(--text-muted);font-family:var(--font-mono);font-size:var(--text-xs);font-weight:var(--font-semibold)}.timeline-role{margin:var(--space-1) 0 0;color:var(--text-primary);font-weight:var(--font-bold);line-height:1.35}.timeline-company{margin:var(--space-1) 0 0;color:var(--text-secondary);font-size:var(--text-sm)}.contact-card-list{display:grid;gap:var(--space-3);margin:var(--space-6) 0}.contact-card{display:flex;flex-wrap:wrap;gap:var(--space-2) var(--space-4);align-items:center;justify-content:space-between;padding:var(--space-4);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md)}.contact-card strong{color:var(--text-primary)}.contact-card span{color:var(--text-secondary)}.site-footer{padding:var(--space-8) 0;background:var(--bg-surface);border-top:1px solid var(--border)}.footer-inner{display:flex;flex-direction:column;gap:var(--space-4);color:var(--text-secondary);font-size:var(--text-sm)}.footer-inner p{margin:0}.detail-hero{padding:104px 0 var(--space-12)}.detail-heading{display:grid;gap:var(--space-4);margin:var(--space-8) 0}.detail-title{font-size:var(--text-4xl)}.detail-role{margin:0;color:var(--text-secondary);font-size:var(--text-lg)}.detail-image{overflow:hidden;margin:0;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-md)}.detail-image img{width:100%;aspect-ratio:1900 / 925;object-fit:cover}.detail-section{padding:var(--space-8) 0;border-top:1px solid var(--border)}.detail-section h2{margin-bottom:var(--space-4);font-size:var(--text-2xl)}.detail-section p{margin:0 0 var(--space-4);color:var(--text-secondary)}.screenshot-grid{display:grid;gap:var(--space-4)}.screenshot-grid figure{margin:0;overflow:hidden;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg)}.screenshot-grid img{width:100%;aspect-ratio:1900 / 925;object-fit:cover}.next-project{justify-content:space-between;width:100%;padding:var(--space-5);margin-top:var(--space-4);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm)}[data-reveal]{opacity:0;transform:translateY(32px);transition:opacity var(--duration-slow) var(--ease-out),transform var(--duration-slow) var(--ease-out)}[data-reveal].is-visible{opacity:1;transform:translateY(0)}@keyframes pulse{0%{box-shadow:0 0 #16a34a57}70%{box-shadow:0 0 0 7px #16a34a00}to{box-shadow:0 0 #16a34a00}}@media(min-width:640px){.hero-copy h1{font-size:var(--text-5xl)}.hero-photo{width:min(42vw,300px)}.footer-inner{flex-direction:row;align-items:center;justify-content:space-between}.screenshot-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:768px){.section-band{padding:var(--space-24) 0}.section-header h2,.page-title{font-size:var(--text-4xl)}.hero-section{padding:112px 0 var(--space-16)}.hero-grid{grid-template-columns:minmax(0,3fr) minmax(260px,2fr)}.hero-copy h1{font-size:var(--text-6xl)}.hero-body{font-size:var(--text-lg)}.hero-actions{display:flex}.about-mobile-actions{display:none}.hero-photo{width:100%;max-width:380px;margin-left:auto}.about-grid,.contact-grid,.resume-grid{grid-template-columns:minmax(0,1.35fr) minmax(280px,.85fr)}.skills-grid,.projects-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:960px){.nav-links{display:flex}.menu-toggle,.mobile-menu{display:none}}@media(max-width:420px){.container,.content-container,.nav-inner{width:min(100% - 24px,var(--container-max))}.hero-section{padding-top:88px}.hero-copy h1{font-size:var(--text-3xl)}.hero-subhead{font-size:var(--text-lg)}.btn-row{align-items:stretch}.btn-row .btn,.btn-row .cv-selector,.btn-row .cv-selector-trigger{flex:1 1 100%}.cv-selector-menu{right:0;left:0;width:100%;min-width:0}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}[data-reveal]{opacity:1;transform:none}}
