:root{color:#111;background:#f4f4f4;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;--accent: #111;--ink: #111;--muted: #666;--line: #e4e4e4;--soft-line: #eeeeee;--panel: #fff;--rail: #f2f2f2;--canvas: #fafafa}*{box-sizing:border-box}body{margin:0;min-width:1120px;min-height:100vh;font-size:14px}button,input,textarea,select{font:inherit}button{border:1px solid transparent;background:#f7f7f7;color:var(--ink);min-height:30px;border-radius:0;padding:0 10px;display:inline-flex;align-items:center;justify-content:center;gap:7px;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.45}button:focus,input:focus,textarea:focus,select:focus{outline:0}button:focus-visible{border-color:#111}input:focus-visible,textarea:focus-visible,select:focus-visible{border-color:transparent;box-shadow:none}input,textarea,select{width:100%;border:1px solid transparent;border-radius:0;background:#f7f7f7;color:var(--ink);padding:7px 9px}input[type=range]{accent-color:var(--accent);padding:0}input[type=color]{min-height:38px;padding:3px}textarea{min-height:66px;resize:none}.app-shell{min-height:100vh;display:grid;grid-template-columns:minmax(520px,1fr) 380px 380px;background:#f4f4f4}.home-shell{min-height:100vh;display:grid;grid-template-rows:auto 1fr;gap:32px;padding:32px;background:#f2f2f2}.home-brand{display:flex;align-items:center;gap:12px}.home-backup-actions{margin-left:auto;display:flex;align-items:center;gap:8px}.home-backup-actions button{min-height:34px;display:inline-flex;align-items:center;gap:6px;padding:7px 12px;background:#fff;font-size:12px;font-weight:900}.home-brand h1,.home-brand p{margin:0}.home-brand h1{font-size:24px;line-height:1}.home-brand p{margin-top:6px;color:#666;font-size:13px;font-weight:800}.home-entry-grid{width:min(1380px,100%);display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;place-self:center;transform:translateY(-30px)}.home-entry-card{min-height:260px;padding:24px;display:grid;place-items:center;align-content:center;gap:12px;background:#fff;text-align:center}.home-entry-card svg{width:46px;height:46px;stroke-width:1.8;color:#111}.home-entry-card strong{font-size:22px;line-height:1.1}.home-entry-card span{color:#666;font-size:13px;font-weight:800}.library-shell{min-height:100vh;display:grid;grid-template-columns:minmax(680px,1fr) 340px;background:#f2f2f2}.inventory-shell{min-height:100vh;display:grid;grid-template-columns:minmax(0,1fr) minmax(360px,440px);background:#f2f2f2}.accounting-shell{min-height:100vh;display:grid;grid-template-rows:auto auto 1fr;gap:14px;padding:18px;background:#f2f2f2}.accounting-topbar{padding:0}.accounting-topbar>button:last-child{margin-left:auto;min-height:38px;background:#fff;font-weight:900}.accounting-overview-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}.accounting-overview-grid div{min-width:0;display:grid;gap:8px;padding:14px;background:#fff}.accounting-overview-grid span{color:var(--muted);font-size:12px;font-weight:800}.accounting-overview-grid strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:24px;line-height:1}.accounting-workspace{min-width:0;min-height:0;overflow:auto;display:grid;align-content:start;gap:10px;padding:12px;background:#fff}.accounting-filter-row{min-width:0;display:grid;grid-template-columns:minmax(0,1fr) minmax(220px,320px);align-items:center;gap:10px}.accounting-filters{width:fit-content;max-width:100%;overflow-x:auto}.accounting-search{min-height:38px}.accounting-table{min-width:1080px;display:grid;gap:4px}.accounting-table-row{min-width:0;min-height:42px;display:grid;grid-template-columns:128px 102px minmax(150px,1fr) 88px 78px 92px 82px 82px 72px minmax(150px,1fr) 34px;align-items:center;gap:6px;padding:4px 6px;background:#f7f7f7}.accounting-table-head{min-height:28px;color:#666;font-size:11px;font-weight:900;background:#fff}.accounting-table-row input,.accounting-table-row select,.accounting-table-row button{min-width:0;min-height:32px;padding:5px 7px;background:#fff;font-size:12px}.accounting-table-row strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}.accounting-object-cell{min-width:0;display:grid;gap:2px}.accounting-object-cell strong,.accounting-object-cell small{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.accounting-object-cell small{color:#777;font-size:10px;font-weight:800}.accounting-source-link{min-width:0;min-height:0!important;justify-self:start;overflow:hidden;padding:0!important;border:0;background:transparent!important;color:#777;font-size:10px!important;font-weight:800;text-align:left;text-overflow:ellipsis;white-space:nowrap;cursor:pointer}.accounting-source-link:hover{color:#111}.accounting-table-check{justify-content:center;background:#fff}.accounting-stock-button{font-weight:900}.accounting-stock-button.is-done{color:#333}.accounting-stock-button:disabled{color:#777;cursor:default}.accounting-table-row .icon-tool{padding:0}.accounting-empty{padding:12px 6px}.accounting-source-detail{position:fixed;z-index:30;width:min(360px,calc(100vw - 36px));max-height:calc(100vh - 36px);min-width:0;overflow:auto;display:grid;gap:14px;padding:14px;background:#f7f7f7;box-shadow:0 16px 40px #00000024}.accounting-source-detail .inventory-panel-head{padding:0}.accounting-source-detail h2,.accounting-source-detail h3{margin:0;font-size:16px}.accounting-source-detail .inventory-panel-head p{margin:4px 0 0;color:#666;font-size:12px;font-weight:800}.accounting-source-lines{display:grid;gap:8px}.accounting-source-line{min-width:0;display:grid;gap:4px;padding:10px;background:#fff}.accounting-source-line strong,.accounting-source-line span,.accounting-source-line em{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.accounting-source-line strong{font-size:13px}.accounting-source-line span{color:#666;font-size:11px;font-weight:800}.accounting-source-line em{color:#111;font-size:12px;font-style:normal;font-weight:900}.accounting-source-note{display:grid;gap:6px}.accounting-source-note span{color:#666;font-size:11px;font-weight:900}.accounting-source-note p{margin:0;padding:10px;background:#fff;color:#333;font-size:12px;font-weight:800}.supplier-shell{min-height:100vh;display:grid;grid-template-rows:auto auto 1fr;gap:14px;padding:18px;background:#f2f2f2}.supplier-topbar{padding:0}.supplier-topbar>button:last-child{margin-left:auto;min-height:38px;background:#fff;font-weight:900}.supplier-overview-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr)) minmax(320px,380px);gap:10px}.supplier-overview-grid div{min-width:0;display:grid;gap:8px;padding:14px;background:#fff}.supplier-overview-grid span{color:var(--muted);font-size:12px;font-weight:800}.supplier-overview-grid strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:24px;line-height:1}.supplier-workspace{min-width:0;min-height:0;display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,380px);gap:10px}.supplier-table-panel,.supplier-detail-panel{min-width:0;min-height:0;overflow:auto;display:grid;align-content:start;gap:10px;padding:12px;background:#fff}.supplier-table{min-width:980px;display:grid;gap:4px}.supplier-table-row{min-width:0;min-height:42px;display:grid;grid-template-columns:minmax(140px,1fr) 128px minmax(150px,1fr) 92px 90px minmax(160px,1fr) 34px;align-items:center;gap:6px;padding:4px 6px;background:#f7f7f7;border:1px solid transparent}.supplier-table-row.is-selected{border-color:#111}.supplier-table-head{min-height:28px;color:#666;font-size:11px;font-weight:900;background:#fff}.supplier-table-row input,.supplier-table-row button{min-width:0;min-height:32px;padding:5px 7px;background:#fff;font-size:12px}.supplier-table-row strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}.supplier-table-row .icon-tool{padding:0}.supplier-empty{padding:12px 6px}.supplier-detail-list{margin:0;display:grid;gap:6px}.supplier-detail-list div,.supplier-history-row{min-width:0;display:grid;grid-template-columns:minmax(90px,auto) minmax(0,1fr);gap:8px;align-items:center;padding:8px 10px;background:#f7f7f7}.supplier-detail-list dt{color:#666;font-size:11px;font-weight:900}.supplier-detail-list dd{min-width:0;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:right;font-size:12px;font-weight:900}.supplier-history{min-width:0;display:grid;gap:6px}.supplier-history h3{margin:4px 0 0;font-size:13px}.supplier-history-row{grid-template-columns:70px minmax(0,1fr) auto}.supplier-history-row span,.supplier-history-row strong,.supplier-history-row em{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:11px}.supplier-history-row span{color:#666;font-weight:800}.supplier-history-row strong{font-size:12px}.supplier-history-row em{font-style:normal;font-weight:900}.design-asset-shell{min-height:100vh;display:grid;grid-template-rows:auto 1fr;gap:14px;padding:18px;background:#f2f2f2}.design-asset-topbar{padding:0}.design-asset-topbar>button{min-height:38px;background:#fff;font-weight:900}.design-asset-view-switcher{margin-left:auto;max-width:100%;overflow-x:auto}.design-asset-layout-switcher{display:inline-flex;gap:4px;padding:4px;background:#e9e9e9}.design-asset-layout-switcher button{width:34px;min-height:30px;padding:0;background:transparent;color:#666}.design-asset-layout-switcher button.active{background:#fff;color:#111}.design-asset-layout-switcher+button{margin-left:0}.design-asset-overview-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.design-asset-overview-grid div{min-width:0;display:grid;gap:8px;padding:14px;background:#fff}.design-asset-overview-grid span{color:var(--muted);font-size:12px;font-weight:800}.design-asset-overview-grid strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:24px;line-height:1}.design-asset-workspace{min-width:0;min-height:0;display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,380px);gap:10px}.design-asset-library-panel,.design-asset-detail-panel{min-width:0;min-height:0;overflow:auto;display:grid;align-content:start;gap:10px;padding:12px;background:#fff}.design-asset-library-panel{align-content:start}.design-asset-card-grid{min-width:0;display:grid;grid-template-columns:repeat(auto-fill,172px);grid-auto-rows:auto;gap:12px;align-content:start}.design-asset-card{min-width:0;min-height:238px;display:grid;grid-template-rows:160px auto;align-items:stretch;gap:0;padding:0;overflow:hidden;background:#f7f7f7;border:2px solid transparent;text-align:left}.design-asset-card.is-selected{border-color:transparent;background:#efefef}.design-asset-card-add{grid-template-rows:none;place-items:center;align-content:center;gap:8px;background:#fff;text-align:center}.design-asset-card-add svg{color:#666;stroke-width:1.6}.design-asset-card-add span,.design-asset-card-add small{display:block;font-weight:900}.design-asset-card-add small{color:#777;font-size:11px}.design-asset-card-media{min-width:0;display:grid;place-items:center;overflow:hidden;background:#fff;color:#111}.design-asset-card-media img{width:100%;height:100%;object-fit:cover}.design-asset-card-meta{min-width:0;display:grid;gap:4px;padding:10px}.design-asset-card-meta strong,.design-asset-card-meta em,.design-asset-card-meta small{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.design-asset-card-meta strong{font-size:13px;line-height:1.2}.design-asset-card-meta em,.design-asset-card-meta small{color:#666;font-size:11px;font-style:normal;font-weight:800}.design-asset-table{width:100%;min-width:0;display:grid;gap:3px}.design-asset-table-row{min-width:0;min-height:52px;display:grid;grid-template-columns:minmax(160px,1.6fr) minmax(72px,.7fr) minmax(76px,.7fr) minmax(70px,1fr) 76px 44px 58px 34px;align-items:center;gap:4px;padding:5px 6px;background:#f7f7f7;border:1px solid transparent;color:#111;text-align:left}.design-asset-table-row.is-selected{border-color:transparent;background:#efefef}.design-asset-table-head{position:sticky;top:-12px;z-index:1;min-height:30px;color:#666;font-size:11px;font-weight:900;background:#fff;border-bottom-color:#e6e6e6}.design-asset-table-add{min-height:48px;background:#fff;border-style:dashed;color:#666;font-weight:900}.design-asset-table-row input,.design-asset-table-row select,.design-asset-table-row button{min-width:0;min-height:32px;padding:5px 7px;background:#fff;font-size:12px}.design-asset-format{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#666;font-size:11px;font-weight:800}.design-asset-file-cell{min-width:0;display:grid;grid-template-columns:34px minmax(0,1fr);align-items:center;gap:6px}.design-asset-file-cell>span:first-child{width:34px;height:34px;display:grid;place-items:center;overflow:hidden;background:#fff;color:#111}.design-asset-file-cell>span:last-child{min-width:0;display:grid;gap:3px}.design-asset-file-cell strong,.design-asset-file-cell em{min-width:0;overflow-wrap:anywhere;white-space:normal}.design-asset-file-cell strong{font-size:13px;line-height:1.1}.design-asset-file-cell em{color:#777;font-size:11px;font-style:normal;font-weight:800}.design-asset-file-cell img{width:100%;height:100%;object-fit:cover}.design-asset-row-status{justify-self:start;min-width:30px;padding:4px 3px;background:#fff;color:#555;font-size:11px;font-weight:900;text-align:center}.design-asset-table-row .icon-tool{padding:0}.design-asset-empty{padding:12px 6px}.design-asset-preview{width:100%;min-height:180px;display:grid;place-items:center;overflow:hidden;padding:0;background:#f7f7f7}.design-asset-preview img{width:100%;height:100%;max-height:260px;object-fit:contain}.design-asset-detail-panel label{display:grid;gap:6px;color:#666;font-size:11px;font-weight:900}.design-asset-detail-grid,.design-asset-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.design-asset-actions button{min-height:38px;background:#f7f7f7;font-weight:900}.design-asset-context-menu{position:fixed;z-index:20;width:170px;display:grid;gap:2px;padding:4px;background:#fff;border:1px solid #d8d8d8;box-shadow:0 12px 28px #0000001f}.design-asset-context-menu button{justify-content:flex-start;min-height:32px;background:#fff;font-size:12px;font-weight:900}.production-shell{min-height:100vh;display:grid;grid-template-rows:auto auto 1fr;gap:14px;padding:18px;background:#f2f2f2}.production-topbar{padding:0}.production-topbar>button:last-child{margin-left:auto;min-height:38px;background:#fff;font-weight:900}.production-overview-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}.production-overview-grid div{min-width:0;display:grid;gap:8px;padding:14px;background:#fff}.production-overview-grid span{color:var(--muted);font-size:12px;font-weight:800}.production-overview-grid strong{font-size:24px;line-height:1}.production-board{min-width:0;min-height:0;overflow:auto;display:grid;grid-template-columns:repeat(5,minmax(220px,1fr));gap:10px}.production-column{min-width:0;min-height:0;overflow:auto;display:flex;flex-direction:column;gap:8px;padding:10px;background:#fff}.production-column-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.production-column-head h2{margin:0;font-size:14px}.production-column-head span{color:#666;font-size:12px;font-weight:900}.production-card-list{display:grid;gap:8px}.production-card{min-width:0;display:grid;gap:6px;padding:8px;background:#f7f7f7}.production-card.is-focused{box-shadow:inset 0 0 0 2px #111}.production-card-media{min-width:0;width:100%;aspect-ratio:4 / 3;overflow:hidden;display:block;background:#fff}.production-card-media img,.production-card-media i{width:100%;height:100%;display:block;object-fit:contain}.production-card-media i{background:linear-gradient(45deg,#f0f0f0 25%,transparent 25%),linear-gradient(-45deg,#f0f0f0 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#f0f0f0 75%),linear-gradient(-45deg,transparent 75%,#f0f0f0 75%);background-color:#fff;background-position:0 0,0 8px,8px -8px,-8px 0;background-size:16px 16px}.production-card-meta{min-width:0;display:grid;gap:2px}.production-card-meta strong,.production-card-meta em{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.production-card-meta strong{font-size:12px;line-height:1.2;font-weight:900}.production-card-meta em{color:#666;font-size:11px;font-style:normal;font-weight:800}.inventory-board,.inventory-ledger{min-width:0;height:100vh;overflow:auto;display:flex;flex-direction:column;gap:14px;padding:18px}.inventory-overview{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.inventory-overview div{min-width:0;display:grid;gap:8px;padding:14px;background:#fff}.inventory-overview span{color:var(--muted);font-size:12px;font-weight:800}.inventory-overview strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:26px;line-height:1}.inventory-table-panel{min-width:0;display:grid;gap:10px;padding:12px;background:#fff}.inventory-table-panel h2,.inventory-panel-head h2{margin:0;display:flex;align-items:center;gap:8px;font-size:14px}.inventory-table{display:grid;gap:4px}.inventory-row{min-width:0;min-height:38px;display:grid;grid-template-columns:minmax(180px,1fr) 70px 90px 90px 70px;align-items:center;gap:6px;padding:4px 6px;background:#f7f7f7}.inventory-row-head{min-height:28px;color:#666;font-size:11px;font-weight:900;background:#fff}.inventory-row strong,.inventory-row span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inventory-row strong{font-size:12px}.inventory-item-name{min-width:0;display:flex;align-items:baseline;gap:5px}.inventory-item-name b,.inventory-item-name small{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inventory-item-name b{font-weight:900}.inventory-item-name small{flex:0 1 auto;color:#777;font-size:10px;font-weight:600;line-height:1}.inventory-row span{color:#666;font-size:12px}.inventory-row input{min-height:30px;padding:5px 7px;background:#fff}.inventory-row button{min-height:30px;background:#fff;font-size:12px;font-weight:800}.inventory-ledger{background:#f4f4f4}.inventory-panel-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.panel-head-actions{display:flex;align-items:center;gap:6px}.compact-switcher{display:inline-grid;grid-template-columns:repeat(2,minmax(44px,auto));gap:2px;padding:2px;background:#f5f5f5}.compact-switcher button{min-height:26px;padding:3px 7px;background:transparent;color:#666;font-size:11px;font-weight:900}.compact-switcher button.active{background:#111;color:#fff}.purchase-list{display:grid;gap:6px}.purchase-card{display:grid;gap:6px;padding:8px;background:#f7f7f7}.purchase-card-main,.purchase-card-actions{min-width:0;display:grid;gap:6px}.purchase-card-main{grid-template-columns:minmax(0,1fr) auto;align-items:center}.purchase-card-main span{min-width:0;color:#666;font-size:11px;font-weight:900}.purchase-card-actions{grid-template-columns:minmax(78px,1fr) minmax(58px,auto) 30px;align-items:center}.purchase-card select,.purchase-card input,.purchase-card button{min-height:28px;padding:4px 6px;background:#fff;min-width:0;font-size:11px}.purchase-card strong{min-width:0;align-self:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}.purchase-card strong.inventory-item-name{overflow:visible}.purchase-supplier-row{min-width:0;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:6px}.purchase-supplier-row span{min-width:0;color:#666;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:11px;font-weight:900}.purchase-lines{min-width:0;display:grid;gap:6px}.purchase-lines-head{min-width:0;display:flex;align-items:center;justify-content:space-between;gap:8px}.purchase-lines-head span{color:#666;font-size:10px;font-weight:800}.purchase-lines-head button{min-height:26px;display:inline-flex;align-items:center;gap:5px;font-weight:800}.purchase-line-row{min-width:0;display:grid;grid-template-columns:minmax(0,1fr) 62px 72px 30px;gap:5px}.purchase-line-item{min-height:28px;align-items:center;padding:4px 6px;background:#fff}.purchase-line-item b{font-size:11px}.purchase-line-item small{font-size:9px;font-weight:500}.purchase-source-list{min-width:0;display:grid;gap:6px}.purchase-source-card{min-width:0;display:grid;gap:5px;padding:7px;background:#f7f7f7}.purchase-source-head,.purchase-source-row{min-width:0;display:grid;align-items:center;gap:8px}.purchase-source-head{grid-template-columns:minmax(0,1fr) auto}.purchase-source-head strong,.purchase-source-row strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.purchase-source-row strong.inventory-item-name{overflow:visible}.purchase-source-head strong{font-size:12px}.purchase-source-head span{color:#666;font-size:10px;font-weight:800}.purchase-source-row{grid-template-columns:minmax(0,1fr) 78px 64px;min-height:28px;padding:4px 6px;background:#fff}.purchase-source-row span,.purchase-source-row em{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:11px}.purchase-source-row span{color:#666;font-weight:800}.purchase-source-row em{justify-self:end;font-style:normal;font-weight:900}.ledger-check{min-height:30px;display:flex;align-items:center;gap:5px;color:#666;font-size:12px;font-weight:800}.ledger-check input{width:auto;min-height:0}.accounting-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.accounting-summary div{min-width:0;display:grid;gap:5px;padding:10px;background:#f7f7f7}.accounting-summary span{color:#666;font-size:11px;font-weight:900}.accounting-summary strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:16px}.accounting-list{display:grid;gap:8px}.accounting-teaser-list{display:grid;gap:6px}.accounting-teaser-row{min-width:0;min-height:36px;display:grid;grid-template-columns:76px minmax(0,1fr) auto;justify-content:stretch;gap:8px;padding:0 8px;background:#f7f7f7;text-align:left}.accounting-teaser-row span,.accounting-teaser-row strong,.accounting-teaser-row em{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}.accounting-teaser-row span{color:#666;font-weight:800}.accounting-teaser-row strong{font-weight:900}.accounting-teaser-row strong.inventory-item-name{overflow:visible}.accounting-teaser-row em{font-style:normal;font-weight:900}.accounting-card{display:grid;gap:8px;padding:10px;background:#f7f7f7}.accounting-source-badge{width:fit-content;padding:3px 7px;background:#111;color:#fff;font-size:11px;font-weight:900}.accounting-card-grid{min-width:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.accounting-card label{min-width:0;display:grid;gap:5px}.accounting-card label>span{color:#666;font-size:11px;font-weight:900}.accounting-card-wide{grid-column:1 / -1}.accounting-card input,.accounting-card select,.accounting-card button{min-width:0;min-height:30px;padding:5px 7px;background:#fff;font-size:12px}.accounting-card input:disabled,.accounting-card select:disabled,.accounting-card button:disabled{color:#222;opacity:1}.accounting-card label.accounting-card-check{min-height:30px;align-self:stretch;display:flex;align-items:center;justify-content:center;gap:6px;padding:5px 8px;background:#fff;color:#666;font-size:11px;font-weight:900}.accounting-card label.accounting-card-check input{width:16px;height:16px;min-height:0;padding:0;accent-color:#1677ff}.accounting-card-actions{min-width:0;display:grid;grid-template-columns:minmax(0,1fr) 30px;gap:6px}.accounting-card .icon-tool{min-height:30px;padding:0}.accounting-lines{display:grid;gap:6px}.accounting-lines-head{min-width:0;display:flex;align-items:center;justify-content:space-between;gap:8px}.accounting-lines-head span{color:#666;font-size:11px;font-weight:900}.accounting-lines-head button{min-height:28px;display:inline-flex;align-items:center;gap:5px;font-weight:800}.accounting-line-row{min-width:0;display:grid;grid-template-columns:minmax(0,1fr) 72px 30px;gap:6px}.accounting-shipping-row{display:grid;grid-template-columns:48px minmax(0,1fr);align-items:center;gap:6px}.accounting-shipping-check-row{min-width:0;display:grid;grid-template-columns:minmax(0,1fr) 108px;align-items:center;gap:6px}.accounting-shipping-check-row .accounting-shipping-row,.accounting-shipping-check-row .accounting-card-check{min-height:30px}.library-board{height:100vh;min-width:0;overflow:auto;display:grid;grid-template-rows:auto 1fr;align-content:start;gap:14px;padding:18px}.library-topbar{display:flex;align-items:center;gap:12px;min-height:44px}.library-topbar>div:nth-of-type(1){min-width:0}.library-topbar h1,.library-topbar p,.library-detail h2{margin:0}.library-topbar h1{font-size:18px;line-height:1}.library-topbar p{margin-top:4px;color:#555;font-size:12px;font-weight:800}.library-back-button{width:42px;min-height:42px;padding:0;background:#fff}.library-subswitcher{margin-left:auto;display:flex;align-items:center;gap:6px;padding:3px;background:#ececec}.library-subswitcher button{min-height:34px;padding:0 12px;background:transparent;color:#666;font-weight:800}.library-subswitcher button.active{background:#fff;color:#111}.library-card-grid{min-width:0;display:grid;grid-template-columns:repeat(auto-fill,160px);grid-auto-rows:auto;gap:10px;align-content:start}.yarn-view-switcher{width:fit-content;min-width:0;display:inline-flex;gap:4px;padding:4px;background:#ededed}.yarn-view-switcher button{min-height:30px;padding:0 12px;background:transparent;color:#666;font-size:12px;font-weight:900}.yarn-view-switcher button.active{background:#fff;color:#111}.misc-view-switcher{margin-left:auto}.yarn-color-picker-shell{position:relative}.yarn-color-picker-trigger{min-height:38px;display:inline-flex;align-items:center;gap:7px;padding:0 12px;background:#fff;font-size:12px;font-weight:900}.yarn-color-wheel{width:18px;height:18px;border-radius:999px;background:conic-gradient(#f33,#fc3,#3c6,#39f,#93f,#f36,#f33)}.yarn-color-popover{position:absolute;z-index:20;top:calc(100% + 8px);right:0;width:214px;display:grid;gap:8px;padding:10px;background:#fff;box-shadow:0 12px 32px #00000029}.yarn-color-plane{height:132px;position:relative;background:linear-gradient(to top,#000,transparent),linear-gradient(to right,#fff,transparent),linear-gradient(135deg,#e63232,#e7cc45 32%,#47b96f,#377ce2 76%,#874de3)}.yarn-color-plane span{position:absolute;left:58%;top:42%;width:12px;height:12px;border:2px solid #fff;border-radius:999px;box-shadow:0 0 0 1px #00000040}.yarn-color-palette{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}.yarn-color-palette button{width:26px;height:26px;min-height:26px;padding:0;border:2px solid transparent;background:transparent}.yarn-color-palette button.active{border-color:#111}.yarn-color-palette span,.yarn-color-current span{width:100%;height:100%;display:block;border:1px solid #ddd}.yarn-color-current{min-height:34px;display:grid;grid-template-columns:28px 1fr;align-items:center;gap:8px;padding:3px;background:#f5f5f5}.yarn-color-current strong{font-size:12px}.yarn-swatch-card{min-width:0;width:160px;height:auto;padding:0;display:grid;grid-template-rows:auto 46px;gap:0;align-items:stretch;justify-content:stretch;overflow:hidden;background:#fff;border:2px solid transparent;text-align:left}.yarn-swatch-card.is-selected{border-color:#111}.yarn-swatch-add{place-items:center;align-content:center;grid-template-rows:auto 46px;color:#777}.yarn-swatch-add svg{place-self:center;width:160px;height:160px;padding:54px}.yarn-swatch-add span{width:100%;min-height:46px;display:grid;place-items:center;background:#f5f5f5;color:#666;font-size:12px;font-weight:800}.yarn-swatch-media{min-width:0;min-height:0;width:100%;aspect-ratio:1 / 1;overflow:hidden;display:block;background:#f8f8f8}.yarn-swatch-media img,.yarn-swatch-media i,.yarn-swatch-color{width:100%;height:100%;display:block;object-fit:cover}.yarn-swatch-color{display:grid;place-items:center;padding:10px;overflow:hidden;text-align:center;font-size:18px;font-weight:900;line-height:1.1;word-break:break-word}.yarn-swatch-media i{background:linear-gradient(45deg,#f0f0f0 25%,transparent 25%),linear-gradient(-45deg,#f0f0f0 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#f0f0f0 75%),linear-gradient(-45deg,transparent 75%,#f0f0f0 75%);background-color:#fff;background-position:0 0,0 8px,8px -8px,-8px 0;background-size:16px 16px}.yarn-swatch-meta{min-width:0;display:grid;grid-template-columns:1fr auto;align-items:center;gap:8px;padding:6px 8px;background:#f5f5f5}.yarn-swatch-meta>span{min-width:0;display:grid;gap:2px}.yarn-swatch-meta strong,.yarn-swatch-meta em,.yarn-swatch-counts strong,.yarn-swatch-counts em{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.yarn-swatch-meta strong{font-size:12px}.yarn-swatch-meta em{color:#666;font-size:10px;font-style:normal}.yarn-swatch-counts{min-width:34px;text-align:right;justify-items:end}.yarn-swatch-counts strong,.yarn-swatch-counts em{color:#666;font-size:10px;font-weight:400;font-style:normal}.yarn-table-view{min-width:0;display:grid;gap:4px;align-content:start}.yarn-table-row{min-width:0;min-height:38px;display:grid;grid-template-columns:34px minmax(130px,1.4fr) minmax(88px,.9fr) minmax(96px,1fr) 64px 64px 64px;gap:6px;align-items:center;padding:4px 6px;background:#f7f7f7;border:1px solid transparent}.yarn-table-row.is-selected{border-color:#111}.yarn-table-head{min-height:28px;background:transparent;color:#666;font-size:11px;font-weight:900}.yarn-table-row input,.yarn-table-row select{min-height:30px;padding:5px 7px;background:#fff;font-size:12px}.yarn-table-swatch{width:26px;height:26px;min-height:26px;padding:0;border:1px solid #ddd;background:linear-gradient(45deg,#f0f0f0 25%,transparent 25%),linear-gradient(-45deg,#f0f0f0 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#f0f0f0 75%),linear-gradient(-45deg,transparent 75%,#f0f0f0 75%);background-color:#fff;background-position:0 0,0 6px,6px -6px,-6px 0;background-size:12px 12px}.misc-table-view{min-width:0;display:grid;gap:4px;align-content:start}.misc-table-row{min-width:0;min-height:42px;display:grid;grid-template-columns:42px minmax(150px,1fr) minmax(120px,.9fr) 76px 76px;gap:6px;align-items:center;padding:4px 6px;background:#f7f7f7;border:1px solid transparent}.misc-table-row.is-selected{border-color:#111}.misc-table-head{min-height:28px;background:transparent;color:#666;font-size:11px;font-weight:900}.misc-table-row input,.misc-table-row select{min-height:30px;padding:5px 7px;background:#fff;font-size:12px}.misc-table-media{width:32px;height:32px;min-height:32px;padding:0;overflow:hidden;background:#fff}.misc-table-media img,.misc-table-media span{width:100%;height:100%;display:block;object-fit:cover}.misc-table-media span{background:linear-gradient(45deg,#f0f0f0 25%,transparent 25%),linear-gradient(-45deg,#f0f0f0 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#f0f0f0 75%),linear-gradient(-45deg,transparent 75%,#f0f0f0 75%);background-color:#fff;background-position:0 0,0 6px,6px -6px,-6px 0;background-size:12px 12px}.yarn-stock-view,.yarn-group-view,.misc-stock-view{min-width:0;display:grid;gap:10px;align-content:start}.yarn-stock-group{min-width:0;display:grid;gap:4px;padding:10px;background:#fff}.yarn-stock-group h3{margin:0 0 4px;display:flex;align-items:center;justify-content:space-between;color:#111;font-size:13px}.yarn-stock-group h3 span{color:#777;font-size:11px}.yarn-stock-row{min-width:0;min-height:36px;display:grid;grid-template-columns:26px minmax(92px,1fr) minmax(100px,1.4fr) 58px 44px;gap:8px;align-items:center;padding:5px 7px;background:#f7f7f7;border:1px solid transparent;text-align:left}.yarn-stock-row.is-selected{border-color:#111}.yarn-stock-row strong,.yarn-stock-row em,.yarn-stock-row span,.yarn-stock-row b{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.yarn-stock-row strong{font-size:12px}.yarn-stock-row em,.yarn-stock-row span{color:#666;font-size:11px;font-style:normal}.yarn-stock-row b{justify-self:end;font-size:12px}.yarn-stock-swatch{width:24px;height:24px;background:linear-gradient(45deg,#f0f0f0 25%,transparent 25%),linear-gradient(-45deg,#f0f0f0 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#f0f0f0 75%),linear-gradient(-45deg,transparent 75%,#f0f0f0 75%);background-color:#fff;background-position:0 0,0 6px,6px -6px,-6px 0;background-size:12px 12px}.misc-stock-row{min-width:0;min-height:42px;display:grid;grid-template-columns:34px minmax(0,1fr) 44px;grid-template-areas:"media name stock" "media meta stock";gap:2px 8px;align-items:center;padding:6px;background:#f7f7f7;border:1px solid transparent;text-align:left}.misc-stock-row.is-selected{border-color:#111}.misc-stock-media{grid-area:media;width:30px;height:30px;overflow:hidden;display:block;background:#fff}.misc-stock-media img,.misc-stock-media i{width:100%;height:100%;display:block;object-fit:cover}.misc-stock-media i{background:linear-gradient(45deg,#f0f0f0 25%,transparent 25%),linear-gradient(-45deg,#f0f0f0 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#f0f0f0 75%),linear-gradient(-45deg,transparent 75%,#f0f0f0 75%);background-color:#fff;background-position:0 0,0 6px,6px -6px,-6px 0;background-size:12px 12px}.misc-stock-row strong,.misc-stock-row em{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.misc-stock-row strong{grid-area:name;font-size:12px}.misc-stock-row em{grid-area:meta;color:#666;font-size:11px;font-style:normal}.misc-stock-row b{grid-area:stock;justify-self:end;font-size:12px}.color-card-grid{min-width:0;display:grid;grid-template-columns:repeat(auto-fill,220px);grid-auto-rows:auto;gap:12px;align-content:start}.misc-card{min-width:0;width:160px;height:auto;padding:0;display:grid;grid-template-rows:auto 46px;gap:0;align-items:stretch;justify-content:stretch;overflow:hidden;background:#fff;border:2px solid transparent;text-align:left}.misc-card.is-selected{border-color:#111}.misc-card-add{place-items:center;align-content:center;grid-template-rows:auto 46px;color:#777}.misc-card-add svg{place-self:center;width:160px;height:160px;padding:54px}.misc-card-add span{width:100%;min-height:46px;display:grid;place-items:center;background:#f5f5f5;color:#666;font-size:12px;font-weight:800}.misc-card-media{min-width:0;min-height:0;width:100%;aspect-ratio:1 / 1;overflow:hidden;display:block;background:#f8f8f8}.misc-card-media img,.misc-card-media i{width:100%;height:100%;display:block;object-fit:cover}.misc-card-media i,.misc-detail-preview span{background:linear-gradient(45deg,#f0f0f0 25%,transparent 25%),linear-gradient(-45deg,#f0f0f0 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#f0f0f0 75%),linear-gradient(-45deg,transparent 75%,#f0f0f0 75%);background-color:#fff;background-position:0 0,0 8px,8px -8px,-8px 0;background-size:16px 16px}.misc-card-meta{min-width:0;display:grid;grid-template-columns:1fr auto;align-items:center;gap:8px;padding:6px 8px;background:#f5f5f5}.misc-card-meta>span{min-width:0;display:grid;gap:2px}.misc-card-meta strong,.misc-card-meta em,.misc-card-counts strong,.misc-card-counts em{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.misc-card-meta strong{font-size:12px}.misc-card-meta em,.misc-card-counts strong,.misc-card-counts em{color:#666;font-size:10px;font-weight:400;font-style:normal}.misc-card-counts{min-width:34px;text-align:right;justify-items:end}.color-card-book{min-width:0;width:220px;height:auto;padding:0;display:grid;grid-template-rows:150px 54px;gap:0;align-items:stretch;justify-content:stretch;overflow:hidden;background:#fff;border:2px solid transparent;text-align:left}.color-card-book.is-selected{border-color:#111}.color-card-add{place-items:center;align-content:center;grid-template-rows:150px 54px;color:#777}.color-card-add svg{place-self:center;width:220px;height:150px;padding:49px 84px}.color-card-add span{width:100%;min-height:54px;display:grid;place-items:center;background:#f5f5f5;color:#666;font-size:12px;font-weight:800}.color-card-media{min-width:0;min-height:0;display:block;overflow:hidden;background:#f8f8f8}.color-card-media img,.color-card-media i{width:100%;height:100%;display:block;object-fit:cover}.color-card-media i,.color-card-detail-preview span{background:linear-gradient(45deg,#f0f0f0 25%,transparent 25%),linear-gradient(-45deg,#f0f0f0 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#f0f0f0 75%),linear-gradient(-45deg,transparent 75%,#f0f0f0 75%);background-color:#fff;background-position:0 0,0 8px,8px -8px,-8px 0;background-size:16px 16px}.color-card-meta{min-width:0;display:grid;gap:4px;padding:8px 10px;background:#f5f5f5}.color-card-meta strong,.color-card-meta em{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.color-card-meta strong{font-size:13px}.color-card-meta em{color:#666;font-size:11px;font-style:normal}.scheme-card-grid{min-width:0;display:grid;grid-template-columns:repeat(auto-fill,160px);grid-auto-rows:auto;gap:10px;align-content:start}.scheme-card{min-width:0;width:160px;height:auto;padding:0;display:grid;grid-template-rows:auto 46px;gap:0;align-items:stretch;justify-content:stretch;overflow:hidden;background:#fff;border:2px solid transparent;text-align:left}.scheme-card.is-selected{border-color:#111}.scheme-card-add{place-items:center;align-content:center;grid-template-rows:auto 46px;color:#777}.scheme-card-add svg{place-self:center;width:160px;height:160px;padding:54px}.scheme-card-add span{width:100%;min-height:46px;display:grid;place-items:center;background:#f5f5f5;color:#666;font-size:12px;font-weight:800}.scheme-card-media{min-width:0;min-height:0;width:100%;aspect-ratio:1 / 1;display:block;overflow:hidden;background:#f8f8f8}.scheme-card-media img,.scheme-card-media i{width:100%;height:100%;display:block;object-fit:contain}.scheme-card-media i,.scheme-detail-preview span{background:linear-gradient(45deg,#f0f0f0 25%,transparent 25%),linear-gradient(-45deg,#f0f0f0 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#f0f0f0 75%),linear-gradient(-45deg,transparent 75%,#f0f0f0 75%);background-color:#fff;background-position:0 0,0 8px,8px -8px,-8px 0;background-size:16px 16px}.scheme-card-meta{min-width:0;display:grid;gap:2px;padding:6px 8px;background:#f5f5f5}.scheme-card-meta strong,.scheme-card-meta em{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.scheme-card-meta strong{font-size:12px}.scheme-card-meta em{color:#666;font-size:10px;font-style:normal}.scheme-empty{width:160px;min-height:206px;display:grid;place-items:center;align-content:center;gap:6px;padding:18px 14px;background:#fff;color:#777;text-align:center}.scheme-empty svg{width:34px;height:34px;stroke-width:1.7;margin-bottom:4px}.scheme-empty strong{color:#111;font-size:13px;line-height:1.25}.scheme-empty span{color:#666;max-width:112px;font-size:11px;line-height:1.45}.scheme-detail-preview{width:100%;aspect-ratio:4 / 3;padding:0;background:#fff;overflow:hidden}.scheme-detail-preview img,.scheme-detail-preview span{width:100%;height:100%;display:block;object-fit:contain}.scheme-stage-tools{display:grid;gap:6px}.scheme-stage-row{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:4px}.scheme-stage-row button{min-width:0;min-height:30px;padding:0 4px;background:#f2f2f2;color:#666;font-size:11px;font-weight:800}.scheme-stage-row button.active{background:#111;color:#fff}.scheme-schedule-link{width:100%;min-height:32px;background:#f7f7f7;font-size:12px;font-weight:900}.scheme-detail-section{display:grid;gap:8px}.scheme-detail-section h3{margin:0;color:#111;font-size:12px;font-weight:900}.scheme-detail-section-head{display:flex;align-items:center;gap:8px}.scheme-detail-section-head h3{flex:1}.scheme-detail-section-head button{min-height:28px;padding:0 9px;background:#f7f7f7;font-size:11px;font-weight:900}.scheme-source-file-list{display:grid;gap:4px}.scheme-source-file-list button{min-width:0;min-height:34px;display:grid;grid-template-columns:18px minmax(0,1fr) auto;justify-content:stretch;gap:7px;padding:6px 8px;background:#f7f7f7;text-align:left}.scheme-source-file-list strong,.scheme-source-file-list span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:11px}.scheme-source-file-list span{color:#666;font-weight:800}.scheme-final-photo{width:100%;aspect-ratio:4 / 3;overflow:hidden;background:#fff}.scheme-final-photo img{width:100%;height:100%;display:block;object-fit:cover}.scheme-source-inline{display:grid;gap:4px}.scheme-source-inline span,.scheme-source-inline button{min-height:28px;justify-content:flex-start;padding:5px 8px;background:#f7f7f7;color:#666;font-size:11px;font-weight:900}.scheme-source-inline button{color:#111}.scheme-color-strip{display:grid;grid-template-columns:repeat(9,1fr);gap:4px}.scheme-color-strip span{aspect-ratio:1 / 1;display:block;background:linear-gradient(45deg,#f0f0f0 25%,transparent 25%),linear-gradient(-45deg,#f0f0f0 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#f0f0f0 75%),linear-gradient(-45deg,transparent 75%,#f0f0f0 75%);background-color:#fff;background-position:0 0,0 5px,5px -5px,-5px 0;background-size:10px 10px}.scheme-yarn-list{display:grid;gap:4px}.scheme-yarn-list p{margin:0;min-height:28px;display:grid;grid-template-columns:22px 1fr;align-items:center;gap:8px;padding:4px 6px;background:#f7f7f7}.scheme-yarn-list span{width:20px;height:20px;display:grid;place-items:center;background:#fff;border:1px solid #d8d8d8;color:#111;font-size:11px;font-weight:900}.scheme-yarn-list strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}.library-detail{height:100vh;overflow:auto;padding:18px;display:flex;flex-direction:column;gap:12px;background:#f4f4f4}.library-detail-head{min-height:42px;display:flex;align-items:center;justify-content:space-between;gap:10px}.library-detail-head h2{display:flex;align-items:center;gap:8px;font-size:16px}.library-detail .form-stack{padding:12px;background:#fff}.library-detail-empty{min-height:240px;display:grid;place-items:center;align-content:center;gap:10px;background:#fff;color:#777}.library-detail-empty strong{color:#111;font-size:16px}.left-rail,.right-rail,.editor-panel{height:100vh;overflow:auto;padding:16px;display:flex;flex-direction:column;gap:14px;border-color:var(--line)}.left-rail{border-right:0;background:var(--rail)}.right-rail{border-left:0;background:var(--rail)}.editor-panel{background:var(--rail)}.yarn-config-panel{border-left:0;overflow:hidden;gap:5px;padding:9px 2.5px 9px 9px}.scheme-detail-panel{border-left:0;gap:5px;padding:9px 9px 9px 2.5px;overflow:hidden}.scheme-detail-panel .panel{min-height:0;overflow:visible}.scheme-detail-panel .panel:last-of-type{flex:1 1 auto;overflow:auto}.brand-block{display:flex;align-items:center;gap:10px;min-height:52px}.brand-mark{width:36px;height:36px;border-radius:0;display:grid;place-items:center;color:#fff;font-weight:800;background:var(--ink)}.brand-block h1,.brand-block p,.panel h2,.note-list p{margin:0}.brand-block h1{font-size:17px;line-height:1.1}.brand-block p{color:var(--muted);font-size:11px;margin-top:4px}.panel{min-width:0;border:0;border-radius:0;background:var(--panel);padding:12px;display:flex;flex-direction:column;gap:10px}@media(max-width:980px){.inventory-shell{grid-template-columns:1fr}.inventory-board,.inventory-ledger{height:auto;min-height:0}}.panel h2{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:800}.field-label,.form-stack label{display:grid;gap:6px;color:var(--muted);font-size:11px;font-weight:700}.date-field{position:relative}.date-trigger{width:100%;min-height:38px;justify-content:space-between;padding:0 9px;background:#f7f7f7}.date-trigger strong{font-size:13px;font-weight:800}.date-popover{position:absolute;top:calc(100% + 5px);left:0;z-index:6;width:min(100%,320px);min-height:300px;padding:18px 20px 22px;border-top:1px solid #bdbdbd;background:#fffef8;color:#111;box-shadow:0 16px 36px #00000014}.date-popover-head{display:grid;grid-template-columns:34px 1fr 34px;align-items:center;margin-bottom:18px}.date-popover-head strong{text-align:center;font-size:20px;font-weight:500;letter-spacing:0}.date-popover-head .icon-tool{width:34px;min-height:34px;padding:0;background:transparent}.date-week-row,.date-day-grid{display:grid;grid-template-columns:repeat(7,1fr);align-items:center;text-align:center}.date-week-row{margin-bottom:8px;color:#888;font-size:16px;font-weight:700}.date-week-row span,.date-day-grid button,.date-day-grid span{min-width:0;height:35px;display:grid;place-items:center}.date-day-grid button{padding:0;background:transparent;border:0;font-size:17px;font-weight:500}.date-day-grid button.selected{background:#111;color:#fff}.primary-action{min-height:36px;border-color:#111;background:#111;color:#fff;font-weight:800}.primary-action svg{width:16px;height:16px}.flow-panel{gap:8px}.flow-step{display:grid;grid-template-columns:24px 1fr;gap:8px;align-items:center}.flow-step span{width:24px;height:24px;border-radius:0;background:#e7e7e7;color:var(--ink);display:grid;place-items:center;font-size:12px;font-weight:800}.flow-step p{margin:0;color:var(--muted);font-size:13px}.action-grid{display:grid;grid-template-columns:1fr}.project-file-menu{display:grid;gap:8px}.project-file-menu summary{min-height:36px;border:1px solid transparent;border-radius:0;background:#f7f7f7;color:var(--ink);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:13px;font-weight:800}.project-file-menu[open] summary{margin-bottom:8px}.repair-panel{gap:6px}.repair-panel h2{margin-bottom:2px}.repair-panel button{justify-content:flex-start}.tool-toggle{min-height:34px;justify-content:space-between;background:#f7f7f7;padding:0 10px}.mode-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.mode-row button{justify-content:center;min-height:34px}.workspace{height:100vh;min-width:0;display:grid;grid-template-rows:50px 1fr}.workspace-toolbar{display:flex;align-items:center;gap:12px;padding:10px 16px;border-bottom:0;background:#fff}.workspace-back-button{width:34px;min-height:34px;padding:0;background:#f7f7f7}.segmented,.toolbar-actions,.button-row,.count-picker{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.segmented{padding:3px;background:#f0f0f0;border-radius:0}.toolbar-actions{margin-left:auto}.segmented button,.count-picker button{border:0;background:transparent;min-height:28px}.segmented button.active,.count-picker button.active,.active-tool{background:#fff;box-shadow:none;color:var(--ink);outline:0;font-weight:800}.toggle{display:flex;align-items:center;gap:6px;color:var(--ink);font-size:13px;font-weight:700}.toggle input{width:auto}.canvas-stage{position:relative;overflow:auto;display:grid;place-items:center;padding:24px;background:var(--canvas)}.canvas-stage.is-coding-view{place-items:start center;padding-top:24px}.canvas-stage.is-library-view{display:block;padding:18px}canvas{max-width:100%;max-height:calc(100vh - 104px);background:#fff;box-shadow:none;border:0;touch-action:none}.is-manual-mode canvas{cursor:var(--placement-cursor),pointer}.is-sampling-color canvas{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='28' height='28' viewBox='0 0 28 28'%3E%3Cg fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 3l5 5-9 9-5-5 9-9z' fill='white'/%3E%3Cpath d='M12 16l-6 6'/%3E%3Cpath d='M4 24h6'/%3E%3C/g%3E%3C/svg%3E") 6 22,copy}.is-sampling-color .canvas-code-step{border-color:#111;border-style:dashed}.canvas-code-step{min-width:56px;min-height:32px;padding:4px 8px;display:flex;align-items:center;justify-content:center;gap:8px;background:#fff;border:1px solid transparent}.placement-tool{position:relative}.tool-plus-mark{position:absolute;right:5px;bottom:4px;width:10px;height:10px;padding:1px;background:#fff;border:1px solid #111}.canvas-code-target{min-width:0;display:grid;grid-template-columns:22px auto;align-items:center;gap:7px;padding:5px 7px;background:#f7f7f7;border:1px solid transparent}.canvas-code-target.is-active{border-color:#111;background:#fff}.canvas-code-target em{color:var(--ink);font-size:12px;font-style:normal;font-weight:900}.yarn-config-head{min-width:0;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px}.yarn-config-tools{display:flex;align-items:center;gap:6px}.yarn-config-tools .icon-tool{width:32px;min-height:32px;padding:0}.yarn-config-sampling,.yarn-config-target{min-height:32px;display:inline-flex;align-items:center;gap:7px;padding:0 8px;background:#fff;border:1px solid transparent}.yarn-config-sampling{border-color:#111;border-style:dashed}.yarn-config-target em{color:var(--ink);font-size:12px;font-style:normal;font-weight:900}.empty-code-badge{background:#fff;color:var(--muted)}.empty-state{width:min(620px,86%);min-height:320px;display:grid;place-items:center;align-content:center;gap:14px;border:1px dashed #d0d0d0;background:#fff;color:var(--ink)}.empty-state strong{font-size:22px}.empty-state span{color:var(--muted)}.busy-mask{position:absolute;inset:0;display:grid;place-items:center;background:#ffffffbd;color:var(--ink);font-weight:800}.analysis-list{display:grid;gap:8px;margin:0}.analysis-list div{display:flex;justify-content:space-between;gap:12px;border-bottom:0;padding-bottom:6px}.analysis-list dt{color:var(--muted);font-size:12px}.analysis-list dd{margin:0;font-size:12px;font-weight:800}.muted{color:var(--muted);font-size:12px;margin:0}.range-row{display:grid;grid-template-columns:60px 1fr 28px;gap:8px;align-items:center;color:var(--muted);font-size:11px;font-weight:700}.range-row em{color:var(--ink);font-style:normal;text-align:right}.block-list{max-height:clamp(180px,calc(100vh - 208px),720px);overflow:auto;display:flex;flex-direction:column;gap:6px}.block-chip-row{min-height:58px;overflow:hidden;display:grid;grid-template-columns:36px minmax(170px,1fr) 38px 56px 30px;gap:0;background:#f7f7f7}.block-chip-swatch{min-width:0;min-height:58px;padding:0;border:0;background:transparent;width:100%}.block-yarn-name{min-width:0;min-height:58px;display:grid;align-content:center;gap:3px;justify-content:flex-start;padding:0 10px;border:0;background:transparent;overflow:hidden;text-align:left}.block-yarn-name:disabled{opacity:1;cursor:default}.block-yarn-name.has-yarn{cursor:pointer}.block-yarn-name strong,.block-yarn-name em{min-width:0;display:block;overflow:visible;white-space:normal}.block-yarn-name strong{font-size:13px;line-height:1.05;font-weight:900}.block-yarn-name em{color:#777;font-size:11px;line-height:1.05;font-style:normal;font-weight:800}.block-yarn-usage{min-height:58px;padding:0 4px;border:0;background:transparent;text-align:right;font-size:12px;font-weight:800}.block-yarn-usage::placeholder{color:#999}.block-yarn-stock{min-width:0;min-height:58px;display:grid;place-items:center end;padding:0 5px 0 0;color:#9a9a9a;font-size:11px;font-weight:800;white-space:nowrap}.block-yarn-stock.is-short{color:#d11}.block-chip-jump{width:30px;min-height:58px;padding:0;background:transparent}.block-chip-row .code-badge{flex:0 0 20px;width:20px;height:20px;display:grid;place-items:center;border-radius:0;border:1px solid rgba(0,0,0,.18);color:#111;font-size:11px;font-weight:900}.code-badge{width:22px;height:22px;display:grid;place-items:center;border:1px solid rgba(0,0,0,.22);color:#111;font-size:11px;font-weight:900}.code-badge.no-color{background:linear-gradient(45deg,#f0f0f0 25%,transparent 25%),linear-gradient(-45deg,#f0f0f0 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#f0f0f0 75%),linear-gradient(-45deg,transparent 75%,#f0f0f0 75%);background-color:#fff;background-position:0 0,0 6px,6px -6px,-6px 0;background-size:12px 12px;color:#111;border-style:dashed}.empty-color-input{min-height:38px;border:1px dashed #aaa;background:linear-gradient(45deg,#f0f0f0 25%,transparent 25%),linear-gradient(-45deg,#f0f0f0 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#f0f0f0 75%),linear-gradient(-45deg,transparent 75%,#f0f0f0 75%);background-color:#fff;background-position:0 0,0 8px,8px -8px,-8px 0;background-size:16px 16px}.block-chip-row.selected{border-color:transparent;background:#eee}.yarn-binding-panel{display:grid;gap:8px}.yarn-binding-panel h3{margin:0;color:#111;font-size:12px;font-weight:900}.selected-yarn-summary{min-width:0;display:grid;grid-template-columns:44px 1fr;align-items:center;gap:8px;padding:8px;background:#f7f7f7}.selected-yarn-swatch,.yarn-picker-swatch{display:grid;place-items:center;background:linear-gradient(45deg,#f0f0f0 25%,transparent 25%),linear-gradient(-45deg,#f0f0f0 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#f0f0f0 75%),linear-gradient(-45deg,transparent 75%,#f0f0f0 75%);background-color:#fff;background-position:0 0,0 6px,6px -6px,-6px 0;background-size:12px 12px;border:1px solid rgba(0,0,0,.16);font-size:11px;font-weight:900}.selected-yarn-swatch{width:44px;height:44px}.selected-yarn-summary div{min-width:0;display:grid;gap:3px}.selected-yarn-summary strong,.selected-yarn-summary em{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.selected-yarn-summary em{color:var(--muted);font-size:11px;font-style:normal}.yarn-picker-grid{max-height:240px;overflow:auto;display:grid;gap:6px}.yarn-picker-card{min-width:0;min-height:52px;display:grid;grid-template-columns:36px 1fr;grid-template-rows:1fr 1fr;align-items:center;justify-content:stretch;gap:0 8px;padding:6px;text-align:left;background:#f7f7f7;border:2px solid transparent}.yarn-picker-card.is-selected{border-color:#111;background:#fff}.yarn-picker-swatch{grid-row:1 / span 2;width:36px;height:36px}.yarn-picker-card strong,.yarn-picker-card em{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.yarn-picker-card strong{font-size:12px}.yarn-picker-card em{color:var(--muted);font-size:11px;font-style:normal}.yarn-picker-empty{min-height:40px;justify-content:flex-start}.form-stack{display:grid;gap:8px}.library-workspace{min-height:calc(100vh - 86px);display:grid;grid-template-rows:auto auto auto 1fr;gap:14px}.library-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px;background:#fff}.library-header h2,.library-header p{margin:0}.library-header h2{font-size:22px;line-height:1.1}.library-header p{margin-top:5px;color:var(--muted);font-size:12px}.library-overview{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.library-overview div{display:grid;gap:8px;padding:14px;background:#fff}.library-overview span{color:var(--muted);font-size:12px;font-weight:800}.library-overview strong{font-size:30px;line-height:1}.library-filter-row{display:grid;grid-template-columns:minmax(220px,1fr) auto;gap:10px;align-items:center}.library-search{min-width:0;display:grid;grid-template-columns:20px 1fr;align-items:center;gap:8px;padding:0 10px;background:#fff}.library-search input{border:0;background:transparent;min-height:38px;padding-left:0}.library-filter-row>span{min-height:38px;display:inline-flex;align-items:center;gap:7px;padding:0 12px;background:#fff;color:var(--muted);font-weight:800}.library-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(172px,1fr));gap:12px;align-content:start;overflow:auto}.library-card{min-width:0;height:248px;padding:0;display:grid;grid-template-rows:162px 1fr;align-items:stretch;justify-content:stretch;overflow:hidden;background:#fff;border:1px solid transparent;text-align:left}.library-card.is-selected{border-color:#111}.library-card-image{min-width:0;min-height:0;display:block;background:#f2f2f2}.library-card-image img,.library-card-image i{width:100%;height:100%;display:block;object-fit:cover}.library-card-image i,.yarn-detail-preview span{background:linear-gradient(45deg,#f0f0f0 25%,transparent 25%),linear-gradient(-45deg,#f0f0f0 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#f0f0f0 75%),linear-gradient(-45deg,transparent 75%,#f0f0f0 75%);background-color:#fff;background-position:0 0,0 8px,8px -8px,-8px 0;background-size:16px 16px}.library-card-body{min-width:0;display:grid;gap:4px;padding:10px}.library-card-body strong,.library-card-body em,.library-card-body small{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.library-card-body strong{font-size:13px}.library-card-body em,.library-card-body small{color:var(--muted);font-size:11px;font-style:normal}.library-empty{place-self:center}.yarn-image-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.yarn-image-tile{min-width:0;display:grid;gap:6px}.yarn-image-label{color:var(--muted);font-size:11px;font-weight:800}.yarn-image-tile>button:not(.yarn-detail-preview){min-width:0;min-height:30px;padding:0 6px;font-size:12px}.yarn-detail-preview{width:100%;aspect-ratio:1;min-height:0;padding:0;border:0;background:#fff;overflow:hidden}.yarn-detail-preview img,.yarn-detail-preview span{width:100%;height:100%;display:block;object-fit:cover}.yarn-color-code-control{position:relative;min-height:58px;display:grid;grid-template-columns:58px 1fr;align-items:stretch;overflow:hidden;background:#f7f7f7}.yarn-color-code-control.has-color{border:1px solid rgba(0,0,0,.08)}.yarn-color-picker-button{min-width:0;min-height:58px;padding:0;border:0;background:#ffffff47;color:inherit;font-size:12px;font-weight:900}.yarn-color-native-input{position:absolute;left:0;top:0;width:58px;height:58px;opacity:0;cursor:pointer}.yarn-color-code-input{min-height:58px;border:0;background:transparent;color:inherit;font-size:18px;font-weight:900}.yarn-color-code-input::placeholder{color:currentColor;opacity:.62}.color-card-detail-preview{width:100%;aspect-ratio:4 / 3;background:#fff;overflow:hidden}.color-card-detail-preview img,.color-card-detail-preview span,.misc-detail-preview img,.misc-detail-preview span{width:100%;height:100%;display:block;object-fit:cover}.misc-detail-preview{width:100%;aspect-ratio:1;background:#fff;overflow:hidden}.yarn-library-panel{gap:8px}.yarn-library-list{display:grid;gap:8px;max-height:300px;overflow:auto}.yarn-library-item{display:grid;grid-template-columns:72px 1fr;gap:8px;padding:8px;background:#f7f7f7}.yarn-thumb{width:72px;height:72px;min-height:72px;padding:0;overflow:hidden;background:#fff}.yarn-thumb img,.yarn-thumb span{width:100%;height:100%;display:block;object-fit:cover}.yarn-thumb span{background:linear-gradient(45deg,#f0f0f0 25%,transparent 25%),linear-gradient(-45deg,#f0f0f0 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#f0f0f0 75%),linear-gradient(-45deg,transparent 75%,#f0f0f0 75%);background-color:#fff;background-position:0 0,0 8px,8px -8px,-8px 0;background-size:16px 16px}.yarn-library-fields{min-width:0;display:grid;gap:6px}.mini-field-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.yarn-library-fields input{min-height:28px;padding:5px 7px;background:#fff;font-size:12px}.yarn-library-actions{display:grid;grid-template-columns:1fr 32px;gap:6px}.yarn-library-actions button{min-height:28px}.check-row{display:flex!important;grid-template-columns:none!important;align-items:center;gap:8px;color:var(--ink)!important}.check-row input{width:auto}.note-list{display:grid;gap:8px;max-height:180px;overflow:auto}.note-list p{border-left:3px solid var(--ink);padding:7px 8px;background:#f2f2f2;color:#333;font-size:12px;line-height:1.45}.inline-tool-settings{display:grid;gap:10px;margin-top:8px;padding-top:10px;background:#fff}
