:root{--bg:#f8f6f1;--surface:#fff;--text:#1f2933;--muted:#68727f;--border:#ddd7ce;--shadow:0 12px 28px #1f293314;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font:16px/1.5 system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}body{margin:0}button,input,textarea,select{font:inherit}h1{margin:0 0 14px;font-size:2.4rem;line-height:1.05}h2{margin:0 0 8px;font-size:1.05rem}p{margin:0}@media (width>=720px){h1{font-size:3.4rem}}.app-shell{box-sizing:border-box;flex-direction:column;gap:22px;width:min(100%,680px);min-height:100svh;margin:0 auto;padding:32px 20px;display:flex}.detail-shell{gap:24px}.intro{padding:20px 0 8px}.intro h1{overflow-wrap:anywhere}.eyebrow{border:1px solid var(--border);width:fit-content;color:var(--muted);border-radius:999px;margin:0 0 14px;padding:6px 10px;font-size:.85rem;font-weight:700}.lead{max-width:32rem;color:var(--muted);font-size:1.1rem}.status-panel,.scope-list article,.auth-panel,.form-panel{background:var(--surface);box-shadow:0 1px 0 #1f29330a, var(--shadow);border:1px solid #d2c8bb;border-radius:8px}.status-panel{padding:18px}.detail-shell>.status-panel,.detail-shell>.form-panel,.detail-shell>.collapsible-project-section,.detail-shell>.project-section-scroll-anchor>.collapsible-project-section{border-color:#c8b9a8;box-shadow:0 2px #365f4614,0 14px 34px #1f293314}.detail-shell>.status-panel,.detail-shell>.form-panel{padding:20px}.detail-shell>.status-panel,.detail-shell>.form-panel,.detail-shell>.collapsible-project-section,.detail-shell>.project-section-scroll-anchor{scroll-margin-top:16px}.detail-shell .section-heading,.detail-shell .project-card-header{border-bottom:1px solid #e2d8cb;padding-bottom:12px}.detail-shell .section-heading h2,.detail-shell .project-card-header h2,.detail-shell .collapsible-project-title>span:not(.section-kicker):not(.collapsible-project-summary){font-size:1.2rem;line-height:1.2}.detail-secondary-panel{background:#fbfaf6}.status-panel h2,.form-panel h2{margin:0}.scope-list,.yarn-list,.project-list,.pattern-list,.project-list-section{gap:12px;display:grid}.project-list-section h2{margin:0}.scope-list article{padding:18px}.yarn-card,.project-card,.pattern-card{border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow);border-radius:8px;gap:14px;padding:18px;display:grid}.yarn-card-button{width:100%;color:var(--text);cursor:pointer;font:inherit;text-align:left}.yarn-card-button:focus-visible{outline-offset:2px;outline:3px solid #9fb8a8}.yarn-card-empty{box-shadow:none;background:#fbfaf7;border-style:dashed}.yarn-card h2,.yarn-card p,.project-card h2,.project-card h3,.project-card p,.pattern-card h2,.pattern-card p,.yarn-details{margin:0}.yarn-card p,.project-card p,.pattern-card p,.yarn-details{color:var(--muted)}.project-card-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.section-heading{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px;display:flex}.section-heading>div,.project-card-header>div{min-width:0}.section-kicker{color:var(--muted);letter-spacing:0;text-transform:uppercase;margin:0 0 4px;font-size:.78rem;font-weight:800}.project-card-actions{gap:10px;display:grid}.project-status{color:#5f4636;background:#efe8dc;border-radius:999px;flex:none;padding:6px 10px;font-size:.85rem;font-weight:700}.yarn-details{gap:8px;display:grid}.yarn-details div{justify-content:space-between;gap:12px;display:flex}.yarn-details dt{font-weight:700}.yarn-details dd{color:var(--text);overflow-wrap:anywhere;text-align:right;margin:0}.yarn-details dd.highlight-amount{font-weight:700}.yarn-tag{color:#365f46;background:#e8f1ea;border-radius:999px;width:fit-content;padding:6px 10px;font-size:.85rem;font-weight:700}.yarn-tag-muted{color:#5f4636;background:#eee8df}.detail-list{margin-bottom:14px}.project-overview-panel{gap:16px;display:grid}.project-overview-panel .detail-list{margin-bottom:0}.project-overview-actions{flex-wrap:wrap;gap:10px;display:flex}.project-back-action:focus-visible,.project-edit-action:focus-visible{outline-offset:2px;outline:3px solid #365f4647}.project-section-scroll-anchor{scroll-margin-top:12px}.project-section-scroll-anchor:focus{outline:none}.collapsible-project-section{background:var(--surface);box-shadow:0 1px 0 #1f29330a, var(--shadow);border:1px solid #d2c8bb;border-radius:8px;overflow:hidden}.detail-shell>.collapsible-project-section+.collapsible-project-section,.detail-shell>.collapsible-project-section+.project-section-scroll-anchor,.detail-shell>.project-section-scroll-anchor+.collapsible-project-section{margin-top:4px}.collapsible-project-header{width:100%;min-height:56px;color:var(--text);cursor:pointer;font:inherit;text-align:left;background:0 0;border:0;justify-content:space-between;align-items:flex-start;gap:12px;padding:17px 18px;font-weight:800;display:flex}.collapsible-project-header[aria-expanded=true]{background:#fbfaf6;border-bottom:1px solid #e2d8cb}.collapsible-project-header:focus-visible{outline-offset:-3px;outline:3px solid #9fb8a8}.collapsible-project-title{gap:4px;min-width:0;display:grid}.collapsible-project-summary{color:var(--muted);overflow-wrap:anywhere;font-size:.92rem;font-weight:500;line-height:1.35}.collapsible-project-indicator{border:1px solid var(--border);width:28px;min-height:28px;color:var(--text);border-radius:999px;flex:none;place-items:center;font-size:1.2rem;line-height:1;display:grid}.collapsible-project-content{gap:16px;padding:16px 18px 18px;display:grid}.collapsible-project-content>.form-panel,.collapsible-project-content>.status-panel{box-shadow:none;background:#fbfaf6;border-color:#e0d7cb}.project-section-stack{gap:14px;display:grid}.note-block{border-top:1px solid var(--border);gap:8px;padding-top:14px;display:grid}.note-block h3{margin:0}.note-text{color:var(--muted);white-space:pre-wrap;margin:0;line-height:1.5}.empty-text,.selected-file{color:var(--muted);margin:0}.helper-text{color:var(--muted);margin:0 0 14px;line-height:1.5}.form-panel>.helper-text{margin-top:8px}.field-note{color:var(--muted);font-size:.9rem;line-height:1.4}.status-save-summary{border:1px solid var(--border);background:#f8faf8;border-radius:8px;gap:4px;padding:12px;display:grid}.status-save-summary p{color:var(--muted);margin:0}.status-save-summary strong{color:var(--text)}.pattern-context{border:1px solid var(--border);background:#f8faf8;border-radius:8px;gap:10px;margin:14px 0;padding:12px;display:grid}.pattern-context h3,.pattern-context p{margin:0}.pattern-context p{color:var(--muted)}.pattern-metadata-status,.metadata-warning{border:1px solid var(--border);background:#f8faf8;border-radius:8px;gap:6px;margin:12px 0 0;padding:12px;display:grid}.detail-shell .pattern-metadata-status,.detail-shell .metadata-warning{border-color:#d9ceb8 #d9ceb8 #d9ceb8 #dbc7a3;border-left-style:solid;border-left-width:4px;margin-top:14px}.detail-shell .pattern-metadata-status.ok{border-color:#b8d3be #b8d3be #b8d3be #365f46}.pattern-metadata-status strong,.metadata-warning strong{color:var(--text)}.pattern-metadata-status p,.metadata-warning p{color:var(--muted);margin:0;line-height:1.45}.pattern-metadata-status.ok{background:#eef7f0;border-color:#b8d3be}.pattern-metadata-status.warning,.metadata-warning{background:#fff8eb;border-color:#dbc7a3}.pattern-metadata-status.neutral{background:#f7f7f4}.pattern-metadata-status .compact-action,.metadata-warning .compact-action{width:fit-content;padding:0 14px}.yarn-check-panel{scroll-margin-top:12px}.detail-shell>.yarn-check-panel{background:#fcfffc;border-color:#b8d3be}.yarn-check-panel:focus{outline:none}.yarn-check-steps{gap:8px;margin:12px 0 0;display:grid}.yarn-check-steps div,.optional-fields{border:1px solid var(--border);background:#f8faf8;border-radius:8px;gap:6px;padding:10px;display:grid}.detail-shell .yarn-check-steps div,.detail-shell .optional-fields,.detail-shell .status-save-summary,.detail-shell .adjustment-summary{background:#fbfaf6;border-color:#e0d7cb}.yarn-check-steps strong{color:var(--text)}.yarn-check-steps span,.optional-fields>p{color:var(--muted);margin:0;font-size:.92rem;line-height:1.4}.optional-fields{gap:12px}.local-save-action{margin-top:-2px}.pdf-text-result{gap:12px;margin-top:14px;display:grid}.pdf-clear-action{justify-self:start}.pdf-text-result p{margin:0}.pdf-text-result .detail-list{margin-bottom:0}.pdf-candidate-section{border-top:1px solid var(--border);gap:12px;padding-top:14px;display:grid}.pdf-candidate-section h3{margin:0}.pdf-candidate-list{gap:12px;display:grid}.pdf-candidate-card{border:1px solid var(--border);background:#f8faf8;border-radius:8px;gap:8px;padding:12px;display:grid}.detail-shell .pdf-candidate-card,.detail-shell .pattern-size-card,.detail-shell .row-counter-card,.detail-shell .reservation-row,.detail-shell .yarn-candidate-card{background:#fbfaf6;border:1px solid #e0d7cb;border-radius:8px}.detail-shell .pattern-size-card,.detail-shell .row-counter-card,.detail-shell .reservation-row,.detail-shell .yarn-candidate-card{padding:14px}.pdf-candidate-card h4,.pdf-candidate-card p{margin:0}.pdf-candidate-card h4{overflow-wrap:anywhere}.pdf-candidate-card p{color:var(--text);overflow-wrap:anywhere}.pdf-candidate-card .candidate-source{color:var(--muted);font-size:.92rem}.yarn-candidate-list{gap:12px;margin-top:14px;display:grid}.yarn-candidate-card{border-top:1px solid var(--border);gap:10px;padding:14px 0;display:grid}.yarn-candidate-card h3,.yarn-candidate-card p{margin:0}.yarn-candidate-card p{color:var(--muted)}.candidate-assessment,.candidate-explanation{gap:4px;display:grid}.candidate-explanation p{color:var(--muted);margin:0;font-size:.92rem;line-height:1.45}.candidate-assessment strong{color:#365f46;background:#e8f1ea;border-radius:999px;width:fit-content;padding:5px 9px;font-size:.85rem}.pattern-size-list{gap:12px;margin-top:14px;display:grid}.pattern-size-card{border-top:1px solid var(--border);gap:12px;padding:14px 0;display:grid}.pattern-size-card-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.pattern-size-card-header h3,.pattern-size-card p,.pattern-size-form h3{margin:0}.pattern-size-card p{color:var(--muted)}.pattern-size-card-header strong{color:var(--text);flex:none}.pattern-size-form{border-top:1px solid var(--border);gap:12px;margin-top:14px;padding-top:14px;display:grid}.pattern-size-form label{color:var(--muted);gap:6px;font-weight:700;display:grid}.pattern-size-form input,.pattern-size-form textarea{box-sizing:border-box;border:1px solid var(--border);width:100%;min-height:44px;color:var(--text);font:inherit;background:#fff;border-radius:8px;padding:10px 12px}.pattern-size-form textarea{resize:vertical}.field-error{color:#9f2f2f;font-size:.92rem;font-weight:700;line-height:1.35}.pattern-size-actions{gap:10px;display:grid}.adjustment-summary{border:1px solid var(--border);background:#f8faf8;border-radius:8px;gap:6px;padding:12px;display:grid}.adjustment-summary p,.adjustment-summary strong{margin:0}.adjustment-summary p{color:var(--muted)}.transaction-list{gap:12px;display:grid}.reservation-list,.row-counter-list{gap:12px;margin-top:14px;display:grid}.project-image-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-top:14px;display:grid}.project-image-card{gap:10px;margin:0;display:grid}.project-image-frame{aspect-ratio:1;border:1px solid var(--border);background:#f8faf8;border-radius:8px;overflow:hidden}.project-image-frame img{object-fit:cover;width:100%;height:100%;display:block}.row-counter-card{border-top:1px solid var(--border);gap:14px;padding:16px 0;display:grid}.row-counter-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.row-counter-header h3,.row-counter-header p{margin:0}.row-counter-header p{color:var(--text);text-align:right;font-size:1.35rem;font-weight:800}.row-counter-actions{grid-template-columns:1fr 1fr;gap:12px;display:grid}.row-counter-edit-form{gap:12px;display:grid}.row-counter-edit-form label{color:var(--muted);gap:6px;font-weight:700;display:grid}.row-counter-edit-form input{box-sizing:border-box;border:1px solid var(--border);width:100%;min-height:44px;color:var(--text);font:inherit;background:#fff;border-radius:8px;padding:10px 12px}.row-counter-edit-actions{gap:10px;display:grid}.counter-action{border:1px solid var(--border);color:#fff;cursor:pointer;min-height:64px;font:inherit;background:#365f46;border-radius:8px;font-size:2rem;font-weight:800}.counter-action:disabled{cursor:not-allowed;opacity:.55}.delete-confirmation{background:#fff7f5;border:1px solid #d9aaa2;border-radius:8px;gap:12px;padding:12px;display:grid}.delete-confirmation p{color:var(--text);margin:0;font-weight:700}.delete-confirmation-actions{gap:10px;display:grid}.project-delete-dialog-backdrop{z-index:20;background:#1f293373;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.project-delete-dialog{background:#fffaf8;border:1px solid #d9aaa2;border-radius:8px;gap:12px;width:min(100%,420px);max-height:calc(100vh - 40px);padding:20px;display:grid;overflow:auto;box-shadow:0 20px 60px #1f293347}.project-delete-dialog h2,.project-delete-dialog p{margin:0}.danger-panel{background:#fffaf8;border-color:#d9aaa2}.danger-action{color:#fff;cursor:pointer;background:#9f1d1d;border:1px solid #9f1d1d;border-radius:8px;min-height:44px;font-weight:700}.danger-action:disabled{cursor:not-allowed;opacity:.65}.reservation-row{border-top:1px solid var(--border);justify-content:space-between;align-items:flex-start;gap:12px;padding:14px 0;display:flex}.reservation-row h3,.reservation-row p{margin:0}.reservation-row div{gap:6px;display:grid}.reservation-row p{color:var(--muted)}.transaction-card{border-top:1px solid var(--border);gap:8px;padding:14px 0;display:grid}.transaction-card h3,.transaction-card p{margin:0}.transaction-card p{color:var(--muted)}.transaction-quantity{font-weight:700;color:var(--text)!important}.auth-shell{justify-content:center}.auth-panel,.form-panel{padding:18px}.auth-toggle{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px;display:grid}.auth-toggle button,.primary-action,.secondary-action{border:1px solid var(--border);background:var(--surface);min-height:44px;color:var(--text);cursor:pointer;border-radius:8px;font-weight:700}.auth-toggle button.active,.primary-action{color:#fff;background:#365f46;border-color:#365f46}.auth-form,.yarn-form{gap:14px;display:grid}.auth-form label,.auth-field,.yarn-form label{color:var(--muted);gap:6px;font-weight:700;display:grid}.field-help{color:var(--muted);font-size:.9rem;font-weight:400;line-height:1.4}.required-mark{color:var(--text);font-weight:800}.auth-field>label{align-items:baseline;gap:4px;width:fit-content;display:inline-flex}.auth-form input,.yarn-form input,.yarn-form select,.yarn-form textarea{box-sizing:border-box;border:1px solid var(--border);width:100%;min-height:44px;color:var(--text);font:inherit;background:#fff;border-radius:8px;padding:10px 12px}.inline-field{color:var(--muted);gap:6px;font-weight:700;display:grid}.inline-field input{box-sizing:border-box;border:1px solid var(--border);width:100%;min-height:44px;color:var(--text);font:inherit;background:#fff;border-radius:8px;padding:10px 12px}.password-input-wrap{position:relative}.password-input-wrap input{padding-right:52px}.password-visibility-button{width:44px;min-height:44px;color:var(--text);cursor:pointer;background:0 0;border:0;border-radius:6px;place-items:center;display:grid;position:absolute;top:50%;right:4px;transform:translateY(-50%)}.password-visibility-button svg{display:block}.password-visibility-button:focus-visible{outline-offset:2px;outline:3px solid #9fb8a8}.yarn-form textarea{resize:vertical}.yarn-form .checkbox-label{align-items:flex-start;gap:10px;min-height:44px;display:flex}.yarn-form .checkbox-label input{width:20px;min-height:20px;margin-top:2px}.list-toggle{border:1px solid var(--border);background:var(--surface);border-radius:8px;align-items:flex-start;gap:10px;min-height:44px;padding:12px;display:flex}.list-toggle input{width:20px;min-height:20px;margin-top:2px}.checkbox-text{gap:4px;display:grid}.primary-action:disabled,.secondary-action:disabled{cursor:not-allowed;opacity:.65}.secondary-action{width:100%}.secondary-action.project-back-action,.secondary-action.project-edit-action{color:#fff;background:#365f46;border-color:#365f46;box-shadow:0 1px #1f293314}.inline-action{flex:none;width:auto;min-width:fit-content;padding:0 14px}@media (width<=420px){.section-heading{display:grid}.inline-action{width:100%}}.feedback{margin-top:14px;font-weight:700}.feedback.error{color:#9f1d1d}.feedback.success{color:#276749}.feedback.warning{color:#8a5a00}@media (width>=720px){.app-shell{padding:56px 24px}.status-panel{padding:22px}}
