@import"https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,600;9..144,700&family=Manrope:wght@300;400;500;600;700&display=swap";:root{color-scheme:light;--bg: #f4efe6;--bg-strong: #e9dfcf;--surface: #ffffff;--surface-muted: #f7f2ea;--text: #1b1410;--muted: #5d5249;--accent: #c96b4b;--accent-strong: #2a6f6a;--stroke: #e5d7c8;--shadow: 0 24px 50px rgba(27, 20, 16, .14);--radius: 18px;--font-display: "Fraunces", "Times New Roman", serif;--font-body: "Manrope", "Helvetica Neue", sans-serif;--max-width: 1100px;--bg-gradient: radial-gradient(circle at 15% 20%, #fff7ed 0%, var(--bg) 45%, #e9f1f7 100%);--hero-gradient: linear-gradient(135deg, #fff8ef 0%, #f3e7d7 48%, #e9e1d6 100%);--card-gradient: linear-gradient(160deg, #fffdf9 0%, #f5eee2 100%);--dot-color: #c7b8a6;--dot-opacity: .25}:root[data-theme=dark]{color-scheme:dark;--bg: #14191f;--bg-strong: #202833;--surface: #1d252f;--surface-muted: #232c36;--text: #f0e8dc;--muted: #c1b7aa;--accent: #e58b6c;--accent-strong: #63b8b1;--stroke: #37404b;--shadow: 0 24px 50px rgba(0, 0, 0, .42);--bg-gradient: radial-gradient(circle at 15% 20%, #243042 0%, #14191f 45%, #11161d 100%);--hero-gradient: linear-gradient(135deg, #2f333d 0%, #272d37 48%, #222a34 100%);--card-gradient: linear-gradient(160deg, #2a313b 0%, #242b35 100%);--dot-color: #6d7a8d;--dot-opacity: .18}*{box-sizing:border-box}body{margin:0;font-family:var(--font-body);color:var(--text);background:var(--bg-gradient);min-height:100vh}#app{min-height:100vh;position:relative;overflow-x:hidden}#app:before{content:"";position:fixed;inset:0;pointer-events:none;background-image:radial-gradient(var(--dot-color) .5px,transparent .5px);background-size:28px 28px;opacity:var(--dot-opacity);mix-blend-mode:multiply}.page{max-width:var(--max-width);margin:0 auto;padding:64px 24px 96px;display:flex;flex-direction:column;gap:32px;position:relative}.hero{position:relative;display:flex;align-items:flex-start;gap:24px;padding:0;border-radius:calc(var(--radius) + 6px);overflow:hidden;background:var(--hero-gradient);box-shadow:var(--shadow);animation:rise .8s ease forwards;opacity:0;transform:translateY(16px);animation-delay:var(--delay, 0ms)}.hero-copy{display:flex;flex-direction:column;gap:12px;padding:32px}.hero-kicker{text-transform:uppercase;letter-spacing:.16em;font-size:1.4rem;color:var(--muted);margin:0}.hero-name{font-family:var(--font-display);font-size:clamp(2.6rem,4vw,3.8rem);margin:0;color:var(--text)}.hero-title{margin:0;font-size:1.1rem;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);font-weight:600}.hero-tagline{margin:0;max-width:520px;color:var(--muted);font-size:1.02rem}.hero-email{color:var(--accent-strong);text-decoration:none;font-weight:600;width:fit-content}.hero-email:hover{text-decoration:underline}.hero-contact{color:var(--muted);text-decoration:none;font-weight:500;margin:0;width:fit-content}.hero-contact:hover{color:var(--accent-strong)}.hero-accent{width:120px;display:flex;align-items:center;justify-content:center}.hero-accent-inner{width:92px;height:92px;border-radius:24px;background:linear-gradient(145deg,var(--accent) 0%,var(--accent-strong) 100%);transform:rotate(12deg);box-shadow:0 20px 40px #2a6f6a4d}.hero-photo-frame{width:var(--hero-photo-size, 220px);height:var(--hero-photo-size, 220px);flex:0 0 auto;aspect-ratio:1 / 1;max-width:none;margin-left:auto;align-self:flex-start;overflow:hidden}.hero-photo{width:100%;height:100%;object-fit:cover;object-position:center;display:block}.layout{display:flex;flex-direction:column;gap:28px}.feature-row{display:grid;grid-template-columns:minmax(0,2.2fr) minmax(0,1fr);gap:28px;align-items:stretch}.feature-primary,.feature-sidebar{display:flex;flex-direction:column;gap:28px}.feature-sidebar .section{height:100%;display:flex;flex-direction:column}.feature-sidebar .section-body{flex:1}.section{padding:28px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--stroke);box-shadow:0 16px 30px #2d221814;animation:rise .8s ease forwards;opacity:0;transform:translateY(16px);animation-delay:var(--delay, 0ms)}.section-header{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}.section-kicker{font-size:.72rem;text-transform:uppercase;letter-spacing:.2em;color:var(--accent-strong);margin:0}.section-title{font-family:var(--font-display);font-size:1.6rem;margin:0}.section-subtitle{margin:0;color:var(--muted)}.section-body{display:flex;flex-direction:column;gap:16px}.card{padding:22px;border-radius:var(--radius);background:var(--card-gradient);border:1px solid var(--stroke);box-shadow:0 18px 30px #2d22181a;animation:rise .8s ease forwards;opacity:0;transform:translateY(16px);animation-delay:var(--delay, 0ms)}.card-kicker{font-size:.7rem;text-transform:uppercase;letter-spacing:.16em;margin:0 0 10px;color:var(--muted)}.card-title{font-family:var(--font-display);margin:0 0 6px}.card-subtitle{margin:0 0 14px;color:var(--muted)}.card-link{color:var(--accent-strong);font-weight:600;text-decoration:none}.card-link:hover{text-decoration:underline}.body-text{margin:0;color:var(--muted);line-height:1.6}.stack{display:flex;flex-direction:column;gap:12px}.experience-list{display:flex;flex-direction:column;gap:28px}.experience-item{padding:24px;border-radius:16px;background:var(--surface-muted);border:1px solid var(--stroke)}.experience-header{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;align-items:baseline}.experience-meta{display:flex;align-items:baseline;gap:10px;min-width:0;flex-wrap:wrap}.experience-company{margin:0;font-family:var(--font-display);font-size:1.3rem}.experience-title{margin:0;color:var(--accent);font-weight:600}.experience-dates{margin:0 0 0 auto;color:var(--muted);font-size:.9rem;white-space:nowrap}.experience-overview,.experience-intro,.experience-impact{margin:12px 0 0;color:var(--muted);line-height:1.6}.experience-sections{margin-top:16px;display:grid;gap:14px}.experience-subheading{margin:0;font-size:.92rem;text-transform:uppercase;letter-spacing:.08em;color:var(--accent-strong)}.experience-sections .bullet-list{margin-top:8px}.experience-achievements{margin-top:16px}.detail-list,.bullet-list,.skills-list{list-style:none;padding:0;margin:12px 0 0;display:grid;gap:10px}.detail-list li,.bullet-list li,.skills-list li{position:relative;padding-left:16px;color:var(--text);line-height:1.5}.detail-list li:before,.bullet-list li:before,.skills-list li:before{content:"-";position:absolute;left:0;color:var(--accent)}.detail-label{font-weight:600;color:var(--text)}.detail-text{color:var(--muted)}.experience-projects{margin-top:18px;display:grid;gap:16px}#experience-previous .section-body{gap:12px}#experience-previous .experience-list{gap:14px}#experience-previous .experience-item{padding:16px;border-radius:12px}#experience-previous .experience-company{font-size:1.08rem}#experience-previous .experience-title{margin-top:0;font-size:.92rem}#experience-previous .experience-dates{font-size:.82rem}#experience-previous .experience-overview{margin-top:8px;line-height:1.45}#experience-previous .bullet-list{margin-top:8px;gap:6px}#experience-previous .bullet-list li{padding-left:13px;line-height:1.35}.project-block{padding:16px;border-radius:12px;background:var(--surface);border:1px solid var(--stroke)}.project-header{display:flex;flex-direction:column;gap:6px}.project-name{margin:0;font-size:1.05rem}.project-stack{margin:0;color:var(--muted);font-size:.9rem}.project-description{margin:10px 0 0;color:var(--muted);line-height:1.6}.skills-grid,.codex-grid{display:grid;gap:18px}.codex-card{padding:16px;border-radius:12px;background:var(--surface);border:1px solid var(--stroke)}.codex-title{margin:0 0 10px;font-size:1rem;color:var(--accent-strong);text-transform:uppercase;letter-spacing:.08em}.codex-intro{margin:0 0 8px;color:var(--muted);font-size:.9rem;line-height:1.3}.skills-group{padding:14px 16px;border-radius:12px;background:var(--surface);border:1px solid var(--stroke)}.theme-toggle{position:absolute;top:max(12px,env(safe-area-inset-top));right:max(12px,env(safe-area-inset-right));z-index:8;display:flex;align-items:center;justify-content:flex-end;gap:2px;padding:0;border:none;background:transparent;box-shadow:none;opacity:.72;transition:opacity .2s ease}.theme-toggle:hover{opacity:1}.theme-toggle-label{display:none}.theme-toggle-button{display:inline-flex;align-items:center;justify-content:center;gap:0;width:28px;height:28px;border:1px solid transparent;background:transparent;color:var(--muted);padding:0;border-radius:999px;font-family:var(--font-body);font-size:.72rem;font-weight:600;cursor:pointer;opacity:.9}.theme-icon{font-size:.9rem;line-height:1}.theme-text{display:none}.theme-toggle-button:hover{color:var(--text);border-color:transparent;background:color-mix(in srgb,var(--surface) 24%,transparent);opacity:1}.theme-toggle-button.is-active{background:color-mix(in srgb,var(--accent) 22%,transparent);border-color:transparent;color:var(--text);opacity:1}.skills-title{margin:0 0 10px;font-size:1rem;color:var(--accent-strong);text-transform:uppercase;letter-spacing:.08em}.education-list{display:flex;flex-direction:column;gap:8px}.education-line{margin:0;color:var(--muted);line-height:1.5}.education-item{padding:16px;border-radius:12px;background:var(--surface-muted);border:1px solid var(--stroke)}.education-header{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}.education-school{margin:0;font-family:var(--font-display);font-size:1.2rem}.education-dates{margin:0;color:var(--muted)}.education-qualification{margin:8px 0 0;color:var(--accent);font-weight:600}.education-summary{margin:8px 0 0;color:var(--muted);line-height:1.6}.contact{display:flex;flex-direction:column;gap:14px}.contact-block{display:flex;flex-direction:column;gap:6px}.contact-line{margin:0;color:var(--text)}.contact-label{margin:0;text-transform:uppercase;letter-spacing:.1em;font-size:.7rem;color:var(--muted)}.contact-link{color:var(--accent-strong);text-decoration:none;font-weight:600}.contact-link:hover{text-decoration:underline}.target{border-left:4px solid var(--accent)}@keyframes rise{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@media(max-width:980px){.feature-row{grid-template-columns:1fr}.hero{flex-direction:column}.hero-accent,.hero-photo-frame{justify-content:flex-start}.hero-photo-frame{width:100%;max-width:none;margin-left:0;height:auto;aspect-ratio:1 / 1}.feature-sidebar .section{height:auto}}@media(max-width:640px){.page{padding:48px 18px 72px}.section,.card,.hero-copy{padding:22px}.hero-accent-inner{width:72px;height:72px}.hero-photo-frame{height:auto;aspect-ratio:1 / 1}}@media(prefers-reduced-motion:reduce){.hero,.section,.card{animation:none;opacity:1;transform:none}}@media print{@page{margin:5mm}*{-webkit-print-color-adjust:exact;print-color-adjust:exact}body{background:#fff;font-size:10px}#app:before{display:none}.theme-toggle{display:none!important}.page{padding:0;max-width:none;gap:2px}.hero,.section,.card{animation:none;opacity:1;transform:none;box-shadow:none;border:none}.hero{display:flex;flex-direction:row;align-items:stretch;justify-content:space-between;border-radius:18px;gap:4px}.hero-copy{flex:1;padding:7px;gap:4px}.hero-kicker{font-size:.82rem}.hero-name{font-size:1.85rem}.hero-title{font-size:.9rem}.hero-tagline{font-size:.84rem}.hero-email{font-size:.83rem}.hero-photo-frame{display:block;flex:0 0 24%;width:auto;height:auto;aspect-ratio:auto;justify-self:stretch;margin-left:auto}.layout{gap:2px}.feature-row{grid-template-columns:1.9fr .85fr;gap:3px}.section{padding:5px}.section-title{font-size:1.05rem}.section-header{margin-bottom:3px}.section-body{gap:2px}#about .stack{gap:6px}#about .body-text{line-height:1.3}.experience-list{gap:3px}.experience-item{padding:6px;border:none}.codex-card,.education-item{border:none}.education-list{gap:3px}.education-line{line-height:1.25}.codex-card{padding:8px}.codex-card .bullet-list{gap:3px}.codex-intro{font-size:.8rem;margin-bottom:6px}.experience-company{font-size:.95rem}.experience-title{margin-top:0;font-size:.8rem}.experience-dates{font-size:.72rem}.experience-overview,.experience-intro,.experience-impact{margin-top:6px;line-height:1.3}.experience-achievements{margin-top:9px}.experience-sections{margin-top:8px;gap:6px}.experience-subheading{font-size:.68rem}.detail-list,.bullet-list,.skills-list{margin-top:4px;gap:2px}.detail-list li,.bullet-list li,.skills-list li{padding-left:10px;line-height:1.2}.feature-sidebar .section{height:auto}#references{display:none}#experience-previous.section{padding:5px}#experience-previous .section-header{display:none}#experience-previous .section-body{gap:2px}#experience-previous .experience-list{gap:4px}#experience-previous .experience-item{padding:4px}#experience-previous .experience-company{font-size:.82rem}#experience-previous .experience-title{margin-top:0;font-size:.7rem}#experience-previous .experience-dates{font-size:.64rem}#experience-previous .experience-overview{margin-top:3px;line-height:1.2}#experience-previous .bullet-list{margin-top:3px;gap:1px}#experience-previous .bullet-list li{padding-left:8px;line-height:1.15}}
