:root{--bg:#f8fafc;--panel:#ffffff;--border:#e2e8f0;--text:#0f172a;--muted:#64748b;--accent:#b45309;--accent-bg:#fef3c7;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}*{box-sizing:border-box}body,html{margin:0;padding:0;height:100%;color:var(--text);background:var(--bg)}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.home{max-width:880px;margin:0 auto;padding:4rem 1.5rem}.home-hero h1{font-size:2.4rem;margin:0 0 .5rem}.home-hero p{color:var(--muted);font-size:1.1rem;margin:0 0 2.5rem}.home-tools{display:grid;grid-gap:1.25rem;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.home-other{margin-top:2.5rem}.home-section-title{font-size:1.1rem;color:var(--muted);margin:0 0 1rem}.tool-card{display:block;padding:1.5rem;background:var(--panel);border:1px solid var(--border);border-radius:12px;color:var(--text)}.tool-card:hover{text-decoration:none;border-color:var(--accent);box-shadow:0 4px 16px rgba(15,23,42,.06)}.tool-card h2{margin:0 0 .5rem;font-size:1.25rem}.tool-card p{margin:0 0 1rem;color:var(--muted);font-size:.95rem;line-height:1.5}.tool-card-cta{font-weight:600;color:var(--accent)}.tool-card--soon{opacity:.6}.tool-page{display:flex;flex-direction:column;min-height:100vh}.tool-header{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;padding:.75rem 1.25rem;background:var(--panel);border-bottom:1px solid var(--border);flex-wrap:wrap}.tool-header h1{margin:.15rem 0 0;font-size:1.4rem}.breadcrumb{font-size:.8rem;color:var(--muted)}.tool-tagline{margin:0;color:var(--muted);font-size:.9rem}.tool-footer{padding:.6rem 1.25rem;font-size:.78rem;color:var(--muted);background:var(--panel);border-top:1px solid var(--border)}.seo-content{max-width:760px;margin:0 auto;padding:2.5rem 1.5rem 3rem;line-height:1.65}.seo-content h2{font-size:1.4rem;margin:2rem 0 .6rem}.seo-content h2:first-child{margin-top:0}.seo-content p{margin:0 0 1rem;color:#334155}.seo-content ol{color:#334155;padding-left:1.25rem}.seo-content ol li{margin-bottom:.4rem}.faq-item{margin-bottom:1.25rem}.faq-item h3{font-size:1.05rem;margin:0 0 .35rem}.faq-item p{margin:0}.planner{height:clamp(560px,80vh,880px);flex-direction:column}.planner,.planner-body{display:flex;min-height:0}.planner-body{flex:1 1}.planner-sidebar{width:260px;flex-shrink:0;display:flex;flex-direction:column;border-right:1px solid var(--border);background:var(--panel);overflow-y:auto}.planner-canvas{flex:1 1;min-width:0;position:relative}.canvas-loading{display:grid;place-items:center;height:100%;color:var(--muted)}.tool-loading{display:grid;place-items:center;min-height:clamp(560px,80vh,880px);color:var(--muted)}.road-hint{position:absolute;top:.75rem;left:50%;transform:translateX(-50%);z-index:10;background:rgba(15,23,42,.9);color:#fff;padding:.4rem .85rem;border-radius:999px;font-size:.8rem;white-space:nowrap;box-shadow:0 4px 16px rgba(15,23,42,.2)}.road-hint kbd{background:rgba(255,255,255,.18);border-radius:4px;padding:0 .3rem;font-family:inherit;font-size:.75rem}.prodchain{height:clamp(560px,80vh,880px);background:#f8fafc;overflow:hidden;contain:layout paint}.prodchain,.toolbar{border-bottom:1px solid var(--border)}.toolbar{display:flex;align-items:center;gap:.4rem;padding:.5rem .75rem;background:var(--panel);flex-wrap:wrap}.toolbar-sep{width:1px;height:20px;background:var(--border);margin:0 .25rem}.tbtn{font:inherit;font-size:.82rem;padding:.35rem .7rem;border:1px solid var(--border);border-radius:7px;background:#fff;color:var(--text);cursor:pointer}.tbtn:hover:not(:disabled){border-color:var(--accent)}.tbtn:disabled{opacity:.4;cursor:not-allowed}.tbtn--on{background:var(--accent-bg);border-color:var(--accent);color:var(--accent)}.tbtn--danger:hover:not(:disabled){border-color:#ef4444;color:#ef4444}.tbtn--primary{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.tbtn--primary:hover:not(:disabled){filter:brightness(1.08)}.toast{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%);background:#0f172a;color:#fff;padding:.6rem 1.1rem;border-radius:999px;font-size:.88rem;box-shadow:0 6px 24px rgba(15,23,42,.25);z-index:50;animation:toast-in .18s ease-out}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}.palette{padding:.75rem}.panel-title{font-size:.95rem;margin:.25rem 0 .75rem}.palette-group{margin-bottom:1rem}.palette-group-title{font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin:0 0 .4rem}.palette-items{gap:.35rem}.palette-item,.palette-items{display:flex;flex-direction:column}.palette-item{align-items:flex-start;text-align:left;font:inherit;padding:.45rem .6rem;border:1px solid;border-radius:8px;cursor:pointer}.palette-item:hover{filter:brightness(.97)}.palette-item-name{font-size:.85rem;font-weight:600}.palette-item-dims{font-size:.72rem;color:var(--muted)}.legend{padding:0 .75rem .75rem}.legend-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.3rem}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.76rem;color:var(--muted)}.legend-swatch{width:16px;height:16px;border-radius:4px;border:1.5px solid;flex-shrink:0}.info-panel{margin-top:auto;padding:.75rem;border-top:1px solid var(--border);font-size:.85rem}.info-panel--empty{color:var(--muted)}.info-name{margin:0 0 .5rem;font-size:1rem}.info-grid{display:grid;grid-template-columns:auto 1fr;grid-gap:.2rem .75rem;gap:.2rem .75rem;margin:0}.info-grid dt{color:var(--muted)}.info-grid dd{margin:0;font-weight:500}.info-note{margin:.6rem 0 .3rem;padding:.4rem .5rem;background:#fffbeb;border:1px solid #fde68a;border-radius:6px;font-size:.78rem;line-height:1.4;color:#92400e}.info-source{margin:.5rem 0 0;font-size:.72rem;color:var(--muted)}