*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg: #0a0a0a;--bg-secondary: #111;--card: #1a1a1a;--border: #2a2a2a;--text: #e0e0e0;--text-heading: #fff;--text-muted: #888;--accent: #4fc3f7;--accent-hover: #81d4fa;--badge-bg: #252525;--coming-soon: #ff9800;--header-bg: rgba(10, 10, 10, .85);--header-bg-scrolled: rgba(10, 10, 10, .95);--link-hover-bg: #222;--shimmer-mid: #2a2a2a;--error-border: #ef535033;color-scheme:dark}[data-theme=light]{--bg: #f5f5f5;--bg-secondary: #eee;--card: #fff;--border: #ddd;--text: #333;--text-heading: #111;--text-muted: #4a4a4a;--accent: #0288d1;--accent-hover: #0277bd;--badge-bg: #e8e8e8;--header-bg: rgba(245, 245, 245, .85);--header-bg-scrolled: rgba(245, 245, 245, .95);--link-hover-bg: #eee;--shimmer-mid: #e0e0e0;--error-border: #ef535033;color-scheme:light}html,body{overflow-x:hidden}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;display:flex;flex-direction:column}body:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:-1;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:256px 256px}a{color:var(--accent);text-decoration:none}.skip-link{position:absolute;top:-9999px;left:-9999px;background:var(--accent);color:#000;padding:.5rem 1rem;border-radius:0 0 8px 8px;z-index:1000;font-weight:600;font-size:.85rem}.skip-link:focus{top:0;left:1rem}@keyframes headerMesh{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}header{text-align:center;padding:2.5rem 1rem 1rem;position:sticky;top:0;z-index:100;background:var(--header-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);transition:padding .3s ease,background .3s ease;overflow:hidden}header:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#4fc3f70f,#ab47bc0a,#4fc3f70f);background-size:400% 400%;animation:headerMesh 20s ease infinite;pointer-events:none;z-index:-1}header.scrolled{padding:1rem 1rem .6rem;background:var(--header-bg-scrolled);border-bottom:1px solid var(--border)}header h1{font-size:clamp(1.3rem,4vw,1.8rem);font-weight:600;letter-spacing:-.02em;background:linear-gradient(135deg,#4fc3f7,#ab47bc 35%,#ff7043 65%,#81d4fa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 0 20px rgba(79,195,247,.3)) drop-shadow(0 0 40px rgba(171,71,188,.15));transition:font-size .3s ease}header p{color:var(--text-muted);margin-top:.4rem;font-size:.95rem;transition:font-size .3s ease,margin .3s ease}header.scrolled p{font-size:.8rem;margin-top:.2rem}.header-controls{display:flex;align-items:center;justify-content:center;gap:1.5rem;margin-top:.6rem}header.scrolled .header-controls{margin-top:.3rem}.header-nav{display:flex;gap:1rem}.header-nav a{color:var(--text-muted);font-size:.8rem;font-weight:500;letter-spacing:.02em;transition:color .2s;text-decoration:none}.header-nav a:hover{color:var(--accent)}.header-nav a.active{color:var(--accent);position:relative}.header-nav a.active:after{content:"";position:absolute;bottom:-4px;left:0;right:0;height:2px;background:var(--accent);border-radius:1px}.theme-toggle{position:absolute;top:50%;right:1rem;transform:translateY(-50%);background:var(--card);border:1px solid var(--border);border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-muted);font-size:1rem;transition:color .2s,border-color .2s,width .3s,height .3s,font-size .3s;line-height:1;z-index:101}header.scrolled .theme-toggle{width:30px;height:30px;font-size:.85rem}.theme-toggle:hover{color:var(--accent);border-color:var(--accent)}.hamburger{display:none;position:absolute;top:50%;left:1rem;transform:translateY(-50%);background:var(--card);border:1px solid var(--border);border-radius:6px;width:32px;height:32px;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;color:var(--text);z-index:101}@media(max-width:480px){.header-nav{display:none}.hamburger{display:flex}header{padding:1.5rem 1rem .8rem}header.scrolled{padding:.8rem 1rem .5rem}header h1{font-size:1.3rem}header p{font-size:.8rem;margin-top:.2rem}}.mobile-nav-overlay{position:fixed;inset:0;background:#000000d9;z-index:200;display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:0;pointer-events:none;transform:translate(100%);transition:opacity .3s ease,transform .3s ease}.mobile-nav-overlay.active{opacity:1;pointer-events:auto;transform:translate(0)}.mobile-nav-close{position:absolute;top:1.5rem;right:1.5rem;background:none;border:none;color:#fff;font-size:2rem;cursor:pointer;padding:.5rem;line-height:1}.mobile-nav-links{display:flex;flex-direction:column;gap:2rem;text-align:center}.mobile-nav-links a{color:#fff;font-size:1.5rem;font-weight:600;text-decoration:none;transition:color .2s}.mobile-nav-links a:hover{color:var(--accent)}.projects{flex:1;display:grid;grid-template-columns:1fr;gap:2rem;max-width:900px;width:100%;margin:2rem auto;padding:0 1.5rem;overflow:hidden}@media(min-width:720px){.projects{grid-template-columns:repeat(2,1fr)}}.card{--shimmer-delay: var(--fade-delay, 0ms);background:var(--card);border:1px solid var(--border);border-radius:10px;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease;position:relative;outline:none;will-change:transform}.card:focus-visible{box-shadow:0 0 0 3px var(--accent)}.card:hover{box-shadow:0 8px 40px #3d5a7326,0 0 20px #c0ccd614}.card:before{content:"";position:absolute;inset:-2px;border-radius:12px;background:linear-gradient(90deg,#3d5a73,#7a8a98,#c0ccd6,#7a8a98,#3d5a73);background-size:400% 100%;z-index:-1;opacity:0;transition:opacity .4s ease;animation:gradientShift 8s linear infinite}.card:hover:before,.card:focus-visible:before{opacity:.35}@keyframes gradientShift{0%{background-position:0% 50%}to{background-position:400% 50%}}.card-img{position:relative;width:100%;aspect-ratio:16/9;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;overflow:hidden;border-radius:10px 10px 0 0;box-shadow:0 4px 24px #0006,0 1px 4px #0000004d,inset 0 1px #ffffff0a}.card-img:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,#0000001a,#0000004d);pointer-events:none;z-index:1}.card-img img{width:100%;height:100%;object-fit:cover;transition:opacity .3s ease}.card-img .carousel{background:linear-gradient(135deg,#1a1520,#2d1f3a,#1a2030);background-size:cover}.card-img .carousel:after{content:"";position:absolute;bottom:0;left:0;right:0;height:40%;background:linear-gradient(transparent 0%,var(--card) 100%);pointer-events:none;z-index:1}.card-body{padding:1.2rem}.card-body h2{font-size:clamp(1.2rem,3.5vw,1.6rem);font-weight:600;color:var(--text-heading);margin-bottom:.5rem;letter-spacing:-.02em;display:flex;align-items:baseline;flex-wrap:wrap;gap:.4rem}.card-body h2 .subtitle{display:block;font-size:.8rem;font-weight:400;color:var(--text-muted);letter-spacing:0;margin-top:.15rem;width:100%}.card-body .desc{font-size:.9rem;color:var(--text-muted);line-height:1.5;margin-bottom:.4rem}.card-updated{font-size:.72rem;color:var(--text-muted);margin-bottom:.75rem;opacity:.7}.ci-badge{font-size:.75rem;font-weight:600;margin-left:.3rem}.ci-badge.ci-success{color:#66bb6a}.ci-badge.ci-failure{color:#ef5350}.tech{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:1.2rem}.tech span{background:var(--badge-bg);color:var(--text);font-size:.72rem;padding:3px 10px;border-radius:20px;border:1px solid var(--border)}.buttons{display:flex;gap:.75rem}.btn{flex:1;text-align:center;padding:.55rem 1rem;border-radius:8px;font-size:.85rem;font-weight:500;transition:background .15s ease,color .15s ease;border:1px solid var(--border);color:var(--text)}.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn-primary{background:var(--accent);color:#000;border-color:var(--accent)}.btn-primary:hover{background:var(--accent-hover)}.btn:not(.btn-primary):hover{background:var(--badge-bg)}.test-badge{display:inline-flex;align-items:center;gap:4px;font-size:.72rem;font-weight:500;color:#a5d6a7;background:#1a2b1a;border:1px solid #2e5930;padding:3px 10px;border-radius:20px;margin-bottom:1rem}[data-theme=light] .test-badge{color:#2e7d32}.card-img-gradient:before,.card-img-gradient-sat:before,.card-img-gradient-audio:before,.card-img-gradient-inky:before{display:none}.card-img-gradient{background:linear-gradient(135deg,#4fc3f7,#ab47bc 35%,#ff7043 65%,#81d4fa);display:flex;align-items:center;justify-content:center}.card-img-gradient-sat{background:linear-gradient(135deg,#0d47a1,#00897b,#1a237e);display:flex;align-items:center;justify-content:center}.card-img-gradient-audio{background:linear-gradient(135deg,#7b1fa2,#ec407a,#ff7043);display:flex;align-items:center;justify-content:center}.card-img-gradient-inky{background:linear-gradient(135deg,#004d40,#00796b 40%,#26a69a,#1a237e);display:flex;align-items:center;justify-content:center}.card-meta-badges{display:flex;gap:.5rem;margin-bottom:.5rem}.card-meta-badge{font-size:.7rem;color:var(--text-muted)}.card-img-text{font-size:1.6rem;font-weight:700;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.3);letter-spacing:-.02em}.btn-disabled{opacity:.5;pointer-events:none;cursor:default}.card[data-link]{cursor:pointer}.card-img-badges{position:absolute;bottom:12px;left:10px;display:flex;gap:6px;z-index:2;flex-wrap:wrap}.card-img-badge{font-size:.65rem;font-weight:600;padding:2px 8px;border-radius:12px;color:#fff;backdrop-filter:blur(4px)}.card-img-badge.blue{background:#2196f3b3}.card-img-badge.green{background:#4caf50b3}.card-img-badge.orange{background:#ff9800b3}.lang-bar{margin-bottom:.75rem}.lang-bar-track{height:4px;border-radius:2px;overflow:hidden;background:var(--border);position:relative}.lang-bar-fill{display:flex;height:100%;border-radius:2px;overflow:hidden}.lang-bar-fill span{height:100%;min-width:2px;filter:blur(.3px);position:relative;transition:width .6s ease-out}.lang-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--card);border:1px solid var(--border);color:var(--text);font-size:.7rem;padding:4px 8px;border-radius:4px;white-space:nowrap;pointer-events:none;z-index:10;box-shadow:0 4px 12px #0000004d}.lang-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:var(--border)}.lang-legend{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.35rem}.lang-total{font-size:.72rem;font-weight:600;color:var(--text);margin-right:.3rem}.lang-legend-item{display:flex;align-items:center;gap:.25rem;font-size:.65rem;color:var(--text-muted)}.lang-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.heatmap-row{display:flex;gap:2px;margin-top:.4rem;margin-bottom:.3rem}.heatmap-cell{flex:1;height:10px;border-radius:2px;background:var(--border);opacity:0;transition:background .2s,opacity .3s ease}.heatmap-cell.active{opacity:1}.filter-bar{display:flex;justify-content:center;gap:.5rem;flex-wrap:wrap;max-width:900px;margin:1rem auto 0;padding:0 1.5rem}.filter-pill{background:var(--badge-bg);color:var(--text);font-size:.75rem;padding:5px 14px;border-radius:20px;border:1px solid var(--border);cursor:pointer;font-family:inherit;transition:background .2s,color .2s,border-color .2s}[data-theme=light] .filter-pill{color:#1a1a1a;background:#d4d4d4;border-color:#bbb}.filter-pill:hover{border-color:var(--accent);color:var(--text)}.filter-pill.active{background:var(--accent);color:#000;border-color:var(--accent)}.card.filter-hidden{opacity:0;transform:scale(.95);pointer-events:none;position:absolute;visibility:hidden;transition:opacity .3s ease,transform .3s ease}.card.filter-visible{opacity:1;transform:scale(1);position:relative;visibility:visible;transition:opacity .3s ease,transform .3s ease}@media(max-width:719px){.projects{gap:1.5rem;padding:0 1rem}}@media(max-width:480px){.card-body{padding:.8rem}.card-body h2{font-size:1.1rem}.card-body .desc{font-size:.8rem;line-height:1.4}.tech span{font-size:.65rem;padding:2px 8px}.card-highlight{font-size:.7rem}.card-updated,.test-badge{font-size:.65rem}.btn{font-size:.8rem;padding:.45rem .8rem}}.card-dots{display:none}.card-dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:background .2s}.card-dot.active{background:var(--accent)}.carousel{position:relative;width:100%;height:100%;touch-action:pan-y}.carousel-slide{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .6s ease}.carousel-slide.active{opacity:1}@keyframes kenBurns{0%{transform:scale(1)}to{transform:scale(1.05)}}.carousel-slide.active.kb-zoom{animation:kenBurns 3.5s ease-out forwards}.carousel-dots{position:absolute;bottom:8px;left:50%;transform:translate(-50%);display:flex;gap:4px;z-index:2}.dot{width:6px;height:6px;border-radius:50%;background:#ffffff4d;cursor:pointer;transition:background .2s}@keyframes dotPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.7}}.dot.active{background:#fff;animation:dotPulse 2s ease-in-out infinite}.dot:focus-visible{outline:2px solid var(--accent);outline-offset:2px}@media(max-width:719px){.dot{width:5px;height:5px;padding:6px;box-sizing:content-box}}.timeline-section{max-width:700px;width:100%;margin:.5rem auto 1.5rem;padding:0 1.5rem}.timeline-section h2{font-size:clamp(1.1rem,3vw,1.3rem);color:var(--text-heading);margin-bottom:1rem;text-align:center;font-weight:600}.timeline{position:relative;padding:1rem 0}.timeline-line{position:absolute;left:8px;top:0;bottom:0;width:2px;background:var(--border)}.timeline-item{position:relative;padding-left:32px;margin-bottom:1rem}.timeline-dot{position:absolute;left:2px;top:4px;width:14px;height:14px;border-radius:50%;background:var(--card);border:2px solid var(--accent)}.timeline-content{background:var(--card);border:1px solid var(--border);border-radius:6px;padding:.6rem .85rem}.commit-msg{font-size:.82rem;color:var(--text);margin-bottom:.35rem;line-height:1.4;word-break:break-word}.commit-msg.expandable{cursor:pointer}.commit-msg.expandable:hover{color:var(--accent)}.repo-badge{font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:12px;text-transform:uppercase;letter-spacing:.03em;transition:box-shadow .2s ease}.repo-megabonk{background:#1a2a33;color:#e1f5fe}.repo-volttracker{background:#1a2b1a;color:#c8e6c9}.repo-landing-page{background:#2a1a2e;color:#e1bee7}.repo-satellite_processor{background:#2e2415;color:#ffe0b2}.repo-audiowhisper{background:#2e1520;color:#f8bbd0}[data-theme=light] .repo-megabonk{color:#0277bd}[data-theme=light] .repo-volttracker{color:#2e7d32}[data-theme=light] .repo-landing-page{color:#7b1fa2}[data-theme=light] .repo-satellite_processor{color:#e65100}[data-theme=light] .repo-audiowhisper{color:#c2185b}.repo-megabonk:hover{box-shadow:0 0 8px #4fc3f780}.repo-volttracker:hover{box-shadow:0 0 8px #4caf5080}.repo-landing-page:hover{box-shadow:0 0 8px #ab47bc80}.repo-satellite_processor:hover{box-shadow:0 0 8px #ff980080}.repo-audiowhisper:hover{box-shadow:0 0 8px #e91e6380}.commit-meta{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.stat-add{font-size:.7rem;font-weight:600;color:#66bb6a;font-family:monospace}.stat-del{font-size:.7rem;font-weight:600;color:#ef5350;font-family:monospace}.commit-time{font-size:.72rem;color:var(--timeline-muted, #aaa);margin-left:auto}.timeline-empty{text-align:center;color:var(--text-muted);font-size:.9rem;padding:2rem 0}a.timeline-link{display:block;text-decoration:none;color:inherit;transition:background .15s ease}a.timeline-link:hover{background:var(--link-hover-bg)}.view-all-link{display:block;text-align:center;margin-top:1.5rem;font-size:.85rem;color:var(--text-muted);text-decoration:none;transition:color .2s}.view-all-link:hover{color:var(--accent)}@media(min-width:720px){.timeline-line{left:50%;transform:translate(-50%)}.timeline-item{width:50%;padding-left:0}.timeline-item.left{padding-right:32px;text-align:right}.timeline-item.left .timeline-dot{left:auto;right:-7px}.timeline-item.left .timeline-content{text-align:left}.timeline-item.right{margin-left:50%;padding-left:32px}.timeline-item.right .timeline-dot{left:-7px}}.stats-bar,.tech-grid-section,.timeline-section{border-top:1px solid var(--border);padding-top:2rem}.stats-bar{display:flex;justify-content:center;gap:2.5rem;max-width:700px;margin:.5rem auto 1.5rem;padding:1rem}.stat{display:flex;flex-direction:column;align-items:center;gap:.15rem}.stat-value{font-size:1.5rem;font-weight:500;font-variant-numeric:tabular-nums;background:linear-gradient(135deg,#4fc3f7,#ab47bc 35%,#ff7043 65%,#81d4fa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:none;filter:drop-shadow(0 0 12px rgba(79,195,247,.25));transition:opacity .4s ease}.stat-label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}@keyframes counterBounce{0%{transform:scale(1)}40%{transform:scale(1.1)}to{transform:scale(1)}}.stat-value.bounce{animation:counterBounce .3s ease-out}@media(max-width:480px){.stats-bar{gap:1.5rem}.stat-value{font-size:1.2rem}}@media(max-width:360px){.stats-bar{flex-direction:column;gap:1rem}}.tech-grid-section{max-width:900px;margin:0 auto 1.5rem;padding:0 1.5rem}.tech-grid-section h2{font-size:clamp(1.1rem,3vw,1.3rem);color:var(--text-heading);margin-bottom:1.2rem;text-align:center;font-weight:600}.tech-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}@media(min-width:720px){.tech-grid{grid-template-columns:repeat(5,1fr)}}@media(min-width:900px){.tech-grid{grid-template-columns:repeat(6,1fr)}}.tech-item{display:flex;align-items:center;gap:.4rem;padding:.4rem .6rem;background:var(--card);border:1px solid var(--border);border-radius:6px;font-size:.74rem;color:var(--text-muted);transition:border-color .2s,transform .2s}.tech-item:hover{border-color:var(--tc, var(--accent));transform:translateY(-2px)}.tech-item svg{flex-shrink:0}.tech-icon{font-size:1rem;flex-shrink:0}@media(max-width:480px){.tech-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:360px){.tech-grid{grid-template-columns:repeat(2,1fr)}}.lightbox:not([open]){display:none}.lightbox{border:none;padding:0;max-width:none;max-height:none;width:100vw;height:100vh;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1000;cursor:zoom-out}.lightbox::backdrop{background:#000000e6}.lightbox-close{position:absolute;top:1rem;right:1rem;background:#333;border:none;color:#fff;font-size:2rem;line-height:1;width:44px;height:44px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1001;transition:background .2s}.lightbox-close:hover,.lightbox-close:focus-visible{background:#555;outline:2px solid #fff}.lightbox img{max-width:90vw;max-height:90vh;border-radius:8px;box-shadow:0 0 60px #00000080}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.shimmer{background:linear-gradient(90deg,var(--card) 25%,var(--shimmer-mid) 37%,var(--card) 63%);background-size:200% 100%;animation:shimmer 1.8s ease-in-out infinite}.timeline-loading{padding-left:32px;transition:opacity .4s ease}.timeline-loading.fade-out{opacity:0}.skeleton-item{height:52px;border:1px solid var(--border);border-radius:8px;margin-bottom:1rem;background:linear-gradient(90deg,var(--card) 25%,var(--shimmer-mid) 37%,var(--card) 63%);background-size:200% 100%;animation:shimmer 1.8s ease-in-out infinite}.stat-value.shimmer-placeholder{display:inline-block;width:4rem;height:1.5rem;border-radius:4px;background:linear-gradient(90deg,var(--card) 25%,var(--shimmer-mid) 37%,var(--card) 63%);background-size:200% 100%;animation:shimmer 1.8s ease-in-out infinite;-webkit-text-fill-color:transparent;-webkit-background-clip:padding-box;background-clip:padding-box;color:transparent}.lang-bar-track.shimmer-track .lang-bar-fill{width:100%;background:linear-gradient(90deg,var(--card) 25%,var(--shimmer-mid) 37%,var(--card) 63%);background-size:200% 100%;animation:shimmer 1.8s ease-in-out infinite;animation-delay:var(--shimmer-delay, 0ms)}.skeleton-fade{transition:opacity .4s ease}.skeleton-fade.fade-out{opacity:0}.content-fade-in{animation:contentAppear .4s ease forwards}@keyframes contentAppear{0%{opacity:0}to{opacity:1}}.fade-in{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease;transition-delay:var(--fade-delay, 0ms)}.fade-in.visible{opacity:1;transform:translateY(0)}#scroll-progress{position:fixed;top:0;left:0;height:3px;width:0%;background:var(--accent);z-index:101;transition:width .1s linear;pointer-events:none}.error-state{text-align:center;padding:1.5rem 1rem;background:var(--card);border:1px solid var(--error-border);border-radius:8px}.error-state p{font-size:.85rem;color:var(--text-muted);margin-bottom:.75rem}.error-state .error-icon{font-size:1.3rem;margin-bottom:.5rem}.retry-btn{display:inline-block;padding:.4rem 1.2rem;font-size:.8rem;font-weight:500;color:var(--accent);border:1px solid var(--accent);border-radius:6px;background:transparent;cursor:pointer;transition:background .15s,color .15s;font-family:inherit}.retry-btn:hover{background:var(--accent);color:#000}footer{text-align:center;padding:1.2rem 1rem;color:var(--text-muted);font-size:.8rem}.footer-content{display:flex;align-items:center;justify-content:center;gap:.5rem;flex-wrap:wrap}.footer-github{color:var(--text-muted);transition:color .2s}.footer-github:hover{color:var(--accent)}.footer-divider{color:var(--border)}.footer-built{color:var(--text-muted)}.back-to-top{position:fixed;bottom:2rem;right:2rem;width:40px;height:40px;border-radius:50%;background:var(--card);border:1px solid var(--border);color:var(--text);font-size:1.2rem;cursor:pointer;opacity:0;pointer-events:none;transition:opacity .3s,background .2s;z-index:50;display:flex;align-items:center;justify-content:center}.back-to-top.visible{opacity:1;pointer-events:auto}.back-to-top:hover{background:var(--accent);color:#000}.parallax-mesh{position:fixed;inset:0;z-index:-1;pointer-events:none;background:radial-gradient(ellipse 600px 400px at 20% 30%,rgba(79,195,247,.04),transparent),radial-gradient(ellipse 500px 500px at 80% 70%,rgba(171,71,188,.03),transparent),radial-gradient(ellipse 400px 300px at 50% 50%,rgba(255,112,67,.02),transparent);will-change:transform;transition:transform .1s linear}@media(max-width:720px){.parallax-mesh{display:none}}body.page-exit{opacity:0;transition:opacity .3s ease}@media(prefers-reduced-motion:reduce){.fade-in{opacity:1;transform:none;transition:none}header:after{animation:none}.card:hover{transform:none}.carousel-slide{transition:none}.carousel-slide.active.kb-zoom,.dot.active,.skeleton-item,.shimmer,.shimmer-placeholder{animation:none}}@media(min-width:1024px){body{font-size:17px}}@media(min-width:1024px){.projects,.tech-grid-section{max-width:1100px}.stats-bar,.timeline-section{max-width:900px}}@keyframes subtitleFadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media(min-width:1024px){header{padding:3.5rem 1rem 2rem}header h1{font-size:clamp(1.3rem,4vw,2.2rem)}header p{animation:subtitleFadeUp .8s ease-out both}}@media(min-width:1024px){.card-img{overflow:hidden;transition:transform .3s ease}.card:hover .card-img{transform:scale(1.02)}}@media(min-width:1024px){.card{background:#1a1a1ad9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}[data-theme=light] .card{background:#ffffffd9}}@media(min-width:720px){.heatmap-cell{height:14px;border-radius:3px}}@media(min-width:720px){.timeline-content{transition:transform .2s ease,box-shadow .2s ease}.timeline-item.left:hover .timeline-content{transform:translate(-4px);box-shadow:0 4px 16px #0003}.timeline-item.right:hover .timeline-content{transform:translate(4px);box-shadow:0 4px 16px #0003}}@media(max-width:480px){.back-to-top{bottom:1rem;right:1rem;width:36px;height:36px;font-size:1rem}}@media(min-width:1024px){.tech-grid-section h2,.timeline-section h2{letter-spacing:.08em;text-transform:uppercase}}.wave-divider{width:100%;height:36px;overflow:hidden;line-height:0}.wave-divider svg{display:block;width:200%;height:100%;animation:waveShift 12s linear infinite}.wave-divider path{fill:var(--accent);opacity:.12}@keyframes waveShift{0%{transform:translate(0)}to{transform:translate(-50%)}}@media(prefers-reduced-motion:reduce){.wave-divider svg{animation:none;width:100%}}.progress-dots{display:none}@media(max-width:720px){.progress-dots{display:flex;flex-direction:column;gap:8px;position:fixed;right:10px;top:50%;transform:translateY(-50%);z-index:90}.progress-dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:background .3s,transform .3s;cursor:pointer;border:none;padding:0}.progress-dot.active{background:var(--accent);transform:scale(1.3)}}
