*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background-color:#f5f5f5;color:#1a1a1a;line-height:1.6}.app{min-height:100vh;display:flex}.user-menu{position:relative;z-index:20}.user-menu-trigger{width:42px;height:42px;border:1px solid #e2e8f0;border-radius:8px;background:#fff;color:#475569;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 14px #0f172a14;transition:all .15s ease}.user-menu-trigger:hover,.user-menu-trigger.active{color:#667eea;border-color:#667eea59;box-shadow:0 8px 22px #667eea29}.user-menu-panel{position:absolute;top:calc(100% + .5rem);right:0;width:240px;padding:.45rem;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 16px 36px #0f172a29}.user-menu-profile{display:flex;flex-direction:column;gap:.1rem;padding:.65rem .75rem .75rem;margin-bottom:.25rem;border-bottom:1px solid #f1f5f9}.user-menu-name{color:#1e293b;font-size:.95rem;font-weight:600;line-height:1.3;overflow-wrap:anywhere}.user-menu-role{color:#64748b;font-size:.78rem;line-height:1.3}.user-menu-item{width:100%;display:flex;align-items:center;gap:.65rem;padding:.65rem .75rem;border:none;border-radius:6px;background:transparent;color:#475569;font-size:.9rem;font-weight:500;text-align:left;cursor:pointer;transition:all .15s ease}.user-menu-item:hover{background:#f8fafc;color:#1e293b}.user-menu-logout:hover{background:#fef2f2;color:#dc2626}.sidebar{width:20%;min-width:250px;background:linear-gradient(180deg,#1e293b,#0f172a);color:#fff;display:flex;flex-direction:column}.hamburger-btn{background:transparent;border:none;border-radius:8px;padding:.4rem;cursor:pointer;color:#fff9;display:flex;align-items:center;justify-content:center;transition:all .15s ease;flex-shrink:0}.hamburger-btn:hover{color:#fff;background:#ffffff1a}.menu-overlay{position:fixed;inset:0;z-index:900;background:#0006;animation:menu-fade-in .15s ease}@keyframes menu-fade-in{0%{opacity:0}to{opacity:1}}.menu-drawer{position:absolute;top:0;left:0;bottom:0;width:260px;background:linear-gradient(180deg,#1e293b,#0f172a);box-shadow:4px 0 24px #0000004d;display:flex;flex-direction:column;animation:menu-slide-in .2s ease}@keyframes menu-slide-in{0%{transform:translate(-100%)}to{transform:translate(0)}}.menu-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1rem;border-bottom:1px solid rgba(255,255,255,.1);color:#fff;font-size:1rem;font-weight:600}.menu-drawer-close{background:transparent;border:none;border-radius:8px;padding:.4rem;cursor:pointer;color:#ffffff80;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.menu-drawer-close:hover{color:#fff;background:#ffffff1a}.brand-label{display:inline-flex;align-items:center;gap:.55rem;min-width:0}.brand-label-icon{width:1.15rem;height:1.15rem;flex-shrink:0;object-fit:contain}.brand-label-text{min-width:0}.menu-drawer-nav{display:flex;flex-direction:column;padding:.5rem;gap:.2rem;flex:1}.menu-drawer-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:transparent;border:none;border-left:3px solid transparent;border-radius:0 8px 8px 0;color:#fff9;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .15s ease;text-align:left}.menu-drawer-item:hover{color:#ffffffe6;background:#ffffff0f}.menu-drawer-item.active{color:#fff;border-left-color:#667eea;background:#667eea26}.menu-drawer-divider{height:1px;background:#ffffff1a;margin:.25rem 1rem}.menu-drawer-spacer{flex:1}.menu-drawer-version{display:flex;flex-direction:column;gap:.15rem;margin:.5rem 1rem 0;padding:.75rem 0;border-top:1px solid rgba(255,255,255,.1)}.menu-drawer-version-label{color:#ffffff73;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em}.menu-drawer-version-value{color:#ffffffeb;font-size:.88rem;font-weight:600;overflow-wrap:anywhere}.menu-drawer-logout{margin-top:.35rem;color:#fca5a5d9}.menu-drawer-logout:hover{color:#fecaca;background:#ef444424}.sidebar-placeholder{color:#ffffff80;font-size:.85rem;line-height:1.5}.sidebar-header{padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center}.sidebar-header h2{font-size:1.25rem;font-weight:600;flex:1;text-align:center}.sidebar-actions{display:flex;gap:.5rem}.sidebar-icon-btn{background:#667eea4d;border:none;border-radius:8px;padding:.5rem;cursor:pointer;color:#fff;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.sidebar-icon-btn:hover{background:#667eea80;transform:scale(1.05)}.sidebar-icon-btn:disabled{opacity:.5;cursor:not-allowed}.sidebar-section{padding:.75rem}.sidebar-section+.sidebar-section{border-top:1px solid rgba(255,255,255,.08)}.sidebar-section-list{flex:1;display:flex;flex-direction:column;overflow:hidden;padding-bottom:0}.sidebar-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.sidebar-section-label{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#fff6;margin-bottom:.5rem}.sidebar-section-header .sidebar-section-label{margin-bottom:0}.project-count-badge{background:#667eea40;color:#ffffffb3;font-size:.65rem;font-weight:600;padding:.1rem .45rem;border-radius:8px;font-variant-numeric:tabular-nums}.sidebar-filters{display:flex;flex-direction:column;gap:.5rem}.filter-field{display:flex;flex-direction:column;gap:.25rem}.filter-label{font-size:.7rem;color:#ffffff80;font-weight:500}.filter-input{width:100%;padding:.45rem .6rem;border:1px solid rgba(255,255,255,.12);border-radius:8px;background:#ffffff0d;color:#fff;font-size:.8rem;outline:none;transition:all .15s ease}.filter-input::placeholder{color:#ffffff4d}.filter-input:focus{border-color:#667eea80;background:#ffffff14;box-shadow:0 0 0 2px #667eea26}.filter-date-row{display:flex;align-items:center;gap:.4rem}.filter-date{flex:1}.filter-date::-webkit-calendar-picker-indicator{filter:invert(.7);cursor:pointer}.filter-clear-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:8px;color:#ffffff80;width:30px;height:30px;font-size:.7rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;flex-shrink:0}.filter-clear-btn:hover{background:#ef444433;border-color:#ef44444d;color:#fca5a5}.sort-controls{display:flex;gap:.35rem}.sort-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.3rem;padding:.4rem .6rem;border:1px solid rgba(255,255,255,.12);border-radius:8px;background:#ffffff0d;color:#ffffff80;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .15s ease}.sort-btn:hover{border-color:#ffffff40;color:#ffffffb3;background:#ffffff14}.sort-btn.active{background:#667eea40;border-color:#667eea66;color:#fff}.sort-arrow{font-size:.7rem;font-weight:700}.pagination{padding:0 0 .5rem}.pagination-row{display:flex;align-items:center;justify-content:space-between;background:#ffffff0a;border-radius:8px;padding:.35rem .5rem}.pagination-nav{display:flex;align-items:center;gap:.4rem}.pagination-btn{background:#667eea33;border:none;border-radius:6px;color:#fff;width:26px;height:26px;font-size:.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.pagination-btn:hover:not(:disabled){background:#667eea66}.pagination-btn:disabled{opacity:.3;cursor:not-allowed}.pagination-info{font-size:.75rem;color:#fff9;font-variant-numeric:tabular-nums;min-width:2.5rem;text-align:center}.pagination-size{display:flex;align-items:center;gap:.2rem}.pagination-size-btn{background:transparent;border:1px solid rgba(255,255,255,.1);border-radius:4px;color:#fff6;padding:.15rem .4rem;font-size:.65rem;cursor:pointer;transition:all .15s ease}.pagination-size-btn:hover{border-color:#ffffff40;color:#ffffffb3}.pagination-size-btn.active{background:#667eea4d;border-color:#667eea80;color:#fff}.project-list{list-style:none;flex:1;overflow-y:auto}.project-item{padding:.7rem .75rem;cursor:pointer;border-radius:8px;margin:.15rem 0;transition:all .15s ease;display:flex;flex-direction:column;gap:.3rem}.project-item:hover{background-color:#ffffff12}.project-item.active{background-color:#667eea33;box-shadow:inset 3px 0 #667eea}.project-name{font-weight:500;font-size:.85rem;line-height:1.3}.project-meta{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.project-date{font-size:.7rem;color:#ffffff73}.project-status{font-size:.6rem;font-weight:600;padding:.1rem .45rem;border-radius:6px;white-space:nowrap}.status-in_progress{background-color:#3b82f633;color:#93c5fd}.status-completed{background-color:#22c55e33;color:#86efac}.status-failed{background-color:#ef444433;color:#fca5a5}.status-waiting_for_user{background-color:#f59e0b33;color:#fcd34d}.project-item.empty{color:#ffffff59;font-style:italic;font-size:.8rem;cursor:default;text-align:center;padding:2rem .75rem}.project-item.empty:hover{background-color:transparent}.main-content{width:80%;flex:1;display:flex;flex-direction:column;min-width:0;background-color:#f8fafc}.app-topbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.5rem;background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px #0f172a0d}.app-topbar-title-group{min-width:0;display:flex;flex-direction:column;gap:.15rem}.app-topbar-label{display:inline-flex;align-items:center;gap:.45rem;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#94a3b8}.app-topbar-label .brand-label-icon{width:.9rem;height:.9rem}.app-topbar-title{font-size:1.25rem;font-weight:600;color:#1e293b;line-height:1.2}.main-content-body{flex:1;min-height:0;min-width:0}.main-content-body.centered{display:flex;align-items:center;justify-content:center;padding:2rem;overflow:auto}.main-content-body.centered>*{max-width:100%}.main-content-body.full-bleed{display:flex;overflow:hidden}.main-content-body.full-bleed>*{flex:1;min-width:0}.main-content-body.scrollable{overflow-y:auto}.upload-button{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:3rem 4rem;background:#fff;border:2px dashed #cbd5e1;border-radius:16px;cursor:pointer;transition:all .3s ease;color:#64748b}.upload-button:hover{border-color:#667eea;background:#f8fafc;color:#667eea;transform:translateY(-2px);box-shadow:0 8px 25px #667eea26}.upload-button svg{opacity:.7}.upload-button:hover svg{opacity:1}.upload-button span{font-size:1.1rem;font-weight:500}.upload-button:disabled{cursor:not-allowed;opacity:.7}.upload-button:disabled:hover{transform:none;box-shadow:none;border-color:#cbd5e1;background:#fff;color:#64748b}.placeholder-content{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;height:100%;color:#94a3b8}.placeholder-content svg{opacity:.5}.placeholder-content span{font-size:1.1rem;font-weight:500}.converter-panel{max-width:560px;width:100%;margin:0 auto;padding:2rem;display:flex;flex-direction:column;gap:1.5rem}.converter-section{display:flex;flex-direction:column;gap:.75rem}.converter-section-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#94a3b8}.converter-options{display:flex;flex-direction:column;gap:.5rem}.converter-option{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;border:2px solid #e2e8f0;border-radius:10px;cursor:pointer;transition:all .2s ease;background:#fff}.converter-option:hover{border-color:#cbd5e1;background:#f8fafc}.converter-option.active{border-color:#667eea;background:#f0f1ff}.converter-option input[type=radio]{margin-top:.15rem;accent-color:#667eea}.converter-option-content{display:flex;flex-direction:column;gap:.15rem}.converter-option-label{font-weight:600;font-size:.95rem;color:#1e293b}.converter-option-desc{font-size:.8rem;color:#64748b}.converter-advanced-toggle{display:flex;align-items:center;gap:.35rem;background:none;border:none;cursor:pointer;font-size:.8rem;font-weight:500;color:#667eea;padding:0;transition:color .15s ease}.converter-advanced-toggle:hover{color:#4f5fcd}.converter-chevron{transition:transform .2s ease}.converter-chevron.open{transform:rotate(90deg)}.converter-advanced{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px}.converter-field{display:flex;flex-direction:column;gap:.3rem}.converter-field-label{font-size:.8rem;font-weight:600;color:#334155}.converter-field-input{padding:.5rem .75rem;border:1px solid #cbd5e1;border-radius:6px;font-size:.9rem;color:#1e293b;background:#fff;width:120px;transition:border-color .15s ease}.converter-field-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea26}.converter-field-hint{font-size:.7rem;color:#94a3b8}.converter-upload-btn{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1.25rem 2rem;border:2px dashed #cbd5e1;border-radius:12px;background:#fff;color:#64748b;cursor:pointer;transition:all .2s ease;font-size:1rem;font-weight:500;margin-top:.5rem}.converter-upload-btn:hover{border-color:#667eea;background:#f8fafc;color:#667eea}.converter-upload-btn:disabled{cursor:not-allowed;opacity:.7}.converter-upload-btn .spinner{width:28px;height:28px;border-width:3px}.converter-hint{font-size:.8rem;color:#94a3b8;text-align:center}.converter-message{padding:.75rem 1rem;border-radius:8px;font-size:.85rem;font-weight:500}.converter-success{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.converter-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.splitter-panel{max-width:560px;width:100%;margin:0 auto;padding:2rem;display:flex;flex-direction:column;gap:1.25rem}.splitter-description{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1rem 1.25rem;color:#475569;font-size:.92rem;line-height:1.55}.splitter-description p+p{margin-top:.6rem}.spinner{width:48px;height:48px;border:4px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.project-detail{width:100%;height:100%;display:flex;flex-direction:column;background:#f8fafc}.project-detail-loading,.project-detail-error{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:#64748b}.back-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:transparent;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;color:#64748b;font-size:.9rem;transition:all .2s ease}.back-button:hover{background:#f1f5f9;color:#1e293b;border-color:#cbd5e1}.project-title{flex:1;font-size:1.5rem;font-weight:600;color:#1e293b;margin:0}.project-title.editable{cursor:pointer;display:flex;align-items:center;gap:.5rem;padding:.2rem .5rem;border-radius:8px;transition:background .15s ease}.project-title.editable:hover{background:#f1f5f9}.project-title .edit-icon{color:#94a3b8;flex-shrink:0}.project-title-input{flex:1;font-size:1.5rem;font-weight:600;color:#1e293b;border:2px solid #667eea;border-radius:8px;padding:.2rem .5rem;outline:none;background:#fff;font-family:inherit;box-shadow:0 0 0 3px #667eea26}.project-detail-status{font-size:.85rem;padding:.4rem 1rem;border-radius:20px;font-weight:500;display:inline-flex;align-items:center}.project-detail-status.status-in_progress{background:#3b82f626;color:#2563eb}.project-detail-status.status-completed{background:#22c55e26;color:#16a34a}.project-detail-status.status-failed{background:#ef444426;color:#dc2626}.project-detail-status.status-waiting_for_user{background:#f59e0b26;color:#d97706}.project-detail-content{flex:1;padding:2rem;overflow-y:auto;display:flex;flex-direction:column;gap:1.5rem}.project-info-card,.warnings-card,.processing-status-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #00000014}.project-info-overview{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid #f1f5f9}.project-info-overview-main{min-width:0;flex:1;display:flex;align-items:center;gap:.75rem}.project-info-title-wrap{min-width:0;flex:1}.project-info-collapse-button{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border:1px solid #e2e8f0;border-radius:8px;background:#fff;color:#64748b;cursor:pointer;transition:all .15s ease;flex-shrink:0}.project-info-collapse-button:hover{background:#f8fafc;border-color:#cbd5e1;color:#1e293b}.project-info-overview-actions{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.project-info-collapsible{display:grid;grid-template-rows:0fr;opacity:0;transition:grid-template-rows .22s ease,opacity .16s ease}.project-info-collapsible.expanded{grid-template-rows:1fr;opacity:1}.project-info-collapsible-inner{min-height:0;overflow:hidden}.project-info-card h3,.warnings-card h3,.processing-status-card h3{font-size:1rem;font-weight:600;color:#1e293b;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid #f1f5f9}.processing-status-source-file{margin-top:-.5rem;margin-bottom:.9rem;color:#64748b;font-size:.9rem}.info-row{display:flex;gap:1rem;padding:.5rem 0}.project-info-actions{display:flex;justify-content:flex-end;margin-top:1rem}.info-label{font-size:.9rem;color:#64748b;min-width:140px}.info-value{font-size:.9rem;color:#1e293b;font-weight:500}.project-files-info-list{margin:0;padding-left:1.1rem}.project-files-info-list li+li{margin-top:.2rem}.warnings-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.6rem}.warning-item{display:flex;flex-direction:column;gap:.2rem;padding:.7rem .8rem;border-radius:8px;background:#fff7ed;border:1px solid #fdba74}.warning-step{font-size:.75rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#b45309}.warning-message{font-size:.9rem;color:#7c2d12}.show-all-matches-row{display:flex;align-items:center;justify-content:flex-end;gap:.5rem;margin-top:1rem}.show-all-matches-button{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.85rem;font-weight:500;color:#3b82f6;background:#3b82f614;border:1px solid rgba(59,130,246,.2);border-radius:6px;cursor:pointer;transition:all .15s ease}.show-all-matches-button:hover{background:#3b82f626;border-color:#3b82f659}.show-all-matches-hint{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;font-size:.7rem;font-weight:700;color:#94a3b8;border:1.5px solid #cbd5e1;border-radius:50%;cursor:help;flex-shrink:0}.show-all-matches-hint:hover{color:#64748b;border-color:#94a3b8}.processing-indicator{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#3b82f61a;border-radius:8px;margin-bottom:1.5rem;color:#2563eb;font-weight:500;font-size:.9rem}.processing-indicator.waiting{background:#f59e0b1a;color:#d97706}.steps-container{display:flex;flex-direction:column;gap:.5rem}.step-item{display:flex;align-items:flex-start;gap:1rem;padding:.75rem 1rem;border-radius:8px;transition:all .2s ease}.step-item.active{background:#3b82f61a}.step-item.done{background:#22c55e1a}.step-item.failed{background:#ef44441a}.step-item.waiting{background:#f59e0b1a}.step-indicator{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600;background:#e2e8f0;color:#64748b;flex-shrink:0}.step-item.active .step-indicator{background:#3b82f6;color:#fff}.step-item.done .step-indicator{background:#22c55e;color:#fff}.step-item.failed .step-indicator{background:#ef4444;color:#fff}.step-item.waiting .step-indicator{background:#f59e0b;color:#fff}.step-item.interrupted{background:#f59e0b1a}.step-item.interrupted .step-indicator{background:#f59e0b;color:#fff}.step-item.interrupted .step-label,.step-item.interrupted .step-chevron{color:#d97706}.step-interrupted-message{display:flex;align-items:center;gap:.4rem;padding:.35rem .6rem;margin-top:.3rem;background:#f59e0b14;border:1px solid rgba(245,158,11,.2);border-radius:6px;color:#d97706;font-size:.8rem;font-weight:500}.step-number{font-size:.75rem}.step-content{display:flex;flex-direction:column;gap:.25rem;flex:1}.step-label{font-size:.9rem;color:#64748b}.step-item.active .step-label{color:#2563eb;font-weight:500}.step-item.done .step-label{color:#16a34a}.step-item.failed .step-label{color:#dc2626}.step-item.waiting .step-label{color:#d97706;font-weight:500}.step-description{font-size:.78rem;color:#a0aec0;font-style:italic;line-height:1.35;margin-top:.15rem}.step-duration{font-size:.75rem;color:#94a3b8}.step-item.done .step-duration{color:#86efac}.step-item.active .step-duration{color:#93c5fd}.step-progress-text{font-size:.75rem;color:#93c5fd;font-variant-numeric:tabular-nums;white-space:nowrap}.step-generating-report{margin-left:.5rem;color:#93c5fd;font-style:italic}.step-progress{height:4px;background:#3b82f626;border-radius:2px;overflow:hidden;margin-top:.5rem}.step-progress-bar{height:100%;background:#3b82f6;border-radius:2px;transition:width .4s ease}.step-header{display:flex;align-items:center;gap:.75rem}.step-header-collapsible{cursor:pointer;-webkit-user-select:none;user-select:none}.step-chevron{flex-shrink:0;transition:transform .2s ease;color:#64748b}.step-chevron.expanded{transform:rotate(90deg)}.step-item.done .step-chevron{color:#16a34a}.step-item.failed .step-chevron{color:#dc2626}.step-item.waiting .step-chevron{color:#d97706}.restart-step-button{display:inline-flex;align-items:center;gap:.35rem;padding:.2rem .6rem;font-size:.75rem;font-weight:500;color:#dc2626;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:4px;cursor:pointer;transition:all .15s ease;margin-left:auto}.restart-step-button:hover:not(:disabled){background:#ef444433;border-color:#ef444480}.restart-step-button:disabled{opacity:.6;cursor:not-allowed}.restart-step-button .step-spinner.small{width:12px;height:12px;border-width:2px}.step-item.done .restart-step-button{color:#64748b;background:#64748b14;border-color:#64748b33}.step-item.done .restart-step-button:hover:not(:disabled){background:#64748b26;border-color:#64748b59}.step-item.waiting .restart-step-button{color:#64748b;background:#64748b14;border-color:#64748b33}.step-item.waiting .restart-step-button:hover:not(:disabled){background:#64748b26;border-color:#64748b59}.interrupt-step-button{display:inline-flex;align-items:center;gap:.35rem;padding:.2rem .6rem;font-size:.75rem;font-weight:500;color:#dc2626;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:4px;cursor:pointer;transition:all .15s ease;margin-left:auto}.interrupt-step-button:hover:not(:disabled){background:#ef444433;border-color:#ef444480}.interrupt-step-button:disabled{opacity:.6;cursor:not-allowed}.interrupt-step-button .step-spinner.small{width:12px;height:12px;border-width:2px}.step-output-box{font-size:.8rem;color:#475569;background:#f8fafc;border:1px solid #e2e8f0;padding:.5rem .75rem;border-radius:6px;margin-top:.5rem;white-space:pre-wrap;word-break:break-word}.step-item.done .step-output-box{background:#22c55e14;border-color:#22c55e33;color:#166534}.step-item.failed .step-output-box{background:#ef444414;border-color:#ef444433;color:#991b1b}.step-item.waiting .step-output-box{background:#f59e0b14;border-color:#f59e0b33;color:#92400e}.step-output-json{display:flex;flex-wrap:wrap;gap:.5rem 1.5rem}.step-output-field{display:flex;align-items:center;gap:.35rem}.step-output-key{font-weight:500;color:#64748b}.step-item.done .step-output-key{color:#15803d}.step-item.failed .step-output-key{color:#b91c1c}.step-output-value{font-family:SF Mono,Monaco,Menlo,monospace;font-weight:600}.step-output-text{display:block}.convert-png-output{display:flex;flex-direction:column;gap:.4rem}.exclude-legend-output{display:flex;flex-direction:column;gap:.35rem}.step-preview-action{margin-top:.45rem}.step-item.done .step-preview-action{border-color:#22c55e47;background:linear-gradient(180deg,#f0fdf4fa,#dcfce7fa)}.step-item.done .step-preview-action.legend-review-option-primary{border-color:#16a34a66;background:linear-gradient(180deg,#ecfdf5,#dcfce7fa)}.step-item.done .step-preview-action:hover:not(:disabled){border-color:#16a34a80;background:linear-gradient(180deg,#dcfce7,#bbf7d0);box-shadow:0 10px 24px #15803d24}.step-item.done .step-preview-action:focus-visible{border-color:#15803d;box-shadow:0 0 0 3px #22c55e2e}.step-item.done .step-preview-action .legend-review-option-copy h4,.step-item.done .step-preview-action .legend-review-option-copy p{color:#166534}.step-item.done .step-preview-action .legend-review-option-state{color:#15803d}.png-summary{font-weight:500;margin-bottom:.1rem}.png-file-info{display:flex;align-items:center;gap:1rem}.png-file-label{font-weight:500;min-width:140px;color:#64748b}.step-item.done .png-file-label{color:#15803d}.step-item.failed .png-file-label{color:#b91c1c}.png-file-detail{font-family:SF Mono,Monaco,Menlo,monospace;font-weight:600}.step-artifact-box{margin-top:.5rem;border:1px solid #e2e8f0;border-radius:6px;overflow:hidden;background:#f8fafc}.step-item.done .step-artifact-box{border-color:#22c55e33;background:#22c55e0a}.step-artifact-image{display:block;max-width:100%;height:auto;max-height:400px;object-fit:contain}.step-artifact-image.clickable{cursor:zoom-in;transition:opacity .15s ease}.step-artifact-image.clickable:hover{opacity:.85}.legend-manual-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .65rem;margin:.5rem .5rem 0;background:#fef3c7;color:#92400e;border:1px solid #fcd34d;border-radius:999px;font-size:.75rem;font-weight:600;line-height:1}.legend-manual-badge svg{flex-shrink:0}.luminaires-symbols-list{margin-top:.25rem}.luminaires-table{width:100%;border-collapse:collapse;font-size:.82rem;table-layout:auto}.luminaires-table th{text-align:left;padding:.4rem .6rem;border-bottom:2px solid #cbd5e1;font-weight:600;color:#334155;font-size:.78rem;text-transform:uppercase;letter-spacing:.03em}.luminaires-table td{padding:.35rem .6rem;border-bottom:1px solid #e2e8f0;vertical-align:top}.luminaires-table tbody tr:last-child td{border-bottom:none}.luminaires-table tbody tr:hover{background:#00000005}.step-item.done .luminaires-table tbody tr:hover{background:#22c55e0f}.luminaire-symbol{font-weight:600;white-space:nowrap;color:#1e293b}.step-item.done .luminaire-symbol{color:#14532d}.luminaire-description{color:#475569}.step-item.done .luminaire-description{color:#166534}.luminaires-table .description-col{width:auto}.luminaires-table .emergency-col{width:1%;white-space:nowrap;line-height:1.2}.symbol-table .description-col{width:32%}.symbol-table .emergency-col{width:132px;white-space:normal;line-height:1.2}.luminaires-table .emergency-col-cell{width:1%;white-space:nowrap}.symbol-table .emergency-col-cell{width:132px}.emergency-col-cell input[type=checkbox]{width:14px;height:14px;margin:0}.emergency-col-cell input[type=checkbox][readonly]{accent-color:lightgray;cursor:default;pointer-events:none}.luminaires-table .luminaire-id,.luminaires-table .luminaire-symbol{white-space:nowrap;width:1%}.luminaires-table th:nth-child(2),.luminaires-table td:nth-child(2),.symbol-table th:nth-child(2),.symbol-table td:nth-child(2){min-width:7rem}.luminaires-count{margin-top:.5rem;font-size:.78rem;color:#64748b;text-align:right}.step-item.done .luminaires-count{color:#166534}.legend-upload-prompt{display:flex;flex-direction:column;gap:1rem;padding:1.25rem}.legend-upload-icon{color:#d97706}.legend-upload-message{font-size:.85rem;font-weight:500;color:#92400e}.legend-upload-hint{font-size:.78rem;color:#a16207}.legend-review-intro{margin:0;text-align:left}.legend-review-options{display:grid;gap:.9rem}.legend-review-option{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;width:100%;padding:1rem 1.1rem;border:1px solid #fde68a;border-radius:14px;background:linear-gradient(180deg,#fffdf5,#fff7ed);text-align:left;cursor:pointer;transition:border-color .2s,background .2s,transform .2s,box-shadow .2s;appearance:none;-webkit-appearance:none;box-shadow:none;outline:none}.legend-review-option-primary{border-color:#f59e0b;background:linear-gradient(180deg,#fff7ed,#fffbeb)}.legend-review-option:hover:not(:disabled){border-color:#f59e0b;background:linear-gradient(180deg,#fff7ed,#fff3c4);transform:translateY(-1px);box-shadow:0 10px 24px #b453091f}.legend-review-option:focus-visible{border-color:#d97706;box-shadow:0 0 0 3px #f59e0b33}.legend-review-option:disabled{opacity:.7;cursor:not-allowed;transform:none;box-shadow:none}.legend-review-option-copy{display:flex;flex-direction:column;gap:.35rem;min-width:0}.legend-review-option-copy h4{margin:0;font-size:.9rem;font-weight:700;color:#9a3412}.legend-review-option-copy p{margin:0;font-size:.8rem;line-height:1.45;color:#7c2d12}.legend-review-option-state{flex-shrink:0;min-width:180px;align-self:center;text-align:right;font-size:.76rem;font-weight:700;color:#b45309}.legend-upload-button{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;background:#f59e0b;color:#fff;border:none;border-radius:8px;font-size:.82rem;font-weight:500;cursor:pointer;transition:background .2s}.legend-upload-button:hover:not(:disabled){background:#d97706}.legend-upload-button:disabled{opacity:.7;cursor:not-allowed}.legend-skip-button{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.55rem 1rem;background:#fff7ed;color:#9a3412;border:1px solid #fdba74;border-radius:8px;font-size:.8rem;font-weight:500;cursor:pointer;transition:background .2s,border-color .2s}.legend-skip-button:hover:not(:disabled){background:#ffedd5;border-color:#fb923c}.legend-skip-button:disabled{opacity:.7;cursor:not-allowed}.legend-upload-error{font-size:.78rem;color:#dc2626}@media(max-width:860px){.legend-review-option{flex-direction:column;align-items:stretch}.legend-review-option-state{min-width:0;text-align:left}}.symbol-table{width:100%;border-collapse:collapse;margin-top:.25rem}.symbol-table th{text-align:left;padding:.45rem .6rem;font-size:.75rem;font-weight:600;color:#64748b;border-bottom:2px solid #e2e8f0;white-space:nowrap;text-transform:uppercase;letter-spacing:.03em}.symbol-table td{padding:.4rem .6rem;border-bottom:1px solid #e2e8f0;font-size:.82rem;vertical-align:middle}.symbol-table tbody tr{transition:background .1s ease}.symbol-table tbody tr:hover{background:#2563eb0a}.symbol-table-id{font-family:SF Mono,Fira Code,Consolas,monospace;font-size:.78rem;color:#94a3b8}.symbol-table-desc{color:#64748b;max-width:320px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.symbol-table-preview{display:block;max-width:80px;max-height:50px;object-fit:contain;cursor:zoom-in;border-radius:3px;transition:opacity .15s ease}.symbol-table-preview:hover{opacity:.8}.symbol-preview-cell{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.symbol-preview-item{position:relative;display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .3rem;border-radius:4px;transition:opacity .15s ease}.symbol-preview-item.preview-deselected{opacity:.35}.symbol-preview-checkbox{display:inline-flex;align-items:center;cursor:pointer}.symbol-preview-checkbox input[type=checkbox]{width:14px;height:14px;cursor:pointer}.symbol-preview-empty{color:#cbd5e1;font-size:.8rem}.symbol-preview-loading,.symbol-preview-error{display:inline-flex;align-items:center;justify-content:center;min-width:80px;min-height:50px;padding:.25rem;border:1px dashed #cbd5e1;border-radius:3px;color:#94a3b8;font-size:.72rem;text-align:center}.symbol-preview-error{color:#b91c1c;border-color:#fecaca;background:#fef2f2}.symbol-image-label{font-weight:600;font-size:.82rem;color:#334155}.step-item.done .symbol-image-label{color:#14532d}.dominant-colors-list{margin-top:.25rem}.dominant-colors-table{width:100%;border-collapse:collapse}.dominant-colors-table th{text-align:left;padding:.4rem .6rem;font-size:.78rem;font-weight:600;color:#64748b;border-bottom:1px solid #e2e8f0}.dominant-colors-table td{padding:.35rem .6rem;border-bottom:1px solid #e2e8f0;font-size:.82rem}.dominant-colors-table tbody tr:last-child td{border-bottom:none}.dominant-colors-table tbody tr:hover{background:#00000005}.step-item.done .dominant-colors-table tbody tr:hover{background:#22c55e0f}.color-cell{display:inline-flex;align-items:center;gap:.4rem}.color-swatch{display:inline-block;width:16px;height:16px;border-radius:3px;border:1px solid rgba(0,0,0,.15);flex-shrink:0}.color-hex{font-family:SF Mono,Fira Code,Consolas,monospace;font-size:.78rem;color:#334155}.color-rgb{font-size:.72rem;color:#94a3b8}.color-none{color:#cbd5e1}.step-item.done .color-hex{color:#166534}.step-item.done .color-rgb{color:#4ade80}.symbol-verification{display:flex;flex-direction:column;gap:.75rem}.symbol-delete-btn{background:#ef44441a;border:1px solid rgba(239,68,68,.3);cursor:pointer;color:#dc2626;padding:3px;border-radius:4px;display:flex;align-items:center;justify-content:center;margin-left:auto;transition:all .15s ease}.symbol-delete-btn:hover{color:#fff;background:#ef4444;border-color:#ef4444}.user-added-badge{display:inline-block;font-size:.65rem;color:#2563eb;background:#2563eb14;padding:.1rem .3rem;border-radius:3px;margin-left:.25rem}.symbol-group-badge{font-size:.65rem;padding:.1rem .4rem;border-radius:3px;text-align:center;font-weight:600}.symbol-verification-footer{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;flex-wrap:wrap;padding-top:.5rem;border-top:1px solid #e2e8f0}.symbol-verification-footer-actions{display:flex;flex-wrap:wrap;gap:.5rem;align-items:stretch;justify-content:flex-end}.symbol-count-info{font-size:.82rem;color:#64748b;line-height:1.35}.same-legend-toggle{display:inline-flex;align-items:center;gap:.55rem;padding:.45rem .65rem;border:1px solid #cbd5e1;border-radius:.6rem;background:#f8fafc;color:#334155;max-width:320px;cursor:pointer;transition:border-color .15s ease,background .15s ease,box-shadow .15s ease}.same-legend-toggle input[type=checkbox]{width:15px;height:15px;margin:0;flex-shrink:0;cursor:pointer}.same-legend-toggle-content{display:inline-flex;flex-direction:column;gap:.1rem}.same-legend-toggle-title{font-size:.78rem;font-weight:600;color:#1e293b}.same-legend-toggle-hint{font-size:.72rem;color:#64748b}.same-legend-toggle:hover{border-color:#93c5fd;background:#eff6ff}.same-legend-toggle.active{border-color:#2563eb;background:#eff6ff;box-shadow:0 0 0 2px #2563eb1f}.same-legend-toggle.disabled{opacity:.7;cursor:not-allowed}.same-legend-toggle.disabled input[type=checkbox]{cursor:not-allowed}.symbol-action-button{display:inline-flex;align-items:center;gap:.4rem;justify-content:center;min-height:36px;padding:.5rem .95rem;border:1px solid transparent;border-radius:.5rem;font-size:.8rem;font-weight:600;line-height:1;cursor:pointer;transition:background-color .15s ease,border-color .15s ease,color .15s ease,opacity .15s ease}.symbol-action-button-secondary{background:#fff7ed;color:#9a3412;border-color:#fdba74}.symbol-action-button-secondary:hover:not(:disabled){background:#ffedd5;border-color:#fb923c}.symbol-action-button-primary{background:#2563eb;color:#fff;border-color:#2563eb;min-width:164px}.symbol-action-button-primary:hover:not(:disabled){background:#1d4ed8;border-color:#1d4ed8}.symbol-action-button:disabled{opacity:.5;cursor:not-allowed}.symbol-import-box{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .45rem;border:1px solid #cbd5e1;border-radius:.65rem;background:#f8fafc;box-shadow:inset 0 1px #ffffffb3}.symbol-import-select{min-height:36px;max-width:240px;padding:.45rem 2rem .45rem .6rem;border:1px solid #cbd5e1;border-radius:.5rem;font-size:.8rem;font-weight:500;color:#1e293b;background:#fff;line-height:1.2;cursor:pointer;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:linear-gradient(45deg,transparent 50%,#64748b 50%),linear-gradient(135deg,#64748b 50%,transparent 50%);background-position:calc(100% - 14px) calc(50% - 2px),calc(100% - 9px) calc(50% - 2px);background-size:5px 5px,5px 5px;background-repeat:no-repeat;transition:border-color .15s ease,box-shadow .15s ease,background-color .15s ease}.symbol-import-select:hover:not(:disabled){border-color:#93c5fd;background-color:#f8fbff}.symbol-import-select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb2e}.symbol-import-select option{font-weight:500;color:#1e293b;background:#fff}.symbol-import-box .symbol-action-button-secondary{min-width:90px}.symbol-import-select:disabled{opacity:.6;cursor:not-allowed}.region-selector-top-hint{position:absolute;bottom:4.5rem;left:50%;transform:translate(-50%);background:#000000a6;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#ffffffeb;font-size:.85rem;padding:.5rem 1.2rem;border-radius:8px;z-index:1001;text-align:center;max-width:90vw;pointer-events:none;-webkit-user-select:none;user-select:none}.region-selector-toast{position:absolute;bottom:5.5rem;left:50%;transform:translate(-50%);background:#22783ce6;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#fff;font-size:.9rem;font-weight:500;padding:.6rem 1.4rem;border-radius:8px;z-index:1002;text-align:center;pointer-events:none;-webkit-user-select:none;user-select:none;animation:region-toast-fade 3s ease-in-out}@keyframes region-toast-fade{0%{opacity:0;transform:translate(-50%) translateY(8px)}10%{opacity:1;transform:translate(-50%) translateY(0)}80%{opacity:1}to{opacity:0}}.region-selector-bottom-form{position:absolute;bottom:4.5rem;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:.5rem;background:#000000b3;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:.5rem .75rem;border-radius:10px;z-index:1001;white-space:nowrap}.region-selector-bottom-form .region-selector-input{padding:.45rem .6rem;border:1px solid rgba(255,255,255,.25);border-radius:.375rem;font-size:.82rem;min-width:130px;background:#ffffff1f;color:#fff}.region-selector-bottom-form .region-selector-input::placeholder{color:#ffffff80}.region-selector-bottom-form .region-selector-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb4d}.region-selector-bottom-form .region-selector-input:disabled{opacity:.45;cursor:not-allowed;background:#ffffff0d}.region-selector-select{padding:.45rem .6rem;border:1px solid rgba(255,255,255,.25);border-radius:.375rem;font-size:.82rem;min-width:150px;background:#ffffff1f;color:#fff;cursor:pointer}.region-selector-select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb4d}.region-selector-select option{background:#1e293b;color:#fff}.region-selector-emergency-toggle{display:inline-flex;align-items:center;gap:.4rem;color:#e2e8f0;font-size:.8rem;-webkit-user-select:none;user-select:none}.region-selector-emergency-toggle input[type=checkbox]{width:14px;height:14px;margin:0}.region-mode-btn.region-mode-active{background:#2563eb80;box-shadow:inset 0 0 0 1.5px #2563ebcc}.region-mode-separator{width:1px;height:20px;background:#fff3;margin:0 .15rem}.region-selector-bottom-form .confirm-symbols-btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem .9rem;background:#2563eb;color:#fff;border:1px solid rgba(255,255,255,.15);border-radius:.375rem;font-size:.82rem;font-weight:600;cursor:pointer;transition:background .2s,box-shadow .2s}.region-selector-bottom-form .confirm-symbols-btn:hover:not(:disabled){background:#1d4ed8;box-shadow:0 0 0 2px #2563eb4d}.region-selector-bottom-form .confirm-symbols-btn:disabled{opacity:.5;cursor:not-allowed}.luminaire-masks-list{margin-top:.25rem}.luminaire-masks-table{width:100%;border-collapse:collapse}.luminaire-masks-table th{text-align:left;padding:.4rem .6rem;font-size:.78rem;font-weight:600;color:#64748b;border-bottom:1px solid #e2e8f0}.luminaire-masks-table td{padding:.35rem .6rem;border-bottom:1px solid #e2e8f0;font-size:.82rem}.luminaire-masks-table tbody tr:last-child td{border-bottom:none}.luminaire-masks-table tbody tr:hover{background:#00000005}.step-item.done .luminaire-masks-table tbody tr:hover{background:#22c55e0f}.mask-colors{display:inline-flex;align-items:center;gap:.6rem}.mask-view-button{display:inline-flex;align-items:center;gap:.35rem;padding:.25rem .6rem;font-size:.78rem;font-weight:500;color:#3b82f6;background:#3b82f614;border:1px solid rgba(59,130,246,.2);border-radius:4px;cursor:pointer;transition:all .15s ease}.mask-view-button:hover{background:#3b82f626;border-color:#3b82f659}.step-item.done .mask-view-button{color:#16a34a;background:#22c55e14;border-color:#22c55e33}.step-item.done .mask-view-button:hover{background:#22c55e26;border-color:#22c55e59}.count-symbols-result{margin-top:.25rem;display:flex;flex-direction:column;gap:.3rem}.count-symbols-row{display:flex;align-items:baseline;gap:.5rem;font-size:.82rem}.count-symbols-label{color:#64748b;font-size:.78rem;min-width:7rem}.step-item.done .count-symbols-label{color:#166534}.step-item.failed .count-symbols-label{color:#991b1b}.count-symbols-value{font-weight:600;color:#1e293b}.step-item.done .count-symbols-value{color:#14532d}.count-symbols-count{font-weight:700;font-size:1.1rem;color:#1e293b}.step-item.done .count-symbols-count{color:#14532d}.count-symbols-pending{font-weight:600;font-size:.95rem;color:#b45309}.lightbox-overlay{position:fixed;inset:0;z-index:1000;background:#000c;display:flex;align-items:center;justify-content:center;cursor:zoom-out;animation:lightbox-fade-in .15s ease}@keyframes lightbox-fade-in{0%{opacity:0}to{opacity:1}}.lightbox-close{position:absolute;top:1rem;right:1rem;background:#ffffff26;border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer;transition:background .15s ease}.lightbox-close:hover{background:#ffffff4d}.lightbox-image{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:4px;cursor:default;box-shadow:0 8px 40px #0006;transition:transform .1s ease-out;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.lightbox-zoom-controls{position:absolute;bottom:1.5rem;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:.25rem;background:#0009;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:8px;padding:.35rem .5rem;z-index:1001}.lightbox-zoom-btn{background:#ffffff1a;border:none;border-radius:6px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer;transition:background .15s ease}.lightbox-zoom-btn:hover{background:#ffffff40}.lightbox-zoom-level{color:#ffffffd9;font-size:.8rem;font-weight:500;min-width:3rem;text-align:center;-webkit-user-select:none;user-select:none;font-variant-numeric:tabular-nums}.match-overlay-container{position:relative;display:inline-block;transition:transform .1s ease-out;-webkit-user-select:none;user-select:none}.match-overlay-image{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:4px;display:block;box-shadow:0 8px 40px #0006;-webkit-user-drag:none}.match-overlay-svg{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.step-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.spinner.small{width:20px;height:20px;border-width:2px}.error-message,.success-message{display:flex;align-items:center;gap:.75rem;padding:1rem;border-radius:8px;margin-top:1.5rem;font-size:.9rem;font-weight:500}.error-message{background:#ef44441a;color:#dc2626}.error-message.interrupted-message{background:#f59e0b1a;color:#d97706}.success-message{background:#22c55e1a;color:#16a34a;flex-wrap:wrap}.export-xlsx-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem 1rem;border:none;border-radius:6px;background:#16a34a;color:#fff;font-size:.85rem;font-weight:500;cursor:pointer;transition:background .15s;white-space:nowrap}.export-xlsx-btn:hover{background:#15803d}.export-xlsx-btn:active{background:#166534}.settings-panel{width:100%;height:100%;display:flex;flex-direction:column;background:#f8fafc}.settings-header{display:flex;align-items:center;gap:1rem;padding:1.5rem 2rem;background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px #0000000d}.settings-title{font-size:1.5rem;font-weight:600;color:#1e293b}.settings-content{flex:1;padding:2rem;overflow-y:auto}.settings-section{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #00000014}.settings-section h3{font-size:1rem;font-weight:600;color:#1e293b;margin-bottom:.25rem}.settings-description{font-size:.85rem;color:#64748b;margin-bottom:1.25rem}.settings-hint{font-size:.78rem;color:#94a3b8;margin-bottom:1rem;line-height:1.5}.settings-hint a{color:#667eea;text-decoration:none}.settings-hint a:hover{text-decoration:underline}.provider-cards{display:flex;gap:1rem}.provider-card{flex:1;display:flex;flex-direction:column;gap:.35rem;padding:1.25rem;background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;cursor:pointer;transition:all .2s ease;text-align:left}.provider-card:hover{border-color:#cbd5e1;background:#f1f5f9}.provider-card.active{border-color:#667eea;background:#667eea14;box-shadow:0 0 0 1px #667eea4d}.provider-card-header{display:flex;justify-content:space-between;align-items:center}.provider-name{font-size:1.1rem;font-weight:600;color:#1e293b}.provider-card.active .provider-name{color:#4f46e5}.provider-card.active svg{color:#667eea}.provider-company{font-size:.8rem;color:#94a3b8;font-weight:500}.provider-model{font-size:.8rem;font-family:SF Mono,Monaco,Menlo,monospace;color:#64748b;background:#0000000a;padding:.2rem .5rem;border-radius:4px;width:fit-content;margin-top:.25rem}.provider-card.active .provider-model{background:#667eea1a;color:#4f46e5}.provider-costs{display:flex;flex-direction:column;gap:.3rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e2e8f0}.provider-card.active .provider-costs{border-top-color:#667eea33}.provider-cost-row{display:flex;justify-content:space-between;align-items:center}.provider-cost-label{font-size:.78rem;color:#94a3b8;font-weight:500}.provider-cost-value{font-size:.78rem;font-family:SF Mono,Monaco,Menlo,monospace;color:#64748b;font-weight:600}.provider-card.active .provider-cost-value{color:#4f46e5}.settings-section+.settings-section{margin-top:1.5rem}.settings-contact-links{display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.settings-contact-link{display:flex;align-items:center;gap:.75rem;min-width:0;padding:1rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;color:#1e293b;text-decoration:none;transition:border-color .2s ease,background .2s ease,transform .2s ease}.settings-contact-link:hover{background:#f1f5f9;border-color:#cbd5e1;transform:translateY(-1px)}.settings-contact-icon{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;flex-shrink:0;border-radius:8px;background:#e0f2fe;color:#0284c7}.settings-contact-icon.google-doc-icon{background:#e8f0fe}.settings-contact-title,.settings-contact-value{display:block}.settings-contact-title{font-size:.9rem;font-weight:600;color:#1e293b}.settings-contact-value{margin-top:.15rem;font-size:.8rem;color:#64748b;overflow-wrap:anywhere}.settings-toggle{display:flex;align-items:center;gap:.75rem;cursor:pointer;-webkit-user-select:none;user-select:none}.settings-toggle input{display:none}.toggle-track{position:relative;width:44px;height:24px;background:#cbd5e1;border-radius:12px;transition:background .2s ease;flex-shrink:0}.settings-toggle input:checked+.toggle-track{background:#667eea}.toggle-thumb{position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .2s ease;box-shadow:0 1px 3px #00000026}.settings-toggle input:checked+.toggle-track .toggle-thumb{transform:translate(20px)}.toggle-label{font-size:.9rem;font-weight:500;color:#475569}.delete-project-button{display:flex;align-items:center;justify-content:center;padding:.5rem;background:transparent;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;color:#94a3b8;transition:all .2s ease;flex-shrink:0}.delete-project-button:hover{background:#ef44441a;border-color:#ef44444d;color:#dc2626}.delete-project-button:disabled{opacity:.5;cursor:not-allowed}.confirm-overlay{position:fixed;inset:0;z-index:1000;background:#00000080;display:flex;align-items:center;justify-content:center;animation:lightbox-fade-in .15s ease}.confirm-dialog{background:#fff;border-radius:16px;padding:2rem;max-width:420px;width:90%;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;align-items:center;text-align:center;gap:.75rem}.confirm-icon{color:#f59e0b;margin-bottom:.25rem}.confirm-icon.confirm-icon-blue{color:#2563eb}.confirm-dialog h3{font-size:1.25rem;font-weight:600;color:#1e293b;margin:0}.confirm-message{font-size:.9rem;color:#475569;line-height:1.5;margin:0}.confirm-warning{font-size:.85rem;color:#dc2626;background:#ef444414;border:1px solid rgba(239,68,68,.15);border-radius:8px;padding:.6rem 1rem;line-height:1.4;margin:0}.confirm-actions{display:flex;gap:.75rem;margin-top:.5rem;width:100%}.confirm-cancel-btn,.confirm-delete-btn{flex:1;padding:.65rem 1rem;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.confirm-cancel-btn{background:#f1f5f9;border:1px solid #e2e8f0;color:#475569}.confirm-cancel-btn:hover:not(:disabled){background:#e2e8f0;color:#1e293b}.confirm-delete-btn{background:#dc2626;border:1px solid #dc2626;color:#fff}.confirm-delete-btn:hover:not(:disabled){background:#b91c1c;border-color:#b91c1c}.confirm-restart-btn{flex:1;padding:.65rem 1rem;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center;gap:.5rem;background:#2563eb;border:1px solid #2563eb;color:#fff}.confirm-restart-btn:hover{background:#1d4ed8;border-color:#1d4ed8}.confirm-cancel-btn:disabled,.confirm-delete-btn:disabled,.confirm-restart-btn:disabled{opacity:.6;cursor:not-allowed}.confirm-delete-btn .spinner.small{width:16px;height:16px;border-width:2px;border-color:#ffffff4d;border-top-color:#fff}.faq-panel{max-width:640px;width:100%;margin:0 auto;padding:2.5rem 2rem}.faq-title{font-size:1.5rem;font-weight:600;color:#1e293b;margin-bottom:1.5rem}.faq-list{display:flex;flex-direction:column;gap:.5rem}.faq-item{background:#fff;border:1px solid #e2e8f0;border-radius:10px;overflow:hidden;transition:box-shadow .2s ease}.faq-item.open{box-shadow:0 2px 8px #0000000f;border-color:#cbd5e1}.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;background:none;border:none;cursor:pointer;font-size:.95rem;font-weight:700;color:#1e293b;text-align:left;line-height:1.4;transition:background .15s ease}.faq-question:hover{background:#f8fafc}.faq-chevron{flex-shrink:0;color:#94a3b8;transition:transform .2s ease}.faq-chevron.open{transform:rotate(180deg);color:#667eea}.faq-answer{padding:0 1.25rem 1.25rem;font-size:.9rem;color:#475569;line-height:1.6}.faq-answer p{margin:0 0 .75rem}.faq-answer p:last-child{margin-bottom:0}.faq-answer ul{margin:.25rem 0 0;padding-left:1.25rem}.faq-answer li{margin-bottom:.35rem}@media(max-width:768px){.app{flex-direction:column}.sidebar{width:100%;min-width:unset;max-height:30vh}.main-content{width:100%;min-height:70vh}.app-topbar{padding:.85rem 1rem}.app-topbar-title{font-size:1.1rem}.main-content-body.centered{padding:1rem}.user-menu-panel{width:min(240px,calc(100vw - 2rem))}.upload-button{padding:2rem}.project-title{font-size:1.2rem}.project-detail-content{padding:1rem}.project-info-overview{flex-direction:column}.project-info-overview-main{width:100%;align-items:flex-start}.project-info-overview-actions{width:100%;justify-content:flex-end}.info-row{flex-direction:column;gap:.25rem}}.match-review-section{margin-top:1rem}.match-review-loading{display:flex;justify-content:center;padding:1rem}.match-group{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(148,163,184,.2)}.match-group:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.match-group-title{font-size:.9rem;font-weight:600;margin:0 0 .5rem}.match-subsection{margin-bottom:.75rem}.match-subsection-header{display:flex;align-items:center;gap:.35rem;font-size:.8rem;font-weight:500;margin-bottom:.4rem}.match-subsection-header.confirmed{color:#16a34a}.match-subsection-header.pending{color:#d97706}.match-subsection-header.rejected{color:#94a3b8}.match-subsection-header.collapsible{cursor:pointer;-webkit-user-select:none;user-select:none}.match-subsection-header.collapsible:hover{opacity:.8}.collapse-toggle-hint{font-size:.75rem;font-weight:500;padding:.1rem .45rem;border-radius:4px;background:#94a3b826;color:#94a3b8}.match-subsection-header.collapsible:hover .collapse-toggle-hint{background:#94a3b840;color:#cbd5e1}.match-grid{display:flex;flex-wrap:wrap;gap:.5rem}.match-card{border:3px solid #e2e8f0;border-radius:6px;display:flex;flex-direction:column;background:#fff;position:relative;z-index:0}.match-card:hover{z-index:10}.match-image-wrapper{height:90px;border-radius:4px 4px 0 0;cursor:zoom-in;clip-path:inset(0 round 4px 4px 0 0);transition:clip-path .3s ease;position:relative}.match-image-wrapper:hover{clip-path:inset(-50% round 4px);z-index:3}.match-card .match-image{border-radius:0}.match-card.confirmed{border-color:#008000b3}.match-card.pending{border-color:#c8a000b3}.match-card.rejected{border-color:#94a3b880;opacity:.5}.match-card.rejected:hover{opacity:.8}.match-card.manual{border-color:#2563ebd9;border-width:2px}.match-manual-badge{position:absolute;top:4px;left:4px;background:#2563ebf2;color:#fff;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:2px 6px;border-radius:3px;pointer-events:none;box-shadow:0 1px 2px #0000002e}.match-image{width:100%;height:90px;object-fit:contain;background:#f8fafc;transition:transform .3s ease,filter .3s ease,box-shadow .3s ease;border-radius:4px}.match-image-wrapper:hover .match-image{transform:scale(2);box-shadow:0 4px 20px #0000004d;filter:brightness(1.03)}.match-card.confirmed .match-image-wrapper:hover .match-image{box-shadow:0 0 0 4px green,0 4px 20px #0000004d}.match-card.pending .match-image-wrapper:hover .match-image{box-shadow:0 0 0 4px #c8a000,0 4px 20px #0000004d}.match-card.rejected .match-image-wrapper:hover .match-image{box-shadow:0 0 0 4px #94a3b8,0 4px 20px #0000004d}.match-card-wrapper{width:120px}.match-id-footer{font-size:.6rem;font-weight:600;color:#94a3b8;text-align:center;padding:2px 0;font-variant-numeric:tabular-nums}.match-spatial-overlap-hint{display:flex;align-items:flex-start;gap:4px;padding:4px 0 0;color:#b45309;text-align:left}.match-spatial-overlap-hint svg{flex-shrink:0;margin-top:1px}.match-spatial-overlap-hint-text{font-size:.58rem;font-weight:500;line-height:1.25;color:#92400e;min-width:0}.match-score-badge{position:absolute;bottom:3px;left:3px;font-size:.65rem;font-weight:700;color:#fff;padding:1px 5px;border-radius:3px;line-height:1.4;pointer-events:none;text-shadow:0 1px 2px rgba(0,0,0,.5);font-variant-numeric:tabular-nums}.match-score-badge.confirmed{background:#006400cc}.match-score-badge.pending{background:#c8a000cc}.match-score-badge.rejected{background:#828282cc}.match-image-wrapper:hover .match-score-badge{display:none}.match-actions{display:flex;border-top:1px solid #e2e8f0}.match-accept-btn,.match-reject-btn{flex:1;display:flex;align-items:center;justify-content:center;padding:.3rem;border:none;cursor:pointer;transition:background .15s}.match-accept-btn{background:#22c55e1a;color:#16a34a;border-right:1px solid #e2e8f0}.match-accept-btn.full-width{border-right:none}.match-accept-btn:hover:not(:disabled){background:#22c55e40}.match-reject-btn{background:#ef44441a;color:#dc2626}.match-reject-btn.full-width{border-right:none}.match-reject-btn:hover:not(:disabled){background:#ef444440}.match-accept-btn:disabled,.match-reject-btn:disabled,.match-reassign-btn:disabled{opacity:.4;cursor:not-allowed}.match-reassign{position:relative}.match-reassign-btn{display:flex;align-items:center;justify-content:center;padding:.3rem .5rem;border:none;background:#94a3b81a;color:#94a3b8;cursor:pointer;transition:background .15s}.match-reassign-btn:hover:not(:disabled){background:#94a3b840}.reassign-dropdown{position:absolute;bottom:100%;left:0;background:#1e293b;border:1px solid rgba(148,163,184,.3);border-radius:6px;padding:.25rem;z-index:20;display:flex;flex-direction:column;gap:.15rem;min-width:80px;box-shadow:0 4px 12px #0000004d;margin-bottom:4px}.reassign-option{padding:.3rem .6rem;border:none;background:transparent;color:#cbd5e1;font-size:.75rem;font-weight:500;cursor:pointer;border-radius:4px;text-align:left;white-space:nowrap;transition:background .15s}.reassign-option:hover{background:#6366f133;color:#a5b4fc}.file-tabs{display:flex;flex-wrap:wrap;gap:.5rem;margin:.5rem 0 1rem;padding:.6rem;border:1px solid #dbe7fb;border-radius:12px;background:linear-gradient(180deg,#f8fbff,#f1f7ff)}.file-tab{display:inline-flex;align-items:center;gap:.55rem;padding:.5rem .75rem;background:#ffffffbf;border:1px solid #d7e4fb;border-radius:10px;font-size:.85rem;color:#334155;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease,background .15s ease;max-width:260px;min-height:40px}.file-tab:hover:not(.active){transform:translateY(-1px);background:#f8fbff;border-color:#9bbcf9;box-shadow:0 4px 12px #2563eb1f;color:#1e3a8a}.file-tab.active{background:linear-gradient(180deg,#2f6af0,#2359d3);border-color:#1e4ebc;color:#fff;box-shadow:0 6px 16px #2563eb4d}.file-tab:focus-visible{outline:none;box-shadow:0 0 0 3px #2563eb40}.file-tab-index{width:1.35rem;height:1.35rem;border-radius:999px;background:#0f172a14;color:#475569;font-size:.7rem;font-weight:700;line-height:1;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;font-variant-numeric:tabular-nums}.file-tab.active .file-tab-index{background:#fff3;color:#fff}.file-tab-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.file-tab-status{display:inline-flex;align-items:center;gap:.35rem;font-size:.7rem;font-weight:600;padding:.12rem .45rem;border-radius:999px;background:#0f172a0f;white-space:nowrap}.file-tab-status-dot{width:.42rem;height:.42rem;border-radius:999px;background:currentColor;opacity:.9;flex-shrink:0}.file-tab.active .file-tab-status{background:#ffffff3d;color:#eff6ff}.file-tab:not(.active) .file-tab-status.status-in_progress{background:#2563eb1f;color:#2563eb}.file-tab:not(.active) .file-tab-status.status-completed{background:#22c55e1f;color:#166534}.file-tab:not(.active) .file-tab-status.status-failed{background:#ef44441f;color:#b91c1c}.file-tab:not(.active) .file-tab-status.status-waiting_for_user{background:#f59e0b1f;color:#92400e}.file-tab:not(.active) .file-tab-status.status-queued{background:#94a3b829;color:#475569}.new-project-dialog{max-width:560px;width:92%;align-items:stretch;text-align:left;padding:1.75rem}.confirm-dialog-header{width:100%}.confirm-dialog-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#1e293b}.confirm-dialog-body{width:100%;display:flex;flex-direction:column;gap:1rem}.confirm-dialog-actions{width:100%;display:flex;justify-content:flex-end;gap:.75rem;margin-top:.5rem}.form-field{display:flex;flex-direction:column;gap:.35rem}.form-label{font-size:.85rem;font-weight:500;color:#475569}.form-input{padding:.55rem .75rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.9rem;color:#1e293b;background:#fff;transition:border-color .15s ease,box-shadow .15s ease}.form-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26}.form-input:disabled{background:#f1f5f9;color:#94a3b8;cursor:not-allowed}.form-error{font-size:.85rem;color:#dc2626;background:#ef444414;border:1px solid rgba(239,68,68,.15);border-radius:8px;padding:.55rem .75rem}.dropzone{border:2px dashed #cbd5e1;border-radius:10px;padding:1.5rem;text-align:center;background:#f8fafc;cursor:pointer;transition:border-color .15s ease,background .15s ease}.dropzone:hover:not(.disabled){border-color:#2563eb;background:#eff6ff}.dropzone.active{border-color:#2563eb;background:#eff6ff}.dropzone.disabled{cursor:not-allowed;opacity:.6}.dropzone-content{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:#475569}.dropzone-content p{margin:0;font-size:.9rem;color:#1e293b;font-weight:500}.dropzone-content .file-types{font-size:.8rem;color:#64748b}.new-project-file-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.4rem;max-height:220px;overflow-y:auto}.new-project-file-item{display:flex;align-items:center;gap:.6rem;padding:.5rem .75rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;font-size:.9rem;color:#1e293b}.new-project-file-item .file-order{color:#64748b;font-weight:500;flex-shrink:0}.new-project-file-item .file-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.new-project-file-item .file-actions{display:flex;gap:.25rem;flex-shrink:0}.file-action-btn{width:26px;height:26px;border:1px solid #e2e8f0;background:#fff;border-radius:6px;color:#475569;font-size:.8rem;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .15s ease}.file-action-btn:hover:not(:disabled){background:#e2e8f0;color:#1e293b}.file-action-btn:disabled{opacity:.4;cursor:not-allowed}.file-action-remove:hover:not(:disabled){background:#fee2e2;border-color:#fecaca;color:#dc2626}.btn{padding:.6rem 1.1rem;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s ease;border:1px solid transparent}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:#f1f5f9;border-color:#e2e8f0;color:#475569}.btn-secondary:hover:not(:disabled){background:#e2e8f0;color:#1e293b}.btn-primary{padding:.65rem 1.25rem;background:#2563eb;border:1px solid #2563eb;border-radius:8px;color:#fff;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s ease}.btn-primary:hover:not(:disabled){background:#1d4ed8;border-color:#1d4ed8}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e293b,#0f172a)}.login-form{background:#fff;border-radius:16px;padding:2.5rem;width:100%;max-width:400px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;gap:1.25rem}.login-header{text-align:center;color:#1e293b;display:flex;flex-direction:column;align-items:center;gap:.5rem}.login-header svg{color:#2563eb}.login-header h2{font-size:1.5rem;font-weight:600;margin:0}.login-subtitle{font-size:.85rem;color:#64748b;margin:0}.login-error{background:#ef444414;border:1px solid rgba(239,68,68,.2);color:#dc2626;padding:.75rem 1rem;border-radius:8px;font-size:.85rem;line-height:1.4}.login-field{display:flex;flex-direction:column;gap:.4rem}.login-field label{font-size:.85rem;font-weight:500;color:#475569}.login-field input{padding:.7rem .9rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.95rem;color:#1e293b;transition:border-color .15s ease,box-shadow .15s ease;outline:none}.login-field input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.login-submit{padding:.75rem;background:#2563eb;color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:background .15s ease;margin-top:.25rem}.login-submit:hover:not(:disabled){background:#1d4ed8}.login-submit:disabled{opacity:.6;cursor:not-allowed}.password-requirements{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:.75rem 1rem;font-size:.8rem;color:#64748b}.password-requirements p{margin:0 0 .35rem;font-weight:500}.password-requirements ul{margin:0;padding-left:1.2rem}.password-requirements li{line-height:1.5}.sidebar-user-info{display:flex;flex-direction:column;padding:.5rem .75rem .75rem;gap:.1rem}.sidebar-user-name{font-size:.85rem;font-weight:500;color:#ffffffe6}.sidebar-user-role{font-size:.75rem;color:#fff6}.user-management{padding:2rem;max-width:1200px;width:100%}.user-management-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.user-management-header h2{font-size:1.5rem;font-weight:600;color:#1e293b}.user-table-wrapper{overflow-x:auto;border:1px solid #e2e8f0;border-radius:12px;background:#fff}.user-table{width:100%;border-collapse:collapse}.user-table th{text-align:left;padding:.75rem 1rem;font-size:.8rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #e2e8f0;background:#f8fafc}.user-table td{padding:.75rem 1rem;font-size:.9rem;color:#1e293b;border-bottom:1px solid #f1f5f9}.user-table tr:last-child td{border-bottom:none}.user-table tr.user-disabled td{opacity:.5}.user-table-empty{text-align:center;color:#94a3b8;padding:2rem!important}.role-badge{display:inline-block;padding:.2rem .6rem;border-radius:6px;font-size:.8rem;font-weight:500}.role-badge.role-admin{background:#8b5cf61a;color:#7c3aed}.role-badge.role-user{background:#3b82f61a;color:#2563eb}.status-badge{display:inline-block;padding:.2rem .6rem;border-radius:6px;font-size:.8rem;font-weight:500}.status-badge.status-active{background:#22c55e1a;color:#16a34a}.status-badge.status-pending{background:#f59e0b1a;color:#d97706}.status-badge.status-disabled{background:#94a3b81a;color:#64748b}.user-actions{display:flex;gap:.35rem}.user-action-btn{background:transparent;border:1px solid #e2e8f0;border-radius:6px;padding:.35rem;cursor:pointer;color:#64748b;transition:all .15s ease;display:flex;align-items:center}.user-action-btn:hover{background:#f1f5f9;color:#1e293b}.user-action-btn.user-action-delete:hover{background:#ef444414;color:#dc2626;border-color:#ef444433}.user-pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1rem}.user-pagination button{background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:.4rem .8rem;cursor:pointer;color:#475569}.user-pagination button:disabled{opacity:.4;cursor:not-allowed}.user-pagination span{font-size:.85rem;color:#64748b}.temp-password-box{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;padding:1rem;text-align:center;width:100%}.temp-password-box code{display:block;font-size:1.2rem;font-weight:600;color:#16a34a;margin:.5rem 0;letter-spacing:.05em}.temp-password-note{font-size:.8rem;color:#64748b;margin-top:.5rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#475569;cursor:pointer}.checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:#2563eb}.permission-section{margin-top:.75rem}.permission-section>label{font-size:.85rem;font-weight:500;color:#475569;display:block;margin-bottom:.4rem}.permission-list{display:flex;flex-direction:column;gap:.5rem;padding:.5rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px}.account-settings{padding:2rem;max-width:600px}.account-settings h2{font-size:1.5rem;font-weight:600;color:#1e293b;margin-bottom:1.5rem}.account-section{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem}.account-section h3{font-size:1.1rem;font-weight:600;color:#1e293b;margin-bottom:1rem}.account-row{display:flex;gap:1rem}.account-row .login-field{flex:1}.account-success{background:#22c55e14;border:1px solid rgba(34,197,94,.2);color:#16a34a;padding:.75rem 1rem;border-radius:8px;font-size:.85rem;margin-bottom:.75rem}.confirm-dialog select{padding:.7rem .9rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.95rem;color:#1e293b;width:100%;outline:none;background:#fff}.confirm-dialog select:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.confirm-dialog .login-field{margin-bottom:.75rem}.role-description-box{margin:.25rem 0 .75rem}.role-description-list{margin:.35rem 0 0;padding-left:1.2rem;color:#475569;font-size:.88rem;line-height:1.45}.confirm-dialog.confirm-dialog-wide{max-width:540px;align-items:stretch;text-align:left}.admin-panel{min-height:100%}.admin-sidebar-section{padding-top:0}.admin-sidebar-tabs{display:flex;flex-direction:column;gap:.65rem}.admin-sidebar-tab{border:1px solid rgba(148,163,184,.18);background:#0f172a2e;color:inherit;border-radius:14px;padding:.9rem 1rem;text-align:left;cursor:pointer;transition:all .18s ease;display:flex;flex-direction:column;gap:.35rem}.admin-sidebar-tab:hover{background:#2563eb3d;border-color:#93c5fd4d}.admin-sidebar-tab.active{background:linear-gradient(180deg,#3b82f659,#2563eb47);border-color:#bfdbfe7a;box-shadow:0 12px 30px #02061740}.admin-sidebar-tab-title{font-size:.98rem;font-weight:600}.admin-sidebar-tab-description{font-size:.82rem;line-height:1.45;color:#e2e8f0b8}.admin-panel-content-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.admin-panel-content-header h2{margin:0;font-size:1.5rem;font-weight:600;color:#1e293b}.admin-panel-content-subtitle{margin:.35rem 0 0;color:#64748b;font-size:.92rem}.admin-logs,.admin-metrics{display:flex;flex-direction:column;gap:1rem;padding:2rem;min-height:100%}.admin-logs-toolbar{display:flex;flex-wrap:wrap;gap:.9rem;align-items:flex-end;padding:1rem;border:1px solid #dbe4f0;border-radius:16px;background:#fff}.admin-logs-field{display:flex;flex-direction:column;gap:.35rem;min-width:180px}.admin-logs-field span{font-size:.78rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:#64748b}.admin-logs-field input{border:1px solid #cbd5e1;border-radius:10px;padding:.72rem .85rem;font-size:.95rem;color:#0f172a;background:#fff}.admin-logs-search{flex:1;min-width:240px}.admin-logs-levels{display:flex;flex-wrap:wrap;gap:.5rem}.admin-logs-filter-btn,.admin-logs-refresh{border:1px solid #cbd5e1;border-radius:999px;background:#fff;color:#334155;padding:.7rem .95rem;font-size:.9rem;cursor:pointer;transition:all .15s ease}.admin-logs-filter-btn.active,.admin-logs-refresh:focus-visible{background:#dbeafe;border-color:#93c5fd;color:#1d4ed8}.admin-logs-refresh:disabled{opacity:.5;cursor:not-allowed}.admin-logs-download:disabled{opacity:.5;cursor:not-allowed}.admin-logs-summary{display:flex;flex-wrap:wrap;gap:1rem;color:#64748b;font-size:.88rem}.admin-metrics-summary{display:flex;flex-wrap:wrap;gap:.75rem;color:#64748b;font-size:.88rem}.admin-metrics-summary span{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem .7rem;border-radius:999px;border:1px solid #dbe4f0;background:#fff}.admin-metrics-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.admin-metrics-card{display:flex;flex-direction:column;gap:1rem;padding:1.1rem;border:1px solid #dbe4f0;border-radius:18px;background:#fff;box-shadow:0 20px 50px #0f172a0f}.admin-metrics-card-wide{grid-column:span 2}.admin-metrics-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.admin-metrics-card h3{margin:0;font-size:1rem;font-weight:600;color:#0f172a}.admin-metrics-card-description{margin:.4rem 0 0;color:#64748b;font-size:.84rem;line-height:1.45;max-width:62ch}.admin-metrics-card-value{margin-top:.35rem;color:#475569;font-size:.94rem}.admin-metrics-card-details{display:flex;flex-wrap:wrap;gap:.55rem;color:#64748b;font-size:.82rem}.admin-metrics-card-details span{display:inline-flex;align-items:center;padding:.4rem .6rem;border-radius:999px;background:#f8fafc;border:1px solid #e2e8f0}.admin-metrics-chart-block{display:flex;flex-direction:column;gap:.75rem}.admin-metrics-chart{width:100%;min-height:180px}.admin-metrics-chart-legend{display:flex;flex-wrap:wrap;gap:.65rem .9rem}.admin-metrics-chart-legend-item{display:inline-flex;align-items:center;gap:.45rem;color:#64748b;font-size:.8rem}.admin-metrics-chart-dot{width:.7rem;height:.7rem;border-radius:999px}.admin-metrics-bars{display:flex;flex-direction:column;gap:.75rem}.admin-metrics-storage-chart{display:flex;flex-direction:column;gap:.9rem}.admin-metrics-storage-row{display:flex;flex-direction:column;gap:.42rem}.admin-metrics-storage-labels{display:flex;align-items:center;justify-content:space-between;gap:1rem;color:#475569;font-size:.84rem}.admin-metrics-storage-track{position:relative;overflow:hidden;width:100%;height:1rem;border-radius:999px;background:#e2e8f0}.admin-metrics-storage-fill{height:100%;min-width:4px;border-radius:999px;box-shadow:inset 0 1px #ffffff59}.admin-metrics-status-chart{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem;align-items:end;min-height:240px;padding:.5rem 0}.admin-metrics-status-column{display:flex;flex-direction:column;align-items:center;gap:.55rem;min-width:0}.admin-metrics-status-value{font-size:.86rem;font-weight:600;color:#334155}.admin-metrics-status-bar-shell{display:flex;align-items:flex-end;width:100%;max-width:92px;height:160px;padding:.35rem;border-radius:18px;background:linear-gradient(180deg,#f8fafc,#e2e8f0);border:1px solid #dbe4f0}.admin-metrics-status-bar-fill{width:100%;min-height:4px;border-radius:14px;box-shadow:inset 0 1px #ffffff59}.admin-metrics-status-label{text-align:center;color:#64748b;font-size:.8rem;line-height:1.35;text-wrap:balance}.admin-metrics-bar-row{display:flex;flex-direction:column;gap:.42rem}.admin-metrics-bar-labels{display:flex;align-items:center;justify-content:space-between;gap:1rem;color:#475569;font-size:.84rem}.admin-metrics-bar-track{position:relative;overflow:hidden;width:100%;height:.85rem;border-radius:999px;background:#e2e8f0}.admin-metrics-bar-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#2563eb,#38bdf8)}.admin-metrics-empty{display:flex;align-items:center;justify-content:center;min-height:360px;border:1px dashed #cbd5e1;border-radius:18px;color:#94a3b8;background:#fff}.admin-logs-viewer{min-height:420px;flex:1;overflow:auto;background:#0f172a;color:#e2e8f0;border-radius:18px;border:1px solid #0b1220;padding:1rem 1.1rem;box-shadow:inset 0 1px #ffffff08}.admin-log-entry+.admin-log-entry{margin-top:.65rem;padding-top:.65rem;border-top:1px solid rgba(148,163,184,.14)}.admin-log-line{display:grid;grid-template-columns:72px minmax(0,1fr);gap:.9rem;align-items:start;padding:.18rem 0;font-family:SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.83rem;line-height:1.55;white-space:pre-wrap;word-break:break-word}.admin-log-line-level{font-weight:700;color:#94a3b8}.admin-log-line-text{min-width:0}.admin-log-line-warn .admin-log-line-level,.admin-log-line-warn .admin-log-line-text{color:#fbbf24}.admin-log-line-error .admin-log-line-level,.admin-log-line-error .admin-log-line-text{color:#fca5a5}.admin-logs-empty{display:flex;align-items:center;justify-content:center;min-height:100%;color:#94a3b8;font-size:.95rem}.admin-logs-error{margin-bottom:0}@media(max-width:980px){.admin-sidebar-tab{min-width:0}.admin-panel-content-header{flex-direction:column}.admin-logs,.admin-metrics{padding:1.25rem}.admin-logs-toolbar{padding:.85rem}.admin-metrics-grid{grid-template-columns:1fr}.admin-metrics-card-wide{grid-column:span 1}.admin-metrics-bar-labels,.admin-metrics-storage-labels{flex-direction:column;align-items:flex-start;gap:.25rem}.admin-metrics-status-chart{grid-template-columns:repeat(2,minmax(0,1fr));min-height:0}.admin-log-line{grid-template-columns:60px minmax(0,1fr)}}.confirm-dialog .btn-primary{flex:1;padding:.65rem 1rem;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer}
