:root{color:#222;background:#eef2f3;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,textarea,select{font:inherit}.app-shell{display:flex;min-height:100vh;align-items:flex-start;justify-content:center;padding:28px}.workspace{display:grid;width:min(1480px,100%);grid-template-columns:minmax(240px,300px) minmax(0,1fr) minmax(280px,340px);gap:20px;align-items:start}.project-panel,.chart-stage,.info-panel{border:1px solid #d7d9cd;border-radius:8px;background:#fff;padding:24px;box-shadow:0 18px 50px #22222214}.info-panel{position:sticky;top:28px}.eyebrow{margin:0 0 10px;color:#7d3f24;font-size:.78rem;font-weight:700;letter-spacing:0;text-transform:uppercase}h1{margin:0;color:#18322d;font-size:clamp(1.6rem,3vw,2.1rem);line-height:1.1;letter-spacing:0}.project-title{display:block}.project-title__input{width:100%;margin:0;border:1px solid transparent;border-radius:6px;background:transparent;padding:2px 6px;color:inherit;font:inherit;letter-spacing:inherit}.project-title__input:hover{border-color:#d7d9cd;background:#fafaf7}.project-title__input:focus{border-color:#0f6b5c;background:#fff;outline:none}h2{margin:0;color:#18322d;font-size:1.2rem;line-height:1.15;letter-spacing:0}.current-tool{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:20px 0 4px}.current-tool__item{display:flex;align-items:center;gap:10px;min-width:0;border:1px solid #e2e4d8;border-radius:8px;padding:10px 12px;background:#fafaf7}.current-tool__glyph,.current-tool__swatch{flex:none;width:30px;height:30px;border:1px solid #d8ddd3;border-radius:6px;background:#fff}.current-tool__glyph{display:grid;place-items:center;color:#15231f}.current-tool__glyph svg{width:22px;height:22px}.current-tool__swatch{border-color:#5f6862}.current-tool__text{display:grid;gap:2px;min-width:0}.current-tool__label{color:#696f66;font-size:.72rem;font-weight:800;text-transform:uppercase}.current-tool__text strong{overflow:hidden;color:#1f2a26;font-size:.95rem;font-weight:800;text-overflow:ellipsis;white-space:nowrap}.panel-section{margin-top:12px;border:1px solid #e2e4d8;border-radius:8px;background:#fafaf7}.panel-section[open]{background:#fff}.panel-section__summary{display:flex;align-items:center;gap:10px;padding:12px 14px;cursor:pointer;color:#18322d;font-size:1.05rem;font-weight:800;list-style:none;-webkit-user-select:none;user-select:none}.panel-section__summary::-webkit-details-marker{display:none}.panel-section__summary:hover{background:#f1f4ee;border-radius:8px}.panel-section__summary:focus-visible{outline:3px solid #0f6b5c;outline-offset:-3px;border-radius:8px}.panel-section__title{flex:1;min-width:0}.panel-section__chevron{flex:none;width:9px;height:9px;border-right:2px solid #5b6760;border-bottom:2px solid #5b6760;transform:rotate(-45deg);transition:transform .15s ease}.panel-section[open] .panel-section__chevron{transform:rotate(45deg)}.panel-section__body{padding:0 14px 14px}.colors-toolbar{display:flex;justify-content:flex-end;margin-bottom:10px}.chart-stage{min-width:0}.chart-stage__header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px}.chart-stage__actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:8px 12px}.chart-stage__divider{align-self:stretch;width:1px;min-height:24px;background:#d7d9cd}.chart-name{min-width:0}.chart-name__heading{margin:0}.chart-name__input{width:100%;max-width:360px;margin:0;border:1px solid transparent;border-radius:6px;background:transparent;padding:2px 6px;color:inherit;font:inherit}.chart-name__input:hover{border-color:#d7d9cd;background:#fafaf7}.chart-name__input:focus{border-color:#0f6b5c;background:#fff;outline:none}.chart-tabs{display:flex;flex-wrap:wrap;align-items:center;gap:4px;margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid #e2e4d8}.chart-tab{display:flex;align-items:center;border:1px solid #d7d9cd;border-radius:8px;background:#f3f4ef}.chart-tab--active{border-color:#0f6b5c;background:#e9f4f1}.chart-tab__select{max-width:170px;overflow:hidden;border:none;background:none;color:#1e2a26;cursor:pointer;padding:7px 6px 7px 11px;font-size:.86rem;font-weight:700;text-overflow:ellipsis;white-space:nowrap}.chart-tab--active .chart-tab__select{color:#0f6b5c}.chart-tab__duplicate,.chart-tab__delete{border:none;background:none;color:#828c84;cursor:pointer;padding:4px 6px;font-size:.9rem;line-height:1}.chart-tab__delete{padding-right:9px}.chart-tab__duplicate:hover{color:#1e2a26}.chart-tab__delete:hover{color:#9f2f22}.chart-tabs__add{min-width:32px;min-height:32px;border:1px dashed #c2c9bd;border-radius:8px;background:#fff;color:#4f5b55;cursor:pointer;font-size:1.1rem;font-weight:700}.tool-section{margin-top:26px}.tool-section h2,.section-heading h2{margin-bottom:12px}.section-heading{display:flex;align-items:baseline;justify-content:space-between;gap:12px}.small-action-button{min-height:30px;border:1px solid #ccd2c7;border-radius:6px;background:#fff;color:#1e2a26;cursor:pointer;padding:0 10px;font-size:.82rem;font-weight:800}.save-status{border-radius:999px;padding:3px 8px;background:#eef2f3;color:#4f5b55;font-size:.72rem;font-weight:800;text-transform:uppercase}.save-status--saved{background:#e9f4f1;color:#0f6b5c}.save-status--saving,.save-status--loading{background:#fff3d8;color:#7d3f24}.save-status--error{background:#f9e1df;color:#8f1f16}.symbol-palette{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.symbol-button,.project-actions button,.project-list button,.history-controls button,.export-controls button,.pan-controls button{min-height:36px;border:1px solid #ccd2c7;border-radius:6px;background:#fff;color:#1e2a26;cursor:pointer}.symbol-button{display:grid;grid-template-columns:30px minmax(0,1fr);align-items:center;gap:8px;padding:6px 8px;text-align:left}.symbol-button--active{border-color:#0f6b5c;background:#e9f4f1;box-shadow:inset 0 0 0 1px #0f6b5c}.symbol-button__glyph{display:grid;width:28px;height:28px;place-items:center;border:1px solid #d8ddd3;background:#fff;color:#15231f}.symbol-button__glyph svg{width:22px;height:22px}.symbol-button__text{overflow:hidden;font-size:.86rem;font-weight:700;text-overflow:ellipsis;white-space:nowrap}.symbol-legend{margin-top:12px;border:1px solid #e2e4d8;border-radius:6px;background:#fafaf7;padding:10px}.symbol-legend h3{margin:0 0 8px;color:#18322d;font-size:.92rem}.symbol-legend p{margin:0;color:#64716b;font-size:.84rem;font-weight:800}.symbol-legend ul{display:grid;gap:6px;margin:0;padding:0;list-style:none}.symbol-legend li{display:grid;grid-template-columns:30px minmax(0,1fr);align-items:center;gap:8px;color:#1e2a26;font-size:.84rem;font-weight:700}.symbol-legend strong{display:inline-block;min-width:36px;margin-right:8px;font-weight:900}.symbol-legend__glyph{display:grid;width:26px;height:26px;place-items:center;border:1px solid #d8ddd3;background:#fff;color:#15231f}.symbol-legend__glyph svg{width:20px;height:20px}.color-swatch{display:inline-block;width:22px;height:22px;border:1px solid #5f6862;border-radius:4px}.color-swatch--background{background:linear-gradient(45deg,#d7d9cd 25%,transparent 25%),linear-gradient(-45deg,#d7d9cd 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#d7d9cd 75%),linear-gradient(-45deg,transparent 75%,#d7d9cd 75%);background-color:#fff;background-position:0 0,0 10px,10px -10px,-10px 0;background-size:20px 20px}.palette{display:grid;gap:6px;margin-top:4px}.palette-row{display:grid;grid-template-columns:auto 40px minmax(0,1fr) auto;align-items:center;gap:8px;border:1px solid transparent;border-radius:6px;padding:3px 6px}.palette-row--option{cursor:pointer;font-size:.86rem;font-weight:800}.palette-row--active{border-color:#0f6b5c;background:#e9f4f1}.palette-row:focus-within:not(.palette-row--active){border-color:#cfd5c9;background:#fafaf7}.palette-row__radio{width:16px;height:16px;margin:0;accent-color:#0f6b5c;cursor:pointer}.palette-row__color{width:40px;min-height:32px;border:1px solid #ccd2c7;border-radius:6px;padding:2px;background:#fff;cursor:pointer}.palette-row__name{min-width:0;min-height:32px;border:1px solid #ccd2c7;border-radius:6px;padding:4px 8px;background:#fff}.palette-row__name--static{border:none;padding:0;background:none;color:#1e2a26}.palette-row__remove{min-height:32px;border:1px solid #ccd2c7;border-radius:6px;background:#fff;color:#1e2a26;cursor:pointer;padding:0 10px;font-weight:800}.empty-state{margin:0;border:1px dashed #c9d0c5;border-radius:6px;background:#fafaf7;color:#65716b;padding:10px;font-size:.84rem;font-weight:800}.contrast-warning-list{display:grid;gap:6px;margin:10px 0 0;border:1px solid #dfb19c;border-radius:6px;background:#fff6ef;color:#783713;padding:10px 10px 10px 28px;font-size:.82rem;font-weight:800}.color-legend{margin-top:12px;border:1px solid #e2e4d8;border-radius:6px;background:#fafaf7;padding:10px}.color-legend h3{margin:0 0 8px;color:#18322d;font-size:.92rem}.color-legend p{margin:0;color:#64716b;font-size:.84rem;font-weight:800}.color-legend ul{display:grid;gap:6px;margin:0;padding:0;list-style:none}.color-legend li{display:flex;align-items:center;gap:8px;color:#1e2a26;font-size:.86rem;font-weight:800}.history-controls{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.history-controls button,.project-actions button,.project-list button,.export-controls button,.pan-controls button{padding:0 12px;font-weight:700}.history-controls button:disabled{cursor:not-allowed;opacity:.45}.project-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.persistence-error{margin:10px 0 0;border:1px solid #e6aaa5;border-radius:6px;background:#fff2f1;color:#7b241c;padding:8px 10px;font-size:.84rem;font-weight:700}.project-actions .project-actions__open{grid-column:1 / -1;border-color:#0f6b5c;background:#e9f4f1;font-weight:800}.project-actions button:disabled{cursor:not-allowed;opacity:.45}.project-summary{margin:12px 0 0;color:#4f5b55;font-size:.84rem;font-weight:700}.project-badge{display:inline-block;border-radius:999px;background:#0f6b5c;color:#fff;padding:1px 8px;font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.02em}.modal-overlay{position:fixed;inset:0;z-index:50;display:grid;place-items:center;padding:24px;background:#141c1973}.modal{display:flex;width:min(560px,100%);max-height:min(80vh,680px);flex-direction:column;border:1px solid #d7d9cd;border-radius:12px;background:#fff;padding:20px;box-shadow:0 24px 70px #141c194d}.modal__header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.modal__header h2{font-size:1.3rem}.modal__close{display:grid;width:32px;height:32px;place-items:center;border:1px solid #ccd2c7;border-radius:8px;background:#fff;color:#1e2a26;cursor:pointer;font-size:1.2rem;line-height:1}.modal__toolbar{display:flex;flex-wrap:wrap;align-items:end;gap:10px;margin-bottom:14px}.modal__search{flex:1;min-width:160px;min-height:38px;border:1px solid #ccd2c7;border-radius:8px;background:#fff;padding:6px 10px}.modal__sort{display:grid;gap:4px;color:#4f5b55;font-size:.76rem;font-weight:800}.modal__sort select{min-height:38px;border:1px solid #ccd2c7;border-radius:8px;background:#fff;padding:0 8px}.manager-list{display:grid;gap:8px;margin:0;padding:0;overflow:auto;list-style:none}.manager-list li{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid #e2e4d8;border-radius:8px;background:#fafaf7;padding:10px 12px}.manager-list__item--current{border-color:#0f6b5c;background:#e9f4f1}.manager-list__meta{min-width:0}.manager-list__title{display:flex;align-items:center;gap:8px}.manager-list__title strong{overflow:hidden;color:#1e2a26;font-size:.95rem;text-overflow:ellipsis;white-space:nowrap}.manager-list__date{display:block;margin-top:2px;color:#67736e;font-size:.76rem}.manager-list__actions{display:flex;flex:none;gap:6px}.manager-list__actions button{min-height:34px;border:1px solid #ccd2c7;border-radius:6px;background:#fff;color:#1e2a26;cursor:pointer;padding:0 12px;font-weight:700}.manager-list__actions button:disabled{cursor:not-allowed;opacity:.45}.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}.gauge-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.gauge-form label{display:grid;gap:5px;color:#4f5b55;font-size:.8rem;font-weight:700}.gauge-form input,.gauge-form select{width:100%;min-height:34px;border:1px solid #ccd2c7;border-radius:6px;background:#fff;padding:4px 8px}.details-form{display:grid;gap:10px}.details-form label{display:grid;gap:5px;color:#4f5b55;font-size:.8rem;font-weight:700}.details-form input,.details-form select,.details-form textarea{width:100%;min-height:34px;border:1px solid #ccd2c7;border-radius:6px;background:#fff;padding:6px 8px;color:#1e2a26}.details-form textarea{min-height:64px;resize:vertical}.chart-controls{display:flex;flex-wrap:wrap;align-items:end;gap:12px;margin-bottom:14px;padding:12px;border:1px solid #e2e4d8;border-radius:8px;background:#fafaf7}.chart-controls label{display:grid;gap:5px;color:#4f5b55;font-size:.8rem;font-weight:700}.chart-controls input[type=number]{width:76px;min-height:34px;border:1px solid #ccd2c7;border-radius:6px;padding:4px 8px}.zoom-cluster{display:grid;gap:5px}.zoom-cluster__label{color:#4f5b55;font-size:.8rem;font-weight:700}.zoom-cluster__buttons{display:flex;gap:4px}.zoom-cluster__buttons button{min-width:36px;min-height:34px;border:1px solid #ccd2c7;border-radius:6px;background:#fff;color:#1e2a26;cursor:pointer;padding:0 8px;font-weight:700}.zoom-cluster__value{min-width:58px;font-variant-numeric:tabular-nums}.export-controls{display:flex;flex-wrap:wrap;gap:6px}.chart-hint{margin:0 0 10px;color:#6a766f;font-size:.78rem;font-weight:600}.repeat-controls{display:flex;align-items:end;gap:6px;color:#4f5b55;font-size:.8rem;font-weight:700}.repeat-controls__label,.repeat-controls__to{align-self:end;padding-bottom:8px}.repeat-controls__to{font-weight:600}.repeat-controls input[type=number]{width:58px;min-height:34px;border:1px solid #ccd2c7;border-radius:6px;padding:4px 8px}.repeat-controls button{min-height:34px;border:1px solid #ccd2c7;border-radius:6px;background:#fff;color:#1e2a26;cursor:pointer;padding:0 10px;font-weight:700}.repeat-controls button:disabled{opacity:.5;cursor:default}.repeat-warning{margin:0 0 10px;padding:8px 12px;border:1px solid #e3b9a0;border-radius:6px;background:#fbeee6;color:#7d3f24;font-size:.82rem;font-weight:600}.dimension-unit{display:grid;gap:4px;margin-bottom:10px;color:#4f5b55;font-size:.76rem;font-weight:800}.dimension-unit select{min-height:30px;border:1px solid #ccd2c7;border-radius:6px;background:#fff}.dimension-empty{margin:0;color:#64716b;font-size:.88rem;font-weight:700}.dimension-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:0}.dimension-grid>div{border:1px solid #e2e4d8;border-radius:6px;background:#fafaf7;padding:10px}.dimension-grid dt{color:#65716b;font-size:.78rem;font-weight:800}.dimension-grid dd{margin:5px 0 0;color:#1f2a26;font-size:.96rem;font-weight:800}.written-instructions{display:grid;max-height:min(46vh,520px);gap:6px;margin:0;overflow:auto;padding:0 0 0 24px;color:#1f2a26;font-size:.92rem;font-weight:650}.written-instructions li{padding-left:2px}.warning-badge{display:inline-grid;min-width:20px;height:20px;place-items:center;border-radius:999px;background:#f9e1df;color:#8f1f16;padding:0 6px;font-size:.78rem;font-weight:800}.validation-panel__ok{margin:0;color:#0f6b5c;font-size:.9rem;font-weight:800}.validation-list{display:grid;gap:6px;margin:0;padding:0 0 0 20px;color:#7b241c;font-size:.9rem;font-weight:800}.chart-frame{max-height:min(68vh,720px);overflow:auto;border:1px solid #d8ddd3;border-radius:8px;background:#f7f8f5}.chart-frame--pan{cursor:grab}.chart-frame--pan *{cursor:grab!important}.chart-preview{display:block;min-width:520px;height:auto;color:#192521;touch-action:none;-webkit-user-select:none;user-select:none}.chart-preview--canvas{position:relative;background:#f7f8f5}.chart-preview__canvas{position:absolute;display:block;outline:none;touch-action:none}.chart-preview__canvas:focus-visible{outline:3px solid #0f6b5c;outline-offset:-3px}.chart-preview__background{fill:#f7f8f5}.chart-preview__cell{fill:#fff;stroke:#80877e;stroke-width:1}.chart-preview__cell--active-symbol{fill:#f4fbf9}.chart-preview__cell--invalid-row{fill:#fff0ed;stroke:#b9483f;stroke-width:1.5}.chart-preview__symbol{color:#15231f}.chart-preview__row-number,.chart-preview__stitch-number{fill:#26332f;font-size:13px;font-weight:700}.chart-preview__row-number--invalid{fill:#9b2d25}.chart-preview__direction{fill:#7d3f24;font-size:10px;font-weight:700}.chart-preview__repeat-edge{stroke:#7d3f24;stroke-width:2;stroke-dasharray:8 6}.chart-preview__repeat-label{fill:#7d3f24;font-size:12px;font-weight:700}.legend-grid{display:grid;gap:12px}.legend-grid h4{margin:0 0 8px;color:#18322d;font-size:.92rem;letter-spacing:0}.legend-grid .symbol-legend,.legend-grid .color-legend{margin-top:0}@media(max-width:1180px){.workspace{grid-template-columns:minmax(240px,300px) minmax(0,1fr)}.info-panel{position:static;grid-column:1 / -1}.legend-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:820px){.app-shell{align-items:stretch;padding:16px}.workspace,.legend-grid{grid-template-columns:1fr}}
