@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}*{box-sizing:border-box}body{margin:0;font-family:var(--font-body);color:var(--text);background:radial-gradient(circle at 15% 20%,#fff7ed 0%,var(--bg) 45%,#e9f1f7 100%);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(#c7b8a6 .5px,transparent .5px);background-size:28px 28px;opacity:.25;mix-blend-mode:multiply}.page{max-width:var(--max-width);margin:0 auto;padding:64px 24px 96px;display:flex;flex-direction:column;gap:32px}.hero{position:relative;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:24px;padding:0;border-radius:calc(var(--radius) + 6px);overflow:hidden;background:linear-gradient(135deg,#fff8ef,#f3e7d7 48%,#e9e1d6);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:clamp(200px,30vw,320px);align-self:stretch;overflow:hidden}.hero-photo{width:100%;height:100%;object-fit:cover;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:linear-gradient(160deg,#fffdf9,#f5eee2);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}.experience-company{margin:0;font-family:var(--font-display);font-size:1.3rem}.experience-title{margin:6px 0 0;color:var(--accent);font-weight:600}.experience-dates{margin:0;color:var(--muted);font-size:.9rem}.experience-overview,.experience-intro,.experience-impact{margin:12px 0 0;color:var(--muted);line-height:1.6}.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}.project-block{padding:16px;border-radius:12px;background:#fffdf8;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:#fffdf8;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:#fffdf8;border:1px solid var(--stroke)}.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:18px}.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,.hero{grid-template-columns:1fr}.hero-accent,.hero-photo-frame{justify-content:flex-start}.hero-photo-frame{width:100%;height:165px}.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:135px}}@media(prefers-reduced-motion:reduce){.hero,.section,.card{animation:none;opacity:1;transform:none}}@media print{@page{margin:9mm}*{-webkit-print-color-adjust:exact;print-color-adjust:exact}body{background:#fff;font-size:11px}#app:before{display:none}.page{padding:0;max-width:none;gap:4px}.hero,.section,.card{animation:none;opacity:1;transform:none;box-shadow:none;border:none}.hero{display:flex;align-items:stretch;justify-content:space-between;border-radius:18px;gap:6px}.hero-copy{flex:1;padding:9px;gap:5px}.hero-kicker{font-size:1rem}.hero-name{font-size:2.2rem}.hero-title{font-size:1.1rem}.hero-tagline{font-size:1.02rem}.hero-email{font-size:1rem}.hero-photo-frame{flex:0 0 24%;width:auto;height:auto;justify-self:stretch;margin-left:auto}.layout{gap:4px}.feature-row{grid-template-columns:1.9fr .85fr;gap:4px}.section{padding:9px}.section-title{font-size:1.25rem}.section-header{margin-bottom:7px}.section-body{gap:7px}#about .stack{gap:6px}#about .body-text{line-height:1.3}.experience-list{gap:9px}#experience-previous .experience-list{gap:18px}.experience-item{padding:9px;border:none}.codex-card,.education-item{border:none}.codex-card{padding:8px}.codex-card .bullet-list{gap:3px}.codex-intro{font-size:.8rem;margin-bottom:6px}.experience-company{font-size:1.1rem}.experience-title{margin-top:4px;font-size:.92rem}.experience-dates{font-size:.8rem}.experience-overview,.experience-intro,.experience-impact{margin-top:8px;line-height:1.45}.experience-achievements{margin-top:12px}.detail-list,.bullet-list,.skills-list{margin-top:5px;gap:4px}.detail-list li,.bullet-list li,.skills-list li{padding-left:12px;line-height:1.35}#experience-previous,#education{break-before:page;page-break-before:always}.feature-sidebar .section{height:auto}}
