:root{color-scheme:light dark;--bg: #ffffff;--bg-accent: #f5f8fe;--surface: rgba(255, 255, 255, .98);--surface-soft: #f8fbff;--surface-accent: #edf3ff;--ink: #111827;--muted: #475569;--line: #dbe4f0;--accent: #163d8f;--accent-strong: #0f2f69;--accent-soft: #eaf1ff;--accent-cool: #245fbc;--accent-mint: #0ea5a4;--warm: #ff8a63;--shadow: 0 18px 42px rgba(17, 24, 39, .06);--dot-primary: rgba(22, 61, 143, .16);--dot-secondary: rgba(14, 165, 164, .12);--dot-tertiary: rgba(255, 138, 99, .1);--page-background: radial-gradient(circle at 50% -10%, rgba(36, 95, 188, .14), transparent 32%), radial-gradient(circle at 6% 22%, rgba(22, 61, 143, .1), transparent 22%), radial-gradient(circle at 94% 18%, rgba(14, 165, 164, .08), transparent 20%), linear-gradient(180deg, #f7fbff 0%, #ffffff 36%, #f6f9ff 72%, #fff8f3 100%);--serif: "Iowan Old Style", "Palatino Linotype", "Book Antiqua", "Times New Roman", serif;--sans: "Avenir Next", "Segoe UI", "Helvetica Neue", sans-serif;--mono: "SFMono-Regular", "IBM Plex Mono", Consolas, monospace}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--page-background);overflow-x:hidden}a{color:inherit;text-decoration:none}button{font:inherit}#root{min-height:100vh}.page-shell{position:relative;isolation:isolate;min-height:100vh;padding-left:5.2rem;background:var(--page-background);background-size:auto;background-position:center top;color:var(--ink)}.page-shell:before,.page-shell:after{content:"";position:fixed;z-index:-1;pointer-events:none;top:0;right:0;bottom:0;left:0}.page-shell:before{background:radial-gradient(circle at 18% 34%,var(--dot-primary) 0 2px,transparent 2.8px),radial-gradient(circle at 70% 20%,var(--dot-secondary) 0 1.5px,transparent 2.25px),radial-gradient(circle at 83% 74%,var(--dot-tertiary) 0 1.1px,transparent 1.9px);background-size:24px 24px,20px 20px,18px 18px;background-position:0 0,8px 10px,10px 6px;opacity:.56;mask-image:radial-gradient(circle at 26% 42%,rgba(0,0,0,.98) 0,rgba(0,0,0,.9) 20%,rgba(0,0,0,.3) 42%,transparent 64%),radial-gradient(circle at 86% 18%,rgba(0,0,0,.82) 0,rgba(0,0,0,.24) 36%,transparent 56%),linear-gradient(180deg,rgba(0,0,0,.68),rgba(0,0,0,.3) 70%,transparent 96%);-webkit-mask-image:radial-gradient(circle at 26% 42%,rgba(0,0,0,.98) 0,rgba(0,0,0,.9) 20%,rgba(0,0,0,.3) 42%,transparent 64%),radial-gradient(circle at 86% 18%,rgba(0,0,0,.82) 0,rgba(0,0,0,.24) 36%,transparent 56%),linear-gradient(180deg,rgba(0,0,0,.68),rgba(0,0,0,.3) 70%,transparent 96%);animation:dotFieldFloat 22s ease-in-out infinite alternate}.page-shell:after{inset:auto auto auto 50%;top:-11rem;width:56rem;height:34rem;border-radius:999px;transform:translate(-50%);background:radial-gradient(circle,#245fbc29,#245fbc00 70%);filter:blur(22px);opacity:.95;animation:heroGlowFloat 18s ease-in-out infinite alternate}.site-header{position:sticky;top:0;z-index:20;border-bottom:1px solid rgba(216,223,232,.9);background:#ffffffeb;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 10px 26px #0a162c14}.site-header__inner,.portfolio{width:min(1320px,calc(100% - 2rem));margin:0 auto}.site-header__inner{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 0}.brand{display:inline-flex;align-items:center;justify-content:center;padding:.62rem 1.15rem;border-radius:999px;border:1px solid rgba(22,61,143,.24);background:linear-gradient(135deg,#163d8f1f,#0ea5a414 46%,#fffffff0);box-shadow:inset 0 1px #ffffffc2,0 10px 20px #1118270f;font-family:var(--serif);font-size:1.22rem;letter-spacing:-.03em;color:var(--ink);font-weight:800;white-space:nowrap;transition:transform .16s ease,border-color .16s ease,background .16s ease,box-shadow .16s ease}.brand:hover{transform:translateY(-1px);border-color:#245fbc57;background:linear-gradient(135deg,#163d8f2e,#0ea5a41a 48%,#fffffff7);box-shadow:inset 0 1px #fffc,0 12px 24px #11182714}.site-links{margin-left:auto;min-width:0;gap:.5rem;align-items:center;justify-content:flex-end}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:2.55rem;height:2.55rem;padding:0;border:1px solid var(--line);border-radius:999px;background:linear-gradient(180deg,#fffffffa,#f4f8ffe6);color:var(--accent-strong);font-weight:600;flex:0 0 auto;cursor:pointer;transition:transform .16s ease,background .16s ease,color .16s ease,border-color .16s ease}.theme-toggle:hover{transform:translateY(-1px);background:#e7efffeb}.theme-toggle svg{width:1.1rem;height:1.1rem}.side-rail{position:fixed;left:.85rem;top:50%;z-index:30;display:grid;gap:.75rem;padding:.75rem .55rem;border:1px solid var(--line);background:linear-gradient(180deg,#fffffff5,#f6f9fff0);border-radius:24px;box-shadow:0 16px 32px #11182714;transform:translateY(-50%);animation:railFloat 8s ease-in-out infinite}.side-rail__link{position:relative;overflow:visible;display:inline-flex;align-items:center;justify-content:center;width:3.35rem;height:3.35rem;border-radius:999px;background:#fffffffa;color:#425168;box-shadow:0 8px 18px #11182714;transition:transform .16s ease,background .16s ease,color .16s ease}.side-rail__link svg{width:1.45rem;height:1.45rem}.side-rail__tooltip{position:absolute;left:calc(100% + .85rem);top:50%;padding:.54rem .88rem;border:1px solid rgba(22,61,143,.18);border-radius:999px;background:linear-gradient(135deg,#fffffffa,#f2f7fff2);color:var(--ink);font-size:.84rem;font-weight:600;line-height:1;white-space:nowrap;box-shadow:0 12px 26px #1118271f;opacity:0;visibility:hidden;pointer-events:none;transform:translateY(-50%) translate(-8px);transition:opacity .16s ease,visibility .16s ease,transform .16s ease}.side-rail__link:hover .side-rail__tooltip,.side-rail__link:focus-visible .side-rail__tooltip{opacity:1;visibility:visible;transform:translateY(-50%) translate(0)}.side-rail__link:hover{transform:translateY(-2px);background:#eef4ff;color:var(--accent-strong)}.side-rail__link:focus-visible{outline:2px solid rgba(36,95,188,.32);outline-offset:3px}.side-rail__link--active{background:linear-gradient(135deg,var(--accent),var(--accent-cool));color:#fff}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.page-shell.theme-dark{color-scheme:dark;--bg: #07101c;--bg-accent: #0f1a2b;--surface: rgba(16, 24, 39, .98);--surface-soft: #121d31;--surface-accent: #1a315f;--ink: #f8fbff;--muted: #d0d9e8;--line: rgba(175, 192, 219, .24);--accent: #2d61d5;--accent-strong: #f4f8ff;--accent-soft: rgba(45, 97, 213, .18);--accent-cool: #4f86ff;--accent-mint: #1fc7b5;--warm: #ff8c6b;--shadow: 0 20px 50px rgba(0, 0, 0, .38);--dot-primary: rgba(231, 237, 248, .28);--dot-secondary: rgba(79, 134, 255, .2);--dot-tertiary: rgba(31, 199, 181, .16);--page-background: radial-gradient(circle at 50% -12%, rgba(86, 132, 255, .26), transparent 34%), radial-gradient(circle at 10% 20%, rgba(37, 73, 166, .22), transparent 24%), radial-gradient(circle at 92% 18%, rgba(31, 199, 181, .14), transparent 20%), radial-gradient(circle at 88% 82%, rgba(255, 140, 107, .12), transparent 24%), linear-gradient(180deg, #040812 0%, #08111d 38%, #0a1728 100%)}.page-shell.theme-dark:before{opacity:.72;mask-image:radial-gradient(circle at 26% 40%,rgba(0,0,0,1) 0,rgba(0,0,0,.9) 22%,rgba(0,0,0,.34) 44%,transparent 66%),radial-gradient(circle at 84% 16%,rgba(0,0,0,.92) 0,rgba(0,0,0,.28) 34%,transparent 54%),linear-gradient(180deg,rgba(0,0,0,.86),rgba(0,0,0,.48) 72%,transparent 98%);-webkit-mask-image:radial-gradient(circle at 26% 40%,rgba(0,0,0,1) 0,rgba(0,0,0,.9) 22%,rgba(0,0,0,.34) 44%,transparent 66%),radial-gradient(circle at 84% 16%,rgba(0,0,0,.92) 0,rgba(0,0,0,.28) 34%,transparent 54%),linear-gradient(180deg,rgba(0,0,0,.86),rgba(0,0,0,.48) 72%,transparent 98%)}.page-shell.theme-dark:after{background:radial-gradient(circle at 42% 42%,#5684ff38,#5684ff00 54%),radial-gradient(circle at 68% 40%,#1fc7b524,#1fc7b500 58%),radial-gradient(circle at 55% 62%,#ff8c6b1a,#ff8c6b00 60%)}.page-shell.theme-dark .site-header{border-bottom-color:#94a3b829;background:linear-gradient(180deg,#070d18f0,#070d18d1);box-shadow:0 14px 34px #0003}.page-shell.theme-dark .brand{border-color:#749dff3d;background:linear-gradient(135deg,#2d61d53d,#1fc7b51f 44%,#0a121feb);box-shadow:inset 0 1px #ffffff0f,0 14px 30px #0000003d}.page-shell.theme-dark .brand:hover{border-color:#8fade261;background:linear-gradient(135deg,#376de44d,#1fc7b529 46%,#0b1424f0)}.page-shell.theme-dark .side-rail{border-color:#94a3b829;background:linear-gradient(180deg,#060a12f5,#0a0f19f0);box-shadow:0 18px 34px #00000057}.page-shell.theme-dark .side-rail__link{background:#f3f7fff5;color:#243044}.page-shell.theme-dark .side-rail__link:hover{background:#dfe9fffa;color:#143b96}.page-shell.theme-dark .side-rail__link--active{background:linear-gradient(135deg,var(--accent),var(--accent-cool));color:#fff}.page-shell.theme-dark .side-rail__tooltip{border-color:#749dff3d;background:linear-gradient(135deg,#101b2cf5,#0a121ff0);color:#eef4ff;box-shadow:0 16px 30px #00000047}.page-shell.theme-dark .theme-toggle{background:linear-gradient(180deg,#f4f8fffa,#e4ecf8f5);color:#0f172a;border-color:#ffffff47}.page-shell.theme-dark .theme-toggle:hover{background:#fff}.page-shell.theme-dark .site-links a{color:#edf3ff}.site-nav,.site-links,.hero-actions,.card-links,.filter-row,.contact-actions{display:flex;flex-wrap:wrap;gap:.75rem}.site-nav{justify-content:center}.site-nav a,.site-links a{padding:.4rem .58rem;border-radius:999px;color:var(--muted);font-size:.94rem;transition:color .16s ease,background .16s ease}.site-nav a:hover,.site-links a:hover{color:var(--accent-strong);background:#e7efffe6}.page-shell.theme-dark .site-links a:hover{color:#fff;background:#2d61d53d}.portfolio{padding:1.35rem 0 3rem}.section-card{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:40px;background:linear-gradient(180deg,#fffffffc,#f7fafff7);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem;opacity:0;transform:translateY(18px);animation:sectionReveal .78s cubic-bezier(.2,.8,.2,1) forwards}.section-card:before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:linear-gradient(90deg,var(--accent),var(--accent-cool) 48%,var(--warm))}.section-card:after{content:"";position:absolute;inset:auto -8% -28% 34%;height:14rem;border-radius:999px;background:radial-gradient(circle,#245fbc14,#245fbc00 72%);pointer-events:none}.page-shell:not(.theme-dark) .section-card:after{background:radial-gradient(circle,#0ea5a414,#0ea5a400 60%),radial-gradient(circle at 70% 30%,#ff8a6314,#ff8a6300 62%);animation:lightGlowSweep 18s ease-in-out infinite alternate}.section-card+.section-card{margin-top:1rem}.page-shell.theme-dark .section-card{background:linear-gradient(180deg,#0c1422fc,#070c16f7)}.page-shell.theme-dark .section-card:after{background:radial-gradient(circle at 20% 20%,#4f86ff1a,#4f86ff00 58%),radial-gradient(circle at 72% 34%,#1fc7b514,#1fc7b500 56%),radial-gradient(circle at 54% 72%,#ff8c6b12,#ff8c6b00 58%)}.section-card:nth-of-type(2){animation-delay:80ms}.section-card:nth-of-type(3){animation-delay:.14s}.section-card:nth-of-type(4){animation-delay:.2s}.section-card:nth-of-type(5){animation-delay:.26s}.section-card:nth-of-type(6){animation-delay:.32s}#home{background:radial-gradient(circle at top left,rgba(22,61,143,.11),transparent 24%),radial-gradient(circle at top right,rgba(14,165,164,.08),transparent 22%),radial-gradient(circle at bottom right,rgba(255,138,99,.08),transparent 20%),linear-gradient(135deg,#ecf5fffa,#fffffffc 48%,#fffaf7f7)}.page-shell.theme-dark #home{background:radial-gradient(circle at top left,rgba(45,97,213,.18),transparent 24%),radial-gradient(circle at top right,rgba(31,199,181,.12),transparent 22%),radial-gradient(circle at bottom right,rgba(255,140,107,.1),transparent 20%),linear-gradient(135deg,#0b1321fc,#060b14fc 48%,#0a121ff7)}#about{background:radial-gradient(circle at top right,rgba(36,95,188,.09),transparent 24%),radial-gradient(circle at bottom left,rgba(14,165,164,.06),transparent 24%),linear-gradient(135deg,#f6fbfffc,#fffbf9fa)}.page-shell.theme-dark #about{background:radial-gradient(circle at top right,rgba(79,134,255,.1),transparent 24%),radial-gradient(circle at bottom left,rgba(31,199,181,.08),transparent 22%),linear-gradient(135deg,#080e18fa,#050911fa)}#skills{background:radial-gradient(circle at top left,rgba(22,61,143,.09),transparent 26%),radial-gradient(circle at top right,rgba(14,165,164,.07),transparent 24%),linear-gradient(135deg,#f1f8fffc,#fcfffffa)}.page-shell.theme-dark #skills{background:radial-gradient(circle at top left,rgba(45,97,213,.11),transparent 26%),radial-gradient(circle at top right,rgba(31,199,181,.08),transparent 22%),linear-gradient(135deg,#080e18fa,#04080ffa)}#resume{background:radial-gradient(circle at top right,rgba(36,95,188,.08),transparent 24%),radial-gradient(circle at bottom left,rgba(255,138,99,.06),transparent 22%),linear-gradient(135deg,#f6f9fffc,#fffbf8fa)}.page-shell.theme-dark #resume{background:radial-gradient(circle at top right,rgba(79,134,255,.1),transparent 24%),radial-gradient(circle at bottom left,rgba(255,140,107,.08),transparent 22%),linear-gradient(135deg,#080e18fa,#04080ffa)}#projects{background:radial-gradient(circle at top left,rgba(22,61,143,.09),transparent 24%),radial-gradient(circle at bottom right,rgba(14,165,164,.06),transparent 24%),linear-gradient(135deg,#f5f9fffc,#f8fffefa)}.page-shell.theme-dark #projects{background:radial-gradient(circle at top left,rgba(45,97,213,.12),transparent 24%),radial-gradient(circle at bottom right,rgba(31,199,181,.08),transparent 22%),linear-gradient(135deg,#080e18fa,#04080ffa)}#project-directory{background:radial-gradient(circle at top right,rgba(36,95,188,.09),transparent 24%),radial-gradient(circle at bottom left,rgba(255,138,99,.06),transparent 24%),linear-gradient(135deg,#f1f7fffc,#fffdfafa)}.page-shell.theme-dark #project-directory{background:radial-gradient(circle at top right,rgba(79,134,255,.12),transparent 24%),radial-gradient(circle at bottom left,rgba(255,140,107,.08),transparent 22%),linear-gradient(135deg,#080e18fa,#04080ffa)}.hero{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(320px,.95fr);grid-template-areas:"copy portrait" "aside aside";align-items:start;gap:1.35rem}.hero-copy,.hero-portrait-card,.hero-aside,.about-copy,.about-card,.skill-card,.experience-card,.sidebar-card,.project-card,.catalog-card{display:grid;gap:1rem}.hero-copy{grid-area:copy}.hero-portrait-card{grid-area:portrait;align-content:start;padding:1rem}.hero-aside{grid-area:aside;grid-template-columns:minmax(0,1.25fr) minmax(300px,.95fr);align-items:start}.hero-topline{display:flex;align-items:center;gap:.8rem;flex-wrap:wrap}.eyebrow,.role-label,.card-topline{font-family:var(--mono);text-transform:uppercase}.eyebrow{margin:0;color:var(--accent);font-size:.76rem;letter-spacing:.18em}.status-pill,.period-badge,.stack-pill,.skill-pill,.skill-token,.filter-chip,.card-links a{display:inline-flex;align-items:center;justify-content:center;border-radius:999px}.status-pill{padding:.38rem .72rem;background:linear-gradient(135deg,#163d8f1a,#ffffffeb);color:var(--accent-strong);font-size:.82rem;border:1px solid rgba(22,61,143,.2)}.hero h1,.section-heading h2,.contact-card h2,.project-card h3,.catalog-card h3,.about-card h3,.skill-card h3,.experience-card h3,.sidebar-card h3,.sidebar-entry h4{margin:0;font-family:var(--serif);letter-spacing:-.03em}.hero h1{max-width:22ch;font-size:clamp(1.88rem,3.15vw,2.72rem);line-height:1.1}.lede,.section-note,.about-copy p,.project-card p,.catalog-card p,.entry-summary,.tech-line,.contact-card h2,.repo-label,.sidebar-entry p,.sidebar-entry span,.metric-card span,.fact-card span,.summary-list li,.plain-list li{color:var(--muted)}.lede,.section-note,.about-copy p,.project-card p,.catalog-card p,.entry-summary,.tech-line,.contact-card h2,.summary-list li,.plain-list li{line-height:1.75}.lede{margin:0;max-width:44rem;font-size:.94rem}.primary-link,.ghost-link{display:inline-flex;align-items:center;justify-content:center;padding:.92rem 1.28rem;border-radius:999px;transition:transform .16s ease,box-shadow .16s ease,background .16s ease,border-color .16s ease}.primary-link{background:linear-gradient(135deg,var(--accent),var(--accent-cool) 58%,var(--accent-mint));color:#fff;box-shadow:0 14px 24px #1e55d733}.ghost-link{border:1px solid var(--line);background:#ffffffdb;color:var(--ink)}.page-shell.theme-dark .ghost-link{background:#121c2cf5;border-color:#afc0db3d;color:var(--ink)}.primary-link:hover,.ghost-link:hover,.card-links a:hover,.filter-chip:hover{transform:translateY(-1px)}.fact-grid,.metric-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem}.fact-card,.metric-card,.hero-portrait-card,.hero-aside,.about-card,.skill-card,.experience-card,.sidebar-card,.project-card,.catalog-card{border:1px solid var(--line);background:linear-gradient(180deg,#fffffff7,#f4f8ffe8);border-radius:22px;box-shadow:0 10px 26px #1522380a;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease,background .18s ease}.page-shell.theme-dark .fact-card,.page-shell.theme-dark .metric-card,.page-shell.theme-dark .hero-portrait-card,.page-shell.theme-dark .hero-aside,.page-shell.theme-dark .about-card,.page-shell.theme-dark .skill-card,.page-shell.theme-dark .experience-card,.page-shell.theme-dark .sidebar-card,.page-shell.theme-dark .project-card,.page-shell.theme-dark .catalog-card{background:linear-gradient(180deg,#111b2cfa,#0a111ef5);box-shadow:0 14px 30px #0003}.fact-card,.metric-card{padding:1rem}.fact-card strong,.metric-card strong{display:block;color:var(--ink);font-size:1rem;line-height:1.35}.fact-card span,.metric-card span{display:block;font-size:.82rem;margin-bottom:.35rem}.hero-skill-group{display:grid;gap:.7rem}.hero-summary-copy{display:grid;gap:1rem}.portrait-frame{position:relative;overflow:hidden;border-radius:24px;aspect-ratio:4 / 4.45;background:radial-gradient(circle at top center,rgba(36,95,188,.16),transparent 48%),linear-gradient(180deg,#dfe9ffcc,#f6f9ff8f)}.page-shell.theme-dark .portrait-frame{background:radial-gradient(circle at top center,rgba(79,134,255,.2),transparent 48%),linear-gradient(180deg,#121e34f5,#0a121ff0)}.portrait-image{display:block;width:100%;height:100%;object-fit:cover;object-position:62% 18%}.portrait-copy{display:grid;gap:.45rem}.portrait-copy h3{margin:0;font-family:var(--serif);letter-spacing:-.03em;font-size:1.34rem;color:var(--ink)}.portrait-copy p{margin:0;color:var(--muted);font-size:.9rem;line-height:1.7}.skill-pill-row,.skill-list{display:flex;flex-wrap:wrap;gap:.6rem}.skill-pill,.skill-token{padding:.42rem .76rem;border:1px solid rgba(30,85,215,.15);background:linear-gradient(180deg,#fffffffa,#e7efffb3);color:var(--ink);font-size:.8rem;line-height:1.15}.page-shell.theme-dark .skill-pill,.page-shell.theme-dark .skill-token,.page-shell.theme-dark .stack-pill,.page-shell.theme-dark .card-links a,.page-shell.theme-dark .filter-chip{background:#131d2ff5;border-color:#afc0db38;color:var(--ink)}.hero-aside{align-content:start;padding:1.35rem;background:radial-gradient(circle at top right,rgba(22,61,143,.06),transparent 28%),linear-gradient(180deg,#fffffffc,#f3f8fff0)}.hero-aside .metric-grid{height:100%}.summary-list,.plain-list{margin:0;padding-left:1.1rem;display:grid;gap:.45rem}.metric-card{min-height:94px}.metric-card strong{font-size:1.3rem;font-family:var(--serif)}.section-heading{display:grid;gap:.75rem;margin-bottom:1.4rem}.section-heading h2,.contact-card h2{font-size:clamp(1.34rem,2.35vw,1.98rem);line-height:1.18;color:var(--accent-strong)}.section-note,.project-card p,.catalog-card p,.entry-summary,.tech-line,.about-copy p{margin:0}.about-grid,.resume-layout{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(280px,1fr);gap:1rem}.about-card,.skill-card,.experience-card,.sidebar-card,.project-card,.catalog-card{padding:1.3rem}.about-card{background:radial-gradient(circle at top right,rgba(22,61,143,.06),transparent 24%),linear-gradient(180deg,#fffffffc,#f5f9fff2)}.page-shell.theme-dark .about-card{background:radial-gradient(circle at top right,rgba(79,134,255,.08),transparent 24%),linear-gradient(180deg,#111b2cfa,#0a111ef5)}.skill-card:nth-child(1){background:linear-gradient(180deg,#e9f2fffa,#fffffff0)}.skill-card:nth-child(2){background:linear-gradient(180deg,#ebfbf8fa,#fffffff0)}.skill-card:nth-child(3){background:linear-gradient(180deg,#fff5f1fa,#fffffff0)}.skill-card:nth-child(4){background:linear-gradient(180deg,#f0f7fffa,#fffffff0)}.skill-card:nth-child(5){background:linear-gradient(180deg,#f1fcf9fa,#fffffff0)}.page-shell.theme-dark .skill-card:nth-child(1),.page-shell.theme-dark .skill-card:nth-child(2),.page-shell.theme-dark .skill-card:nth-child(3),.page-shell.theme-dark .skill-card:nth-child(4),.page-shell.theme-dark .skill-card:nth-child(5){background:linear-gradient(180deg,#111b2cfa,#0a111ef5)}.about-card h3,.skill-card h3,.experience-card h3,.sidebar-card h3{font-size:1.14rem}.skills-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}.experience-column,.resume-sidebar,.sidebar-stack{display:grid;gap:1rem}.experience-top,.catalog-meta,.card-footer,.card-topline{display:flex;align-items:center;justify-content:space-between;gap:.8rem}.experience-top{align-items:flex-start;flex-wrap:wrap}.role-label{margin:0 0 .2rem;color:var(--accent);font-size:.78rem;letter-spacing:.14em}.period-badge{padding:.36rem .7rem;background:linear-gradient(135deg,#1e55d71f,#ffffffeb);color:var(--accent-strong);font-size:.8rem}.tech-line strong{color:var(--ink)}.sidebar-entry{display:grid;gap:.2rem}.sidebar-entry+.sidebar-entry{padding-top:.95rem;border-top:1px solid var(--line)}.sidebar-entry h4{font-size:.95rem}.sidebar-entry p,.sidebar-entry span{margin:0;font-size:.88rem;line-height:1.6}.project-grid,.catalog-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}.project-card,.catalog-card{min-height:255px}.project-card{background:radial-gradient(circle at top right,rgba(22,61,143,.06),transparent 24%),linear-gradient(180deg,#fffffffc,#f4f8fff2);transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.page-shell.theme-dark .project-card,.page-shell.theme-dark .catalog-card,.page-shell.theme-dark .contact-card{background:linear-gradient(180deg,#101929fc,#090f1bf7)}.catalog-card{background:linear-gradient(180deg,#fffffffa,#f2f7ffeb);transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.project-card:hover,.catalog-card:hover{transform:translateY(-3px);border-color:#1e55d733;box-shadow:0 16px 34px #15223817}.fact-card:hover,.metric-card:hover,.hero-aside:hover,.about-card:hover,.skill-card:hover,.experience-card:hover,.sidebar-card:hover{transform:translateY(-2px);border-color:#245fbc2e;box-shadow:0 16px 34px #15223814}.page-shell.theme-dark .project-card:hover,.page-shell.theme-dark .catalog-card:hover,.page-shell.theme-dark .skill-card:hover,.page-shell.theme-dark .experience-card:hover,.page-shell.theme-dark .about-card:hover,.page-shell.theme-dark .sidebar-card:hover,.page-shell.theme-dark .fact-card:hover,.page-shell.theme-dark .metric-card:hover{border-color:#749dff47;box-shadow:0 18px 38px #0000003d}.card-topline{color:var(--accent);font-size:.75rem;letter-spacing:.12em}.project-card h3,.catalog-card h3{font-size:1.18rem;line-height:1.18}.stack-pill{padding:.44rem .76rem;background:linear-gradient(180deg,#fffffffa,#edf2ffdb);border:1px solid var(--line);color:var(--ink);font-size:.82rem}.repo-label{font-family:var(--mono);font-size:.75rem}.card-links a{padding:.52rem .86rem;border:1px solid var(--line);background:#ffffffe6;color:var(--ink);font-size:.84rem}.archive-toolbar{margin-bottom:1.2rem}.filter-row{gap:.7rem}.filter-chip{gap:.55rem;padding:.75rem .95rem;border:1px solid var(--line);background:linear-gradient(180deg,#fffffffa,#f4f8ffe6);color:var(--ink);cursor:pointer}.filter-chip strong{color:var(--accent-strong)}.filter-chip--active{border-color:#1e55d747;background:linear-gradient(135deg,#1e55d721,#0ea5a417,#ff8a6317)}.contact-card{background:radial-gradient(circle at top left,rgba(22,61,143,.11),transparent 24%),radial-gradient(circle at bottom right,rgba(36,95,188,.08),transparent 22%),linear-gradient(135deg,#f2f7fff7,#fffffffc)}.page-shell.theme-dark .contact-card{background:radial-gradient(circle at top left,rgba(45,97,213,.2),transparent 24%),radial-gradient(circle at bottom right,rgba(79,134,255,.14),transparent 22%),linear-gradient(135deg,#0d1524fc,#070c15fc)}.page-shell.theme-dark .eyebrow,.page-shell.theme-dark .role-label,.page-shell.theme-dark .card-topline{color:#8eb4ff}.page-shell.theme-dark .status-pill,.page-shell.theme-dark .period-badge{background:linear-gradient(135deg,#2d61d538,#1fc7b524 58%,#ff8c6b1f);border-color:#8fade24d;color:#f4f8ff}.page-shell.theme-dark .lede,.page-shell.theme-dark .section-note,.page-shell.theme-dark .about-copy p,.page-shell.theme-dark .project-card p,.page-shell.theme-dark .catalog-card p,.page-shell.theme-dark .entry-summary,.page-shell.theme-dark .tech-line,.page-shell.theme-dark .repo-label,.page-shell.theme-dark .sidebar-entry p,.page-shell.theme-dark .sidebar-entry span,.page-shell.theme-dark .metric-card span,.page-shell.theme-dark .fact-card span,.page-shell.theme-dark .summary-list li,.page-shell.theme-dark .plain-list li,.page-shell.theme-dark .contact-card h2{color:#dbe5f3}.contact-grid{display:grid;grid-template-columns:minmax(0,.7fr) minmax(0,2fr) minmax(0,1.2fr);gap:1rem;align-items:center}.contact-label{margin:.35rem 0 0;color:var(--ink);font-family:var(--serif);font-size:1.1rem}.contact-card h2{margin:0;color:var(--ink)}.contact-actions{justify-content:flex-end}@keyframes pageGradientShift{0%{background-position:0% 0%,100% 0%,100% 100%,50% 50%}to{background-position:14% 10%,84% 12%,88% 88%,50% 50%}}@keyframes dotFieldFloat{0%{transform:translateZ(0)}to{transform:translate3d(-1.25rem,.9rem,0)}}@keyframes heroGlowFloat{0%{transform:translate(-50%) translateY(0) scale(1)}to{transform:translate(-50%) translateY(1rem) scale(1.04)}}@keyframes orbDriftLeft{0%{transform:translateZ(0) scale(1)}to{transform:translate3d(3rem,-2rem,0) scale(1.08)}}@keyframes orbDriftRight{0%{transform:translateZ(0) scale(1)}to{transform:translate3d(-2.5rem,1.8rem,0) scale(1.06)}}@keyframes railFloat{0%,to{transform:translateY(-50%)}50%{transform:translateY(calc(-50% - 6px))}}@keyframes sectionReveal{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes lightGlowSweep{0%{transform:translateZ(0) scale(1);opacity:.8}to{transform:translate3d(-2rem,-1rem,0) scale(1.06);opacity:1}}@media (prefers-reduced-motion: reduce){.page-shell,.page-shell:before,.page-shell:after,.side-rail,.section-card{animation:none}.section-card{opacity:1;transform:none}}@media (max-width: 1120px){.site-header__inner,.hero,.about-grid,.resume-layout,.contact-grid{grid-template-columns:1fr}.site-header__inner{align-items:flex-start}.hero{grid-template-areas:"portrait" "copy" "aside"}.hero-portrait-card{width:min(100%,420px);margin:0 auto}.hero-aside{grid-template-columns:1fr}.site-links,.site-nav{justify-content:flex-start}.skills-grid,.project-grid,.catalog-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.contact-actions{justify-content:flex-start}}@media (max-width: 760px){.page-shell{padding-left:0;padding-bottom:1rem}.site-header__inner,.portfolio{width:min(100% - 1rem,1180px)}.site-header__inner{gap:.85rem}.brand{width:100%;justify-content:flex-start;white-space:normal;line-height:1.1;font-size:clamp(1.02rem,5.4vw,1.48rem);padding:.72rem 1rem}.site-links{margin-left:0;width:100%;justify-content:flex-start;gap:.55rem}.site-links a{flex:0 0 auto;padding:.46rem .72rem;font-size:.9rem}.theme-toggle{width:2.7rem;height:2.7rem}.section-card{padding:1.4rem;border-radius:28px}.hero-portrait-card{width:100%;padding:.95rem}.portrait-frame{aspect-ratio:4 / 4.4}.portrait-copy{justify-items:start}.side-rail{position:static;left:auto;top:auto;bottom:auto;transform:none;grid-auto-flow:column;grid-auto-columns:max-content;gap:.55rem;padding:.55rem;width:min(100% - 1rem,1180px);margin:0 auto .85rem;overflow-x:auto;border-radius:999px;animation:none;box-shadow:0 14px 26px #1118271f;scrollbar-width:none}.side-rail::-webkit-scrollbar{display:none}.side-rail__link{width:2.95rem;height:2.95rem;flex:0 0 auto}.side-rail__link svg{width:1.2rem;height:1.2rem}.side-rail__tooltip{display:none}.hero h1{max-width:100%;font-size:clamp(1.86rem,7.2vw,2.35rem);line-height:1.1}.hero-topline{align-items:flex-start;gap:.65rem}.lede{max-width:100%;font-size:.92rem;line-height:1.68}.fact-grid,.metric-grid,.skills-grid,.project-grid,.catalog-grid{grid-template-columns:1fr}.hero-actions,.contact-actions,.filter-row,.site-nav,.site-links,.primary-link,.ghost-link{width:100%}}@media (max-width: 560px){.page-shell{padding-bottom:.85rem}.site-header__inner{padding:.85rem 0}.brand{font-size:clamp(.98rem,5.8vw,1.22rem);padding:.68rem .9rem}.hero-portrait-card{padding:.85rem}.portrait-frame{aspect-ratio:1 / 1.08}.portrait-copy h3{font-size:1.18rem}.portrait-copy p{font-size:.86rem;line-height:1.62}.site-links{gap:.45rem}.site-nav a,.card-links a,.stack-pill{width:100%;justify-content:center}.site-links a{width:auto;justify-content:center;font-size:.86rem;padding:.42rem .66rem}.theme-toggle{width:2.5rem;height:2.5rem}.side-rail{gap:.45rem;padding:.45rem;width:min(100% - .75rem,1180px);margin-bottom:.75rem}.side-rail__link{width:2.55rem;height:2.55rem}.side-rail__link svg{width:1.08rem;height:1.08rem}.hero-topline{flex-direction:column}.card-footer,.catalog-meta{align-items:flex-start;flex-direction:column}}
