:root{--font-display:'Inter Tight',sans-serif;--font-body:'Inter',sans-serif;--font-mono:'JetBrains Mono',monospace;--font-serif:'Instrument Serif',serif;--bg:#09090f;--surface:rgba(244,243,238,0.04);--border:rgba(244,243,238,0.08);--text:#f4f3ee;--text-muted:rgba(244,243,238,0.42);--accent:#d2a859;--accent-rgb:210,168,89;--ease-out:cubic-bezier(0.22,1,0.36,1);--header-h:58px;--filter-h:46px;--panel-w:560px}*,::after,::before{box-sizing:border-box;margin:0;padding:0}.skip-to-content{position:fixed;top:-100px;left:50%;transform:translateX(-50%);z-index:100000;background:#d2a859;color:#09090f;padding:12px 24px;font-family:var(--font-mono);font-size:12px;letter-spacing:.15em;text-transform:uppercase;text-decoration:none;border-radius:0 0 6px 6px;transition:top .2s ease;font-weight:600}.skip-to-content:focus{top:0;outline:2px solid #d2a859;outline-offset:2px}body,html{width:100%;height:100%;overflow:hidden;background:var(--bg);color:var(--text);font-family:var(--font-body);-webkit-font-smoothing:antialiased}#bg-canvas{position:fixed;inset:0;pointer-events:none;z-index:4}.blog-header{position:fixed;top:0;left:0;right:0;height:var(--header-h);z-index:300;display:flex;align-items:center;justify-content:space-between;padding:0 32px;background:rgba(9,9,15,.8);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom:1px solid var(--border)}.blog-brand{display:flex;align-items:center;gap:9px;text-decoration:none;color:var(--text);transition:opacity .22s}.blog-brand:hover{opacity:.7}.blog-brand-mark{width:24px;height:24px;object-fit:contain;filter:brightness(0) invert(1);opacity:.8}.blog-brand span{font-family:var(--font-display);font-weight:700;font-size:12.5px;letter-spacing:.05em;text-transform:uppercase;opacity:.8}.blog-brand small{font-weight:300;opacity:.5;margin-left:1px}.blog-title-wrap{position:absolute;left:50%;transform:translateX(-50%);display:flex;align-items:baseline;gap:8px;pointer-events:none}.blog-eyebrow{font-family:var(--font-mono);font-size:9px;letter-spacing:.28em;color:var(--accent);text-transform:uppercase;opacity:.75}.blog-name{font-family:var(--font-serif);font-style:italic;font-size:17px;color:var(--text);letter-spacing:.01em}.blog-back{display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-muted);text-decoration:none;transition:color .22s}.blog-back svg{width:13px;height:13px;flex-shrink:0}.blog-back:hover{color:var(--text)}.blog-filters{position:fixed;top:var(--header-h);left:0;right:0;height:var(--filter-h);z-index:260;display:flex;align-items:center;gap:6px;padding:0 32px;background:rgba(9,9,15,.55);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid rgba(244,243,238,.04);overflow-x:auto;scrollbar-width:none}.blog-filters::-webkit-scrollbar{display:none}.blog-filter{flex-shrink:0;font-family:var(--font-mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;padding:5px 13px;border-radius:2px;border:1px solid transparent;background:0 0;color:var(--text-muted);cursor:pointer;transition:color .2s,border-color .2s,background .2s;white-space:nowrap}.blog-filter:hover{color:var(--text);border-color:rgba(244,243,238,.12)}.blog-filter.active{color:var(--accent);border-color:rgba(var(--accent-rgb),.35);background:rgba(var(--accent-rgb),.07)}.blog-search-wrap{flex-shrink:0;position:relative;display:flex;align-items:center;gap:8px}.blog-search-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);pointer-events:none;color:rgba(244,243,238,.28);display:flex;align-items:center;z-index:1;transition:color .22s}.blog-search-wrap:focus-within .blog-search-icon{color:var(--accent)}.blog-search{appearance:none;background:rgba(244,243,238,.05);border:1px solid rgba(244,243,238,.13);border-radius:20px;padding:5px 30px 5px 30px;font-family:var(--font-mono);font-size:9.5px;letter-spacing:.1em;color:var(--text);outline:0;width:168px;transition:width .38s var(--ease-out),border-color .22s,background .22s,box-shadow .22s}.blog-search::placeholder{color:rgba(244,243,238,.22)}.blog-search.has-value,.blog-search:focus{width:232px;border-color:rgba(var(--accent-rgb),.55);background:rgba(var(--accent-rgb),.05);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.07)}.blog-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:0 0;border:none;color:rgba(244,243,238,.3);cursor:pointer;padding:3px;display:none;align-items:center;justify-content:center;border-radius:50%;transition:color .15s,background .15s;line-height:1}.blog-search-clear:hover{color:var(--text);background:rgba(244,243,238,.08)}.blog-search-wrap.has-value .blog-search-clear{display:flex}.blog-search-count{flex-shrink:0;font-family:var(--font-mono);font-size:8.5px;letter-spacing:.08em;color:var(--accent);white-space:nowrap;opacity:0;transform:translateX(-6px);transition:opacity .22s,transform .22s;pointer-events:none}.blog-search-count.visible{opacity:1;transform:translateX(0)}.blog-search-kbd{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-family:var(--font-mono);font-size:8px;letter-spacing:.06em;color:rgba(244,243,238,.22);pointer-events:none;transition:opacity .2s}.blog-search-wrap.has-value .blog-search-kbd,.blog-search-wrap:focus-within .blog-search-kbd{opacity:0}@media (max-width:768px){.blog-search-wrap{margin-left:8px}.blog-search{width:120px}.blog-search.has-value,.blog-search:focus{width:160px}.blog-search-count{display:none}}#graph-blur{position:fixed;top:0;left:0;z-index:8;display:block;pointer-events:none;will-change:filter}#graph-canvas{position:fixed;top:0;left:0;z-index:10;display:block}.graph-tooltip{position:fixed;z-index:400;pointer-events:none;background:rgba(9,9,15,.92);border:1px solid var(--border);border-radius:6px;padding:8px 12px;font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;color:var(--text);max-width:220px;line-height:1.5;opacity:0;transform:translateY(4px);transition:opacity .15s,transform .15s;backdrop-filter:blur(8px)}.graph-tooltip.visible{opacity:1;transform:translateY(0)}.graph-tooltip-cat{font-size:8.5px;letter-spacing:.18em;color:var(--accent);text-transform:uppercase;margin-bottom:3px}.graph-tooltip-title{font-size:11px;color:var(--text);letter-spacing:.02em;font-family:var(--font-body);font-weight:500}.blog-panel{position:fixed;top:calc(var(--header-h) + var(--filter-h));right:0;bottom:0;width:var(--panel-w);z-index:250;background:#0a0a0d;border-left:1px solid var(--border);display:flex;flex-direction:column;transform:translateX(100%);transition:transform .52s var(--ease-out);overflow:hidden}.blog-panel.open{transform:translateX(0)}.blog-panel::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:.6;z-index:2}.blog-panel-resize{position:absolute;left:0;top:0;bottom:0;width:8px;cursor:ew-resize;z-index:20;background:0 0;transition:background .2s}.blog-panel-resize::after{content:'';position:absolute;left:3px;top:50%;transform:translateY(-50%);width:2px;height:36px;border-radius:2px;background:rgba(210,168,89,.5);opacity:0;transition:opacity .2s}.blog-panel-resize.is-dragging::after,.blog-panel-resize:hover::after{opacity:1}.blog-panel-resize.is-dragging,.blog-panel-resize:hover{background:rgba(210,168,89,.06)}.blog-panel-close{position:absolute;top:16px;right:18px;width:32px;height:32px;background:rgba(244,243,238,.05);border:1px solid var(--border);border-radius:50%;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:background .2s,color .2s,border-color .2s;flex-shrink:0}.blog-panel-close:hover{background:rgba(244,243,238,.1);border-color:rgba(244,243,238,.18);color:var(--text)}.blog-panel-close svg{width:12px;height:12px}.blog-panel-mobile-header{display:none;align-items:center;flex-shrink:0;height:52px;padding:0 18px;background:rgba(9,9,15,.95);border-bottom:1px solid var(--border);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}.blog-panel-back{display:flex;align-items:center;gap:8px;background:none;border:none;color:var(--text-muted);font-family:var(--font-mono);font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;padding:0;transition:color .22s}.blog-panel-back:hover{color:var(--text)}.blog-panel-back svg{flex-shrink:0}.blog-panel-inner{flex:1;overflow-y:auto;overflow-x:hidden;padding:44px 30px 48px;scrollbar-width:thin;scrollbar-color:rgba(244,243,238,0.07) transparent}.blog-panel-inner::-webkit-scrollbar{width:3px}.blog-panel-inner::-webkit-scrollbar-thumb{background:rgba(244,243,238,.07);border-radius:3px}.bp-cat{font-family:var(--font-mono);font-size:8.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--accent);margin-bottom:14px;display:flex;align-items:center;gap:8px;opacity:0;animation:bpFadeUp .5s .1s var(--ease-out) forwards}.bp-cat::before{content:'';display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--accent)}.bp-title{font-family:var(--font-display);font-size:clamp(18px, 2.8vw, 26px);font-weight:700;letter-spacing:-.022em;line-height:1.2;color:var(--text);margin-bottom:16px;opacity:0;animation:bpFadeUp .5s .18s var(--ease-out) forwards}.bp-meta{display:flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:9px;letter-spacing:.12em;color:var(--text-muted);text-transform:uppercase;margin-bottom:28px;padding-bottom:20px;border-bottom:1px solid var(--border);opacity:0;animation:bpFadeUp .5s .24s var(--ease-out) forwards}.bp-meta-sep{opacity:.3}.bp-share{position:relative;margin:20px 0;padding:16px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.bp-share-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;background:rgba(var(--accent-rgb),.08);border:1px solid var(--border);border-radius:6px;color:var(--accent);font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:all .2s}.bp-share-btn:hover{background:rgba(var(--accent-rgb),.15);border-color:var(--accent)}.bp-share-btn svg{width:14px;height:14px;flex-shrink:0}.bp-share-menu{position:absolute;top:calc(100% - 8px);left:0;min-width:190px;background:#0f1120;border:1px solid rgba(244,243,238,.12);border-radius:8px;padding:4px;z-index:50;opacity:0;transform:translateY(-6px);pointer-events:none;transition:opacity .18s var(--ease-out),transform .18s var(--ease-out);box-shadow:0 12px 32px rgba(0,0,0,.5)}.bp-share-menu.open{opacity:1;transform:translateY(0);pointer-events:all}.bp-share-option{display:flex;align-items:center;gap:10px;width:100%;padding:9px 13px;background:0 0;border:none;border-radius:5px;color:rgba(244,243,238,.55);font-family:var(--font-mono);font-size:10.5px;letter-spacing:.08em;cursor:pointer;transition:background .15s,color .15s;text-decoration:none;white-space:nowrap}.bp-share-option:hover{background:rgba(244,243,238,.06);color:var(--text)}.bp-share-option svg{width:13px;height:13px;flex-shrink:0;opacity:.65;transition:opacity .15s}.bp-share-option:hover svg{opacity:1}.bp-share-option.copied{color:var(--accent)}.bp-content{font-family:var(--font-body);font-size:13.5px;line-height:1.78;color:rgba(244,243,238,.7);opacity:0;animation:bpFadeUp .5s .32s var(--ease-out) forwards;word-break:break-word;overflow-wrap:break-word}.bp-content p{margin-bottom:16px;word-break:break-word;overflow-wrap:break-word}.bp-content p:last-child{margin-bottom:0}.bp-content strong{color:var(--text);font-weight:600}.bp-content em{font-style:italic;color:rgba(244,243,238,.85)}.bp-content blockquote{margin:22px 0;padding:14px 16px;border-left:2px solid var(--accent);font-family:var(--font-serif);font-style:italic;font-size:14.5px;color:rgba(244,243,238,.88);background:rgba(var(--accent-rgb),.05);border-radius:0 6px 6px 0;line-height:1.65}.bp-images{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin:28px 0}.bp-content-img{width:100%;height:auto;max-height:400px;object-fit:cover;border-radius:8px;border:1px solid var(--border)}.bp-related{margin-top:36px;padding-top:24px;border-top:1px solid var(--border);opacity:0;animation:bpFadeUp .5s .4s var(--ease-out) forwards}.bp-related-label{font-family:var(--font-mono);font-size:8.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--text-muted);margin-bottom:12px}.bp-related-list{display:flex;flex-direction:column;gap:7px}.bp-related-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:background .18s,border-color .18s,transform .18s}.bp-related-item:hover{background:rgba(244,243,238,.07);border-color:rgba(244,243,238,.14);transform:translateX(3px)}.bp-related-dot{width:5px;height:5px;border-radius:50%;background:var(--accent);flex-shrink:0;opacity:.65}.bp-related-title{font-size:12px;color:rgba(244,243,238,.62);line-height:1.35;font-family:var(--font-body)}@keyframes bpFadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.graph-zoom-ui{position:fixed;top:120px;left:28px;z-index:180;display:flex;flex-direction:row;align-items:center;gap:8px;background:rgba(9,9,15,.78);border:1px solid var(--border);border-radius:10px;padding:8px 7px;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);transition:opacity .2s}.graph-zoom-ui:hover{opacity:1!important}.gz-btn{width:26px;height:26px;background:0 0;border:1px solid rgba(244,243,238,.07);border-radius:5px;color:var(--text-muted);font-size:15px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .18s,border-color .18s,background .18s;flex-shrink:0}.gz-btn:hover{color:var(--accent);border-color:rgba(var(--accent-rgb),.35);background:rgba(var(--accent-rgb),.08)}.gz-reset{font-size:13px;margin-top:3px;border-top:1px solid rgba(244,243,238,.05);border-radius:5px}.gz-label{font-family:var(--font-mono);font-size:8.5px;letter-spacing:.06em;color:var(--text-muted);padding:2px 0;min-width:32px;text-align:center}.gz-sep{display:block;width:60%;height:1px;background:rgba(244,243,238,.07);margin:2px auto}.gz-col{display:flex;flex-direction:column;align-items:center;gap:3px}@media (hover:hover){.graph-zoom-ui{opacity:.55}.graph-zoom-ui:hover{opacity:1}}.blog-mobile-list{display:none;position:fixed;top:calc(var(--header-h) + var(--filter-h));left:0;right:0;bottom:0;overflow-y:auto;z-index:10;padding:0 20px 48px;scrollbar-width:thin;scrollbar-color:rgba(244,243,238,0.06) transparent}.bm-article{padding:20px 0;border-bottom:1px solid var(--border);cursor:pointer;transition:padding-left .22s var(--ease-out)}.bm-article:last-child{border-bottom:none}.bm-article:hover{padding-left:6px}.bm-cat{font-family:var(--font-mono);font-size:8px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:7px}.bm-title{font-family:var(--font-display);font-weight:600;font-size:16px;letter-spacing:-.015em;line-height:1.22;color:var(--text);margin-bottom:7px}.bm-excerpt{font-size:12.5px;color:var(--text-muted);line-height:1.65}@media (max-width:768px){:root{--panel-w:100vw;--header-h:52px}#graph-canvas,#graph-blur{display:none!important}.graph-zoom-ui{display:none!important}.blog-mobile-list{display:block}.blog-header{padding:0 18px}.blog-title-wrap{display:none}.blog-filters{padding:0 18px;gap:5px}.blog-panel{top:0;border-left:none;border-top:none;z-index:310}.blog-panel-inner{padding:24px 20px 40px}.blog-panel::before{display:none}.blog-panel-close{display:none}.blog-panel-mobile-header{display:flex}}@media (max-width:400px){.blog-back span{display:none}}.submit-trigger{position:fixed;bottom:28px;left:28px;z-index:180;display:flex;align-items:center;padding:9px 16px;background:rgba(9,9,15,.78);border:1px solid rgba(var(--accent-rgb),.35);border-radius:5px;font-family:var(--font-mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);cursor:pointer;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);transition:background .22s,border-color .22s,transform .22s var(--ease-out);opacity:.7}.submit-trigger:hover{opacity:1;background:rgba(var(--accent-rgb),.12);border-color:rgba(var(--accent-rgb),.6);transform:translateY(-2px)}.submit-trigger-icon{font-size:11px;line-height:1}.submit-overlay{position:fixed;inset:0;z-index:600;background:rgba(9,9,15,.88);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);display:flex;align-items:flex-start;justify-content:center;padding:32px 20px;overflow-y:auto;opacity:0;pointer-events:none;transition:opacity .28s}.submit-overlay.open{opacity:1;pointer-events:all}.submit-panel{width:100%;max-width:620px;background:#0a0a0d;border:1px solid var(--border);border-radius:5px;overflow:hidden;transform:translateY(24px);transition:transform .32s var(--ease-out);position:relative}.submit-overlay.open .submit-panel{transform:translateY(0)}.submit-panel::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:.55}.submit-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:28px 28px 16px;border-bottom:1px solid var(--border)}.submit-eyebrow{font-family:var(--font-mono);font-size:8.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--accent);margin-bottom:6px}.submit-title{font-family:var(--font-display);font-size:20px;font-weight:700;letter-spacing:-.02em}.submit-close{width:32px;height:32px;background:rgba(244,243,238,.05);border:1px solid var(--border);border-radius:50%;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .18s,color .18s}.submit-close svg{width:12px;height:12px}.submit-close:hover{background:rgba(244,243,238,.1);color:var(--text)}.submit-notice{display:flex;align-items:flex-start;gap:10px;margin:0 28px 0;padding:12px 14px;background:rgba(var(--accent-rgb),.06);border:1px solid rgba(var(--accent-rgb),.18);border-radius:6px;font-size:11.5px;color:rgba(244,243,238,.65);line-height:1.55;margin-top:20px}.submit-notice svg{width:14px;height:14px;flex-shrink:0;color:var(--accent);margin-top:1px}.submit-section{padding:20px 28px 0}.submit-section-label{font-family:var(--font-mono);font-size:8.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--text-muted);margin-bottom:12px;display:flex;align-items:center;gap:8px}.submit-badge-opt{font-size:7.5px;padding:2px 7px;background:rgba(244,243,238,.05);border:1px solid rgba(244,243,238,.08);border-radius:3px;letter-spacing:.12em;color:rgba(244,243,238,.28);text-transform:lowercase}.submit-row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.submit-field{display:flex;flex-direction:column;gap:5px;margin-bottom:12px;position:relative}.submit-label{font-size:10.5px;font-family:var(--font-mono);letter-spacing:.1em;color:rgba(244,243,238,.55);display:flex;align-items:center;gap:6px}.submit-required{color:var(--accent)}.submit-counter{margin-left:auto;font-size:9px;color:rgba(244,243,238,.28)}.submit-input{width:100%;background:rgba(244,243,238,.04);border:1px solid rgba(244,243,238,.09);border-radius:6px;padding:10px 12px;font-family:var(--font-body);font-size:13px;color:var(--text);outline:0;transition:border-color .18s,background .18s}.submit-input:focus{border-color:rgba(var(--accent-rgb),.45);background:rgba(244,243,238,.06)}.submit-input::placeholder{color:rgba(244,243,238,.22)}.submit-input-error{border-color:rgba(224,85,85,.55)!important}.submit-select{cursor:pointer;appearance:none;padding-right:32px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='rgba(244,243,238,0.35)' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.submit-select option{background:#0c0e1a}.submit-textarea{resize:vertical;line-height:1.65}.submit-textarea-lg{min-height:180px}.submit-error{min-height:14px;font-family:var(--font-mono);font-size:9.5px;color:#e05555;letter-spacing:.06em}.submit-hint{font-family:var(--font-mono);font-size:9px;color:rgba(244,243,238,.28);letter-spacing:.06em;margin-top:3px}.submit-hint-sm{font-family:var(--font-mono);font-size:9px;color:rgba(244,243,238,.28);letter-spacing:.1em}.submit-tags-preview{display:flex;flex-wrap:wrap;gap:5px;min-height:8px;margin-top:4px}.submit-tag{font-family:var(--font-mono);font-size:9px;letter-spacing:.1em;padding:3px 9px;background:rgba(var(--accent-rgb),.1);border:1px solid rgba(var(--accent-rgb),.28);border-radius:3px;color:var(--accent)}.submit-dropzone{position:relative;border:1px dashed rgba(244,243,238,.14);border-radius:8px;transition:border-color .18s,background .18s;overflow:hidden}.submit-dropzone.drag-over,.submit-dropzone:hover{border-color:rgba(var(--accent-rgb),.45);background:rgba(var(--accent-rgb),.04)}.submit-file-input{position:absolute;inset:0;opacity:0;cursor:pointer;z-index:2}.submit-dropzone-inner{display:flex;flex-direction:column;align-items:center;gap:7px;padding:28px;color:rgba(244,243,238,.38);font-size:12px;text-align:center;pointer-events:none}.submit-dropzone-inner svg{width:28px;height:28px;opacity:.45}.submit-previews{display:flex;gap:10px;flex-wrap:wrap;padding:10px 0 2px}.submit-preview-item{position:relative;width:88px;height:64px;border-radius:6px;overflow:hidden;border:1px solid var(--border)}.submit-preview-item img{width:100%;height:100%;object-fit:cover}.submit-preview-rm{position:absolute;top:3px;right:3px;width:18px;height:18px;background:rgba(9,9,15,.75);border:none;border-radius:50%;color:#e05555;font-size:13px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.submit-preview-rm:hover{background:rgba(224,85,85,.4)}.submit-footer{padding:20px 28px 28px}.submit-btn{width:100%;padding:13px;background:var(--accent);border:none;border-radius:7px;font-family:var(--font-display);font-weight:700;font-size:13.5px;letter-spacing:.01em;color:#09090f;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:opacity .18s,transform .18s}.submit-btn:hover{opacity:.88}.submit-btn:active{transform:scale(.99)}.submit-btn:disabled{opacity:.45;cursor:not-allowed}.submit-btn-loader{display:flex;align-items:center;gap:7px}.submit-spin{width:16px;height:16px;animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.submit-success{padding:60px 28px 52px;text-align:center}.submit-success-icon{font-size:32px;color:var(--accent);margin-bottom:18px;animation:pulse-gold 2.5s ease-in-out infinite}@keyframes pulse-gold{0%,100%{opacity:1;text-shadow:0 0 0 rgba(var(--accent-rgb),0)}50%{opacity:.8;text-shadow:0 0 18px rgba(var(--accent-rgb),.6)}}.submit-success-title{font-family:var(--font-display);font-size:22px;font-weight:700;letter-spacing:-.02em;margin-bottom:12px}.submit-success-text{font-size:13px;color:rgba(244,243,238,.55);line-height:1.7;margin-bottom:28px}.submit-success-close{padding:10px 28px;background:var(--surface);border:1px solid var(--border);border-radius:6px;font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-muted);cursor:pointer;transition:color .18s,border-color .18s}.submit-success-close:hover{color:var(--text);border-color:rgba(244,243,238,.2)}.blog-filter[data-cat=design],.bm-cat[data-cat=design],.bp-cat[data-cat=design]{color:#d2a859}.blog-filter[data-cat=uiux],.bm-cat[data-cat=uiux],.bp-cat[data-cat=uiux]{color:#e8c880}.blog-filter[data-cat=web],.bm-cat[data-cat=web],.bp-cat[data-cat=web]{color:#f4f3ee}.blog-filter[data-cat=tech],.bm-cat[data-cat=tech],.bp-cat[data-cat=tech]{color:#a8c5d4}.blog-filter[data-cat=ia],.bm-cat[data-cat=ia],.bp-cat[data-cat=ia]{color:#c4d4a8}.blog-filter[data-cat=methode],.bm-cat[data-cat=methode],.bp-cat[data-cat=methode]{color:#c4b4e8}.blog-filter[data-cat=sonore],.bm-cat[data-cat=sonore],.bp-cat[data-cat=sonore]{color:#d4a8c8}.submit-related-list{position:absolute;top:100%;left:0;right:0;max-height:280px;overflow-y:auto;background:#0f1120;border:1px solid var(--border);border-top:none;border-radius:0 0 6px 6px;z-index:10;margin-top:-6px;padding:4px;display:none}.submit-related-item{display:flex;align-items:center;gap:10px;padding:9px 12px;background:0 0;border:none;border-radius:4px;color:rgba(244,243,238,.55);font-family:var(--font-body);font-size:12px;cursor:pointer;transition:background .15s,color .15s;text-align:left;width:100%}.submit-related-item:hover{background:rgba(244,243,238,.06);color:var(--text)}.submit-related-dot{width:4px;height:4px;border-radius:50%;background:var(--accent);flex-shrink:0}.submit-related-title{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.submit-related-empty{padding:12px;text-align:center;color:rgba(244,243,238,.28);font-size:11px}.submit-related-selected{display:flex;flex-wrap:wrap;gap:5px;min-height:4px;margin-top:6px}.submit-related-tag{display:flex;align-items:center;gap:5px;padding:5px 9px;background:rgba(var(--accent-rgb),.1);border:1px solid rgba(var(--accent-rgb),.25);border-radius:4px;font-size:11px;color:var(--accent);font-family:var(--font-mono)}.submit-related-remove{background:0 0;border:none;color:var(--accent);cursor:pointer;padding:0;width:16px;height:16px;display:flex;align-items:center;justify-content:center;font-size:14px;line-height:1;opacity:.6;transition:opacity .15s}.submit-related-remove:hover{opacity:1}@media (max-width:640px){.submit-trigger{bottom:20px;left:16px}.submit-overlay{padding:0;align-items:flex-end}.submit-panel{border-radius:5px 5px 0 0;max-height:95vh;overflow-y:auto}.submit-row-2{grid-template-columns:1fr}}/* ── Rangée recherche + « Proposer un article » (mobile uniquement) ── */.blog-actions{display:none}@media (max-width:768px){:root{--actions-h:50px}.blog-actions{display:flex;align-items:center;gap:8px;position:fixed;top:calc(var(--header-h) + var(--filter-h));left:0;right:0;height:var(--actions-h);z-index:255;padding:0 18px;background:rgba(9,9,15,.55);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid rgba(244,243,238,.04)}.blog-actions .blog-search-wrap{flex:1;min-width:0;margin-left:0}.blog-actions .blog-search{width:100%}.blog-actions .blog-search.has-value,.blog-actions .blog-search:focus{width:100%}.blog-actions .submit-trigger{position:static;flex-shrink:0;bottom:auto;left:auto;opacity:1}.blog-mobile-list{top:calc(var(--header-h) + var(--filter-h) + var(--actions-h))}}@media (max-width:768px){#bg-canvas{opacity:.3}}
/* ── Compteur de résultats cliquable + liste de résultats ── */
.blog-search-count.clickable{pointer-events:auto;cursor:pointer;text-decoration:underline;text-decoration-color:rgba(var(--accent-rgb),.4);text-underline-offset:3px;transition:color .18s,text-decoration-color .18s}
.blog-search-count.clickable:hover{color:#e8c880;text-decoration-color:var(--accent)}
.blog-search-count.clickable::after{content:'▾';margin-left:5px;font-size:7px;opacity:.7}
.blog-results{position:fixed;z-index:500;min-width:280px;max-width:380px;max-height:min(60vh,420px);overflow-y:auto;background:#0f1120;border:1px solid rgba(244,243,238,.12);border-radius:8px;padding:5px;box-shadow:0 14px 40px rgba(0,0,0,.55);opacity:0;transform:translateY(-6px);pointer-events:none;transition:opacity .18s var(--ease-out),transform .18s var(--ease-out);scrollbar-width:thin;scrollbar-color:rgba(244,243,238,.1) transparent}
.blog-results.open{opacity:1;transform:translateY(0);pointer-events:auto}
.blog-results::-webkit-scrollbar{width:4px}
.blog-results::-webkit-scrollbar-thumb{background:rgba(244,243,238,.1);border-radius:4px}
.blog-result-item{display:flex;flex-direction:column;align-items:flex-start;gap:3px;width:100%;padding:9px 12px;background:0 0;border:none;border-radius:5px;cursor:pointer;text-align:left;transition:background .14s,transform .14s var(--ease-out)}
.blog-result-item:hover{background:rgba(var(--accent-rgb),.1);transform:translateX(3px)}
.blog-result-cat{font-family:var(--font-mono);font-size:7.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent)}
.blog-result-title{font-family:var(--font-body);font-size:12.5px;line-height:1.35;color:rgba(244,243,238,.78)}
.blog-result-item:hover .blog-result-title{color:var(--text)}
.blog-result-cat[data-cat=design]{color:#d2a859}.blog-result-cat[data-cat=uiux]{color:#e8c880}.blog-result-cat[data-cat=web]{color:#f4f3ee}.blog-result-cat[data-cat=tech]{color:#a8c5d4}.blog-result-cat[data-cat=ia]{color:#c4d4a8}.blog-result-cat[data-cat=methode]{color:#c4b4e8}.blog-result-cat[data-cat=sonore]{color:#d4a8c8}