: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:20px;width:min(100%,680px);min-height:100svh;margin:0 auto;padding:32px 20px;display:flex}.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{border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow);border-radius:8px}.status-panel{padding:18px}.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 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-tag{color:#365f46;background:#e8f1ea;border-radius:999px;width:fit-content;padding:6px 10px;font-size:.85rem;font-weight:700}.detail-list{margin-bottom:14px}.project-overview-panel{gap:14px;display:grid}.project-overview-panel .detail-list{margin-bottom:0}.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}.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)}.pdf-text-result{gap:12px;margin-top:14px;display:grid}.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}.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}.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}.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,.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-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}.yarn-form textarea{resize:vertical}.yarn-form .checkbox-label{align-items:center;gap:10px;min-height:44px;display:flex}.yarn-form .checkbox-label input{width:20px;min-height:20px}.primary-action:disabled,.secondary-action:disabled{cursor:not-allowed;opacity:.65}.secondary-action{width:100%}.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}@media (width>=720px){.app-shell{padding:56px 24px}.status-panel{padding:22px}}
