.portfolio-page{min-height:100vh;position:relative}.portfolio-shell{width:100%;max-width:none;margin:0;padding:0 18px 72px;position:relative}@media (width>=900px){.portfolio-shell{padding:0 18px 72px}}.portfolio-nav{z-index:12;opacity:0;width:calc(100% + 36px);box-shadow:none;will-change:transform, opacity;background:0 0;border:0;border-radius:0;grid-template-columns:auto 1fr;align-items:center;gap:16px;margin:0 -18px;padding:20px 18px 16px;transition:none;display:grid;position:sticky;top:0;transform:translateY(-110%)}.portfolio-nav:before{content:"";z-index:-1;-webkit-backdrop-filter:blur(28px)saturate(180%);opacity:0;pointer-events:none;background:#eef1f7f0;transition:opacity .42s,background-color .42s,-webkit-backdrop-filter .42s,backdrop-filter .42s;position:absolute;inset:0}.portfolio-nav.is-scrolled:before{opacity:1}.portfolio-nav.is-top-page:before{opacity:0}.portfolio-nav.is-visible{opacity:1;transition:transform .95s cubic-bezier(.22,1,.36,1),opacity .95s cubic-bezier(.22,1,.36,1);transform:translateY(0)}.portfolio-nav:not(.is-visible){opacity:0;transform:translateY(-110%)}html.dark .portfolio-nav:before,[data-theme=dark] .portfolio-nav:before{background:#0c182ef0}html.dark .portfolio-nav.is-top-page:before,[data-theme=dark] .portfolio-nav.is-top-page:before{opacity:0}.nav-cluster{flex-wrap:wrap;justify-self:end;align-items:center;gap:14px;display:inline-flex}.portfolio-nav.is-visible .brand-mark{animation:.76s cubic-bezier(.22,1,.36,1) both nav-enter}.nav-actions{align-items:center;gap:8px;margin-left:auto;display:inline-flex}.portfolio-nav.is-visible .nav-actions{animation:.76s cubic-bezier(.22,1,.36,1) both nav-enter}.brand-mark{clip-path:none;width:34px;height:34px;color:var(--text-main);box-shadow:none;background:0 0;border:0;border-radius:0;place-items:center;text-decoration:none;display:grid}.brand-mark svg{width:100%;height:100%}.brand-mark__icon{overflow:visible}.brand-mark__asterisk,.brand-mark__circle{transform-origin:50%;will-change:transform;transition:transform 1.8s cubic-bezier(.22,1,.36,1),opacity 1.8s cubic-bezier(.22,1,.36,1)}.brand-mark__circle{opacity:0;transform-box:fill-box;transform:scale(.55)rotate(0)}.brand-mark__asterisk{opacity:1;transform-box:fill-box;transform:scale(1)rotate(0)}.brand-mark:hover .brand-mark__asterisk{opacity:0;transform:rotate(540deg)scale(.45)}.brand-mark:hover .brand-mark__circle{opacity:1;transform:scale(1)rotate(540deg)}.portfolio-nav__links{font-family:var(--font-mono);flex-wrap:wrap;justify-content:center;gap:16px 24px;font-size:.9rem;display:flex}.portfolio-nav.is-visible .portfolio-nav__links a{animation:.76s cubic-bezier(.22,1,.36,1) backwards nav-enter;animation-delay:calc(var(--nav-index,0) * .14s + .16s)}.portfolio-nav__links a{color:var(--text-muted);gap:8px;text-decoration:none;transition:color .25s cubic-bezier(.645,.045,.355,1),transform .25s cubic-bezier(.645,.045,.355,1);display:inline-flex}.portfolio-nav__links a:hover{color:var(--button-accent);transform:translateY(-4px)}.portfolio-nav__links a.is-active,.portfolio-nav__links span{color:var(--text-main)}.cert-link{font-weight:700;text-decoration:none;transition:transform .4s cubic-bezier(.645,.045,.355,1);display:inline-block;position:relative}.cert-link:hover{transform:translateY(-4px)}.theme-button{isolation:isolate;color:var(--text-main);width:32px;height:32px;font-family:var(--font-mono);cursor:pointer;background:0 0;border:0;border-radius:0;justify-content:center;align-items:center;padding:0;font-size:.82rem;transition:none;display:inline-flex;position:relative;overflow:visible;transform:none}.menu-button{isolation:isolate;border:1px solid var(--button-accent);color:var(--button-accent);cursor:pointer;z-index:10000;background:0 0;border-radius:999px;justify-content:center;align-items:center;width:40px;height:40px;padding:0;transition:all .25s cubic-bezier(.645,.045,.355,1);display:none;position:relative;overflow:visible;transform:translate(0)}.menu-button:hover,.menu-button:focus-visible{color:var(--button-accent);border-color:var(--button-accent);background:0 0;transform:translate(0)}.hamburger,.hamburger-box{width:30px;height:24px;display:inline-block;position:relative}.hamburger-inner{background-color:currentColor;border-radius:4px;width:30px;height:2px;transition:transform .22s cubic-bezier(.55,.055,.675,.19);position:absolute;top:50%;right:0;transform:rotate(0)}.hamburger-inner:before,.hamburger-inner:after{content:"";background-color:currentColor;border-radius:4px;height:2px;transition-property:transform;transition-duration:.15s;transition-timing-function:ease;display:block;position:absolute;left:auto;right:0}.hamburger-inner:before{width:120%;transition:top .1s ease-in .25s,opacity .1s ease-in;top:-10px}.hamburger-inner:after{width:80%;transition:bottom .1s ease-in .25s,transform .22s cubic-bezier(.55,.055,.675,.19);bottom:-10px}.menu-button.is-active .hamburger-inner{transition-delay:.12s;transition-timing-function:cubic-bezier(.215,.61,.355,1);transform:rotate(225deg)}.menu-button.is-active .hamburger-inner:before{opacity:0;transition:top .1s ease-out,opacity .1s ease-out .12s;top:0}.menu-button.is-active .hamburger-inner:after{width:100%;transition:bottom .1s ease-out,transform .22s cubic-bezier(.215,.61,.355,1) .12s;bottom:0;transform:rotate(-90deg)}.mobile-nav-panel{display:none}.theme-button__icon{place-items:center;width:22px;height:22px;display:grid}.theme-button__icon svg{width:22px;height:22px}.portfolio-content{align-content:center;gap:48px;width:100%;max-width:1280px;min-height:calc(100vh - 96px);margin:0 auto;padding:56px 0 0;display:grid;position:relative}@media (width>=900px){.portfolio-content{gap:64px;padding-top:88px}}.hero{opacity:0;max-width:760px}.hero.is-visible{opacity:1}.hero__eyebrow{color:var(--text-main);font-family:var(--font-mono);opacity:0;margin-bottom:12px;font-size:.95rem;transform:translateY(20px)}.hero__eyebrow.is-visible{animation:.7s cubic-bezier(.22,1,.36,1) both hero-text-rise}.hero__title{color:var(--text-main);letter-spacing:-.06em;opacity:0;font-size:clamp(3rem,9vw,6.2rem);line-height:.95;transform:translateY(20px)}.reveal-on-scroll{opacity:0;will-change:opacity, transform;transition:opacity .8s cubic-bezier(.645,.045,.355,1),transform .8s cubic-bezier(.645,.045,.355,1);transform:translateY(40px)}.reveal-on-scroll.is-revealed{opacity:1;transform:translateY(0)}.hero__title.is-visible{animation:.7s cubic-bezier(.22,1,.36,1) .12s both hero-text-rise}.hero__subtitle{color:var(--text-muted);letter-spacing:-.05em;opacity:0;margin-top:14px;font-size:clamp(2rem,5vw,4rem);line-height:1.04;transform:translateY(20px)}.hero__subtitle.is-visible{animation:.7s cubic-bezier(.22,1,.36,1) .24s both hero-text-rise}.hero__copy{opacity:0;max-width:620px;margin-top:24px;font-size:1.05rem;transform:translateY(20px)}.hero__copy.is-visible{animation:.7s cubic-bezier(.22,1,.36,1) .36s both hero-text-rise}.hero__actions{flex-wrap:wrap;gap:14px;margin-top:34px;display:flex}.hero__cta{opacity:0;transform:translateY(10px);transition:opacity .56s cubic-bezier(.22,1,.36,1),transform .56s cubic-bezier(.22,1,.36,1),box-shadow .25s cubic-bezier(.645,.045,.355,1),color .25s cubic-bezier(.645,.045,.355,1),border-color .25s cubic-bezier(.645,.045,.355,1)!important}.hero__cta.is-visible{opacity:1;transform:translateY(0)}.button{min-width:170px;font-family:var(--font-mono);border:1px solid var(--button-accent);color:var(--button-accent);background:0 0;border-radius:0;justify-content:center;align-items:center;padding:14px 22px;line-height:1;text-decoration:none;display:inline-flex;position:relative}.button--primary{background:var(--button-accent);color:var(--bg-main);box-shadow:none}.button--ghost{border-color:var(--button-accent);color:var(--button-accent);background:0 0}.button--contact{isolation:isolate;background:var(--bg-main);color:var(--button-accent);border-color:var(--button-accent);z-index:1;padding:1.25rem 1.75rem;transition:all .25s cubic-bezier(.645,.045,.355,1);overflow:visible;transform:translate(0)}.button--contact:after{content:"";z-index:-1;background:var(--button-accent);opacity:0;pointer-events:none;transition:all .25s cubic-bezier(.645,.045,.355,1);position:absolute;inset:0;transform:translate(5px,5px)}.button--contact:hover,.button--contact:focus-visible{transform:translate(5px,5px)}.button--contact:hover:after,.button--contact:focus-visible:after{opacity:1}.feature-section,.contact-section,.about-section{gap:26px;display:grid}.reveal-group{opacity:0;will-change:opacity, transform;transition:opacity .72s cubic-bezier(.22,1,.36,1),transform .72s cubic-bezier(.22,1,.36,1);transform:translateY(42px)}.reveal-group--about .section-heading--about,.reveal-group--about .about-layout,.reveal-group--about .portrait-swap,.reveal-group--about .about-card{opacity:0;transform:translateY(24px)}.reveal-group--about.is-revealed .section-heading--about{animation:.7s cubic-bezier(.22,1,.36,1) both about-fade-rise}.reveal-group--about.is-revealed .about-layout{animation:.8s cubic-bezier(.22,1,.36,1) .12s both about-fade-rise}.reveal-group--about.is-revealed .portrait-swap{animation:.76s cubic-bezier(.22,1,.36,1) .22s both about-card-rise}.reveal-group--about.is-revealed .about-card{animation:.76s cubic-bezier(.22,1,.36,1) both about-card-rise}.reveal-group--about.is-revealed .about-card--bio{animation-delay:.16s}.reveal-group--about.is-revealed .about-card--skills:first-of-type{animation-delay:.26s}.reveal-group--about.is-revealed .about-card--skills:nth-of-type(2){animation-delay:.34s}.about-layout{grid-template-columns:minmax(0,1fr) minmax(280px,360px);align-items:flex-start;gap:clamp(28px,5vw,60px);display:grid}.about-copy{order:1;gap:26px;display:grid}.about-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;display:grid}.about-skills{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:26px;display:grid}.portrait-swap{order:2;justify-self:end;width:100%;max-width:360px}.portrait-swap__frame{aspect-ratio:.92;width:100%;box-shadow:none;isolation:isolate;background:0 0;border:0;border-radius:0;padding:0;transition:transform .52s cubic-bezier(.22,1,.36,1);position:relative;overflow:visible;transform:translate(0)}.portrait-swap__frame:after{content:"";border-right:4px solid var(--portrait-border);border-bottom:4px solid var(--portrait-border);border-left:4px solid var(--portrait-border);border-top:4px solid var(--portrait-border);z-index:0;pointer-events:none;border-radius:0;transition:transform .52s cubic-bezier(.22,1,.36,1);position:absolute;inset:0;transform:translate(14px,14px)}.portrait-swap:hover .portrait-swap__frame{transform:translate(-4px,-4px)}.portrait-swap:hover .portrait-swap__frame:after{transform:translate(22px,22px)}.portrait-swap{cursor:pointer;display:inline-block;position:relative}.portrait-swap__image{object-fit:cover;z-index:1;will-change:transform, filter;backface-visibility:hidden;transform-origin:50%;filter:grayscale()contrast();border-radius:0;width:100%;height:100%;transition:transform .25s cubic-bezier(.645,.045,.355,1),filter .25s cubic-bezier(.645,.045,.355,1);position:absolute;inset:0;transform:translate(0)}.portrait-swap:hover .portrait-swap__image{filter:grayscale(0%)contrast();transform:translate(-5px,-5px)}.about-card{-webkit-backdrop-filter:none;backdrop-filter:none;box-shadow:none;background:0 0;border:0;border-radius:0;padding:0}.about-card h4{color:var(--text-main);font-size:1.1rem;line-height:1.25}.about-card p{margin-top:0}.about-card--bio p+p{margin-top:18px}.section-heading{align-items:center;gap:16px;width:100%;margin-bottom:40px;display:flex}.section-heading span{color:var(--button-accent)!important;font-size:clamp(1.1rem,2vw,1.4rem)!important;font-family:var(--font-mono)!important;letter-spacing:normal!important;text-transform:none!important;margin-bottom:0!important}.section-heading h3{white-space:nowrap;max-width:none!important;color:var(--text-main)!important;margin:0!important;font-size:clamp(1.5rem,3vw,2rem)!important;font-weight:600!important}.section-heading__line{background:var(--border);flex:1;height:1px;margin-top:2px}@keyframes about-fade-rise{0%{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}@keyframes about-card-rise{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}.about-copy p{font-size:1.08rem;line-height:1.8}.skills-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 14px;margin-top:16px;padding-left:0;list-style:none;display:grid}.skills-list li{color:var(--text-main);padding-left:16px;font-size:.98rem;position:relative}.skills-list li:before{content:"✦";color:var(--text-main);position:absolute;top:0;left:0}.feature-grid{grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:18px;display:grid}.projects-section{--projects-accent:#18bfae;--projects-accent-soft:#18bfae24;--projects-image-start:#d2e2eff5;--projects-image-end:#97b0cafa;--projects-image-border:#50638a2e;--projects-image-shadow:0 30px 70px #30467024;--projects-description-bg:#f6f9fffa;--projects-description-border:#50638a38;--projects-description-shadow:0 18px 42px #30467029;--projects-description-text:var(--text-main);--projects-kicker:var(--projects-accent);--projects-label:var(--text-muted);--projects-link:var(--projects-accent);gap:30px;display:grid}html.dark .projects-section,[data-theme=dark] .projects-section{--projects-accent:#64ffda;--projects-accent-soft:#64ffda1f;--projects-image-start:#245966f5;--projects-image-end:#0f2c48fa;--projects-image-border:#64ffda1f;--projects-image-shadow:0 30px 70px #020c1b9e;--projects-description-bg:#0b1c34fa;--projects-description-border:#64ffda1a;--projects-description-shadow:0 22px 48px #020c1b75;--projects-description-text:#d8e4ff;--projects-kicker:#64ffda;--projects-label:#a7b4c8;--projects-link:#64ffda}.section-heading--projects{align-items:center}.projects-stack{gap:clamp(30px,4vw,56px);display:grid}.project-showcase{align-items:center;gap:22px;display:grid}.project-showcase__media{z-index:1;position:relative}.project-image-link{text-decoration:none;display:block}.project-image-card{aspect-ratio:16/10;background:radial-gradient(circle at 20% 20%, var(--projects-accent-soft), transparent 34%), linear-gradient(135deg, var(--projects-image-start), var(--projects-image-end));width:100%;box-shadow:var(--projects-image-shadow);border:1px solid var(--projects-image-border);filter:grayscale()contrast(1.03)saturate(.85);border-radius:4px;transition:filter .32s cubic-bezier(.22,1,.36,1),transform .32s cubic-bezier(.22,1,.36,1);position:relative;overflow:hidden}.project-image-card:hover{filter:grayscale(0)contrast(1.02)saturate();transform:translateY(-6px)scale(1.01)}.project-image-link:focus-visible .project-image-card{outline:2px solid var(--projects-link);outline-offset:4px}.project-image-card:before{content:"";mix-blend-mode:screen;opacity:.8;background:linear-gradient(#020c1b1f,#020c1b57),repeating-linear-gradient(90deg,#ffffff0a 0 1px,#0000 1px 12px),repeating-linear-gradient(0deg,#ffffff08 0 1px,#0000 1px 12px);position:absolute;inset:0}.project-image-card:after{content:"";background:linear-gradient(120deg,#0000 38%,#64ffda14 58%,#0000 78%);position:absolute;inset:0}.project-image-card__tint{background:radial-gradient(circle, var(--projects-accent-soft), transparent 70%);filter:blur(18px);border-radius:50%;width:58%;height:58%;position:absolute;inset:auto -10% -18% auto}.project-image-card__visual{color:#f2fcfffa;font-family:var(--font-mono);text-align:center;letter-spacing:.08em;text-transform:uppercase;place-items:center;gap:8px;display:grid;position:absolute;inset:0}.project-image-card__visual span{font-size:clamp(2.4rem,9vw,5.4rem);line-height:1}.project-image-card__visual small{color:#e7f1ffc7;letter-spacing:.2em;max-width:75%;font-size:.74rem}.project-showcase__details{z-index:2;justify-items:start;gap:8px;display:grid;position:relative}.project-kicker{color:var(--projects-label);font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;font-size:.82rem}.project-showcase__details h4{color:var(--text-main);letter-spacing:-.04em;margin:0;font-size:clamp(1.7rem,4vw,2.5rem);line-height:1.1}.project-description-card{background:var(--projects-description-bg);border:1px solid var(--projects-description-border);width:min(100%,560px);box-shadow:var(--projects-description-shadow);border-radius:0;margin-top:0;padding:22px 24px}.project-description-card p{color:var(--projects-description-text);margin:0;font-size:1rem;line-height:1.8}.project-stack{max-width:560px;color:var(--text-muted);font-family:var(--font-mono);flex-wrap:wrap;align-items:center;gap:6px;margin-top:4px;font-size:.92rem;line-height:1.6;display:flex}.project-stack span{color:var(--text-main)}@media (width>=980px){.project-showcase{grid-template-columns:minmax(0,1.05fr) minmax(360px,.95fr);gap:0}.project-showcase__details{margin-left:-72px;padding-top:36px}.project-showcase--reverse{grid-template-columns:minmax(360px,.95fr) minmax(0,1.05fr)}.project-showcase--reverse .project-showcase__media{order:2}.project-showcase--reverse .project-showcase__details{order:1;justify-items:end;margin-left:0;margin-right:-72px}.project-showcase--reverse .project-description-card,.project-showcase--reverse .project-stack{text-align:left}.project-image-card{aspect-ratio:16/10;min-height:auto}.project-showcase:nth-child(odd) .project-description-card{margin-left:-16px}.project-showcase:nth-child(2n) .project-description-card{margin-right:-16px}}.project-title-row{align-items:center;gap:0;width:98%;display:flex}.project-title-row .project-title-link{color:var(--text-main);align-items:center;margin-left:auto;text-decoration:none;transition:transform .25s cubic-bezier(.645,.045,.355,1),color .25s cubic-bezier(.645,.045,.355,1);display:inline-flex}.project-title-row .project-title-link:hover{color:var(--projects-link);transform:translateY(-4px)}.project-showcase--reverse .project-title-row .project-title-link{order:-1;margin-left:0;margin-right:auto}.project-title-row .project-title-link svg{width:20px;height:20px}@media (width<=979px){.project-description-card{margin-top:0}}.feature-card{border:1px solid var(--border);background:var(--bg-surface);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:var(--shadow);border-radius:22px;padding:24px}.feature-card h4{color:var(--text-main);font-size:1.04rem;line-height:1.25}.feature-card p{margin-top:12px}.side-rail{z-index:4;opacity:0;pointer-events:none;flex-direction:column;justify-content:flex-start;align-items:center;gap:16px;display:flex;position:fixed;top:50%;bottom:0;transform:translateY(-50%)}.side-rail.is-visible{animation:.76s cubic-bezier(.22,1,.36,1) .22s forwards rail-rise}.side-rail.is-visible a{opacity:1}.side-rail a{color:var(--text-main);pointer-events:auto;background:0 0;border:0;border-radius:0;justify-content:center;align-items:center;text-decoration:none;transition:all .25s cubic-bezier(.645,.045,.355,1);display:inline-flex}.side-rail__line{background:var(--border);flex:1;width:2px;min-height:220px}.side-rail--left{left:18px}.side-rail--right{right:18px}.side-rail--right a{width:auto;height:auto}.side-rail__icon{place-items:center;display:inline-grid}.side-rail__icon svg{width:24px;height:24px;transition:color .25s cubic-bezier(.645,.045,.355,1);display:block}.side-rail__email{writing-mode:vertical-rl;text-orientation:mixed;font-family:var(--font-mono);letter-spacing:.08em;transform-origin:50%;font-size:.78rem;line-height:1;transition:all .25s cubic-bezier(.645,.045,.355,1);position:relative}.side-rail__email:hover{color:var(--button-accent);transform:translateY(-4px)}.loading-screen{z-index:20;background:linear-gradient(135deg, #ffffffeb, #e8ecf4e6), var(--bg-main);place-items:center;transition:opacity .22s,transform .22s;display:grid;position:fixed;inset:0}.loading-screen.is-hidden{opacity:0;transform:scale(1.01)}.loading-screen__card{border:1px solid var(--border);background:var(--bg-surface);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);width:min(360px,100vw - 40px);box-shadow:var(--shadow);border-radius:26px;padding:28px}.loading-screen__label{color:var(--text-main);font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;margin-bottom:16px;display:block}.loading-screen__bar{background:var(--bg-soft);border-radius:999px;height:4px;position:relative;overflow:hidden}.loading-screen__bar:after{content:"";border-radius:inherit;background:linear-gradient(90deg,#0000,#475c83f2,#0000);width:40%;animation:1.1s ease-in-out infinite loading-slide;position:absolute;inset:0}@keyframes nav-drop{0%{opacity:0;transform:translateY(-32px)}to{opacity:1;transform:translateY(0)}}@keyframes nav-enter{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes hero-text-rise{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes hero-cta-scale{0%{opacity:0;transform:translateY(12px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes hero-rise{0%{opacity:0;transform:translateY(36px)}to{opacity:1;transform:translateY(0)}}@keyframes rail-rise{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes rail-item-rise{0%{opacity:0;transform:translateY(44px)}to{opacity:1;transform:translateY(0)}}@keyframes loading-slide{0%{transform:translate(-120%)}to{transform:translate(260%)}}@media (width<=900px){.portfolio-nav{grid-template-columns:1fr auto;justify-items:start;width:calc(100% + 36px);margin:0 -18px;padding:20px 14px 16px}.portfolio-shell{padding-top:0}.nav-cluster{justify-self:end;gap:10px}.portfolio-nav__links{display:none}.theme-button{justify-self:end}.menu-button{z-index:100;display:inline-flex}.nav-actions{gap:8px}.portfolio-nav.is-menu-open{border-radius:0}.mobile-nav-panel{background-color:var(--bg-surface);-webkit-backdrop-filter:blur(20px);z-index:99;visibility:hidden;pointer-events:none;flex-direction:column;justify-content:center;align-items:center;width:min(75vw,320px);height:100vh;padding:50px 20px;transition:transform .25s cubic-bezier(.645,.045,.355,1),visibility .25s cubic-bezier(.645,.045,.355,1);position:fixed;top:0;bottom:0;right:0;transform:translate(100%);box-shadow:-10px 0 30px -15px #020c1b40;filter:none!important;display:flex!important}.mobile-nav-panel.is-open{visibility:visible;pointer-events:auto;transform:translate(0)}.mobile-menu-close{color:var(--text-main);cursor:pointer;background:0 0;border:none;transition:color .25s,transform .25s;display:block;position:absolute;top:24px;right:24px}.mobile-menu-close:hover{color:var(--button-accent);transform:rotate(90deg)}.mobile-nav-links{flex-direction:column;align-items:center;gap:24px;width:100%;display:flex}.mobile-nav-links a{font-family:var(--font-mono);color:var(--text-muted);flex-direction:column;align-items:center;gap:6px;font-size:1.1rem;text-decoration:none;transition:all .25s cubic-bezier(.645,.045,.355,1);display:flex}.mobile-nav-links a:hover{color:var(--button-accent);transform:translateY(-4px)}.mobile-nav-links a.is-active{color:var(--button-accent)}.mobile-nav-links a span{color:var(--button-accent);font-size:.85rem}.side-rail{display:none}.portfolio-content{gap:68px;min-height:auto;padding-top:28px}.hero__title{font-size:clamp(2.6rem,12vw,4.6rem)}.hero__subtitle{font-size:clamp(1.5rem,7vw,2.6rem)}.about-layout{grid-template-columns:1fr;gap:28px}.about-skills{grid-template-columns:1fr}.portrait-swap{justify-self:start;max-width:100%}.section-heading--about{flex-wrap:wrap}.section-heading--about h3{white-space:normal}.portrait-swap__frame:after{inset:14px -10px -10px 14px}.button{min-width:100%}}@media (width<=560px){.portrait-swap__frame{padding:14px}.portrait-swap__image{width:calc(100% - 28px);height:calc(100% - 28px);inset:14px}.skills-list{grid-template-columns:1fr}}.button,.button--contact{min-width:170px;font-family:var(--font-mono);cursor:pointer;z-index:1;justify-content:center;align-items:center;padding:14px 22px;line-height:1;text-decoration:none;display:inline-flex;position:relative;border:1px solid var(--button-accent)!important;background:var(--bg-main)!important;color:var(--button-accent)!important;box-shadow:0 0 0 0 var(--button-accent)!important;border-radius:4px!important;transition:transform .25s cubic-bezier(.645,.045,.355,1),box-shadow .25s cubic-bezier(.645,.045,.355,1),color .25s cubic-bezier(.645,.045,.355,1),border-color .25s cubic-bezier(.645,.045,.355,1)!important;transform:translate(0)!important}.button:hover,.button:focus-visible,.button--contact:hover,.button--contact:focus-visible{outline:none;box-shadow:5px 5px 0 0 var(--button-accent)!important;background:var(--bg-main)!important;color:var(--button-accent)!important;transform:translate(-5px,-5px)!important}.side-rail a{text-decoration:none;display:inline-block;transition:transform .25s cubic-bezier(.645,.045,.355,1),color .25s cubic-bezier(.645,.045,.355,1)!important}.side-rail a:hover{color:var(--button-accent)!important;transform:translateY(-4px)!important}.side-rail__icon svg{width:24px;height:24px;display:block;transition:color .25s cubic-bezier(.645,.045,.355,1)!important;transform:none!important}.side-rail__email{text-decoration:none;display:inline-block;transition:transform .25s cubic-bezier(.645,.045,.355,1),color .25s cubic-bezier(.645,.045,.355,1),letter-spacing .25s cubic-bezier(.645,.045,.355,1)!important}.side-rail__email:hover{color:var(--button-accent)!important;font-weight:400!important;transform:translateY(-4px)!important}.side-rail__email:after{display:none!important}.mobile-menu-overlay{z-index:98;-webkit-backdrop-filter:blur(4px);opacity:0;pointer-events:none;background-color:#020c1b73;transition:opacity .25s;display:none;position:fixed;inset:0}.mobile-menu-overlay.is-active{opacity:1;pointer-events:auto;display:block}body.blur-active .portfolio-shell>:not(header):not(.mobile-menu-overlay){filter:blur(6px)brightness(.7);transition:filter .25s}.experience-section{width:100%;max-width:700px;margin:0 auto}.section-heading--experience span{color:var(--button-accent)}.experience-layout{gap:30px;min-height:320px;margin-top:36px;display:flex}@media (width<=600px){.experience-layout{flex-direction:column;min-height:auto}}.tab-list{border-left:2px solid var(--border);flex-direction:column;width:max-content;margin:0;padding:0;display:flex;position:relative}@media (width<=600px){.tab-list{border-left:none;border-bottom:2px solid var(--border);flex-direction:row;width:100%;margin-bottom:24px;padding-bottom:2px;overflow-x:auto}}.tab-button{width:100%;height:42px;color:var(--text-muted);font-family:var(--font-mono);text-align:left;white-space:nowrap;cursor:pointer;background-color:#0000;border:none;align-items:center;padding:0 20px;font-size:.85rem;transition:background-color .25s cubic-bezier(.645,.045,.355,1),color .25s cubic-bezier(.645,.045,.355,1);display:flex}.tab-button:hover{background-color:var(--bg-soft);color:var(--button-accent)}.tab-button.is-active{color:var(--button-accent)}@media (width<=600px){.tab-button{text-align:center;justify-content:center;min-width:120px;padding:0 15px}}.tab-highlight{z-index:2;background:var(--button-accent);width:2px;height:42px;transform:translateY(calc(var(--active-index,0) * 42px));transition:transform .25s cubic-bezier(.645,.045,.355,1);position:absolute;top:0;left:-2px}@media (width<=600px){.tab-highlight{width:120px;height:2px;transform:translateX(calc(var(--active-index,0) * 120px));top:auto;bottom:-2px;left:0}}.tab-panels{flex:1}.tab-panel{width:100%;animation:.3s ease-in-out forwards tabFadeIn;display:none}.tab-panel.is-active{display:block}.tab-panel h4{color:var(--text-main);margin:0 0 5px;font-size:1.25rem;font-weight:500;line-height:1.2}.tab-panel h4 .job-company a{color:var(--button-accent);text-decoration:none;transition:opacity .25s}.tab-panel h4 .job-company a:hover{opacity:.8}.tab-panel .job-range{font-family:var(--font-mono);color:var(--text-muted);align-items:center;gap:8px;margin-bottom:20px;font-size:.8rem;display:flex}.cert-badge{color:var(--text-muted);border-radius:4px;justify-content:center;align-items:center;padding:4px;transition:color .25s cubic-bezier(.645,.045,.355,1),transform .25s cubic-bezier(.645,.045,.355,1);display:inline-flex}.cert-badge:hover{color:var(--button-accent);transform:translateY(-2px)}.tab-panel .job-duties{margin:0;padding:0;list-style:none}.tab-panel .job-duties li{color:var(--text-muted);margin-bottom:12px;padding-left:20px;font-size:.95rem;line-height:1.6;position:relative}.tab-panel .job-duties li:before{content:"✦";color:var(--button-accent);position:absolute;left:0}@keyframes tabFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.noteworthy-heading{justify-content:flex-start!important;margin-bottom:40px!important}.noteworthy-heading h3{white-space:nowrap!important;text-align:left!important;font-size:clamp(1.5rem,3vw,2rem)!important}.noteworthy-section{flex-direction:column;align-items:center;width:100%;display:flex;padding:80px 0!important}.noteworthy-grid{grid-template-columns:repeat(3,1fr);gap:15px;width:100%;margin-top:40px;margin-bottom:50px;display:grid}@media (width<=1080px){.noteworthy-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}}@media (width<=600px){.noteworthy-grid{grid-template-columns:1fr}}.noteworthy-card{background-color:var(--card-bg,var(--bg-surface));border:1px solid var(--border);border-radius:4px;flex-direction:column;align-self:stretch;padding:2rem 1.75rem;transition:transform .25s cubic-bezier(.645,.045,.355,1),box-shadow .25s cubic-bezier(.645,.045,.355,1);display:flex}:root{--card-bg:#fff}html.dark,[data-theme=dark]{--card-bg:#112240fa}.noteworthy-card:hover{transform:translateY(-7px);box-shadow:0 10px 30px -15px #020c1b59}.noteworthy-card .card-top{justify-content:space-between;align-items:center;margin-bottom:30px;display:flex}.noteworthy-card .folder-icon{color:var(--button-accent)}.noteworthy-card .card-links{align-items:center;gap:14px;display:flex}.noteworthy-card .card-links a{color:var(--text-muted);align-items:center;transition:color .25s cubic-bezier(.645,.045,.355,1),transform .25s cubic-bezier(.645,.045,.355,1);display:inline-flex}.noteworthy-card .card-links a:hover{color:var(--button-accent);transform:translateY(-3px)}.noteworthy-card .card-title{color:var(--text-main);margin:0 0 10px;font-size:1.15rem;font-weight:600}.noteworthy-card .card-description{color:var(--text-muted);text-align:left;flex-grow:1;margin-bottom:20px;font-size:.93rem;line-height:1.6}.noteworthy-card .card-tech{color:var(--text-muted);font-family:var(--font-mono);flex-wrap:wrap;gap:10px;margin:0;padding:0;font-size:.73rem;list-style:none;display:flex}body{font-size:16px;line-height:1.6}.hero__title{letter-spacing:-.02em!important;font-size:clamp(40px,8vw,80px)!important;font-weight:600!important;line-height:1.1!important}.hero__subtitle{color:var(--text-muted)!important;letter-spacing:-.02em!important;font-size:clamp(30px,6vw,60px)!important;font-weight:600!important;line-height:1.1!important}.section-heading h3,.section-heading--about h3{font-size:clamp(24px,5vw,32px)!important;font-weight:600!important}.reveal-group{opacity:0;will-change:opacity, transform;transform:translateY(20px);transition:opacity .8s cubic-bezier(.645,.045,.355,1),transform .8s cubic-bezier(.645,.045,.355,1)!important}.reveal-group.is-revealed{opacity:1;transform:translateY(0)}.portfolio-content{max-width:1000px!important}section{padding:80px 0!important}p{text-align:left}.contact-overlay{z-index:9999;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#00000080;justify-content:center;align-items:center;animation:.25s overlay-fade;display:flex;position:fixed;inset:0}.contact-modal{background:var(--bg-surface);border:1px solid var(--border);width:min(420px,90vw);box-shadow:var(--shadow);border-radius:12px;padding:40px 36px 32px;animation:.3s cubic-bezier(.22,1,.36,1) modal-scale;position:relative}.contact-modal__close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px;transition:color .2s;display:flex;position:absolute;top:14px;right:14px}.contact-modal__close:hover{color:var(--text-main)}.contact-modal h3{color:var(--text-main);text-align:center;margin-bottom:28px;font-size:1.4rem}.contact-modal__options{flex-direction:column;gap:14px;display:flex}.contact-modal__option{border:1px solid var(--border);color:var(--button-accent);font-size:1rem;font-family:var(--font-mono);z-index:1;background:0 0;border-radius:4px;justify-content:center;align-items:center;gap:12px;padding:16px 20px;text-decoration:none;transition:transform .25s cubic-bezier(.645,.045,.355,1),box-shadow .25s cubic-bezier(.645,.045,.355,1),color .25s cubic-bezier(.645,.045,.355,1),border-color .25s cubic-bezier(.645,.045,.355,1);display:flex;position:relative}.contact-modal__option:hover{box-shadow:5px 5px 0 0 var(--button-accent);border-color:var(--button-accent);transform:translate(-5px,-5px)}@keyframes overlay-fade{0%{opacity:0}to{opacity:1}}@keyframes modal-scale{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--font-sans:"Fira Code", ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", Menlo, monospace;--font-mono:"Fira Code", ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", Menlo, monospace;--transition-smooth:.24s cubic-bezier(.22, 1, .36, 1);--bg-main:#eef1f7;--bg-surface:#ffffffc7;--bg-soft:#30467014;--text-main:#172033;--text-muted:#5f6d85;--border:#50638a38;--portrait-border:#071428;--shadow:0 20px 60px #3046701f;--button-accent:#172033}html.dark,[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg-main:#071428;--bg-surface:#0c182ee0;--bg-soft:#819ccf1a;--text-main:#f1f5fb;--text-muted:#a7b4c8;--border:#a8b8d53d;--portrait-border:#eef1f7;--shadow:0 24px 70px #0208176b;--button-accent:#fff}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;background-color:var(--bg-main)}body{background-color:var(--bg-main);background:radial-gradient(circle at top left, #ffffffa6, transparent 22%), radial-gradient(circle at right center, #475c8329, transparent 36%), var(--bg-main);color:var(--text-muted);font-family:var(--font-sans);min-width:320px;transition:background-color var(--transition-smooth), color var(--transition-smooth);line-height:1.6;overflow-x:hidden}html.dark body,[data-theme=dark] body{background:radial-gradient(circle at top left, #ffffff24, transparent 10%), radial-gradient(circle at right center, #475c8314, transparent 16%), var(--bg-main)}html[data-transition-theme] body{transition:none!important}a{color:inherit}button,a{-webkit-tap-highlight-color:transparent}section{scroll-margin-top:96px}#root{min-height:100vh}::view-transition{background-color:#eef1f7}html.dark ::view-transition{background-color:#071428}::view-transition-old(root){z-index:1;mix-blend-mode:normal;animation:none}::view-transition-new(root){z-index:9999;mix-blend-mode:normal;animation:.4s ease-in theme-reveal}html[data-transition-theme=dark] ::view-transition-old(root){z-index:9999;animation:.4s ease-out reverse theme-reveal}html[data-transition-theme=dark] ::view-transition-new(root){z-index:1;animation:none}@keyframes theme-reveal{0%{clip-path:circle(0 at var(--x,50vw) var(--y,50vh))}to{clip-path:circle(150vmax at var(--x,50vw) var(--y,50vh))}}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,:before,:after{scroll-behavior:auto!important;transition-duration:1ms!important;animation-duration:1ms!important;animation-iteration-count:1!important}}
