body{-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--font-display:"Cormorant Garamond","Playfair Display",serif;--font-body:"Lora","Georgia",serif;--font-mono:"SFMono-Regular",ui-monospace,monospace}body,html{-webkit-font-smoothing:antialiased;color:#fcfcfc;font-family:Lora,Georgia,serif;font-family:var(--font-body);font-weight:400;height:100%;margin:0;padding:0;text-rendering:optimizeLegibility;width:100%}html{overflow-x:hidden;overflow-y:auto;scrollbar-color:#444 #ffffff14;scrollbar-width:thin}html::-webkit-scrollbar{width:10px}html::-webkit-scrollbar-track{background:#ffffff0a}html::-webkit-scrollbar-thumb{background:linear-gradient(140deg,#303030,#555);border:2px solid #0006;border-radius:20px}html::-webkit-scrollbar-thumb:hover{background:linear-gradient(140deg,#3a3a3a,#666)}body{-webkit-font-smoothing:antialiased;background-color:#1f1c1c;overscroll-behavior-y:contain}*,:after,:before{box-sizing:border-box}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.site-nav{align-items:center;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);background:linear-gradient(180deg,#0f0f0fe0,#0f0f0f8c 60%,#0f0f0f00);display:flex;justify-content:space-between;padding:clamp(.55rem,1.1vw,1.1rem) clamp(1rem,2vw,2.5rem);position:-webkit-sticky;position:sticky;top:0;z-index:50}.nav-brand{background:none;border:none;color:#fff;cursor:pointer;font-family:Cormorant Garamond,Playfair Display,serif;font-family:var(--font-display);font-size:clamp(1.6rem,3.5vw,2.8rem);font-weight:600;letter-spacing:.5px;line-height:1;padding:.15rem .5rem .2rem;position:relative;transition:color .3s ease}.nav-brand .brand-name{display:block}.nav-brand .brand-role{color:#f3ede8;display:block;font-family:Lora,Georgia,serif;font-family:var(--font-body);font-size:clamp(.62rem,1.05vw,.82rem);font-weight:500;letter-spacing:.55px;line-height:1.05;margin-top:.3rem;opacity:.85}@media (max-width:620px){.nav-brand{font-size:clamp(1.45rem,6vw,2.2rem)}.nav-brand .brand-role{font-size:clamp(.58rem,2.3vw,.75rem);letter-spacing:.4px}}.nav-brand:focus-visible,.nav-brand:hover{color:#fc8e5b;outline:none}.nav-links{display:flex;gap:clamp(.4rem,1vw,.9rem)}.nav-link{--accent:#fc8e5b;-webkit-tap-highlight-color:transparent;align-items:center;background:none;border:none;color:#fff;cursor:pointer;display:inline-flex;font-family:Lora,Georgia,serif;font-family:var(--font-body);font-size:clamp(.82rem,.85vw,.95rem);font-weight:500;justify-content:center;letter-spacing:.4px;line-height:1.15;padding:.55rem .85rem .65rem;position:relative;transition:color .35s ease,text-shadow .35s ease}.nav-link span{pointer-events:none}.nav-link:focus-visible{border-radius:4px;outline:2px solid var(--accent);outline-offset:3px}.nav-link:focus-visible,.nav-link:hover{color:var(--accent);text-shadow:0 0 6px #fc8e5b8c}.nav-link.active{color:var(--accent);text-shadow:0 0 8px #fc8e5b80}.nav-links:before{background:linear-gradient(90deg,#0000,#ffffff26,#0000);content:"";height:1px;left:0;pointer-events:none;position:absolute;right:0;top:0}@media (max-width:720px){.site-nav{align-items:flex-start;flex-direction:column;gap:.35rem;padding-bottom:.6rem}.nav-links{flex-wrap:wrap;padding-left:.15rem;position:relative}.nav-link{padding:.45rem .6rem .6rem}.nav-link:after{bottom:.25rem}}.overlay{align-items:flex-end;background:linear-gradient(180deg,#0000 10%,#0000008c 75%);color:#fff;display:flex;font-size:24px;inset:0;justify-content:flex-end;opacity:0;pointer-events:none;position:absolute;transform:translateY(8px);transition:opacity .45s ease,transform .6s ease}.overlay-content{background:linear-gradient(180deg,#0000,#0000008c 60%,#000000bf);box-sizing:border-box;display:flex;flex-direction:column;gap:.35rem;max-height:100%;overflow:hidden;padding:1.1rem 1.2rem 1.4rem;width:100%}.project-title{font-size:clamp(1.05rem,2.2vw,1.65rem);font-weight:600;letter-spacing:.5px;line-height:1.15;margin:0;text-shadow:0 2px 10px #00000080}.project-shortd{color:#ffffffe6;font-size:clamp(.7rem,1.4vw,.9rem);letter-spacing:.4px;line-height:1.35;margin:0;opacity:.9}.container:hover .overlay{opacity:1;transform:translateY(0)}.container{-ms-overflow-style:none;contain:paint layout;overflow:hidden;overscroll-behavior:none;position:relative;scrollbar-width:none}.container::-webkit-scrollbar{display:none}.overlay,.overlay-content{-ms-overflow-style:none;overflow:clip;scrollbar-width:none}.overlay-content::-webkit-scrollbar,.overlay::-webkit-scrollbar{display:none;height:0;width:0}.overlay-content .project-shortd,.overlay-content .project-title{overflow-wrap:anywhere}.container ::-webkit-scrollbar{display:none!important;height:0!important;width:0!important}.container *{-ms-overflow-style:none!important;scrollbar-width:none!important}.project-card-reveal{filter:blur(6px);opacity:0;transform:translateY(34px) scale(.94)}.project-card-reveal.visible{filter:blur(0);opacity:1;transform:translateY(0) scale(1);transition:opacity .85s cubic-bezier(.33,.14,.22,1),transform .85s cubic-bezier(.33,.14,.22,1),filter 1s ease}.project-card-reveal,.project-card-reveal *{scrollbar-width:none}.project-card-reveal::-webkit-scrollbar{display:none}.project-inspector{-webkit-backdrop-filter:blur(18px) saturate(140%);backdrop-filter:blur(18px) saturate(140%);background:radial-gradient(circle at 25% 15%,#ffffff14,#000000e6 68%),linear-gradient(125deg,#000000e0,#000000f0);display:flex;flex-direction:column;height:100vh;isolation:isolate;left:0;overflow:hidden;position:fixed;top:0;width:100vw;z-index:9999}.project-inspector .pi-scroll{-webkit-overflow-scrolling:touch;box-sizing:border-box;flex:1 1 auto;height:100%;overflow-y:auto;padding:clamp(1rem,2vw,1.8rem) clamp(1rem,3vw,2.4rem) 2.4rem;width:100%}.pi-close{align-items:center;background:#0000;border:none;border-radius:50%;box-shadow:none;cursor:pointer;display:flex;height:2.4rem;justify-content:center;padding:.4rem;position:absolute;right:1rem;top:.9rem;transition:transform .25s ease,background .25s ease;width:2.4rem}.pi-close:hover{transform:scale(1.05)}.pi-close:active{transform:scale(.9)}.pi-close:focus-visible{box-shadow:0 0 0 3px #fc8e5b8c;outline:0}.pi-close-icon{stroke:#fffc;stroke-width:2.1;stroke-linecap:round;fill:none;height:1.3rem;pointer-events:none;transition:stroke .25s ease,opacity .25s ease;width:1.3rem}.pi-close:hover .pi-close-icon{stroke:#fc8e5b}.pi-close:active .pi-close-icon{stroke:#fc8e5b;opacity:.8}.visually-hidden{clip:rect(0 0 0 0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.pi-header{align-items:baseline;display:flex;flex-wrap:wrap;gap:1rem}.pi-title{font-size:clamp(1.6rem,3.6vw,3rem);letter-spacing:.5px;margin:0}.pi-meta{font-size:.85rem;letter-spacing:1px;opacity:.75}.pi-description{font-size:clamp(.85rem,1.1vw,1.05rem);line-height:1.5;opacity:.88}.pi-video-wrapper{margin:1rem 0 1.6rem}.pi-video{border-radius:10px;box-shadow:0 6px 20px -4px #0009;max-height:70vh;object-fit:contain;width:100%}.pi-gallery-wrapper{margin-top:.5rem}.pi-status{font-size:.9rem;opacity:.7}.pi-status.error{color:#ff6b6b}.pi-gallery{grid-gap:.65rem;gap:.65rem;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));margin-top:.6rem}.pi-thumb{aspect-ratio:16/9;background:#ffffff0f;border-radius:8px;overflow:hidden;position:relative}.pi-thumb img,.pi-thumb span.lazy-load-image-background img{display:block;filter:blur(6px);height:100%;object-fit:cover;opacity:0;transform:translateY(8px) scale(1.02);transition:opacity .6s cubic-bezier(.22,.12,.28,1),transform .6s cubic-bezier(.22,.12,.28,1),filter .5s ease,transform .6s ease;width:100%}.pi-thumb span.lazy-load-image-background.loaded img,.pi-thumb.loaded img{filter:blur(0);opacity:1;transform:translateY(0) scale(1)}.pi-thumb:hover img{transform:scale(1.08)}.pi-thumb.reveal{filter:blur(6px);opacity:0;transform:translateY(30px) scale(.94)}.pi-thumb.reveal.visible{filter:blur(0);opacity:1;transform:translateY(0) scale(1);transition:opacity .8s cubic-bezier(.33,.14,.22,1),transform .8s cubic-bezier(.33,.14,.22,1),filter 1s ease}.pi-thumb.reveal.leaving{filter:blur(8px);opacity:0;transform:translateY(14px) scale(.9);transition:opacity .35s ease,transform .45s ease,filter .45s ease}.project-inspector *,.project-inspector :after,.project-inspector :before{overflow:visible}@media (min-width:1400px){.pi-gallery{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media (max-width:760px){.project-inspector{padding:1rem 1rem 2.2rem}.pi-title{font-size:clamp(1.5rem,6vw,2.4rem)}}h1{align-items:center;color:#fff;font-size:24px;justify-content:center}.img-skeleton{animation:shimmer 1.4s ease-in-out infinite;background:linear-gradient(90deg,#ffffff14 25%,#ffffff2e 37%,#ffffff14 63%);background-size:400% 100%;display:block;filter:blur(3px);height:100%;width:100%}@keyframes shimmer{0%{background-position:100% 0}to{background-position:0 0}}.ratio-16x9{aspect-ratio:16/9;overflow:hidden;position:relative;width:100%}.ratio-4x3{aspect-ratio:4/3}.ratio-1x1{aspect-ratio:1/1}.project-carousel{align-items:stretch;display:flex;gap:.65rem;position:relative}.pc-viewport{flex:1 1 auto;overflow:hidden}.pc-track{--slide-width:min(300px,32vw);display:flex;gap:.9rem;transform:translateX(calc(var(--pc-index)*-1*(var(--slide-width) + .9rem)));transition:transform .55s cubic-bezier(.33,.14,.22,1)}.pc-slide{background:#ffffff0d;border-radius:10px;box-shadow:0 4px 18px -6px #0009;color:inherit;display:flex;flex:0 0 var(--slide-width);flex-direction:column;overflow:hidden;position:relative;text-decoration:none;transition:transform .45s ease,box-shadow .45s ease}.pc-slide:hover{box-shadow:0 10px 26px -6px #0000008c;transform:translateY(-6px)}.pc-image-wrap{aspect-ratio:16/9;background:#111;position:relative;width:100%}.pc-image-wrap img,.pc-image-wrap span.lazy-load-image-background img{display:block;height:100%;object-fit:cover;transition:transform .8s ease;width:100%}.pc-slide:hover .pc-image-wrap img{transform:scale(1.07)}.pc-meta{display:flex;flex-direction:column;gap:.25rem;padding:.65rem .75rem .85rem}.pc-title{font-size:.95rem;letter-spacing:.4px;line-height:1.2}.pc-date{font-size:.65rem;letter-spacing:1px;opacity:.65}.pc-nav{align-items:center;align-self:center;background:#ffffff12;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:.95rem;height:2.4rem;justify-content:center;transition:background .3s ease,transform .3s ease,opacity .3s ease;width:2.4rem}.pc-nav:hover:not(:disabled){background:#ffffff2e}.pc-nav:disabled{cursor:default;opacity:.3}.pc-nav:active:not(:disabled){transform:scale(.9)}@media (max-width:820px){.pc-track{--slide-width:min(70vw,260px)}}@media (max-width:520px){.pc-track{--slide-width:min(78vw,240px)}.project-carousel{gap:.4rem}.pc-nav{height:2rem;width:2rem}}.lightbox-overlay{align-items:center;background:#000000e6;display:flex;height:100vh;justify-content:center;left:0;position:fixed;top:0;width:100vw;z-index:9999}.lightbox-content img{max-height:90vh;object-fit:contain}.lightbox-close{font-size:2rem;right:1rem;top:1rem}.lightbox-next,.lightbox-prev{background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:2rem;padding:.5rem;position:absolute;top:50%;transform:translateY(-50%)}.lightbox-prev{left:1rem}.lightbox-next{right:1rem}.other-projects-wrapper{margin:3.5rem 0 0;text-align:center}.section-divider{background:linear-gradient(90deg,#fff0,#ffffff38 50%,#fff0);height:1px;margin:0 0 1.8rem;opacity:.7;width:100%}.other-projects-heading{font-size:1.15rem;font-weight:600;letter-spacing:.6px;margin:0 0 1.4rem;opacity:.9}.other-projects-list{display:flex;flex-wrap:wrap;justify-content:center}.other-project-card{background:#ffffff0d;border-radius:10px;box-shadow:0 4px 18px -6px #0000008c;color:inherit;flex:0 1 270px;max-width:320px;overflow:hidden;transition:transform .45s ease,box-shadow .45s ease}.other-project-card:hover{box-shadow:0 10px 26px -6px #0000008c;transform:translateY(-6px)}.other-project-card:active{transform:translateY(-2px) scale(.97)}.project-detail-wrapper{margin:1.8rem auto 4.2rem;width:min(1100px,94%)}.project-detail-header{margin:.6rem 0 1.8rem}.project-detail-title{font-family:serif;font-family:var(--font-display,serif);font-size:clamp(1.9rem,4.2vw,3.1rem);font-weight:600;letter-spacing:.6px;line-height:1.1;margin:0 0 .55rem}.project-detail-meta{font-size:.72rem;letter-spacing:1.2px;margin-bottom:.85rem;opacity:.7;text-transform:uppercase}.project-detail-description{color:#ffffffd9;font-size:clamp(.85rem,1vw,1.02rem);line-height:1.5;margin:0;max-width:840px}.project-video-block{margin:1.2rem 0 2.2rem}.project-video-block video{border-radius:12px;box-shadow:0 8px 26px -6px #0009;max-height:70vh;object-fit:contain;width:100%}.project-gallery-section{margin:2.4rem 0 1.4rem}.project-gallery-heading{font-family:var(--font-body);font-size:1.15rem;font-weight:600;letter-spacing:.6px;margin:0 0 1rem;opacity:.92;text-transform:uppercase}.back-link{color:#4fa3ff;display:inline-block;font-size:.78rem;font-weight:500;letter-spacing:.8px;text-decoration:none;text-transform:uppercase}.back-link:hover{text-decoration:underline}.other-projects-wrapper{margin:3.8rem 0 0;width:100%}.other-projects-heading{text-transform:uppercase}@media (max-width:760px){.project-detail-title{font-size:clamp(1.7rem,7vw,2.6rem)}.project-detail-description{font-size:clamp(.82rem,1.9vw,1rem)}.project-gallery-section{margin-top:2rem}}.project-detail-skills-style{box-sizing:border-box;display:flex;flex-direction:column;margin:0 auto;max-width:1700px;padding:1rem clamp(2.5rem,6vw,6rem) 5rem;width:100%}.project-detail-hero{margin-bottom:2.2rem}.project-detail-title{background:linear-gradient(90deg,#fff,#ffe1d2 55%,#fff 90%);-webkit-background-clip:text;background-clip:text;color:#0000;font-size:clamp(1.6rem,2.8vw,3.1rem);letter-spacing:1px;line-height:1.05}.project-detail-meta{color:#ffd4c2;font-size:1rem;margin-bottom:1.2rem}.project-main-image{align-items:center;display:flex;justify-content:center;margin:1.5rem 0;max-height:500px;overflow:hidden;width:100%}.project-detail-description-block{display:flex;flex-direction:column;margin-top:1.2rem}.project-description-section{margin-bottom:1.2rem}.project-description-heading{-webkit-text-fill-color:#0000;align-items:center;background:linear-gradient(90deg,#fff,#ffdfcf 45%,#fff 90%);background-clip:text;-webkit-background-clip:text;color:#fff;display:flex;font-size:1.25rem;font-weight:700;gap:.5rem;margin-bottom:.2rem;margin-top:.5rem}.expand-arrow{color:#ffd4c2;cursor:pointer;font-size:1rem;transition:transform .3s ease}.expand-arrow:hover{color:#fff}.project-description-text.collapsed{display:none}.project-description-text.expanded{display:block}.project-description-text,.project-detail-description{background:#201e1ea6;box-shadow:0 4px 18px -4px #0000008c;color:#f2f2f2;font-size:1.08rem;line-height:1.7;padding:1rem}.toggle-button{background:linear-gradient(90deg,#fc8e5b,#ffdfcf);border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;margin-top:.5rem;padding:.4rem 1rem;transition:all .3s ease}.toggle-button:hover{background:linear-gradient(90deg,#ffdfcf,#fc8e5b)}.project-video-blocks{display:grid;margin:0;width:50%}.project-links-section,.project-video-block{margin-bottom:2rem}.project-links-heading{-webkit-text-fill-color:#0000;background:linear-gradient(90deg,#fff,#ffdfcf 45%,#fff 90%);background-clip:text;-webkit-background-clip:text;color:#fff;font-size:1.25rem;font-weight:700;margin-bottom:1rem}.project-links-list{list-style:none;margin:0;padding:0}.project-link-item{margin-bottom:.5rem}.project-link{color:#ffd4c2;font-size:1.08rem;text-decoration:none;transition:color .3s ease}.project-link:hover{color:#fff;text-decoration:underline}.project-gallery-section{margin-bottom:2.2rem}.project-gallery-heading{-webkit-text-fill-color:#0000;background:linear-gradient(90deg,#fff,#ffdfcf 45%,#fff 90%);background-clip:text;-webkit-background-clip:text;color:#fff;font-size:1.25rem;font-weight:700;margin-bottom:1rem}.pi-gallery{grid-gap:1.1rem;display:grid;gap:1.1rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-top:.4rem}.other-projects-wrapper{margin-top:2.2rem}.section-divider{background:linear-gradient(90deg,#0000,#fc8e5b,#0000);border-radius:2px;height:2px;margin:2rem 0 1.2rem}.other-projects-heading{-webkit-text-fill-color:#0000;background:linear-gradient(90deg,#fff,#ffdfcf 45%,#fff 90%);background-clip:text;-webkit-background-clip:text;color:#fff;font-size:1.18rem;font-weight:700;margin-bottom:1rem}.other-projects-list{grid-gap:1.2rem;display:grid;gap:1.2rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.other-project-card{background:#201e1ea6;border-radius:18px;box-shadow:0 4px 18px -4px #0000008c;display:flex;flex-direction:column;gap:.7rem;padding:1.1rem 1.1rem 1.3rem;text-decoration:none}.pc-image-wrap{border-radius:12px;margin-bottom:.7rem;overflow:hidden}.pc-image-wrap img{height:160px;object-fit:cover;width:100%}.pc-title{color:#fff;font-size:1.05rem;font-weight:600}.pc-date{color:#ffd4c2;font-size:.92rem}.lightbox-overlay{background:#201e1ed9;z-index:1000}.lightbox-close{background:none;border:none;color:#fff;cursor:pointer;font-size:2.2rem;position:absolute;right:2rem;top:2rem}.lightbox-prev{left:2rem}.lightbox-next,.lightbox-prev{background:none;border:none;color:#fff;cursor:pointer;font-size:2rem;position:absolute;top:50%;transform:translateY(-50%)}.lightbox-next{right:2rem}.lightbox-content{align-items:center;display:flex;height:100vh;justify-content:center}.lightbox-content img{box-shadow:0 4px 18px -4px #0000008c;max-height:80vh;max-width:90vw}.project-back-link{background:#0000;border-radius:8px;color:#fff;display:inline-block;font-size:1rem;font-weight:600;margin-bottom:1.2rem;max-width:200px;text-decoration:none;transition:all .3s ease}.project-error{background:#2a2a2a;border-radius:16px;box-shadow:0 4px 18px -4px #0000008c;color:salmon;font-size:1.1rem;padding:2rem}.project-error button{background:var(--skill-accent);border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;margin-left:1rem;padding:.4rem 1rem}:root{--timeline-line-color:#ffffff2e;--timeline-accent:#fc8e5b;--timeline-accent-alt:#ffb896;--timeline-accent-dark:#d76638;--timeline-bg:hsla(0,0%,100%,.045);--timeline-bg-alt:#ffffff14;--radius-sm:5px;--radius-md:12px;--shadow-soft:0 3px 10px -3px #00000061;--gradient-accent:linear-gradient(120deg,#fc8e5b,#ffbea3);--text-soft:#ffffffb8;--text-faint:#ffffff85;--focus-ring:0 0 0 3px #fc8e5b73}.clean-theme{--timeline-line-color:#ffffff29;--timeline-accent:#fc8e5b;--timeline-accent-alt:#ffb896;--timeline-accent-dark:#d76638;--timeline-bg:hsla(0,0%,100%,.035);--timeline-bg-alt:hsla(0,0%,100%,.065);--gradient-accent:linear-gradient(110deg,#fc8e5b,#ffbea3)}.timeline-wrapper{margin:1.5rem auto 3rem;padding:.4rem 0 1.2rem;position:relative;width:min(1000px,94%)}.timeline-line{background:linear-gradient(180deg,#ffffff2e,#ffffff80,#ffffff2e);background:linear-gradient(to bottom,var(--timeline-line-color),#ffffff80,var(--timeline-line-color));bottom:0;left:50%;pointer-events:none;position:absolute;top:clamp(70px,12vh,140px);transform:translateX(-50%);width:3px}.timeline-item{grid-gap:1.4rem;display:grid;gap:1.4rem;grid-template-columns:repeat(2,1fr);margin-bottom:1.9rem;position:relative}.timeline-item.even .timeline-side-left{order:2}.timeline-item.even .timeline-side-right{order:1}.timeline-side-left,.timeline-side-right{position:relative}.timeline-marker{background:radial-gradient(circle at 42% 38%,#fff 4%,#fc8e5b 42%,#d76638 88%);background:radial-gradient(circle at 42% 38%,#fff 4%,var(--timeline-accent) 42%,var(--timeline-accent-dark) 88%);border:1px solid #00000059;border-radius:50%;box-shadow:0 0 0 2px #00000059,0 0 0 5px #ffffff0a,0 4px 10px -2px #000000a6;height:18px;left:50%;position:absolute;top:1rem;transform:translate(-50%,-50%);width:18px}.card{-webkit-backdrop-filter:blur(12px) saturate(140%);backdrop-filter:blur(12px) saturate(140%);background:linear-gradient(145deg,hsla(0,0%,100%,.045),#ffffff03);background:linear-gradient(145deg,var(--timeline-bg) 0,#ffffff03 100%);border:1px solid hsla(0,0%,100%,.055);border-radius:9px;box-shadow:0 3px 10px -3px #00000061;box-shadow:var(--shadow-soft);padding:.65rem .75rem .75rem;position:relative;transition:transform .4s cubic-bezier(.4,.14,.2,1),border-color .3s,background .35s}.card:before{background:linear-gradient(120deg,#ffffff14,#fff0);content:"";inset:0;opacity:0;position:absolute;transition:opacity .6s}.card:hover{background:linear-gradient(145deg,#ffffff14,#ffffff0a);background:linear-gradient(145deg,var(--timeline-bg-alt) 0,#ffffff0a 100%);border-color:#ffffff29;transform:translateY(-6px) scale(1.012)}.card:hover:before{opacity:1}.card-header{align-items:center;display:flex;gap:.55rem;margin-bottom:.42rem}.company-logo{background:hsla(0,0%,100%,.045);border-radius:6px;box-shadow:inset 0 0 0 1px hsla(0,0%,100%,.035);height:46px;object-fit:contain;padding:.4rem;width:46px}.company-title{font-size:clamp(1.15rem,1.85vw,1.45rem);margin:0}.company-time{color:#ffffffb8;color:var(--text-soft);font-size:.72rem;letter-spacing:.35px;margin:0 0 .38rem}.job-block{margin:.38rem 0 .55rem}.job-title{font-size:.88rem;font-weight:600;letter-spacing:.5px;margin:0 0 .22rem}.job-resp{color:#ffffffb8;color:var(--text-soft);font-size:.74rem;line-height:1.28;margin:.1rem 0}.reveal{filter:blur(4px);opacity:0;transform:translateY(40px) scale(.98);will-change:opacity,transform,filter}.reveal.visible{filter:blur(0);opacity:1;transform:translateY(0) scale(1);transition:opacity .75s cubic-bezier(.33,.14,.22,1),transform .75s cubic-bezier(.33,.14,.22,1),filter .9s ease}.reveal.leaving{will-change:opacity,transform,filter}@media (max-width:880px){.timeline-item{gap:1.1rem;grid-template-columns:1fr;margin-bottom:1.4rem}.timeline-line{left:18px;transform:none}.timeline-marker{left:18px}.timeline-item.even .timeline-side-left,.timeline-item.even .timeline-side-right{order:0}.timeline-side-left,.timeline-side-right{padding-left:2.75rem}}.accent-text{background:linear-gradient(120deg,#fc8e5b,#ffbea3);background:var(--gradient-accent);-webkit-background-clip:text;background-clip:text;color:#0000;filter:drop-shadow(0 1px 4px rgba(0,0,0,.2))}.scroll-hint{font-size:.8rem;letter-spacing:2px;margin-top:-1rem;opacity:.55;text-align:center}.timeline-wrapper,.timeline-wrapper *{scrollbar-width:none}.timeline-wrapper ::-webkit-scrollbar,.timeline-wrapper::-webkit-scrollbar{display:none;height:0;width:0}.card{overflow:hidden}.reveal.leaving{animation:card-exit .56s ease forwards;pointer-events:none}@keyframes card-exit{0%{filter:blur(0);opacity:1;transform:translateY(0) scale(1) rotateX(0)}35%{filter:blur(1px);opacity:.55;transform:translateY(-6px) scale(.985) rotateX(4deg)}65%{filter:blur(3px);opacity:.28;transform:translateY(4px) scale(.96) rotateX(-6deg)}to{filter:blur(8px);opacity:0;transform:translateY(12px) scale(.88) rotateX(18deg)}}.timeline-wrapper.animate-depth .card:hover{box-shadow:0 8px 26px -6px #0000008c,0 0 0 1px #ffffff0a}@media (prefers-reduced-motion:reduce){.reveal,.reveal.leaving,.reveal.visible{animation:none!important;filter:none!important;opacity:1!important;transform:none!important;transition:none!important}}html{scroll-behavior:smooth}:root{scroll-padding-top:110px}.skills-layout{grid-gap:clamp(1.2rem,2.5vw,3rem);display:grid;gap:clamp(1.2rem,2.5vw,3rem);grid-template-columns:250px 1fr;margin:0 auto;max-width:1700px;padding:clamp(1.2rem,2.5vw,3rem) clamp(1rem,3vw,3rem) 5rem;position:relative;width:100%}@media (max-width:1050px){.skills-layout{grid-template-columns:1fr}.skills-toc{position:static;top:auto}}.skills-toc{align-self:flex-start;position:-webkit-sticky;position:sticky;top:90px}.skills-toc .toc-inner{backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);background:#2826268c;border:1px solid #ffffff14;border-radius:16px;box-shadow:0 4px 14px -4px #0000008c;font-family:ui-monospace,SFMono-Regular,Consolas,Roboto Mono,monospace;padding:1.1rem 1.1rem 1.2rem 1rem}.toc-title{color:#fff;font-size:.95rem;font-weight:600;letter-spacing:.5px;margin:0 0 .75rem}.skills-toc ul{display:flex;flex-direction:column;list-style:none;margin:0;padding:0 0 0 .35rem}.toc-top>li{line-height:1.15;margin:.2rem 0;padding:0 0 0 .9rem;position:relative}.toc-top>li.has-subs{margin-bottom:.4rem}.toc-top>li:before{background:linear-gradient(180deg,#ffffff47,#fff0);bottom:0;content:"";left:.25rem;position:absolute;top:0;width:1px}.toc-top>li:last-child:before{height:50%}.skills-toc a{align-items:center;border-radius:6px;color:#d8d8d8;display:inline-flex;font-family:Segoe UI,Segoe UI Emoji,system-ui,-apple-system,BlinkMacSystemFont,Apple Color Emoji,Noto Color Emoji,sans-serif;font-size:.82rem;gap:.45rem;letter-spacing:.3px;line-height:1.25;padding:.24rem .38rem .24rem .55rem;position:relative;text-decoration:none;transition:background .25s ease,color .25s ease}.skills-toc a:hover{background:#ffffff0d;color:#fff}.skills-toc a:focus-visible{outline:1px solid #fc8e5b;outline:1px solid var(--skill-accent);outline-offset:2px}.skills-toc a.is-active{background:#fc8e5b24;font-weight:600;transform:scale(1.06)}.toc-sub a.is-active{background:#fc8e5b2e}.skills-toc a.is-active:before{box-shadow:0 0 0 3px #fc8e5b61,0 0 6px 2px #fc8e5b8c}.toc-sub a.is-active:before{box-shadow:0 0 0 2px #fc8e5b66,0 0 5px 1px #fc8e5b8c}.toc-top>li>a:before{background:radial-gradient(circle at 35% 30%,#fff 5%,#ffbe9d 55%,#fc8e5b 95%);border-radius:50%;box-shadow:0 0 0 3px #fc8e5b38,0 0 4px 1px #fc8e5b59;content:"";display:inline-block;flex:0 0 auto;height:.55rem;position:relative;top:-1px;width:.55rem}.toc-top>li.has-subs>a:before{box-shadow:0 0 0 3px #fc8e5b47,0 0 6px 1px #fc8e5b61;height:.62rem;width:.62rem}.toc-sub{border-left:1px dashed #ffffff40;display:flex;flex-direction:column;gap:.2rem;list-style:none;margin:.3rem 0 .35rem .55rem;padding:0 0 0 .65rem;position:relative}.toc-sub:before{background:linear-gradient(180deg,#ffffff4d,#fff0);bottom:0;content:"";left:-1px;position:absolute;top:0;width:1px}.toc-sub li{padding-left:.7rem;position:relative}.toc-sub li:before{background:#ffffff59;content:"";height:1px;left:-.65rem;position:absolute;top:.72em;width:.6rem}.toc-sub a{border-radius:4px;color:#cfcfcf;font-size:.7rem;opacity:.9;padding:.18rem .28rem .18rem .3rem}.toc-sub a:before{background:radial-gradient(circle at 35% 30%,#fff 5%,#ffd0b8 55%,#fc8e5b 95%);border-radius:50%;box-shadow:0 0 0 2px #fc8e5b38,0 0 3px 1px #fc8e5b4d;content:"";display:inline-block;flex:0 0 auto;height:.5rem;margin-right:.05rem;position:relative;top:-1px;width:.5rem}.toc-sub a:hover{background:#ffffff0d;color:#fff;opacity:1}.skills-toc a.is-active{background:#fc8e5b2e;color:#fff}.toc-top>li.has-subs>a{font-weight:600}.skills-main{display:flex;flex-direction:column;gap:clamp(1.5rem,2.5vw,3rem)}.skills-hero{backdrop-filter:blur(7px) saturate(120%);-webkit-backdrop-filter:blur(7px) saturate(120%);background:linear-gradient(160deg,#ffffff0d,#201e1ea6 70%);border:1px solid #ffffff14;border-radius:24px;box-shadow:0 6px 28px -6px #0000008c,0 3px 10px -2px #00000073;overflow:hidden;padding:clamp(1.8rem,3vw,3rem) clamp(1.5rem,2.6vw,3rem) clamp(2rem,3vw,3.2rem);position:relative;scroll-margin-top:110px}.skills-hero:before{background:radial-gradient(circle at 22% 18%,#fc8e5b59,#0000 60%);content:"";inset:0;opacity:.45;pointer-events:none;position:absolute}.hero-title{background:linear-gradient(90deg,#fff,#ffe1d2 55%,#fff 90%);-webkit-background-clip:text;background-clip:text;color:#0000;font-size:clamp(1.6rem,2.8vw,3.1rem);letter-spacing:1px;line-height:1.05;margin:0 0 1rem}.hero-body{line-height:1.4}.hero-body,.hero-body .md-paragraph{font-size:.9rem}.hero-body h3,.hero-body h4,.hero-body h5{margin-top:1.15rem}.skills-grid{grid-gap:clamp(1.1rem,1.9vw,2rem);display:grid;gap:clamp(1.1rem,1.9vw,2rem);grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.skills-grid .skill-card{opacity:0;scroll-margin-top:110px;transform:translateY(14px)}:root{--skill-accent:#fc8e5b}.skills-wrapper{display:contents}.skills-wrapper:before{background:radial-gradient(circle at 15% 20%,#fc8e5b14,#0000 55%),radial-gradient(circle at 85% 70%,#fc8e5b0f,#0000 60%);content:"";inset:0;opacity:.9;pointer-events:none;position:absolute}.skill-card{--card-bg:#201e1ea6;backdrop-filter:blur(6px) saturate(120%);-webkit-backdrop-filter:blur(6px) saturate(120%);background:linear-gradient(150deg,#ffffff0d 0,var(--card-bg) 70%);border:1px solid #ffffff0f;border-radius:18px;box-shadow:0 4px 18px -4px #0000008c,0 2px 6px -2px #00000080;display:flex;flex-direction:column;gap:.85rem;isolation:isolate;min-height:260px;opacity:0;overflow:hidden;padding:clamp(1rem,1.4vw,1.6rem) clamp(1rem,1.6vw,1.9rem) clamp(1.1rem,1.7vw,2rem);position:relative;transform:translateY(12px);transition:opacity .8s ease,transform .8s cubic-bezier(.55,.12,.18,1)}.skill-card.reveal-visible{opacity:1;transform:translateY(0)}.skill-card:before{background:radial-gradient(circle at 25% 15%,#fc8e5b40,#0000 60%);content:"";inset:0;opacity:0;pointer-events:none;position:absolute;transition:opacity .6s ease}.skill-card:hover:before{opacity:0}.skill-card h2{background:linear-gradient(90deg,#fff,#ffdfcf 45%,#fff 90%);background-clip:text;-webkit-background-clip:text;color:#0000;font-size:clamp(1.05rem,1.25vw,1.45rem);font-weight:700;letter-spacing:.5px;margin:0 0 .55rem}.markdown-body{display:flex;flex-direction:column;font-size:clamp(.9rem,.95vw,1.05rem);gap:.75rem;line-height:1.55;max-width:68ch}.markdown-body h3,.markdown-body h4,.markdown-body h5{color:#fff;font-size:clamp(.95rem,1.05vw,1.15rem);font-weight:600;letter-spacing:.5px;margin:1rem 0 .4rem;scroll-margin-top:120px}.markdown-body h3{padding-bottom:.35rem;position:relative}.markdown-body h3:after{background:linear-gradient(90deg,#fc8e5b,#fc8e5b00);background:linear-gradient(90deg,var(--skill-accent),#fc8e5b00);border-radius:2px;bottom:0;content:"";height:3px;left:0;opacity:.9;position:absolute;width:60px}.markdown-body h4{padding-left:1.1rem;position:relative}.markdown-body h4:before{background:#fc8e5b26;border:2px solid #fc8e5b;border:2px solid var(--skill-accent);border-radius:3px;box-shadow:0 0 0 1px #fc8e5b40,0 0 4px -1px #fc8e5b80;content:"";height:.7rem;left:.15rem;position:absolute;top:.52em;width:.7rem}.markdown-body h5{font-weight:500;opacity:.95;padding-left:1.1rem;position:relative}.markdown-body h5:before{background:radial-gradient(circle at 45% 45%,#fff,#fc8e5b);background:radial-gradient(circle at 45% 45%,#fff,var(--skill-accent));border-radius:50%;box-shadow:0 0 0 2px #fc8e5b40;content:"";height:.5rem;left:.25rem;position:absolute;top:.63em;width:.5rem}.markdown-body h4{font-size:clamp(.85rem,.95vw,1.05rem)}.markdown-body h5{font-size:clamp(.78rem,.9vw,.98rem)}.markdown-body .md-paragraph{color:#f2f2f2;font-size:clamp(.88rem,.95vw,1.02rem);line-height:1.6;margin:0}.markdown-body code{background:#ffffff14;border-radius:5px;font-size:.7rem;padding:2px 5px}.markdown-body hr{background:linear-gradient(90deg,#0000,#666,#0000);border:none;height:1px;margin:.6rem 0}.markdown-body strong{color:#fff}.markdown-body em{color:#ffd4c2}.skill-list{display:flex;flex-direction:column;gap:.35rem;list-style:none;margin:0;padding:0}.skill-list li{color:#f0f0f0;font-size:clamp(.78rem,.85vw,.98rem);font-weight:500;line-height:1.35;padding-left:1.15rem;position:relative}.skill-list li:before{background:radial-gradient(circle at 40% 35%,#fff 5%,#ffc3a3 55%,#fc8e5b 95%);border-radius:50%;box-shadow:0 0 0 3px #fc8e5b38,0 0 4px -1px #fc8e5b59;content:"";height:.55rem;left:.15rem;position:absolute;top:.62em;width:.55rem}.markdown-body ul ul{margin-top:.3rem;padding-left:1rem}.markdown-body ul ul li{padding-left:1.2rem}.markdown-body ul ul li:before{background:radial-gradient(circle at 45% 40%,#fff 10%,#ffbfa0 60%,#f9783f 95%);box-shadow:0 0 0 2px #fc8e5b40;height:.45rem;left:.25rem;top:.68em;width:.45rem}.skill-card.about{grid-column:span 1}@media (prefers-reduced-motion:reduce){.skill-card{opacity:1!important;transform:none!important;transition:none}}.skill-card:focus-within{outline:none}.skill-card:focus-visible,.skill-card:focus-within :focus-visible{outline:2px solid #fc8e5b;outline:2px solid var(--skill-accent);outline-offset:3px}
/*# sourceMappingURL=main.044405fe.css.map*/