@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@500;600;700&family=Manrope:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{color-scheme:dark;--bg: #121212;--bg-accent: #0f1f22;--panel: #1b1b1b;--panel-soft: #242424;--border: #343434;--text: #fbfaf4;--muted: #a6b0b6;--accent: #20808d;--accent-bright: #20b2aa;--accent-soft: #7cdad3;--eyebrow-color: #7cdad3;--cta-text: #9be7e1;--cta-border: color-mix(in srgb, var(--accent) 38%, var(--border));--cta-bg: color-mix(in srgb, var(--accent) 13%, transparent);--shadow: 0 18px 48px rgba(0, 0, 0, .35);--shadow-hover: 0 24px 58px rgba(0, 0, 0, .45);--card-hover-shadow: 0 14px 30px rgba(0, 0, 0, .24)}:root[data-theme=light]{color-scheme:light;--bg: #ebf3f8;--bg-accent: #d4eaf0;--panel: #ffffff;--panel-soft: #f2f8fb;--border: #d8e6ee;--text: #112126;--muted: #53656b;--accent: #20808d;--accent-bright: #0f7f93;--accent-soft: #4e989a;--eyebrow-color: #115e68;--cta-text: #0f5964;--cta-border: #7daeb9;--cta-bg: #d6edf2;--shadow: 0 14px 38px rgba(23, 50, 63, .12);--shadow-hover: 0 19px 46px rgba(23, 50, 63, .2);--card-hover-shadow: 0 10px 24px rgba(23, 50, 63, .14)}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;font-family:Manrope,sans-serif;color:var(--text);background:radial-gradient(circle at 18% -8%,rgba(32,178,170,.22),transparent 35%),radial-gradient(circle at 88% 8%,rgba(124,218,211,.2),transparent 32%),linear-gradient(165deg,var(--bg-accent) 0%,var(--bg) 60%);transition:background .22s ease,color .22s ease}.mono{font-family:JetBrains Mono,monospace}.app-shell{width:min(1120px,calc(100% - 2rem));margin:2rem auto 3rem}.topbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.brand{margin:0;font-size:.8rem;letter-spacing:.22em;color:var(--muted)}.topbar-actions{display:flex;align-items:center;gap:.6rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.theme-switch{position:relative;width:4.2rem;height:2.25rem;border:1px solid var(--border);border-radius:999px;background:color-mix(in srgb,var(--panel) 84%,transparent);color:var(--text);padding:0;cursor:pointer;transition:border-color .18s ease,transform .18s ease,background-color .18s ease}.theme-switch:hover{border-color:var(--accent-bright);transform:translateY(-1px)}.theme-switch:focus-visible{outline:2px solid color-mix(in srgb,var(--accent-bright) 76%,white 24%);outline-offset:2px}.switch-track{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:space-between;padding:0 .48rem;color:var(--muted)}.switch-side-icon{width:.76rem;height:.76rem;opacity:.9}.switch-thumb{position:absolute;top:.18rem;left:.18rem;width:1.78rem;height:1.78rem;border-radius:999px;border:1px solid color-mix(in srgb,var(--accent) 26%,var(--border));background:color-mix(in srgb,var(--panel-soft) 86%,var(--accent) 14%);color:var(--accent-soft);box-shadow:0 5px 12px #0000003d;display:grid;place-items:center;transition:transform .22s ease,color .18s ease,border-color .18s ease}.theme-switch.is-light .switch-thumb{transform:translate(1.95rem);color:var(--accent-bright)}.switch-thumb-icon{width:.86rem;height:.86rem}.layout{display:grid;gap:1rem}.panel{border:1px solid var(--border);background:linear-gradient(155deg,rgba(255,255,255,.02),transparent 45%),var(--panel);border-radius:22px;padding:clamp(1.2rem,2vw,2rem);box-shadow:var(--shadow);animation:rise .42s ease both}.layout>.panel:nth-child(2){animation-delay:80ms}.layout>.panel:nth-child(3){animation-delay:.14s}.layout>.panel:nth-child(4){animation-delay:.2s}@media(hover:hover)and (pointer:fine){.panel,.subpanel,.timeline-item{transform-origin:center;transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease;will-change:transform}.panel:hover,.subpanel:hover,.timeline-item:hover{transform:scale(1.012)}.panel:hover{box-shadow:var(--shadow-hover)}.subpanel:hover,.timeline-item:hover{border-color:color-mix(in srgb,var(--accent) 30%,var(--border));box-shadow:var(--card-hover-shadow)}}.hero{padding-top:clamp(1.4rem,2.4vw,2.5rem)}.eyebrow{margin:0;font-size:.84rem;letter-spacing:.16em;text-transform:uppercase;color:var(--eyebrow-color)}h1,h2,h3{font-family:Space Grotesk,sans-serif;line-height:1.15;margin:0}h1{margin-top:.8rem;font-size:clamp(2rem,5vw,3.25rem);max-width:18ch}h2{font-size:clamp(1.15rem,2vw,1.55rem);margin-bottom:1rem}h3{font-size:1rem;margin-bottom:.75rem}.lead{margin:1rem 0 0;max-width:65ch;color:var(--muted);line-height:1.65}.hero-project-cta{display:inline-flex;align-items:center;gap:.45rem;text-decoration:none;color:var(--cta-text);border:1px solid var(--cta-border);background:var(--cta-bg);border-radius:999px;padding:.44rem .75rem;font-size:.84rem;font-weight:700;transition:border-color .18s ease,transform .18s ease,color .18s ease}.hero-project-cta:hover{color:var(--accent-bright);border-color:color-mix(in srgb,var(--accent-bright) 44%,var(--border));transform:translateY(-1px)}.topbar-project-cta{margin-top:0}.cta-link-icon{width:.95rem;height:.95rem}.contact-row{display:flex;flex-wrap:wrap;align-items:center;gap:.6rem;margin-top:1.3rem}.email-copy{-webkit-appearance:none;-moz-appearance:none;appearance:none;position:relative;cursor:pointer;border-radius:999px;border:1px solid var(--border);background:linear-gradient(120deg,color-mix(in srgb,var(--accent) 18%,transparent),color-mix(in srgb,var(--accent-bright) 10%,transparent)),color-mix(in srgb,var(--panel-soft) 88%,transparent);color:var(--text);display:inline-flex;align-items:center;gap:.55rem;padding:.52rem .9rem;font-size:.89rem;font-weight:600;transition:border-color .18s ease,transform .18s ease;max-width:100%}.email-copy:hover{border-color:var(--accent-bright);transform:translateY(-1px)}.email-text{word-break:break-all}.email-tooltip{position:absolute;left:50%;bottom:calc(100% + .5rem);transform:translate(-50%,6px);opacity:0;pointer-events:none;z-index:2;white-space:nowrap;border-radius:9px;border:1px solid var(--border);padding:.32rem .5rem;font-size:.72rem;line-height:1;color:var(--text);background:color-mix(in srgb,var(--panel-soft) 94%,black 6%);box-shadow:0 6px 22px #0003;transition:opacity .16s ease,transform .16s ease}.email-tooltip:after{content:"";position:absolute;top:100%;left:50%;width:8px;height:8px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);background:color-mix(in srgb,var(--panel-soft) 94%,black 6%);transform:translate(-50%) rotate(45deg)}.email-copy:hover .email-tooltip,.email-copy:focus-visible .email-tooltip{opacity:1;transform:translate(-50%)}.icon-btn{text-decoration:none;border-radius:999px;color:var(--text);border-color:var(--border);background:color-mix(in srgb,var(--panel-soft) 90%,transparent);border:1px solid var(--border);width:2.35rem;height:2.35rem;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .18s ease,border-color .18s ease,background-color .18s ease}.icon-btn:hover{transform:translateY(-1px);border-color:var(--accent);background:color-mix(in srgb,var(--panel-soft) 76%,var(--accent-soft) 24%)}.icon{width:1rem;height:1rem;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;fill:none}.copy-feedback{min-height:1.2rem;margin:.5rem 0 0;color:transparent;font-size:.82rem;font-weight:600;transition:color .18s ease}.copy-feedback.is-visible{color:var(--accent-soft)}.skills-grid{display:grid;gap:.8rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.subpanel{border:1px solid var(--border);background:var(--panel-soft);border-radius:16px;padding:1rem}.chips{display:flex;flex-wrap:wrap;gap:.4rem}.chip{border:1px solid color-mix(in srgb,var(--accent) 26%,var(--border));background:color-mix(in srgb,var(--panel) 72%,var(--accent) 12%);border-radius:999px;padding:.32rem .68rem;font-size:.81rem;color:color-mix(in srgb,var(--text) 92%,white 8%)}.timeline{display:grid;gap:.72rem}.timeline-item{display:grid;grid-template-columns:minmax(160px,220px) 1fr;gap:.95rem;border:1px solid var(--border);border-radius:14px;padding:.9rem;background:color-mix(in srgb,var(--panel-soft) 92%,transparent)}.timeline-role{margin:0;font-weight:700;font-size:.91rem}.timeline-period{margin:.32rem 0 0;font-size:.72rem;color:var(--muted)}.timeline-org{margin:0;font-weight:600}.timeline-summary{margin:.45rem 0 0;color:var(--muted);line-height:1.55}.two-col{display:grid;gap:1rem;grid-template-columns:repeat(2,minmax(0,1fr))}.two-col .subpanel p{margin:0;color:var(--muted);line-height:1.6}.inline-link{display:inline-flex;margin-top:.8rem;color:var(--accent-bright);text-decoration:none;font-weight:700}.inline-link:hover{text-decoration:underline}.education-list{display:grid;gap:.82rem}.edu-item{border-left:2px solid var(--accent);padding-left:.82rem}.edu-degree{margin:0;font-weight:700}.edu-school{margin:.3rem 0 0;color:var(--muted)}.edu-period{margin:.5rem 0 0;color:var(--muted);font-size:.75rem}@keyframes rise{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:820px){.timeline-item,.two-col{grid-template-columns:1fr}}@media(max-width:560px){.app-shell{width:calc(100% - 1rem);margin:1rem auto 2rem}.topbar{flex-wrap:wrap}.topbar-actions{width:100%;justify-content:space-between}.email-copy{width:100%;justify-content:flex-start}}
