:root{color-scheme:light;--ivory: #F5F0E8;--cream: #EDE7D9;--paper: #FAF7F2;--charcoal: #1A1814;--ink: #2D2A26;--muted: #6B6560;--accent: #0047FF;--accent-light: #E8EEFF;--accent-warm: #FF4D00;--line: rgba(26, 24, 20, .12);--nav-bg: rgba(250, 247, 242, .85);--nav-shadow: rgba(0, 0, 0, .06);--image-filter: none;--font-display: "Syne", sans-serif;--font-serif: "Fraunces", serif;--font-mono: "DM Mono", monospace}:root[data-theme=dark]{color-scheme:dark;--ivory: #171B22;--cream: #202631;--paper: #0E1116;--charcoal: #F6F0E6;--ink: #E6DED2;--muted: #B8AD9F;--accent: #7AA2FF;--accent-light: rgba(122, 162, 255, .14);--accent-warm: #FF7A45;--line: rgba(246, 240, 230, .14);--nav-bg: rgba(14, 17, 22, .84);--nav-shadow: rgba(0, 0, 0, .32);--image-filter: saturate(.88) brightness(.82)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}*:focus-visible{outline:2px solid var(--accent);outline-offset:2px}button:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.overflow-hidden,.menu-open{overflow:hidden}.block{display:block}body{background:var(--paper);color:var(--charcoal);font-family:var(--font-display);overflow-x:hidden;cursor:none;transition:background .3s ease,color .3s ease}#cursor{position:fixed;top:0;left:0;width:32px;height:32px;pointer-events:none;z-index:99999;transform:translate(-50%,-50%);transition:transform .08s linear}#cursor svg{width:100%;height:100%;transition:all .2s ease;filter:drop-shadow(0 2px 6px rgba(0,71,255,.4))}#cursor.hover svg{transform:scale(1.4);filter:drop-shadow(0 2px 12px rgba(0,71,255,.7))}#cursor.click svg{transform:scale(.8)}@media(max-width:768px){body{cursor:auto}#cursor{display:none}}@media(hover:none),(pointer:coarse){body,a,button,.breadcrumb-link,.filter-btn,.form-submit,.gallery-item,.project-item,.skill-tag{cursor:auto}#cursor,#proj-hover-img{display:none}}body:before{content:"";position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E");pointer-events:none;z-index:9999;opacity:.4}nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:0 3rem;height:72px;display:flex;align-items:center;justify-content:space-between;background:var(--nav-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--line);transition:background .3s ease,border-color .3s ease,box-shadow .3s ease}.nav-logo{font-family:var(--font-mono);font-size:13px;letter-spacing:.05em;color:var(--charcoal);text-decoration:none}.nav-logo span{color:var(--accent)}.nav-links{display:flex;gap:2.5rem;list-style:none}.nav-links a{font-family:var(--font-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);text-decoration:none;position:relative;transition:color .2s}.nav-links a:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--accent);transition:width .3s ease}.nav-links a:hover{color:var(--charcoal)}.nav-links a:hover:after{width:100%}.nav-links a.active{color:var(--charcoal)}.nav-links a.active:after{width:100%;background:var(--accent)}.nav-links a:focus-visible{outline:2px solid var(--accent);outline-offset:-4px}.nav-cta{font-family:var(--font-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--paper);background:var(--charcoal);padding:10px 20px;text-decoration:none;border:1px solid var(--charcoal);transition:all .25s ease}.nav-cta:hover{background:var(--accent);border-color:var(--accent)}.nav-actions{display:flex;align-items:center;gap:.75rem}.language-switcher{display:inline-grid;grid-template-columns:repeat(3,1fr);border:1px solid var(--line);background:var(--ivory);height:32px}.lang-option{min-width:34px;height:30px;border:0;border-right:1px solid var(--line);background:transparent;color:var(--muted);font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;cursor:none;transition:background .2s ease,color .2s ease}.lang-option:last-child{border-right:0}.lang-option:hover,.lang-option:focus-visible{color:var(--charcoal);outline:none}.lang-option:focus-visible{box-shadow:inset 0 0 0 2px var(--accent)}.lang-option.active{background:var(--charcoal);color:var(--paper)}.theme-toggle{width:54px;height:32px;display:inline-flex;align-items:center;justify-content:center;padding:0;border:1px solid var(--line);background:var(--ivory);color:var(--charcoal);cursor:none;transition:border-color .25s ease,background .25s ease,transform .25s ease}.theme-toggle:hover,.theme-toggle:focus-visible{border-color:var(--accent);outline:none;transform:translateY(-1px)}.theme-toggle-track{position:relative;width:42px;height:20px;display:block}.theme-toggle-thumb{position:absolute;top:1px;left:1px;width:18px;height:18px;background:var(--charcoal);transition:transform .28s cubic-bezier(.2,.8,.2,1),background .25s ease}.theme-toggle-icon{position:absolute;top:2px;width:16px;height:16px;color:var(--muted);display:grid;place-items:center;transition:color .25s ease,opacity .25s ease}.theme-toggle-icon svg{width:16px;height:16px}.theme-toggle-sun{left:2px;opacity:0}.theme-toggle-moon{right:2px;opacity:1}:root[data-theme=dark] .theme-toggle-thumb{transform:translate(22px)}:root[data-theme=dark] .theme-toggle-sun{opacity:1}:root[data-theme=dark] .theme-toggle-moon{opacity:0}.hamburger{display:none;flex-direction:column;gap:5px;padding:0;border:0;background:transparent;cursor:pointer}.hamburger:focus-visible{outline:2px solid var(--accent);outline-offset:4px;border-radius:2px}.hamburger span{display:block;width:24px;height:1.5px;background:var(--charcoal);transition:all .3s}@media(max-width:768px){nav{padding:0 1rem;min-height:72px}.nav-links,.nav-cta{display:none}.hamburger{display:flex;width:42px;height:42px;justify-content:center;align-items:center}.nav-actions{gap:.55rem}.lang-option{min-width:30px;font-size:10px}.mobile-menu{position:fixed;top:72px;left:0;right:0;background:var(--nav-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--line);padding:1.5rem;display:none;flex-direction:column;gap:1rem;z-index:999;max-height:calc(100vh - 72px);overflow-y:auto}.mobile-menu.open{display:flex}.mobile-menu-controls{display:none;padding-bottom:.5rem;border-bottom:1px solid var(--line)}.mobile-menu a{font-family:var(--font-mono);font-size:14px;letter-spacing:.08em;text-transform:uppercase;color:var(--charcoal);text-decoration:none;padding:.75rem 0;border-bottom:1px solid var(--line)}.mobile-menu a:last-child{border-bottom:0}}@media(max-width:560px){nav{padding:0 .875rem}.nav-logo{font-size:12px;letter-spacing:.02em}.nav-actions>.language-switcher{display:none}.mobile-menu-controls{display:flex}.mobile-language-switcher{display:inline-grid;width:100%;height:38px}.mobile-language-switcher .lang-option{height:36px}.theme-toggle{width:50px}}@media(max-width:360px){.nav-logo{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-actions{gap:.4rem}.theme-toggle{width:46px}.hamburger{width:38px}}.breadcrumb-nav{position:fixed;top:72px;left:0;right:0;z-index:999;padding:0 3rem;height:40px;display:flex;align-items:center;background:var(--nav-bg);border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);transition:all .3s ease}.breadcrumb-list{list-style:none;display:flex;align-items:center;gap:.5rem;min-width:0}.breadcrumb-item{display:flex;align-items:center;gap:.5rem}.breadcrumb-sep{color:var(--muted);font-family:var(--font-mono);font-size:11px;opacity:.5}.breadcrumb-link,.breadcrumb-current{font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;transition:all .2s ease}.breadcrumb-link{color:var(--muted);cursor:none}.breadcrumb-link:hover{color:var(--accent)}.breadcrumb-link:focus-visible{outline:2px solid var(--accent);outline-offset:-4px}.breadcrumb-current{color:var(--accent);font-weight:500}@media(max-width:768px){.breadcrumb-nav{padding:0 1.5rem;height:36px;overflow-x:auto;scrollbar-width:none}.breadcrumb-nav::-webkit-scrollbar{display:none}.breadcrumb-list{min-width:max-content}.breadcrumb-link,.breadcrumb-current,.breadcrumb-sep{font-size:10px}}@media(max-width:480px){.breadcrumb-nav{display:flex;padding:0 1rem}.breadcrumb-item:not(:has(.breadcrumb-current)),.breadcrumb-sep{display:none}}section{scroll-margin-top:80px}#hero{scroll-margin-top:0}#about,#projects,#gallery,#experience,#github-section,#contact{scroll-margin-top:80px}@media(max-width:480px){section{scroll-margin-top:72px}}.mobile-menu a{font-family:var(--font-mono);font-size:14px;letter-spacing:.1em;text-transform:uppercase;color:var(--charcoal)}#hero{min-height:100vh;min-height:100svh;padding:0 3rem 6rem;display:flex;flex-direction:column;justify-content:flex-end;position:relative;overflow:hidden}.hero-bg-grid{position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:60px 60px;opacity:.5}.hero-index{font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;color:var(--muted);text-transform:uppercase;margin-bottom:2rem;display:flex;align-items:center;gap:1rem}.hero-index:before{content:"";display:block;width:40px;height:1px;background:var(--accent)}.hero-title{font-family:var(--font-display);font-size:clamp(52px,9vw,140px);font-weight:800;line-height:.92;letter-spacing:-.03em;color:var(--charcoal);position:relative;z-index:1}.hero-title .serif-word{font-family:var(--font-serif);font-weight:300;font-style:italic;color:var(--accent)}.hero-title .outline-text{-webkit-text-stroke:2px var(--charcoal);color:transparent}.hero-bottom{display:flex;justify-content:space-between;align-items:flex-end;margin-top:3rem;position:relative;z-index:1}.hero-desc{font-family:var(--font-mono);font-size:13px;line-height:1.8;color:var(--muted);max-width:320px}.hero-scroll{display:flex;flex-direction:column;align-items:center;gap:8px;font-family:var(--font-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}.hero-scroll-line{width:1px;height:60px;background:linear-gradient(to bottom,var(--accent),transparent);animation:scrollLine 2s ease-in-out infinite}@keyframes scrollLine{0%,to{transform:scaleY(1);opacity:1}50%{transform:scaleY(.5);opacity:.4}}.hero-availability{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11px;letter-spacing:.05em;color:var(--charcoal);padding:8px 16px;border:1px solid var(--line);background:var(--ivory);margin-top:1.5rem}.hero-dot{width:8px;height:8px;border-radius:50%;background:#22c55e;animation:pulse 2s infinite}@keyframes pulse{0%,to{box-shadow:0 0 #22c55e66}50%{box-shadow:0 0 0 6px #22c55e00}}.hero-number{position:absolute;right:3rem;top:50%;transform:translateY(-50%);font-family:var(--font-serif);font-size:clamp(120px,20vw,280px);font-weight:100;color:transparent;-webkit-text-stroke:1px rgba(0,71,255,.08);-webkit-user-select:none;user-select:none;pointer-events:none;line-height:1;letter-spacing:-.05em}@media(max-width:768px){#hero{padding:7.5rem 1.5rem 4rem}.hero-title{font-size:clamp(44px,15vw,86px);line-height:.98}.hero-index{flex-wrap:wrap;gap:.6rem 1rem;margin-bottom:1.5rem}.hero-number{display:none}.hero-bottom{flex-direction:column;align-items:flex-start;gap:2rem}.hero-scroll{display:none}}@media(max-width:420px){#hero{padding-left:1rem;padding-right:1rem;padding-bottom:3rem}.hero-title{font-size:clamp(40px,15.5vw,62px);letter-spacing:-.045em}.hero-title .outline-text{-webkit-text-stroke-width:1px}.hero-desc{font-size:12px;line-height:1.7}.hero-availability{max-width:100%;padding:8px 12px;font-size:10px}}.marquee-wrap{border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;background:var(--charcoal);padding:14px 0}.marquee-track{display:flex;gap:0;animation:marquee 25s linear infinite;white-space:nowrap}.marquee-item{font-family:var(--font-mono);font-size:12px;letter-spacing:.15em;text-transform:uppercase;color:var(--ivory);padding:0 2rem;opacity:.7}.marquee-sep{color:var(--accent);opacity:1!important;padding:0 1rem}@keyframes marquee{0%{transform:translate(0)}to{transform:translate(-50%)}}#about{padding:8rem 3rem;display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:start;border-bottom:1px solid var(--line)}.section-label{font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem}.section-label:after{content:"";flex:1;height:1px;background:var(--line);max-width:80px}.about-title{font-family:var(--font-display);font-size:clamp(32px,4vw,56px);font-weight:700;line-height:1.05;letter-spacing:-.02em;color:var(--charcoal)}.about-title em{font-family:var(--font-serif);font-weight:300;font-style:italic}.about-text{font-family:var(--font-mono);font-size:14px;line-height:1.9;color:var(--muted);margin-top:2rem}.about-stats{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);margin-top:3rem;border:1px solid var(--line)}.stat-box{padding:1.5rem;background:var(--paper);transition:background .2s}.stat-box:hover{background:var(--accent-light)}.stat-num{font-family:var(--font-serif);font-size:40px;font-weight:300;color:var(--accent);line-height:1}.stat-label{font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:.5rem}.about-right{padding-top:4rem}.skills-group{margin-bottom:2rem}.skills-group-title{font-family:var(--font-mono);font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--line)}.skills-tags{display:flex;flex-wrap:wrap;gap:.5rem}.skill-tag{font-family:var(--font-mono);font-size:12px;padding:6px 14px;border:1px solid var(--line);background:var(--ivory);color:var(--ink);letter-spacing:.05em;transition:all .2s;position:relative;overflow:hidden}.skill-tag:before{content:"";position:absolute;inset:0;background:var(--accent);transform:translateY(101%);transition:transform .3s ease}.skill-tag:hover:before{transform:translateY(0)}.skill-tag:hover{color:#fff;border-color:var(--accent)}.skill-tag span{position:relative;z-index:1}@media(max-width:768px){#about{grid-template-columns:1fr;gap:3rem;padding:4rem 1.5rem}.about-right{padding-top:0}.about-text{font-size:15px;max-width:100%}.about-stats{grid-template-columns:1fr}.skills-tags{gap:.75rem}}@media(max-width:420px){#about,#projects,#gallery,#experience,#github-section,#contact{padding-left:1rem;padding-right:1rem}.section-label{font-size:10px;letter-spacing:.16em}.about-stats{grid-template-columns:1fr 1fr}.stat-box{padding:1.1rem}.stat-num{font-size:34px}.stat-label{font-size:9px;line-height:1.4}}#projects{padding:8rem 3rem;border-bottom:1px solid var(--line)}.projects-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:4rem}.projects-title{font-family:var(--font-display);font-size:clamp(36px,5vw,72px);font-weight:800;letter-spacing:-.03em;line-height:1;color:var(--charcoal)}.projects-count{font-family:var(--font-mono);font-size:13px;color:var(--muted)}.project-item{display:grid;grid-template-columns:80px 1fr 200px 120px;align-items:center;padding:2rem 0;border-bottom:1px solid var(--line);gap:2rem;cursor:none;position:relative;transition:background .2s;overflow:hidden}.project-item:before{content:"";position:absolute;left:-20px;top:0;bottom:0;width:3px;background:var(--accent);transform:scaleY(0);transition:transform .3s ease}.project-item:hover:before{transform:scaleY(1)}.project-item:hover{background:var(--ivory);padding-left:1rem;padding-right:1rem;margin:0 -1rem}.project-num{font-family:var(--font-mono);font-size:12px;color:var(--muted);letter-spacing:.1em}.project-name{font-family:var(--font-display);font-size:clamp(20px,2.5vw,32px);font-weight:700;letter-spacing:-.02em;color:var(--charcoal)}.project-desc{font-family:var(--font-mono);font-size:12px;color:var(--muted);margin-top:4px}.project-tech{display:flex;gap:.5rem;flex-wrap:wrap}.tech-badge{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:4px 10px;border:1px solid var(--line);color:var(--muted)}.project-link{font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);text-decoration:none;display:flex;align-items:center;gap:.5rem;justify-content:flex-end}.project-link svg{transition:transform .2s}.project-item:hover .project-link svg{transform:translate(4px,-4px)}.project-item:focus-within{background:var(--ivory);padding-left:1rem;padding-right:1rem;margin:0 -1rem}.project-item:focus-within:before{transform:scaleY(1)}.project-link:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.project-preview{position:absolute;right:200px;top:50%;transform:translateY(-50%) scale(.9);width:200px;height:130px;object-fit:cover;opacity:0;transition:all .3s ease;pointer-events:none;border:1px solid var(--line);z-index:10}.project-item:hover .project-preview{opacity:1;transform:translateY(-50%) scale(1)}@media(max-width:768px){#projects{padding:4rem 1.5rem}.projects-header{flex-direction:column;align-items:flex-start;gap:1rem}.project-item{grid-template-columns:40px 1fr;align-items:flex-start;gap:1rem}.project-tech{grid-column:1 / -1;display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.project-link{grid-column:1 / -1;justify-content:flex-start;margin-top:1rem}.project-preview{display:none}}@media(max-width:560px){.project-item{grid-template-columns:32px 1fr;gap:.8rem;padding:1.5rem 0}.project-item:hover,.project-item:focus-within{margin:0;padding-left:0;padding-right:0}.project-name{font-size:clamp(22px,8vw,32px)}.tech-badge{font-size:9px;padding:4px 8px}}#gallery{padding:8rem 3rem;border-bottom:1px solid var(--line);background:var(--ivory)}.gallery-header{display:grid;grid-template-columns:1fr 1fr;gap:4rem;margin-bottom:4rem;align-items:end}.gallery-title{font-family:var(--font-display);font-size:clamp(36px,5vw,72px);font-weight:800;letter-spacing:-.03em;line-height:1}.gallery-desc{font-family:var(--font-mono);font-size:13px;line-height:1.9;color:var(--muted)}.gallery-filters{display:flex;gap:1rem;margin-bottom:3rem;flex-wrap:wrap}.filter-btn{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;padding:8px 20px;border:1px solid var(--line);background:transparent;color:var(--muted);cursor:none;transition:all .25s}.filter-btn.active,.filter-btn:hover{background:var(--charcoal);color:var(--paper);border-color:var(--charcoal)}.filter-btn:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.gallery-grid{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:80px;gap:12px}.gallery-item{overflow:hidden;position:relative;background:var(--cream);cursor:none}.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease;display:block;filter:var(--image-filter)}.gallery-item:hover img{transform:scale(1.06)}.gallery-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(26,24,20,.85) 0%,transparent 60%);opacity:0;transition:opacity .3s ease;display:flex;flex-direction:column;justify-content:flex-end;padding:1.5rem}.gallery-item:hover .gallery-overlay{opacity:1}.gallery-item:focus-visible{outline:2px solid var(--accent);outline-offset:-4px}.gallery-item:focus-visible .gallery-overlay{opacity:1}.gallery-item-title{font-family:var(--font-display);font-size:15px;font-weight:600;color:#fff;margin-bottom:4px}.gallery-item-cat{font-family:var(--font-mono);font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:#fff9}.g1{grid-column:span 5;grid-row:span 5}.g2{grid-column:span 4;grid-row:span 3}.g3{grid-column:span 3;grid-row:span 3}.g4{grid-column:span 4;grid-row:span 4}.g5{grid-column:span 3;grid-row:span 2}.g6{grid-column:span 5;grid-row:span 4}.g7{grid-column:span 4;grid-row:span 2}.g8{grid-column:span 3;grid-row:span 3}.g9{grid-column:span 5;grid-row:span 3}@media(max-width:1024px){.gallery-grid{grid-template-columns:repeat(6,1fr)}.g1{grid-column:span 4}.g2{grid-column:span 2}.g3,.g5,.g4{grid-column:span 3}.g6,.g7,.g8,.g9{grid-column:span 6}}@media(max-width:768px){#gallery{padding:4rem 1.5rem}.gallery-header{grid-template-columns:1fr;gap:1.5rem}.gallery-grid{grid-template-columns:1fr 1fr;grid-auto-rows:200px}.g1,.g2,.g3,.g4,.g5,.g6,.g7,.g8,.g9{grid-column:span 1;grid-row:span 1}.g1{grid-column:span 2}}@media(max-width:560px){.gallery-filters{flex-wrap:nowrap;gap:.6rem;margin-inline:-1rem;padding-inline:1rem;overflow-x:auto;scrollbar-width:none}.gallery-filters::-webkit-scrollbar{display:none}.filter-btn{flex:0 0 auto;padding:8px 14px;font-size:10px}.gallery-grid{grid-template-columns:1fr;grid-auto-rows:minmax(220px,62vw);gap:10px}.g1,.g2,.g3,.g4,.g5,.g6,.g7,.g8,.g9{grid-column:span 1}}@media(hover:none),(pointer:coarse){.gallery-overlay{opacity:1}}#experience{padding:8rem 3rem;border-bottom:1px solid var(--line)}.exp-grid{display:grid;grid-template-columns:1fr 2fr;gap:6rem;margin-top:4rem}.exp-timeline{position:relative}.exp-item{border-bottom:1px solid var(--line);position:relative;padding:2rem 0 2rem 1.5rem;cursor:none;transition:padding-left .2s}.exp-item:before{content:"";position:absolute;left:0;top:2.5rem;width:6px;height:6px;border-radius:50%;background:var(--line);transition:background .2s,transform .2s}.exp-item:hover:before{background:var(--accent);transform:scale(1.5)}.exp-item:hover{padding-left:2rem}.exp-year{font-family:var(--font-mono);font-size:11px;letter-spacing:.15em;color:var(--accent);margin-bottom:.5rem}.exp-role{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--charcoal);margin-bottom:.25rem}.exp-company{font-family:var(--font-mono);font-size:12px;color:var(--muted);margin-bottom:.75rem}.exp-desc{font-family:var(--font-mono);font-size:12px;line-height:1.8;color:var(--muted)}.exp-right{position:relative}.exp-big-text{font-family:var(--font-display);font-size:clamp(48px,6vw,96px);font-weight:800;letter-spacing:-.03em;line-height:1.05;color:var(--charcoal);margin-bottom:3rem}.exp-big-text em{font-family:var(--font-serif);font-weight:300;font-style:italic;color:var(--accent)}.awards-list{list-style:none}.award-item{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 0;border-bottom:1px solid var(--line)}.award-name{font-family:var(--font-display);font-size:16px;font-weight:600;color:var(--charcoal)}.award-org{font-family:var(--font-mono);font-size:12px;color:var(--muted);margin-top:2px}.award-year{font-family:var(--font-mono);font-size:12px;color:var(--accent)}@media(max-width:768px){#experience{padding:4rem 1.5rem}.exp-grid{grid-template-columns:1fr;gap:3rem}.exp-item{padding-left:0}.exp-item:before{left:auto;right:0}}@media(max-width:560px){.exp-grid{margin-top:2.5rem}.exp-big-text{font-size:clamp(38px,13vw,58px)}.award-item{align-items:flex-start;gap:1rem}}#github-section{padding:6rem 3rem;border-bottom:1px solid var(--line);background:var(--charcoal);color:var(--paper)}.github-inner{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center}.github-title{font-family:var(--font-display);font-size:clamp(36px,5vw,64px);font-weight:800;letter-spacing:-.03em;line-height:1.05;color:var(--paper)}.github-title em{font-family:var(--font-serif);font-weight:300;font-style:italic;color:var(--accent)}.github-desc{font-family:var(--font-mono);font-size:13px;line-height:1.9;color:#f5f0e880;margin-top:1.5rem}.github-btn{display:inline-flex;align-items:center;gap:.75rem;font-family:var(--font-mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--paper);border:1px solid rgba(245,240,232,.2);padding:14px 28px;text-decoration:none;margin-top:2.5rem;transition:all .25s}.github-btn:hover{background:var(--accent);border-color:var(--accent)}#github-stats{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:#ffffff0f}.gh-stat{padding:2rem;background:#ffffff08;transition:background .2s}.gh-stat:hover{background:#0047ff26}.skeleton{position:relative;overflow:hidden;background-color:#ffffff0d;border-radius:4px;min-height:44px;min-width:60px;display:inline-block}.skeleton:after{content:"";position:absolute;inset:0;transform:translate(-100%);background-image:linear-gradient(90deg,#fff0 0,#ffffff0d 20%,#ffffff1a 60%,#fff0);animation:shimmer 1.5s infinite}@keyframes shimmer{to{transform:translate(100%)}}.gh-num{font-family:var(--font-serif);font-size:44px;font-weight:300;color:var(--accent);line-height:1}.gh-label{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#f5f0e866;margin-top:.5rem}.contribution-grid{margin-top:3rem;max-width:100%;overflow-x:auto;padding-bottom:.35rem;scrollbar-width:thin}.contrib-title{font-family:var(--font-mono);font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:#f5f0e866;margin-bottom:1rem}.react-activity-calendar{font-family:var(--font-mono)}@media(max-width:768px){#github-section{padding:4rem 1.5rem}.github-inner{grid-template-columns:1fr;gap:3rem}}@media(max-width:420px){#github-stats{grid-template-columns:1fr}.gh-stat{padding:1.4rem}}#contact{padding:8rem 3rem;border-bottom:1px solid var(--line)}.contact-inner{display:grid;grid-template-columns:1fr 1fr;gap:8rem}.contact-big{font-family:var(--font-display);font-size:clamp(48px,7vw,112px);font-weight:800;letter-spacing:-.04em;line-height:.95;color:var(--charcoal)}.contact-big em{display:block;font-family:var(--font-serif);font-weight:300;font-style:italic;color:var(--accent)}.contact-sub{font-family:var(--font-mono);font-size:13px;line-height:1.9;color:var(--muted);margin-top:2rem;max-width:360px}.contact-links{margin-top:3rem;display:flex;flex-direction:column;gap:0}.contact-link{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 0;border-bottom:1px solid var(--line);text-decoration:none;color:var(--charcoal);transition:padding-left .2s;gap:1rem}.contact-link:hover{padding-left:1rem;color:var(--accent)}.contact-link:focus-visible{outline:2px solid var(--accent);outline-offset:-2px;padding-left:1rem}.contact-link-name{font-family:var(--font-display);font-size:18px;font-weight:700;letter-spacing:-.01em}.contact-link-handle{font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;color:var(--muted);overflow-wrap:anywhere}.contact-form-wrap{padding-top:1rem}.form-row{margin-bottom:1.5rem}.form-label{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:.6rem}.form-input,.form-textarea{width:100%;font-family:var(--font-mono);font-size:14px;color:var(--charcoal);background:transparent;border:none;border-bottom:1px solid var(--line);padding:.75rem 0;outline:none;transition:border-color .2s;resize:none}.form-input:focus,.form-textarea:focus{border-color:var(--accent)}.form-input:focus-visible,.form-textarea:focus-visible{outline:2px solid var(--accent);outline-offset:-2px;border-color:var(--accent)}.form-input::placeholder,.form-textarea::placeholder{color:var(--line)}.form-submit{font-family:var(--font-mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--paper);background:var(--charcoal);border:none;padding:16px 40px;cursor:none;margin-top:1rem;transition:background .25s;position:relative;overflow:hidden}.form-submit:before{content:"";position:absolute;inset:0;background:var(--accent);transform:translate(-101%);transition:transform .3s ease}.form-submit:hover:before{transform:translate(0)}.form-submit:focus-visible{outline:2px solid var(--paper);outline-offset:2px}.form-submit span{position:relative;z-index:1}@media(max-width:768px){#contact{padding:4rem 1.5rem}.contact-inner{grid-template-columns:1fr;gap:4rem}}@media(max-width:560px){.contact-big{font-size:clamp(42px,15vw,70px)}.contact-link{align-items:flex-start;padding:1rem 0}.contact-link svg{flex:0 0 auto;margin-top:.25rem}.form-submit{width:100%;padding:16px 24px}}footer{padding:3rem;display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--line)}.footer-left{font-family:var(--font-mono);font-size:12px;color:var(--muted)}.footer-logo{font-family:var(--font-display);font-size:20px;font-weight:800;letter-spacing:-.02em;color:var(--charcoal)}.footer-logo span{color:var(--accent)}.footer-right{font-family:var(--font-mono);font-size:12px;color:var(--muted)}@media(max-width:768px){footer{flex-direction:column;gap:1.5rem;text-align:center;padding:2rem 1.5rem}}#loader{position:fixed;inset:0;background:var(--charcoal);z-index:100000;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:2rem}.loader-name{font-family:var(--font-display);font-size:clamp(32px,6vw,80px);font-weight:800;color:var(--paper);letter-spacing:-.03em;opacity:0;transform:translateY(20px)}.loader-bar-wrap{width:200px;height:1px;background:#ffffff26;position:relative;overflow:hidden}.loader-bar{position:absolute;top:0;left:0;height:100%;background:var(--accent);width:0}.loader-counter{font-family:var(--font-mono);font-size:12px;color:#fff6;letter-spacing:.2em}.reveal{opacity:0;transform:translateY(30px)}#proj-hover-img{position:fixed;width:280px;height:180px;pointer-events:none;z-index:500;opacity:0;transform:scale(.95);transition:opacity .25s,transform .25s;overflow:hidden;border:1px solid var(--line)}#proj-hover-img img{width:100%;height:100%;object-fit:cover;filter:var(--image-filter)}#proj-hover-img.visible{opacity:1;transform:scale(1)}.loader-accent{color:var(--accent)}.github-section-label{color:#f5f0e866}.form-success-msg{font-family:var(--font-mono);font-size:12px;color:var(--accent);margin-top:1rem;letter-spacing:.05em}.form-error-msg{font-family:var(--font-mono);font-size:12px;color:#e55;margin-top:1rem;letter-spacing:.05em}.form-submit.sending{opacity:.7;cursor:not-allowed}.form-submit.sent{opacity:.6}.project-link{-webkit-appearance:none;background:none;border:none;cursor:none}.gallery-expand-hint{position:absolute;top:1rem;right:1rem;width:32px;height:32px;background:#00000073;border:1px solid rgba(255,255,255,.2);border-radius:2px;display:flex;align-items:center;justify-content:center;color:#fff;opacity:0;transform:scale(.85);transition:opacity .25s ease,transform .25s ease;pointer-events:none}.gallery-item:hover .gallery-expand-hint,.gallery-item:focus-visible .gallery-expand-hint{opacity:1;transform:scale(1)}.lightbox-overlay{position:fixed;inset:0;z-index:10000;background:#000000eb;display:flex;align-items:center;justify-content:center;padding:2rem;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:lightboxFadeIn .2s ease}@keyframes lightboxFadeIn{0%{opacity:0}to{opacity:1}}.lightbox-content{display:flex;flex-direction:column;align-items:center;gap:1rem;max-width:min(88vw,1100px);animation:lightboxSlideUp .3s cubic-bezier(.2,.8,.2,1)}@keyframes lightboxSlideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.lightbox-img{max-height:78vh;max-width:88vw;width:auto;height:auto;object-fit:contain;display:block;border-radius:2px}.lightbox-footer{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:88vw;font-family:var(--font-mono);font-size:11px;color:#ffffff80;letter-spacing:.08em;gap:1rem}.lightbox-counter{font-variant-numeric:tabular-nums;white-space:nowrap}.lightbox-close{position:fixed;top:1.25rem;right:1.25rem;width:40px;height:40px;background:#ffffff14;border:1px solid rgba(255,255,255,.18);color:#fffc;display:flex;align-items:center;justify-content:center;border-radius:2px;cursor:none;z-index:10001;transition:background .2s,color .2s}.lightbox-close:hover,.lightbox-close:focus-visible{background:#ffffff2e;color:#fff;outline:none}.lightbox-nav{position:fixed;top:50%;transform:translateY(-50%);width:44px;height:44px;background:#ffffff12;border:1px solid rgba(255,255,255,.15);color:#fffc;display:flex;align-items:center;justify-content:center;border-radius:2px;cursor:none;z-index:10001;transition:background .2s,color .2s,opacity .2s}.lightbox-nav:hover:not(:disabled),.lightbox-nav:focus-visible{background:#ffffff29;color:#fff;outline:none}.lightbox-nav:disabled{opacity:.2;cursor:default}.lightbox-prev{left:1.25rem}.lightbox-next{right:1.25rem}@media(max-width:560px){.lightbox-prev{left:.5rem}.lightbox-next{right:.5rem}.lightbox-close{top:.75rem;right:.75rem}}.drawer-overlay{position:fixed;inset:0;z-index:10000;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:drawerFadeIn .3s ease}@keyframes drawerFadeIn{0%{opacity:0}to{opacity:1}}.project-drawer{position:fixed;top:0;right:0;bottom:0;z-index:10001;width:min(520px,95vw);background:var(--paper);border-left:1px solid var(--line);overflow-y:auto;padding:4.5rem 2.5rem 3rem;display:flex;flex-direction:column;gap:1.75rem;transform:translate(100%);transition:transform .4s cubic-bezier(.2,.8,.2,1)}.project-drawer.open{transform:translate(0)}.drawer-close{position:absolute;top:1.25rem;right:1.25rem;width:36px;height:36px;background:transparent;border:1px solid var(--line);color:var(--muted);display:flex;align-items:center;justify-content:center;border-radius:2px;cursor:none;transition:border-color .2s,color .2s}.drawer-close:hover,.drawer-close:focus-visible{border-color:var(--charcoal);color:var(--charcoal);outline:none}.drawer-num{font-family:var(--font-mono);font-size:11px;color:var(--accent);letter-spacing:.12em;text-transform:uppercase}.drawer-name{font-family:var(--font-display);font-size:clamp(22px,4vw,34px);font-weight:700;letter-spacing:-.02em;color:var(--charcoal);line-height:1.1;margin:0}.drawer-img-wrap{overflow:hidden;border:1px solid var(--line);background:var(--cream);flex-shrink:0}.drawer-img{width:100%;height:220px;object-fit:cover;display:block;filter:var(--image-filter);transition:transform .5s ease}.drawer-img-wrap:hover .drawer-img{transform:scale(1.04)}.drawer-desc{font-family:var(--font-mono);font-size:13px;line-height:1.85;color:var(--muted);margin:0}.drawer-tech{display:flex;gap:.5rem;flex-wrap:wrap}.drawer-actions{display:flex;flex-direction:column;gap:.75rem;margin-top:auto;padding-top:1.5rem;border-top:1px solid var(--line)}.drawer-btn{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;padding:14px 24px;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:none;transition:background .25s ease,border-color .25s ease,color .25s ease;border:1px solid;border-radius:0}.drawer-btn-primary{background:var(--charcoal);color:var(--paper);border-color:var(--charcoal)}.drawer-btn-primary:hover,.drawer-btn-primary:focus-visible{background:var(--accent);border-color:var(--accent);color:#fff;outline:none}.drawer-btn-secondary{background:transparent;color:var(--charcoal);border-color:var(--line)}.drawer-btn-secondary:hover,.drawer-btn-secondary:focus-visible{border-color:var(--charcoal);outline:none}@media(max-width:480px){.project-drawer{padding:4rem 1.5rem 2rem}}body{overflow-x:hidden}#hero,#about,#projects,#gallery,#experience,#github-section,#contact{max-width:100vw;overflow-x:hidden}@media(max-width:768px){.form-input,.form-textarea{font-size:16px}.mobile-menu,.project-drawer,.contribution-grid,.gallery-filters{-webkit-overflow-scrolling:touch}}nav{padding-left:max(3rem,env(safe-area-inset-left,0px));padding-right:max(3rem,env(safe-area-inset-right,0px))}@media(max-width:768px){nav{padding-left:max(1rem,env(safe-area-inset-left,0px));padding-right:max(1rem,env(safe-area-inset-right,0px))}.mobile-menu{padding-left:max(1.5rem,env(safe-area-inset-left,0px));padding-right:max(1.5rem,env(safe-area-inset-right,0px));padding-bottom:max(1.5rem,env(safe-area-inset-bottom,0px))}footer{padding-bottom:max(2rem,calc(1rem + env(safe-area-inset-bottom,0px)))}}@media(hover:none),(pointer:coarse){.filter-btn{min-height:44px;padding:0 1.25rem}.lang-option{min-height:44px;min-width:44px}.project-link{min-height:44px;display:inline-flex;align-items:center}.drawer-btn{min-height:52px;padding:16px 24px}.github-btn,.contact-link{min-height:52px}.lightbox-nav{width:52px;height:52px}.lightbox-close{width:48px;height:48px}.gallery-expand-hint{opacity:1;transform:scale(1)}.gallery-overlay{opacity:1}}@media(max-width:768px){#hero{padding-top:6.5rem}}@media(min-width:769px)and (max-width:1024px){#about,#projects,#gallery,#experience,#contact{padding-left:2rem;padding-right:2rem}#github-section{padding:5rem 2rem}.github-inner{gap:3rem}.contact-inner{gap:4rem}.exp-grid{gap:3rem}.project-item{gap:1.5rem}}@media(max-width:380px){#hero{padding-top:5.5rem;padding-left:1rem;padding-right:1rem}.hero-index{display:none}.project-drawer{width:100vw}#about,#projects,#gallery,#experience,#github-section,#contact{padding-left:1rem;padding-right:1rem}.contrib-cell{width:7px;height:7px}.award-item{flex-direction:column;gap:.25rem}.award-year{font-size:11px}}@media print{nav,.mobile-menu,#loader,#cursor,.marquee-wrap,.gallery-filters,.hero-bg-grid,.hero-scroll,.hero-number,.lightbox-overlay,.project-drawer,.drawer-overlay{display:none!important}body{background:#fff;color:#000}section{break-inside:avoid;page-break-inside:avoid;padding:2rem 1rem!important}a{color:#000;text-decoration:underline}}
