*,:before,:after{box-sizing:border-box}body{color:#1e293b;-webkit-font-smoothing:antialiased;background:#f1f5f9;margin:0;font-family:Trebuchet MS,Trebuchet,Arial,sans-serif;font-size:16px;line-height:1.5}h1,h2,h3,h4{margin:0;font-family:Trebuchet MS,Trebuchet,Arial,sans-serif;font-weight:700;line-height:1.2}p{margin:0}a{color:#00a2d3;text-underline-offset:2px;text-decoration:underline}a:hover{color:#0082ab}button{cursor:pointer;font-family:inherit}textarea,input{font-family:Courier New,Courier,monospace}#root{min-height:100dvh}.app{flex-direction:column;min-height:100dvh;display:flex}.app-header{color:#fff;text-align:center;background:linear-gradient(135deg,#005f8a 0%,#00a2d3 100%);padding:2.5rem 1.5rem}.header-inner{max-width:860px;margin:0 auto}.app-title-row{justify-content:center;align-items:center;gap:1rem;margin-bottom:.5rem;display:flex}.header-logo{flex-shrink:0;width:auto;height:3rem}.app-title{color:#fff;letter-spacing:-.02em;margin-bottom:0;font-size:clamp(1.8rem,5vw,3rem)}.app-subtitle{opacity:.9;margin-bottom:.5rem;font-size:1.05rem}.app-source{opacity:.75;font-size:.875rem}.app-source a{color:#b3e8f7}.app-source a:hover{color:#fff}.app-main{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:1.5rem 1rem 3rem}.category-filter{flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;display:flex}.filter-btn{color:#475569;background:#fff;border:2px solid #cbd5e1;border-radius:9999px;align-items:center;gap:.4rem;padding:.4rem .9rem;font-size:.82rem;font-weight:600;transition:border-color .15s,background .15s,color .15s,box-shadow .15s;display:inline-flex}.filter-btn:hover{border-color:#94a3b8;box-shadow:0 1px 4px #00000014}.filter-btn.active{color:#fff;background:#00a2d3;border-color:#00a2d3}.filter-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.results-count{color:#64748b;margin-bottom:1.25rem;font-size:.9rem}.results-count strong{color:#1e293b}.techniques-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));align-items:start;gap:1.25rem;display:grid}.technique-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem;transition:box-shadow .2s;box-shadow:0 1px 3px #0000000f}.technique-card:hover{box-shadow:0 4px 16px #0000001a}.card-header{justify-content:space-between;align-items:center;margin-bottom:.6rem;display:flex}.category-badge{letter-spacing:.02em;text-transform:uppercase;border:1px solid;border-radius:9999px;padding:.2rem .65rem;font-size:.72rem;font-weight:700}.technique-num{color:#94a3b8;font-size:.78rem;font-weight:600}.card-title{color:#1e293b;margin-bottom:.45rem;font-size:1rem;font-weight:700}.card-desc{color:#475569;margin-bottom:1rem;font-size:.85rem;line-height:1.55}.try-btn{color:#00a2d3;letter-spacing:.01em;background:0 0;border:2px solid #00a2d3;border-radius:8px;width:100%;padding:.5rem;font-size:.85rem;font-weight:700;transition:background .15s,color .15s;display:block}.try-btn:hover{color:#fff;background:#00a2d3}.modal-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:1000;background:#0009;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.modal-box{background:#fff;border-radius:16px;flex-direction:column;width:100%;max-width:90vw;max-height:90vh;display:flex;overflow:hidden;box-shadow:0 24px 64px #00000059}.modal-header{border-bottom:1px solid #e2e8f0;flex-shrink:0;justify-content:space-between;align-items:flex-start;gap:1rem;padding:1.25rem 1.5rem;display:flex}.modal-header-text{flex-direction:column;gap:.4rem;display:flex}.modal-title{color:#1e293b;margin:0;font-size:1.15rem;font-weight:700}.modal-close{color:#64748b;background:#f1f5f9;border:none;border-radius:50%;flex-shrink:0;width:2.2rem;height:2.2rem;font-size:1rem;line-height:1;transition:background .15s,color .15s}.modal-close:hover{color:#1e293b;background:#e2e8f0}.modal-body{flex:1;padding:1.5rem;overflow-y:auto}.modal-desc{color:#475569;margin-bottom:1.25rem;font-size:.9rem;line-height:1.6}.modal-body .mini-codepen{min-height:460px}.modal-body .mcp-textarea{min-height:380px}.modal-body .mcp-iframe{min-height:400px}.mini-codepen{grid-template-columns:1fr 1fr;gap:.75rem;min-height:260px;margin-top:1rem;display:grid}@media (width<=600px){.mini-codepen{grid-template-columns:1fr}}.mcp-editor{background:#1e293b;border-radius:8px;flex-direction:column;display:flex;overflow:hidden}.mcp-tabs{background:#0f172a;display:flex}.mcp-tab{color:#94a3b8;letter-spacing:.05em;text-transform:uppercase;background:0 0;border:none;flex:1;padding:.45rem 0;font-size:.8rem;font-weight:700;transition:background .15s,color .15s}.mcp-tab:hover{color:#e2e8f0}.mcp-tab.active{color:#b3e8f7;background:#1e293b;border-bottom:2px solid #00a2d3}.mcp-textarea{resize:none;color:#e2e8f0;tab-size:2;background:#1e293b;border:none;outline:none;flex:1;min-height:180px;padding:.75rem;font-family:Courier New,Courier,monospace;font-size:.78rem;line-height:1.6}.mcp-textarea::selection{background:#00a2d34d}.mcp-copy-row{background:#0f172a;gap:.5rem;padding:.5rem;display:flex}.mcp-copy-btn{color:#cbd5e1;background:#334155;border:1px solid #475569;border-radius:5px;flex:1;padding:.35rem .5rem;font-size:.75rem;font-weight:700;transition:background .15s,color .15s,border-color .15s}.mcp-copy-btn:hover{color:#fff;background:#475569}.mcp-copy-btn.copied{color:#fff;background:#16a34a;border-color:#16a34a}.mcp-preview{border:1px solid #e2e8f0;border-radius:8px;flex-direction:column;display:flex;overflow:hidden}.mcp-preview-label{color:#94a3b8;letter-spacing:.06em;text-transform:uppercase;background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:.3rem .75rem;font-size:.72rem;font-weight:700;display:block}.mcp-iframe{background:#f8fafc;border:none;flex:1;width:100%;min-height:220px}.app-footer{color:#94a3b8;text-align:center;background:#1e293b;padding:1.25rem;font-size:.82rem}.app-footer a{color:#7dd5ef}.app-footer a:hover{color:#fff}
