:root{color-scheme:light;--color-ivory: #f5f0e7;--color-stone: #ebe3d6;--color-paper: #fffaf1;--color-ink: #201d18;--color-muted: #6f675d;--color-soft: #a79a87;--color-line: rgba(32, 29, 24, .13);--color-charcoal: #24211d;--color-graphite: #353331;--color-bronze: #9c7a49;--color-champagne: #d7c5a2;--color-navy: #14324a;--color-teal: #2f6f68;--color-accent: #14324a;--color-moss: #4f5c4b;--font-display: "Iowan Old Style", "Palatino Linotype", Palatino, Georgia, serif;--font-sans: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 14px;--shadow-soft: 0 22px 70px rgba(45, 36, 25, .13);--shadow-card: 0 18px 55px rgba(45, 36, 25, .09);--container: 1180px;--transition: .22s ease}*{box-sizing:border-box}html{scroll-behavior:smooth;--header-offset: 90px;scroll-padding-top:var(--header-offset)}body{margin:0;background:radial-gradient(circle at 20% 28svh,rgba(215,197,162,.18),transparent 34rem),linear-gradient(180deg,rgba(235,227,214,.58),rgba(245,240,231,.16) 74svh,transparent 100svh),radial-gradient(circle at 12% 8%,rgba(47,111,104,.12),transparent 34rem),radial-gradient(circle at 86% 18%,rgba(215,197,162,.2),transparent 30rem),linear-gradient(180deg,var(--color-ivory),#efe7da 42%,var(--color-ivory));color:var(--color-ink);font-family:var(--font-sans);font-size:16px;line-height:1.6;text-rendering:optimizeLegibility}body:before{position:fixed;inset:0;z-index:-1;pointer-events:none;content:"";opacity:.36;background-image:linear-gradient(rgba(32,29,24,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(32,29,24,.025) 1px,transparent 1px);background-size:44px 44px;-webkit-mask-image:linear-gradient(180deg,black,transparent 78%);mask-image:linear-gradient(180deg,black,transparent 78%)}a{color:inherit;text-decoration:none}button,input,textarea{font:inherit}main{overflow:hidden}::selection{background:var(--color-champagne);color:var(--color-ink)}.container{width:min(calc(100% - 40px),var(--container));margin:0 auto}.container--wide{width:min(calc(100% - 32px),1360px)}.site-header{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;flex-wrap:nowrap;gap:clamp(12px,2vw,24px);width:min(calc(100% - 40px),1280px);margin:0 auto;padding:14px 16px;background:#f5f0e7d1;border:1px solid rgba(32,29,24,.11);border-radius:var(--radius-md);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:0 12px 40px #2e271d14}.brand-mark{display:inline-flex;align-items:baseline;flex:0 1 auto;gap:12px;min-width:0;width:fit-content;white-space:nowrap}.brand-mark span{display:grid;place-items:center;width:38px;height:38px;color:var(--color-paper);background:var(--color-charcoal);border-radius:var(--radius-sm);font-family:var(--font-display);font-size:17px}.brand-mark small{overflow:hidden;color:var(--color-muted);font-size:12px;letter-spacing:.08em;text-overflow:ellipsis;text-transform:uppercase}.site-nav{display:flex;align-items:center;justify-content:center;flex:1 1 auto;gap:clamp(10px,1.35vw,18px);min-width:0;color:var(--color-muted);font-size:clamp(11px,.9vw,12px);white-space:nowrap}.site-nav a{position:relative;flex:0 0 auto;white-space:nowrap;transition:color var(--transition)}.site-nav a:hover,.site-nav a:focus-visible,.site-nav a.is-active{color:var(--color-navy)}.site-nav a.is-active:after{position:absolute;right:0;bottom:-8px;left:0;height:1px;content:"";background:var(--color-teal)}.site-header>.button{flex:0 0 auto;white-space:nowrap}.mobile-nav,.menu-toggle{display:none}.button{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:0 20px;border:1px solid transparent;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:600;line-height:1;transition:transform var(--transition),background var(--transition),border-color var(--transition),color var(--transition)}.button:hover,.button:focus-visible{transform:translateY(-1px)}.button:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible{outline:2px solid rgba(47,111,104,.45);outline-offset:3px}.button--primary{color:var(--color-paper);background:var(--color-navy);border-color:var(--color-navy)}.button--primary:hover{background:#0e2538}.button--secondary{color:var(--color-ink);background:#fffaf194;border-color:var(--color-line)}.button--secondary:hover{background:var(--color-paper)}.button--outline{color:var(--color-navy);background:transparent;border-color:#14324a3d}.button--text{min-height:auto;padding:0;color:var(--color-ink);background:transparent;border:0}.button--text:after{margin-left:10px;content:"->"}.button--sm{min-height:36px;padding:0 14px;font-size:12px}.hero{min-height:100svh;padding:0 0 clamp(34px,5vh,56px)}.hero__inner{display:grid;grid-template-columns:minmax(0,1.06fr) minmax(320px,.78fr);align-items:center;gap:clamp(30px,5vw,64px);min-height:calc(100svh - 70px)}.hero__content{justify-self:start;max-width:740px}.hero__meta{display:flex;flex-wrap:wrap;gap:10px 20px;margin-bottom:18px;color:var(--color-muted);font-size:12px;letter-spacing:.11em;text-transform:uppercase}.hero h1,.section-title h2,.contact h2{margin:0;font-family:var(--font-display);font-weight:400;letter-spacing:0;line-height:.98}.hero h1{max-width:760px;font-size:clamp(38px,4.45vw,64px);line-height:1}.hero__content>p{max-width:610px;margin:20px 0 0;color:var(--color-muted);font-size:clamp(16px,1.35vw,19px);line-height:1.5}.hero__actions{display:flex;align-items:center;flex-wrap:wrap;gap:14px;margin-top:26px}.hero__actions>.button{min-height:44px;padding:0 20px}.hero__links{display:inline-flex;align-items:center;flex-wrap:wrap;gap:8px}.hero__links a{display:inline-flex;align-items:center;justify-content:center;min-height:36px;padding:0 12px;color:var(--color-muted);background:#fffaf157;border:1px solid rgba(32,29,24,.09);border-radius:var(--radius-sm);font-size:12px;font-weight:600;line-height:1;transition:background var(--transition),border-color var(--transition),color var(--transition),transform var(--transition)}.hero__links a:hover,.hero__links a:focus-visible{color:var(--color-navy);background:#fffaf19e;border-color:#14324a2e;transform:translateY(-1px)}.hero__visual{display:grid;justify-self:end;width:min(100%,390px);gap:14px;align-self:center}.hero__caption{display:grid;grid-template-columns:118px 1fr;gap:18px;padding-top:14px;border-top:1px solid var(--color-line)}.hero__caption span{color:var(--color-teal);font-size:12px;letter-spacing:.11em;text-transform:uppercase}.hero__caption p{max-width:320px;margin:0;color:var(--color-muted);font-size:14px}.hero-card{position:relative;display:grid;justify-items:center;align-content:start;gap:12px;width:100%;padding:clamp(20px,2.4vw,26px);overflow:hidden;text-align:center;background:#fffaf1ad;border:1px solid rgba(32,29,24,.1);border-radius:var(--radius-md);box-shadow:0 14px 38px #2d241914}.hero-card__portrait{display:block;width:124px;height:124px;margin:2px auto 6px;object-fit:cover;object-position:center 34%;border:4px solid rgba(255,250,241,.86);border-radius:50%;box-shadow:0 16px 42px #201d1824}.hero-card__body{position:relative;display:grid;justify-items:center;gap:8px}.hero-card h2{margin:0;font-family:var(--font-display);font-size:clamp(30px,3.3vw,42px);font-weight:400;line-height:1}.hero-card__body p{margin:0;color:var(--color-muted);font-size:16px}.hero-card__body span,.hero-card__location{display:block;margin:0;color:var(--color-teal);font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.hero-card__location{margin-top:0;color:var(--color-muted);font-weight:500;letter-spacing:0;text-transform:none}.visual-panel{position:relative;min-height:clamp(390px,55vh,520px);padding:16px;overflow:hidden;background:linear-gradient(145deg,#fffaf1b8,#e5daca61),var(--color-stone);border:1px solid rgba(32,29,24,.14);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft)}.visual-panel:before{position:absolute;inset:12%;content:"";background:radial-gradient(circle,rgba(47,111,104,.16),transparent 62%)}.visual-panel--compact{min-height:360px}.visual-panel__header,.visual-panel__footer{position:relative;z-index:1;display:flex;justify-content:space-between;color:var(--color-muted);font-size:11px;letter-spacing:.09em;text-transform:uppercase}.visual-panel__header span{width:7px;height:7px;background:#201d1842;border-radius:999px}.system-panel{position:relative;z-index:1;display:grid;grid-template-rows:auto 1fr;gap:16px;height:calc(100% - 50px);min-height:330px;padding:22px 0 8px}.system-panel__code,.system-panel article{background:#fffaf1bd;border:1px solid rgba(20,50,74,.12);border-radius:var(--radius-md)}.system-panel__code{padding:20px;box-shadow:0 18px 45px #201d1814}.system-panel__code span,.system-panel article span{color:var(--color-teal);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.system-panel__code strong{display:block;margin-top:10px;color:var(--color-navy);font-family:var(--font-display);font-size:clamp(26px,3vw,38px);font-weight:400;line-height:1.05}.system-panel__code code{display:block;margin-top:16px;color:var(--color-muted);font-family:SFMono-Regular,Consolas,monospace;font-size:13px}.system-panel__grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.system-panel article{padding:16px}.system-panel article strong{display:block;margin-top:8px;color:var(--color-ink);font-size:14px;line-height:1.35}.system-panel__wide{grid-column:1 / -1}.section-reveal{animation:reveal .7s ease both}@keyframes reveal{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.about,.projects,.experience,.education,.skills,.contact{scroll-margin-top:var(--header-offset);padding:128px 0}.hero{scroll-margin-top:var(--header-offset)}.about{background:#fffaf157}.section-title{max-width:690px}.section-title--center{margin:0 auto;text-align:center}.eyebrow{display:inline-block;margin-bottom:18px;color:var(--color-teal);font-size:12px;font-weight:700;letter-spacing:.13em;text-transform:uppercase}.section-title h2,.contact h2{font-size:clamp(40px,4.8vw,74px)}.section-title p{max-width:620px;margin:24px 0 0;color:var(--color-muted);font-size:18px}.about__grid{display:grid;grid-template-columns:.9fr .72fr;gap:56px 84px;align-items:start}.about__copy{align-self:end;max-width:520px;padding-top:64px}.about__copy p{margin:0;color:var(--color-muted);font-size:20px;line-height:1.7}.about__copy p+p{margin-top:26px}.strength-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:30px}.strength-list span{display:inline-flex;min-height:24px;align-items:center;padding:0 8px;color:var(--color-muted);background:#fffaf161;border:1px solid rgba(32,29,24,.08);border-radius:var(--radius-sm);font-size:11px}.technical-focus{grid-column:1 / -1;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;padding-top:14px}.technical-focus article{min-height:136px;padding:22px;background:#fffaf175;border:1px solid var(--color-line);border-radius:var(--radius-sm);box-shadow:none}.technical-focus span{color:var(--color-teal);font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.technical-focus p{margin:16px 0 0;color:var(--color-muted);font-size:15px;line-height:1.55}.projects{background:linear-gradient(180deg,#24211df7,#292621fa),var(--color-charcoal);color:var(--color-paper)}.projects .section-title p,.projects .eyebrow{color:#fffaf1a8}.projects__header{display:flex;justify-content:flex-end;margin-bottom:58px}.projects__grid{display:grid;grid-template-columns:1fr;gap:28px;margin-top:28px}.card{background:#fffaf19e;border:1px solid var(--color-line);border-radius:var(--radius-md);box-shadow:var(--shadow-card)}.project-card{display:grid;grid-template-columns:minmax(0,1fr) minmax(360px,.9fr);min-height:560px;overflow:hidden;color:var(--color-ink);background:var(--color-paper)}.project-card--featured{grid-template-columns:minmax(0,1.12fr) minmax(390px,.88fr);min-height:660px}.project-card__visual{position:relative;min-height:520px;padding:26px;overflow:hidden;background:#f4efe6}.project-preview{display:grid;gap:20px;height:100%}.browser-frame{overflow:hidden;display:grid;grid-template-rows:28px 1fr;min-height:0;background:var(--color-paper);border:1px solid rgba(32,29,24,.09);border-radius:var(--radius-sm);box-shadow:0 14px 36px #201d181a}.browser-frame__bar{display:flex;gap:6px;align-items:center;height:28px;padding:0 12px;background:#fffaf1eb;border-bottom:1px solid rgba(20,50,74,.1)}.browser-frame__bar span{width:6px;height:6px;background:#14324a38;border-radius:999px}.browser-frame img{display:block;width:100%;height:100%;min-height:0;object-fit:contain;object-position:top center;padding:10px;background:#f8f5ee}.browser-frame--primary,.browser-frame--secondary{min-height:0}.project-card__content{display:flex;flex-direction:column;justify-content:center;padding:clamp(32px,4.5vw,58px)}.project-card__content h3,.timeline h3,.skills-group h3{margin:0;font-family:var(--font-display);font-size:clamp(30px,3vw,48px);font-weight:400;line-height:1.04}.project-card__content p{margin:24px 0 0;color:var(--color-muted);font-size:17px}.project-card dl{margin:30px 0 0}.project-card dt{color:var(--color-soft);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.project-card dd{margin:8px 0 0;color:var(--color-ink)}.tag-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:24px}.tag{display:inline-flex;align-items:center;min-height:24px;padding:0 8px;color:var(--color-muted);background:#fffaf16b;border:1px solid rgba(32,29,24,.08);border-radius:var(--radius-sm);font-size:11px}.project-card .button--text{align-self:flex-start;margin-top:34px}.experience{background:linear-gradient(180deg,#f5f0e738,#ebe3d6a3)}.experience__grid,.education__grid{display:grid;grid-template-columns:.82fr 1fr;gap:82px;align-items:start}.timeline{border-top:1px solid var(--color-line)}.timeline__item{display:grid;grid-template-columns:140px 1fr;gap:34px;padding:32px 0;border-bottom:1px solid var(--color-line)}.timeline time{color:var(--color-teal);font-size:12px;letter-spacing:.1em;text-transform:uppercase}.timeline h3{font-size:30px}.timeline span{display:block;margin-top:8px;color:var(--color-muted)}.timeline p{max-width:620px;margin:18px 0 0;color:var(--color-muted)}.education{background:#fffaf157}.education-list{display:grid;gap:18px}.education-card{padding:30px;background:#fffaf194;border:1px solid var(--color-line);border-radius:var(--radius-md);box-shadow:var(--shadow-card)}.education-card time{color:var(--color-teal);font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.education-card h3{margin:16px 0 0;font-family:var(--font-display);font-size:32px;font-weight:400;line-height:1.05}.education-card span{display:block;margin-top:8px;color:var(--color-muted)}.education-card p{margin:18px 0 0;color:var(--color-muted)}.education-card ul{display:grid;gap:8px;margin:22px 0 0;padding-left:18px;color:var(--color-ink)}.skills__grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:22px;margin-top:52px}.skills-group{padding:32px;background:#fffaf18a}.skills-group h3{font-size:28px}.skills-group p{min-height:78px;margin:18px 0 0;color:var(--color-muted)}.contact{padding-bottom:104px}.contact__inner{max-width:940px;padding:clamp(34px,6vw,72px);color:var(--color-paper);background:radial-gradient(circle at 20% 0%,rgba(215,197,162,.18),transparent 30rem),var(--color-charcoal);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft)}.contact h2{max-width:660px}.contact p{max-width:560px;margin:24px 0 0;color:#fffaf1ad;font-size:17px}.contact-links{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;max-width:620px;margin-top:42px}.contact-links a{display:inline-flex;align-items:center;justify-content:center;min-height:52px;padding:0 16px;color:#fffaf1d6;background:#fffaf10f;border:1px solid rgba(215,197,162,.24);border-radius:var(--radius-sm);font-size:13px;font-weight:600;line-height:1;transition:background var(--transition),color var(--transition),border-color var(--transition),transform var(--transition)}.contact-links__primary{color:var(--color-ink)!important;background:var(--color-champagne)!important;border-color:var(--color-champagne)!important}.contact-links a:hover,.contact-links a:focus-visible{color:var(--color-champagne);background:#fffaf11a;border-color:var(--color-champagne);transform:translateY(-1px)}.site-footer{display:flex;justify-content:space-between;align-items:center;gap:24px;width:min(calc(100% - 40px),var(--container));margin:0 auto;padding:38px 0 54px;color:var(--color-muted);border-top:1px solid var(--color-line)}.site-footer p{margin:0;color:var(--color-ink);font-family:var(--font-display);font-size:24px}.site-footer span{font-size:13px}.footer-links{display:flex;gap:20px;font-size:13px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;animation-duration:1ms!important;transition-duration:1ms!important}}@media(max-width:980px){.site-header{gap:12px;padding:12px 14px}.site-nav{gap:10px;font-size:11px}.hero{padding-top:0}.hero__inner,.about__grid,.experience__grid,.education__grid{grid-template-columns:1fr}.hero__visual{justify-self:center;max-width:620px}.hero-card{max-width:380px}.about__copy{padding-top:0}.technical-focus{grid-template-columns:repeat(2,minmax(0,1fr))}.project-card,.project-card--featured{grid-template-columns:1fr}.project-card__content{order:1}.project-card__visual{order:2}.projects__grid,.skills__grid{grid-template-columns:1fr}}@media(max-width:680px){.container,.site-header,.site-footer{width:min(calc(100% - 28px),var(--container))}.site-header{margin-top:0;padding:9px 10px;background:#f5f0e7f0;border-color:#201d1824;border-radius:10px;box-shadow:0 12px 30px #2e271d24;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.brand-mark small{display:none}.brand-mark{align-items:center}.site-nav{justify-content:flex-end}.site-header>.button{display:none}.menu-toggle{position:relative;align-items:center;justify-content:center;flex-direction:column;flex:0 0 auto;gap:5px;width:40px;height:40px;padding:0;background:#fffaf1d6;border:1px solid rgba(32,29,24,.18);border-radius:9px;cursor:pointer;box-shadow:0 8px 18px #2e271d14;transition:background var(--transition),border-color var(--transition),box-shadow var(--transition),transform var(--transition)}.menu-toggle:hover,.menu-toggle:focus-visible{background:var(--color-paper);border-color:#201d183d}.menu-toggle:active{transform:scale(.97)}.menu-toggle span{display:block;width:16px;height:1.5px;background:var(--color-ink);transform-origin:center;transition:opacity var(--transition),transform var(--transition),background var(--transition)}.menu-toggle[aria-expanded=true] span:first-child{transform:translateY(6px) rotate(45deg)}.menu-toggle[aria-expanded=true] span:nth-child(2){opacity:0;transform:scaleX(.35)}.menu-toggle[aria-expanded=true] span:last-child{transform:translateY(-6px) rotate(-45deg)}.hero{min-height:100svh;padding:0 0 92px}.hero__inner{gap:46px;min-height:auto;padding-top:42px}.hero h1{font-size:clamp(32px,9.3vw,44px);line-height:1.06}.hero__meta{margin-bottom:24px}.hero__content>p{margin-top:24px;line-height:1.58}.hero__actions{gap:14px;margin-top:34px}.hero__actions>.button{min-height:48px}.hero__links{gap:10px}.hero__links a{min-height:38px}.hero__visual{margin-top:10px}.hero-card{gap:16px;padding:28px 24px}.hero__caption,.timeline__item{grid-template-columns:1fr;gap:14px}.about__grid{gap:28px}.about__copy p+p{margin-top:24px}.visual-panel{min-height:390px}.hero-card__portrait{width:96px;height:96px;margin-bottom:8px}.hero-card__body{gap:10px}.hero-card__location{margin-top:2px}.system-panel{min-height:300px;padding-top:18px}.system-panel__grid{grid-template-columns:1fr}.system-panel__wide{grid-column:auto}.technical-focus{grid-template-columns:1fr}html{--header-offset: 70px}.about,.projects,.experience,.education,.skills,.contact{padding:104px 0}.project-card__content,.project-card__visual,.skills-group{padding:24px}.project-card,.project-card--featured{min-height:0}.project-card__visual{min-height:360px;margin-top:20px}.project-preview,.project-preview--forecast,.project-preview--commerce,.project-preview--queue{gap:16px}.section-title h2,.contact h2{font-size:clamp(38px,12vw,54px)}.contact__inner{padding:28px}.contact-links{grid-template-columns:1fr}.site-footer{align-items:flex-start;flex-direction:column}}@media(max-width:520px){.site-nav{display:none}.menu-toggle{display:inline-flex}.mobile-nav{position:absolute;top:calc(100% + 6px);right:0;left:0;display:flex;flex-direction:column;gap:2px;padding:8px;color:var(--color-ink);font-size:13px;white-space:nowrap;pointer-events:none;visibility:hidden;background:#f5f0e7fa;border:1px solid rgba(32,29,24,.14);border-radius:10px;box-shadow:0 18px 44px #2e271d2e;opacity:0;transform:translateY(-6px) scale(.985);transform-origin:top center;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);transition:opacity var(--transition),transform var(--transition),visibility var(--transition)}.mobile-nav.is-open{pointer-events:auto;visibility:visible;opacity:1;transform:translateY(0) scale(1)}.mobile-nav a{position:relative;min-height:46px;padding:12px;border-radius:var(--radius-sm);color:var(--color-ink);white-space:nowrap;transition:background var(--transition),color var(--transition)}.mobile-nav a+a{border-top:1px solid rgba(32,29,24,.1)}.mobile-nav a:hover,.mobile-nav a:focus-visible{background:#fffaf1b8}.mobile-nav a.is-active{color:var(--color-navy)}.mobile-nav a.is-active:after{position:absolute;top:9px;bottom:9px;left:0;width:1px;content:"";background:var(--color-teal)}}
