:root{--green: #2f6df6;--green-dark: #1f4eb4;--green-light: #ebf2ff;--black: #0f0f0f;--gray-900: #1a1a1a;--gray-700: #3d3d3d;--gray-500: #6b6b6b;--gray-300: #c4c4c4;--gray-100: #f5f5f3;--white: #ffffff;--red-accent: #ff7a59;--serif: "DM Serif Display", Georgia, serif;--sans: "DM Sans", system-ui, sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:var(--sans);background:var(--white);color:var(--gray-900);font-size:16px;line-height:1.7;min-width:320px;min-height:100vh}a{color:inherit;text-decoration:none}p,h1,h2,h3{margin:0}#root{min-height:100vh}nav{position:fixed;top:0;left:0;right:0;z-index:100;background:#ffffffeb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid #e8e8e8;padding:0 2rem;height:56px;display:flex;align-items:center;justify-content:space-between}.nav-logo{font-family:var(--serif);font-size:18px;color:var(--black);text-decoration:none}.nav-links{display:flex;gap:2rem;list-style:none}.nav-links a{font-size:13px;font-weight:500;color:var(--gray-500);text-decoration:none;letter-spacing:.04em;text-transform:uppercase;transition:color .2s}.nav-links a:hover{color:var(--green)}.hero{padding:140px 2rem 80px;max-width:920px;margin:0 auto}.hero-tag{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--green-dark);background:var(--green-light);padding:6px 14px;border-radius:100px;margin-bottom:2rem}.hero-tag .dot{width:6px;height:6px;border-radius:50%;background:var(--green)}h1{font-family:var(--serif);font-size:clamp(40px,6vw,72px);line-height:1.08;color:var(--black);margin-bottom:1.5rem;font-weight:400}h1 em{font-style:italic;color:var(--green)}.hero-desc{font-size:18px;color:var(--gray-500);max-width:600px;line-height:1.7;margin-bottom:3rem}.hero-meta{display:flex;flex-wrap:wrap;gap:2.5rem;border-top:1px solid #e8e8e8;padding-top:2rem}.meta-label{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--gray-300);margin-bottom:4px}.meta-value{font-size:15px;font-weight:500;color:var(--gray-700)}.home-content{max-width:1040px;margin:0 auto;padding:0 2rem}.section{margin-bottom:5rem}.section-label{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--green);margin-bottom:1rem}h2.section-title{font-family:var(--serif);font-size:clamp(28px,4vw,40px);font-weight:400;line-height:1.2;color:var(--black);margin-bottom:1.5rem}p.body-text{font-size:17px;color:var(--gray-500);line-height:1.75;margin-bottom:1.25rem}.resume-card{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(260px,.9fr);gap:24px;padding:2rem;background:var(--gray-100);border:1px solid #e8e8e8;border-radius:12px}.resume-copy .section-title{max-width:14ch}.primary-cta{display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:0 1.2rem;border-radius:999px;background:var(--green);color:var(--white);font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;transition:transform .2s ease,opacity .2s ease}.primary-cta:hover{transform:translateY(-2px);opacity:.92}.resume-meta{display:grid;gap:12px}.mini-stat{background:var(--white);border:1px solid #e8e8e8;border-radius:12px;padding:1rem 1.1rem}.mini-stat-value{display:block;font-family:var(--serif);font-size:28px;line-height:1;color:var(--green-dark);margin-bottom:6px}.mini-stat-label{font-size:14px;color:var(--gray-500)}.project-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin:2rem 0}.project-card{display:flex;flex-direction:column;min-height:280px;padding:1.5rem;border-radius:12px;border:1px solid #e8e8e8;background:var(--gray-100)}.project-card.featured{background:var(--green-light);border-color:#d5e2ff}.project-card-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:2rem}.project-index,.project-status{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.project-index{color:var(--gray-300)}.project-status{color:var(--green-dark)}.project-status.muted{color:var(--gray-500)}.project-card h3{font-family:var(--serif);font-size:28px;font-weight:400;line-height:1.18;color:var(--black);margin-bottom:.9rem}.project-card p{font-size:15px;color:var(--gray-500);line-height:1.68;margin-bottom:1.5rem}.project-card strong{margin-top:auto;font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--green)}.contact-grid{display:grid;grid-template-columns:1.2fr .9fr;gap:20px;margin:2rem 0}.contact-section{margin-bottom:5rem}.contact-section .section-title{max-width:14ch}.contact-card-shell{margin-top:2rem;border-radius:0;padding:0}.contact-panel{padding:1.6rem;border-radius:12px;border:1px solid #e8e8e8;background:var(--gray-100)}.contact-panel.accent{background:linear-gradient(180deg,#e8f4ebfa,#f2f9f4fa);border-color:#cfe4d5;box-shadow:0 16px 34px #2f7a4714}.contact-panel.accent .contact-kicker{color:var(--green-dark)}.contact-kicker{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--green);margin-bottom:1rem}.contact-list,.availability-list{display:grid;gap:12px}.availability-intro{margin:0 0 1.15rem;font-size:15px;line-height:1.7;color:#233451}.availability-badge{display:inline-flex;align-items:center;min-height:30px;margin-bottom:.8rem;padding:0 .8rem;border-radius:999px;background:linear-gradient(180deg,#5aa870,#2f7a47);box-shadow:0 10px 20px #2f7a472e;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--white)}.availability-copy{color:#233451}.contact-item{padding:.95rem 1rem;border-radius:12px;background:var(--white)}.contact-item span{display:block;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--gray-300);margin-bottom:.35rem}.contact-item strong{font-size:15px;font-weight:500;color:var(--gray-700)}.contact-cta{display:inline-flex;align-items:center;justify-content:center;min-height:46px;margin-top:1.25rem;padding:0 1.2rem;border-radius:999px;background:var(--black);color:var(--white);font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;transition:transform .2s ease,opacity .2s ease}.contact-cta:hover{transform:translateY(-2px);opacity:.94}.availability-list{padding:0;gap:0}.availability-row{display:grid;gap:.35rem;padding:.95rem 0;border-top:1px solid rgba(44,72,122,.12)}.availability-row:first-child{border-top:1px solid rgba(44,72,122,.18)}.availability-row span{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#5670a3}.availability-row strong{font-size:15px;font-weight:600;line-height:1.55;color:#173056}.divider{height:1px;background:#e8e8e8;margin:4rem 0}footer{text-align:center;padding:4rem 2rem;border-top:1px solid #e8e8e8}footer p{font-size:14px;color:var(--gray-300)}.case-study-route{min-height:100vh;background:#0f0f0f}.case-study-loading{min-height:100vh;display:grid;place-items:center;background:#0f0f0f;color:#fffc;font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.case-study-topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:1rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.08);background:#111}.case-study-back,.case-study-slug{font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.case-study-slug{color:#ffffff8c}.case-study-topbar .case-study-back{color:var(--white)}.resume-topbar .case-study-back{color:var(--resume-accent-dark)}.case-study-frame{display:block;width:100%;height:calc(100vh - 57px);border:0;background:#fff}.resume-page{--resume-accent: #2f6df6;--resume-accent-dark: #1f4eb4;--resume-accent-light: #ebf2ff;--resume-band: #233f84;min-height:100vh;background:radial-gradient(circle at top left,rgba(47,109,246,.1),transparent 24%),linear-gradient(180deg,#fcfcfa,#fff)}.resume-topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:1rem 1.25rem;border-bottom:1px solid #e8e8e8;background:#ffffffeb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.resume-hero,.resume-content{width:min(1100px,calc(100% - 3rem));margin:0 auto}.resume-hero{padding:140px 2rem 72px;max-width:920px}.resume-role{font-size:18px;color:var(--gray-700);line-height:1.7;margin-bottom:1rem}.resume-page .hero-tag{color:var(--resume-accent-dark);background:var(--resume-accent-light)}.resume-page .hero-tag .dot{background:var(--resume-accent)}.resume-page h1 em{color:var(--resume-accent)}.resume-hero .primary-cta{margin-bottom:1.5rem}.resume-meta-strip{display:flex;flex-wrap:wrap;gap:2.5rem;border-top:1px solid #e8e8e8;padding-top:2rem}.resume-band{background:var(--resume-band);padding:56px 0;margin-bottom:5rem}.resume-band-inner{max-width:1100px;margin:0 auto;padding:0 60px;display:grid;grid-template-columns:340px minmax(0,1fr);gap:28px;align-items:start}.resume-band-text h2{font-family:var(--serif);font-size:36px;color:#fff;font-weight:400;line-height:1.2;margin:0 0 14px}.resume-band-text p{margin:0;color:#ffffffb3;font-size:15px;line-height:1.65}.resume-band-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(260px,.9fr);gap:16px}.resume-contact-card{display:grid;gap:12px;padding:1.25rem;border:1px solid rgba(255,255,255,.2);border-radius:12px;background:#fffffff2}.resume-contact-item{padding:.9rem 1rem;border-radius:12px;background:var(--gray-100)}.resume-contact-item span,.resume-role-meta{display:block;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--gray-300)}.resume-contact-item strong{display:block;margin-top:.35rem;font-size:15px;font-weight:500;color:var(--gray-700)}.resume-focus-card{padding:1.25rem;border-radius:12px;background:#ffffff1f;border:1px solid rgba(255,255,255,.18)}.resume-focus-card span{display:block;margin-bottom:.45rem;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#ffffffa6}.resume-focus-card p{margin:0;font-size:14px;line-height:1.65;color:var(--white)}.resume-highlight-grid,.resume-highlights-list,.resume-skills-groups{display:grid;gap:16px}.resume-highlight-grid{grid-template-columns:repeat(3,minmax(0,1fr));margin:1.5rem 0}.resume-metric-card,.resume-skill-group{border-radius:16px;border:1px solid #e8e8e8;background:var(--gray-100);box-shadow:0 10px 24px #0f0f0f06}.resume-metric-card{padding:1.5rem;background:linear-gradient(180deg,#ebf2ff,#ffffffe6),var(--gray-100)}.resume-metric{display:block;font-family:var(--serif);font-size:46px;line-height:1;color:var(--resume-accent);margin-bottom:.65rem}.resume-metric-card p,.resume-role-intro,.resume-role-points li,.resume-skill-group p,.resume-education-card p{font-size:15px;color:var(--gray-500);line-height:1.7}.resume-highlights-list{grid-template-columns:repeat(2,minmax(0,1fr));column-gap:30px;row-gap:0;margin-top:.5rem}.resume-bullet-card{padding:1rem 0 1rem 1.4rem;position:relative;border-bottom:1px solid #e8e8e8;font-size:15px;color:var(--gray-500);line-height:1.7}.resume-bullet-card:before{content:"";position:absolute;left:0;top:1.45rem;width:7px;height:7px;border-radius:50%;background:var(--resume-accent)}.resume-timeline{display:grid;margin-top:1.5rem}.resume-timeline-item{display:grid;grid-template-columns:minmax(220px,250px) minmax(0,1fr);gap:30px;padding:1.2rem 0;align-items:start}.resume-role-head{margin-bottom:.9rem}.resume-timeline-content{position:relative;padding-left:2rem}.resume-timeline-content:before{content:"";position:absolute;left:0;top:.1rem;bottom:-1.2rem;width:1px;background:#dfe6f2}.resume-timeline-item:last-child .resume-timeline-content:before{bottom:.45rem}.resume-timeline-content:after{content:"";position:absolute;left:-.4rem;top:.2rem;width:13px;height:13px;border-radius:50%;background:#fff;border:2px solid var(--resume-accent)}.resume-role-card h3,.resume-skill-group h3,.resume-education-content h3{font-family:var(--serif);font-size:28px;font-weight:400;line-height:1.2;color:var(--black);margin:0 0 .35rem}.resume-company{margin:0;font-size:16px;font-weight:600;color:var(--resume-accent-dark)}.resume-role-meta{padding-top:.15rem}.resume-role-period,.resume-role-location{margin:0}.resume-role-period{font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--gray-700)}.resume-role-location{margin-top:.35rem;font-size:12px;font-weight:500;color:var(--gray-500)}.resume-role-intro{margin-top:0;font-style:italic;margin-bottom:1rem}.resume-role-points,.availability-list{padding:0;list-style:none}.resume-role-points{display:grid;gap:10px}.resume-role-points li{padding-left:1.35rem;position:relative}.resume-role-points li:before{content:"";position:absolute;left:0;top:.72rem;width:8px;height:8px;border-radius:50%;background:var(--resume-accent)}.resume-lower-grid{display:grid;grid-template-columns:1fr;gap:24px}.resume-skills-panel{display:grid;gap:16px}.resume-skills-panel{padding:0;border-radius:0;background:transparent;border:0}.resume-skills-panel .section-title{margin-bottom:0}.resume-skill-row h3,.resume-education-content h3{font-size:22px}.resume-skill-table{margin-top:1.5rem;border-top:1px solid #e8e8e8}.resume-skill-table-head,.resume-skill-row{display:grid;grid-template-columns:minmax(180px,220px) minmax(0,1fr);gap:24px}.resume-skill-table-head{padding:.75rem 0;border-bottom:1px solid #e8e8e8}.resume-skill-table-head span{font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--gray-300)}.resume-skill-row{padding:1rem 0 1.1rem;border-bottom:1px solid #f0f0f0}.resume-skill-row:last-child{border-bottom:0}.resume-skill-row h3{margin:0;font-family:var(--sans);font-size:15px;font-weight:600;line-height:1.45;color:var(--black)}.resume-skill-row p{margin:0;font-size:15px;color:var(--gray-500);line-height:1.7}.resume-education-stack{display:grid;gap:0;margin-top:1.5rem}.resume-education-row{display:grid;grid-template-columns:28px minmax(0,1fr);gap:20px;padding:1.4rem 0;border-bottom:1px solid #e8e8e8}.resume-education-row:first-child{border-top:1px solid #e8e8e8}.resume-education-marker{width:14px;height:14px;margin-top:.45rem;border-radius:50%;background:var(--resume-accent-light);border:2px solid var(--resume-accent)}.resume-education-content h3{margin:0 0 .45rem}.resume-education-content p{margin:0;font-size:15px;color:var(--gray-500);line-height:1.7}@media(max-width:900px){.hero{padding-top:124px;padding-bottom:64px}.hero-meta,.resume-meta-strip{gap:1.5rem}.home-content{padding:0 1.5rem}.section,.contact-section{margin-bottom:4rem}.divider{margin:3.25rem 0}.resume-hero{padding:120px 1.5rem 60px}.resume-band{padding:44px 0;margin-bottom:4rem}.resume-card,.project-grid,.contact-grid,.resume-highlight-grid,.resume-highlights-list,.resume-lower-grid,.resume-band-inner,.resume-band-grid{grid-template-columns:1fr}.resume-timeline-item{grid-template-columns:1fr;gap:12px}.resume-skill-table-head,.resume-skill-row{grid-template-columns:1fr;gap:10px}.resume-skill-table-head{display:none}.resume-skill-row{padding:1rem 0}.resume-timeline-content{padding-left:1.4rem}.resume-role-meta{padding-top:0}.resume-band-inner{padding:0 32px}.resume-band-text h2{font-size:32px}.contact-section .section-title,.resume-copy .section-title{max-width:none}}@media(max-width:640px){nav{padding:0 1rem}.nav-links{display:none}.home-content,.hero{padding-left:1rem;padding-right:1rem}.hero{padding-top:108px;padding-bottom:52px}.hero-tag{margin-bottom:1.35rem}h1{font-size:clamp(34px,11vw,48px);line-height:1.06;margin-bottom:1rem}.hero-desc,.resume-role,p.body-text{font-size:16px;line-height:1.7}.hero-desc{margin-bottom:2rem}.hero-meta,.resume-meta-strip{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem 1.25rem;padding-top:1.5rem}.resume-card,.contact-panel,.project-card{padding:1.25rem}.project-card{min-height:0}.project-card-top{margin-bottom:1.25rem}.project-card h3{font-size:24px}.contact-card-shell{margin-top:1.5rem}.contact-grid{gap:16px;margin:1.5rem 0}.contact-cta,.resume-hero .primary-cta{width:100%}.contact-item strong,.resume-contact-item strong{line-height:1.5;overflow-wrap:anywhere}.case-study-topbar{padding:.85rem 1rem}.case-study-back,.case-study-slug{font-size:11px}.case-study-frame{height:calc(100svh - 53px)}.resume-topbar{padding:.85rem 1rem}.resume-hero,.resume-content{width:min(100% - 1.5rem,1100px)}.resume-band-inner{padding:0 24px}.resume-band-text h2{font-size:28px}.resume-band-text p,.resume-focus-card p,.availability-intro,.resume-skill-row p,.resume-education-content p,.resume-bullet-card,.resume-role-intro,.resume-role-points li{font-size:14px}.resume-contact-card,.resume-focus-card{padding:1rem}.resume-highlight-grid{gap:12px;margin:1.25rem 0}.resume-metric-card{padding:1.2rem}.resume-metric{font-size:38px}.resume-highlights-list{gap:0;margin-top:0}.resume-timeline{margin-top:1.25rem}.resume-timeline-item{gap:10px;padding:1rem 0}.resume-timeline-content{padding-left:1.1rem}.resume-timeline-content:after{left:-.32rem;width:11px;height:11px}.resume-role-card h3,.resume-education-content h3{font-size:24px}.resume-company{font-size:15px}.resume-skill-table{margin-top:1rem}.resume-skill-row{gap:6px}.resume-education-row{grid-template-columns:20px minmax(0,1fr);gap:14px;padding:1.15rem 0}footer{padding:3rem 1rem}}@media(max-width:480px){nav{height:52px}.nav-logo{font-size:17px}.hero{padding-top:96px;padding-bottom:44px}.hero-tag,.case-study-back,.case-study-slug,.section-label,.meta-label{letter-spacing:.06em}.hero-meta,.resume-meta-strip{grid-template-columns:1fr}.meta-value{font-size:14px}.section,.contact-section{margin-bottom:3.25rem}.divider{margin:2.75rem 0}.resume-topbar,.case-study-topbar{padding:.8rem .9rem}.case-study-slug{display:none}.resume-hero,.resume-content{width:min(100% - 1.25rem,1100px)}.resume-hero{padding:104px .5rem 52px}.resume-band{padding:36px 0;margin-bottom:3.25rem}.resume-band-inner{padding:0 16px}.resume-band-text h2{font-size:24px}.resume-contact-item,.contact-item{padding:.85rem .9rem}.availability-row{padding:.8rem 0}.resume-role-period,.resume-role-location,.availability-row span,.contact-item span,.resume-contact-item span{font-size:10px}.resume-skill-row h3{font-size:14px}}
