*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}img,svg,video{display:block;max-width:100%;height:auto}button,input,textarea,select{font:inherit;color:inherit}button{cursor:pointer;background:none;border:0}a{color:inherit;text-decoration:none}ul,ol{list-style:none}:root{--bg-primary:#0A0E1A;--bg-secondary:#0F1524;--bg-tertiary:#1A2238;--border:#1E2A44;--border-subtle:#141B2D;--text-primary:#FFFFFF;--text-secondary:#B8C5D6;--text-tertiary:#8A99B3;--text-muted:#7B8AA3;--accent:#00FF94;--accent-hover:#00E085;--accent-glow:rgba(0,255,148,0.15);--accent-dim:#00A56E;--danger:#FF4757;--warning:#FFA726;--info:#3B82F6;--font-sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;--font-mono:'JetBrains Mono','Menlo','Courier New',monospace;--font-serif:'Fraunces','Georgia',serif;--r-sm:6px;--r-md:10px;--r-lg:16px;--r-pill:999px;--container:1200px;--container-narrow:760px;--header-h:84px;--transition:200ms ease-out}[data-theme="light"]{--bg-primary:#FFFFFF;--bg-secondary:#FAFAF7;--bg-tertiary:#F1F5F9;--border:#E2E8F0;--border-subtle:#F1F5F9;--text-primary:#0A0E1A;--text-secondary:#334155;--text-tertiary:#475569;--text-muted:#64748B;--accent:#00A56E;--accent-hover:#008F5E;--accent-glow:rgba(0,165,110,0.12);--accent-dim:#00A56E}body{font-family:var(--font-sans);font-size:16px;line-height:1.6;color:var(--text-primary);background:var(--bg-primary);transition:background .25s ease,color .25s ease}h1,h2,h3,h4{font-family:var(--font-sans);font-weight:700;line-height:1.15;color:var(--text-primary);letter-spacing:-0.02em}h1{font-weight:800;letter-spacing:-0.035em}h2{font-size:clamp(26px,3.2vw,32px);letter-spacing:-0.025em;margin:48px 0 20px}h3{font-size:clamp(20px,2.2vw,24px);margin:32px 0 14px}h4{font-size:20px;font-weight:600;margin:24px 0 10px}p{color:var(--text-secondary);margin:0 0 18px}strong{color:var(--text-primary);font-weight:600}a{color:var(--text-primary);transition:color var(--transition)}a:hover{color:var(--accent)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}.skip-link{position:absolute;left:-9999px;top:8px;padding:8px 16px;background:var(--accent);color:#001b11;font-weight:600;border-radius:var(--r-md);z-index:9999}.skip-link:focus{left:8px}.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 24px}.container-narrow{max-width:var(--container-narrow)}.section{padding:64px 0}.section-lg{padding:96px 0}.kbd,.terminal-label{font-family:var(--font-mono);font-size:12px;letter-spacing:0.18em;text-transform:uppercase;color:var(--text-tertiary);font-weight:500}.terminal-label::before{content:"> ";color:var(--accent)}.section-title{display:flex;align-items:baseline;gap:12px;margin:0 0 28px}.section-title-row{justify-content:space-between;flex-wrap:wrap}.section-link{font-family:var(--font-mono);font-size:12px;letter-spacing:0.12em;text-transform:uppercase;color:var(--text-tertiary);text-decoration:none;font-weight:500;transition:color var(--transition)}.section-link:hover{color:var(--accent)}.section-cat + .section-cat{padding-top:0}.actu-stack{display:flex;flex-direction:column;gap:24px}.actu-stack > .card-featured{grid-column:auto;width:100%}.outils-grid{display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.outils-grid .card{font-size:14px}.outils-grid .card-body{padding:16px 18px;gap:8px}.outils-grid .card h3{font-size:16px}.comp-grid{display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.comp-card{position:relative;display:flex;flex-direction:column;gap:12px;padding:32px 24px 24px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--r-lg);transition:transform var(--transition),border-color var(--transition),box-shadow var(--transition);overflow:hidden;text-decoration:none;--mx:50%;--my:50%}.comp-card::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at var(--mx) var(--my),rgba(0,255,148,0.20) 0%,rgba(0,255,148,0.08) 25%,transparent 60%);opacity:0;transition:opacity .4s ease-out;pointer-events:none}.comp-card::after{content:"";position:absolute;top:-60px;right:-60px;width:240px;height:240px;background:conic-gradient(from 0deg,transparent,var(--accent-glow),transparent,var(--accent-glow),transparent);filter:blur(40px);opacity:0.35;animation:compRotate 8s linear infinite;pointer-events:none}@keyframes compRotate{to{transform:rotate(360deg)}}.comp-card:hover{transform:translateY(-4px);border-color:var(--accent);box-shadow:0 20px 50px -20px var(--accent-glow),0 0 0 1px var(--accent-glow)}.comp-card:hover::before{opacity:1}.comp-card > *{position:relative;z-index:1}.comp-card-vs{font-family:var(--font-mono);font-size:13px;font-weight:700;letter-spacing:0.3em;color:var(--accent);text-shadow:0 0 16px var(--accent-glow)}.comp-card h3{font-size:18px;line-height:1.3;color:var(--text-primary);margin:0}.comp-card p{font-size:14px;line-height:1.5;color:var(--text-secondary);margin:0;flex:1}.comp-card-cta{font-family:var(--font-mono);font-size:12px;letter-spacing:0.1em;color:var(--accent);margin-top:6px}.cat-grid.cat-grid-big{grid-template-columns:repeat(3,minmax(0,1fr)) !important}@media (max-width:880px){.cat-grid.cat-grid-big{grid-template-columns:repeat(2,minmax(0,1fr)) !important}}@media (max-width:560px){.cat-grid.cat-grid-big{grid-template-columns:1fr !important}}.cat-card-big{padding:32px 28px;min-height:220px}.cat-card-big .cat-icon{width:40px;height:40px}.cat-card-big h3{font-size:22px;margin-top:8px}.cat-card-big p{font-size:14px}.cat-card-big .count{font-size:12px;color:var(--accent);margin-top:auto}.tuto-list{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--border-subtle)}.tuto-row{display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:center;padding:22px 16px;border-bottom:1px solid var(--border-subtle);text-decoration:none;color:inherit;background:transparent;transition:background var(--transition),transform var(--transition);will-change:transform}.tuto-row:hover{background:var(--bg-secondary);transform:translateX(8px)}.tuto-num{font-family:var(--font-mono);font-size:36px;font-weight:700;color:var(--accent);width:60px;text-align:center;text-shadow:0 0 16px var(--accent-glow);transition:transform var(--transition),text-shadow var(--transition)}.tuto-row:hover .tuto-num{transform:scale(1.2);text-shadow:0 0 24px var(--accent),0 0 40px var(--accent-glow)}.tuto-body h3{margin:0 0 4px;font-size:18px;color:var(--text-primary)}.tuto-body p{margin:0;font-size:14px;color:var(--text-secondary);line-height:1.5}.tuto-meta{font-family:var(--font-mono);font-size:12px;letter-spacing:0.1em;color:var(--text-tertiary);white-space:nowrap}@media (max-width:680px){.tuto-row{grid-template-columns:auto 1fr;gap:16px;padding:16px 8px}.tuto-num{font-size:28px;width:40px}.tuto-meta{display:none}}.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px}@media (max-width:880px){.split-grid{grid-template-columns:1fr;gap:32px}}.split-list{display:flex;flex-direction:column;gap:0}.split-row{display:flex;flex-direction:column;gap:6px;padding:18px 16px;border-top:1px solid var(--border-subtle);text-decoration:none;color:inherit;transition:background var(--transition),transform var(--transition);will-change:transform}.split-row:last-child{border-bottom:1px solid var(--border-subtle)}.split-row:hover{background:var(--bg-secondary);transform:translateX(8px)}.split-row h3,.split-row h4{margin:0;font-size:16px;font-weight:600;color:var(--text-primary);line-height:1.4}.split-row:hover h3,.split-row:hover h4{color:var(--accent)}.split-meta{font-family:var(--font-mono);font-size:11px;letter-spacing:0.1em;color:var(--text-tertiary)}.section-title .terminal-label{font-size:13px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 22px;font-family:var(--font-sans);font-size:14px;font-weight:600;letter-spacing:-0.01em;border:1px solid transparent;border-radius:var(--r-md);transition:transform var(--transition),background var(--transition),border-color var(--transition),box-shadow var(--transition),color var(--transition);white-space:nowrap}.btn-sm{padding:8px 14px;font-size:13px}.btn-lg{padding:16px 28px;font-size:15px}.btn-accent{background:var(--accent);color:#001b11;border-color:var(--accent)}.btn-accent:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 10px 30px -12px var(--accent-glow),0 0 40px -10px var(--accent-glow);color:#001b11}.btn-outline{background:transparent;color:var(--text-primary);border-color:var(--border)}.btn-outline:hover{border-color:var(--accent);color:var(--accent)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-tertiary);color:var(--text-primary)}.btn-icon{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--r-md);color:var(--text-secondary);transition:background var(--transition),color var(--transition)}.btn-icon:hover{background:var(--bg-tertiary);color:var(--text-primary)}.link-btn{background:none;border:0;padding:0;color:inherit;text-align:left;cursor:pointer;font:inherit;text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--border)}.link-btn:hover{color:var(--accent);text-decoration-color:var(--accent)}.site-header{position:sticky;top:0;z-index:100;background:color-mix(in oklab,var(--bg-primary) 88%,transparent);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border-subtle)}.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;min-height:var(--header-h)}.logo{display:inline-flex;align-items:center;flex-shrink:0}.logo img{height:48px;width:auto;display:block}.main-nav{flex:1;display:flex;justify-content:center}.main-nav ul{display:flex;gap:6px;align-items:center}.main-nav a{padding:8px 14px;font-size:14px;font-weight:500;color:var(--text-secondary);border-radius:var(--r-md);transition:color var(--transition),background var(--transition)}.main-nav a:hover{color:var(--text-primary);background:var(--bg-tertiary)}.header-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.icon-sun{display:none}[data-theme="light"] .icon-sun{display:block}[data-theme="light"] .icon-moon{display:none}.btn-mobile-menu{display:none}.mobile-nav{position:fixed;inset:var(--header-h) 0 0;z-index:99;background:var(--bg-primary);padding:24px;overflow-y:auto;border-top:1px solid var(--border-subtle)}.mobile-nav ul{display:flex;flex-direction:column;gap:4px}.mobile-nav a{display:block;padding:14px 16px;font-size:17px;font-weight:500;border-radius:var(--r-md);border:1px solid var(--border-subtle)}.mobile-nav a:hover{border-color:var(--accent);color:var(--accent)}@media (max-width:980px){.main-nav{display:none}.btn-mobile-menu{display:inline-flex}.header-actions > .btn{display:none}}.hero{position:relative;overflow:hidden;padding:80px 0 64px;border-bottom:1px solid var(--border-subtle)}.hero-grid-bg{position:absolute;inset:0;z-index:0;background-image:linear-gradient(var(--border-subtle) 1px,transparent 1px),linear-gradient(90deg,var(--border-subtle) 1px,transparent 1px);background-size:56px 56px;opacity:0.5;mask-image:radial-gradient(ellipse at center,black 30%,transparent 75%);-webkit-mask-image:radial-gradient(ellipse at center,black 30%,transparent 75%);pointer-events:none}.hero-inner{position:relative;z-index:1;text-align:center;max-width:820px;margin:0 auto}.badge{display:inline-flex;align-items:center;gap:10px;padding:8px 16px;font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:0.22em;text-transform:uppercase;color:var(--text-tertiary);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--r-pill);margin-bottom:24px}.badge .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 12px var(--accent);animation:pulse 1.8s ease-in-out infinite}@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.4}}.hero h1{font-size:clamp(38px,6.5vw,64px);line-height:1.05;letter-spacing:-0.04em;margin-bottom:20px}.hero h1 .accent{color:var(--accent);text-shadow:0 0 40px var(--accent-glow)}.hero-lead{font-size:clamp(17px,1.8vw,20px);line-height:1.5;max-width:640px;margin:0 auto 36px;color:var(--text-secondary)}.hero-ctas{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:40px}.hero-stats{display:flex;justify-content:center;gap:40px;font-family:var(--font-mono);font-size:13px;color:var(--text-tertiary);flex-wrap:wrap}.hero-stats strong{color:var(--accent);font-weight:600}.grid-articles{display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.card{position:relative;display:flex;flex-direction:column;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--r-lg);overflow:hidden;transition:transform var(--transition),border-color var(--transition),box-shadow var(--transition)}.card:hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:0 12px 32px -16px var(--accent-glow)}.card-link-overlay{position:absolute;inset:0;z-index:2;border-radius:inherit}.card-link-overlay:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.card > *:not(.card-link-overlay){position:relative;z-index:1}.card h3{font-size:20px;line-height:1.25;margin:0;letter-spacing:-0.02em;color:var(--text-primary);transition:color var(--transition)}.card:hover h3{color:var(--accent)}.card-image{aspect-ratio:16/9;background:var(--bg-tertiary);overflow:hidden}.card-image img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease-out}.card:hover .card-image img{transform:scale(1.03)}.card-body{padding:20px 22px 22px;display:flex;flex-direction:column;gap:12px;flex:1}.card-meta{font-family:var(--font-mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--text-tertiary);display:flex;align-items:center;gap:10px;flex-wrap:wrap}.card-meta .cat{color:var(--accent)}.card-meta .dot{width:3px;height:3px;border-radius:50%;background:currentColor;opacity:0.5}.card-excerpt{font-size:14px;line-height:1.55;color:var(--text-secondary);margin:0}.card-footer{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:auto;padding-top:12px;border-top:1px solid var(--border-subtle);font-size:13px;color:var(--text-tertiary)}.card-footer img{width:28px;height:28px;border-radius:50%;border:1px solid var(--border)}.card-cta{font-family:var(--font-mono);font-size:12px;font-weight:600;letter-spacing:0.08em;color:var(--accent);white-space:nowrap;transition:transform var(--transition)}.card:hover .card-cta{transform:translateX(4px)}.card-date{font-family:var(--font-mono);font-size:12px;color:var(--text-tertiary)}.card-featured{grid-column:span 2;flex-direction:row}.card-featured .card-image{aspect-ratio:16/9;flex:0 0 52%;min-height:320px}.card-featured .card-body{justify-content:center;padding:32px}.card-featured h3{font-size:clamp(22px,2.6vw,30px)}@media (max-width:820px){.card-featured{grid-column:span 1;flex-direction:column}.card-featured .card-image{min-height:0;aspect-ratio:16/9}}.card-noimage{position:relative;border-left:3px solid var(--accent)}.card-noimage .card-body{padding:24px 26px}.card-noimage h3{font-size:18px}.card-noimage::before{content:"";position:absolute;top:0;right:0;width:80px;height:80px;background:radial-gradient(circle at top right,var(--accent-glow) 0%,transparent 70%);pointer-events:none;opacity:0;transition:opacity .3s ease-out}.card-noimage:hover::before{opacity:1}.cat-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.cat-card{display:flex;flex-direction:column;gap:10px;padding:24px 26px;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--r-lg);transition:border-color var(--transition),transform var(--transition)}.cat-card:hover{border-color:var(--accent);transform:translateY(-2px)}.cat-card .cat-icon{width:32px;height:32px;color:var(--accent)}.cat-card h3{font-size:18px;margin:0}.cat-card p{font-size:13px;color:var(--text-tertiary);margin:0;line-height:1.5}.cat-card .count{font-family:var(--font-mono);font-size:11px;letter-spacing:0.15em;color:var(--text-muted);margin-top:4px}.newsletter-section{background:var(--bg-secondary);border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle);padding:72px 0}.newsletter-inner{max-width:640px;margin:0 auto;text-align:center}.newsletter-inner h2{font-size:clamp(26px,3.2vw,34px);margin:0 0 14px}.newsletter-inner p{color:var(--text-secondary);font-size:16px;margin:0 0 28px}.newsletter-form{display:flex;gap:8px;padding:6px;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--r-md);transition:border-color var(--transition);max-width:460px;margin:0 auto}.newsletter-form:focus-within{border-color:var(--accent)}.newsletter-form input[type=email]{flex:1;background:transparent;border:0;outline:none;padding:10px 14px;font-size:14px;color:var(--text-primary)}.newsletter-form input::placeholder{color:var(--text-muted)}.newsletter-tiny{font-size:12px;color:var(--text-muted);margin-top:14px}.newsletter-tiny a{color:var(--text-secondary);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px}.newsletter-tiny a:hover{color:var(--accent)}.site-footer{background:var(--bg-secondary);border-top:1px solid var(--border-subtle);padding:64px 0 24px;margin-top:0}main + .site-footer{margin-top:0}.footer-inner{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,2fr);gap:64px;margin-bottom:48px;align-items:start}.footer-brand img{height:56px;margin-bottom:18px;display:block}.footer-brand .footer-tagline{font-size:14px;color:var(--text-secondary);line-height:1.5;margin:0 0 16px;max-width:340px}.footer-brand .footer-disclosure{font-size:12px;color:var(--text-tertiary);line-height:1.55;max-width:340px;margin:0}.footer-brand .footer-disclosure a{color:var(--text-secondary);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px}.footer-brand .footer-disclosure a:hover{color:var(--accent)}.footer-cols{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:32px}.footer-col h3{font-family:var(--font-mono);font-size:11px;line-height:1.4;letter-spacing:0.2em;text-transform:uppercase;color:var(--text-tertiary);font-weight:600;margin:0 0 14px}.footer-col ul{display:flex;flex-direction:column;gap:4px;padding:0;margin:0;list-style:none}.footer-col li{line-height:1.4;padding:0;margin:0}.footer-col a,.footer-col button{display:inline-block;font-size:14px;line-height:1.5;color:var(--text-secondary);padding:4px 0;text-align:left}.footer-col button{background:none;border:0;cursor:pointer;font-family:inherit}.footer-col a:hover,.footer-col button:hover{color:var(--accent)}.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;padding-top:24px;border-top:1px solid var(--border-subtle);font-size:12px;color:var(--text-tertiary);flex-wrap:wrap}.footer-meta{font-family:var(--font-mono);letter-spacing:0.1em}@media (max-width:980px){.footer-inner{grid-template-columns:1fr;gap:40px}.footer-brand{padding-bottom:24px;border-bottom:1px solid var(--border-subtle)}}@media (max-width:560px){.footer-cols{grid-template-columns:1fr;gap:28px}.footer-bottom{flex-direction:column;align-items:flex-start;gap:8px}}.nl-feedback{margin-top:14px;padding:12px 16px;border-radius:var(--r-md);font-size:14px;line-height:1.5;text-align:center;border:1px solid transparent;opacity:0;transform:translateY(-4px);transition:opacity .25s ease-out,transform .25s ease-out}.nl-feedback:not(:empty){opacity:1;transform:translateY(0)}.nl-feedback-loading{background:var(--bg-secondary);border-color:var(--border);color:var(--text-secondary)}.nl-feedback-success{background:var(--accent-glow);border-color:color-mix(in oklab,var(--accent) 40%,transparent);color:var(--accent);font-weight:500}.nl-feedback-already,.nl-feedback-pending{background:rgba(59,130,246,0.1);border-color:rgba(59,130,246,0.3);color:#60a5fa;font-weight:500}.nl-feedback-error{background:rgba(255,71,87,0.1);border-color:rgba(255,71,87,0.3);color:#ff6b7a;font-weight:500}.btn-loading{position:relative;cursor:wait;opacity:0.85}.btn-loading .btn-spinner{display:inline-block;width:14px;height:14px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;margin-right:8px;vertical-align:middle;animation:btnSpin .7s linear infinite}@keyframes btnSpin{to{transform:rotate(360deg)}}.search-modal{position:fixed;inset:0;z-index:400;display:flex;align-items:flex-start;justify-content:center;padding:80px 20px 20px}.search-modal[hidden]{display:none !important}.search-modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,0.7);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:fadeIn .2s ease-out}.search-modal-content{position:relative;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--r-lg);max-width:680px;width:100%;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 30px 80px -30px rgba(0,0,0,0.7);animation:modalIn .25s ease-out;overflow:hidden}.search-modal-input-wrap{display:flex;align-items:center;gap:12px;padding:18px 22px;border-bottom:1px solid var(--border-subtle)}.search-modal-icon{flex-shrink:0;color:var(--text-tertiary)}.search-modal-input-wrap input{flex:1;background:transparent;border:0;outline:none;font-size:18px;color:var(--text-primary);font-family:var(--font-sans);padding:6px 0}.search-modal-input-wrap input::placeholder{color:var(--text-muted)}.search-modal-results{flex:1;overflow-y:auto;padding:8px}.search-modal-hint{padding:32px 16px;text-align:center;font-size:14px;color:var(--text-tertiary);font-family:var(--font-mono)}.search-modal-count{padding:8px 14px;font-family:var(--font-mono);font-size:11px;letter-spacing:0.15em;text-transform:uppercase;color:var(--text-tertiary)}.search-modal-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px}.search-modal-item a{display:flex;gap:14px;align-items:flex-start;padding:14px 16px;border-radius:var(--r-md);text-decoration:none;color:inherit;transition:background var(--transition)}.search-modal-item-img{flex:0 0 88px;width:88px;height:60px;border-radius:var(--r-sm);overflow:hidden;background:var(--bg-tertiary);border:1px solid var(--border-subtle)}.search-modal-item-img img{width:100%;height:100%;object-fit:cover;display:block}.search-modal-item-body{flex:1;min-width:0}@media (max-width:480px){.search-modal-item-img{flex:0 0 64px;width:64px;height:44px}}.search-modal-item.selected a,.search-modal-item a:hover{background:var(--bg-tertiary)}.search-modal-item-meta{display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:6px}.search-modal-cat{color:var(--accent)}.search-modal-item-meta .dot{color:var(--text-muted)}.search-modal-item h4{margin:0 0 4px;font-size:16px;font-weight:600;color:var(--text-primary);line-height:1.35}.search-modal-item p{margin:0;font-size:13px;color:var(--text-tertiary);line-height:1.5}.search-modal-item mark{background:var(--accent-glow);color:var(--accent);padding:0 2px;border-radius:2px}.search-modal-foot{display:flex;justify-content:flex-end;gap:18px;padding:12px 22px;border-top:1px solid var(--border-subtle);font-size:11px;color:var(--text-tertiary)}.search-modal-foot kbd{font-size:10px;padding:1px 6px}@media (max-width:560px){.search-modal{padding:20px 12px}.search-modal-foot{flex-wrap:wrap;gap:10px}}.cookie-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:200;max-width:560px;margin-left:auto;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:0 20px 60px -20px rgba(0,0,0,0.5);animation:cookieIn .3s ease-out}@keyframes cookieIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.cookie-inner{padding:22px 24px;display:flex;flex-direction:column;gap:14px}.cookie-title{font-size:16px;margin:0;color:var(--text-primary);font-weight:700}.cookie-inner p{font-size:13.5px;color:var(--text-secondary);margin:0;line-height:1.5}.cookie-tiny{font-size:11px;color:var(--text-tertiary);margin:0}.cookie-tiny a{color:var(--text-secondary);text-decoration:underline}.cookie-actions{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}@media (max-width:520px){.cookie-banner{left:8px;right:8px;bottom:8px;max-width:none}.cookie-actions{flex-direction:column-reverse}.cookie-actions .btn{width:100%}}.cookie-modal{position:fixed;inset:0;z-index:300;display:flex;align-items:center;justify-content:center;padding:20px}.cookie-modal[hidden]{display:none !important}.cookie-banner[hidden]{display:none !important}.cookie-modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,0.7);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:fadeIn .2s ease-out}@keyframes fadeIn{from{opacity:0}to{opacity:1}}.cookie-modal-content{position:relative;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--r-lg);max-width:640px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 30px 80px -30px rgba(0,0,0,0.7);animation:modalIn .25s ease-out}@keyframes modalIn{from{opacity:0;transform:scale(0.96)}to{opacity:1;transform:scale(1)}}.cookie-modal-head{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-subtle)}.cookie-modal-head h2{font-size:18px;margin:0;color:var(--text-primary)}.cookie-modal-body{padding:20px 24px;overflow-y:auto;flex:1}.cookie-modal-intro{font-size:13.5px;color:var(--text-secondary);margin:0 0 20px;line-height:1.5}.cookie-cat{padding:18px 20px;margin-bottom:12px;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--r-md)}.cookie-cat-head{display:flex;gap:16px;align-items:flex-start;justify-content:space-between}.cookie-cat h3{font-size:15px;margin:0 0 6px;color:var(--text-primary)}.cookie-cat p{font-size:13px;line-height:1.5;color:var(--text-tertiary);margin:0}.cookie-toggle{flex-shrink:0;display:flex;align-items:center}.cookie-toggle input[type=checkbox]{appearance:none;-webkit-appearance:none;position:relative;width:42px;height:24px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:999px;cursor:pointer;transition:background var(--transition)}.cookie-toggle input[type=checkbox]::after{content:"";position:absolute;width:18px;height:18px;border-radius:50%;background:var(--text-tertiary);top:2px;left:2px;transition:transform var(--transition),background var(--transition)}.cookie-toggle input[type=checkbox]:checked{background:var(--accent);border-color:var(--accent)}.cookie-toggle input[type=checkbox]:checked::after{transform:translateX(18px);background:#001b11}.cookie-toggle input[type=checkbox]:disabled{opacity:0.6;cursor:not-allowed}.cookie-toggle input[type=checkbox]:disabled:checked{background:var(--accent-dim)}.cookie-toggle label{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--text-tertiary);font-family:var(--font-mono);letter-spacing:0.1em;text-transform:uppercase;cursor:pointer}.cookie-toggle .sr{position:absolute;left:-9999px}.cookie-modal-foot{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;padding:18px 24px;border-top:1px solid var(--border-subtle)}.cookie-modal-foot-right{display:flex;gap:8px;flex-wrap:wrap}@media (max-width:520px){.cookie-modal-foot{flex-direction:column;align-items:stretch}.cookie-modal-foot .btn,.cookie-modal-foot-right{width:100%}.cookie-modal-foot-right{flex-direction:column}.cookie-modal-foot-right .btn{width:100%}}[data-reveal],.reveal,.reveal-up,.reveal-down,.reveal-left,.reveal-right,.reveal-zoom,.reveal-blur,.reveal-item{--p:1;--curve:0}[data-reveal],.reveal,.reveal-up{transform:translate3d(0,calc((1 - var(--p)) * 50px),0);filter:blur(calc((1 - var(--p)) * 6px))}.reveal-down{transform:translate3d(0,calc((var(--p) - 1) * 50px),0);filter:blur(calc((1 - var(--p)) * 6px))}.reveal-left{transform:translate3d(calc((1 - var(--p)) * -70px),0,0);filter:blur(calc((1 - var(--p)) * 6px))}.reveal-right{transform:translate3d(calc((1 - var(--p)) * 70px),0,0);filter:blur(calc((1 - var(--p)) * 6px))}.reveal-zoom{transform:translate3d(0,calc((1 - var(--p)) * 25px),0) scale(calc(0.94 + var(--p) * 0.06));filter:blur(calc((1 - var(--p)) * 5px))}.reveal-blur{filter:blur(calc((1 - var(--p)) * 10px))}body.js-ready [data-reveal],body.js-ready .reveal,body.js-ready .reveal-up,body.js-ready .reveal-down,body.js-ready .reveal-left,body.js-ready .reveal-right,body.js-ready .reveal-zoom,body.js-ready .reveal-blur{transition:transform .15s linear,filter .15s linear;will-change:transform,filter}.reveal-item{transform-origin:50% 0%;transform:translate3d(0,calc((1 - var(--p)) * 40px),calc(var(--curve) * -120px)) rotateX(calc(var(--curve) * 35deg));filter:blur(calc((1 - var(--p)) * 3px));opacity:calc(0.6 + var(--p) * 0.4);transform-style:preserve-3d;backface-visibility:hidden}body.js-ready .reveal-item{transition:transform 60ms linear,filter .15s linear,opacity .15s linear}.reveal-stagger{perspective:1400px;perspective-origin:50% 0%;transform-style:preserve-3d}.reveal-stagger > *:nth-child(1){--i:0}.reveal-stagger > *:nth-child(2){--i:1}.reveal-stagger > *:nth-child(3){--i:2}.reveal-stagger > *:nth-child(4){--i:3}.reveal-stagger > *:nth-child(5){--i:4}.reveal-stagger > *:nth-child(6){--i:5}.reveal-stagger > *:nth-child(7){--i:6}.reveal-stagger > *:nth-child(8){--i:7}.reveal-stagger > *:nth-child(9){--i:8}.reveal-stagger > *:nth-child(10){--i:9}@media (prefers-reduced-motion:reduce){body.js-ready [data-reveal],body.js-ready .reveal,body.js-ready .reveal-up,body.js-ready .reveal-down,body.js-ready .reveal-left,body.js-ready .reveal-right,body.js-ready .reveal-zoom,body.js-ready .reveal-blur,body.js-ready .reveal-stagger > *{transform:none !important;opacity:1 !important;filter:none !important}}.logo img{transition:filter var(--transition)}.site-header:hover .logo img,.logo:hover img{filter:drop-shadow(0 0 12px var(--accent-glow))}@keyframes gridDrift{0%{background-position:0 0,0 0}100%{background-position:56px 56px,56px 56px}}body.js-ready .hero-grid-bg{animation:gridDrift 30s linear infinite}.hero{position:relative;overflow:hidden}.hero-network{position:absolute;inset:0;z-index:0;width:100%;height:100%;pointer-events:none;opacity:0.7}.hero .container{position:relative;z-index:2}body.js-ready .hero-inner{--hp:0;opacity:calc(1 - var(--hp));filter:blur(calc(var(--hp) * 12px));transform:translate3d(0,calc(var(--hp) * -80px),0) scale(calc(1 - var(--hp) * 0.06));transition:opacity .1s linear,filter .1s linear,transform .1s linear}body.js-ready .hero-network{--hp:0;opacity:calc(0.7 - var(--hp) * 0.7);transform:translate3d(0,calc(var(--hp) * -40px),0)}body.js-ready .hero-grid-bg{--hp:0;opacity:calc(0.5 - var(--hp) * 0.5)}.badge .dot{box-shadow:0 0 0 0 var(--accent);animation:dotPulse 2s ease-out infinite}@keyframes dotPulse{0%{box-shadow:0 0 0 0 rgba(0,255,148,0.7),0 0 12px var(--accent)}70%{box-shadow:0 0 0 12px rgba(0,255,148,0),0 0 12px var(--accent)}100%{box-shadow:0 0 0 0 rgba(0,255,148,0),0 0 12px var(--accent)}}.hero h1 .accent{background:linear-gradient(110deg,var(--accent) 0%,#80ffc8 45%,var(--accent) 55%,var(--accent) 100%);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 0 40px var(--accent-glow);animation:textShine 4s linear infinite}@keyframes textShine{0%{background-position:200% 0}100%{background-position:-200% 0}}.card{position:relative;overflow:hidden}.card::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 0%,rgba(0,255,148,0.04) 50%,transparent 100%);transform:translateY(-100%);pointer-events:none;transition:transform .8s ease-out}.card:hover::before{transform:translateY(100%)}.terminal-label{position:relative}.terminal-label::after{content:"_";display:inline-block;margin-left:4px;color:var(--accent);animation:blinkCursor 1s steps(2) infinite;font-weight:400}@keyframes blinkCursor{50%{opacity:0}}.newsletter-section{position:relative;overflow:hidden}.newsletter-section::after{content:"";position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,var(--accent-glow) 0%,transparent 60%);top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;animation:nlGlow 6s ease-in-out infinite;z-index:0}.newsletter-section .container{position:relative;z-index:1}@keyframes nlGlow{0%,100%{opacity:0.4;transform:translate(-50%,-50%) scale(1)}50%{opacity:0.7;transform:translate(-50%,-50%) scale(1.15)}}.cat-card{position:relative;overflow:hidden}.cat-card::before{content:"";position:absolute;width:140px;height:140px;border-radius:50%;background:radial-gradient(circle,var(--accent-glow) 0%,transparent 70%);top:-40px;right:-40px;opacity:0;pointer-events:none;transition:opacity .4s ease-out}.cat-card:hover::before{opacity:1}.cat-card .cat-icon{transition:transform .4s ease-out,filter .3s ease-out}.cat-card:hover .cat-icon{transform:scale(1.1) rotate(-4deg);filter:drop-shadow(0 0 8px var(--accent))}.btn-accent{position:relative;overflow:hidden}.btn-accent::after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,0.3) 50%,transparent 70%);transform:translateX(-100%);transition:transform .6s ease-out;pointer-events:none}.btn-accent:hover::after{transform:translateX(100%)}@media (prefers-reduced-motion:reduce){.badge .dot,.hero::before,.hero::after,.hero h1 .accent,.terminal-label::after,.newsletter-section::after,.hero-grid-bg{animation:none !important}}.breadcrumb{padding:20px 0 0;font-size:13px;color:var(--text-tertiary)}.breadcrumb ol{display:flex;flex-wrap:wrap;gap:6px;align-items:center;list-style:none}.breadcrumb li{display:flex;align-items:center;gap:6px}.breadcrumb li:not(:last-child)::after{content:"/";color:var(--text-muted);margin-left:6px}.breadcrumb a{color:var(--text-tertiary)}.breadcrumb a:hover{color:var(--accent)}.breadcrumb li[aria-current]{color:var(--text-secondary)}.breadcrumb-inline{font-size:13px;color:var(--text-tertiary);margin-bottom:16px}.breadcrumb-inline a{color:var(--text-tertiary)}.breadcrumb-inline a:hover{color:var(--accent)}.breadcrumb-inline span{color:var(--text-muted);margin:0 4px}.reading-progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--accent);box-shadow:0 0 8px var(--accent-glow);z-index:150;transition:width 50ms linear}.article{padding:32px 0 80px}.article-grid{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:56px;max-width:1100px;margin:0 auto}@media (max-width:980px){.article-grid{grid-template-columns:1fr;gap:32px}}.article-header{margin-bottom:32px}.article-category{display:inline-block;font-family:var(--font-mono);font-size:12px;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--accent);margin-bottom:20px}.article-category .terminal-prefix{color:var(--accent)}.article-header h1{font-size:clamp(32px,5vw,48px);line-height:1.1;letter-spacing:-0.03em;margin:0 0 16px}.article-subtitle{font-size:clamp(18px,2vw,22px);line-height:1.4;color:var(--text-secondary);margin:0 0 24px;font-weight:400}.article-meta{font-size:14px;color:var(--text-tertiary);display:flex;gap:10px;align-items:center;flex-wrap:wrap}.article-meta strong{color:var(--text-primary);font-weight:600}.article-meta .sep{color:var(--text-muted)}.article-hero{margin:32px 0 40px;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border-subtle)}.article-hero img{width:100%;height:auto;display:block;aspect-ratio:16/9;object-fit:cover}.tldr{background:var(--bg-secondary);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--r-md);padding:22px 26px;margin:32px 0}.tldr-head{font-family:var(--font-mono);font-size:12px;letter-spacing:0.2em;text-transform:uppercase;color:var(--accent);font-weight:600;margin-bottom:12px}.tldr-head .terminal-prefix{color:var(--accent)}.tldr ul{display:flex;flex-direction:column;gap:8px}.tldr li{padding-left:20px;position:relative;font-size:15px;color:var(--text-secondary);line-height:1.55;list-style:none}.tldr li::before{content:"";position:absolute;left:0;top:10px;width:6px;height:6px;background:var(--accent);border-radius:1px}.prose{font-size:18px;line-height:1.7;color:var(--text-secondary);max-width:720px}.prose > * + *{margin-top:1em}.prose h2{font-size:clamp(24px,3vw,30px);margin:56px 0 20px;padding-bottom:14px;border-bottom:1px solid var(--border-subtle);color:var(--text-primary);letter-spacing:-0.025em;scroll-margin-top:100px}.prose h3{font-size:22px;margin:40px 0 14px;color:var(--text-primary);scroll-margin-top:100px}.prose h4{font-size:18px;font-weight:600;margin:28px 0 10px;color:var(--text-primary)}.prose p{margin:0 0 20px;color:var(--text-secondary)}.prose strong{color:var(--text-primary);font-weight:600}.prose em{color:var(--text-primary)}.prose a{color:var(--accent);text-decoration:underline;text-decoration-color:color-mix(in oklab,var(--accent) 40%,transparent);text-underline-offset:3px;transition:text-decoration-color var(--transition)}.prose a:hover{text-decoration-color:var(--accent)}.prose ul,.prose ol{padding-left:24px;margin:0 0 20px}.prose ul{list-style:disc}.prose ol{list-style:decimal}.prose li{margin:6px 0;color:var(--text-secondary)}.prose li::marker{color:var(--accent)}.prose blockquote{border-left:3px solid var(--accent);padding:4px 0 4px 20px;margin:24px 0;font-style:normal;color:var(--text-primary);font-size:19px;line-height:1.55;background:var(--accent-glow);border-radius:0 var(--r-md) var(--r-md) 0;padding:16px 20px}.prose img{border-radius:var(--r-md);margin:24px 0;border:1px solid var(--border-subtle)}.prose figure{margin:28px 0}.prose figcaption{font-size:13px;color:var(--text-tertiary);text-align:center;margin-top:8px;font-family:var(--font-mono)}.prose code{font-family:var(--font-mono);font-size:0.88em;background:var(--bg-tertiary);border:1px solid var(--border-subtle);padding:2px 7px;border-radius:4px;color:var(--accent)}.prose pre{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--r-md);padding:18px 20px;overflow-x:auto;font-size:14px;line-height:1.6;margin:24px 0}.prose pre code{background:none;border:0;padding:0;color:var(--text-primary)}.prose table{width:100%;border-collapse:collapse;margin:24px 0;border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;font-size:15px}.prose th,.prose td{padding:12px 16px;border-bottom:1px solid var(--border-subtle);text-align:left}.prose th{background:var(--bg-secondary);font-weight:600;color:var(--text-primary);font-size:13px;letter-spacing:0.02em;text-transform:uppercase;font-family:var(--font-mono)}.prose tr:last-child td{border-bottom:0}.prose hr{border:0;border-top:1px solid var(--border-subtle);margin:40px 0}.callout{padding:18px 22px;margin:28px 0;background:var(--bg-secondary);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--r-md);display:flex;gap:14px;align-items:flex-start}.callout.warning{border-left-color:var(--warning)}.callout.danger{border-left-color:var(--danger)}.callout.info{border-left-color:var(--info)}.callout-icon{flex-shrink:0;width:20px;height:20px;color:var(--accent);margin-top:2px}.callout.warning .callout-icon{color:var(--warning)}.callout.danger .callout-icon{color:var(--danger)}.callout.info .callout-icon{color:var(--info)}.callout-body{font-size:15px;line-height:1.55;color:var(--text-secondary)}.callout-body p:last-child{margin-bottom:0}.article-sidebar{position:relative}.article-sidebar > * + *{margin-top:20px}@media (min-width:981px){.article-sidebar{position:sticky;top:100px;align-self:start;max-height:calc(100vh - 120px);overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.article-sidebar::-webkit-scrollbar{width:4px}.article-sidebar::-webkit-scrollbar-track{background:transparent}.article-sidebar::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}}.sidebar-block{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--r-md);padding:20px 22px}.sidebar-title{font-family:var(--font-mono);font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--text-tertiary);font-weight:600;margin-bottom:14px}.toc ol{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}.toc a{display:block;padding:6px 10px;font-size:13px;line-height:1.4;color:var(--text-secondary);border-radius:4px;border-left:2px solid transparent;transition:all var(--transition)}.toc a:hover{color:var(--accent);background:var(--bg-tertiary)}.toc .toc-h3{padding-left:20px;font-size:12.5px;color:var(--text-tertiary)}.toc a.active{color:var(--accent);border-left-color:var(--accent);background:var(--accent-glow)}.sidebar-newsletter p{font-size:13px;color:var(--text-tertiary);margin:0 0 12px}.newsletter-form-compact{padding:4px;flex-direction:column;gap:6px}.newsletter-form-compact input{padding:8px 12px;font-size:13px}.newsletter-form-compact button{width:100%}.article-faq{margin:56px 0 32px;max-width:720px}.article-faq h2{margin-bottom:20px}.faq-item{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--r-md);margin-bottom:10px;overflow:hidden;transition:border-color var(--transition)}.faq-item[open]{border-color:var(--border)}.faq-item summary{padding:16px 20px;font-size:16px;font-weight:600;color:var(--text-primary);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px}.faq-item summary::-webkit-details-marker{display:none}.faq-item summary::after{content:"+";font-family:var(--font-mono);font-weight:400;color:var(--accent);font-size:20px;flex-shrink:0;transition:transform var(--transition)}.faq-item[open] summary::after{content:"−"}.faq-answer{padding:0 20px 18px;font-size:15px;line-height:1.6;color:var(--text-secondary)}.article-share{margin:48px 0 24px;padding:24px 0;border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;gap:20px;flex-wrap:wrap}.share-links{display:flex;gap:8px}.share-links a{padding:8px 14px;font-size:13px;font-weight:500;border:1px solid var(--border);border-radius:var(--r-md);color:var(--text-secondary);transition:all var(--transition)}.share-links a:hover{border-color:var(--accent);color:var(--accent)}.aff-cta{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--r-lg);padding:24px 28px;margin:32px 0;display:flex;flex-direction:column;gap:14px;max-width:720px;transition:border-color var(--transition),box-shadow var(--transition);position:relative}.aff-cta:hover{border-color:var(--accent);box-shadow:0 12px 40px -20px var(--accent-glow)}.aff-cta-head{display:flex;gap:14px;align-items:flex-start}.aff-cta-head img{width:44px;height:44px;border-radius:10px;background:var(--bg-primary);padding:6px;border:1px solid var(--border-subtle);flex-shrink:0}.aff-cta-logo-fallback{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:10px;font-weight:700;color:var(--accent);font-size:20px;flex-shrink:0}.aff-cta-head h4{margin:0 0 4px;font-size:18px;color:var(--text-primary)}.aff-cta-head p{margin:0;font-size:14px;color:var(--text-secondary);line-height:1.45}.aff-cta-meta{display:flex;gap:10px;align-items:center;font-size:14px;color:var(--text-tertiary);flex-wrap:wrap}.aff-cta-meta .rating{color:var(--accent);font-weight:600}.aff-cta-meta .sep{color:var(--text-muted)}.aff-cta-btn{align-self:flex-start}.aff-disclosure{font-size:12px;color:var(--text-muted);margin:0;font-family:var(--font-mono)}.aff-link{color:var(--accent);position:relative}.aff-link::after{content:"⎘";font-size:0.75em;margin-left:2px;color:var(--text-tertiary);vertical-align:super}.page-hero{padding:48px 0 32px;border-bottom:1px solid var(--border-subtle)}.page-hero h1{font-size:clamp(36px,5vw,56px);letter-spacing:-0.035em;margin:12px 0 16px;line-height:1.05}.page-hero .terminal-label{display:block;margin-bottom:8px}.page-lead{font-size:17px;line-height:1.55;color:var(--text-secondary);max-width:640px;margin:0 0 12px}.page-stats{font-family:var(--font-mono);font-size:13px;letter-spacing:0.1em;color:var(--text-tertiary);margin:0}.empty-state{padding:48px 24px;text-align:center;background:var(--bg-secondary);border:1px dashed var(--border);border-radius:var(--r-lg);color:var(--text-secondary)}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:48px;padding-top:32px;border-top:1px solid var(--border-subtle)}.pagination-status{font-family:var(--font-mono);font-size:13px;color:var(--text-tertiary);letter-spacing:0.08em}.form-row{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}.form-row label{font-family:var(--font-mono);font-size:12px;letter-spacing:0.15em;text-transform:uppercase;color:var(--text-tertiary);font-weight:600}.form-row input,.form-row textarea,.form-row select{padding:12px 16px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text-primary);font-size:15px;font-family:var(--font-sans);transition:border-color var(--transition);width:100%}.form-row input:focus,.form-row textarea:focus,.form-row select:focus{outline:none;border-color:var(--accent)}.form-row textarea{resize:vertical;min-height:140px;line-height:1.5}.form-row select{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none' stroke='%236B7A94' stroke-width='2'><path d='m1 1 5 5 5-5'/></svg>");background-repeat:no-repeat;background-position:right 16px center;padding-right:40px}.form-tiny{font-size:12px;color:var(--text-tertiary);line-height:1.5;margin:8px 0 16px}.form-tiny a{color:var(--text-secondary);text-decoration:underline;text-underline-offset:2px}.contact-form{padding:28px 32px;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--r-lg)}.contact-form button[type=submit]{width:100%;padding:14px 20px}.honeypot{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}.newsletter-form-big{display:flex;gap:8px;padding:6px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--r-md);max-width:520px;margin:0 auto;transition:border-color var(--transition)}.newsletter-form-big:focus-within{border-color:var(--accent)}.newsletter-form-big input[type=email]{flex:1;background:transparent;border:0;outline:none;padding:12px 16px;font-size:15px;color:var(--text-primary)}.newsletter-form-big button{flex-shrink:0}@media (max-width:520px){.newsletter-form-big{flex-direction:column}.newsletter-form-big button{width:100%}}.nl-hero{text-align:center;padding:32px 0 40px}.nl-hero .badge{margin:0 auto 20px}.nl-benefits{margin:64px 0 48px}.nl-benefits h2{margin-bottom:24px}.nl-list{list-style:none;padding:0;display:grid;gap:14px;grid-template-columns:1fr 1fr}.nl-list li{padding:20px 22px;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--r-md);display:flex;flex-direction:column;gap:6px}.nl-list strong{color:var(--text-primary);font-size:15px}.nl-list span{color:var(--text-secondary);font-size:14px;line-height:1.5}@media (max-width:680px){.nl-list{grid-template-columns:1fr}}.nl-faq{margin:48px 0}.nl-faq h2{margin-bottom:20px}.authors-grid{display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));max-width:1000px;margin:0 auto}.author-card{display:flex;gap:20px;padding:24px 26px;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--r-lg);transition:border-color var(--transition),transform var(--transition)}.author-card:hover{border-color:var(--accent);transform:translateY(-2px)}.author-avatar{flex-shrink:0}.author-avatar img{width:80px;height:80px;border-radius:50%;object-fit:cover;border:1px solid var(--border)}.avatar-fallback{display:flex;align-items:center;justify-content:center;width:80px;height:80px;border-radius:50%;background:var(--bg-tertiary);border:1px solid var(--border);font-size:32px;font-weight:700;color:var(--accent)}.author-body h3{margin:0 0 4px;font-size:18px;color:var(--text-primary)}.author-title{font-family:var(--font-mono);font-size:12px;letter-spacing:0.12em;text-transform:uppercase;color:var(--accent);margin:0 0 10px}.author-bio-short{font-size:14px;color:var(--text-secondary);line-height:1.5;margin:0 0 12px}.author-expertise{display:flex;flex-wrap:wrap;gap:6px;margin:0 0 10px}.tag{font-family:var(--font-mono);font-size:11px;letter-spacing:0.1em;padding:4px 10px;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--r-pill);color:var(--text-secondary)}.author-count{font-family:var(--font-mono);font-size:12px;color:var(--text-tertiary);letter-spacing:0.1em}.author-hero{padding:48px 0 24px;border-bottom:1px solid var(--border-subtle)}.author-hero-grid{display:grid;grid-template-columns:180px 1fr;gap:40px;align-items:start;margin-top:16px}.author-hero-avatar img{width:180px;height:180px;border-radius:var(--r-lg);object-fit:cover;border:1px solid var(--border)}.author-hero-avatar .avatar-fallback{width:180px;height:180px;border-radius:var(--r-lg);font-size:72px}.author-hero-body h1{font-size:clamp(32px,4.5vw,48px);margin:12px 0 12px;letter-spacing:-0.03em}.author-hero-title{font-size:17px;color:var(--text-secondary);margin:0 0 20px}.author-social{display:flex;gap:10px;margin-top:20px;flex-wrap:wrap}.author-social a{padding:6px 14px;font-size:13px;font-weight:500;border:1px solid var(--border);border-radius:var(--r-md);color:var(--text-secondary);transition:all var(--transition)}.author-social a:hover{border-color:var(--accent);color:var(--accent)}@media (max-width:680px){.author-hero-grid{grid-template-columns:1fr;gap:24px}.author-hero-avatar img,.author-hero-avatar .avatar-fallback{width:120px;height:120px}.author-hero-avatar .avatar-fallback{font-size:48px}}.search-wrap{position:relative;display:flex;align-items:center;gap:12px;max-width:640px;margin-top:24px;padding:8px 16px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--r-md);transition:border-color var(--transition)}.search-wrap:focus-within{border-color:var(--accent)}.search-icon{flex-shrink:0;color:var(--text-tertiary)}.search-wrap input[type=search]{flex:1;background:transparent;border:0;outline:none;padding:10px 0;font-size:16px;color:var(--text-primary);-webkit-appearance:none;appearance:none}.search-wrap input::placeholder{color:var(--text-muted)}.search-count{font-family:var(--font-mono);font-size:12px;color:var(--text-tertiary);letter-spacing:0.1em;flex-shrink:0}mark{background:var(--accent-glow);color:var(--accent);padding:0 2px;border-radius:2px}kbd{display:inline-block;font-family:var(--font-mono);font-size:12px;padding:2px 8px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:4px;color:var(--text-secondary);box-shadow:inset 0 -1px 0 var(--border)}.vs-block{margin:32px 0;padding:32px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--r-lg)}.vs-heads{display:grid;grid-template-columns:1fr auto 1fr;gap:24px;align-items:center;margin-bottom:28px}.vs-head{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;padding:20px;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--r-md)}.vs-head img{width:48px;height:48px;border-radius:10px;background:var(--bg-tertiary);padding:6px}.vs-head strong{font-size:18px;color:var(--text-primary)}.vs-head span{font-size:13px;color:var(--text-tertiary);line-height:1.4}.vs-separator{font-family:var(--font-mono);font-size:22px;font-weight:700;color:var(--accent);padding:0 8px;letter-spacing:0.1em;text-shadow:0 0 20px var(--accent-glow)}.vs-verdict{padding:20px 22px;margin-bottom:24px;background:var(--accent-glow);border:1px solid color-mix(in oklab,var(--accent) 30%,transparent);border-radius:var(--r-md)}.vs-verdict .terminal-label{margin-bottom:8px;color:var(--accent)}.vs-verdict p{margin:0;color:var(--text-primary);font-size:16px;line-height:1.55;font-weight:500}.vs-table-wrap{overflow-x:auto}.vs-table{width:100%;border-collapse:collapse;font-size:14px}.vs-table th,.vs-table td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--border-subtle)}.vs-table thead th{background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-mono);font-size:12px;letter-spacing:0.1em;text-transform:uppercase;font-weight:600}.vs-table tbody th{color:var(--text-tertiary);font-weight:500;width:30%}.vs-table tbody td{color:var(--text-secondary)}.vs-table tr:last-child th,.vs-table tr:last-child td{border-bottom:0}@media (max-width:680px){.vs-heads{grid-template-columns:1fr;gap:12px}.vs-separator{transform:rotate(90deg);padding:8px 0}}.terminal-block{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--r-md);padding:18px 20px;margin:24px 0;font-family:var(--font-mono);font-size:14px;line-height:1.7}.terminal-line{color:var(--text-secondary)}.terminal-line + .terminal-line{margin-top:4px}.terminal-line .terminal-prefix{color:var(--accent);margin-right:8px;user-select:none}.terminal-line code{background:none;border:0;padding:0;color:var(--text-primary);font-size:inherit}.hidden{display:none !important}.text-center{text-align:center}.mt-0{margin-top:0}.mb-0{margin-bottom:0}.filter-bar{background:var(--bg-secondary);border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle);padding:24px 0;margin:0 0 8px}.filter-bar .container{display:flex;flex-direction:column;gap:14px}.filter-row{display:flex;align-items:flex-start;gap:14px;flex-wrap:wrap}.filter-label{font-family:var(--font-mono,'JetBrains Mono',monospace);font-size:11px;text-transform:uppercase;letter-spacing:0.12em;color:var(--text-tertiary);padding-top:8px;flex-shrink:0;min-width:120px}.filter-label::before{content:"> ";color:var(--accent)}.filter-chips{display:flex;flex-wrap:wrap;gap:8px;flex:1;min-width:0}.chip{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:transparent;border:1px solid var(--border);border-radius:999px;font-size:13px;color:var(--text-secondary);text-decoration:none;cursor:pointer;transition:all 0.15s ease;user-select:none;line-height:1}.chip:hover{border-color:var(--accent-dim);color:var(--text-primary)}.chip.is-active{background:var(--accent-glow);border-color:var(--accent);color:var(--accent)}.chip.is-active .chip-count{background:var(--accent);color:#001b11}.chip-metier{font-weight:500}.chip-logo{width:16px;height:16px;border-radius:4px;object-fit:contain;flex-shrink:0}.chip-name{font-weight:500}.chip-count{display:inline-block;padding:2px 7px;border-radius:999px;background:var(--bg-tertiary);color:var(--text-tertiary);font-size:11px;font-weight:600;font-variant-numeric:tabular-nums}.filter-row-reset{margin-top:4px}.filter-reset{display:inline-flex;align-items:center;font-size:13px;color:var(--text-tertiary);text-decoration:none;cursor:pointer;background:none;border:0;padding:0}.filter-reset:hover{color:var(--accent)}@media (max-width:640px){.filter-row{flex-direction:column;gap:10px}.filter-label{padding-top:0;min-width:0}}.grid-articles .month-heading{grid-column:1 / -1;margin:32px 0 4px;padding:0 0 12px;font-size:22px;font-weight:700;color:var(--text-primary);letter-spacing:-0.01em;border-bottom:1px solid var(--border-subtle)}.grid-articles .month-heading::before{content:"// ";color:var(--accent);font-family:var(--font-mono,'JetBrains Mono',monospace);font-weight:500;font-size:0.85em}.grid-articles .month-heading:first-child{margin-top:0}.month-card-wrap{display:contents}.scroll-sentinel{height:1px;width:100%;margin:24px 0 0;pointer-events:none}.scroll-loader{display:flex;justify-content:center;align-items:center;gap:6px;padding:32px 0;min-height:60px;opacity:0;transition:opacity 0.2s ease}.scroll-loader.is-visible{opacity:1}.loader-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:loader-bounce 1.4s infinite ease-in-out both}.loader-dot:nth-child(1){animation-delay:-0.32s}.loader-dot:nth-child(2){animation-delay:-0.16s}@keyframes loader-bounce{0%,80%,100%{transform:scale(0.6);opacity:0.4}40%{transform:scale(1);opacity:1}}.skeleton-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;margin-top:20px}.skel-card{height:340px;border-radius:12px;background:linear-gradient(90deg,var(--bg-secondary) 0%,var(--bg-tertiary) 50%,var(--bg-secondary) 100%);background-size:200% 100%;animation:skel-shimmer 1.6s infinite linear;border:1px solid var(--border-subtle)}@keyframes skel-shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}.scroll-error{text-align:center;padding:24px;margin:16px 0;border:1px solid var(--border);border-radius:8px;background:var(--bg-secondary);color:var(--text-secondary);font-size:14px;display:flex;flex-direction:column;gap:12px;align-items:center}.exit-popup{position:fixed;inset:0;z-index:9000;display:flex;align-items:center;justify-content:center;padding:20px;animation:exitPopupFade 0.25s ease-out}.exit-popup-backdrop{position:absolute;inset:0;background:rgba(0,0,0,0.7);backdrop-filter:blur(4px)}.exit-popup-content{position:relative;z-index:1;background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;padding:40px 32px;max-width:480px;width:100%;box-shadow:0 30px 80px -20px rgba(0,0,0,0.5),0 0 0 1px var(--accent-glow);text-align:center}.exit-popup-close{position:absolute;top:14px;right:14px;background:transparent;border:0;color:var(--text-tertiary);cursor:pointer;padding:8px;border-radius:6px;transition:color 0.15s,background 0.15s}.exit-popup-close:hover{color:var(--text-primary);background:var(--bg-tertiary)}.exit-popup-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;color:var(--accent);background:var(--accent-glow);border:1px solid var(--accent);border-radius:999px;margin-bottom:18px}.exit-popup-badge .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent)}.exit-popup-content h2{font-size:clamp(22px,3vw,28px);margin:0 0 12px;color:var(--text-primary);letter-spacing:-0.02em}.exit-popup-content p{color:var(--text-secondary);font-size:15px;margin:0 0 24px}.exit-popup-content .newsletter-form{margin:0 auto;max-width:380px}.exit-popup-tiny{font-size:12px;color:var(--text-tertiary);margin-top:14px !important}@keyframes exitPopupFade{from{opacity:0;transform:scale(0.96)}to{opacity:1;transform:scale(1)}}.sticky-mobile{position:fixed;left:12px;right:12px;bottom:12px;z-index:8500;display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--bg-secondary);border:1px solid var(--accent);border-radius:14px;box-shadow:0 10px 30px -10px rgba(0,0,0,0.4),0 0 0 1px var(--accent-glow);animation:stickySlide 0.3s ease-out}.sticky-mobile-content{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.sticky-mobile-content strong{font-size:14px;color:var(--text-primary);font-weight:700}.sticky-mobile-content span{font-size:12px;color:var(--text-tertiary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sticky-mobile-close{position:absolute;top:6px;right:6px;background:transparent;border:0;color:var(--text-tertiary);cursor:pointer;padding:6px;border-radius:50%;transition:color 0.15s,background 0.15s}.sticky-mobile-close:hover{color:var(--text-primary);background:var(--bg-tertiary)}.sticky-mobile .btn{flex-shrink:0}@keyframes stickySlide{from{transform:translateY(120%)}to{transform:translateY(0)}}@media (min-width:721px){.sticky-mobile{display:none !important}}body.has-sticky-mobile .cookie-banner{bottom:90px}.prose .inline-related{margin:32px 0;padding:18px 22px;background:var(--bg-secondary);border-left:3px solid var(--accent);border-radius:6px;font-size:15px}.prose .inline-related-label{display:block;font-family:var(--font-mono,'JetBrains Mono',monospace);font-size:12px;text-transform:uppercase;letter-spacing:0.1em;color:var(--accent);margin-bottom:8px;font-weight:600}.prose .inline-related-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.prose .inline-related-list li{padding:0;margin:0}.prose .inline-related-list a{color:var(--text-primary);text-decoration:none;border-bottom:1px solid var(--border);padding-bottom:2px;transition:color 0.15s ease,border-color 0.15s ease}.prose .inline-related-list a:hover{color:var(--accent);border-bottom-color:var(--accent)}.prose a.autolink{color:inherit;text-decoration:none;border-bottom:1px dashed var(--accent-dim);transition:color 0.15s ease,border-color 0.15s ease}.prose a.autolink:hover{color:var(--accent);border-bottom-color:var(--accent);border-bottom-style:solid}