:root{font-family:Outfit,system-ui,sans-serif;line-height:1.6;font-weight:400;color:#1b1b1b;background-color:#f6f1e9;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html{scroll-behavior:smooth;scroll-padding-top:110px}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:var(--page-bg)}a{color:inherit}img{max-width:100%;display:block}:root{color-scheme:light;--ink-900: #1b1b1b;--ink-700: #3a3a3a;--ink-500: #6b6b6b;--cream-50: #f6f1e9;--cream-100: #f2e9dd;--surface-0: #ffffff;--surface-50: #fbfaf7;--sage-500: #8aa28f;--sage-600: #6e8b77;--coral-500: #e07a5f;--sun-500: #f2c14e;--shadow-soft: rgba(32, 30, 27, .12);--shadow-strong: rgba(32, 30, 27, .2);--page-bg: #f6f1e9;--panel-bg: rgba(255, 255, 255, .92);--panel-border: rgba(32, 30, 27, .08);--panel-shadow: 0 24px 50px rgba(32, 30, 27, .12);--panel-shadow-strong: 0 32px 60px rgba(32, 30, 27, .18);--card-image-bg: #f5efe6;--button-bg: rgba(255, 255, 255, .7);--button-border: rgba(32, 30, 27, .12);--hero-panel: rgba(255, 255, 255, .78)}[data-theme=dark]{color-scheme:dark;--ink-900: #f2efe9;--ink-700: #d7dde7;--ink-500: #b6c0cf;--cream-50: #0f1011;--cream-100: #15171a;--surface-0: #141516;--surface-50: #191b1e;--sage-500: #84a38a;--sage-600: #6e8b77;--coral-500: #e18a73;--sun-500: #f3c767;--shadow-soft: rgba(0, 0, 0, .35);--shadow-strong: rgba(0, 0, 0, .45);--page-bg: #0f1011;--panel-bg: rgba(24, 25, 28, .92);--panel-border: rgba(255, 255, 255, .08);--panel-shadow: 0 24px 50px rgba(0, 0, 0, .35);--panel-shadow-strong: 0 32px 60px rgba(0, 0, 0, .45);--card-image-bg: #1b1d21;--button-bg: rgba(22, 23, 26, .9);--button-border: rgba(255, 255, 255, .12);--hero-panel: rgba(18, 19, 22, .85)}#root{max-width:none;margin:0;padding:0;text-align:left}.page{color:var(--ink-900);position:relative;overflow-x:clip;background:var(--page-bg)}.page:before,.page:after{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none}.page:before{background:radial-gradient(circle at 15% 10%,rgba(224,122,95,.18),transparent 45%),radial-gradient(circle at 85% 20%,rgba(138,162,143,.2),transparent 50%),radial-gradient(circle at 70% 85%,rgba(242,193,78,.18),transparent 55%)}.page:after{background-image:linear-gradient(120deg,#ffffff40,#fff0 60%);mix-blend-mode:multiply}.navbar{position:fixed;top:1.25rem;left:0;right:0;z-index:10;padding:0 6vw}.navbar-inner{display:flex;align-items:center;justify-content:space-between;padding:.7rem 1.4rem;border-radius:999px;background:var(--hero-panel);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid var(--panel-border);box-shadow:0 18px 40px var(--shadow-soft)}.brand{font-weight:700;text-decoration:none;color:var(--ink-900);transition:color .15s ease,transform .15s ease;padding:.35rem .75rem;border-radius:999px;font-family:Fraunces,serif;letter-spacing:.02em}.brand-group{display:inline-flex;align-items:center;gap:.2rem}.nav-icon-link{width:38px;height:38px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:var(--button-bg);border:1px solid var(--button-border);color:var(--ink-900);text-decoration:none;transition:transform .15s ease,background .15s ease,border-color .15s ease}.nav-icon-link svg{width:18px;height:18px;fill:currentColor}.nav-icon-link:hover{transform:translateY(-1px);background:#e07a5f2e;border-color:#e07a5f4d}.nav-links{display:flex;gap:.4rem}.nav-links a{text-decoration:none;font-weight:600;color:var(--ink-900);padding:.45rem .9rem;border-radius:999px;transition:color .15s ease,transform .15s ease,background .15s ease}.brand:hover,.nav-links a:hover{color:var(--ink-700);transform:translateY(-1px);background:#e07a5f29}.hero{min-height:100vh;display:flex;align-items:center;padding:8rem 6vw 6rem;scroll-margin-top:110px}.hero-inner{max-width:740px}.hero-inner.split{max-width:none;width:100%;display:grid;grid-template-columns:1.6fr 1fr;gap:3.5rem;align-items:center}.hero-copy{background:var(--hero-panel);border-radius:2rem;padding:2.5rem;border:1px solid var(--panel-border);box-shadow:0 30px 60px var(--shadow-soft)}.hero-media{display:flex;justify-content:flex-end}.hero-image{width:100%;max-width:360px;aspect-ratio:4 / 5;object-fit:cover;border-radius:1.75rem;border:2px solid rgba(215,225,245,.9);box-shadow:0 0 0 1px #e1ebff1f,0 12px 32px #0000008c}.eyebrow{text-transform:uppercase;letter-spacing:.35em;font-size:.7rem;color:var(--sage-600);margin-bottom:1rem;font-weight:600}.hero-title{font-size:clamp(3.2rem,8vw,6.2rem);margin:0 0 1.2rem;font-family:Outfit,system-ui,sans-serif;font-weight:300;letter-spacing:-.01em;line-height:.95}.typewriter{display:inline-block;white-space:nowrap;overflow:visible;border-right:0;width:auto;animation:none}@keyframes typing{99%{border-color:var(--ink-900)}to{width:11ch;border-color:transparent}}.hero-subtitle{font-size:1.15rem;color:var(--ink-500);line-height:1.7}.hero-cta{display:flex;gap:.85rem;margin-top:2rem;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.7rem 1.45rem;border-radius:999px;background:var(--ink-900);color:#fff;text-decoration:none;font-weight:600;border:0;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background .15s ease;box-shadow:0 18px 30px #201e1b24}.btn.resume{background:var(--coral-500);color:#2b1e1a;display:inline-flex;align-items:center;gap:.5rem;box-shadow:0 18px 30px #e07a5f59}.btn.resume svg{width:18px;height:18px;fill:currentColor}.btn.resume:hover{background:#ea8f76;box-shadow:0 22px 40px #e07a5f73}.btn.ghost{background:transparent;color:var(--ink-900);border:1px solid rgba(32,30,27,.25);box-shadow:none}.btn:hover{transform:translateY(-2px)}.btn.ghost:hover{background:#201e1b0f}.section{padding:5.5rem 6vw;background:transparent;scroll-margin-top:110px}.section.alt{background:#fff9;border-top:1px solid rgba(32,30,27,.05);border-bottom:1px solid rgba(32,30,27,.05)}.section-inner{max-width:980px}.section-inner.split{max-width:none}.section h2{margin-top:0;font-size:2.2rem;font-family:Fraunces,serif}.about-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:2.5rem;align-items:center;margin-top:1.5rem}.about-carousel{display:flex;justify-content:flex-end}.carousel-frame{position:relative;width:100%;max-width:360px}.about-text p{font-size:1.15rem;line-height:1.8;color:var(--ink-500);margin-top:.5rem;background:var(--panel-bg);padding:1.8rem;border-radius:1.5rem;border:1px solid var(--panel-border);box-shadow:0 18px 40px var(--shadow-soft)}.about-image{width:100%;max-width:360px;aspect-ratio:3 / 4;object-fit:cover;border-radius:1.5rem;border:2px solid rgba(215,225,245,.9);box-shadow:0 0 0 1px #e1ebff1f,0 12px 32px #0000008c}.carousel-dots{position:absolute;left:50%;bottom:-18px;transform:translate(-50%);display:flex;gap:.5rem;padding:.35rem .65rem;border-radius:999px;background:var(--panel-bg);box-shadow:0 10px 25px var(--shadow-soft);border:1px solid var(--panel-border)}.carousel-dot{width:10px;height:10px;border-radius:999px;border:0;background:#201e1b33;cursor:pointer;transition:transform .15s ease,background .15s ease}.carousel-dot.active{background:var(--coral-500);transform:scale(1.15)}.section-inner.wide{max-width:none;width:100%}.skills-row{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:auto}.education-card{padding:2rem;border-radius:1.5rem;background:var(--panel-bg);border:1px solid var(--panel-border);box-shadow:0 22px 44px var(--shadow-soft);display:flex;flex-direction:column;gap:1.5rem}.education-grid{display:grid;grid-template-columns:minmax(0,1.8fr) minmax(0,1fr);gap:2.5rem;margin-top:1.8rem;align-items:stretch}.education-image{border-radius:1.5rem;overflow:hidden;border:1px solid var(--panel-border);box-shadow:0 20px 40px var(--shadow-soft);background:var(--surface-0);min-height:100%}.education-image img{width:100%;height:100%;object-fit:cover;display:block}.education-header{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:1rem}.education-header h3{margin:0;font-size:1.35rem;font-family:Fraunces,serif}.education-major,.education-specialization{margin:.4rem 0 0;color:var(--ink-500);font-weight:600}.education-specialization{font-weight:500}.education-coursework{margin:.9rem 0 0;color:var(--ink-500);font-weight:600}.education-grad{background:var(--sage-600);color:#f8f6f1;padding:.45rem .9rem;border-radius:999px;font-weight:700;font-size:.8rem;letter-spacing:.04em}.education-timeline{display:flex;align-items:center;gap:1rem;margin-top:auto}.education-year{font-weight:700;color:var(--ink-900)}.education-track{position:relative;flex:1;height:6px;border-radius:999px;background:var(--sage-600)}.education-dot{position:absolute;top:50%;width:14px;height:14px;border-radius:999px;background:var(--ink-900);transform:translate(-50%,-50%);box-shadow:0 6px 14px #201e1b2e}.education-dot.start{left:0}.education-dot.end{left:100%}.skill-pill{padding:.4rem .9rem;background:#efe7dae6;border-radius:999px;font-weight:600;transition:transform .15s ease,box-shadow .15s ease}.skill-pill:hover{transform:translateY(-2px);box-shadow:0 10px 20px #201e1b1f}.cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:2.2rem;margin-top:2.5rem}.project-card{display:flex;flex-direction:column;border:1px solid rgba(15,23,42,.08);border-radius:.9rem;background:#ffffffe6;overflow:hidden;box-shadow:0 1px 2px #0f172a14;text-decoration:none;color:inherit;transition:transform .18s ease,box-shadow .18s ease;cursor:default}.project-card:hover{transform:translateY(-2px);box-shadow:0 12px 28px #0f172a1f,0 0 0 1px #0f172a0f,0 0 30px #e07a5f26}.project-image{padding:0}.project-image img{width:100%;height:220px;object-fit:cover;background:#f8fafc;border-radius:.9rem .9rem 0 0;display:block;box-shadow:inset 0 0 0 1px #0f172a0f,0 8px 20px #0f172a14}.project-body{padding:1.6rem;display:flex;flex:1;flex-direction:column;gap:1.1rem;font-size:.98rem}.project-body p{font-size:.98rem;line-height:1.7;margin:0;white-space:pre-line}.project-meta{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.project-title{display:flex;flex-direction:column;gap:.6rem;min-width:0}.project-meta h3{margin:0;font-size:1.2rem;font-weight:600}.project-meta-right{display:flex;flex-direction:column;align-items:flex-end;gap:.7rem}.project-status{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;padding:.25rem .6rem;border-radius:999px}.project-status.done,.project-status.in-progress{background:#0f172a0f;color:#0f172a}.project-timeline{display:inline-flex;align-items:center;gap:.5rem;font-size:.8rem;color:#475569;background:#0f172a0a;border:1px solid rgba(15,23,42,.08);border-radius:999px;padding:.3rem .7rem}.timeline-label{text-transform:uppercase;letter-spacing:.12em;font-size:.6rem;font-weight:600;color:#64748b}.timeline-value{font-weight:600}.project-links{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}.project-links.muted{font-size:.85rem;color:var(--ink-500)}.project-awards{display:flex;flex-direction:column;gap:.45rem}.project-award-item{display:inline-flex;align-items:flex-start;gap:.45rem;max-width:100%;width:fit-content;padding:.35rem .62rem;border-radius:.6rem;border:1px solid rgba(15,23,42,.12);background:#0f172a0d;color:#334155;font-size:.76rem;font-weight:600;letter-spacing:.01em;line-height:1.3}.award-emoji{flex-shrink:0;line-height:1;font-size:.88rem;margin-top:.04rem}.award-text{overflow-wrap:anywhere}.link-chip{width:40px;height:40px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#fff;border:1px solid rgba(15,23,42,.1);color:#0f172a;text-decoration:none;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.link-chip svg{width:18px;height:18px;fill:currentColor}.link-chip:hover{transform:translateY(-2px);box-shadow:0 10px 20px #0f172a1f;border-color:#0f172a33}.footer{padding:3.5rem 6vw 3rem;background:#1d1c19;color:#efe9df;border-top:1px solid rgba(239,233,223,.12)}[data-theme=dark] .section.alt{background:#141518bf;border-top:1px solid rgba(255,255,255,.05);border-bottom:1px solid rgba(255,255,255,.05)}[data-theme=dark] .project-status.done,[data-theme=dark] .project-status.in-progress{background:#ffffff14;color:#e2e8f0}[data-theme=dark] .project-timeline{background:#ffffff0f;color:#cbd5f5;border-color:#ffffff1f}[data-theme=dark] .project-card{background:#111214e6;border-color:#ffffff14;box-shadow:0 1px 2px #00000080}[data-theme=dark] .project-card:hover{box-shadow:0 18px 32px #00000073,0 0 0 1px #e2e8f014,0 0 28px #60a5fa2e;border-color:#e2e8f04d}[data-theme=dark] .project-image img{background:#0f1115;box-shadow:inset 0 0 0 1px #ffffff0f,0 10px 22px #00000059}[data-theme=dark] .link-chip{background:#111318;border-color:#ffffff1f;color:#e2e8f0}[data-theme=dark] .project-award-item{border-color:#ffffff24;background:#ffffff14;color:#d7dde7}[data-theme=dark] .carousel-dot{background:#ffffff59}[data-theme=dark] .skill-pill{background:#282a2ee6}[data-theme=dark] .footer{background:#0c0d0f;border-top:1px solid rgba(255,255,255,.08)}[data-theme=dark] .footer-tagline,[data-theme=dark] .footer-text{color:#cbd5f5}[data-theme=dark] .footer-title{color:#f2efe9}[data-theme=dark] .btn{background:#f2efe9;color:#1a1b1e;box-shadow:0 16px 28px #00000059}[data-theme=dark] .btn:hover{background:#fff}[data-theme=dark] .btn.ghost{background:transparent;color:#f2efe9;border:1px solid rgba(242,239,233,.5);box-shadow:none}[data-theme=dark] .btn.resume{background:var(--coral-500);color:#2b1e1a;box-shadow:0 18px 30px #e07a5f59}[data-theme=dark] .btn.resume:hover{background:#ea8f76;box-shadow:0 22px 40px #e07a5f73}[data-theme=dark] .hero-title,[data-theme=dark] .section h2{color:var(--ink-900)}[data-theme=dark] .hero-subtitle{color:var(--ink-500)}[data-theme=dark] .eyebrow{color:var(--ink-700)}[data-theme=dark] .about-text p{color:var(--ink-500)}[data-theme=dark] .education-header h3{color:var(--ink-900)}[data-theme=dark] .education-major,[data-theme=dark] .education-specialization,[data-theme=dark] .education-coursework{color:var(--ink-500)}[data-theme=dark] .education-grad{background:#84a38a40;color:#cfe7d6}[data-theme=dark] .education-year{color:var(--ink-900)}.theme-toggle{width:40px;height:40px;border-radius:999px;border:1px solid var(--panel-border);background:var(--panel-bg);color:var(--ink-900);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease,background .15s ease}.theme-toggle svg{width:18px;height:18px;fill:currentColor}.theme-toggle:hover{transform:translateY(-1px);box-shadow:0 10px 20px var(--shadow-soft);border-color:#e07a5f66}.footer-inner{display:flex;flex-direction:column;align-items:stretch;gap:1.5rem;max-width:1200px;margin:0 auto}.footer-main{display:flex;align-items:center;justify-content:space-between;gap:2rem}.footer-brand{max-width:420px}.footer-title{margin:0 0 .35rem;font-size:1.2rem;font-weight:700;color:#f8f4ee;font-family:Fraunces,serif}.footer-tagline{margin:0;color:#c6bfb3;line-height:1.6}.footer-actions{display:flex;align-items:center;gap:1.5rem}.footer-link{color:#f2ede4;text-decoration:none;font-weight:600;padding:.5rem .95rem;border-radius:999px;border:1px solid rgba(239,233,223,.2);background:#ffffff14;transition:transform .15s ease,background .15s ease,border-color .15s ease}.footer-link:hover{transform:translateY(-2px);background:#ffffff29;border-color:#efe9df66}.footer-links{display:flex;gap:1rem}.icon-link{width:44px;height:44px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#ffffff14;color:inherit;text-decoration:none;border:1px solid rgba(255,255,255,.16);transition:transform .15s ease,background .15s ease,border-color .15s ease}.icon-link:hover{transform:translateY(-2px);background:#ffffff29;border-color:#ffffff59}.icon-link svg{width:22px;height:22px;fill:currentColor}.footer-text{margin:0;font-weight:600;letter-spacing:.02em;color:#b8b1a7}@keyframes floatUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.hero,.section,.project-card,.education-card{animation:floatUp .9s ease both}.cards .project-card:nth-child(2){animation-delay:.08s}.cards .project-card:nth-child(3){animation-delay:.16s}.cards .project-card:nth-child(4){animation-delay:.24s}.cards .project-card:nth-child(5){animation-delay:.32s}.cards .project-card:nth-child(6){animation-delay:.4s}.cards .project-card:nth-child(7){animation-delay:.48s}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}.hero,.section,.project-card,.education-card{animation:none}.typewriter{animation:none;width:auto;border-right:0}}@media(max-width:1024px){.hero-inner.split{grid-template-columns:1fr}.hero-media{justify-content:flex-start}.about-grid{grid-template-columns:1fr}}@media(max-width:900px){.education-grid{grid-template-columns:1fr}.education-image{min-height:220px}}@media(max-width:768px){.navbar{display:none}.cards{grid-template-columns:1fr}}@media(max-width:600px){.hero{padding:6.5rem 6vw 4rem}.hero-cta{flex-direction:column;align-items:stretch}.footer-main,.footer-actions{flex-direction:column;align-items:flex-start}}
