*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--navy: #0d2137;--blue: #1a4a7a;--accent: #2980b9;--light: #f4f7fa;--white: #ffffff;--border: #d0dce8;--text: #1e2a38;--muted: #6b7c90;--green: #27ae60;--radius: 8px;--toast-z: 9000}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--light);color:var(--text);min-height:100vh}a{color:inherit;text-decoration:none}.app-header{position:sticky;top:0;z-index:100;background:var(--navy);color:var(--white);padding:0 1.5rem;height:56px;display:flex;align-items:center;gap:.75rem;box-shadow:0 2px 8px #0000004d}.header-logo{font-size:1.2rem;font-weight:700;letter-spacing:.4px;color:var(--white);text-decoration:none;white-space:nowrap;flex-shrink:0}.header-logo span{color:#7ec8e3}.header-search-trigger{flex:1;max-width:300px;display:flex;align-items:center;gap:.5rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.18);border-radius:var(--radius);color:#ffffffbf;padding:.3rem .75rem;font-size:.88rem;cursor:pointer;transition:background .15s}.header-search-trigger:hover{background:#ffffff2e}.header-search-label{flex:1;text-align:left}.header-search-kbd{font-family:monospace;font-size:.78rem;background:#ffffff26;border:1px solid rgba(255,255,255,.2);border-radius:3px;padding:.05rem .35rem;line-height:1.5}.header-right{display:flex;align-items:center;gap:.75rem;margin-left:auto;flex-shrink:0}.conn-pill{display:inline-flex;align-items:center;gap:.4rem;font-size:.78rem;font-weight:600;padding:.2rem .6rem;border-radius:999px;background:#ffffff1f;color:var(--white);white-space:nowrap}.conn-pill__dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.pill-dot--connected{background:#2ecc71;box-shadow:0 0 4px #2ecc71}.pill-dot--reconnecting{background:#f39c12;box-shadow:0 0 4px #f39c12}.pill-dot--disconnected{background:#e74c3c;box-shadow:0 0 4px #e74c3c}.theme-toggle{background:#ffffff1a;border:1px solid rgba(255,255,255,.18);border-radius:var(--radius);color:var(--white);cursor:pointer;font-size:1rem;line-height:1;padding:.25rem .5rem;transition:background .15s}.theme-toggle:hover{background:#ffffff38}.user-chip{display:inline-flex;align-items:center;gap:.4rem;font-size:.82rem;color:var(--white);max-width:200px}.user-chip__avatar{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,#2980b9,#8e44ad);color:var(--white);font-size:.78rem;font-weight:700;flex-shrink:0}.user-chip__email{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:140px}.user-chip__admin-star{font-size:.82rem}.user-chip__signin{opacity:.7;font-style:italic;font-size:.82rem}.container{max-width:1100px;margin:0 auto;padding:2rem 1.5rem}.hero{text-align:center;padding:2.5rem 0 2rem}.hero h1{font-size:2rem;font-weight:700;color:var(--navy);margin-bottom:.5rem}.hero p{color:var(--muted);font-size:1rem}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.25rem;margin-top:1.5rem}.doc-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem 1.5rem 1rem;cursor:pointer;transition:box-shadow .15s,transform .15s;display:flex;flex-direction:column;gap:.5rem}.doc-card:hover{box-shadow:0 4px 16px #0d21371f;transform:translateY(-2px)}.doc-card .doc-id{font-size:.75rem;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.8px}.doc-card .doc-title{font-size:1rem;font-weight:700;color:var(--navy);line-height:1.3}.doc-card .doc-subtitle{font-size:.8rem;color:var(--muted);line-height:1.4}.mini-progress{margin-top:.75rem}.mini-progress-label{display:flex;justify-content:space-between;font-size:.72rem;color:var(--muted);margin-bottom:4px}.mini-progress-bar{height:6px;background:var(--border);border-radius:999px;overflow:hidden}.mini-progress-fill{height:100%;background:var(--green);border-radius:999px;transition:width .4s}.mini-progress-fill.rec-fill,.progress-fill.rec-fill{background:var(--accent)}.back-link{display:inline-flex;align-items:center;gap:.4rem;color:var(--accent);font-size:.875rem;margin-bottom:1.25rem;transition:opacity .15s}.back-link:hover{opacity:.75}.doc-header{margin-bottom:1.5rem}.doc-header h2{font-size:1.5rem;font-weight:700;color:var(--navy);margin-bottom:.25rem}.doc-meta{font-size:.875rem;color:var(--muted)}.tab-bar{display:flex;border-bottom:2px solid var(--border);margin-bottom:1.25rem}.tab-btn{background:none;border:none;padding:.65rem 1.5rem;font-size:.9rem;font-weight:600;color:var(--muted);cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s}.tab-btn:hover{color:var(--accent)}.tab-btn.active{color:var(--navy);border-bottom-color:var(--accent)}.tab-panel{display:none}.tab-panel.active{display:block}.tab-panel>.progress-block{margin-bottom:1rem}.progress-label{display:flex;justify-content:space-between;font-size:.8rem;color:var(--muted);margin-bottom:6px}.progress-bar{height:8px;background:var(--border);border-radius:999px;overflow:hidden}.progress-fill{height:100%;background:var(--green);border-radius:999px;transition:width .4s}.checklist{list-style:none;background:var(--white);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.checklist-item{display:flex;align-items:flex-start;gap:.85rem;padding:.9rem 1.25rem;border-bottom:1px solid var(--border);transition:background .12s}.checklist-item:last-child{border-bottom:none}.checklist-item:hover{background:#f0f5fa}.checklist-item input[type=checkbox]{margin-top:2px;width:17px;height:17px;accent-color:var(--green);flex-shrink:0;cursor:pointer}.checklist-item label{cursor:pointer;font-size:.9rem;line-height:1.5}.checklist-item label .item-id{font-weight:700;color:var(--accent);margin-right:.5rem}.checklist-item.checked label{color:var(--muted);text-decoration:line-through}.empty-state{padding:2rem;text-align:center;color:var(--muted);font-size:.875rem}.breadcrumb{font-size:.8rem;color:var(--muted);margin-bottom:1rem}.breadcrumb a{color:var(--accent)}.breadcrumb a:hover{text-decoration:underline}.breadcrumb-sep{margin:0 .4rem;opacity:.5}.signin-stub{text-align:center;padding:4rem 2rem}.signin-stub h2{font-size:1.4rem;color:var(--navy);margin-bottom:.5rem}.signin-stub p{color:var(--muted);font-size:.9rem}.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;display:flex;flex-direction:column;gap:.6rem;z-index:var(--toast-z);pointer-events:none}.toast{pointer-events:all;display:flex;align-items:flex-start;gap:.75rem;background:var(--navy);color:var(--white);padding:.75rem 1rem;border-radius:var(--radius);font-size:.875rem;line-height:1.4;max-width:340px;box-shadow:0 4px 16px #00000040;animation:toast-in .2s ease-out}.toast.toast-error{background:#c0392b}.toast.toast-warning{background:#e67e22}.toast-msg{flex:1}.toast-dismiss{background:none;border:none;color:#ffffffb3;cursor:pointer;font-size:1rem;line-height:1;padding:0;flex-shrink:0;margin-top:1px}.toast-dismiss:hover{color:var(--white)}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(max-width:600px){header{padding:0 1rem}.hero h1{font-size:1.4rem}.container{padding:1.25rem 1rem}.tab-btn{padding:.6rem 1rem;font-size:.82rem}.toast-container{bottom:1rem;right:1rem;left:1rem}.toast{max-width:100%}}.doc-detail-title{font-size:1.4rem;color:var(--navy);margin:.75rem 0 1.25rem;line-height:1.3}.offline-banner{background:#f5a623;color:#1e2a38;font-size:.85rem;font-weight:600;padding:.5rem 1rem;border-radius:var(--radius);margin-bottom:1rem}.offline-banner--hidden{display:none}.doc-tabs{display:flex;gap:.5rem;border-bottom:2px solid var(--border);margin-bottom:1.25rem}.req-row{display:grid;grid-template-columns:1.5rem 1fr auto;grid-template-rows:auto auto auto auto;column-gap:.75rem;align-items:start;min-height:96px;padding:.75rem 0;border-bottom:1px solid var(--border);border-left:4px solid transparent;transition:border-color .15s}.req-row--done{border-left-color:var(--green, #2c8a4a)}.req-row--wont-do{border-left-color:#c08a3e}.req-checkbox{grid-column:1;grid-row:1 / 3;margin-top:.2rem;width:1rem;height:1rem;cursor:pointer}.req-label{grid-column:2;grid-row:1;display:flex;flex-direction:column;gap:.25rem;cursor:pointer}.req-row--done .req-label{text-decoration:line-through;color:var(--muted)}.req-section{font-size:.75rem;font-weight:700;color:var(--muted);letter-spacing:.5px;text-transform:uppercase}.req-text{font-size:.9rem;line-height:1.45}.req-status-badge{grid-column:3;grid-row:1;font-size:1rem}.req-reason{grid-column:2;grid-row:2;font-size:.8rem;color:var(--muted);font-style:italic;margin-top:.2rem}.req-wont-do-btn{grid-column:2;grid-row:3;align-self:start;margin-top:.4rem;background:none;border:1px solid #c08a3e;border-radius:var(--radius);color:#c08a3e;font-size:.78rem;padding:.2rem .6rem;cursor:pointer;width:fit-content}.req-wont-do-btn:hover{background:#fdf3e2}.req-wontdo-form{grid-column:1 / -1;grid-row:4;display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background:var(--light);border-radius:var(--radius);margin-top:.5rem;border:1px solid var(--border)}.req-wontdo-form--hidden{display:none}.req-wontdo-textarea{width:100%;padding:.5rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.875rem;resize:vertical;font-family:inherit}.req-wontdo-textarea:focus{outline:2px solid var(--accent)}.req-wontdo-actions{display:flex;gap:.5rem;flex-wrap:wrap}.btn{border:none;border-radius:var(--radius);cursor:pointer;font-size:.85rem;padding:.35rem .85rem;font-family:inherit}.btn--primary{background:var(--accent);color:var(--white)}.btn--primary:hover{background:var(--blue)}.btn--ghost{background:none;border:1px solid var(--border);color:var(--text)}.btn--ghost:hover{background:var(--border)}.btn--danger{background:none;border:1px solid #c0392b;color:#c0392b}.btn--danger:hover{background:#fdecea}[role=tabpanel]{overflow-y:auto;max-height:70vh}@media(max-width:600px){.req-row{grid-template-columns:1.25rem 1fr}.req-status-badge{grid-column:2;grid-row:3}.req-wont-do-btn{grid-row:4}.req-wontdo-form{grid-row:5}}:focus-visible{outline:2px solid #005fcc;outline-offset:2px}.filter-chip-bar{display:flex;flex-wrap:wrap;gap:.5rem;margin:.75rem 0 1rem}.filter-chip{padding:.3rem .85rem;border-radius:999px;border:1.5px solid var(--accent);background:none;color:var(--accent);font-size:.85rem;font-weight:500;cursor:pointer;transition:background .15s,color .15s}.filter-chip:hover,.filter-chip--active,.filter-chip[aria-pressed=true]{background:var(--accent);color:var(--white)}.filter-chip:focus-visible{outline:2px solid #005fcc;outline-offset:2px}dialog.search-overlay{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;max-width:680px;height:auto;max-height:80vh;margin:5vh auto;padding:0;border:none;border-radius:12px;background:var(--white);box-shadow:0 8px 40px #00000038;overflow:hidden;display:flex;flex-direction:column}dialog.search-overlay::backdrop{background:#00000073}.search-overlay__inner{display:flex;flex-direction:column;height:100%;overflow:hidden}.search-overlay__input-wrap{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-bottom:1px solid #e8ecf0;flex-shrink:0}.search-overlay__icon{font-size:1.1rem;color:var(--muted);flex-shrink:0}.search-overlay__input{flex:1;border:none;outline:none;font-size:1.05rem;color:var(--navy);background:transparent;min-width:0}.search-overlay__input:focus{outline:none}.search-overlay__close{background:none;border:none;cursor:pointer;color:var(--muted);font-size:1rem;padding:.25rem;border-radius:4px;flex-shrink:0}.search-overlay__close:hover{color:var(--navy)}.search-overlay__results{overflow-y:auto;flex:1;padding:.5rem 0 .75rem}.search-overlay__hint{color:var(--muted);font-size:.9rem;text-align:center;padding:1.5rem 1rem;margin:0}.search-overlay__group{margin-bottom:.25rem}.search-overlay__group-heading{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);padding:.5rem 1rem .25rem}.search-overlay__item{display:flex;flex-direction:column;gap:.2rem;padding:.55rem 1rem;cursor:pointer;border-radius:6px;margin:0 .5rem;transition:background .1s}.search-overlay__item:hover,.search-overlay__item--selected{background:#f0f4ff}.search-overlay__item:focus-visible{outline:2px solid #005fcc;outline-offset:1px}.search-overlay__section{font-size:.75rem;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.5px}.search-overlay__snippet{font-size:.88rem;color:var(--navy);line-height:1.45;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.search-overlay__match{background:#fff3b0;color:#5a3e00;border-radius:2px;padding:0 1px}.search-overlay__status{font-size:.78rem;color:var(--muted)}dialog.help-overlay{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;max-width:420px;height:auto;margin:10vh auto;padding:1.5rem;border:none;border-radius:12px;background:var(--white);box-shadow:0 8px 40px #00000038}dialog.help-overlay::backdrop{background:#00000059}.help-overlay__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.help-overlay__title{font-size:1rem;font-weight:700;color:var(--navy);margin:0}.help-overlay__close{background:none;border:none;cursor:pointer;color:var(--muted);font-size:1rem;padding:.25rem;border-radius:4px}.help-overlay__close:hover{color:var(--navy)}.help-overlay__table{width:100%;border-collapse:collapse;font-size:.9rem}.help-overlay__table tr+tr td{border-top:1px solid #e8ecf0}.help-overlay__keys{padding:.5rem .75rem .5rem 0;white-space:nowrap;width:40%}.help-overlay__keys kbd{display:inline-block;background:#f0f2f5;border:1px solid #d0d5dd;border-radius:4px;padding:.15rem .45rem;font-family:monospace;font-size:.82rem;color:var(--navy)}.help-overlay__desc{padding:.5rem 0;color:var(--navy)}.req-status-badge{font-size:.85rem}.req-row--done .req-status-badge{color:#27ae60;font-weight:700}.req-row--wont-do .req-status-badge{color:#7f8c8d}[data-theme=dark]{--navy: #0a1929;--blue: #102840;--accent: #4da6e0;--light: #121e2b;--white: #1c2e40;--border: #2a3e54;--text: #d6e4f0;--muted: #7a9ab8;--green: #2ecc71}[data-theme=dark] a{color:var(--accent)}[data-theme=dark] :focus-visible{outline-color:var(--accent)}[data-theme=dark] .req-row--wont-do .req-status-badge{color:#95a5a6}[data-theme=dark] .status-badge--completed{background:#1a4a2e;color:#2ecc71}[data-theme=dark] .status-badge--in-progress{background:#1a3a5a;color:#4da6e0}[data-theme=dark] .status-badge--not-started{background:#2d2d3a;color:#8a9ab0}[data-theme=dark] .status-badge--wont-do{background:#2d2d2d;color:#888}[data-theme=dark] .help-overlay__keys kbd{background:#1e3048;border-color:var(--border);color:var(--accent)}[data-theme=dark] .help-overlay__desc{color:var(--accent)}[data-theme=dark] .help-overlay__table tr+tr td{border-top-color:var(--border)}[data-theme=dark] .help-overlay__panel,[data-theme=dark] .search-dialog{background:var(--white);border-color:var(--border)}[data-theme=dark] .search-input{background:var(--light);color:var(--text);border-color:var(--border)}[data-theme=dark] .search-input:focus{border-color:var(--accent);outline-color:var(--accent)}[data-theme=dark] .search-result-item:hover,[data-theme=dark] .search-result-item--selected{background:#1a3a5a}[data-theme=dark] ::-webkit-scrollbar-track{background:var(--light)}[data-theme=dark] ::-webkit-scrollbar-thumb{background:var(--border)}
