:root,[data-theme=dark]{--bg:#0d1117;--bg-surface:#161b22;--bg-card:#21262d;--batman-filter: invert(1);--border:#30363d;--border-muted:#21262d;--accent:#3fb950;--accent-hover:#46c55e;--green:#3fb950;--yellow:#e3b341;--orange:#f78451;--purple:#bc8cff;--red:#f85149;--blue:#58a6ff;--text:#e6edf3;--text-muted:#8b949e;--text-subtle:#484f58;--tag-react:#3fb95022;--tag-react-c:#3fb950;--tag-js:#e3b34122;--tag-js-c:#e3b341;--tag-python:#3fb95022;--tag-python-c:#3fb950;--tag-html:#f7845122;--tag-html-c:#f78451;--tag-css:#f7845122;--tag-css-c:#f78451;--tag-api:#bc8cff22;--tag-api-c:#bc8cff;--tag-ml:#3fb95022;--tag-ml-c:#3fb950;--shadow:0 8px 24px rgba(0,0,0,.4);--radius:6px;--radius-lg:12px;--nav-bg:#161b22;--nav-w:72px}[data-theme=light]{--bg:#f6f8fa;--bg-surface:#fff;--bg-card:#f6f8fa;--batman-filter: none;--border:#d0d7de;--border-muted:#e1e4e8;--accent:#1a7f37;--accent-hover:#157532;--green:#1a7f37;--yellow:#9a6700;--orange:#bc4c00;--purple:#8250df;--red:#cf222e;--blue:#0969da;--text:#1f2328;--text-muted:#656d76;--text-subtle:#adb5bd;--shadow:0 8px 24px rgba(140,149,159,.2);--nav-bg:#fff}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:Outfit,sans-serif;background:var(--bg);color:var(--text);line-height:1.7;transition:background .3s,color .3s}a{color:var(--accent);text-decoration:none;transition:color .2s}a:hover{color:var(--accent-hover)}button{font-family:Outfit,sans-serif}img{max-width:100%;display:block}.mono{font-family:JetBrains Mono,monospace}::-webkit-scrollbar{width:6px;background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:10px}@media (min-width:992px){.page-main{margin-left:var(--nav-w)}}.container{max-width:1100px;margin:0 auto;padding:0 32px}.page-section{padding:80px 0}.section-title{margin-bottom:48px}.section-label{font-size:12px;color:var(--accent);letter-spacing:3px;margin-bottom:8px;font-family:JetBrains Mono,monospace}.section-title h2{font-size:28px;font-weight:700;color:var(--text);padding-bottom:16px;border-bottom:1px solid var(--border)}.btn-primary{display:inline-flex;align-items:center;gap:6px;background:var(--accent);color:#fff!important;border:1px solid var(--accent);padding:8px 20px;border-radius:var(--radius);font-size:14px;font-weight:500;cursor:pointer;transition:background .2s,transform .15s;text-decoration:none}.btn-primary:hover{background:var(--accent-hover);color:#fff!important;transform:translateY(-1px);text-decoration:none}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-ghost{display:inline-flex;align-items:center;gap:6px;background:transparent;color:var(--text)!important;border:1px solid var(--border);padding:8px 20px;border-radius:var(--radius);font-size:14px;font-weight:500;cursor:pointer;transition:border-color .2s,background .2s,transform .15s;text-decoration:none}.btn-ghost:hover{border-color:var(--accent);background:#3fb95014;color:var(--text)!important;transform:translateY(-1px);text-decoration:none}.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--nav-w);z-index:9997;background:var(--nav-bg);border-right:1px solid var(--border);display:flex;flex-direction:column;align-items:center;padding:20px 0;transition:background .3s,border-color .3s,left .3s}@media (max-width:991px){.sidebar{left:-300px;width:260px;align-items:flex-start;padding:20px 16px}.sidebar.open{left:0}}.sidebar-brand{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius);background:var(--bg);margin-bottom:28px;font-family:JetBrains Mono,monospace;font-weight:700;font-size:18px;color:#fff;text-decoration:none;cursor:pointer;flex-shrink:0}.nav-menu{width:100%}.nav-menu ul{list-style:none}.nav-menu a{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:var(--radius);color:var(--text-muted);font-size:18px;margin:4px auto;transition:background .2s,color .2s;text-decoration:none;position:relative}.nav-menu a span{display:none}.nav-menu a:hover,.nav-menu a.active{background:#3fb9501a;color:var(--accent);text-decoration:none}@media (min-width:992px){.nav-menu a[data-tooltip]:after{content:attr(data-tooltip);position:absolute;left:56px;background:var(--bg-card);color:var(--text);font-family:Outfit,sans-serif;font-size:13px;padding:4px 10px;border-radius:var(--radius);border:1px solid var(--border);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s;z-index:100}.nav-menu a[data-tooltip]:hover:after{opacity:1}}@media (max-width:991px){.nav-menu a{width:100%;justify-content:flex-start;gap:12px;padding:10px 12px;height:auto}.nav-menu a span{display:block;font-size:14px}}.sidebar-footer{margin-top:auto;display:flex;flex-direction:column;gap:8px;align-items:center}.theme-btn{width:36px;height:36px;border-radius:var(--radius);border:1px solid var(--border);background:transparent;color:var(--text-muted);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s}.theme-btn:hover{background:#3fb9501a;color:var(--accent)}.mobile-toggle{position:fixed;right:16px;top:16px;z-index:9998;background:var(--bg-surface);border:1px solid var(--border);color:var(--text);width:38px;height:38px;border-radius:var(--radius);font-size:20px;cursor:pointer;display:none;align-items:center;justify-content:center}@media (max-width:991px){.mobile-toggle{display:flex}}.nav-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:9996}.nav-overlay.active{display:block}.btt{position:fixed;bottom:24px;right:24px;z-index:996;width:38px;height:38px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);font-size:16px;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all .3s;cursor:pointer;text-decoration:none}.btt:hover{background:var(--accent);border-color:var(--accent);color:#fff}.btt.show{opacity:1;visibility:visible}.hero{min-height:100vh;background:var(--bg);position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;text-align:center}.hero-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(var(--border) 1px,transparent 1px);background-size:32px 32px;opacity:.5;pointer-events:none}.hero:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 80% 60% at 50% 50%,transparent 40%,var(--bg) 100%);pointer-events:none}.hero-inner{position:relative;z-index:2;padding:80px 32px;max-width:860px;width:100%}.hero-label{font-family:JetBrains Mono,monospace;font-size:13px;color:var(--text-muted);margin-bottom:16px;letter-spacing:2px}.hero-label .c{color:var(--accent)}.hero-name{font-family:Bebas Neue,sans-serif;font-size:clamp(64px,12vw,160px);line-height:.88;letter-spacing:-1px;color:var(--text);margin:0 0 8px}.hero-name:after{content:"";display:block;width:72px;height:3px;background:var(--accent);margin:20px auto 0;border-radius:2px}.hero-sub{font-family:JetBrains Mono,monospace;font-size:clamp(13px,1.6vw,16px);color:var(--text-muted);margin:20px 0 36px;min-height:24px}.hero-sub .typed-text{color:var(--green)}.typed-cursor{color:var(--accent);animation:blink 1s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-bottom:40px}.hero-social{display:flex;gap:16px;justify-content:center}.hero-social a{font-size:22px;color:var(--text-subtle);transition:color .2s,transform .2s}.hero-social a:hover{color:var(--text);transform:translateY(-3px)}.hero-scroll{position:absolute;bottom:32px;left:50%;transform:translate(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--text-subtle);font-size:11px;letter-spacing:2px;font-family:JetBrains Mono,monospace;animation:bounce 2s infinite}@keyframes bounce{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(6px)}}.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}@media (max-width:768px){.about-grid{grid-template-columns:1fr;gap:32px}}.about-text p{color:var(--text-muted);margin-bottom:16px;font-size:15px}.about-text strong{color:var(--text);font-weight:600}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 16px;display:flex;flex-direction:column;gap:6px;transition:border-color .2s,transform .2s}.stat-card:hover{border-color:var(--accent);transform:translateY(-2px)}.stat-icon{font-size:18px;color:var(--accent)}.stat-label{font-size:11px;color:var(--text-muted);letter-spacing:1px;text-transform:uppercase;font-family:JetBrains Mono,monospace}.stat-val{font-size:13px;color:var(--text);font-weight:500}.heatmap-wrap{margin-top:48px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;transition:border-color .2s}.heatmap-wrap:hover{border-color:var(--accent)}.heatmap-header{display:flex;align-items:center;gap:8px;margin-bottom:20px;font-size:14px;color:var(--text-muted)}.heatmap-header i{color:var(--green);font-size:16px}.heatmap-link{margin-left:auto;display:inline-flex;align-items:center;gap:5px;font-family:JetBrains Mono,monospace;font-size:12px;color:var(--accent)}.heatmap-img-wrap{width:100%;overflow-x:auto}.heatmap-img{display:block;width:100%;min-width:600px;height:auto}[data-theme=light] .heatmap-img{filter:contrast(.9)}.heatmap-note{margin-top:10px;font-size:11px;color:var(--text-subtle);letter-spacing:1px;font-family:JetBrains Mono,monospace}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.repo-card{flex:0 0 320px;scroll-snap-align:start;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;display:flex;flex-direction:column;transition:border-color .2s,transform .2s,box-shadow .2s}.repo-card:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:var(--shadow)}.repo-card-link{cursor:pointer;text-decoration:none;color:inherit}.repo-card-link:hover{color:inherit;text-decoration:none}.repo-header{display:flex;align-items:center;gap:8px;margin-bottom:14px}.repo-icon{color:var(--text-muted);font-size:16px;flex-shrink:0}.repo-name{font-family:JetBrains Mono,monospace;font-size:14px;font-weight:600;color:var(--accent);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.repo-name:hover{text-decoration:underline;color:var(--accent-hover)}.repo-badge{font-size:11px;border:1px solid var(--border);border-radius:20px;padding:1px 8px;color:var(--text-muted);font-family:JetBrains Mono,monospace;flex-shrink:0}.repo-img{width:100%;height:160px;overflow:hidden;border-radius:var(--radius);border:1px solid var(--border-muted);margin-bottom:14px;flex-shrink:0}.repo-img img{width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .4s}.repo-card:hover .repo-img img{transform:scale(1.04)}.repo-desc{font-size:13px;color:var(--text-muted);line-height:1.6;flex:1;margin-bottom:16px}.repo-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto}.repo-tags{display:flex;flex-wrap:wrap;gap:6px}.repo-tag{font-family:JetBrains Mono,monospace;font-size:11px;padding:2px 8px;border-radius:20px;font-weight:500}.repo-tag.react{background:var(--tag-react);color:var(--tag-react-c)}.repo-tag.js{background:var(--tag-js);color:var(--tag-js-c)}.repo-tag.python{background:var(--tag-python);color:var(--tag-python-c)}.repo-tag.html{background:var(--tag-html);color:var(--tag-html-c)}.repo-tag.css{background:var(--tag-css);color:var(--tag-css-c)}.repo-tag.api{background:var(--tag-api);color:var(--tag-api-c)}.repo-tag.ml{background:var(--tag-ml);color:var(--tag-ml-c)}.repo-actions{display:flex;gap:10px;align-items:center}.repo-link{color:var(--text-muted);font-size:16px;transition:color .2s;text-decoration:none}.repo-link:hover{color:var(--accent)}.carousel-wrap{position:relative}.carousel-wrap:after{content:"";position:absolute;top:0;right:0;width:80px;height:calc(100% - 28px);background:linear-gradient(to right,transparent,var(--bg));pointer-events:none;border-radius:0 var(--radius-lg) var(--radius-lg) 0}.carousel-track{display:flex;gap:16px;overflow-x:auto;padding-bottom:12px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}.carousel-track::-webkit-scrollbar{height:4px}.carousel-track::-webkit-scrollbar-track{background:transparent}.carousel-track::-webkit-scrollbar-thumb{background:var(--border);border-radius:10px}.carousel-wrap--surface:after{background:linear-gradient(to right,transparent,var(--bg-surface))}.carousel-hint{font-size:11px;color:var(--text-subtle);margin-top:10px;letter-spacing:.5px}.cert-card{flex:0 0 300px;scroll-snap-align:start;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;display:flex;align-items:center;gap:16px;transition:border-color .2s,box-shadow .2s;text-decoration:none;color:inherit}.cert-card:hover{border-color:var(--accent);box-shadow:0 8px 24px #0000004d;color:inherit}.cert-logo-wrap{flex-shrink:0;width:44px;height:44px;display:flex;align-items:center;justify-content:center}.cert-logo{width:100%;height:100%;object-fit:contain}.cert-info{flex:1;display:flex;flex-direction:column;gap:3px}.cert-name{font-size:13px;font-weight:600;color:var(--text);line-height:1.4}.cert-issuer{font-size:11px;color:var(--text-muted);letter-spacing:.5px}.cert-year{font-size:10px;color:var(--accent);margin-top:4px;display:inline-block}.cert-check{font-size:18px;color:var(--accent);flex-shrink:0;align-self:flex-start}.skills-wrap{max-width:1100px;margin:0 auto;padding:0 32px}.skills-box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;text-align:center}.skill-item{position:relative;margin:8px;display:inline-block;cursor:pointer}.skill-img{width:64px;height:auto;transition:transform .25s}.skill-tip{position:absolute;bottom:-28px;left:50%;transform:translate(-50%);visibility:hidden;color:var(--text);background:var(--bg-card);border:1px solid var(--border);font-family:JetBrains Mono,monospace;font-size:11px;padding:3px 8px;border-radius:var(--radius);opacity:0;transition:opacity .2s;z-index:5;white-space:nowrap}.skill-item:hover .skill-img{transform:scale(1.15) translateY(-4px)}.skill-item:hover .skill-tip{visibility:visible;opacity:1}@media (max-width:768px){.skill-img{width:32px}}@media (max-width:992px){.skill-img{width:48px}}.contact-section{background:var(--bg-surface);padding:80px 0}.contact-wrap{display:grid;grid-template-columns:1fr 1.4fr;gap:48px;align-items:start}@media (max-width:768px){.contact-wrap{grid-template-columns:1fr;gap:32px}}.contact-info h3{font-size:20px;font-weight:600;color:var(--text);margin-bottom:12px}.contact-info p{color:var(--text-muted);font-size:14px;margin-bottom:28px}.contact-links{display:flex;flex-direction:column;gap:14px}.contact-links a{display:flex;align-items:center;gap:12px;color:var(--text-muted);font-size:14px;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);transition:border-color .2s,color .2s;text-decoration:none}.contact-links a i{font-size:18px;color:var(--accent)}.contact-links a:hover{border-color:var(--accent);color:var(--text)}.cf-label{display:block;font-size:12px;color:var(--accent);letter-spacing:1px;margin-bottom:6px;font-family:JetBrains Mono,monospace}.cf-field{width:100%;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:Outfit,sans-serif;font-size:14px;padding:12px 16px;transition:border-color .2s;margin-bottom:16px}.cf-field:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #3fb9501f}.cf-field::placeholder{color:var(--text-subtle)}textarea.cf-field{resize:vertical}.cf-submit{width:100%;justify-content:center;padding:12px;font-size:15px}.blog-tabs{display:flex;gap:8px;margin-bottom:32px}.blog-tab{padding:6px 18px;border-radius:20px;border:1px solid var(--border);background:transparent;color:var(--text-muted);font-size:13px;cursor:pointer;font-family:JetBrains Mono,monospace;transition:all .2s}.blog-tab:hover{border-color:var(--accent);color:var(--accent)}.blog-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}.blogs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.blog-card{flex:0 0 320px;scroll-snap-align:start;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;display:flex;flex-direction:column;cursor:pointer;transition:border-color .2s,transform .2s,box-shadow .2s;text-decoration:none;color:inherit}.blog-card:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:var(--shadow);text-decoration:none;color:inherit}.blog-cat{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--accent);letter-spacing:2px;text-transform:uppercase;margin-bottom:10px}.blog-card h3{font-size:17px;font-weight:600;color:var(--text);margin-bottom:10px;line-height:1.4}.blog-card p{font-size:13px;color:var(--text-muted);flex:1;line-height:1.6}.blog-card-foot{display:flex;align-items:center;justify-content:space-between;margin-top:20px}.blog-date{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--text-subtle)}.blog-more{font-size:13px;color:var(--accent);display:flex;align-items:center;gap:4px}.empty-state{color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:14px;margin-top:24px}.blog-article-page{padding-top:72px;padding-bottom:0}.blog-topbar{max-width:860px;margin:0 auto;padding:16px 32px;display:flex;align-items:center;justify-content:space-between}.detail-back{display:inline-flex;align-items:center;gap:6px;color:var(--text-muted);font-size:13px;font-family:JetBrains Mono,monospace;cursor:pointer;background:none;border:none;transition:color .2s;padding:0}.detail-back:hover{color:var(--accent)}.detail-cat{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--accent);letter-spacing:2px;text-transform:uppercase}.detail-date{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--text-subtle)}.meta-sep{color:var(--text-subtle);font-size:12px}.blog-hero-banner{width:100%;overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.blog-hero-img{width:100%;height:auto;max-height:360px;object-fit:contain;object-position:center top;display:block}.blog-hero-gradient{height:280px;background:linear-gradient(135deg,var(--bg-surface) 0%,var(--bg-card) 60%,var(--bg) 100%);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.blog-hero-gradient:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(var(--border) 1px,transparent 1px);background-size:28px 28px;opacity:.4}.blog-hero-cat-label{font-size:11px;color:var(--accent);letter-spacing:4px;text-transform:uppercase;opacity:.7;position:relative;z-index:1}.blog-article{max-width:740px;margin:0 auto;padding:52px 32px 80px}.blog-article-header{margin-bottom:44px}.blog-article-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:22px}.blog-article-title{font-size:clamp(28px,4vw,46px);font-weight:800;color:var(--text);line-height:1.15;letter-spacing:-.5px;margin-bottom:18px}.blog-article-lede{font-size:20px;color:var(--text-muted);line-height:1.65;margin-bottom:32px;font-weight:400;font-style:italic}.blog-article-rule{border:none;border-top:1px solid var(--border);margin:0}.blog-body{color:var(--text-muted);font-size:18px;line-height:1.9;margin-top:44px}.blog-section{margin-bottom:4px}.blog-body h2{font-size:27px;font-weight:700;color:var(--text);margin:52px 0 18px;letter-spacing:-.3px;line-height:1.25}.blog-body h3{font-size:21px;font-weight:600;color:var(--text);margin:36px 0 12px;letter-spacing:-.1px}.blog-body p{margin-bottom:26px}.blog-body strong{color:var(--text);font-weight:600}.blog-body em{font-style:italic}.blog-body a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}.blog-list{padding-left:28px;margin-bottom:26px}.blog-list li{margin-bottom:10px;line-height:1.75}.blog-body ul.blog-list{list-style:disc}.blog-body ol.blog-list{list-style:decimal}.blog-body .blog-list li::marker{color:var(--accent)}.blog-body code{font-family:JetBrains Mono,monospace;font-size:14px;background:var(--bg-card);border:1px solid var(--border);border-radius:4px;padding:2px 7px;color:var(--orange)}.blog-code{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px 28px;overflow-x:auto;font-family:JetBrains Mono,monospace;font-size:13px;line-height:1.8;color:var(--text);margin-bottom:28px}.blog-callout{border-left:4px solid var(--accent);background:#3fb9500a;border-radius:0 var(--radius) var(--radius) 0;padding:22px 26px;margin:36px 0;font-size:18px;line-height:1.7}.blog-callout p{margin:0;color:var(--text-muted)}.blog-callout strong{color:var(--text)}.blog-section-divider{display:flex;align-items:center;justify-content:center;gap:16px;margin:52px 0}.blog-section-divider span{width:5px;height:5px;border-radius:50%;background:var(--text-subtle);display:block}.blog-article-footer{border-top:1px solid var(--border);padding-top:32px;margin-top:56px}.proj-detail{max-width:860px;margin:0 auto;padding:0 32px}.proj-hero-wrap{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:40px}.proj-hero-wrap img{width:100%;height:260px;object-fit:cover;object-position:center;border-bottom:1px solid var(--border)}.proj-hero-body{padding:28px 32px}.proj-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:16px}.proj-tag{font-family:JetBrains Mono,monospace;font-size:11px;padding:2px 10px;border-radius:20px;font-weight:500}.proj-tag.python{background:#3fb95022;color:var(--green)}.proj-tag.rag,.proj-tag.llm{background:#bc8cff22;color:var(--purple)}.proj-tag.lc{background:#e3b34122;color:var(--yellow)}.proj-tag.pg,.proj-tag.docker{background:#58a6ff22;color:var(--blue)}.proj-tag.local{background:#e3b34122;color:var(--yellow)}.proj-tag.chroma{background:#f7845122;color:var(--orange)}.proj-tag.fastapi{background:#3fb95022;color:var(--green)}.proj-tag.year{background:var(--bg-card);color:var(--text-muted);border:1px solid var(--border)}.proj-hero-body h1{font-family:Bebas Neue,sans-serif;font-size:clamp(28px,5vw,52px);line-height:1;color:var(--text);letter-spacing:.5px;margin-bottom:10px}.proj-subtitle{font-size:15px;color:var(--text-muted);margin-bottom:16px}.proj-role{display:flex;align-items:center;gap:8px;font-family:JetBrains Mono,monospace;font-size:12px;color:var(--text-muted)}.proj-role i{color:var(--accent)}.doc-section{margin-bottom:40px}.doc-section h2{font-size:20px;font-weight:700;color:var(--text);padding-bottom:10px;border-bottom:1px solid var(--border);margin-bottom:20px;display:flex;align-items:center;gap:10px}.doc-section h2 i{color:var(--accent);font-size:18px}.doc-section h3{font-size:15px;font-weight:600;color:var(--text);margin:20px 0 8px}.doc-section p{font-size:14px;color:var(--text-muted);margin-bottom:12px}.doc-section strong{color:var(--text)}.doc-divider{border:none;border-top:1px solid var(--border);margin:36px 0}.doc-list{list-style:none;padding:0;margin:0 0 16px}.doc-list li{font-size:14px;color:var(--text-muted);padding:5px 0 5px 20px;position:relative}.doc-list li:before{content:"–";position:absolute;left:0;color:var(--accent);font-family:JetBrains Mono,monospace}.callout{background:#3fb9500f;border:1px solid rgba(63,185,80,.2);border-left:3px solid var(--accent);border-radius:var(--radius);padding:14px 18px;margin-bottom:16px}.callout p{margin:0;font-size:14px;color:var(--text-muted)}.callout strong{color:var(--green)}.arch-flow{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;display:flex;flex-direction:column;align-items:center;gap:0;margin-bottom:16px}.arch-step{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:10px 28px;font-family:JetBrains Mono,monospace;font-size:13px;color:var(--text);text-align:center;min-width:220px;transition:border-color .2s}.arch-step:hover{border-color:var(--accent);color:var(--accent)}.arch-step.hl{border-color:var(--accent);color:var(--accent);background:#3fb95012}.arch-arrow{color:var(--text-subtle);font-size:18px;line-height:1;margin:4px 0;text-align:center;width:100%}.info-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin-bottom:16px}.info-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;display:flex;flex-direction:column;gap:6px}.info-card i{color:var(--accent);font-size:16px}.info-card-label{font-family:JetBrains Mono,monospace;font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.info-card-val{font-size:13px;color:var(--text);font-weight:500}.tradeoff-table{width:100%;border-collapse:collapse;font-size:13px;margin-bottom:16px}.tradeoff-table th{font-family:JetBrains Mono,monospace;font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);padding:10px 14px;border-bottom:1px solid var(--border);text-align:left}.tradeoff-table td{padding:10px 14px;border-bottom:1px solid var(--border);color:var(--text-muted);vertical-align:top}.tradeoff-table tr:last-child td{border-bottom:none}.tradeoff-table td:first-child{color:var(--text);font-weight:500}.tradeoff-table .pro{color:var(--green)}.tradeoff-table .con{color:var(--orange)}.tradeoff-table tr:hover td{background:var(--bg-card)}.doc-pre{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;overflow-x:auto;font-family:JetBrains Mono,monospace;font-size:12px;line-height:1.8;color:var(--text);margin-bottom:16px}.pre-key{color:var(--purple)}.pre-val{color:var(--green)}.pre-str{color:var(--yellow)}.pre-cmd{color:var(--green)}.pre-label{color:var(--purple)}.pre-cmt{color:var(--text-subtle)}.model-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}@media (max-width:500px){.model-grid{grid-template-columns:1fr}}.model-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;display:flex;flex-direction:column;gap:6px;transition:border-color .2s}.model-card:hover{border-color:var(--accent)}.model-card i{color:var(--accent);font-size:18px}.model-label{font-family:JetBrains Mono,monospace;font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.model-val{font-size:13px;color:var(--text);font-weight:600}.model-sub{font-size:12px;color:var(--text-muted)}.proj-footer-nav{border-top:1px solid var(--border);padding-top:24px;margin-top:32px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}.proj-footer-id{font-family:JetBrains Mono,monospace;font-size:12px;color:var(--text-subtle)}.footer{background:var(--bg);border-top:1px solid var(--border);padding:32px 0}.footer-inner{max-width:1100px;margin:0 auto;padding:0 32px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}.footer-name{font-family:JetBrains Mono,monospace;font-size:14px;color:var(--text-muted)}.footer-copy{font-size:12px;color:var(--text-subtle)}.footer-social{display:flex;gap:12px}.footer-social a{font-size:18px;color:var(--text-muted);transition:color .2s;text-decoration:none}.footer-social a:hover{color:var(--accent)}@media (max-width:768px){.container{padding:0 20px}.page-section{padding:60px 0}}
