:root{font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;color:#0f172a;background-color:#f8fafc;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background-color:#f8fafc}#root{min-height:100vh}.page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:48px 20px;background:linear-gradient(180deg,#f8fafc,#eef2f7)}.login-card{width:min(420px,92vw);background:#fff;border-radius:20px;box-shadow:0 20px 40px #0f172a14;border:1px solid #e5eaf2;padding:32px 32px 36px;position:relative}.card-accent{position:absolute;inset:0 0 auto;height:6px;border-radius:20px 20px 0 0;background:linear-gradient(90deg,#2563eb,#38bdf8)}.card-header{margin-bottom:24px}.eyebrow{text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;font-weight:600;color:#3b82f6;margin:0 0 4px}.card-header h1{margin:0 0 8px;font-size:1.8rem;color:#0f172a}.subheading{margin:0;color:#475569;font-size:.95rem}.login-form{display:grid;gap:16px}.field{display:grid;gap:8px;font-size:.92rem;color:#1f2937}.field-label{font-weight:600;color:#1e293b}.field-input{border:1px solid #d9e1ec;border-radius:12px;padding:12px 14px;font-size:.95rem;background:#f8fafc;color:#0f172a;transition:border-color .2s ease,box-shadow .2s ease}.field-input::placeholder{color:#94a3b8}.field-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 4px #3b82f626;background:#fff}.status{border-radius:12px;padding:10px 12px;font-size:.88rem}.status-error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c}.status-success{background:#eff6ff;border:1px solid #bfdbfe;color:#1d4ed8}.submit-button{border:none;border-radius:12px;padding:12px;font-size:1rem;font-weight:600;color:#fff;background:#2563eb;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background .15s ease}.submit-button:hover{background:#1d4ed8;box-shadow:0 8px 20px #2563eb40;transform:translateY(-1px)}.submit-button:disabled{cursor:not-allowed;background:#93c5fd;box-shadow:none;transform:none}.dashboard-shell{min-height:100vh;display:flex;flex-direction:row;background:#f1f5f9}.sidenav{position:fixed;top:0;left:0;width:172px;height:100vh;background:#fff;border-right:1px solid #e2e8f0;padding:24px 12px;display:flex;flex-direction:column;gap:24px;box-shadow:16px 0 30px #0f172a0d;transition:width .2s ease;z-index:10}.sidenav--collapsed{width:72px;padding:24px 10px}.sidenav--collapsed .sidenav-meta,.sidenav--collapsed .nav-label{position:absolute;opacity:0;overflow:hidden;width:0;min-width:0;height:0;padding:0;margin:0;white-space:nowrap;pointer-events:none}.sidenav--collapsed .sidenav-links{align-items:center}.sidenav--collapsed .sidenav-link,.sidenav--collapsed .logout-button{display:grid;place-items:center;gap:0;width:44px;height:44px;padding:0;box-sizing:border-box}.sidenav--collapsed .sidenav-link .sidenav-icon,.sidenav--collapsed .logout-button .sidenav-icon{display:grid;place-items:center}.sidenav--collapsed .sidenav-header{width:auto;min-width:0;justify-content:center;gap:0;padding:8px}.sidenav-toggle{width:36px;height:36px;flex-shrink:0;border-radius:12px;border:none;background:#2563eb;color:#fff;display:grid;place-items:center;cursor:pointer;transition:background .2s ease,color .2s ease}.sidenav-toggle:hover{background:#1d4ed8;color:#fff}.sidenav-toggle:focus-visible{outline:2px solid #2563eb;outline-offset:2px}.sidenav-toggle ion-icon{font-size:18px}.sidenav-header{position:relative;display:flex;align-items:center;gap:12px;width:148px;padding:8px 10px;border-radius:14px;background:#f8fafc;height:58px;overflow:hidden;box-sizing:border-box}.sidenav-meta{display:grid;gap:2px;color:#1e293b}.sidenav-meta span{font-weight:600;font-size:.92rem}.sidenav-meta small{color:#64748b;font-size:.75rem}.sidenav-links{display:grid;gap:8px}.sidenav-link{position:relative;display:flex;align-items:center;gap:12px;width:148px;padding:10px 12px;border-radius:14px;color:#475569;text-decoration:none;font-weight:600;transition:background .2s ease,color .2s ease;overflow:hidden}.sidenav-link:hover{background:#eff6ff;color:#1d4ed8}.sidenav-link.is-active{background:#e0edff;color:#1d4ed8}.logout-button{margin-top:auto;display:flex;align-items:center;gap:12px;width:148px;padding:10px 12px;border-radius:14px;border:none;background:#fff1f2;color:#b91c1c;font-weight:600;cursor:pointer;transition:background .2s ease,color .2s ease}.logout-button:hover{background:#fee2e2;color:#991b1b}.logout-button:focus-visible{outline:3px solid rgba(239,68,68,.35);outline-offset:2px}.sidenav-icon{width:24px;height:24px;display:grid;place-items:center}.sidenav-icon ion-icon{font-size:20px;color:currentColor}.nav-label{white-space:nowrap}.dashboard-content{flex:1;margin-left:172px;padding:0;height:100vh;min-height:100vh;display:flex;flex-direction:column;overflow:hidden;transition:margin-left .2s ease}.dashboard-shell[data-sidenav-expanded=false] .dashboard-content{margin-left:72px}.dashboard-panel{background:#fff;width:100%;flex:1;display:flex;flex-direction:column;min-height:0;box-shadow:0 18px 32px #0f172a0f;border:1px solid #e2e8f0}.dashboard-panel:not(:has(.dashboard-panel-scroll)){padding:24px 28px;min-height:calc(100vh - 80px)}.dashboard-panel:has(.dashboard-panel-scroll)>.dashboard-header{position:sticky;top:0;z-index:10;flex-shrink:0;padding:24px 28px 16px;background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px #0000000a}.dashboard-panel-scroll{flex:1;min-height:0;overflow-y:auto;padding:24px 28px 28px}.dashboard-header h1{margin:0;font-size:2rem;color:#0f172a}.dashboard-header-row{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}.header-title-row{display:flex;align-items:center;gap:10px}.searchbar{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:14px;border:1px solid #e2e8f0;background:#f8fafc;min-width:min(360px,100%);flex:1;max-width:420px}.searchbar ion-icon{color:#64748b;font-size:18px}.searchbar input{border:none;background:transparent;flex:1;font-size:.95rem;color:#0f172a}.searchbar input:focus{outline:none}.table-card{border-radius:16px;border:1px solid #e2e8f0;background:#fff;overflow:hidden}table{width:100%;border-collapse:collapse}thead{background:#f8fafc}th,td{text-align:left;padding:14px 16px;font-size:.95rem;color:#1e293b}tbody tr{border-top:1px solid #eef2f7}.table-empty{text-align:center;color:#64748b}.role-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:#eff6ff;color:#1d4ed8;font-weight:600;font-size:.85rem}.row-actions{display:flex;align-items:center;gap:8px}.ghost-button,.danger-button{display:inline-flex;align-items:center;gap:6px;border:none;border-radius:10px;padding:8px 12px;font-weight:600;cursor:pointer;background:transparent}.ghost-button{color:#1d4ed8;background:#eff6ff}.ghost-button:hover{background:#dbeafe}.danger-button{color:#b91c1c;background:#fee2e2}.danger-button:hover{background:#fecaca}.icon-only{padding:8px;width:36px;height:36px;justify-content:center}.submit-button.icon-only{display:grid;place-items:center;line-height:0}.pagination{margin-top:16px;display:flex;align-items:center;justify-content:flex-end;gap:16px;color:#475569}.pagination button{border:1px solid #e2e8f0;background:#fff;color:#1e293b;border-radius:10px;padding:8px 12px;cursor:pointer}.pagination button:disabled{opacity:.5;cursor:not-allowed}.sidepanel-overlay{position:fixed;inset:0;background:#0f172a59;display:flex;justify-content:flex-end;z-index:20;animation:fade-in .2s ease}.sidepanel{width:min(520px,100%);background:#fff;padding:24px;height:100%;box-shadow:-20px 0 40px #0f172a33;display:flex;flex-direction:column;gap:12px;animation:slide-in .25s ease;overflow-y:auto}.sidepanel-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.sidepanel-header h2{margin:2px 0 0;font-size:1rem;line-height:1.3;color:#0f172a;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.icon-button{border:none;background:#f1f5f9;border-radius:10px;width:36px;height:36px;display:grid;place-items:center;cursor:pointer}.icon-button:hover{background:#e2e8f0}.sidepanel-form{display:grid;gap:6px;overflow-y:auto}.sidepanel-actions{display:flex;justify-content:flex-end;gap:10px}.sidepanel-actions .submit-button{padding:10px 16px}.toast{position:fixed;right:24px;bottom:24px;background:#fff;border-radius:14px;padding:12px 14px;display:flex;align-items:center;gap:12px;box-shadow:0 16px 30px #0f172a1f;border:1px solid #e2e8f0;color:#0f172a;z-index:30}.toast-success{border-color:#bbf7d0;background:#f0fdf4;color:#15803d}.toast-error{border-color:#fecaca;background:#fef2f2;color:#dc2626}.toast button{border:none;background:transparent;color:inherit;cursor:pointer;width:28px;height:28px;display:grid;place-items:center;border-radius:8px}.toast button:hover{background:#0f172a14}.modal-overlay{position:fixed;inset:0;background:#0f172a59;display:grid;place-items:center;z-index:25;padding:24px;animation:fade-in .2s ease}.modal-card{width:min(420px,100%);background:#fff;border-radius:18px;padding:20px;border:1px solid #e2e8f0;box-shadow:0 18px 40px #0f172a33;display:grid;gap:16px;animation:slide-in .25s ease}.modal-card h3{margin:6px 0 8px;color:#0f172a}.modal-actions{display:flex;justify-content:flex-end;gap:10px}@keyframes slide-in{0%{transform:translate(24px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.dashboard-body{flex:1;display:grid;place-items:center}.empty-state{text-align:center;max-width:320px}.empty-state h2{margin-bottom:8px;color:#1e293b}.empty-state p{margin:0;color:#64748b}.documents-upload-section{margin-bottom:40px;padding-bottom:32px;border-bottom:1px solid #e2e8f0}.documents-list-section{margin-top:8px}.documents-section-title{margin:0 0 8px;font-size:1.25rem;color:#0f172a}.documents-hint{margin:0 0 20px;max-width:720px}.documents-form{display:grid;gap:16px;max-width:720px}.documents-form-grid{display:grid;gap:14px}@media(min-width:640px){.documents-form-grid{grid-template-columns:1fr 1fr;gap:16px}.documents-form-grid .field:first-child{grid-column:1 / -1}}.documents-submit{max-width:280px}.documents-file-preview{margin-top:8px}.documents-file-list{list-style:none;margin:8px 0 0;display:grid;gap:6px;max-height:240px;overflow-y:auto;border:1px solid #e2e8f0;border-radius:12px;padding:12px;background:#f8fafc}.documents-file-item{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:.88rem;color:#1e293b}.documents-file-item--invalid{color:#b91c1c}.documents-file-error{font-size:.8rem;color:#b91c1c;font-weight:600}.status-info{background:#f0f9ff;border:1px solid #bae6fd;color:#0369a1}.book-status-pill{display:inline-flex;align-items:center;gap:6px;font-size:.75rem;font-weight:600;padding:4px 10px;border-radius:999px;white-space:nowrap}.book-status-pill--uploaded{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.book-status-pill--processing{background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe}.book-status-pill__dot{width:8px;height:8px;border-radius:50%;background:#2563eb;animation:book-status-pulse 1.2s ease-in-out infinite}@keyframes book-status-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.45;transform:scale(.85)}}.book-status-pill--operator{background:#fff7ed;color:#c2410c;border:1px solid #fed7aa}.book-status-pill--editor{background:#faf5ff;color:#7c3aed;border:1px solid #ddd6fe}.book-status-pill--validator{background:#ecfdf5;color:#059669;border:1px solid #a7f3d0}.book-status-pill--validated{background:#f0fdf4;color:#15803d;border:1px solid #bbf7d0}.documents-row-clickable{cursor:pointer}.documents-row-clickable:hover{background:#f8fafc}.documents-actions-cell{width:48px;text-align:right}.documents-edit-btn{color:#2563eb}.sidepanel--book{width:min(640px,100%)}.book-edit-status-row{display:flex;align-items:center;gap:10px;margin-top:8px}.book-edit-status-row .field-label{margin:0;font-size:.75rem}.book-ocr-field{margin-top:4px;display:grid;gap:8px}.book-ocr-edit-btn{display:inline-flex;align-items:center;gap:8px;justify-self:start;font-size:.88rem;padding:10px 18px}.book-edit-meta-value{font-size:.85rem;color:#334155;font-weight:500}.status-warning{background:#fffbeb;border:1px solid #fde68a;color:#92400e}.book-workflow-section{border-top:1px solid #e2e8f0;padding-top:12px;margin-top:4px;display:grid;gap:10px}.book-return-form{display:grid;gap:10px}.book-return-textarea{resize:vertical;min-height:60px}.submit-button--success{background:#16a34a}.submit-button--success:hover{background:#15803d}.submit-button--danger{background:#dc2626}.submit-button--danger:hover{background:#b91c1c}.ghost-button--danger{color:#dc2626;display:inline-flex;align-items:center;gap:6px}.ghost-button--danger:hover{background:#fef2f2}.ocr-modal-overlay{position:fixed;inset:0;background:#0f172a80;z-index:40;display:flex;align-items:stretch;justify-content:center;padding:20px;animation:fade-in .2s ease}.ocr-modal{width:100%;max-width:1400px;background:#fff;border-radius:16px;box-shadow:0 24px 60px #0f172a40;display:flex;flex-direction:column;overflow:hidden;animation:slide-in .25s ease}.ocr-modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid #e2e8f0;flex-shrink:0}.ocr-modal-nav{display:flex;align-items:center;gap:8px}.ocr-nav-btn{border:1px solid #e2e8f0;background:#f8fafc;border-radius:8px;width:32px;height:32px;display:grid;place-items:center;cursor:pointer;color:#1e293b;font-size:1.1rem}.ocr-nav-btn:hover:not(:disabled){background:#e2e8f0}.ocr-nav-btn:disabled{opacity:.4;cursor:not-allowed}.ocr-nav-label{font-size:.85rem;font-weight:600;color:#334155;min-width:180px;text-align:center}.ocr-modal-header-right{display:flex;align-items:center;gap:12px}.ocr-changed-badge{font-size:.75rem;font-weight:600;background:#fef2f2;color:#dc2626;border:1px solid #fecaca;border-radius:999px;padding:4px 10px}.ocr-modal-error{margin:12px 20px 0}.ocr-modal-loading{flex:1;display:grid;place-items:center;font-size:.95rem;color:#64748b}.ocr-modal-body{flex:1;display:grid;grid-template-columns:1fr 1fr;min-height:0}.ocr-editor-pane{border-right:1px solid #e2e8f0;overflow:hidden;display:flex;flex-direction:column}.ocr-editor-container{flex:1;position:relative;overflow:hidden}.ocr-editor-backdrop,.ocr-editor-textarea{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.82rem;line-height:1.5;padding:16px;margin:0;white-space:pre-wrap;overflow-wrap:break-word;word-break:break-word;letter-spacing:0;tab-size:4}.ocr-editor-backdrop{position:absolute;inset:0;overflow:hidden;pointer-events:none;color:#0f172a}.ocr-editor-textarea{position:absolute;inset:0;width:100%;height:100%;resize:none;border:none;outline:none;background:transparent;color:transparent;caret-color:#0f172a;overflow:auto}.ocr-editor-textarea::selection{background:#3b82f64d}.ocr-line-normal{color:#334155}.ocr-line-changed{color:#dc2626;background:#fef2f2;border-radius:2px}.ocr-image-pane{overflow:auto;display:flex;align-items:flex-start;justify-content:center;background:#f1f5f9;padding:12px}.ocr-page-image{max-width:100%;height:auto;border-radius:4px;box-shadow:0 4px 12px #0f172a1a}.ocr-image-placeholder{color:#94a3b8;font-size:.9rem;padding:40px 20px;text-align:center}.ocr-modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:14px 20px;border-top:1px solid #e2e8f0;flex-shrink:0}.nav-badge{margin-left:auto;min-width:1.35rem;height:1.35rem;padding:0 .4rem;border-radius:999px;background:#dc2626;color:#fff;font-size:.68rem;font-weight:700;line-height:1;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.sidenav--collapsed .nav-badge{position:absolute;top:4px;right:4px;margin-left:0;min-width:1rem;height:1rem;font-size:.6rem}.fise-page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:20px}.fise-list-ul{list-style:none;margin:0;padding:0;display:grid;gap:12px}.fise-card{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:16px 18px;background:#fff;border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 2px 8px #0f172a0a}.fise-card-main h3{margin:0 0 6px;font-size:1.05rem}.fise-desc{margin:0 0 10px;font-size:.9rem}.fise-meta{display:flex;flex-wrap:wrap;gap:8px}.fise-badge{display:inline-flex;align-items:center;gap:4px;font-size:.78rem;font-weight:600;padding:4px 10px;border-radius:999px}.fise-badge--done{background:#dcfce7;color:#166534}.fise-badge--pending{background:#fef3c7;color:#92400e}.fise-badge--inactive{background:#f1f5f9;color:#64748b}.fise-card-actions{display:flex;flex-wrap:wrap;gap:8px;flex-shrink:0}.fise-answer-modal,.fise-create-modal,.fise-results-modal{max-width:min(640px,96vw);max-height:90vh;overflow:auto}.fise-questions{display:grid;gap:18px;margin:16px 0}.fise-question-block{display:grid;gap:8px}.fise-q-label{font-weight:600;font-size:.92rem}.fise-textarea{width:100%;border:1px solid #d9e1ec;border-radius:10px;padding:10px 12px;font-size:.92rem;resize:vertical}.fise-radios{display:grid;gap:8px}.fise-radio-row{display:flex;align-items:center;gap:8px;font-size:.92rem}.fise-q-editor{display:grid;gap:8px;margin-bottom:12px;padding:12px;background:#f8fafc;border-radius:10px}.fise-q-editor input[type=text],.fise-q-editor select,.fise-q-editor textarea{width:100%;border:1px solid #d9e1ec;border-radius:10px;padding:8px 10px;font-size:.9rem}.fise-filter-row{display:grid;grid-template-columns:1fr 1fr auto;gap:8px;align-items:center;margin-bottom:8px}@media(max-width:640px){.fise-filter-row{grid-template-columns:1fr}}.fise-results-body{display:grid;gap:16px}.fise-result-q{padding:12px;background:#f8fafc;border-radius:10px}.fise-mc-summary{list-style:none;margin:8px 0 0;padding:0;display:grid;gap:8px}.fise-mc-summary li{display:grid;gap:4px}.fise-bar-wrap{height:6px;background:#e2e8f0;border-radius:999px;overflow:hidden}.fise-bar{height:100%;background:linear-gradient(90deg,#2563eb,#38bdf8);border-radius:999px;transition:width .3s ease}.fise-text-answers{margin:8px 0 0;padding-left:1.1rem;max-height:200px;overflow:auto;font-size:.9rem}.fise-results-table-wrap{overflow:auto;max-height:320px;border:1px solid #e2e8f0;border-radius:10px}.fise-results-table{width:100%;border-collapse:collapse;font-size:.82rem}.fise-results-table th,.fise-results-table td{padding:8px 10px;border-bottom:1px solid #e2e8f0;text-align:left;vertical-align:top}.fise-results-table th{background:#f1f5f9;font-weight:600}.muted.small{font-size:.82rem}.form-field{display:grid;gap:6px;margin-bottom:12px}.form-field span:first-child{font-weight:600;font-size:.85rem;color:#334155}.form-field input,.form-field textarea{border:1px solid #d9e1ec;border-radius:10px;padding:10px 12px;font-size:.92rem}.documents-upload-section .fise-filter-row--inline{display:grid;grid-template-columns:1fr 1fr auto;gap:12px;align-items:end;margin-bottom:12px}.documents-upload-section .fise-filter-field{margin-bottom:0}.documents-upload-section .fise-filter-remove{padding-bottom:2px}.documents-upload-section .fise-add-filter-btn{margin-bottom:16px}.documents-upload-section .fise-q-editor--page{margin-bottom:16px;padding:14px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px}@media(max-width:640px){.documents-upload-section .fise-filter-row--inline{grid-template-columns:1fr}}
