:root{--ff-display: "Instrument Serif", "Georgia", serif;--ff-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--ff-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--fw-regular: 400;--fw-medium: 500;--fw-semibold: 600;--fw-bold: 700;--lh-tight: 1.25;--lh-snug: 1.4;--lh-normal: 1.6;--lh-relaxed: 1.75;--ls-tighter: -.025em;--ls-tight: -.015em;--ls-normal: 0em;--ls-caps: .07em;--ls-caps-sm: .05em;--ls-mono: .015em;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-in-out: cubic-bezier(.45, 0, .55, 1);--duration-fast: .15s;--duration-base: .25s;--duration-slow: .4s;--duration-slower: .6s;--max-width: 1100px;--header-height: 76px;--section-padding: 7rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px}:root{color-scheme:light;--dot-color: rgba(90, 65, 30, .13);--bg-primary: #F7F3EC;--bg-secondary: #EFE9DC;--bg-elevated: #FBF8F2;--bg-overlay: rgba(247, 243, 236, .94);--text-primary: #1C1814;--text-secondary: #3D3025;--text-muted: #7A6E5E;--text-inverse: #F0EDE8;--border-subtle: rgba(90, 65, 30, .08);--border-default: rgba(90, 65, 30, .16);--border-strong: rgba(90, 65, 30, .3);--accent: #0080A0;--accent-hover: #006680;--accent-muted: #22D3EE;--accent-subtle: rgba(0, 128, 160, .08);--success: #1A7A4A;--success-subtle: rgba(26, 122, 74, .08);--warning: #A86520;--warning-subtle: rgba(168, 101, 32, .08);--error: #BE3535;--error-subtle: rgba(190, 53, 53, .08);--info: #0080A0;--info-subtle: rgba(0, 128, 160, .08);--code-bg: #EFE9DC;--code-text: #0080A0;--header-bg: rgba(247, 243, 236, .92);--header-border: rgba(90, 65, 30, .12);--shadow-sm: 0 1px 2px 0 rgb(80 55 20 / .08);--shadow-md: 0 4px 6px -1px rgb(80 55 20 / .12), 0 2px 4px -2px rgb(80 55 20 / .07);--shadow-lg: 0 10px 20px -4px rgb(80 55 20 / .15), 0 4px 6px -4px rgb(80 55 20 / .08);--shadow-xl: 0 20px 40px -8px rgb(80 55 20 / .18), 0 8px 12px -6px rgb(80 55 20 / .09)}[data-theme=dark]{color-scheme:dark;--dot-color: rgba(34, 211, 238, .12);--bg-primary: #12141A;--bg-secondary: #1C1F2A;--bg-elevated: #222536;--bg-overlay: rgba(18, 20, 26, .93);--text-primary: #F0EDE8;--text-secondary: #A8A39C;--text-muted: #6B6762;--text-inverse: #12141A;--border-subtle: rgba(240, 237, 232, .08);--border-default: rgba(240, 237, 232, .15);--border-strong: rgba(240, 237, 232, .32);--accent: #22D3EE;--accent-hover: #38BDF8;--accent-muted: #0E7490;--accent-subtle: rgba(34, 211, 238, .1);--success: #34D399;--success-subtle: rgba(52, 211, 153, .1);--warning: #FBBF24;--warning-subtle: rgba(251, 191, 36, .1);--error: #F87171;--error-subtle: rgba(248, 113, 113, .1);--info: #22D3EE;--info-subtle: rgba(34, 211, 238, .1);--code-bg: rgba(28, 31, 42, .85);--code-text: #22D3EE;--header-bg: rgba(18, 20, 26, .9);--header-border: rgba(240, 237, 232, .12);--shadow-sm: 0 1px 3px 0 rgb(0 0 0 / .45);--shadow-md: 0 4px 8px -2px rgb(0 0 0 / .6), 0 2px 4px -2px rgb(0 0 0 / .45);--shadow-lg: 0 10px 24px -4px rgb(0 0 0 / .7), 0 4px 8px -4px rgb(0 0 0 / .45);--shadow-xl: 0 20px 48px -8px rgb(0 0 0 / .8), 0 8px 16px -6px rgb(0 0 0 / .5)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth;scroll-padding-top:var(--header-height)}body{min-height:100vh;line-height:1.6;position:relative}body:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:9998;opacity:.035;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='250' height='250'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='250' height='250' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px 200px;background-repeat:repeat}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}ul,ol{list-style:none}a{text-decoration:none;color:inherit}button{background:none;border:none;cursor:pointer}:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:var(--radius-sm)}.skip-to-content{position:absolute;top:-100%;left:1rem;z-index:9999;padding:.75rem 1.25rem;background:var(--accent);color:#fff;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:.875rem;font-weight:600;border-radius:var(--radius-md);transition:top .2s}.skip-to-content:focus{top:1rem}@font-face{font-family:Inter;src:url("./media/inter-var-latin-A7HJR4GC.woff2") format("woff2");font-weight:100 900;font-style:normal;font-display:swap}@font-face{font-family:JetBrains Mono;src:url("./media/jetbrains-mono-latin-2TKUHYWA.woff2") format("woff2");font-weight:400 700;font-style:normal;font-display:swap}@font-face{font-family:"Instrument Serif";src:url("./media/instrument-serif-latin-5BZOH4SR.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}.text-xs{font-size:.75rem;line-height:1rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-5xl{font-size:3rem;line-height:1}.font-serif{font-family:"Instrument Serif",Georgia,serif}.font-sans{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.font-mono{font-family:JetBrains Mono,Fira Code,Cascadia Code,monospace}.section-label{font-family:JetBrains Mono,Fira Code,Cascadia Code,monospace;font-size:.75rem;font-weight:500;color:var(--text-muted);letter-spacing:.05em;display:block;margin-bottom:.75rem}.section-label:before{content:"// ";color:var(--accent-muted)}.section-heading{font-family:"Instrument Serif",Georgia,serif;font-size:clamp(2rem,4vw,2.75rem);font-weight:400;color:var(--text-primary);line-height:1.1;letter-spacing:-.02em;margin:0}.data-text{font-family:JetBrains Mono,Fira Code,Cascadia Code,monospace;font-size:.8125rem;color:var(--text-secondary)}.tech-tag{display:inline-flex;align-items:center;gap:.3em;font-family:JetBrains Mono,Fira Code,Cascadia Code,monospace;font-size:.6875rem;font-weight:500;color:var(--code-text);background:var(--code-bg);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:.2em .5em;letter-spacing:.02em;white-space:nowrap;transition:border-color var(--duration-fast) var(--ease-out),background var(--duration-fast) var(--ease-out)}.tech-tag:hover{border-color:color-mix(in srgb,var(--t-color, var(--accent-muted)) 50%,transparent);background:color-mix(in srgb,var(--t-color, var(--accent-muted)) 6%,var(--code-bg))}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleXIn{0%{transform:scaleX(0)}to{transform:scaleX(1)}}@keyframes drawLine{0%{stroke-dashoffset:100}to{stroke-dashoffset:0}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes typewriterBlink{0%,to{opacity:1}50%{opacity:0}}@keyframes progressGrow{0%{width:0}to{width:var(--progress-width, 0%)}}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}.reveal{opacity:0;transform:translateY(20px);transition:opacity var(--duration-slow) var(--ease-out),transform var(--duration-slow) var(--ease-out)}.reveal.visible{opacity:1;transform:translateY(0)}.reveal:nth-child(1){transition-delay:0ms}.reveal:nth-child(2){transition-delay:80ms}.reveal:nth-child(3){transition-delay:.16s}.reveal:nth-child(4){transition-delay:.24s}.reveal:nth-child(5){transition-delay:.32s}.reveal:nth-child(6){transition-delay:.4s}.reveal:nth-child(7){transition-delay:.48s}.reveal:nth-child(8){transition-delay:.56s}.reveal:nth-child(9){transition-delay:.64s}.reveal:nth-child(10){transition-delay:.72s}.reveal:nth-child(11){transition-delay:.8s}.reveal:nth-child(12){transition-delay:.88s}.reveal-children>*{opacity:0;transform:translateY(16px);transition:opacity var(--duration-slow) var(--ease-out),transform var(--duration-slow) var(--ease-out)}.reveal-children>*:nth-child(1){transition-delay:0ms}.reveal-children>*:nth-child(2){transition-delay:.1s}.reveal-children>*:nth-child(3){transition-delay:.2s}.reveal-children>*:nth-child(4){transition-delay:.3s}.reveal-children>*:nth-child(5){transition-delay:.4s}.reveal-children>*:nth-child(6){transition-delay:.5s}.reveal-children>*:nth-child(7){transition-delay:.6s}.reveal-children>*:nth-child(8){transition-delay:.7s}.reveal-children>*:nth-child(9){transition-delay:.8s}.reveal-children>*:nth-child(10){transition-delay:.9s}.reveal-children>*:nth-child(11){transition-delay:1s}.reveal-children>*:nth-child(12){transition-delay:1.1s}.reveal-children.visible>*{opacity:1;transform:translateY(0)}.proficiency-bar{height:3px;background:var(--border-subtle);border-radius:var(--radius-full);overflow:hidden}.proficiency-bar__fill{height:100%;background:var(--accent);border-radius:var(--radius-full);transform-origin:left center;transform:scaleX(0);transition:transform .8s var(--ease-out);transition-delay:var(--bar-delay, 0ms)}.proficiency-bar__fill.animate{transform:scaleX(1)}.timeline-line.animate{animation:drawLine .8s var(--ease-out) forwards}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.reveal,.reveal-children>*{opacity:1;transform:none;transition:none}}.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 1.5rem}@media (max-width: 640px){.container{padding:0 1rem}}.section{padding:var(--section-padding) 0}@media (max-width: 768px){.section{padding:4rem 0}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-4{gap:1rem}.gap-8{gap:2rem}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-accent{color:var(--accent)}.link-hover{position:relative;color:var(--text-primary);transition:color var(--duration-fast) var(--ease-out)}.link-hover:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--accent);transition:width var(--duration-base) var(--ease-out)}.link-hover:hover{color:var(--accent)}.link-hover:hover:after{width:100%}.divider{width:48px;height:2px;background:var(--accent);border:none;transform-origin:left center;animation:scaleXIn var(--duration-slow) var(--ease-out) both}.badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .75rem;border-radius:var(--radius-full);font-size:.6875rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;font-family:JetBrains Mono,Fira Code,Cascadia Code,monospace}.badge--success{background:var(--success-subtle);color:var(--success)}.badge--accent{background:var(--accent-subtle);color:var(--accent)}.badge-dot{width:6px;height:6px;border-radius:var(--radius-full);background:currentColor;animation:pulse 2s ease-in-out infinite}.card{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:1.5rem;transition:border-color var(--duration-base) var(--ease-out),box-shadow var(--duration-base) var(--ease-out)}.card:hover{border-color:var(--border-default);box-shadow:var(--shadow-md)}.icon-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-lg);color:var(--text-secondary);border:1px solid var(--border-subtle);background:var(--bg-elevated);transition:color var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out),background var(--duration-fast) var(--ease-out)}.icon-btn:hover{color:var(--text-primary);border-color:var(--border-default);background:var(--bg-secondary)}.content-visibility-auto{content-visibility:auto}html{overflow-x:hidden;overflow-x:clip}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:1rem;color:var(--text-primary);background-color:var(--bg-primary);background-image:radial-gradient(circle,var(--dot-color) 1.5px,transparent 1.5px);background-size:24px 24px;transition:background-color var(--duration-base) var(--ease-out),color var(--duration-base) var(--ease-out)}::selection{background:var(--accent);color:var(--bg-primary)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}main{display:flex;flex-direction:column}
