*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f8f9fb;--white:#fff;--text:#1e293b;--text-secondary:#64748b;--border:#e2e8f0;--accent:#6366f1;--accent-light:#eef2ff;--accent-dark:#4f46e5;--green:#10b981;--green-light:#ecfdf5;--yellow:#f59e0b;--yellow-light:#fffbeb;--red:#ef4444;--red-light:#fef2f2;--purple:#8b5cf6;--purple-light:#f5f3ff;--blue:#3b82f6;--blue-light:#eff6ff;--shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;--shadow-md:0 4px 6px #0000000d,0 2px 4px #0000000a;--shadow-lg:0 10px 15px #0000000f,0 4px 6px #0000000a;--radius:16px;--radius-sm:10px;--radius-xs:8px;--mono:"JetBrains Mono",monospace;--sans:"Inter",-apple-system,sans-serif}body{font-family:var(--sans);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh;line-height:1.5}.container{max-width:1140px;margin:0 auto;padding:0 24px}header{flex-wrap:wrap;align-items:center;gap:16px;padding:20px 0;display:flex}.logo{color:var(--text);align-items:center;gap:10px;font-size:1.3rem;font-weight:800;text-decoration:none;display:inline-flex}.logo-icon{background:var(--accent);color:#fff;width:38px;height:38px;font-family:var(--mono);border-radius:12px;justify-content:center;align-items:center;font-size:.95rem;font-weight:700;display:flex;box-shadow:0 2px 8px #10b9814d}.logo em{color:var(--accent);font-style:normal}.nav-pills{gap:6px;margin-left:auto;display:flex}.nav-pill{color:var(--text-secondary);background:var(--white);border:1px solid var(--border);border-radius:20px;padding:6px 14px;font-size:.78rem;font-weight:600;text-decoration:none;transition:all .15s}.nav-pill:hover,.nav-pill.active{background:var(--green-light);color:var(--green);border-color:var(--accent)}.page-hero{text-align:center;padding:16px 0 24px}.page-hero h1{letter-spacing:-.02em;margin-bottom:6px;font-size:1.8rem;font-weight:800}.page-hero p{color:var(--text-secondary);max-width:560px;margin:0 auto;font-size:1rem}.spec-note{color:var(--text-secondary);background:var(--white);border:1px solid var(--border);border-radius:20px;margin-top:10px;padding:4px 14px;font-size:.75rem;display:inline-block}.card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:16px;padding:20px}.card-header{align-items:center;gap:8px;margin-bottom:14px;display:flex}.card-header .icon{border-radius:8px;justify-content:center;align-items:center;width:28px;height:28px;font-size:.9rem;display:flex}.card-header h3{text-transform:uppercase;letter-spacing:.04em;color:var(--text);font-size:.85rem;font-weight:700}.controls{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.form-select{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-xs);color:var(--text);font-family:var(--sans);appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%2364748b' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding:10px 36px 10px 14px;font-size:.9rem;font-weight:500;transition:border-color .15s}.form-select:focus{border-color:var(--green);outline:none;box-shadow:0 0 0 3px #10b98126}.form-input{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-xs);color:var(--text);font-family:var(--sans);padding:10px 14px;font-size:.9rem;transition:border-color .15s}.form-input:focus{border-color:var(--green);outline:none;box-shadow:0 0 0 3px #10b98126}.btn{border:1.5px solid var(--border);border-radius:var(--radius-xs);background:var(--white);color:var(--text);font-family:var(--sans);cursor:pointer;box-shadow:var(--shadow);justify-content:center;align-items:center;gap:6px;padding:10px 18px;font-size:.88rem;font-weight:600;transition:all .15s;display:inline-flex}.btn:hover{border-color:var(--green);color:var(--green);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn:active{box-shadow:var(--shadow);transform:translateY(0)}.btn.primary{background:var(--green);border-color:var(--green);color:#fff;box-shadow:0 2px 8px #10b98140}.btn.primary:hover{background:#059669;box-shadow:0 4px 12px #6366f14d}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.slider-group{background:var(--bg);border-radius:var(--radius-xs);border:1px solid var(--border);align-items:center;gap:8px;padding:6px 14px;display:flex}.slider-group label{color:var(--text-secondary);white-space:nowrap;font-size:.78rem;font-weight:600}.slider-group input[type=range]{width:100px;accent-color:var(--green);height:4px}.slider-group .val{font-family:var(--mono);color:var(--accent);text-align:right;min-width:28px;font-size:.82rem;font-weight:600}#canvas-wrap{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius);width:100%;height:360px;box-shadow:var(--shadow);position:relative;overflow:hidden}canvas{width:100%;height:100%;display:block}#step-desc{font-family:var(--mono);color:var(--text-secondary);min-height:1.5em;padding:8px 0;font-size:.82rem;line-height:1.5}.stats{flex-wrap:wrap;gap:12px;display:flex}.stat{background:var(--bg);border-radius:var(--radius-sm);text-align:center;flex:1;min-width:100px;padding:12px 16px}.stat .label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:2px;font-size:.7rem;font-weight:600}.stat .value{font-family:var(--mono);color:var(--text);font-size:1.2rem;font-weight:700}.info-grid{grid-template-columns:1fr 1fr;gap:0;display:grid}.info-item{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 12px;display:flex}.info-item:nth-child(odd){border-right:1px solid var(--border)}.info-label{color:var(--text-secondary);font-size:.82rem}.info-val{font-family:var(--mono);color:var(--text);font-size:.85rem;font-weight:700}.info-desc{color:var(--text-secondary);border-top:1px solid var(--border);padding:14px 12px 4px;font-size:.88rem;line-height:1.7}#custom-input{margin-top:10px;display:none}.legend{flex-wrap:wrap;gap:16px;padding:10px 0 0;display:flex}.legend-item{color:var(--text-secondary);align-items:center;gap:6px;font-size:.78rem;font-weight:500;display:flex}.legend-dot{width:14px;height:14px;box-shadow:var(--shadow);border-radius:4px}.two-col{grid-template-columns:1fr 320px;align-items:start;gap:16px;display:grid}@media (width<=860px){.two-col,.info-grid{grid-template-columns:1fr}.info-item:nth-child(odd){border-right:none}}
