:root{--primary:#EC4356;--primary-dark:#d13345;--primary-light:#fdeef0;--accent:#FF6E3A;--accent-dark:#e05a28;--accent-warm:#FFBB56;--text:#383539;--text-secondary:#5a575c;--text-muted:#9a979c;--bg:#ffffff;--bg-alt:#f9f9f9;--bg-dark:#383539;--border:#e1e1e1;--border-light:#f0f0f0;--shadow-sm:0 1px 3px rgba(56,53,57,.08);--shadow-md:0 2px 8px rgba(56,53,57,.1);--font-body:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;--font-heading:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;--font-article:'Merriweather',Georgia,serif;--font-mono:'JetBrains Mono','Fira Code',monospace;--max-width:1200px;--header-height:56px;--topbar-height:36px}*,::after,::before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}body{font-family:var(--font-body);color:var(--text);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}img{max-width:100%;height:auto;display:block}a{color:var(--text);text-decoration:none;transition:color .2s}a:hover{color:var(--primary)}.container{max-width:var(--max-width);margin:0 auto;padding:0 16px}.topbar{background:var(--bg-dark);color:#ccc;font-size:.75rem;height:var(--topbar-height);line-height:var(--topbar-height)}.topbar-inner{display:flex;align-items:center;justify-content:space-between;height:100%}.topbar-left{display:flex;align-items:center;gap:16px}.topbar-date{color:#ccc}.topbar-links{display:flex;gap:12px}.topbar-links a{color:#ccc;font-size:.75rem}.topbar-links a:hover{color:#fff}.site-header{background:var(--bg);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;transition:box-shadow .2s}.site-header.scrolled{box-shadow:var(--shadow-md)}.header-inner{display:flex;align-items:center;justify-content:space-between;height:var(--header-height)}.logo{display:flex;align-items:center;flex-shrink:0}.logo:hover{opacity:.85}.logo-img{height:36px;width:auto;max-height:36px;display:block;object-fit:contain}.main-nav{display:flex;align-items:center;gap:0;height:var(--header-height)}.nav-link{padding:0 16px;height:var(--header-height);line-height:var(--header-height);font-size:.85rem;font-weight:600;color:var(--text);text-transform:uppercase;letter-spacing:.02em;background:0 0;border:none;cursor:pointer;transition:color .2s,background .2s;white-space:nowrap}.nav-link:hover{color:var(--bg);background:var(--text)}.dropdown{position:relative;height:var(--header-height)}.dropdown-toggle{display:flex;align-items:center;gap:4px}.dropdown-toggle::after{content:'';border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid currentColor;margin-left:2px}.dropdown-menu{display:none;position:absolute;top:100%;left:0;min-width:200px;background:var(--bg);border:1px solid var(--border);box-shadow:var(--shadow-md);padding:4px 0;z-index:200}.dropdown.open .dropdown-menu,.dropdown:hover .dropdown-menu{display:block}.dropdown-item{display:block;padding:8px 16px;font-size:.83rem;color:var(--text-secondary);white-space:nowrap}.dropdown-item:hover{background:var(--bg-alt);color:var(--primary)}.header-actions{display:flex;align-items:center;gap:8px}.search-toggle{background:0 0;border:none;cursor:pointer;padding:8px;color:var(--text);font-size:1rem;display:flex;align-items:center}.search-toggle:hover{color:var(--primary)}.search-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.85);z-index:999;align-items:center;justify-content:center}.search-overlay.active{display:flex}.search-overlay-inner{width:90%;max-width:640px}.search-overlay-form{display:flex;border-bottom:2px solid #fff}.search-overlay-input{flex:1;background:0 0;border:none;color:#fff;font-size:1.5rem;padding:12px 0;outline:0;font-family:var(--font-body)}.search-overlay-input::placeholder{color:#888}.search-overlay-close{background:0 0;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:12px}.mobile-menu-toggle{display:none;flex-direction:column;gap:5px;background:0 0;border:none;cursor:pointer;padding:4px}.mobile-menu-toggle span{width:22px;height:2px;background:var(--text);border-radius:1px;transition:transform .2s,opacity .2s}.mobile-menu-toggle.active span:first-child{transform:rotate(45deg) translate(5px,5px)}.mobile-menu-toggle.active span:nth-child(2){opacity:0}.mobile-menu-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.mobile-drawer{display:none}.section{margin:28px 0}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;border-bottom:1px solid var(--border);padding-bottom:12px}.section-title{font-size:.95rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--bg);background:var(--text);padding:6px 14px;display:inline-block}.section-title.accent-red{background:var(--primary)}.section-title.accent-orange{background:var(--accent);color:var(--text)}.section-title.accent-gold{background:var(--accent-warm);color:var(--text)}.view-all{font-size:.82rem;font-weight:500;color:var(--primary)}.view-all:hover{color:var(--primary-dark)}.hero-carousel{position:relative;overflow:hidden;background:var(--bg-dark);color:#fff}.hero-track{display:flex;transition:transform .5s ease}.hero-slide{min-width:100%;flex-shrink:0}.hero-slide-inner{display:flex;align-items:center;gap:40px;padding:48px 16px;min-height:420px}.hero-text{flex:1;min-width:0}.hero-platform-badge{display:inline-block;background:var(--primary);color:#fff;font-size:.7rem;font-weight:700;text-transform:uppercase;padding:4px 10px;letter-spacing:.04em;margin-bottom:8px}.hero-platform-badge:hover{background:var(--primary-dark);color:#fff}.hero-category{font-size:.75rem;color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:.04em;margin-left:8px}.hero-title{font-family:var(--font-heading);font-size:1.8rem;font-weight:700;line-height:1.25;margin:12px 0 14px}.hero-title a{color:#fff}.hero-title a:hover{color:var(--accent-warm)}.hero-excerpt{font-size:.92rem;line-height:1.6;color:rgba(255,255,255,.75);margin-bottom:16px}.hero-meta{font-size:.78rem;color:rgba(255,255,255,.5);display:flex;align-items:center;gap:6px;margin-bottom:18px}.hero-read-more{display:inline-block;font-size:.82rem;font-weight:600;color:var(--accent-warm);border-bottom:1px solid var(--accent-warm);padding-bottom:2px}.hero-read-more:hover{color:#fff;border-color:#fff}.hero-image{flex:0 0 45%;border-radius:8px;overflow:hidden;aspect-ratio:16/9}.hero-image img{width:100%;height:100%;object-fit:cover;display:block}.hero-arrow{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.15);border:none;color:#fff;font-size:1.3rem;width:44px;height:44px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:background .2s;backdrop-filter:blur(4px)}.hero-arrow:hover{background:rgba(255,255,255,.3)}.hero-arrow-left{left:16px}.hero-arrow-right{right:16px}.hero-dots{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:10}.hero-dot{width:10px;height:10px;border-radius:50%;border:2px solid rgba(255,255,255,.5);background:0 0;cursor:pointer;padding:0;transition:background .2s,border-color .2s}.hero-dot.active,.hero-dot:hover{background:#fff;border-color:#fff}.filter-tabs{display:flex;gap:8px;margin-bottom:24px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:4px}.filter-tabs::-webkit-scrollbar{display:none}.filter-tab{display:inline-block;padding:7px 18px;font-size:.8rem;font-weight:600;border:1px solid var(--border);border-radius:20px;color:var(--text-secondary);white-space:nowrap;transition:all .2s}.filter-tab:hover{border-color:var(--primary);color:var(--primary)}.filter-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}.tech-section{padding:36px 0}.tech-section-alt{background:var(--bg-alt)}.tech-section-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:start}.tech-lead-card .card-image{border-radius:6px;overflow:hidden;aspect-ratio:16/9}.tech-lead-card .card-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.tech-lead-card:hover .card-image img{transform:scale(1.03)}.tech-lead-card .card-body{padding-top:14px}.tech-lead-card .card-title{font-size:1.1rem;margin-bottom:8px}.tech-lead-card .card-excerpt{font-size:.85rem;color:var(--text-secondary);line-height:1.55;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.tech-compact-stack{display:flex;flex-direction:column;gap:0}.tech-compact-card{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid var(--border);align-items:flex-start}.tech-compact-card:last-child{border-bottom:none}.tech-compact-thumb{flex-shrink:0;width:140px;aspect-ratio:16/9;border-radius:4px;overflow:hidden}.tech-compact-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s}.tech-compact-card:hover .tech-compact-thumb img{transform:scale(1.04)}.tech-compact-body{flex:1;min-width:0}.tech-compact-category{display:inline-block;font-size:.65rem;font-weight:700;text-transform:uppercase;color:var(--primary);letter-spacing:.04em;margin-bottom:4px}.tech-compact-title{font-size:.88rem;font-weight:600;line-height:1.35;margin-bottom:6px}.tech-compact-title a{color:var(--text)}.tech-compact-title a:hover{color:var(--primary)}.tech-compact-meta{font-size:.72rem;color:var(--text-muted)}.content-layout{display:grid;grid-template-columns:1fr 300px;gap:30px;margin:20px auto}.content-main{min-width:0}.article-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:24px}.article-grid-2col{display:grid;grid-template-columns:1fr 1fr;gap:24px}.article-grid-3col{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.article-card{background:var(--bg);overflow:hidden;transition:transform .2s}.article-card:hover{transform:translateY(-2px)}.card-image{position:relative;overflow:hidden;display:block;border-radius:6px;aspect-ratio:16/9}.card-image img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s}.article-card:hover .card-image img{transform:scale(1.04)}.card-badge{position:absolute;bottom:8px;left:8px;background:var(--primary);color:#fff;font-size:.65rem;font-weight:700;text-transform:uppercase;padding:3px 8px;letter-spacing:.03em;border-radius:2px;z-index:1}.card-body{padding:12px 0 0}.card-title{font-size:.95rem;font-weight:700;line-height:1.35;margin-bottom:6px}.card-title a{color:var(--text)}.card-title a:hover{color:var(--primary)}.card-excerpt{font-size:.82rem;color:var(--text-secondary);line-height:1.5;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-footer{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-muted)}.article-hero{margin-bottom:24px;overflow:hidden;border-radius:8px;aspect-ratio:16/9}.article-hero-img{width:100%;height:100%;object-fit:cover;display:block}.card-compact{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--border-light)}.card-compact:last-child{border-bottom:none}.card-compact-body{flex:1;min-width:0}.card-compact-title{font-size:.85rem;font-weight:600;line-height:1.3;margin-bottom:4px}.card-compact-title a{color:var(--text)}.card-compact-title a:hover{color:var(--primary)}.card-compact-meta{font-size:.72rem;color:var(--text-muted)}.card-compact-rank{font-size:1.5rem;font-weight:700;color:var(--border);min-width:28px;line-height:1;flex-shrink:0;padding-top:2px}.card-platform-badge{display:inline-block;padding:2px 8px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;background:var(--accent);color:#fff;border-radius:2px;margin-bottom:6px}.card-platform-badge:hover{background:var(--accent-dark);color:#fff}.article-platform-badge{display:inline-block;background:var(--accent);color:#fff;font-size:.7rem;font-weight:700;text-transform:uppercase;padding:4px 10px;margin-bottom:4px;margin-right:6px;letter-spacing:.03em}.article-platform-badge:hover{background:var(--accent-dark);color:#fff}.badge{display:inline-block;padding:3px 8px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em}.badge-category{background:var(--primary);color:#fff}.badge-tag{background:var(--bg-alt);color:var(--text-secondary);border:1px solid var(--border)}.static-page .article-body{padding:1.5rem 0}.static-page .article-body h2{margin-top:2rem}.single-article{background:var(--bg)}.article-header{margin-bottom:20px}.article-category-badge{display:inline-block;background:var(--primary);color:#fff;font-size:.7rem;font-weight:700;text-transform:uppercase;padding:4px 10px;margin-bottom:12px;letter-spacing:.03em}.article-category-badge:hover{background:var(--primary-dark);color:#fff}.article-title{font-size:2rem;font-weight:700;line-height:1.2;color:var(--text);margin-bottom:12px}.article-meta-bar{display:flex;align-items:center;gap:12px;padding:12px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);flex-wrap:wrap}.article-author-info{display:flex;align-items:center;gap:6px;font-size:.85rem}.article-author-info strong{color:var(--text)}.article-meta-sep{color:var(--border)}.article-meta-item{font-size:.82rem;color:var(--text-muted);display:flex;align-items:center;gap:4px}.article-share{margin-left:auto;display:flex;gap:6px}.share-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:4px;font-size:.75rem;color:#fff;border:none;cursor:pointer;text-decoration:none;transition:opacity .2s,transform .15s}.share-btn:hover{opacity:.85;color:#fff;transform:translateY(-1px)}.share-btn svg{width:16px;height:16px;fill:currentColor;display:block;flex-shrink:0}.share-btn.twitter{background:#000}.share-btn.linkedin{background:#0077b5}.share-btn.email-share{background:#666}.article-body{font-family:var(--font-article);font-size:1.05rem;line-height:1.85;color:var(--text)}.article-body h2{font-family:var(--font-heading);font-size:1.45rem;font-weight:700;margin:2rem 0 .75rem;color:var(--text);border-bottom:2px solid var(--border);padding-bottom:8px}.article-body h3{font-family:var(--font-heading);font-size:1.15rem;font-weight:600;margin:1.5rem 0 .5rem}.article-body p{margin-bottom:1.25rem}.article-body ol,.article-body ul{margin:1rem 0 1.25rem 1.5rem}.article-body li{margin-bottom:.5rem}.article-body blockquote{border-left:4px solid var(--primary);padding:.75rem 1.25rem;margin:1.5rem 0;background:var(--bg-alt);font-style:italic;color:var(--text-secondary)}.article-body a{color:var(--primary);text-decoration:underline;text-underline-offset:2px}.article-body strong{color:var(--text);font-weight:700}.article-body pre{background:#f6f6f6;border:1px solid var(--border);border-radius:4px;padding:1rem 1.25rem;overflow-x:auto;margin-bottom:1.5rem;font-size:.875rem;line-height:1.6;font-family:var(--font-mono)}.article-body code{font-family:var(--font-mono);font-size:.85em}.article-body :not(pre)>code{background:#f3f3f3;padding:.15rem .4rem;border-radius:3px;color:var(--primary);font-size:.85em}.article-body table{width:100%;border-collapse:collapse;margin-bottom:1.5rem;font-size:.9rem;font-family:var(--font-body)}.article-body td,.article-body th{border:1px solid var(--border);padding:.5rem .75rem;text-align:left}.article-body th{background:var(--bg-alt);font-weight:600}.article-body hr{border:none;border-top:1px solid var(--border);margin:2rem 0}.article-body img{max-width:100%;height:auto;display:block;margin:1.5rem auto;border-radius:6px;border:1px solid var(--border);box-shadow:0 2px 8px rgba(0,0,0,.08)}.article-body p>img:only-child{margin:2rem auto}.article-source-box{display:flex;align-items:center;gap:10px;margin-top:28px;padding:14px 20px;background:var(--bg-alt);border:1px solid var(--border);border-radius:6px;font-size:.9rem;color:var(--text-secondary)}.article-source-box svg{flex-shrink:0;color:var(--text-muted)}.article-source-box a{color:var(--primary);text-decoration:underline;text-underline-offset:2px}.article-author-box{display:flex;gap:16px;margin-top:24px;padding:20px 24px;background:var(--bg-alt);border:1px solid var(--border);border-radius:6px}.author-avatar{flex-shrink:0;width:52px;height:52px;display:flex;align-items:center;justify-content:center;background:var(--primary-light);border-radius:50%;color:var(--primary)}.author-details{flex:1}.author-label{display:block;font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.author-name{font-size:1rem;color:var(--text)}.author-bio{font-size:.85rem;color:var(--text-secondary);line-height:1.6;margin-top:6px}.article-tags{margin-top:24px;padding-top:16px;border-top:1px solid var(--border);display:flex;gap:6px;flex-wrap:wrap}.tag{display:inline-block;padding:4px 12px;background:var(--bg-alt);border:1px solid var(--border);font-size:.78rem;color:var(--text-secondary);transition:all .2s}.tag:hover{background:var(--primary-light);color:var(--primary);border-color:var(--primary)}.related-section{margin-top:32px;padding-top:24px;border-top:2px solid var(--border)}.breadcrumb{font-size:.8rem;color:var(--text-muted);margin-bottom:16px;padding:8px 0}.breadcrumb a{color:var(--text-muted)}.breadcrumb a:hover{color:var(--primary)}.breadcrumb-sep{margin:0 6px;color:var(--border)}.breadcrumb-current{color:var(--text-secondary)}.page-header{margin-bottom:20px}.page-header h1{font-size:1.75rem;font-weight:700;margin-bottom:4px}.page-description{font-size:.9rem;color:var(--text-muted)}.category-tabs{display:flex;gap:0;margin-bottom:24px;overflow-x:auto;border-bottom:2px solid var(--border);scrollbar-width:none}.category-tabs::-webkit-scrollbar{display:none}.tab{padding:10px 18px;font-size:.82rem;font-weight:600;white-space:nowrap;color:var(--text-muted);border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s;text-transform:uppercase;letter-spacing:.02em}.tab:hover{color:var(--text);border-bottom-color:var(--text)}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.sidebar{position:sticky;top:calc(var(--header-height) + 20px);align-self:start;max-height:calc(100vh - var(--header-height) - 40px);overflow-y:auto;padding-left:16px;scrollbar-width:none}.sidebar::-webkit-scrollbar{display:none}.sidebar-widget{margin-bottom:24px}.widget-title{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--bg);background:var(--text);padding:6px 14px;margin-bottom:16px;display:inline-block}.category-list{list-style:none}.category-list li{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border-light)}.category-list li:last-child{border-bottom:none}.category-list a{font-size:.85rem;color:var(--text);font-weight:500}.category-list a:hover{color:var(--primary)}.category-count{font-size:.75rem;color:var(--text-muted)}.pagination{display:flex;justify-content:center;align-items:center;gap:4px;margin:32px 0}.page-link{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:34px;padding:0 8px;font-size:.85rem;font-weight:500;color:var(--text-secondary);background:var(--bg);border:1px solid var(--border);transition:all .2s}.page-link:hover{border-color:var(--text);color:var(--text)}.page-link.active{background:var(--primary);color:#fff;border-color:var(--primary)}.page-dots{color:var(--text-muted);padding:0 4px}.page-info{font-size:.82rem;color:var(--text-muted);margin-left:12px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 24px;border:none;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s;text-transform:uppercase;letter-spacing:.03em;font-family:var(--font-body)}.btn:active{transform:scale(.98)}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark);color:#fff}.site-footer{background:var(--bg-dark);color:#ccc;margin-top:40px}.footer-top{padding:40px 0 30px;border-bottom:1px solid #444}.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px}.footer-col h4{color:#fff;font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-bottom:16px}.footer-col p{font-size:.85rem;line-height:1.7}.footer-col ul{list-style:none}.footer-col li{margin-bottom:4px}.footer-col a{color:#aaa;font-size:.85rem}.footer-col a:hover{color:#fff}.footer-category-list li{display:flex;justify-content:space-between;padding:5px 0;border-bottom:1px solid #444}.footer-category-list li:last-child{border-bottom:none}.footer-bottom{padding:16px 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}.footer-copyright{font-size:.78rem;color:#777}.footer-legal{display:flex;gap:16px}.footer-legal a{font-size:.78rem;color:#777}.footer-legal a:hover{color:#fff}.back-to-top{position:fixed;bottom:20px;right:20px;width:40px;height:40px;background:var(--primary);color:#fff;border:none;cursor:pointer;font-size:1.1rem;display:none;align-items:center;justify-content:center;z-index:90;transition:background .2s}.back-to-top.visible{display:flex}.back-to-top:hover{background:var(--primary-dark)}.error-page{text-align:center;padding:80px 20px}.error-code{font-size:6rem;font-weight:800;color:var(--border);line-height:1;margin-bottom:12px}.error-page p{font-size:1rem;color:var(--text-muted);margin-bottom:24px}.text-center{text-align:center}.no-results{text-align:center;padding:60px 20px;color:var(--text-muted);font-size:1rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.reading-progress-bar{position:fixed;top:0;left:0;width:0;height:3px;background:linear-gradient(90deg,var(--primary),var(--accent));z-index:9999;transition:width .1s linear;pointer-events:none}.toc-widget{margin-bottom:24px}.toc-nav{font-size:.85rem;line-height:1.6}.toc-nav ul{list-style:none;padding:0;margin:0}.toc-nav>ul>li{margin-bottom:6px}.toc-nav ul ul{padding-left:14px;margin-top:4px;border-left:2px solid var(--border-light)}.toc-nav a{color:var(--text-secondary);font-weight:500;display:block;padding:3px 0;transition:color .15s,border-color .15s}.toc-nav a:hover{color:var(--primary)}.toc-nav a.toc-active{color:var(--primary);font-weight:600}.code-block-wrapper{position:relative}.code-copy-btn{position:absolute;top:8px;right:8px;background:rgba(56,53,57,.08);border:1px solid var(--border);border-radius:4px;padding:4px 10px;font-size:.72rem;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .2s;font-family:var(--font-body);text-transform:uppercase;letter-spacing:.03em;opacity:0;z-index:2}.code-block-wrapper:hover .code-copy-btn{opacity:1}.code-copy-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.code-copy-btn.copied{background:#22c55e;color:#fff;border-color:#22c55e;opacity:1}.article-hero,.card-image,.hero-image{background:linear-gradient(90deg,#f0f0f0 25%,#e8e8e8 37%,#f0f0f0 63%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite}@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}@media (max-width:960px){.content-layout{grid-template-columns:1fr}.sidebar{position:static;max-height:none;overflow-y:visible;padding-left:0;margin-top:32px}.footer-grid{grid-template-columns:1fr 1fr}.article-grid-3col{grid-template-columns:1fr 1fr}.article-grid-2col{grid-template-columns:1fr}.tech-section-grid{grid-template-columns:1fr}.hero-slide-inner{gap:24px;padding:32px 16px 36px;min-height:280px}.hero-title{font-size:1.35rem}.hero-image{flex:0 0 42%}.hero-excerpt{font-size:.85rem;-webkit-line-clamp:3;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}}@media (max-width:768px){.topbar{display:none}.main-nav{display:none!important}.mobile-menu-toggle{display:flex}.mobile-drawer{display:none;flex-direction:column;background:#fff;border-top:1px solid var(--border);box-shadow:0 6px 16px rgba(0,0,0,.12)}.mobile-drawer.open{display:flex}.mobile-drawer-link{display:block;padding:14px 20px;font-size:.9rem;font-weight:600;color:var(--text);text-transform:uppercase;letter-spacing:.02em;border-bottom:1px solid var(--border)}.mobile-drawer-link:hover{background:var(--bg-alt);color:var(--primary)}.mobile-accordion{border-bottom:1px solid var(--border)}.mobile-accordion-btn{display:flex;width:100%;align-items:center;justify-content:space-between;padding:14px 20px;background:#fff;border:none;font-size:.9rem;font-weight:600;color:var(--text);text-transform:uppercase;letter-spacing:.02em;cursor:pointer}.mobile-accordion-btn:hover{background:var(--bg-alt)}.mobile-arrow{font-size:.7rem;transition:transform .25s}.mobile-accordion.open .mobile-arrow{transform:rotate(180deg)}.mobile-accordion.open .mobile-accordion-btn{background:var(--bg-alt);color:var(--primary)}.mobile-accordion-body{max-height:0;overflow:hidden;transition:max-height .3s ease;background:#f5f5f5}.mobile-accordion.open .mobile-accordion-body{max-height:600px}.mobile-drawer-sublink{display:block;padding:12px 20px 12px 32px;font-size:.85rem;color:var(--text-secondary);border-top:1px solid var(--border)}.mobile-drawer-sublink:hover{background:#eee;color:var(--primary)}.logo-img{height:28px;max-height:28px}.header-inner{height:48px}.article-title{font-size:1.5rem}.article-grid{grid-template-columns:1fr}.article-grid-3col{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr}.footer-bottom{flex-direction:column;text-align:center}.category-tabs{gap:0}.article-meta-bar{flex-wrap:wrap;gap:6px 10px;padding:10px 0}.article-meta-bar .article-meta-sep{display:none}.article-share{margin-left:auto}.hero-carousel{overflow:hidden;max-width:100vw}.hero-slide{overflow:hidden}.hero-slide-inner{display:block;position:relative;aspect-ratio:16/9;height:auto;padding:0;min-height:auto;gap:0;max-width:100%;overflow:hidden}.hero-image{position:absolute;inset:0;flex:none;width:100%;height:100%;border-radius:0;aspect-ratio:auto;z-index:1}.hero-image::after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.4) 0,rgba(0,0,0,.35) 35%,rgba(0,0,0,.6) 65%,rgba(0,0,0,.92) 100%);z-index:2}.hero-image img{width:100%;height:100%;object-fit:cover;max-height:none}.hero-text{position:absolute;bottom:32px;left:0;right:0;padding:0 16px;z-index:3;text-align:left;min-width:0}.hero-platform-badge{font-size:.6rem;padding:3px 8px;margin-bottom:4px}.hero-category{font-size:.6rem;margin-left:6px}.hero-title{font-size:1.05rem;margin:4px 0 6px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.hero-excerpt{display:none}.hero-meta{margin-bottom:0;font-size:.7rem}.hero-read-more{display:none}.hero-arrow{display:none}.hero-dots{bottom:10px;gap:6px;z-index:4}.hero-dot{width:7px;height:7px;border-width:1.5px}.tech-section-grid{grid-template-columns:1fr}.tech-compact-thumb{width:110px}.tech-compact-title{font-size:.82rem}}.cookie-table{width:100%;border-collapse:collapse;margin:12px 0 20px;font-size:.88rem}.cookie-table td,.cookie-table th{border:1px solid #ddd;padding:8px 12px;text-align:left}.cookie-table th{background:#f5f5f5;font-weight:600}.cookie-table code{background:#f0f0f0;padding:1px 5px;border-radius:3px;font-size:.82rem}