:root{--font-sans:'Outfit', 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-mono:'Fira Code', 'JetBrains Mono', source-code-pro, Menlo, Monaco, Consolas, "Courier New", monospace;--bg-main:#0b0f19;--bg-header:radial-gradient(circle at top center, #1e293b 0%, #0b0f19 70%);--bg-card:rgba(17, 24, 39, 0.7);--bg-card-hover:rgba(30, 41, 59, 0.7);--bg-modal:#111827;--bg-code:#1e293b;--accent:#3b82f6;--accent-rgb:59, 130, 246;--accent-glow:rgba(59, 130, 246, 0.15);--accent-gradient:linear-gradient(135deg, #3b82f6 0%, #6366f1 100%);--text-primary:#f3f4f6;--text-secondary:#9ca3af;--text-muted:#6b7280;--border:rgba(255, 255, 255, 0.08);--border-hover:rgba(59, 130, 246, 0.3);--creational:#f43f5e;--creational-bg:rgba(244, 63, 94, 0.1);--structural:#3b82f6;--structural-bg:rgba(59, 130, 246, 0.1);--behavioral:#10b981;--behavioral-bg:rgba(16, 185, 129, 0.1);--architectural:#f59e0b;--architectural-bg:rgba(245, 158, 11, 0.1);--microservices:#8b5cf6;--microservices-bg:rgba(139, 92, 246, 0.1);--transition:all 0.25s cubic-bezier(0.4, 0, 0.2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg-main);color:var(--text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--bg-main)}::-webkit-scrollbar-thumb{background:#1e293b;border-radius:5px}::-webkit-scrollbar-thumb:hover{background:#334155}header{background:var(--bg-header);border-bottom:1px solid var(--border);position:relative;padding:1.25rem 0}header::after{content:'';position:absolute;bottom:-1px;left:0;width:100%;height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent)}.header-container{width:90%;max-width:none;margin:0 auto;padding:0 2rem;display:flex;flex-direction:column;align-items:center;text-align:center}.logo{display:flex;align-items:center;font-size:1.4rem;font-weight:800;letter-spacing:-.04em;color:var(--text-primary);text-decoration:none;margin-bottom:.75rem;background:linear-gradient(135deg,#ffffff 50%,#9ca3af 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.logo-dot{width:6px;height:6px;background-color:var(--accent);border-radius:50%;margin-right:6px;display:inline-block;box-shadow:0 0 12px var(--accent)}h1{font-size:1.85rem;font-weight:800;letter-spacing:-.04em;line-height:1.15;margin-bottom:.35rem;max-width:800px}.subtitle{font-size:.95rem;color:var(--text-secondary);margin-bottom:1rem;max-width:650px;font-weight:400}.hero-quote{font-size:1rem;color:var(--text-primary);margin-bottom:1rem;max-width:700px;font-style:italic;font-weight:500;line-height:1.5;border-left:3px solid var(--accent);padding-left:1rem;background:rgba(59,130,246,5%);padding:.75rem 1rem;border-radius:0 8px 8px 0}.hero-description{font-size:.9rem;color:var(--text-secondary);margin-bottom:1rem;max-width:650px;font-weight:400;line-height:1.5}.search-container{width:100%;max-width:650px;margin-bottom:1rem}.search-wrapper{position:relative;width:100%}.search-icon{position:absolute;left:1.1rem;top:50%;transform:translateY(-50%);width:1.1rem;height:1.1rem;color:var(--text-muted);pointer-events:none;transition:var(--transition)}.search-wrapper input{width:100%;padding:.75rem 1.25rem .75rem 3rem;font-size:.95rem;color:var(--text-primary);background:rgba(15,23,42,.6);border:1px solid var(--border);border-radius:10px;outline:none;transition:var(--transition);font-family:var(--font-sans);backdrop-filter:blur(8px)}.search-wrapper input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow);background:rgba(15,23,42,.8)}.search-wrapper:focus-within .search-icon{color:var(--accent)}.tabs{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:center;margin-top:.5rem}.tab-btn{background:0 0;border:1px solid var(--border);color:var(--text-secondary);padding:.4rem .9rem;font-size:.85rem;font-weight:500;border-radius:9999px;cursor:pointer;transition:var(--transition);font-family:var(--font-sans)}.tab-btn:hover{border-color:rgba(255,255,255,.2);color:var(--text-primary);background:rgba(255,255,255,3%)}.tab-btn.active{background:var(--accent-gradient);border-color:transparent;color:#fff;box-shadow:0 2px 10px rgba(59,130,246,.2)}.sub-category-tabs{display:flex;flex-wrap:wrap;gap:.35rem;justify-content:center;margin-top:.5rem;min-height:2rem}.sub-category-tabs.hidden{display:none}.sub-tab-btn{background:0 0;border:1px solid var(--border);color:var(--text-muted);padding:.25rem .8rem;font-size:.8rem;font-weight:500;border-radius:9999px;cursor:pointer;transition:var(--transition);font-family:var(--font-sans)}.sub-tab-btn:hover{border-color:var(--accent);color:var(--text-primary);background:rgba(59,130,246,8%)}.sub-tab-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 1px 6px rgba(59,130,246,.15)}.header-stats{display:flex;justify-content:center;gap:.75rem;margin-top:.5rem;flex-wrap:wrap}.stat-pill{background:rgba(59,130,246,6%);border:1px solid rgba(59,130,246,.15);border-radius:9999px;padding:.25rem .85rem;display:flex;align-items:center;gap:.4rem;font-size:.78rem;transition:var(--transition);cursor:default}.stat-pill:hover{background:rgba(59,130,246,.12);border-color:rgba(59,130,246,.3);transform:translateY(-1px);box-shadow:0 4px 12px rgba(59,130,246,.1)}.stat-pill-number{color:var(--accent);font-weight:700}.stat-pill-label{color:var(--text-secondary);font-weight:500}.categories-section{padding:2rem 1.5rem;width:90%;max-width:none;margin:0 auto}.section-title{font-size:1.35rem;font-weight:600;color:var(--text-primary);text-align:center;margin-bottom:1.25rem}.categories-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.category-card{background:rgba(255,255,255,2%);border:1px solid var(--border);border-radius:12px;padding:1rem;text-decoration:none;transition:var(--transition)}.category-card:hover{transform:translateY(-4px);border-color:var(--accent);box-shadow:0 8px 20px rgba(0,0,0,.15)}.category-icon{font-size:1.75rem;margin-bottom:.35rem}.category-card h3{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:.2rem}.category-card p{color:var(--text-secondary);margin-bottom:.75rem;font-size:.8rem}.category-subcategories{list-style:none;padding:0;margin:0}.category-subcategories li{padding:.2rem 0;color:var(--text-muted);font-size:.75rem;border-left:2px solid var(--border);padding-left:.65rem}.attribution-section{padding:2.5rem 1.5rem;max-width:1e3px;margin:0 auto}.attribution-description{text-align:center;color:var(--text-secondary);margin-bottom:1.5rem}.sources-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.25rem}.source-item{padding:1.25rem;background:rgba(255,255,255,2%);border:1px solid var(--border);border-radius:12px}.source-item h4{font-size:1rem;font-weight:600;color:var(--accent);margin-bottom:.5rem}.source-item p{color:var(--text-secondary);font-size:.85rem;line-height:1.45}.playbooks-section{padding:2.5rem 1.5rem;width:90%;max-width:1e3px;margin:0 auto}.playbooks-description{text-align:center;color:var(--text-secondary);margin-bottom:1.5rem;font-size:.9rem;max-width:700px;margin-left:auto;margin-right:auto}.playbooks-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.25rem}.playbook-card{background:rgba(255,255,255,2%);border:1px solid var(--border);border-radius:12px;padding:1.5rem;text-decoration:none;transition:var(--transition);display:flex;flex-direction:column;position:relative;overflow:hidden}.playbook-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--accent),#8b5cf6);transform:scaleX(0);transition:transform .3s ease}.playbook-card:hover{transform:translateY(-4px);border-color:var(--accent);box-shadow:0 8px 24px rgba(59,130,246,.15)}.playbook-card:hover::before{transform:scaleX(1)}.playbook-icon{font-size:2rem;margin-bottom:.75rem}.playbook-card h3{font-size:1.15rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem;letter-spacing:-.02em}.playbook-card p{color:var(--text-secondary);font-size:.85rem;line-height:1.5;margin-bottom:1rem;flex-grow:1}.playbook-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.playbook-tag{display:inline-block;padding:.25rem .6rem;font-size:.7rem;font-weight:600;border-radius:9999px;background:rgba(139,92,246,.1);color:#a78bfa;border:1px solid rgba(139,92,246,.2);text-transform:uppercase;letter-spacing:.05em}.playbook-footer{display:flex;justify-content:space-between;align-items:center;padding-top:.75rem;border-top:1px solid var(--border);margin-top:auto}.playbook-code-location{font-size:.75rem;color:var(--text-muted);font-family:var(--font-mono);background:rgba(0,0,0,.2);padding:.2rem .5rem;border-radius:4px}.playbook-link-text{font-size:.8rem;font-weight:600;color:var(--accent);transition:var(--transition);display:inline-flex;align-items:center;text-decoration:none;padding:.3rem}.playbook-link-text svg{transition:var(--transition)}.playbook-card:hover .playbook-link-text{color:#fff;transform:translateX(3px)}.playbook-card:hover .playbook-link-text svg{transform:scale(1.1)}.playbook-link-actions{display:flex;align-items:center;gap:.5rem}.playbook-copy-btn{font-size:.8rem;font-weight:600;color:var(--text-secondary);transition:var(--transition);display:inline-flex;align-items:center;text-decoration:none;padding:.3rem;background:0 0;border:none;cursor:pointer;border-radius:4px}.playbook-copy-btn svg{transition:var(--transition)}.playbook-copy-btn:hover{color:var(--accent);background:rgba(59,130,246,.1)}.playbook-copy-btn:hover svg{transform:scale(1.1)}.playbook-copy-btn.copied{color:#10b981}.playbook-copy-btn.copied svg{transform:scale(1.1)}.playbooks-navigation{display:flex;justify-content:center;align-items:center;gap:1.5rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border)}.playbook-nav-btn{display:flex;align-items:center;gap:.5rem;background:rgba(255,255,255,2%);border:1px solid var(--border);color:var(--text-secondary);padding:.6rem 1rem;border-radius:8px;cursor:pointer;transition:var(--transition);font-family:var(--font-sans);font-size:.85rem;font-weight:500}.playbook-nav-btn:hover:not(:disabled){background:rgba(59,130,246,.1);border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}.playbook-nav-btn:disabled{opacity:.3;cursor:not-allowed}.playbook-nav-btn svg{transition:var(--transition)}.playbook-nav-btn:hover:not(:disabled) svg{transform:scale(1.1)}.playbook-page-indicator{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.9rem;font-weight:500}.playbook-page-divider{color:var(--text-muted)}#playbook-current-page{color:var(--accent);font-weight:600}.playbook-card{transition:var(--transition);display:none}.playbook-card.hidden{display:none}.playbook-card.visible{display:flex;animation:fadeIn .3s ease}@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.stats-grid{grid-template-columns:1fr}.about-title{font-size:2rem}.categories-grid{grid-template-columns:1fr}}main{width:90%;max-width:none;margin:0 auto;padding:2rem 1.5rem}main.list-main{max-width:1600px;width:95%;padding:1.25rem 1.5rem}.grid{display:grid;grid-template-columns:1fr;gap:.85rem;transition:var(--transition)}@media(min-width:640px){.grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:900px){.grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1200px){.grid{grid-template-columns:repeat(4,1fr)}}@media(min-width:1600px){.grid{grid-template-columns:repeat(5,1fr)}}.card{text-decoration:none;color:inherit;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:.85rem 1rem;display:flex;flex-direction:column;justify-content:space-between;transition:var(--transition);cursor:pointer;backdrop-filter:blur(12px);position:relative;overflow:hidden}.card::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px;background:0 0;transition:var(--transition)}.card:hover{background:var(--bg-card-hover);border-color:var(--border-hover);transform:translateY(-4px);box-shadow:0 8px 20px rgba(0,0,0,.2)}.card[data-category=creational]:hover::before{background:var(--creational)}.card[data-category=structural]:hover::before{background:var(--structural)}.card[data-category=behavioral]:hover::before{background:var(--behavioral)}.card[data-category=architectural]:hover::before{background:var(--architectural)}.top-category-badge.microservices{background:rgba(139,92,246,.15);color:var(--microservices);border:1px solid rgba(139,92,246,.3)}.card-header{margin-bottom:.5rem;display:flex;flex-wrap:wrap;gap:.35rem;align-items:center}.top-category-badge{display:inline-block;padding:.15rem .5rem;font-size:.65rem;font-weight:600;border-radius:9999px;text-transform:uppercase;letter-spacing:.05em;background:rgba(59,130,246,.15);color:var(--accent);border:1px solid rgba(59,130,246,.3)}.source-badge{display:inline-flex;align-items:center;justify-content:center;padding:.2rem;font-size:.6rem;font-weight:500;border-radius:4px;background:rgba(16,185,129,.15);color:#10b981;border:1px solid rgba(16,185,129,.3);cursor:pointer;transition:var(--transition);text-decoration:none}.source-badge:hover{background:rgba(16,185,129,.25);border-color:rgba(16,185,129,.5);transform:translateY(-1px);color:#10b981}.source-badge svg{display:block}.subcategory-badge{display:inline-block;padding:.15rem .5rem;font-size:.65rem;font-weight:500;border-radius:9999px;background:rgba(245,158,11,.15);color:#f59e0b;border:1px solid rgba(245,158,11,.3)}.category-badge{display:inline-block;padding:.15rem .45rem;font-size:.65rem;font-weight:600;border-radius:9999px;text-transform:uppercase;letter-spacing:.05em}.category-badge.creational{color:var(--creational);background:var(--creational-bg)}.category-badge.structural{color:var(--structural);background:var(--structural-bg)}.category-badge.behavioral{color:var(--behavioral);background:var(--behavioral-bg)}.category-badge.architectural{color:var(--architectural);background:var(--architectural-bg)}.card h3{font-size:1.05rem;font-weight:700;margin-bottom:.35rem;color:var(--text-primary);letter-spacing:-.02em}.card p{font-size:.82rem;color:var(--text-secondary);margin-bottom:.75rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.4}.card-footer{display:flex;justify-content:flex-start;align-items:center;margin-top:auto}.explore-link{font-size:.75rem;font-weight:600;color:var(--accent);transition:var(--transition)}.card:hover .explore-link{color:#fff;transform:translateX(3px)}.hidden{display:none!important}#no-results{width:100%;display:flex;justify-content:center;padding:5rem 2rem}.no-results-content{display:flex;flex-direction:column;align-items:center;text-align:center;max-width:400px}.no-results-icon{width:4rem;height:4rem;color:var(--text-muted);margin-bottom:1.5rem}.no-results-content p{font-size:1.15rem;color:var(--text-secondary);margin-bottom:1.5rem}#clear-search-btn{background:rgba(255,255,255,5%);border:1px solid var(--border);color:var(--text-primary);padding:.65rem 1.25rem;border-radius:8px;cursor:pointer;font-weight:500;transition:var(--transition);font-family:var(--font-sans)}#clear-search-btn:hover{background:rgba(255,255,255,.1);border-color:var(--text-muted)}footer{border-top:1px solid var(--border);padding:1.5rem 0;margin-top:3rem;background:rgba(11,15,25,.9)}.footer-container{width:90%;max-width:none;margin:0 auto;padding:0 2rem;text-align:center;color:var(--text-muted);font-size:.9rem}.modal{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1.5rem;opacity:0;pointer-events:none;transition:opacity .3s ease}.modal:not(.hidden){opacity:1;pointer-events:auto}.modal-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(3,7,18,.75);backdrop-filter:blur(12px)}.single-pattern-content{width:90%;max-width:none;background-color:var(--bg-modal,#111827);border:1px solid rgba(255,255,255,8%);border-radius:16px;padding:40px;box-shadow:0 20px 40px rgba(0,0,0,.3)}.modal-container{position:relative;background:var(--bg-modal);border:1px solid var(--border);border-radius:20px;width:100%;max-width:850px;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px -12px rgba(0,0,0,.5);z-index:1001;transform:scale(.95)translateY(20px);transition:transform .3s cubic-bezier(.34,1.56,.64,1)}.modal:not(.hidden) .modal-container{transform:scale(1)translateY(0)}.modal-close{position:absolute;top:1.25rem;right:1.25rem;background:rgba(255,255,255,5%);border:1px solid var(--border);border-radius:50%;width:2.25rem;height:2.25rem;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);transition:var(--transition);z-index:10}.modal-close:hover{background:rgba(255,255,255,.1);color:var(--text-primary);transform:rotate(90deg)}.modal-close svg{width:1.25rem;height:1.25rem}.modal-content{padding:1.25rem}.modal-header{margin-bottom:.85rem;border-bottom:1px solid var(--border);padding-bottom:.75rem}.modal-header .category-badge{margin-bottom:.4rem}.modal-header h2{font-size:1.4rem;font-weight:800;letter-spacing:-.03em;color:var(--text-primary);margin-bottom:.2rem}.modal-tagline{font-size:.85rem;color:var(--text-secondary);max-width:800px}.modal-tabs{display:flex;gap:1.5rem;border-bottom:1px solid var(--border);margin-bottom:1rem;padding-bottom:.25rem}.modal-tab-btn{background:0 0;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);padding:.5rem .25rem;font-size:.85rem;font-weight:600;cursor:pointer;transition:var(--transition);display:flex;align-items:center;gap:.4rem;font-family:var(--font-sans)}.modal-tab-btn svg{color:var(--text-muted);transition:var(--transition)}.modal-tab-btn:hover{color:var(--text-primary)}.modal-tab-btn:hover svg{color:var(--text-secondary)}.modal-tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.modal-tab-btn.active svg{color:var(--accent)}.modal-tab-content{display:none;width:100%}.modal-tab-content.active{display:flex;flex-direction:column}.modal-body{position:relative;width:100%;min-height:250px}.modal-details-col{display:flex;flex-direction:column;gap:1rem}.modal-section h4{font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:.35rem}.modal-section p{color:var(--text-secondary);font-size:.85rem;line-height:1.4}.use-case-box{background:rgba(255,255,255,2%);border-left:3px solid var(--accent);padding:.65rem;border-radius:0 8px 8px 0}.use-case-box p{font-size:.85rem;color:var(--text-primary)}.source-box{background:rgba(59,130,246,5%);border:1px solid rgba(59,130,246,.2);padding:.5rem .75rem;border-radius:8px;margin-top:.25rem}.source-link{color:var(--accent);text-decoration:none;font-weight:500;display:inline-flex;align-items:center;gap:.5rem;transition:var(--transition);font-size:.8rem}.source-link:hover{color:var(--text-primary);text-decoration:none;transform:translateX(2px)}.pros-cons-grid{display:grid;grid-template-columns:1fr;gap:.75rem}@media(min-width:640px){.pros-cons-grid{grid-template-columns:repeat(2,1fr)}}.pros-box,.cons-box{background:rgba(255,255,255,.015);border:1px solid var(--border);border-radius:8px;padding:.65rem}.pros-box h5,.cons-box h5{font-size:.8rem;font-weight:700;text-transform:uppercase;margin-bottom:.35rem}.pros-box h5{color:var(--behavioral)}.cons-box h5{color:var(--creational)}.pros-box ul,.cons-box ul{list-style:none;display:flex;flex-direction:column;gap:.3rem}.pros-box li,.cons-box li{font-size:.78rem;color:var(--text-secondary);position:relative;padding-left:1rem}.pros-box li::before{content:'✓';position:absolute;left:0;color:var(--behavioral);font-weight:700}.cons-box li::before{content:'✗';position:absolute;left:0;color:var(--creational);font-weight:700}.modal-code-col{display:flex;flex-direction:column;max-height:100%}.code-header{background:#111827;border:1px solid var(--border);border-bottom:none;border-radius:12px 12px 0 0;padding:.5rem 1rem;display:flex;justify-content:space-between;align-items:center;font-size:.8rem;color:var(--text-secondary)}#copy-code-btn{background:rgba(255,255,255,5%);border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);padding:.25rem .6rem;display:flex;align-items:center;gap:.4rem;cursor:pointer;font-size:.75rem;font-family:var(--font-sans);transition:var(--transition)}#copy-code-btn:hover{background:rgba(255,255,255,.1);color:var(--text-primary)}.modal-code-col pre{margin:0;background:var(--bg-code)!important;border:1px solid var(--border);border-radius:0 0 12px 12px;padding:.75rem!important;overflow:auto;font-family:var(--font-mono);font-size:.78rem;line-height:1.35;flex-grow:1;max-height:60vh}.modal-code-col code{font-family:var(--font-mono)!important;background:0 0!important;padding:0!important;border-radius:0!important}pre[class*=language-]{background:var(--bg-code)}.search-wrapper{position:relative;width:100%;display:flex;align-items:center}.search-kbd{position:absolute;right:1.1rem;top:50%;transform:translateY(-50%);background:rgba(255,255,255,8%);border:1px solid rgba(255,255,255,.15);border-radius:4px;padding:.05rem .35rem;font-size:.7rem;color:var(--text-muted);font-family:var(--font-sans);pointer-events:none;transition:var(--transition)}#search-bar:focus~.search-kbd,#search-bar:not(:placeholder-shown)~.search-kbd,#home-search-bar:focus~.search-kbd,#home-search-bar:not(:placeholder-shown)~.search-kbd{opacity:0;transform:translateY(-50%)scale(.8)}.search-clear-btn{position:absolute;right:1.1rem;top:50%;transform:translateY(-50%);background:0 0;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;transition:var(--transition);border-radius:50%}.search-clear-btn:hover{color:var(--text-primary);background:rgba(255,255,255,.1)}.search-clear-btn.hidden{display:none}.top-level-tabs .tab-btn{text-decoration:none;display:inline-flex;align-items:center;justify-content:center}.sub-category-tabs-wrapper{position:relative;width:100%;max-width:900px;margin:.75rem auto 0}.sub-category-tabs{display:flex;flex-wrap:nowrap!important;gap:.4rem;overflow-x:auto;padding:.25rem 1.25rem;scrollbar-width:none;-ms-overflow-style:none;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.sub-category-tabs::-webkit-scrollbar{display:none}.sub-category-tabs-fade-left,.sub-category-tabs-fade-right{position:absolute;top:0;bottom:0;width:2rem;pointer-events:none;z-index:2;transition:opacity .3s ease}.sub-category-tabs-fade-left{left:0;background:linear-gradient(90deg,#0b0f19 0%,rgba(11,15,25,0) 100%);opacity:0}.sub-category-tabs-fade-right{right:0;background:linear-gradient(-90deg,#0b0f19 0%,rgba(11,15,25,0) 100%);opacity:0}.category-card.featured-card{background:linear-gradient(135deg,rgba(59,130,246,8%) 0%,rgba(99,102,241,8%) 100%);border:1px solid rgba(59,130,246,.2);box-shadow:0 4px 20px rgba(59,130,246,3%)}.category-card.featured-card:hover{border-color:var(--accent);box-shadow:0 12px 30px rgba(59,130,246,.15)}.top-category-badge.agentic_ai{background:rgba(6,182,212,.15);color:#06b6d4;border:1px solid rgba(6,182,212,.3)}.top-category-badge.data_science{background:rgba(20,184,166,.15);color:#14b8a6;border:1px solid rgba(20,184,166,.3)}.top-category-badge.language_models{background:rgba(236,72,153,.15);color:#ec4899;border:1px solid rgba(236,72,153,.3)}.top-category-badge.machine_learning{background:rgba(245,158,11,.15);color:#f59e0b;border:1px solid rgba(245,158,11,.3)}.top-category-badge.microservices{background:rgba(139,92,246,.15);color:#8b5cf6;border:1px solid rgba(139,92,246,.3)}.top-category-badge.software_design{background:rgba(59,130,246,.15);color:#3b82f6;border:1px solid rgba(59,130,246,.3)}.card[data-top-category=agentic_ai]::before{background:#06b6d4}.card[data-top-category=data_science]::before{background:#14b8a6}.card[data-top-category=language_models]::before{background:#ec4899}.card[data-top-category=machine_learning]::before{background:#f59e0b}.card[data-top-category=microservices]::before{background:#8b5cf6}.card[data-top-category=software_design]::before{background:#3b82f6}.card[data-top-category=agentic_ai]:hover{border-color:rgba(6,182,212,.4);box-shadow:0 12px 30px rgba(6,182,212,.15)}.card[data-top-category=data_science]:hover{border-color:rgba(20,184,166,.4);box-shadow:0 12px 30px rgba(20,184,166,.15)}.card[data-top-category=language_models]:hover{border-color:rgba(236,72,153,.4);box-shadow:0 12px 30px rgba(236,72,153,.15)}.card[data-top-category=machine_learning]:hover{border-color:rgba(245,158,11,.4);box-shadow:0 12px 30px rgba(245,158,11,.15)}.card[data-top-category=microservices]:hover{border-color:rgba(139,92,246,.4);box-shadow:0 12px 30px rgba(139,92,246,.15)}.card[data-top-category=software_design]:hover{border-color:rgba(59,130,246,.4);box-shadow:0 12px 30px rgba(59,130,246,.15)}.no-results-buttons{display:flex;gap:1rem;margin-top:1.5rem}#search-global-btn{background:var(--accent-gradient);border:none;color:#fff;padding:.65rem 1.25rem;border-radius:8px;cursor:pointer;font-weight:600;transition:var(--transition);font-family:var(--font-sans);box-shadow:0 4px 14px rgba(59,130,246,.3)}#search-global-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(59,130,246,.4)}#search-global-btn.hidden{display:none}.modal-navigation-footer{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--border);padding-top:.75rem;margin-top:1rem}.modal-navigation-footer .nav-btn{display:inline-flex;align-items:center;gap:.4rem;background:rgba(255,255,255,3%);border:1px solid var(--border);color:var(--text-primary);padding:.35rem .75rem;font-size:.75rem;font-weight:500;border-radius:6px;cursor:pointer;transition:var(--transition);font-family:var(--font-sans)}.modal-navigation-footer .nav-btn:hover:not(.disabled):not([disabled]){background:rgba(255,255,255,8%);border-color:rgba(255,255,255,.2);transform:translateY(-1px)}.modal-navigation-footer .nav-btn.disabled,.modal-navigation-footer .nav-btn[disabled]{opacity:.3;cursor:not-allowed;pointer-events:none}.modal-navigation-footer .nav-position-indicator{font-size:.75rem;color:var(--text-muted);font-weight:500}.modal-navigation-footer #modal-current-index{color:var(--text-primary);font-weight:600}body.workspace-body{height:100vh;overflow:hidden;display:flex;flex-direction:column;background-color:#070a13}.app-header{height:52px;background:rgba(11,15,25,.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;padding:0 1.25rem;flex-shrink:0;z-index:100}.header-left,.header-right{display:flex;align-items:center;gap:.85rem}.header-left .logo{margin-bottom:0;font-size:1.15rem}.divider-v{width:1px;height:16px;background:var(--border)}.app-tagline{font-size:.78rem;color:var(--text-muted);font-weight:500}.header-stats-minimal{display:flex;gap:.5rem}.stat-pill-mini{background:rgba(59,130,246,5%);border:1px solid rgba(59,130,246,.15);border-radius:6px;padding:.15rem .5rem;display:flex;align-items:center;gap:.25rem;font-size:.7rem}.stat-num{color:var(--accent);font-weight:700}.stat-lbl{color:var(--text-muted)}.github-link{color:var(--text-secondary);display:flex;align-items:center;justify-content:center;padding:.35rem;border-radius:6px;border:1px solid transparent;transition:var(--transition)}.github-link:hover{background:rgba(255,255,255,5%);border-color:var(--border);color:var(--text-primary)}.app-workspace{flex:1;display:flex;overflow:hidden;height:calc(100vh - 52px);position:relative}.sidebar-pane{width:250px;background-color:#090d16;border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;transition:var(--transition)}.sidebar-scrollable{flex:1;overflow-y:auto;padding:.85rem .5rem;display:flex;flex-direction:column;gap:1.25rem}.tree-group{display:flex;flex-direction:column;gap:.25rem}.tree-section-heading{font-size:.68rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding:0 .65rem .35rem}.tree-item,.tree-folder-header{display:flex;align-items:center;padding:.4rem .65rem;font-size:.82rem;color:var(--text-secondary);border-radius:6px;cursor:pointer;transition:var(--transition);user-select:none;position:relative;gap:.5rem}.tree-item:hover,.tree-folder-header:hover{background:rgba(255,255,255,2%);color:var(--text-primary)}.tree-item.active,.tree-folder.active>.tree-folder-header{background:rgba(59,130,246,8%);color:#fff;font-weight:500}.tree-item.active::before,.tree-folder.active>.tree-folder-header::before{content:'';position:absolute;left:0;top:6px;bottom:6px;width:3px;background:var(--accent);border-radius:0 4px 4px 0}.tree-arrow{font-size:.6rem;color:var(--text-muted);transition:transform .2s ease;display:inline-block;width:10px}.tree-folder.expanded>.tree-folder-header .tree-arrow{transform:rotate(90deg);color:var(--text-secondary)}.tree-item-icon{font-size:.95rem}.tree-item-label{flex-grow:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tree-item-count{font-size:.65rem;font-family:var(--font-mono);color:var(--text-muted);background:rgba(255,255,255,4%);padding:.05rem .35rem;border-radius:4px;border:1px solid rgba(255,255,255,2%)}.tree-item.active .tree-item-count,.tree-folder.active>.tree-folder-header .tree-item-count{color:var(--accent);background:rgba(59,130,246,.15);border-color:rgba(59,130,246,.1)}.tree-sub-items{display:flex;flex-direction:column;padding-left:1.65rem;margin-top:.15rem;gap:.15rem;position:relative}.tree-sub-items::after{content:'';position:absolute;left:18px;top:0;bottom:10px;width:1px;background:var(--border)}.tree-sub-item{display:flex;align-items:center;padding:.3rem .5rem;font-size:.76rem;color:var(--text-muted);border-radius:4px;cursor:pointer;transition:var(--transition);position:relative}.tree-sub-item::before{content:'';position:absolute;left:-7px;top:10px;width:6px;height:1px;background:var(--border)}.tree-sub-item:hover{color:var(--text-primary);background:rgba(255,255,255,.015)}.tree-sub-item.active{color:var(--accent);font-weight:500}.list-pane{flex:1;background-color:#0b0f19;border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;transition:flex .2s ease,width .2s ease}.list-pane-header{padding:.85rem 1rem;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:.65rem;background:rgba(11,15,25,.4)}.mobile-sidebar-toggle{display:none}.list-pane .search-container{width:100%;margin-bottom:0}.list-pane .search-wrapper input{padding:.55rem 1rem .55rem 2.5rem;font-size:.85rem;border-radius:6px;background:rgba(15,23,42,.4)}.list-pane .search-icon{left:.85rem;width:.95rem;height:.95rem}.list-pane .search-kbd{right:.85rem;font-size:.65rem;border-radius:3px;padding:0 .25rem}.filter-status-row{display:flex;justify-content:space-between;align-items:center}.filter-info{font-size:.72rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pattern-count-badge{background:rgba(255,255,255,4%);border:1px solid var(--border);border-radius:12px;padding:.1rem .45rem;font-size:.65rem;font-family:var(--font-mono);font-weight:500;color:var(--text-secondary)}.list-pane-scrollable{flex:1;overflow-y:auto;padding:.65rem}.list-pane-scrollable .grid{display:flex;flex-direction:column;gap:.4rem}.list-pane-scrollable .card{background:rgba(17,24,39,.35);border:1px solid var(--border);border-radius:8px;padding:.55rem .75rem;display:flex;flex-direction:row;gap:.65rem;position:relative;cursor:pointer;transition:var(--transition);overflow:hidden;backdrop-filter:none;align-items:stretch}.list-pane-scrollable .card::before{display:none}.card-indicator{width:3px;border-radius:4px;flex-shrink:0;background:rgba(255,255,255,.15)}.card-indicator.agentic_ai{background:#06b6d4}.card-indicator.cloud{background:#3b82f6}.card-indicator.data_science{background:#14b8a6}.card-indicator.language_models{background:#ec4899}.card-indicator.machine_learning{background:#f59e0b}.card-indicator.microservices{background:#8b5cf6}.card-indicator.software_design{background:#3b82f6}.card-indicator.integration{background:#10b981}.card-body{flex-grow:1;display:flex;flex-direction:column;gap:.15rem;min-width:0}.card-meta{display:flex;flex-wrap:wrap;gap:.25rem;align-items:center;margin-bottom:.15rem}.list-pane-scrollable .card-meta .top-category-badge{padding:.05rem .35rem;font-size:.58rem;border-radius:4px}.list-pane-scrollable .card-meta .subcategory-badge{padding:.05rem .35rem;font-size:.58rem;border-radius:4px;max-width:130px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-pane-scrollable .card h3{font-size:.88rem;font-weight:600;margin-bottom:0;letter-spacing:-.01em;color:var(--text-primary)}.list-pane-scrollable .card p{font-size:.75rem;color:var(--text-muted);margin-bottom:0;line-height:1.35;-webkit-line-clamp:1}.list-pane-scrollable .card:hover{background:rgba(30,41,59,.4);border-color:rgba(255,255,255,.15);transform:translateY(0)}.list-pane-scrollable .card.selected{background:rgba(30,41,59,.85);border-color:rgba(59,130,246,.4);box-shadow:0 4px 12px rgba(0,0,0,.15)}.list-pane-scrollable .card.selected h3{color:#fff}.list-pane-scrollable .card.selected p{color:var(--text-secondary)}.detail-pane{flex:1;overflow-y:auto;background-color:#070a13;position:relative;display:flex;flex-direction:column}.detail-overlay{display:none}.detail-close{display:none}@media(min-width:1025px){.app-workspace:not(.has-selection) .detail-pane{display:none!important}.app-workspace.has-selection .list-pane{flex:0 0 380px!important;width:380px!important}.app-workspace:not(.has-selection) .list-pane-scrollable .grid{display:grid!important;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))!important;gap:.65rem!important}.app-workspace.has-selection .list-pane-scrollable .grid{display:grid!important;grid-template-columns:1fr!important;gap:.4rem!important}.app-workspace.has-selection .detail-close{display:inline-flex;align-items:center;gap:.4rem;background:rgba(255,255,255,3%);border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);padding:.35rem .75rem;font-size:.75rem;font-family:var(--font-sans);font-weight:500;cursor:pointer;transition:var(--transition);margin-bottom:1.25rem;align-self:flex-start}.app-workspace.has-selection .detail-close:hover{background:rgba(255,255,255,8%);color:var(--text-primary)}}.detail-empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;max-width:500px;margin:auto}.empty-state-visual{position:relative;width:60px;height:60px;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem}.empty-icon{font-size:1.85rem;z-index:1}.pulse-ring{position:absolute;width:100%;height:100%;border-radius:50%;background:rgba(59,130,246,4%);border:1px solid rgba(59,130,246,.1);animation:pulseGlow 3s infinite ease-in-out}@keyframes pulseGlow{0%{transform:scale(.9);opacity:.6}50%{transform:scale(1.15);opacity:1;border-color:rgba(59,130,246,.25);background:rgba(59,130,246,8%)}100%{transform:scale(.9);opacity:.6}}.detail-empty-state h3{font-size:1.1rem;font-weight:600;margin-bottom:.5rem;color:var(--text-primary)}.detail-empty-state p{font-size:.82rem;color:var(--text-muted);line-height:1.5;margin-bottom:1.5rem}.empty-shortcuts{display:flex;flex-direction:column;gap:.45rem;width:100%;align-items:center}.shortcut-tip{display:flex;align-items:center;gap:.5rem;font-size:.72rem;color:var(--text-muted)}.shortcut-tip kbd{background:rgba(255,255,255,5%);border:1px solid rgba(255,255,255,.12);border-radius:4px;padding:.05rem .35rem;font-size:.68rem;font-family:var(--font-mono);color:var(--text-secondary)}.detail-pane-content{padding:1.5rem 2rem;width:100%;max-width:900px;margin:0 auto;display:flex;flex-direction:column;min-height:100%;animation:contentFadeIn .2s ease-out}@keyframes contentFadeIn{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.detail-pane-content .modal-header{border-bottom:1px solid var(--border);padding-bottom:.85rem;margin-bottom:1rem}.detail-pane-content .modal-header h2{font-size:1.6rem;font-weight:800;letter-spacing:-.03em;margin-bottom:.35rem;background:linear-gradient(135deg,#ffffff 60%,#9ca3af 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.detail-pane-content .modal-tagline{font-size:.9rem;color:var(--text-secondary);line-height:1.45}.detail-pane-content .modal-tabs{margin-bottom:1.25rem}.detail-pane-content .modal-body{flex-grow:1}.detail-pane-content .modal-section{margin-bottom:1.25rem}.detail-pane-content .modal-code-col pre{max-height:calc(100vh - 250px)}.sidebar-scrollable::-webkit-scrollbar,.list-pane-scrollable::-webkit-scrollbar,.detail-pane::-webkit-scrollbar{width:6px;height:6px}.sidebar-scrollable::-webkit-scrollbar-track,.list-pane-scrollable::-webkit-scrollbar-track,.detail-pane::-webkit-scrollbar-track{background:0 0}.sidebar-scrollable::-webkit-scrollbar-thumb,.list-pane-scrollable::-webkit-scrollbar-thumb,.detail-pane::-webkit-scrollbar-thumb{background:rgba(255,255,255,5%);border-radius:10px}.sidebar-scrollable::-webkit-scrollbar-thumb:hover,.list-pane-scrollable::-webkit-scrollbar-thumb:hover,.detail-pane::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.12)}@media(max-width:1024px){.sidebar-pane{position:absolute;left:-250px;top:0;bottom:0;z-index:110;height:100%;box-shadow:15px 0 30px rgba(0,0,0,.4)}.sidebar-pane.mobile-open{left:0}.list-pane{flex:1;width:100%}.mobile-sidebar-toggle{display:inline-flex;align-items:center;gap:.5rem;background:rgba(255,255,255,3%);border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);padding:.35rem .75rem;font-size:.75rem;font-family:var(--font-sans);font-weight:500;cursor:pointer;align-self:flex-start;transition:var(--transition);margin-bottom:.25rem}.mobile-sidebar-toggle:hover{background:rgba(255,255,255,8%);color:var(--text-primary)}.detail-pane{position:absolute;top:0;right:-100%;width:100%;height:100%;z-index:120;transition:right .3s cubic-bezier(.4,0,.2,1);box-shadow:-10px 0 30px rgba(0,0,0,.3)}.detail-pane.mobile-open{right:0}.detail-overlay{display:block;position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(3,7,18,.5);backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:opacity .3s ease;z-index:119}.detail-pane.mobile-open~.detail-overlay{opacity:1;pointer-events:auto}.detail-empty-state{display:none!important}.detail-pane-content{background-color:#070a13;padding:1rem 1.25rem;z-index:121;position:relative}.detail-close{display:inline-flex;align-items:center;gap:.4rem;background:rgba(255,255,255,3%);border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);padding:.35rem .75rem;font-size:.75rem;font-family:var(--font-sans);font-weight:500;cursor:pointer;align-self:flex-start;margin-bottom:1.25rem;transition:var(--transition)}.detail-close:hover{background:rgba(255,255,255,8%);color:var(--text-primary)}.sidebar-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(3,7,18,.5);backdrop-filter:blur(4px);z-index:109;animation:fadeIn .25s ease-out}}.buckets-section{padding:2rem 1.5rem;width:90%;max-width:none;margin:0 auto}.buckets-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:1.5rem;margin-bottom:2rem}.bucket-card{background:rgba(255,255,255,3%);border:1px solid var(--border);border-radius:16px;padding:1.5rem;transition:var(--transition)}.bucket-card:hover{border-color:var(--accent);box-shadow:0 8px 24px rgba(0,0,0,.2)}.bucket-icon{font-size:2.5rem;margin-bottom:.75rem}.bucket-card h3{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.bucket-card p{color:var(--text-secondary);margin-bottom:1rem;font-size:.9rem;line-height:1.5}.bucket-highlights{list-style:none;padding:0;margin:0 0 1.5rem}.bucket-highlights li{padding:.3rem 0;color:var(--text-muted);font-size:.85rem;border-left:2px solid var(--accent);padding-left:.75rem}.bucket-subcategories{border-top:1px solid var(--border);padding-top:1.5rem}.bucket-subcategory{margin-bottom:1.5rem}.bucket-subcategory:last-child{margin-bottom:0}.bucket-subcategory h4{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}.category-card.mini{background:rgba(255,255,255,2%);border:1px solid var(--border);border-radius:8px;padding:.75rem;text-decoration:none;transition:var(--transition);display:block}.category-card.mini:hover{transform:translateY(-2px);border-color:var(--accent);background:rgba(255,255,255,4%)}.category-card.mini .category-icon{font-size:1.25rem;margin-bottom:.25rem}.category-card.mini h5{font-size:.95rem;font-weight:600;color:var(--text-primary);margin-bottom:.15rem}.category-card.mini p{color:var(--text-muted);font-size:.75rem;margin-bottom:0}.pattern-categories-grid,.oop-concepts-grid,.solid-grid,.principles-grid,.code-smells-grid,.algorithms-grid,.data-structures-grid,.big-o-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.75rem}@media(max-width:768px){.buckets-grid{grid-template-columns:1fr}.pattern-categories-grid,.oop-concepts-grid,.solid-grid,.principles-grid,.code-smells-grid,.algorithms-grid,.data-structures-grid,.big-o-grid{grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:.5rem}.bucket-card{padding:1.25rem}.bucket-icon{font-size:2rem}.bucket-card h3{font-size:1.25rem}}.single-pattern-container{display:flex;justify-content:center;align-items:flex-start;min-height:calc(100vh - 56px);padding:40px 24px;background-color:var(--bg-main,#0b0f19);overflow-y:auto}.single-pattern-content{width:90%;max-width:none;margin:0 auto;background-color:var(--bg-modal,#111827);border:1px solid rgba(255,255,255,8%);border-radius:16px;padding:40px;box-shadow:0 20px 40px rgba(0,0,0,.3)}.single-pattern-content .detail-close{position:static;display:inline-flex;align-items:center;gap:8px;background:0 0;border:none;color:#9ca3af;cursor:pointer;font-family:inherit;font-size:14px;font-weight:500;margin-bottom:28px;padding:0;transition:color .2s ease;text-decoration:none}.single-pattern-content .detail-close:hover{color:#3b82f6}.single-pattern-content .modal-header{margin-bottom:32px}.single-pattern-content .modal-tabs{margin-bottom:32px;border-bottom:1px solid rgba(255,255,255,8%);padding-bottom:12px;display:flex;gap:16px}.single-pattern-content .modal-tab-content{display:none}.single-pattern-content .modal-tab-content.active{display:block}.single-pattern-content .modal-code-col pre{background-color:#0d1117!important;border-radius:12px;border:1px solid rgba(255,255,255,5%)}.app-header .app-tagline-link{color:#9ca3af;text-decoration:none;font-size:13px;font-weight:500;transition:color .2s ease}.app-header .app-tagline-link:hover{color:#fff}.callout-box{margin:24px 0;padding:20px 24px;border-radius:12px;border-left:4px solid transparent;box-shadow:0 4px 20px rgba(0,0,0,.15);transition:transform .2s ease,box-shadow .2s ease}.callout-box:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(0,0,0,.2)}.callout-box h5{margin:0 0 10px;font-family:outfit,sans-serif;font-size:13.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;display:flex;align-items:center;gap:8px}.callout-box p{margin:0;font-size:15px;line-height:1.65;color:#e5e7eb}.callout-box p a{color:#60a5fa;text-decoration:none;border-bottom:1px dashed rgba(96,165,250,.4);transition:border-bottom-color .2s}.callout-box p a:hover{border-bottom-color:#60a5fa}.intent-box{border-left-color:#3b82f6;background:linear-gradient(90deg,rgba(59,130,246,8%) 0%,rgba(59,130,246,2%) 100%)}.intent-box h5{color:#60a5fa}.context-box{border-left-color:#10b981;background:linear-gradient(90deg,rgba(16,185,129,8%) 0%,rgba(16,185,129,2%) 100%)}.context-box h5{color:#34d399}.solution-box{border-left-color:#8b5cf6;background:linear-gradient(90deg,rgba(139,92,246,8%) 0%,rgba(139,92,246,2%) 100%)}.solution-box h5{color:#a78bfa}.problem-box{border-left-color:#ef4444;background:linear-gradient(90deg,rgba(239,68,68,8%) 0%,rgba(239,68,68,2%) 100%)}.problem-box h5{color:#f87171}.forces-box{border-left-color:#f59e0b;background:linear-gradient(90deg,rgba(245,158,11,8%) 0%,rgba(245,158,11,2%) 100%)}.forces-box h5{color:#fbbf24}.tldr-box{border-left-color:#ec4899;background:linear-gradient(90deg,rgba(236,72,153,8%) 0%,rgba(236,72,153,2%) 100%)}.tldr-box h5{color:#f472b6}@media(max-width:768px){.single-pattern-container{padding:16px 12px}.single-pattern-content{padding:24px 16px;border-radius:12px}}.subcategory-references{margin-top:32px;padding:24px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px}.subcategory-references h4{color:var(--text-primary);font-size:16px;font-weight:600;margin-bottom:16px;display:flex;align-items:center;gap:8px}.subcategory-references h4::before{content:"📚"}.references-list{list-style:none;padding:0;margin:0}.references-list li{margin-bottom:12px}.references-list li:last-child{margin-bottom:0}.references-list a{color:var(--accent);text-decoration:none;font-size:14px;transition:var(--transition);display:inline-flex;align-items:center;gap:6px}.references-list a:hover{color:var(--text-primary);text-decoration:underline}.references-list a::after{content:"↗";font-size:12px;opacity:.7}