@layer tokens{:root{--phi: 1.618;--phi-inverse: .618;--space-1: .25rem;--space-2: .5rem;--space-3: 1rem;--space-4: 1.5rem;--space-5: 2.5rem;--space-6: 3rem;--space-8: 4rem;--space-10: 5rem;--space-12: 6.5rem;--space-16: 8rem;--space-20: 10.5rem;--text-xs: .824rem;--text-sm: .941rem;--text-base: 1rem;--text-lg: 1.25rem;--text-xl: 1.563rem;--text-2xl: 1.953rem;--text-3xl: 2.441rem;--text-4xl: 3.052rem;--text-5xl: 3.815rem;--text-6xl: 4.768rem;--font-serif: "Cormorant Garamond", Georgia, "Times New Roman", serif;--font-display: "Cormorant Garamond", Georgia, serif;--font-mono: "Anonymous Pro", Monaco, "Courier New", monospace;--font-regular: 400;--font-bold: 700;--leading-tight: 1.2;--leading-normal: 1.618;--leading-relaxed: 1.75;--bg-primary: hsl(30, 10%, 98%);--bg-secondary: hsl(30, 8%, 95%);--bg-elevated: hsl(0, 0%, 100%);--bg-subtle: hsl(30, 10%, 96%);--text-primary: hsl(210, 15%, 10%);--text-secondary: hsl(210, 12%, 28%);--text-tertiary: hsl(210, 8%, 48%);--text-muted: hsl(210, 6%, 62%);--accent-primary: hsl(200, 18%, 32%);--accent-hover: hsl(200, 22%, 42%);--accent-subtle: hsla(200, 18%, 32%, .1);--border-subtle: hsl(30, 10%, 88%);--border-default: hsl(30, 8%, 75%);--border-emphasis: hsl(30, 6%, 60%);--interactive: var(--accent-primary);--interactive-hover: var(--accent-hover);--shadow-sm: 0 1px 2px hsla(0, 0%, 0%, .04);--shadow-md: 0 4px 8px hsla(0, 0%, 0%, .06);--shadow-lg: 0 8px 16px hsla(0, 0%, 0%, .08);--shadow-xl: 0 16px 32px hsla(0, 0%, 0%, .1);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--transition-slower: .6s cubic-bezier(.4, 0, .2, 1);--ease-out: cubic-bezier(.4, 0, .2, 1);--ease-in: cubic-bezier(.4, 0, 1, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--max-width: 64rem;--max-width-wide: 80rem;--border-radius-sm: .375rem;--border-radius-md: .5rem;--border-radius-lg: .75rem;--border-radius-xl: 1rem;--border-radius-full: 9999px;--z-base: 1;--z-dropdown: 10;--z-sticky: 20;--z-fixed: 30;--z-modal-backdrop: 40;--z-modal: 50;--z-popover: 60;--z-tooltip: 70}}@layer reset{*,*:before,*:after{box-sizing:border-box}*{margin:0;padding:0}html{font-size:112.5%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth}@media (max-width: 639px){html{font-size:106.25%}}html,body{height:100%}body{line-height:var(--leading-normal, 1.5);font-family:var(--font-mono, monospace);font-size:var(--text-base, 1rem);color:var(--text-primary);background-color:var(--bg-primary);transition:background-color .3s var(--ease-out),color .3s var(--ease-out)}ul,ol{list-style:none}img,picture,video,canvas,svg{display:block;max-width:100%;height:auto}input,button,textarea,select{font:inherit;color:inherit}button{background:none;border:none;cursor:pointer}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}a{color:inherit;text-decoration:none}table{border-collapse:collapse;border-spacing:0}#root,#__next{isolation:isolate}:focus-visible{outline:2px solid var(--interactive);outline-offset:4px}:focus:not(:focus-visible){outline:none}@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}}@layer base{h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:500;line-height:var(--leading-tight);letter-spacing:-.02em}h1{font-size:clamp(var(--text-4xl),5vw,var(--text-6xl));margin-block-end:var(--space-6)}h2{font-size:clamp(var(--text-3xl),4vw,var(--text-5xl));margin-block-end:var(--space-5)}h3{font-size:clamp(var(--text-2xl),3vw,var(--text-4xl));margin-block-end:var(--space-4)}h4{font-size:clamp(var(--text-xl),2.5vw,var(--text-3xl));margin-block-end:var(--space-3)}h5{font-size:clamp(var(--text-lg),2vw,var(--text-2xl));margin-block-end:var(--space-3)}h6{font-size:clamp(var(--text-base),1.5vw,var(--text-xl));margin-block-end:var(--space-2)}body{font-family:var(--font-serif)}p{font-family:var(--font-serif);font-size:var(--text-base);line-height:var(--leading-relaxed);margin-block-end:var(--space-4)}p:last-child{margin-block-end:0}.font-serif{font-family:var(--font-serif)}.font-display{font-family:var(--font-display)}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.text-3xl{font-size:var(--text-3xl)}.text-4xl{font-size:var(--text-4xl)}.text-5xl{font-size:var(--text-5xl)}.text-6xl{font-size:var(--text-6xl)}.font-regular{font-weight:var(--font-regular)}.font-bold{font-weight:var(--font-bold)}.leading-tight{line-height:var(--leading-tight)}.leading-normal{line-height:var(--leading-normal)}.leading-relaxed{line-height:var(--leading-relaxed)}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.text-muted{color:var(--text-muted)}.fluid-text{font-size:clamp(var(--text-base),2vw,var(--text-lg))}.fluid-heading{font-size:clamp(var(--text-2xl),4vw,var(--text-4xl))}.fluid-display{font-size:clamp(var(--text-4xl),6vw,var(--text-6xl))}}@layer layout{:root{--frame-size: 12px;--frame-size-x: 10px;--frame-size-y: 0px}@media (min-width: 640px){:root{--frame-size: 16px;--frame-size-x: 16px;--frame-size-y: 16px}}@media (min-width: 1024px){:root{--frame-size: 20px;--frame-size-x: 20px;--frame-size-y: 20px}}html{scroll-behavior:smooth}@media (min-width: 640px){html{scroll-snap-type:y mandatory}}.section-framed{position:relative;min-height:100vh;min-height:100dvh;display:flex;align-items:stretch;padding:var(--frame-size-y) var(--frame-size-x)}@media (min-width: 640px){.section-framed{padding:var(--frame-size);scroll-snap-align:start;scroll-snap-stop:always}}@media (max-width: 639px){.section-framed{min-height:auto}.section-framed:not(.section-contact):not(.section-projects-index):not(.section-project){margin-block-end:var(--space-6)}.section-contact{margin-block-start:var(--space-6)}}.section-framed:before{content:"";position:absolute;inset:var(--frame-size-y) var(--frame-size-x);border:1px solid hsla(30,12%,65%,.55);pointer-events:none;z-index:1}@media (min-width: 640px){.section-framed:before{inset:var(--frame-size)}}.section-framed.section-left{justify-content:flex-start}.section-framed.section-right{justify-content:flex-end}.section-framed.section-full{justify-content:stretch}.section-card{background:#fafaf9e0;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid hsla(30,10%,80%,.6);box-shadow:inset 0 1px #ffffff80,0 4px 24px #38332e0f;padding:var(--space-5) var(--space-4);width:100%;margin:0;display:flex;flex-direction:column;justify-content:center;max-height:none}@media (min-width: 640px){.section-card{padding:var(--space-10) var(--space-8);max-height:calc(100vh - 2 * var(--frame-size));max-height:calc(100dvh - 2 * var(--frame-size))}}@media (min-width: 1024px){.section-card{padding:var(--space-6) var(--space-5)}.section-left .section-card{width:38.2%;border-left:none;border-top-left-radius:0;border-bottom-left-radius:0}.section-right .section-card{width:38.2%;border-right:none;border-top-right-radius:0;border-bottom-right-radius:0}.section-full .section-card{width:100%;border-left:none;border-right:none;border-radius:0}}@media (min-width: 1280px){.section-card{padding:var(--space-6)}}.section-hero .section-card{background:#fafaf9eb}.section-contact .section-card{background:#fafaf9d1}.section-heading{flex-shrink:0}.experience-list,.skills-tiered,.projects-compact{flex:1;overflow-y:auto;mask-image:linear-gradient(to bottom,black calc(100% - var(--space-4)),transparent 100%);-webkit-mask-image:linear-gradient(to bottom,black calc(100% - var(--space-4)),transparent 100%);padding-bottom:var(--space-4)}.experience-list:not(.is-scrollable),.skills-tiered:not(.is-scrollable),.projects-compact:not(.is-scrollable){mask-image:none;-webkit-mask-image:none;padding-bottom:0}@media (max-width: 639px){.experience-list,.skills-tiered,.projects-compact{flex:none;overflow-y:visible;mask-image:none;-webkit-mask-image:none;padding-bottom:0}}.section-framed:not(.section-hero):not(.section-contact) .section-card{justify-content:flex-start}.section-hero .section-card,.section-contact .section-card{max-height:none}.section-hero{min-height:100vh;min-height:100dvh}@media (max-width: 639px){.section-hero{min-height:100vh;min-height:100dvh}.section-hero .section-card{justify-content:center;min-height:calc(100dvh - 2 * var(--frame-size-x))}}@media (min-width: 1024px){.section-hero{align-items:flex-end}.section-hero .section-card{width:38.2%;border-left:none;border-top-left-radius:0;border-bottom-left-radius:0;border-bottom:none;padding-block:var(--space-8)}}.section-contact{min-height:100vh;min-height:100dvh;align-items:flex-end}.section-contact .section-card{height:calc(38.2vh - var(--frame-size));height:calc(38.2dvh - var(--frame-size));min-height:220px;flex:none;padding-block:var(--space-5);border-bottom:none;border-bottom-left-radius:0;border-bottom-right-radius:0;justify-content:center}@media (max-width: 639px){.section-contact{min-height:auto;align-items:stretch}.section-contact .section-card{height:auto;min-height:38.2dvh;flex:none}}@media (min-width: 640px){.section-contact .section-card{padding-block:var(--space-6)}}@media (min-width: 1024px){.section-contact .section-card{height:calc(38.2vh - var(--frame-size));height:calc(38.2dvh - var(--frame-size));padding-block:var(--space-8)}}.section-project{justify-content:stretch}@media (min-width: 1024px){.section-project .section-card{width:100%;border-left:none;border-right:none;border-radius:0}}}@layer components{body:not([data-loading])>*:not(.site-loader){transition:opacity .6s cubic-bezier(.4,0,.2,1)}@media (prefers-reduced-motion: reduce){body:not([data-loading])>*:not(.site-loader){transition:none}}.webgl-canvas{position:fixed;inset:0;width:100%;height:100%;z-index:-1;pointer-events:none}.painting-attribution{position:fixed;bottom:calc(var(--frame-size) + var(--space-3));left:calc(var(--frame-size) + var(--space-3));z-index:1;display:flex;flex-direction:column;gap:2px;opacity:0;transform:translateY(4px);transition:opacity .8s cubic-bezier(.4,0,.2,1),transform .8s cubic-bezier(.4,0,.2,1);pointer-events:none;visibility:hidden}@media (min-width: 1024px){.painting-attribution{visibility:visible}.painting-attribution.is-visible{opacity:.4;transform:translateY(0)}.painting-attribution:hover{opacity:.7}}.painting-attribution.is-transitioning{opacity:.15}.painting-title{font-family:var(--font-serif);font-size:var(--text-xs);font-style:italic;font-weight:400;color:var(--text-secondary);letter-spacing:.01em}.painting-artist{font-family:var(--font-mono);font-size:.625rem;font-weight:400;color:var(--text-tertiary);letter-spacing:.08em;text-transform:uppercase}@media (prefers-reduced-motion: reduce){.painting-attribution{transition:opacity .3s ease;transform:none}}.menu-trigger{position:fixed;top:var(--frame-size);right:var(--frame-size);z-index:var(--z-fixed);width:48px;height:48px;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:6px;cursor:pointer;background:#fafaf9e0;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid hsla(30,10%,80%,.6);border-top:none;border-right:none;border-radius:0;box-shadow:inset 0 1px #ffffff80,0 4px 24px #38332e0f;transition:all var(--transition-base)}@media (max-width: 639px){.menu-trigger{top:var(--space-4);right:var(--space-4);border:1px solid hsla(30,10%,80%,.6);border-radius:var(--border-radius-sm);box-shadow:none;z-index:calc(var(--z-fixed) + 1)}}.menu-trigger:hover{background:#f6f5f4eb;border-color:#bab3abb3}.menu-trigger-line{width:18px;height:1.5px;background:var(--text-primary);transition:all var(--transition-base);transform-origin:center}.menu-trigger.active .menu-trigger-line:first-child{transform:rotate(45deg) translate(2.5px,2.5px)}.menu-trigger.active .menu-trigger-line:last-child{transform:rotate(-45deg) translate(2.5px,-2.5px)}.dropdown-menu{position:fixed;top:calc(var(--frame-size) + 48px);right:var(--frame-size);z-index:var(--z-fixed);background:#fafaf9e0;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid hsla(30,10%,80%,.6);border-top:none;border-right:none;border-radius:0;box-shadow:inset 0 1px #ffffff80,0 4px 24px #38332e0f;padding:var(--space-4) var(--space-5);display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-3);opacity:0;visibility:hidden;transform:translateY(-8px);transition:opacity var(--transition-base),visibility var(--transition-base),transform var(--transition-base)}.dropdown-menu.active{opacity:1;visibility:visible;transform:translateY(0)}@media (max-width: 639px){.dropdown-menu{inset:0;width:100%;height:100vh;height:100dvh;border:none;border-radius:0;background:#fafaf9f5;padding:var(--space-10) var(--space-6);align-items:center;justify-content:center;gap:var(--space-2);transform:translateY(0);opacity:0;visibility:hidden}.dropdown-menu.active{opacity:1;visibility:visible}}.dropdown-link{font-family:var(--font-display);font-size:var(--text-lg);font-weight:400;color:var(--text-secondary);text-decoration:none;transition:color var(--transition-base);position:relative}button.dropdown-link{background:none;border:none;cursor:pointer;text-align:right;width:100%}@media (max-width: 639px){.dropdown-link{font-size:var(--text-2xl);font-weight:500;color:var(--text-primary);padding:var(--space-3) var(--space-4)}}@media (max-width: 767px){[data-change-painting]{display:none}}body.is-painting-transitioning [data-change-painting]{opacity:.5;pointer-events:none;cursor:default}.dropdown-link:after{content:"";position:absolute;bottom:-2px;left:0;width:100%;height:1px;background:var(--accent-primary);transform:scaleX(0);transform-origin:right;transition:transform var(--transition-base)}@media (max-width: 639px){.dropdown-link:after{bottom:0;left:var(--space-4);width:calc(100% - var(--space-8))}}.dropdown-link:hover{color:var(--text-primary)}.dropdown-link:hover:after{transform:scaleX(1);transform-origin:left}@media (max-width: 639px){.dropdown-link:active{color:var(--accent-primary)}.dropdown-menu.active .dropdown-link{animation:navLinkIn .4s cubic-bezier(.4,0,.2,1) backwards}.dropdown-menu.active .dropdown-link:nth-child(1){animation-delay:50ms}.dropdown-menu.active .dropdown-link:nth-child(2){animation-delay:.1s}.dropdown-menu.active .dropdown-link:nth-child(3){animation-delay:.15s}.dropdown-menu.active .dropdown-link:nth-child(4){animation-delay:.2s}.dropdown-menu.active .dropdown-link:nth-child(5){animation-delay:.25s}.dropdown-menu.active .dropdown-link:nth-child(6){animation-delay:.3s}}@keyframes navLinkIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.section-heading{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:600;color:var(--text-primary);margin-block-end:var(--space-6);letter-spacing:-.02em;position:relative;padding-block-end:var(--space-3)}.section-heading:after{content:"";position:absolute;bottom:0;left:0;width:2.5rem;height:1px;background:var(--text-tertiary)}@media (min-width: 640px){.section-heading{font-size:var(--text-3xl);margin-block-end:var(--space-8)}.section-heading:after{width:3rem}}.hero-content{max-width:32rem;display:flex;flex-direction:column;align-items:flex-start;text-align:left;height:100%;min-height:0}.hero-identity{flex:1;display:flex;flex-direction:column;justify-content:flex-end;align-items:flex-start}@media (min-width: 1024px){.hero-content{height:auto}.hero-identity{flex:none}}.hero-index{display:flex;flex-direction:column;gap:var(--space-2);padding-block-start:var(--space-6);padding-block-end:var(--space-2)}@media (min-width: 640px){.hero-index{gap:var(--space-3)}}.hero-index-link{font-family:var(--font-serif);font-size:var(--text-sm);color:var(--text-secondary);text-decoration:none;transition:color var(--transition-base);display:inline-flex;align-items:baseline;gap:var(--space-2)}.hero-index-link:hover{color:var(--text-primary)}.hero-index-num{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary);transition:color var(--transition-base)}.hero-index-link:hover .hero-index-num{color:var(--accent-primary)}.hero-blurb{display:flex;flex-direction:column;gap:var(--space-3);padding-block-start:var(--space-4);padding-block-end:var(--space-2)}.hero-blurb p{font-family:var(--font-serif);font-size:var(--text-sm);line-height:1.6;color:var(--text-secondary);margin:0}.hero-blurb strong{color:var(--text-primary);font-weight:600}@media (min-width: 640px){.hero-blurb{gap:var(--space-4)}.hero-blurb p{font-size:var(--text-base)}}.hero-name{font-family:var(--font-display);font-size:clamp(2.25rem,6vw,3.5rem);font-weight:500;line-height:1.05;letter-spacing:-.03em;margin-block-end:var(--space-4);color:var(--text-primary)}@media (min-width: 1024px){.hero-name{letter-spacing:-.04em}}.hero-name-last{color:var(--text-secondary)}.hero-title{font-family:var(--font-serif);font-size:var(--text-lg);font-style:italic;color:var(--text-tertiary);margin-block-end:0}@media (min-width: 640px){.hero-title{font-size:var(--text-xl)}}.hero-bio{font-family:var(--font-serif);font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);margin-block-end:0;flex-grow:1}@media (min-width: 640px){.hero-bio{font-size:var(--text-base);line-height:1.8}}.hero-links{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-2);padding-block-start:var(--space-4);align-self:flex-end}.hero-links a,.hero-email-btn{font-family:var(--font-serif);font-size:var(--text-sm);font-style:italic;color:var(--text-secondary);text-decoration:underline;text-underline-offset:.15em;background:none;border:none;padding:0;cursor:pointer;transition:color var(--transition-base)}.hero-links a:hover,.hero-email-btn:hover{color:var(--text-primary)}.hero-links-separator{font-family:var(--font-serif);font-size:var(--text-sm);font-style:italic;color:var(--text-tertiary);user-select:none}.hero-email-btn{position:relative}.hero-email-btn.copied:after{content:"Copied!";position:absolute;left:50%;bottom:100%;transform:translate(-50%);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-primary);background:var(--surface-primary);padding:var(--space-1) var(--space-2);border-radius:var(--border-radius-sm);white-space:nowrap;opacity:0;animation:copied-fade 1.5s ease-out forwards}@keyframes copied-fade{0%{opacity:0;transform:translate(-50%) translateY(4px)}15%{opacity:1;transform:translate(-50%) translateY(0)}85%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(-4px)}}@media (min-width: 640px){.hero-links a,.hero-email-btn,.hero-links-separator{font-size:var(--text-base)}}.experience-list{display:flex;flex-direction:column;gap:var(--space-4)}.experience-item{padding-bottom:var(--space-4);border-bottom:1px solid var(--border-subtle);transition:transform var(--transition-base)}.experience-item:last-child{border-bottom:none;padding-bottom:0}.experience-year{display:inline-block;font-family:var(--font-mono);font-size:var(--text-xs);font-weight:700;color:var(--accent-primary);background:var(--accent-subtle);padding:var(--space-1) var(--space-2);border-radius:var(--border-radius-sm);margin-block-end:var(--space-2)}.experience-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:600;color:var(--text-primary);margin:0;margin-block-end:var(--space-1)}.experience-company{font-family:var(--font-serif);font-size:var(--text-sm);color:var(--text-secondary);margin-block-end:var(--space-3);font-style:italic}.experience-description{font-family:var(--font-serif);font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);margin:0}.experience-item{cursor:pointer;position:relative;padding-left:var(--space-3);padding-right:var(--space-5);transition:transform var(--transition-base)}@media (min-width: 640px){.experience-item{padding-left:var(--space-4);padding-right:0}}.experience-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--accent-primary);transform:scaleY(0);transform-origin:bottom;transition:transform .3s cubic-bezier(.4,0,.2,1)}.experience-item:hover:before,.experience-item.is-active:before{transform:scaleY(1);transform-origin:top}.experience-item:hover .experience-title,.experience-item.is-active .experience-title{color:var(--accent-primary)}.experience-item.is-active{border-color:transparent}.experience-detail-content,.experience-detail-panel{display:none}@media (min-width: 1024px){.experience-detail-panel{display:flex;flex-direction:column;position:absolute;top:var(--frame-size);left:var(--frame-size);bottom:var(--frame-size);width:calc(61.8% - var(--frame-size));background:#fafaf9e0;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid hsla(30,10%,80%,.6);border-right:none;box-shadow:inset 0 1px #ffffff80,0 4px 24px #38332e0f;padding:var(--space-8);opacity:0;visibility:hidden;transition:opacity .5s ease-out,visibility .5s ease-out;z-index:2}.experience-detail-panel.is-visible,.experience-detail-panel.is-pinned{opacity:1;visibility:visible}}.panel-close-btn{position:absolute;top:var(--space-4);right:var(--space-4);width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--border-radius-sm);color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-base);opacity:0;pointer-events:none}.experience-detail-panel.is-pinned .panel-close-btn{opacity:1;pointer-events:auto}.panel-close-btn:hover{background:#e8e6e380;color:var(--text-primary)}.panel-content{display:flex;flex-direction:column;height:100%;overflow-y:auto}.panel-header{margin-bottom:var(--space-6);padding-bottom:var(--space-6);border-bottom:1px solid var(--border-subtle)}.panel-title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:600;color:var(--text-primary);margin:0;margin-bottom:var(--space-2)}.panel-company{font-family:var(--font-serif);font-size:var(--text-lg);font-style:italic;color:var(--text-secondary);margin:0;margin-bottom:var(--space-2)}.panel-duration{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--accent-primary);margin:0}.panel-body{flex:1;display:flex;flex-direction:column;gap:var(--space-6)}.panel-description{font-family:var(--font-serif);font-size:var(--text-base);color:var(--text-primary);line-height:var(--leading-relaxed);margin:0}.panel-section-title{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:700;color:var(--accent-primary);text-transform:uppercase;letter-spacing:.08em;margin:0;margin-bottom:var(--space-3)}.panel-responsibilities{font-family:var(--font-serif);font-size:var(--text-base);color:var(--text-primary);line-height:var(--leading-relaxed);margin:0;padding-left:var(--space-5);list-style:disc}.panel-responsibilities li{margin-bottom:var(--space-2)}.panel-responsibilities li:last-child{margin-bottom:0}.panel-tech{font-family:var(--font-serif);font-size:var(--text-base);color:var(--text-secondary);line-height:var(--leading-relaxed);margin:0}.panel-footer{margin-top:auto;padding-top:var(--space-6);border-top:1px solid var(--border-subtle)}.panel-link{display:inline-flex;align-items:center;gap:var(--space-2);font-family:var(--font-serif);font-size:var(--text-sm);color:var(--text-secondary);text-decoration:none;padding:var(--space-2) var(--space-3);border:1px solid var(--border-subtle);border-radius:var(--border-radius-sm);transition:all var(--transition-base)}.panel-link:hover{color:var(--text-primary);border-color:var(--border-emphasis);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.panel-link svg{transition:transform var(--transition-base)}.panel-link:hover svg{transform:translate(2px,-2px)}@media (max-width: 1023px){.experience-item{cursor:pointer}.experience-accordion{display:none;padding-top:var(--space-4);margin-top:var(--space-4);border-top:1px dashed var(--border-subtle)}.experience-item.is-expanded .experience-accordion{display:block}.experience-accordion-section{margin-bottom:var(--space-4)}.experience-accordion-section:last-child{margin-bottom:0}.experience-accordion-title{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:700;color:var(--accent-primary);text-transform:uppercase;letter-spacing:.08em;margin:0;margin-bottom:var(--space-2)}.experience-accordion-content{font-family:var(--font-serif);font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);margin:0}.experience-accordion-description{font-family:var(--font-serif);font-size:var(--text-sm);color:var(--text-primary);line-height:var(--leading-relaxed);margin:0}.experience-accordion-list{font-family:var(--font-serif);font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);margin:0;padding-left:var(--space-4)}.experience-accordion-list li{margin-bottom:var(--space-1)}.experience-accordion-link{display:inline-flex;align-items:center;gap:var(--space-1);font-family:var(--font-serif);font-size:var(--text-sm);color:var(--accent-primary);text-decoration:none}.experience-accordion-link:hover{text-decoration:underline}.experience-item:after{content:"+";position:absolute;right:var(--space-3);top:0;font-family:var(--font-mono);font-size:var(--text-lg);color:var(--text-tertiary);transition:transform var(--transition-base)}.experience-item.is-expanded:after{content:"-"}}.skills-tiered{display:flex;flex-direction:column;gap:var(--space-5)}@media (min-width: 640px){.skills-tiered{gap:var(--space-4)}}.skill-tier{padding-bottom:var(--space-5);border-bottom:1px solid var(--border-subtle)}@media (min-width: 640px){.skill-tier{padding-bottom:var(--space-4)}}.skill-tier:last-child{border-bottom:none;padding-bottom:0}.skill-tier-title{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-primary);text-transform:uppercase;letter-spacing:.08em;margin:0;margin-block-end:var(--space-2);font-weight:700;display:flex;align-items:center;gap:var(--space-2)}@media (min-width: 640px){.skill-tier-title{margin-block-end:var(--space-1)}}.skill-tier-marker{width:6px;height:6px;border-radius:var(--border-radius-full);flex-shrink:0}.skill-tier-marker--primary{background:var(--accent-primary)}.skill-tier-marker--extended{background:transparent;border:1.5px solid var(--accent-primary)}.skill-tier-marker--familiar{background:transparent;border:1px dashed var(--text-tertiary)}.skill-tier-subtitle{font-family:var(--font-serif);font-size:var(--text-xs);font-style:italic;color:var(--text-tertiary);margin:0;margin-block-end:var(--space-4)}@media (min-width: 640px){.skill-tier-subtitle{margin-block-end:var(--space-3)}}.skill-items{display:flex;flex-wrap:wrap;gap:var(--space-3)}@media (min-width: 640px){.skill-items{gap:6px}}.skill-item{font-family:var(--font-serif);font-size:var(--text-sm);color:var(--text-primary);background:transparent;border:1px solid var(--border-default);border-radius:var(--border-radius-sm);padding:var(--space-2) var(--space-3);padding-left:calc(var(--space-3) + 6px);cursor:pointer;transition:all var(--transition-base);position:relative;text-align:left}@media (min-width: 640px){.skill-item{padding:var(--space-1) var(--space-3);padding-left:calc(var(--space-3) + 6px)}}.skill-item:before{content:"";position:absolute;left:6px;top:50%;transform:translateY(-50%) scaleY(0);width:2px;height:calc(100% - 12px);background:var(--accent-primary);border-radius:1px;transform-origin:bottom;transition:transform .25s cubic-bezier(.4,0,.2,1)}.skill-item:hover:before{transform:translateY(-50%) scaleY(1);transform-origin:top}.skill-item:hover{border-color:var(--border-default);color:var(--accent-primary)}.skill-item:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-subtle)}.skill-item:focus:before{transform:translateY(-50%) scaleY(1)}.skill-name{pointer-events:none}.skill-context{display:none}.skill-item.is-expanded{width:100%;flex-direction:column;align-items:flex-start;border-color:var(--border-default);color:var(--accent-primary);padding:var(--space-2) var(--space-3);padding-left:calc(var(--space-3) + 6px)}.skill-item.is-expanded:before{transform:translateY(-50%) scaleY(1);height:calc(100% - 16px)}.skill-item.is-expanded .skill-name{font-weight:500}.skill-item.is-expanded .skill-context{display:block;font-size:var(--text-xs);color:var(--text-secondary);line-height:var(--leading-relaxed);margin-top:var(--space-2);width:100%}.projects-compact{display:flex;flex-direction:column;gap:var(--space-5)}.project-row{padding:var(--space-4);padding-bottom:var(--space-5);border-bottom:1px solid var(--border-subtle);margin-inline:calc(-1 * var(--space-4));border-radius:var(--border-radius-md);transition:background-color var(--transition-base),transform var(--transition-base)}.project-row:hover{background-color:#f4f2f180}.project-row:last-child{border-bottom:none;padding-bottom:var(--space-4)}.project-row-header{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-3);margin-block-end:var(--space-3)}.project-row-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin:0;transition:color var(--transition-base)}.project-row:hover .project-row-title{color:var(--accent-primary)}@media (min-width: 640px){.project-row-title{font-size:var(--text-xl)}}.project-row-tag{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:700;color:var(--accent-primary);background:var(--accent-subtle);padding:var(--space-1) var(--space-2);border-radius:var(--border-radius-sm);flex-shrink:0;text-transform:uppercase;letter-spacing:.03em}.project-row-desc{font-family:var(--font-serif);font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);margin:0}.contact-band{display:flex;flex-direction:column;gap:var(--space-5);text-align:center;padding-block:var(--space-4)}@media (min-width: 640px){.contact-band{flex-direction:row;justify-content:space-between;align-items:center;text-align:left}}.contact-band-left{flex-shrink:0}.contact-band-title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:500;font-style:italic;color:var(--text-primary);margin:0;margin-block-end:var(--space-2)}@media (min-width: 640px){.contact-band-title{font-size:var(--text-3xl)}}.contact-band-subtitle{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--accent-primary);text-transform:uppercase;letter-spacing:.08em;margin:0}.contact-band-right{display:flex;flex-direction:column;gap:var(--space-3)}@media (min-width: 640px){.contact-band-right{align-items:flex-end}}.contact-band-link{font-family:var(--font-serif);font-size:var(--text-base);color:var(--text-primary);text-decoration:none;position:relative;transition:color var(--transition-base)}.contact-band-link:after{content:"";position:absolute;bottom:-2px;left:0;width:100%;height:1px;background:var(--accent-primary);transform:scaleX(0);transform-origin:right;transition:transform var(--transition-base)}.contact-band-link:hover:after{transform:scaleX(1);transform-origin:left}@media (min-width: 640px){.contact-band-link{font-size:var(--text-lg)}}.contact-band-link:hover{color:var(--accent-primary)}.contact-band-social{display:flex;gap:var(--space-3);justify-content:center}@media (min-width: 640px){.contact-band-social{justify-content:flex-end}}.contact-band-social a{font-family:var(--font-serif);font-size:var(--text-sm);color:var(--text-secondary);text-decoration:none;transition:color var(--transition-base)}.contact-band-social a:hover{color:var(--accent-primary)}.contact-separator{color:var(--text-muted)}.contact-footer{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-secondary);text-align:center;margin:0;margin-block-start:var(--space-5);padding-block-start:var(--space-4);border-top:1px solid var(--border-subtle);letter-spacing:.02em}.projects-index-layout{display:flex;flex-direction:column;gap:var(--space-5);height:100%}.projects-index-intro{flex:0 0 auto}.projects-index-description{font-family:var(--font-serif);font-size:var(--text-base);color:var(--text-secondary);line-height:var(--leading-relaxed);margin:0;margin-block-end:var(--space-4)}.projects-index-hint{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary);margin:0}.projects-index-nav{flex:1;display:flex;flex-direction:column;gap:var(--space-2);overflow-y:auto}.project-index-item{display:flex;align-items:baseline;gap:var(--space-3);padding:var(--space-3) 0;text-decoration:none;border:1px solid transparent;border-radius:var(--border-radius-sm);transition:all var(--transition-base);position:relative}@media (min-width: 640px){.project-index-item{padding:var(--space-3) var(--space-4)}}.project-index-item:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%) scaleY(0);width:2px;height:calc(100% - var(--space-4));background:var(--accent-primary);border-radius:1px;transform-origin:bottom;transition:transform .25s cubic-bezier(.4,0,.2,1)}.project-index-item:hover:before{transform:translateY(-50%) scaleY(1);transform-origin:top}.project-index-item:hover{background:#f4f2f180;border-color:var(--border-subtle)}.project-index-num{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--accent-primary);font-weight:700;flex-shrink:0}.project-index-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:500;color:var(--text-primary);transition:color var(--transition-base)}.project-index-item:hover .project-index-title{color:var(--accent-primary)}.section-project{display:flex;align-items:stretch}.section-project .section-card{flex-direction:column}@media (min-width: 640px){.section-project .section-card{padding:var(--space-5)}}@media (min-width: 1024px){.section-project .section-card{flex-direction:row;padding:0}}.project-article{flex:1;display:flex;flex-direction:column;overflow-y:auto;padding-right:var(--space-2)}@media (min-width: 1024px){.project-article{flex:0 0 61.8%;padding:var(--space-6);order:1;mask-image:linear-gradient(to bottom,black calc(100% - var(--space-4)),transparent 100%);-webkit-mask-image:linear-gradient(to bottom,black calc(100% - var(--space-4)),transparent 100%)}}.project-article-header{margin-block-end:var(--space-5);padding-block-end:var(--space-4);border-bottom:1px solid var(--border-subtle)}.project-num{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:700;color:var(--accent-primary);display:block;margin-block-end:var(--space-2)}.project-title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:600;color:var(--text-primary);margin:0;margin-block-end:var(--space-3);letter-spacing:-.02em}@media (min-width: 640px){.project-title{font-size:var(--text-3xl)}}.project-tags{display:flex;flex-wrap:wrap;gap:var(--space-2)}.project-tag{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:700;color:var(--accent-primary);background:var(--accent-subtle);padding:var(--space-1) var(--space-2);border-radius:var(--border-radius-sm);text-transform:uppercase;letter-spacing:.03em}.project-article-content{flex:1}.project-teaser{display:none}.project-description{font-family:var(--font-serif);font-size:var(--text-base);color:var(--text-secondary);line-height:var(--leading-relaxed);margin:0;margin-block-end:var(--space-5)}.project-image{margin:0;margin-block-end:var(--space-5);border-radius:var(--border-radius-md);overflow:hidden;border:1px solid var(--border-subtle)}.project-image img{width:100%;height:auto;display:block}.project-image figcaption{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary);padding:var(--space-2) var(--space-3);background:#f4f2f180;border-top:1px solid var(--border-subtle)}.project-highlights{margin-block-start:var(--space-5);padding-block-start:var(--space-4);border-top:1px dashed var(--border-subtle)}.project-highlights-title{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:700;color:var(--accent-primary);text-transform:uppercase;letter-spacing:.08em;margin:0;margin-block-end:var(--space-3)}.project-highlights-list{font-family:var(--font-serif);font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);margin:0;padding-left:var(--space-4)}.project-highlights-list li{margin-block-end:var(--space-2)}.project-highlights-list li:last-child{margin-block-end:0}.project-meta{display:none}@media (min-width: 1024px){.project-meta{display:block;flex:0 0 38.2%;position:relative;order:2;border-left:1px solid var(--border-subtle)}}.project-meta-content{position:sticky;top:var(--space-6);padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-5)}.project-meta-label{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:700;color:var(--accent-primary);text-transform:uppercase;letter-spacing:.08em;margin:0;margin-block-end:var(--space-2)}.project-meta-value{font-family:var(--font-serif);font-size:var(--text-sm);color:var(--text-secondary);margin:0}.project-tech-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-1)}.project-tech-list li{font-family:var(--font-serif);font-size:var(--text-sm);color:var(--text-secondary)}.project-meta-links{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-2);margin-block-start:auto;padding-block-start:var(--space-4)}.project-link{display:inline-flex;align-items:center;gap:var(--space-2);font-family:var(--font-serif);font-size:var(--text-sm);color:var(--text-secondary);text-decoration:none;padding:var(--space-2) var(--space-3);border:1px solid var(--border-subtle);border-radius:var(--border-radius-sm);transition:all var(--transition-base);width:fit-content}.project-link:hover{color:var(--text-primary);border-color:var(--border-emphasis);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.project-meta-note{font-family:var(--font-mono);font-size:var(--text-xs);font-style:italic;color:var(--text-tertiary);margin:0;margin-block-start:var(--space-3)}.project-link svg{width:14px;height:14px;transition:transform var(--transition-base)}.project-link:hover svg{transform:translate(2px,-2px)}.project-meta-mobile{display:flex;flex-wrap:wrap;gap:var(--space-4);margin-block-end:var(--space-5);padding-block-end:var(--space-4);border-bottom:1px solid var(--border-subtle)}@media (min-width: 1024px){.project-meta-mobile{display:none}}.project-meta-mobile-section{flex:1 1 45%;min-width:120px}.project-meta-mobile-links{display:flex;gap:var(--space-2);flex-wrap:wrap;margin-block-start:var(--space-3)}@media (max-width: 1023px){.project-article{cursor:pointer;position:relative}.project-article-header:after{content:"+";position:absolute;right:var(--space-3);top:0;font-family:var(--font-mono);font-size:var(--text-lg);color:var(--text-tertiary);transition:transform var(--transition-base)}.project-article.is-expanded .project-article-header:after{content:"-"}.project-teaser{font-family:var(--font-serif);font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);margin:0;margin-block-start:var(--space-3)}.project-article.is-expanded .project-teaser,.project-meta-mobile,.project-article-content{display:none}.project-article.is-expanded .project-meta-mobile,.project-article.is-expanded .project-article-content{display:block;animation:projectAccordionIn .3s var(--ease-out)}}@keyframes projectAccordionIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.project-side-nav{position:fixed;right:calc(var(--frame-size) + var(--space-4));top:50%;transform:translateY(-50%);z-index:var(--z-fixed);display:none;flex-direction:column;align-items:flex-end;gap:var(--space-3);opacity:0;visibility:hidden;transition:opacity var(--transition-base),visibility var(--transition-base)}@media (min-width: 1024px){.project-side-nav{display:flex}}.project-side-nav.is-visible{opacity:1;visibility:visible}.project-side-nav-item{display:flex;flex-direction:row-reverse;align-items:center;justify-content:flex-start;gap:var(--space-2);text-decoration:none;padding:var(--space-2);transition:all var(--transition-base)}.project-side-nav-num{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:700;color:var(--text-tertiary);transition:color var(--transition-base)}.project-side-nav-item:hover .project-side-nav-num,.project-side-nav-item.is-active .project-side-nav-num{color:var(--accent-primary)}.project-side-nav-line{width:24px;height:2px;background:var(--text-tertiary);transition:all var(--transition-base);transform-origin:right}.project-side-nav-item:hover .project-side-nav-line,.project-side-nav-item.is-active .project-side-nav-line{width:40px;background:var(--accent-primary)}.project-dots-nav{display:none}.project-dots-nav.is-visible{opacity:1;visibility:visible}.project-dot{width:10px;height:10px;border-radius:var(--border-radius-full);background:var(--text-tertiary);border:none;cursor:pointer;transition:all var(--transition-base);padding:0}.project-dot:hover,.project-dot.is-active{background:var(--accent-primary);transform:scale(1.2)}}@layer components{.chat-fab{position:fixed;bottom:var(--frame-size);right:var(--frame-size);z-index:var(--z-fixed);width:48px;height:48px;display:flex;justify-content:center;align-items:center;cursor:pointer;background:#fafaf9e0;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid hsla(30,10%,80%,.6);border-bottom:none;border-right:none;border-radius:0;box-shadow:inset 0 1px #ffffff80,0 4px 24px #38332e0f;transition:all var(--transition-base);padding:0}.chat-fab:hover{background:#f6f5f4eb;border-color:#bab3abb3}.chat-fab-icon{width:22px;height:22px;color:var(--text-primary);position:absolute;transition:opacity var(--transition-base),transform var(--transition-base)}.chat-fab.active .chat-fab-icon{opacity:0;transform:scale(.5)}.chat-fab-line{width:18px;height:1.5px;background:var(--text-primary);transition:all var(--transition-base);transform-origin:center;opacity:0;position:absolute}.chat-fab.active .chat-fab-line{opacity:1}.chat-fab.active .chat-fab-line:first-of-type{transform:rotate(45deg)}.chat-fab.active .chat-fab-line:last-of-type{transform:rotate(-45deg)}.chat-fab.is-hidden{opacity:0;pointer-events:none}@media (max-width: 639px){.chat-fab{bottom:var(--space-4);right:var(--space-4);border:1px solid hsla(30,10%,80%,.6);border-radius:var(--border-radius-sm);box-shadow:none}}.chat-panel{position:fixed;bottom:calc(var(--frame-size) + 48px);right:var(--frame-size);z-index:var(--z-modal);width:460px;height:600px;display:flex;flex-direction:column;background:#fafaf9eb;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid hsla(30,10%,80%,.6);border-bottom:none;border-right:none;border-radius:0;box-shadow:inset 0 1px #ffffff80,0 4px 24px #38332e0f;opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity var(--transition-base),visibility var(--transition-base),transform var(--transition-base);overflow:hidden}.chat-panel.is-open{opacity:1;visibility:visible;transform:translateY(0)}@media (max-width: 639px){.chat-panel{inset:0;width:100%;height:100vh;height:100dvh;border:none;border-radius:0;transform:translateY(100%);transition:opacity .3s var(--ease-out),visibility .3s var(--ease-out),transform .3s var(--ease-out)}.chat-panel.is-open{transform:translateY(0)}.chat-panel.is-dragging{transition:none}.chat-header{position:relative;padding-top:calc(var(--space-3) + env(safe-area-inset-top,0px))}.chat-header:before{content:"";position:absolute;top:calc(var(--space-2) + env(safe-area-inset-top,0px));left:50%;transform:translate(-50%);width:32px;height:3px;border-radius:2px;background:var(--border-default)}.chat-input-area{padding-bottom:calc(var(--space-3) + env(safe-area-inset-bottom,0px))}}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-subtle);flex-shrink:0}.chat-header-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin:0;letter-spacing:-.01em}.chat-close-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--border-radius-sm);color:var(--text-tertiary);cursor:pointer;transition:background var(--transition-base),color var(--transition-base);padding:0}.chat-close-btn:hover{background:#e8e6e380;color:var(--text-primary)}.chat-close-btn svg{width:16px;height:16px}.chat-messages{flex:1;overflow-y:auto;padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3);min-height:0}.chat-message{display:flex;max-width:88%}.chat-message--user{align-self:flex-end}.chat-message--assistant{align-self:flex-start}.chat-message-bubble{font-family:var(--font-serif);font-size:var(--text-sm);line-height:var(--leading-relaxed);padding:var(--space-2) var(--space-3);border-radius:var(--border-radius-md);word-break:break-word}.chat-message--user .chat-message-bubble{background:var(--accent-primary);color:#fafafa;border-bottom-right-radius:var(--space-1)}.chat-message--assistant .chat-message-bubble{background:#edebe9b3;color:var(--text-primary);border-bottom-left-radius:var(--space-1)}.chat-message-bubble p{margin:0}.chat-message-bubble p+p{margin-top:var(--space-2)}.chat-message-bubble strong{font-weight:700}.chat-message-bubble em{font-style:italic}.chat-message-bubble code{font-family:var(--font-mono);font-size:.85em;background:#73808c1f;padding:.1em .35em;border-radius:3px}.chat-message--user .chat-message-bubble code{background:#ffffff2e}.chat-message-bubble pre{margin:var(--space-2) 0;padding:var(--space-2) var(--space-3);background:#22262a0f;border-radius:var(--border-radius-sm);overflow-x:auto;font-family:var(--font-mono);font-size:.8em;line-height:1.5}.chat-message--user .chat-message-bubble pre{background:#00000026}.chat-message-bubble pre code{background:none;padding:0}.chat-message-bubble ul,.chat-message-bubble ol{margin:var(--space-2) 0;padding-left:var(--space-4)}.chat-message-bubble li{margin-bottom:var(--space-1)}.chat-message-bubble a{color:inherit;text-decoration:underline;text-underline-offset:.15em}.chat-message--assistant .chat-message-bubble a{color:var(--accent-primary)}.chat-message-bubble a:hover{opacity:.8}.chat-message-bubble h1,.chat-message-bubble h2,.chat-message-bubble h3,.chat-message-bubble h4,.chat-message-bubble h5,.chat-message-bubble h6{font-family:var(--font-display);font-weight:600;line-height:var(--leading-tight);margin:var(--space-2) 0 var(--space-1)}.chat-message-bubble h1{font-size:1.2em}.chat-message-bubble h2{font-size:1.15em}.chat-message-bubble h3{font-size:1.1em}.chat-message-bubble h4{font-size:1.05em}.chat-message-bubble h5,.chat-message-bubble h6{font-size:1em}.chat-message-bubble :first-child{margin-top:0}.chat-message-bubble blockquote{margin:var(--space-2) 0;padding:var(--space-1) 0 var(--space-1) var(--space-3);border-left:2px solid currentColor;opacity:.75}.chat-message-bubble blockquote p{margin:0}.chat-message-bubble hr{border:none;border-top:1px solid currentColor;opacity:.2;margin:var(--space-2) 0}.chat-message-bubble del{opacity:.6}.chat-message-bubble table{display:block;overflow-x:auto;margin:var(--space-2) 0;font-size:.85em}.chat-message-bubble th,.chat-message-bubble td{padding:var(--space-1) var(--space-2);text-align:left;white-space:nowrap}.chat-message-bubble th{font-weight:600}.chat-message--assistant .chat-message-bubble th,.chat-message--assistant .chat-message-bubble td{border-bottom:1px solid hsla(30,10%,20%,.15);border-right:1px solid hsla(30,10%,20%,.15)}.chat-message--user .chat-message-bubble th,.chat-message--user .chat-message-bubble td{border-bottom:1px solid hsla(0,0%,100%,.2);border-right:1px solid hsla(0,0%,100%,.2)}.chat-message-bubble .task-list-item{list-style:none;margin-left:calc(-1 * var(--space-4))}.chat-message-bubble .task-list-item input[type=checkbox]{margin-right:var(--space-1);pointer-events:none}.chat-typing{display:flex;align-self:flex-start;gap:4px;padding:var(--space-2) var(--space-3);background:#edebe9b3;border-radius:var(--border-radius-md);border-bottom-left-radius:var(--space-1)}.chat-typing-dot{width:6px;height:6px;border-radius:var(--border-radius-full);background:var(--text-tertiary);animation:chatTypingBounce 1.4s ease-in-out infinite}.chat-typing-dot:nth-child(2){animation-delay:.2s}.chat-typing-dot:nth-child(3){animation-delay:.4s}@keyframes chatTypingBounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}.chat-message,.chat-typing{animation:chatMessageIn .25s var(--ease-out) both}@keyframes chatMessageIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.chat-input-area{display:flex;align-items:flex-end;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-top:1px solid var(--border-subtle);flex-shrink:0}.chat-input{flex:1;font-family:var(--font-serif);font-size:var(--text-sm);color:var(--text-primary);background:transparent;border:1px solid var(--border-default);border-radius:var(--border-radius-md);padding:var(--space-2) var(--space-3);resize:none;min-height:38px;max-height:120px;line-height:var(--leading-normal);outline:none;transition:border-color var(--transition-base)}.chat-input::placeholder{color:var(--text-muted);font-style:italic}.chat-input:focus{border-color:var(--accent-primary)}.chat-input:disabled{opacity:.5;cursor:not-allowed}.chat-send-btn{height:calc(var(--text-sm) * var(--leading-normal) + 2 * var(--space-2));aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:var(--accent-primary);color:#fafafa;border:none;border-radius:var(--border-radius-md);cursor:pointer;transition:background var(--transition-base),opacity var(--transition-base);flex-shrink:0;padding:0}.chat-send-btn:hover{background:var(--accent-hover)}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.chat-send-btn svg{width:16px;height:16px}.chat-status{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary);text-align:center;padding:var(--space-2) var(--space-3);align-self:center}.chat-status--error{color:#b82e2e}.chat-status--rate-limit{color:var(--accent-primary)}@media (max-width: 639px){.chat-close-btn{width:44px;height:44px}.chat-send-btn{min-width:44px;min-height:44px}}@media (prefers-reduced-motion: reduce){.chat-panel{transition:opacity .15s ease,visibility .15s ease;transform:none}.chat-panel.is-open{transform:none}.chat-fab{transition:opacity var(--transition-base)}.chat-typing-dot{animation:none;opacity:.6}.chat-message,.chat-typing{animation:none}}}@layer animations{@keyframes gentle-reveal{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slide-in-left{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes slide-in-right{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}.name-reveal{opacity:0;animation:gentle-reveal 1s cubic-bezier(.23,1,.32,1) forwards}.name-reveal-delay-1{animation-delay:.2s}.name-reveal-delay-2{animation-delay:.4s}.name-reveal-delay-3{animation-delay:.6s}.fade-in{animation:fade-in 1s var(--ease-out)}.fade-in-slow{animation:fade-in 1.4s var(--ease-out)}.scale-in{animation:scale-in .8s var(--ease-out)}.slide-in-left{animation:slide-in-left 1s var(--ease-out)}.slide-in-right{animation:slide-in-right 1s var(--ease-out)}.reveal{opacity:0;transform:translateY(40px);transition:opacity .8s cubic-bezier(.23,1,.32,1),transform .8s cubic-bezier(.23,1,.32,1)}.reveal.is-visible{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:.15s}.reveal-delay-2{transition-delay:.3s}.reveal-delay-3{transition-delay:.45s}.reveal-delay-4{transition-delay:.6s}.experience-item:nth-child(1).reveal{transition-delay:0ms}.experience-item:nth-child(2).reveal{transition-delay:.1s}.experience-item:nth-child(3).reveal{transition-delay:.2s}.project-row:nth-child(1).reveal{transition-delay:0ms}.project-row:nth-child(2).reveal{transition-delay:.1s}.project-row:nth-child(3).reveal{transition-delay:.2s}.project-row:nth-child(4).reveal{transition-delay:.3s}.skill-group:nth-child(1).reveal{transition-delay:0ms}.skill-group:nth-child(2).reveal{transition-delay:.1s}.skill-group:nth-child(3).reveal{transition-delay:.2s}.hover-lift{transition:transform var(--transition-slow) var(--ease-out),box-shadow var(--transition-slow) var(--ease-out)}.hover-lift:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.hover-lift-strong{transition:transform var(--transition-slow) var(--ease-out),box-shadow var(--transition-slow) var(--ease-out)}.hover-lift-strong:hover{transform:translateY(-6px) scale(1.02);box-shadow:var(--shadow-xl)}.hover-scale{transition:transform var(--transition-base) var(--ease-out)}.hover-scale:hover{transform:scale(1.05)}.hover-brighten{transition:filter var(--transition-base) var(--ease-out)}.hover-brighten:hover{filter:brightness(1.1)}.active-scale{transition:transform var(--transition-fast) var(--ease-out)}.active-scale:active{transform:scale(.98)}.transition-colors{transition:background-color var(--transition-base) var(--ease-out),color var(--transition-base) var(--ease-out),border-color var(--transition-base) var(--ease-out)}.transition-all{transition:all var(--transition-base) var(--ease-out)}.transition-transform{transition:transform var(--transition-base) var(--ease-out)}.transition-opacity{transition:opacity var(--transition-base) var(--ease-out)}.skeleton{background:linear-gradient(90deg,var(--bg-secondary) 0%,var(--bg-subtle) 50%,var(--bg-secondary) 100%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.reveal{opacity:1!important;transform:none!important}.name-reveal{opacity:1!important;animation:none!important}.hover-lift:hover,.hover-lift-strong:hover{transform:none!important}}.no-animation{animation:none!important;transition:none!important}.delay-100{animation-delay:.1s}.delay-200{animation-delay:.2s}.delay-300{animation-delay:.3s}.delay-400{animation-delay:.4s}.delay-500{animation-delay:.5s}.delay-600{animation-delay:.6s}}@layer utilities{.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.not-sr-only{position:static;width:auto;height:auto;padding:0;margin:0;overflow:visible;clip:auto;white-space:normal}.border{border:1px solid var(--border-default)}.border-subtle{border:1px solid var(--border-subtle)}.border-emphasis{border:1px solid var(--border-emphasis)}.border-top{border-top:1px solid var(--border-default)}.border-bottom{border-bottom:1px solid var(--border-default)}.rounded-sm{border-radius:var(--border-radius-sm)}.rounded{border-radius:var(--border-radius-md)}.rounded-lg{border-radius:var(--border-radius-lg)}.rounded-xl{border-radius:var(--border-radius-xl)}.rounded-full{border-radius:var(--border-radius-full)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow,.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-xl{box-shadow:var(--shadow-xl)}.shadow-none{box-shadow:none}.backdrop-blur{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.backdrop-blur-sm{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.backdrop-blur-lg{backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}.opacity-0{opacity:0}.opacity-25{opacity:.25}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.opacity-100{opacity:1}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.cursor-pointer{cursor:pointer}.cursor-default{cursor:default}.cursor-not-allowed{cursor:not-allowed}.select-none{user-select:none}.select-text{user-select:text}.select-all{user-select:all}.object-contain{object-fit:contain}.object-cover{object-fit:cover}.object-fill{object-fit:fill}.isolate{isolation:isolate}.will-change-transform{will-change:transform}.will-change-opacity{will-change:opacity}.no-tap-highlight{-webkit-tap-highlight-color:transparent}.smooth-scroll{scroll-behavior:smooth}*{scrollbar-width:none}*::-webkit-scrollbar{display:none}}
