:root{--background: #050505;--surface: #101010;--surface-strong: #171717;--foreground: #f5f3ef;--muted: #bdb7ab;--subtle: #8b8579;--focus: #f5f3ef;--error: #ff8f8f;--success: #b7f7c6;--max-width: 1080px;--sidebar-width: 272px;--transition: .22s ease}html[data-theme=light]{--background: #f5f1e8;--surface: #ebe4d8;--surface-strong: #dfd5c6;--foreground: #161616;--muted: #49443e;--subtle: #70675d;--focus: #161616;--error: #7a1f1f;--success: #165b2f}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Outfit,sans-serif;background:var(--background);color:var(--foreground);line-height:1.6;transition:background-color var(--transition),color var(--transition)}body.menu-open{overflow:hidden}main,section,article,div,button,input,textarea,a{border-radius:0}img{display:block;max-width:100%;height:auto}a{color:inherit;text-decoration:none}button,input,textarea{font:inherit;color:inherit}button{cursor:pointer}h1,h2,h3,h4,h5,h6{margin:0;font-family:Inter,sans-serif;font-weight:700;line-height:.98}p,li,label,textarea,input,a,button{font-family:Outfit,sans-serif}ul{margin:0;padding-left:1.2rem}.skip-link{position:absolute;top:1rem;left:1rem;z-index:30;padding:.75rem 1rem;background:var(--foreground);color:var(--background);transform:translateY(-140%);transition:transform var(--transition)}.skip-link:focus-visible{transform:translateY(0)}.mobile-topbar,.mobile-drawer{display:none}.mobile-drawer:not([hidden]){display:block}.desktop-sidebar{position:fixed;inset:0 auto 0 0;width:var(--sidebar-width);padding:2rem 1.5rem;display:flex;flex-direction:column;justify-content:space-between;gap:2rem;background:var(--background);transition:background-color var(--transition),color var(--transition)}.sidebar-intro{display:grid;gap:.75rem;max-height:0;opacity:0;overflow:hidden;pointer-events:none;transform:translateY(-.5rem);transition:max-height var(--transition),opacity var(--transition),transform var(--transition)}.sidebar-intro.is-visible{max-height:10rem;opacity:1;pointer-events:auto;transform:translateY(0)}.sidebar-kicker,.section-kicker{margin:0;text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;color:var(--subtle)}.sidebar-summary{margin:0;max-width:18rem;color:var(--muted);font-size:.95rem}.site-nav,.mobile-nav{display:grid;gap:.2rem}.nav-link{min-height:44px;display:inline-flex;align-items:center;padding:.35rem 0;text-transform:uppercase;letter-spacing:.08em;font-size:.82rem;opacity:.52;transition:opacity var(--transition),transform var(--transition),font-size var(--transition),letter-spacing var(--transition)}.nav-link.is-active{opacity:1;transform:translate(.4rem) scale(1.05);font-size:.96rem;letter-spacing:.11em}.theme-toggle,.menu-toggle,.button{min-height:44px;display:inline-flex;align-items:center;justify-content:center;padding:.85rem 1rem;background:var(--foreground);color:var(--background);border:1px solid currentColor;transition:background-color var(--transition),color var(--transition),opacity var(--transition),transform var(--transition),box-shadow var(--transition)}.theme-toggle{width:44px;flex:0 0 44px;padding:0}.theme-toggle__icon{width:24px;height:24px}.desktop-theme-toggle{align-self:flex-start}.button-secondary{background:var(--surface);color:var(--foreground)}main{margin-left:var(--sidebar-width);padding:0 2rem 4rem}.site-footer{margin-left:var(--sidebar-width);padding:0 2rem 2.5rem}.site-footer p{max-width:var(--max-width);margin:0 auto;color:var(--subtle);font-size:.82rem;letter-spacing:.08em;text-transform:uppercase}.panel{max-width:var(--max-width);margin:0 auto;padding:4rem 0;scroll-margin-top:2rem}.hero{min-height:100vh;display:grid;grid-template-columns:minmax(0,1.1fr) minmax(300px,.9fr);gap:3rem;align-items:center}.hero-copy{display:grid;gap:1.5rem}.hero h1{font-size:clamp(4rem,11vw,7.6rem);letter-spacing:-.06em}.hero-tagline{margin:0;max-width:28rem;font-size:clamp(1.25rem,3vw,1.85rem);line-height:1.2}.hero-detail{margin:0;max-width:34rem;color:var(--muted);font-size:1rem}.hero-actions{display:flex;flex-wrap:wrap;gap:.9rem}.hero-figure{margin:0;background:var(--surface)}.hero-figure img{width:100%;aspect-ratio:3 / 4;object-fit:cover}.section-heading{display:grid;gap:.4rem;margin-bottom:2.25rem}.section-heading h2{font-size:clamp(2rem,6vw,3.5rem);letter-spacing:-.05em}.section-heading-spread{grid-template-columns:repeat(2,minmax(0,1fr));align-items:end;gap:1.5rem}.reading-column{display:grid;gap:1.5rem;max-width:44rem}.reading-column p,.work-item p,.project-card p,.resume-block p,.contact-copy p{margin:0;color:var(--muted);font-size:1.02rem}.timeline{display:grid;gap:2rem}.work-item{display:grid;gap:.8rem;padding:1.5rem;background:var(--surface)}.work-meta{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}.work-company,.work-dates{margin:0;color:var(--subtle);text-transform:uppercase;letter-spacing:.08em;font-size:.82rem}.work-item h3,.project-card h3,.resume-block h3{font-size:1.35rem;letter-spacing:-.03em}.project-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.5rem;align-items:start}.project-card,.resume-block,.contact-form,.contact-copy{background:var(--surface);padding:1.5rem}.project-card{display:grid;gap:1.25rem;align-content:start;cursor:pointer;transition:transform var(--transition),box-shadow var(--transition),background-color var(--transition)}.project-card:hover,.project-card:focus-visible{transform:translateY(-6px);box-shadow:0 18px 40px color-mix(in srgb,var(--foreground) 10%,transparent)}.project-media,.project-modal-media{position:relative;overflow:hidden;min-height:220px;background:radial-gradient(circle at top right,color-mix(in srgb,var(--foreground) 18%,transparent),transparent 35%),linear-gradient(135deg,color-mix(in srgb,var(--surface-strong) 85%,black),var(--surface))}.project-card .project-media{margin:-1.5rem -1.5rem 0}.project-card .project-media.project-media--has-image{min-height:260px}.project-media--has-image{background:var(--surface-strong)}.project-media--has-image:before,.project-media--has-image:after{display:none}.project-media-track{position:absolute;inset:0}.project-media-slide{position:absolute;inset:0;opacity:0;transition:opacity .42s ease}.project-media-slide.is-active{opacity:1}.project-media-image{display:block;width:100%;height:100%;object-fit:cover}.project-media--has-image>.project-media-image{position:absolute;inset:0}.project-card .project-media--has-image{background:linear-gradient(135deg,color-mix(in srgb,var(--surface-strong) 85%,black),var(--surface))}.project-card .project-media-image{padding:.45rem .45rem .85rem;object-fit:contain;background:color-mix(in srgb,var(--surface) 86%,black);border:1px solid color-mix(in srgb,var(--foreground) 12%,transparent);box-shadow:0 14px 28px color-mix(in srgb,black 24%,transparent)}.project-modal-media .project-media-image{object-fit:contain;background:color-mix(in srgb,var(--surface-strong) 82%,black)}.project-media-controls,.project-media-pagination{position:absolute;z-index:2;display:flex;align-items:center}.project-media-controls{top:1rem;right:1rem;gap:.55rem}.project-media-pagination{left:50%;bottom:1rem;gap:.45rem;transform:translate(-50%)}.project-media-button,.project-media-dot{border:0;box-shadow:none;background:color-mix(in srgb,var(--background) 80%,transparent);color:var(--foreground)}.project-media-button{width:2.35rem;height:2.35rem;padding:0;display:inline-flex;align-items:center;justify-content:center;font-size:1rem}.project-media-dot{width:.45rem;height:.45rem;padding:0;border-radius:999px;border:1px solid #f5f3ef;background:#050505;opacity:.78}.project-media-dot.is-active{background:#f5f3ef;opacity:1;transform:scale(1.08)}.project-media-button:hover,.project-media-button:focus-visible,.project-media-dot:hover,.project-media-dot:focus-visible{opacity:1}.project-media:before,.project-modal-media:before{content:"";position:absolute;inset:1rem;border:1px solid color-mix(in srgb,var(--foreground) 12%,transparent)}.project-media:after,.project-modal-media:after{content:"";position:absolute;width:44%;aspect-ratio:1;right:-8%;bottom:-18%;border-radius:50%;background:color-mix(in srgb,var(--foreground) 12%,transparent)}.project-media-label{position:absolute;left:1rem;bottom:1rem;z-index:1;max-width:14rem;padding:.45rem .65rem;background:color-mix(in srgb,var(--background) 88%,transparent);color:var(--foreground);font-size:.82rem;letter-spacing:.08em;text-transform:uppercase}.project-media-caritas{background:linear-gradient(160deg,rgba(245,177,122,.24),transparent 50%),linear-gradient(135deg,#131313,#27201a 55%,#443228)}.project-media-kids{background:linear-gradient(150deg,rgba(118,196,166,.28),transparent 50%),linear-gradient(135deg,#101414,#17352e 56%,#285046)}.project-media-golf{background:linear-gradient(145deg,rgba(201,218,130,.24),transparent 50%),linear-gradient(135deg,#111412,#223527 56%,#496a4a)}.project-media-snake{background:linear-gradient(145deg,rgba(226,138,138,.24),transparent 50%),linear-gradient(135deg,#120f13,#2e1929 56%,#5d2b37)}.project-copy{display:grid;gap:.8rem}.project-card-cta{margin:auto 0 0;color:var(--subtle);text-transform:uppercase;letter-spacing:.08em;font-size:.82rem}.project-modal{position:fixed;inset:0;z-index:40;display:grid;place-items:center;padding:1.25rem}.project-modal[hidden]{display:none}.project-modal-backdrop{position:absolute;inset:0;background:color-mix(in srgb,var(--background) 55%,black);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.project-modal-dialog{position:relative;z-index:1;width:min(980px,100%);height:min(72vh,640px);max-height:min(72vh,640px);overflow:hidden;display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,1fr);align-items:stretch;background:var(--surface);box-shadow:0 28px 80px color-mix(in srgb,black 38%,transparent)}.project-modal-media-shell{position:relative;min-height:0}.project-modal-media{min-height:100%}.project-modal-media-link{position:absolute;inset:0;z-index:1}.project-modal-media-link:hover{opacity:1}.project-modal-copy{display:grid;gap:1rem;padding:2rem;align-content:start;min-height:0;overflow-y:auto}.project-modal-eyebrow,.project-modal-subtitle{margin:0;color:var(--subtle);text-transform:uppercase;letter-spacing:.08em;font-size:.82rem}.project-modal-details{color:var(--muted)}.project-modal-action,.project-modal-note{margin:0;font-size:.98rem}.project-modal-action{width:fit-content;color:#4da3ff;text-decoration:none}.project-modal-action:hover,.project-modal-action:focus-visible{color:#7bbbff;opacity:1}.project-modal-note{color:var(--subtle)}.project-modal-close{position:absolute;top:1rem;right:1rem;z-index:2;display:inline-flex;align-items:center;justify-content:center;width:2.75rem;height:2.75rem;padding:0;background:transparent;border:0;box-shadow:none}.project-modal-close img{display:block;width:1.5rem;height:1.5rem}body.project-modal-open{overflow:hidden}.tag-list,.resume-list{display:flex;flex-wrap:wrap;gap:.6rem;padding:0;list-style:none}.tag-list li,.resume-list li{padding:.35rem .6rem;background:var(--surface-strong);color:var(--foreground);font-size:.92rem}.resume-actions{display:grid;justify-items:end;gap:.75rem}.resume-status{margin:0;color:var(--error);text-align:right}.resume-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.5rem}.resume-block{display:grid;gap:.7rem}.resume-block-lead{grid-column:span 2;gap:1rem;background:linear-gradient(135deg,color-mix(in srgb,var(--surface-strong) 88%,transparent),var(--surface))}.resume-kicker{margin:0;text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;color:var(--subtle)}.resume-lead-text{margin:0;max-width:38rem;color:var(--foreground);font-family:Inter,sans-serif;font-size:clamp(1.3rem,2vw,1.7rem);font-weight:600;line-height:1.15;letter-spacing:-.04em}.resume-block-accent{background:linear-gradient(180deg,color-mix(in srgb,var(--foreground) 5%,var(--surface)),var(--surface))}.resume-list{display:grid;gap:.6rem}.resume-list li{padding:0;background:transparent;color:var(--muted)}.resume-list-highlights{gap:1rem}.resume-list-highlights li{display:grid;grid-template-columns:auto 1fr;gap:.9rem;align-items:start}.resume-highlight-number{min-width:3.5rem;font-family:Inter,sans-serif;font-size:clamp(2rem,4vw,3rem);font-weight:800;line-height:.9;letter-spacing:-.06em;color:var(--foreground)}.resume-highlight-copy{display:block;padding-top:.2rem}.resume-education-entry{display:grid;gap:.35rem;padding-left:.9rem;border-left:1px solid color-mix(in srgb,var(--foreground) 12%,transparent)}.resume-education-school,.resume-education-detail{margin:0}.resume-education-school{color:var(--foreground);font-family:Inter,sans-serif;font-size:1.02rem;font-weight:650;letter-spacing:-.025em;line-height:1.25}.resume-education-detail{color:var(--subtle);font-size:.88rem;line-height:1.45;font-style:italic}.contact-layout{display:grid;grid-template-columns:minmax(0,1fr);gap:1.5rem}.contact-copy{display:grid;align-content:start;gap:1rem}.social-links{display:flex;flex-wrap:wrap;gap:.75rem}.social-links a{min-height:44px;display:inline-flex;align-items:center;justify-content:center;gap:.65rem;width:fit-content;padding:.85rem 1rem;transition:opacity var(--transition)}.social-link-icon{background:var(--surface-strong);color:var(--foreground);border:1px solid currentColor;text-transform:uppercase;letter-spacing:.08em;font-size:.82rem;transition:background-color var(--transition),color var(--transition),opacity var(--transition),transform var(--transition),box-shadow var(--transition)}.social-link-icon img{width:24px;height:24px;filter:invert(1)}html[data-theme=light] .social-link-icon img{filter:none}.social-link-icon:hover{transform:translateY(-3px);box-shadow:0 8px color-mix(in srgb,currentColor 22%,transparent)}.contact-form{display:grid;gap:1rem}.contact-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem 1.25rem}.hidden-field{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}.field-group{display:grid;gap:.45rem}.field-group-full{grid-column:1 / -1}.field-group label{color:var(--foreground);font-size:.95rem}.required-marker{color:var(--error)}.field-group input,.field-group textarea{width:100%;padding:.95rem 1rem;background:var(--surface-strong);border:0;transition:background-color var(--transition),color var(--transition),outline-color var(--transition)}.field-group textarea{resize:vertical;min-height:160px}.field-error,.form-status{margin:0;min-height:1.35rem;font-size:.94rem}.field-error[aria-hidden=true]{visibility:hidden}.field-error,.form-status.is-error{color:var(--error)}.form-status.is-success{color:var(--success)}a:hover,button:hover{opacity:.8}.theme-toggle:hover,.menu-toggle:hover,.button:hover{transform:translateY(-3px);box-shadow:0 8px color-mix(in srgb,currentColor 22%,transparent)}:focus-visible{outline:3px solid var(--focus);outline-offset:3px}@media(min-width:1400px){.project-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:1023px){.desktop-sidebar{display:none}.mobile-topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem;background:var(--background);transition:background-color var(--transition),color var(--transition)}.mobile-brand{min-height:44px;display:inline-flex;align-items:center;font-family:Inter,sans-serif;font-weight:700;letter-spacing:-.04em;font-size:1.15rem}.mobile-actions{display:flex;gap:.75rem;align-items:center}.theme-toggle,.menu-toggle{padding-inline:.9rem}.theme-toggle{padding:0}.mobile-drawer{position:fixed;inset:76px 0 0;z-index:15;padding:1rem;background:var(--background);transition:background-color var(--transition),color var(--transition)}.mobile-nav{gap:.4rem}.mobile-nav .nav-link{padding:.6rem 0}main{margin-left:0;padding:0 1rem 3rem}.site-footer{margin-left:0;padding:0 1rem 2rem}.panel{padding:3rem 0;scroll-margin-top:7.5rem}.hero{min-height:auto;grid-template-columns:1fr;gap:2rem;padding-top:2rem}.hero-actions{flex-direction:column;align-items:stretch}.button,.menu-toggle{width:100%}.section-heading-spread,.resume-grid,.contact-layout{grid-template-columns:1fr}.resume-block-lead{grid-column:auto}.project-modal-dialog{grid-template-columns:1fr;height:min(88vh,900px);max-height:min(88vh,900px)}.contact-form-grid{grid-template-columns:1fr}.field-group-full{grid-column:auto}.resume-actions{justify-items:start}.resume-status{text-align:left}.project-grid{grid-template-columns:1fr}.project-modal-media{min-height:280px}}@media(max-width:640px){.hero h1{font-size:3.5rem}.work-item,.project-card,.resume-block,.contact-copy,.contact-form{padding:1.2rem}.project-card .project-media{margin:-1.2rem -1.2rem 0}.project-card .project-media.project-media--has-image{min-height:236px}.project-modal{padding:.75rem}.project-modal-copy{padding:1.2rem}.project-modal-close,.project-media-controls{top:.75rem;right:.75rem}.project-media-pagination{bottom:.75rem}}
