:root{font-family:IBM Plex Sans,Arial,sans-serif;line-height:1.5;font-weight:400;color:#0e2a2e;background-color:#e7f4f1;--tile-unit-pos: #5cc77a;--tile-unit-neg: #9ea7ad;--tile-linear-pos: #4f8fe3;--tile-linear-neg: #f1a64d;--tile-quad-pos: #a275d6;--tile-quad-neg: #f3d164}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at 10% 10%,#e9fbf5,#dff3f4 55%,#d1e7f3)}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer}button:disabled{opacity:.6;cursor:not-allowed}.container{max-width:1200px;margin:0 auto;padding:24px}.card{border:1px solid #b4d6d2;background:#f1fbf7;border-radius:12px;padding:16px;box-shadow:0 10px 30px #1b1f2414}.page-header{border:1px solid #79bdb2;background:linear-gradient(135deg,#d7f3ec,#f1fbf7)}.selection-chip{display:inline-flex;gap:8px;align-items:center;margin:8px 0 0;padding:6px 12px;border-radius:999px;background:#e6f7f3;border:1px solid #79bdb2;font-size:.9rem}.header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid #b4d6d2;background:linear-gradient(90deg,#cfeee8,#eaf7f4);box-shadow:0 8px 20px #1b1f2414}.header-title{display:inline-flex;align-items:center;gap:10px}.nav{display:flex;gap:16px;font-weight:600}.btn{border:1px solid #0e2a2e;background:#46b3a6;color:#0e2a2e;padding:10px 16px;border-radius:999px;font-weight:600}.btn.secondary{background:#effaf7}.icon-button{width:28px;height:28px;border-radius:999px;border:1px solid #0e2a2e;background:#e7f4f1;color:#0e2a2e;font-weight:700;display:inline-flex;align-items:center;justify-content:center;padding:0}.legend-label{font-size:.9rem;font-weight:600;color:#2c4b50}.context-menu{position:fixed;z-index:20;min-width:200px;border-radius:10px;border:1px solid #b4d6d2;background:#f7fdfb;box-shadow:0 12px 30px #0c1e242e;padding:6px}.context-menu-item{width:100%;text-align:left;padding:8px 10px;border-radius:8px;border:none;background:transparent;font-weight:600;color:#0e2a2e}.context-menu-item:hover:not(:disabled){background:#e6f7f3}.context-menu-item:disabled{color:#6f8c91;cursor:not-allowed}.context-menu-empty{padding:8px 10px;font-size:.9rem;color:#6f8c91}.grid{display:grid;gap:16px}.grid.two{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.panel{border:1px dashed #9cc8c5;background:#f7fdfb;border-radius:12px;padding:16px;min-height:120px}.workspace{display:grid;gap:16px;grid-template-columns:280px 1fr}.hint{font-size:.9rem;color:#3b6f75}.inventory{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(90px,1fr));margin-top:12px}.inventory-item{border:1px solid #0e2a2e;border-radius:10px;padding:10px 8px;background:#6fd4c6;font-weight:600;cursor:grab}.inventory-item:active{cursor:grabbing}.inventory-item.neg{background:#8fb2f5}.controls{display:grid;gap:12px}.controls-row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.input{flex:1 1 280px;border:1px solid #9cc8c5;border-radius:10px;padding:10px 12px;background:#fff}.select-label{display:inline-flex;align-items:center;gap:8px;font-weight:600}.select{border:1px solid #9cc8c5;border-radius:10px;padding:8px 10px;background:#fff}.toggle{display:inline-flex;align-items:center;gap:8px;font-weight:600}.error-text{color:#a23b3b;font-weight:600}.factor-status{margin-top:8px}.factor-status.success{color:#0f3d34;font-weight:700}.factor-coords{font-size:.85rem;color:#3b6f75}.factor-board-layout{display:grid;grid-template-columns:80px 1fr;grid-template-rows:36px 1fr;gap:8px;align-items:center}.factor-axis{font-weight:700;color:#0e2a2e;text-align:center}.factor-axis.y-axis{writing-mode:vertical-rl;transform:rotate(180deg)}.board-wrapper{margin:12px 0;overflow:auto}.grid-board{position:relative;border-radius:12px;border:1px solid #b4d6d2;background-image:linear-gradient(to right,rgba(119,178,179,.25) 1px,transparent 1px),linear-gradient(to bottom,rgba(119,178,179,.25) 1px,transparent 1px);background-size:52px 52px;background-color:#f3fbf8}.selection-rect{position:absolute;border:2px dashed #0e2a2e;background:#46b3a62e;border-radius:8px;pointer-events:none}.tile-wrapper{position:absolute}.tile{display:grid;place-items:center;border-radius:10px;border:2px solid #0e2a2e;background:#6fd4c6;font-weight:700;-webkit-user-select:none;user-select:none;touch-action:none;box-shadow:0 6px 14px #1b1f2426}.tile.selected{outline:3px solid #0e2a2e;outline-offset:2px}.tile.neg{background:#8fb2f5}.tile.tile-1.pos,.inventory-item.tile-1.pos,.legend-swatch.tile-1.pos{background:var(--tile-unit-pos)}.tile.tile-1.neg,.inventory-item.tile-1.neg,.legend-swatch.tile-1.neg{background:var(--tile-unit-neg)}.tile.tile-x.pos,.inventory-item.tile-x.pos,.legend-swatch.tile-x.pos{background:var(--tile-linear-pos)}.tile.tile-x.neg,.inventory-item.tile-x.neg,.legend-swatch.tile-x.neg{background:var(--tile-linear-neg)}.tile.tile-x2.pos,.inventory-item.tile-x2.pos,.legend-swatch.tile-x2.pos{background:var(--tile-quad-pos)}.tile.tile-x2.neg,.inventory-item.tile-x2.neg,.legend-swatch.tile-x2.neg{background:var(--tile-quad-neg)}.tile.tile-x.vertical{background-image:repeating-linear-gradient(90deg,rgba(12,30,36,.2) 0,rgba(12,30,36,.2) 4px,transparent 4px,transparent 8px);background-blend-mode:multiply}.result{border-radius:10px;padding:10px 12px;font-weight:600;margin-top:12px}.result.success{background:#c7f2e6;border:1px solid #7bcdb6;color:#0f3d34}.result.fail{background:#d5e4fb;border:1px solid #8fb2f5;color:#1b2b4f}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#081f2473;display:grid;place-items:center;padding:24px;z-index:10}.modal{background:#f1fbf7;border-radius:16px;border:1px solid #b4d6d2;max-width:420px;width:100%;padding:20px;box-shadow:0 12px 40px #0c1e2433}.legend-modal{max-width:760px}.legend-modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:16px}.tile-legend{overflow:hidden}.legend-table-wrapper{overflow-x:auto;margin-top:12px}.legend-table{width:100%;border-collapse:collapse;font-size:.95rem}.legend-table th,.legend-table td{text-align:left;padding:8px 10px;border-bottom:1px solid #c7e3dd}.legend-piece{display:flex;align-items:center;gap:10px}.legend-swatch{width:18px;height:18px;border-radius:4px;border:2px solid #0e2a2e;background:#e5f1ef;flex:0 0 auto}.legend-swatch.muted{border-style:dashed;background:#e9f5f2}.tile-x2,.tile-x{font-size:1rem}.tile-1{font-size:.95rem}.solve-workspace{grid-template-columns:240px 1fr}.solve-boards{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);gap:12px;align-items:center}.solve-divider{font-size:2rem;font-weight:700;color:#0e2a2e;padding:0 8px}@media (max-width: 900px){.workspace,.solve-workspace,.solve-boards{grid-template-columns:1fr}.solve-divider{text-align:center}}
