*{box-sizing:border-box;margin:0;padding:0}:root{--primary: #1a56db;--primary-dark: #1e40af;--success: #10b981;--success-light: #ecfdf5;--warning: #f59e0b;--warning-light: #fef3c7;--danger: #ef4444;--danger-light: #fef2f2;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--sidebar-width: 240px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--gray-100);color:var(--gray-800);line-height:1.5}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--gray-900);color:#fff;display:flex;flex-direction:column;position:fixed;height:100vh;z-index:100}.sidebar-header{padding:1.5rem;border-bottom:1px solid var(--gray-700);text-align:center}.sidebar-header .logo-img-sidebar{width:60px;height:auto;margin-bottom:.75rem}.sidebar-header h1{font-size:1.5rem;font-weight:700;margin:0 0 .5rem}.sidebar-header .sidebar-title{font-size:.65rem;color:var(--gray-400);line-height:1.3;margin:.5rem 0}.sidebar-header .sidebar-subtitle{font-size:.7rem;color:var(--gray-500);text-transform:uppercase;letter-spacing:.1em;margin:.25rem 0 0}.sidebar-nav{flex:1;padding:1rem 0;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;color:var(--gray-400);text-decoration:none;transition:all .2s}.nav-item:hover{background:var(--gray-800);color:#fff}.nav-item.active{background:var(--primary);color:#fff}.nav-icon{font-size:1.25rem}.nav-text{font-size:.9rem}.sidebar-footer{padding:1rem 1.5rem;border-top:1px solid var(--gray-700);font-size:.75rem;color:var(--gray-500)}.main-content{flex:1;margin-left:var(--sidebar-width);padding:2rem;min-height:100vh}.page{display:none}.page.active{display:block}.page-header{margin-bottom:1.5rem}.page-header h2{font-size:1.5rem;font-weight:600;margin-bottom:.25rem}.page-desc{color:var(--gray-500);font-size:.9rem}.card{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 1px 3px #0000001a;margin-bottom:1rem}.card h3{font-size:1rem;font-weight:600;margin-bottom:1rem;color:var(--gray-700)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.stat-card{background:#fff;border-radius:8px;padding:1.25rem;display:flex;align-items:center;gap:1rem;box-shadow:0 1px 3px #0000001a}.stat-icon{font-size:2rem;width:50px;height:50px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:var(--gray-100)}.stat-card.primary .stat-icon{background:#dbeafe}.stat-card.success .stat-icon{background:var(--success-light)}.stat-card.warning .stat-icon{background:var(--warning-light)}.stat-card.muted .stat-icon{background:var(--gray-100)}.stat-value{font-size:1.75rem;font-weight:700;line-height:1}.stat-card.primary .stat-value{color:var(--primary)}.stat-card.success .stat-value{color:var(--success)}.stat-card.warning .stat-value{color:var(--warning)}.stat-label{font-size:.8rem;color:var(--gray-500);margin-top:.25rem}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.issues-list{display:flex;flex-direction:column;gap:.5rem}.issue-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--gray-100)}.issue-row:last-child{border-bottom:none}.issue-row .count{font-weight:600;color:var(--gray-700)}.quick-actions{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.btn-action{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:6px;cursor:pointer;transition:all .2s;font-size:.875rem}.btn-action:hover{background:var(--gray-100);border-color:var(--gray-300)}.action-icon{font-size:1.25rem}.filters-bar{display:flex;flex-wrap:wrap;gap:.75rem;padding:1rem;background:#fff;border-radius:8px;margin-bottom:1rem;box-shadow:0 1px 3px #0000001a}.search-box{flex:1;min-width:200px}.search-box input{width:100%;padding:.5rem 1rem;border:1px solid var(--gray-300);border-radius:6px;font-size:.9rem}.filter-group select{padding:.5rem .75rem;border:1px solid var(--gray-300);border-radius:6px;font-size:.875rem;background:#fff}.list-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.list-info{font-size:.875rem;color:var(--gray-500)}.list-actions{display:flex;gap:.5rem}.btn-primary{padding:.625rem 1.25rem;background:var(--primary);color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;font-size:.875rem;transition:background .2s}.btn-primary:disabled{background:var(--gray-300);cursor:not-allowed}.btn-secondary{padding:.625rem 1.25rem;background:var(--gray-500);color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;font-size:.875rem}.btn-secondary:hover{background:var(--gray-600)}.btn-warning{padding:.625rem 1.25rem;background:var(--warning);color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;font-size:.875rem}.btn-warning:hover{background:#d97706}.btn-danger{padding:.625rem 1.25rem;background:var(--danger);color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;font-size:.875rem}.btn-danger:hover{background:#dc2626}.btn-back{background:none;border:none;color:var(--primary);cursor:pointer;font-size:.9rem;padding:.5rem 0}.btn-large{padding:1rem 2rem;font-size:1rem;width:100%;margin-top:1rem}.results-list{display:flex;flex-direction:column;gap:.5rem}.lecturer-card{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fff;border:1px solid var(--gray-200);border-radius:8px;cursor:pointer;transition:all .2s}.lecturer-card:hover{border-color:var(--primary);box-shadow:0 2px 8px #0000001a}.lecturer-card.has-issues{border-left:4px solid var(--warning)}.lecturer-card.archived{background:var(--gray-50)}.lecturer-card.sim-found{border-left:4px solid var(--success)}.lecturer-card.nidn-mismatch{border-left:4px solid var(--warning)}.lecturer-main{flex:1}.lecturer-name{font-weight:600;margin-bottom:.25rem}.lecturer-original-name{font-size:.75rem;color:#92400e;font-style:italic;margin-bottom:.25rem}.lecturer-meta{font-size:.8rem;color:var(--gray-500);display:flex;gap:1rem}.lecturer-stats{text-align:center;min-width:60px}.sinta-score{font-size:1.25rem;font-weight:700;color:var(--primary)}.sinta-label{font-size:.7rem;color:var(--gray-400)}.lecturer-status{min-width:150px;text-align:right}.status-ok{color:var(--success);font-size:1.25rem}.issue-badges{display:flex;flex-wrap:wrap;gap:.25rem;justify-content:flex-end}.issue-badge{padding:.2rem .5rem;border-radius:4px;font-size:.7rem;font-weight:500}.issue-badge.inactive{background:var(--danger-light);color:#991b1b}.issue-badge.unverified{background:var(--warning-light);color:#92400e}.issue-badge.nidn_empty,.issue-badge.nidn_invalid{background:var(--gray-100);color:var(--gray-700)}.issue-badge.duplicate_nidn,.issue-badge.duplicate_name{background:#dbeafe;color:#1e40af}.issue-badge.has_title{background:var(--warning-light);color:#92400e}.issue-badge.source_inconsistent{background:#fef3c7;color:#b45309}.issue-badge.pddikti_not_found{background:#fee2e2;color:#991b1b}.issue-badge.sinta_not_found{background:#fce7f3;color:#9d174d}.issue-badge.simlitabmas_not_found{background:#ede9fe;color:#5b21b6}.issue-badges.large .issue-badge{font-size:.875rem;padding:.4rem .75rem}.archive-toolbar{display:flex;gap:.75rem;margin-bottom:1rem}.archive-actions-inline{display:flex;gap:.5rem}.btn-restore,.btn-crosscheck,.btn-fix-restore{padding:.4rem .6rem;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem}.btn-restore{background:var(--success)}.btn-restore:hover{background:#059669}.btn-crosscheck{background:#3b82f6}.btn-crosscheck:hover{background:#2563eb}.btn-fix-restore{background:var(--success)}.btn-fix-restore:hover{background:#059669}.btn-success{padding:.625rem 1.25rem;background:var(--success);color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:background .2s}.btn-success:hover{background:#059669}.fix-data-container{display:flex;flex-direction:column;gap:1rem}.fix-info{padding:.75rem;background:var(--gray-50);border-radius:6px}.fix-info p{margin:0;display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.verification-mini{display:flex;gap:.5rem;margin-top:.5rem}.verify-badge{padding:.2rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.verify-badge.found{background:var(--success-light);color:#059669}.valid-elsewhere{color:#059669;font-size:.8rem}.teaching-history-container{margin-top:1rem}.teaching-summary{display:flex;gap:1.5rem;padding:.75rem 1rem;background:var(--gray-50);border-radius:6px;margin-bottom:1rem}.teaching-stat{font-size:.9rem;color:var(--gray-600)}.teaching-stat strong{color:var(--primary)}.teaching-semesters{display:flex;flex-direction:column;gap:1rem}.teaching-semester{border:1px solid var(--gray-200);border-radius:8px;overflow:hidden}.semester-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--primary-light);border-bottom:1px solid var(--gray-200)}.semester-label{font-weight:600;color:var(--primary-dark)}.semester-count{font-size:.8rem;color:var(--gray-500);background:#fff;padding:.2rem .5rem;border-radius:4px}.semester-courses{padding:.5rem}.course-item{display:grid;grid-template-columns:80px 1fr 80px;gap:.5rem;padding:.5rem;border-bottom:1px solid var(--gray-100);font-size:.85rem}.course-item:last-child{border-bottom:none}.course-code{color:var(--gray-500);font-family:monospace}.course-name{color:var(--gray-700)}.course-class{color:var(--gray-400);text-align:right;font-size:.8rem}.course-more{padding:.5rem;text-align:center;color:var(--gray-400);font-size:.8rem;font-style:italic}.btn-check-teaching{background:#8b5cf6}.btn-check-teaching:hover{background:#7c3aed}.archive-section{margin-bottom:2rem}.section-header{padding:.75rem 1rem;border-radius:6px;margin-bottom:.5rem;font-size:1rem;font-weight:600}.section-header.found{background:var(--success-light);color:#059669;border-left:4px solid var(--success)}.section-header.not-found{background:var(--danger-light);color:#dc2626;border-left:4px solid var(--danger)}.section-header.pending{background:var(--gray-100);color:var(--gray-500);border-left:4px solid var(--gray-400)}.section-desc{font-size:.8rem;color:var(--gray-500);margin-bottom:.75rem;padding-left:1rem}.simlitabmas-result{margin-top:.5rem;padding:.5rem;border-radius:4px;font-size:.8rem}.simlitabmas-result.found{background:var(--success-light);border:1px solid var(--success)}.simlitabmas-result.not-found{background:var(--danger-light);border:1px solid var(--danger)}.sim-status{font-weight:500}.simlitabmas-result.found .sim-status{color:#059669}.simlitabmas-result.not-found .sim-status{color:#dc2626}.sim-detail{color:var(--gray-500);margin-left:.5rem}.nidn-warning{color:var(--warning);font-weight:500;display:block;margin-top:.25rem}.sim-link{display:inline-block;margin-top:.25rem;color:var(--primary);text-decoration:none}.sim-link:hover{text-decoration:underline}.upload-area{border:2px dashed var(--gray-300);border-radius:12px;padding:3rem 2rem;text-align:center;background:#fff;transition:all .2s;cursor:pointer}.upload-area:hover,.upload-area.dragover{border-color:var(--primary);background:#f0f7ff}.upload-icon{font-size:3rem;margin-bottom:1rem}.upload-or{color:var(--gray-400);margin:1rem 0}.btn-upload{display:inline-block;padding:.75rem 2rem;background:var(--primary);color:#fff;border-radius:6px;cursor:pointer;font-weight:500}.btn-upload:hover{background:var(--primary-dark)}.upload-hint{margin-top:1rem;font-size:.875rem;color:var(--gray-400)}.progress-section{margin:1.5rem 0;padding:1rem;background:#fff;border-radius:8px}.progress-section.hidden{display:none}.progress-bar{height:8px;background:var(--gray-200);border-radius:4px;overflow:hidden}.progress-bar.large{height:12px}.progress-fill{height:100%;background:var(--primary);width:0;transition:width .3s}.progress-text{margin-top:.5rem;font-size:.875rem;color:var(--gray-500)}.progress-stats{display:flex;justify-content:space-between;margin-top:.5rem;font-size:.875rem;color:var(--gray-600)}.upload-result{margin-top:1.5rem}.upload-result.hidden{display:none}.result-success{background:var(--success-light);border:1px solid var(--success);border-radius:8px;padding:1.5rem;text-align:center}.result-success h4{color:#059669;margin-bottom:.5rem}.result-warning{color:var(--warning);margin-top:.5rem}.data-actions{margin-top:1rem;text-align:right}.sync-sources{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.source-card{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;border:2px solid var(--gray-200);border-radius:8px;cursor:pointer;transition:all .2s}.source-card:hover{border-color:var(--gray-300)}.source-card:has(input:checked){border-color:var(--primary);background:#f0f7ff}.source-card input{margin-top:.25rem}.source-info{display:flex;flex-direction:column}.source-icon{font-size:1.5rem}.source-name{font-weight:600;margin-top:.25rem}.source-fields{font-size:.75rem;color:var(--gray-500);margin-top:.25rem}.sync-targets{display:flex;flex-direction:column;gap:.75rem}.radio-option{display:flex;align-items:center;gap:.5rem;cursor:pointer}.sync-estimate{margin-top:1rem;padding:.75rem;background:var(--gray-50);border-radius:6px;font-size:.875rem;color:var(--gray-600)}.sync-overall-progress{margin-bottom:1.5rem}.sync-source-status{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem}.source-status{display:flex;align-items:center;gap:.75rem;padding:.5rem 0}.status-icon{font-size:1.25rem}.status-name{font-weight:500;min-width:100px}.status-count{font-size:.875rem;color:var(--gray-500)}.sync-log{margin-bottom:1rem}.sync-log h4{font-size:.875rem;margin-bottom:.5rem}.log-content{max-height:200px;overflow-y:auto;background:var(--gray-900);color:var(--gray-300);padding:.75rem;border-radius:6px;font-family:monospace;font-size:.75rem;line-height:1.6}.log-entry{padding:.125rem 0}.log-entry.success{color:var(--success)}.log-entry.error{color:var(--danger)}.log-entry.info{color:#60a5fa}.integrated-profile{display:flex;flex-direction:column;gap:1.5rem}.profile-section{background:#fff;border:1px solid var(--gray-200);border-radius:8px;padding:1.25rem}.profile-section h3{font-size:1rem;font-weight:600;margin-bottom:1rem;color:var(--gray-700)}.profile-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.profile-field{display:flex;flex-direction:column;gap:.25rem}.profile-field label{font-size:.75rem;color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em}.profile-field .field-value{font-size:1rem;font-weight:500;color:var(--gray-800)}.profile-field .field-note{font-size:.75rem;color:var(--warning);font-style:italic}.profile-field .field-source{font-size:.7rem;color:var(--gray-400)}.profile-field .field-source.updated{color:var(--success);font-weight:500}.profile-field .field-value.field-warning{color:var(--warning)}.profile-field .field-note.warning{color:var(--danger);font-weight:500}.profile-field .field-value.status-active{color:var(--success);font-weight:500}.profile-field .field-value.status-inactive{color:var(--danger);font-weight:500}.profile-field .field-value.no-data{color:var(--gray-400);font-style:italic}.profile-field .field-value .profile-link{color:var(--primary);text-decoration:none}.profile-field .field-value .profile-link:hover{text-decoration:underline}.loading-text{color:var(--gray-400);font-style:italic}.profile-field .field-value.not-checked{color:var(--gray-400);font-style:italic;font-size:.9rem}.btn-check-external{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.875rem 1.5rem;font-size:1rem;margin-bottom:1rem}.btn-check-external:disabled{background:var(--gray-400);cursor:not-allowed}.verification-grid{display:flex;gap:1rem}.verification-item{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--gray-50);border-radius:6px;flex:1}.verification-item.found{background:var(--success-light)}.verification-item.not-found{background:var(--danger-light)}.verification-item.error{background:var(--warning-light)}.verification-item.skip{background:var(--gray-100)}.verify-icon{font-size:1.25rem}.verify-name{font-weight:500;min-width:80px}.verify-status{font-size:.875rem;color:var(--gray-600)}.differences-list{display:flex;flex-direction:column;gap:.75rem}.diff-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background:var(--warning-light);border-radius:6px;border-left:4px solid var(--warning)}.diff-field{font-weight:600;min-width:120px;color:var(--gray-700)}.diff-values{flex:1;display:flex;gap:1.5rem}.diff-excel,.diff-external{display:flex;gap:.5rem;font-size:.875rem}.diff-label{color:var(--gray-500)}.diff-value{font-weight:500}.btn-use-value{padding:.4rem .75rem;background:var(--primary);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.8rem;white-space:nowrap}.btn-use-value:hover{background:var(--primary-dark)}.auto-updates-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.update-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background:var(--success-light);border-radius:6px;border-left:4px solid var(--success)}.update-field{font-weight:600;min-width:120px;color:var(--gray-700)}.update-change{display:flex;align-items:center;gap:.5rem;font-size:.9rem}.update-change .old-value{color:var(--gray-500);text-decoration:line-through}.update-change .arrow{color:var(--success);font-weight:700}.update-change .new-value{color:var(--success);font-weight:600}.update-reason{font-size:.8rem;color:var(--gray-500);display:flex;align-items:center;gap:.5rem}.source-badge{padding:.2rem .5rem;background:var(--gray-200);border-radius:4px;font-size:.7rem;font-weight:500}.section-desc{font-size:.875rem;color:var(--gray-500);margin-bottom:1rem}.external-links{display:flex;gap:.75rem}.detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}.detail-header-left{display:flex;flex-direction:column;gap:.5rem;flex:1}.detail-header h2{margin:0}.detail-photo{width:120px;height:150px;border-radius:8px;overflow:hidden;background:var(--gray-100);border:2px solid var(--gray-200);flex-shrink:0;margin-left:1.5rem}.detail-photo .photo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:3rem;color:var(--gray-400)}.detail-photo .lecturer-photo-img{width:100%;height:100%;object-fit:cover}.detail-timestamps{display:flex;gap:1rem;flex-wrap:wrap}.detail-timestamps .timestamp{font-size:.8rem;color:var(--gray-500);background:var(--gray-100);padding:.25rem .5rem;border-radius:4px}.detail-timestamps .timestamp.updated{background:var(--success-light);color:var(--success)}.status-badge.ok{background:var(--success-light);color:#059669;padding:.5rem 1rem;border-radius:6px}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin-bottom:1.5rem}.detail-grid.four-cols{grid-template-columns:repeat(4,1fr)}.detail-card{background:#fff;border:1px solid var(--gray-200);border-radius:8px;padding:1rem}.detail-card h4{margin-bottom:.75rem;color:var(--gray-700);font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.detail-row{display:flex;justify-content:space-between;padding:.4rem 0;border-bottom:1px solid var(--gray-100);font-size:.875rem}.detail-row:last-child{border-bottom:none}.detail-row span:first-child{color:var(--gray-500)}.detail-row.warning{color:var(--warning);font-weight:500}.detail-row a{color:var(--primary);text-decoration:none}.detail-row a:hover{text-decoration:underline}.loading-small{display:flex;align-items:center;gap:.5rem;color:var(--gray-500);font-size:.875rem}.no-data{color:var(--gray-400);font-style:italic;font-size:.875rem}.status-active{color:#059669;font-weight:500}.data-comparison{background:var(--warning-light);border:1px solid var(--warning);border-radius:8px;padding:1rem;margin-top:1rem}.data-comparison.hidden{display:none}.data-comparison h4{color:#92400e;margin-bottom:.75rem}.diff-item{padding:.4rem 0;color:#92400e;font-size:.875rem;border-bottom:1px solid #fcd34d}.diff-item:last-child{border-bottom:none}.detail-actions{background:#fff;border:1px solid var(--gray-200);border-radius:8px;padding:1rem}.detail-actions h4{margin-bottom:.75rem}.action-buttons{display:flex;gap:1rem}.btn-link{padding:.5rem 1rem;background:var(--gray-100);color:var(--gray-700);text-decoration:none;border-radius:6px;font-size:.875rem}.btn-link:hover{background:var(--gray-200)}.hidden{display:none!important}.empty-state{text-align:center;padding:3rem;color:var(--gray-500)}.empty-state.small{padding:1rem}.loading{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:2rem;color:var(--gray-500)}.spinner{width:20px;height:20px;border:2px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.toast{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);padding:.75rem 1.5rem;border-radius:8px;color:#fff;z-index:1000;animation:slideUp .3s ease}.toast.success{background:var(--success)}.toast.error{background:var(--danger)}.toast.info{background:#3b82f6}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,20px)}to{opacity:1;transform:translate(-50%)}}.eligibility-results{margin-top:1rem}.eligibility-summary{background:var(--gray-100);padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;text-align:center}.eligibility-summary strong{color:var(--primary)}.eligibility-group{margin-bottom:1.5rem}.eligibility-group h4{font-size:.9rem;color:var(--gray-600);margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--gray-200)}.eligibility-scheme{background:#fff;border:1px solid var(--gray-200);border-radius:8px;margin-bottom:.5rem;overflow:hidden}.eligibility-scheme.eligible{border-left:4px solid var(--success)}.eligibility-scheme.not-eligible{border-left:4px solid var(--danger)}.scheme-header{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;cursor:pointer;transition:background .2s}.scheme-header:hover{background:var(--gray-50)}.scheme-badge{font-size:.75rem;font-weight:600;padding:.25rem .5rem;border-radius:4px;white-space:nowrap}.scheme-badge.eligible{background:var(--success-light);color:var(--success)}.scheme-badge.not-eligible{background:var(--danger-light);color:var(--danger)}.scheme-name{font-weight:500;flex:1}.scheme-id{font-size:.8rem;color:var(--gray-500)}.scheme-expand{color:var(--gray-400);transition:transform .2s}.eligibility-scheme.expanded .scheme-expand{transform:rotate(180deg)}.scheme-details{display:none;padding:0 1rem 1rem;border-top:1px solid var(--gray-100)}.eligibility-scheme.expanded .scheme-details{display:block}.scheme-notes{font-size:.85rem;color:var(--gray-600);font-style:italic;margin-bottom:.75rem;padding:.5rem;background:var(--gray-50);border-radius:4px}.criteria-list{display:flex;flex-direction:column;gap:.5rem}.criteria-item{display:flex;align-items:center;gap:.5rem;font-size:.85rem;padding:.5rem;border-radius:4px}.criteria-item.passed{background:var(--success-light)}.criteria-item.failed{background:var(--danger-light)}.criteria-icon{font-weight:700;width:1.25rem;text-align:center}.criteria-item.passed .criteria-icon{color:var(--success)}.criteria-item.failed .criteria-icon{color:var(--danger)}.criteria-message{flex:1}.criteria-value{font-size:.8rem;color:var(--gray-600);text-align:right}.eligibility-summary-list{display:flex;flex-direction:column;gap:.5rem}.eligibility-row{display:flex;align-items:center;gap:.75rem}.eligibility-row .scheme-label{width:80px;font-size:.85rem;font-weight:500}.eligibility-bar{flex:1;height:8px;background:var(--gray-200);border-radius:4px;overflow:hidden}.eligibility-fill{height:100%;background:var(--success);border-radius:4px;transition:width .3s ease}.eligibility-count{font-size:.8rem;color:var(--gray-600);width:60px;text-align:right}.eligibility-toolbar{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1.5rem;padding:1rem;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.eligibility-toolbar .filter-group{display:flex;align-items:center;gap:.5rem}.eligibility-toolbar label{font-size:.85rem;color:var(--gray-600);white-space:nowrap}.eligibility-toolbar select{padding:.5rem;border:1px solid var(--gray-300);border-radius:6px;font-size:.9rem;min-width:200px}.eligibility-page-stat{background:#fff;padding:1rem 1.5rem;border-radius:8px;margin-bottom:1rem;box-shadow:0 1px 3px #0000001a}.stat-scheme-name{font-size:1.25rem;font-weight:600;color:var(--gray-800)}.stat-scheme-type{font-size:.85rem;color:var(--gray-500);margin-bottom:.5rem}.stat-counts{display:flex;align-items:center;gap:.5rem}.eligible-count{color:var(--success);font-weight:600}.total-count{color:var(--gray-600)}.separator{color:var(--gray-400)}.excluded-info{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--gray-200);display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.excluded-count{color:var(--warning);font-weight:500;font-size:.9rem}.excluded-detail{color:var(--gray-500);font-size:.8rem}.eligibility-list{display:flex;flex-direction:column;gap:.5rem}.eligibility-card{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#fff;border-radius:8px;border:1px solid var(--gray-200);cursor:pointer;transition:all .2s}.eligibility-card:hover{box-shadow:0 2px 8px #0000001a}.eligibility-card.eligible{border-left:4px solid var(--success)}.eligibility-card.not-eligible{border-left:4px solid var(--danger)}.eligibility-card.partial{border-left:4px solid var(--warning)}.card-main{flex:1}.card-name{font-weight:600;color:var(--gray-800);margin-bottom:.25rem}.card-info{font-size:.85rem;color:var(--gray-500);display:flex;gap:.5rem}.card-eligibility{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}.eligibility-badge{font-size:.8rem;font-weight:600;padding:.25rem .75rem;border-radius:4px}.eligibility-badge.eligible{background:var(--success-light);color:var(--success)}.eligibility-badge.not-eligible{background:var(--danger-light);color:var(--danger)}.criteria-mini-list{display:flex;gap:.25rem}.criteria-mini{width:1.25rem;height:1.25rem;display:flex;align-items:center;justify-content:center;border-radius:4px;font-size:.7rem;font-weight:700}.criteria-mini.passed{background:var(--success-light);color:var(--success)}.criteria-mini.failed{background:var(--danger-light);color:var(--danger)}.eligible-schemes{display:flex;flex-wrap:wrap;gap:.25rem;justify-content:flex-end}.scheme-mini-badge{font-size:.7rem;padding:.15rem .4rem;background:var(--success-light);color:var(--success);border-radius:3px;font-weight:600}.no-eligible{font-size:.8rem;color:var(--gray-500)}.filter-info-banner{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#fff8e6;border:1px solid #ffd666;border-radius:8px;margin-bottom:1rem}.filter-info-banner.success{background:var(--success-light);border-color:var(--success)}.filter-icon{font-size:1.25rem}.filter-text{font-size:.9rem;color:var(--gray-700)}.filter-detail{color:var(--gray-500);font-size:.85rem}.filter-note{font-size:.8rem;color:var(--gray-500);font-style:italic;margin-top:.5rem;margin-bottom:1rem;padding-left:.5rem;border-left:2px solid var(--gray-300)}@media (max-width: 1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}.dashboard-grid{grid-template-columns:1fr}.detail-grid.four-cols{grid-template-columns:repeat(2,1fr)}.sync-sources{grid-template-columns:1fr}.profile-grid{grid-template-columns:repeat(2,1fr)}.verification-grid{flex-wrap:wrap}}.status-khusus-container{display:flex;flex-direction:column;gap:1rem}.status-khusus-current{display:flex;align-items:center;gap:.75rem}.status-khusus-current label{font-size:.875rem;color:var(--gray-600);min-width:100px}.status-khusus-select{display:flex;align-items:center;gap:.75rem}.status-khusus-select label{font-size:.875rem;color:var(--gray-600);min-width:100px}.status-khusus-select select{flex:1;padding:.5rem .75rem;border:1px solid var(--gray-300);border-radius:6px;font-size:.875rem;background:#fff;max-width:300px}.status-khusus-catatan{display:flex;align-items:center;gap:.75rem}.status-khusus-catatan label{font-size:.875rem;color:var(--gray-600);min-width:100px}.status-khusus-catatan input{flex:1;padding:.5rem .75rem;border:1px solid var(--gray-300);border-radius:6px;font-size:.875rem;max-width:400px}.status-khusus-actions{display:flex;gap:.5rem;margin-top:.5rem}.status-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.35rem .75rem;border-radius:6px;font-size:.875rem;font-weight:500}.status-badge.default{background:var(--gray-100);color:var(--gray-600)}.status-badge.success{background:var(--success-light);color:#059669}.status-badge.warning{background:var(--warning-light);color:#b45309}.status-badge.danger{background:var(--danger-light);color:#dc2626}.status-badge.info{background:#dbeafe;color:#1e40af}.issue-badge.tidak_mengajar{background:var(--danger-light);color:#991b1b}.issue-badge.cuti,.issue-badge.pindah_pt{background:var(--warning-light);color:#92400e}.issue-badge.dosen_tidak_tetap{background:#dbeafe;color:#1e40af}.issue-badge.bukan_dosen{background:var(--danger-light);color:#991b1b}.issue-badge.data_tidak_lengkap{background:var(--warning-light);color:#92400e}.lecturer-status-khusus{margin-top:.25rem}.lecturer-status-khusus .status-badge{font-size:.7rem;padding:.2rem .5rem}.category-badge{font-size:.75rem;margin-left:.5rem}.pagination{display:flex;flex-direction:column;align-items:center;gap:.75rem;margin-top:1.5rem;padding:1rem;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.pagination-info{font-size:.875rem;color:var(--gray-500)}.pagination-buttons{display:flex;align-items:center;gap:.25rem;flex-wrap:wrap;justify-content:center}.btn-page{padding:.5rem .75rem;border:1px solid var(--gray-300);background:#fff;border-radius:6px;cursor:pointer;font-size:.875rem;transition:all .2s}.btn-page:hover{background:var(--gray-100);border-color:var(--gray-400)}.btn-page.active{background:var(--primary);color:#fff;border-color:var(--primary)}.page-ellipsis{padding:.5rem .25rem;color:var(--gray-400)}.list-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.75rem}.list-actions{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.list-actions .filter-group{display:flex;align-items:center;gap:.5rem}.list-actions .filter-group label{font-size:.875rem;color:var(--gray-600)}.list-actions .filter-group select{padding:.4rem .6rem;border:1px solid var(--gray-300);border-radius:6px;font-size:.875rem;background:#fff}@media (max-width: 768px){.sidebar{width:60px}.sidebar-header h1,.sidebar-header .subtitle,.nav-text,.sidebar-footer{display:none}.nav-item{justify-content:center;padding:1rem}.nav-icon{font-size:1.5rem}.main-content{margin-left:60px;padding:1rem}.stats-grid{grid-template-columns:1fr 1fr}.quick-actions{grid-template-columns:1fr}.filters-bar{flex-direction:column}.search-box{min-width:100%}.detail-grid.four-cols,.profile-grid{grid-template-columns:1fr}.verification-grid{flex-direction:column}.detail-header{flex-direction:column-reverse;gap:1rem}.detail-photo{margin-left:0;align-self:center}.lecturer-card{flex-direction:column;align-items:flex-start}.lecturer-status{width:100%;text-align:left;margin-top:.5rem}.diff-item{flex-direction:column;align-items:flex-start}.diff-values{flex-direction:column;gap:.5rem}.update-item{flex-direction:column;align-items:flex-start;gap:.5rem}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;max-width:800px;width:90%;max-height:80vh;overflow:hidden;box-shadow:0 20px 60px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--gray-200)}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--gray-500);padding:0;line-height:1}.modal-close:hover{color:var(--gray-700)}.modal-body{padding:1.5rem;overflow-y:auto;max-height:calc(80vh - 60px)}.history-table{width:100%;border-collapse:collapse;font-size:.9rem}.history-table th,.history-table td{padding:.75rem;text-align:left;border-bottom:1px solid var(--gray-200)}.history-table th{background:var(--gray-50);font-weight:600;color:var(--gray-700)}.history-table tr:hover{background:var(--gray-50)}.btn-download{color:var(--primary);text-decoration:none;padding:.25rem .5rem;border-radius:4px;background:var(--gray-100)}.btn-download:hover{background:var(--gray-200)}.btn-history{background:none;border:1px solid var(--gray-300);border-radius:4px;padding:.25rem .5rem;cursor:pointer;font-size:1rem;margin-left:auto}.btn-history:hover{background:var(--gray-100)}.kpi-card{margin-bottom:1.5rem}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:1rem}.kpi-item{text-align:center;padding:1rem;border-right:1px solid var(--gray-200)}.kpi-item:last-child{border-right:none}.kpi-value{font-size:2.5rem;font-weight:700;color:var(--primary);line-height:1.2}.kpi-label{font-size:.85rem;color:var(--gray-500);margin-top:.5rem}.kpi-note{font-size:.8rem;color:var(--gray-500);line-height:1.5;padding:.75rem;background:var(--gray-50);border-radius:6px;margin:0}@media (max-width: 900px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.kpi-item:nth-child(2){border-right:none}.kpi-item:nth-child(3),.kpi-item:nth-child(4){border-top:1px solid var(--gray-200);padding-top:1.5rem}}@media (max-width: 500px){.kpi-grid{grid-template-columns:1fr 1fr}.kpi-value{font-size:1.75rem}}.charts-row{display:grid;grid-template-columns:1fr 1.5fr;gap:1rem;margin-bottom:1.5rem}.chart-card{min-height:300px}.chart-container{position:relative;width:100%}.pie-chart-container{height:280px;display:flex;align-items:center;justify-content:center}.histogram-container{height:280px}@media (max-width: 900px){.charts-row{grid-template-columns:1fr}}.dashboard-bottom-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media (max-width: 900px){.dashboard-bottom-grid{grid-template-columns:1fr}}.bar-chart-container{height:280px}.horizontal-bar-container{height:350px}.eligibility-chart-container{height:320px}.table-responsive{overflow-x:auto;margin:-.5rem;padding:.5rem}.scheme-table{width:100%;border-collapse:collapse;font-size:.85rem;min-width:900px}.scheme-table th,.scheme-table td{padding:.75rem .5rem;text-align:left;border-bottom:1px solid var(--gray-200)}.scheme-table th{background:var(--gray-50);font-weight:600;color:var(--gray-700);white-space:nowrap}.scheme-table td{color:var(--gray-600)}.scheme-table tbody tr:hover{background:var(--gray-50)}.scheme-table code{background:var(--gray-100);padding:.2rem .4rem;border-radius:4px;font-size:.8rem;color:var(--gray-700)}.scheme-table .badge{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.scheme-table .badge.penelitian{background:#dbeafe;color:#1e40af}.scheme-table .badge.pengabdian{background:#ffedd5;color:#c2410c}.scheme-table em{font-style:italic;color:var(--gray-500)}.scheme-table-compact{font-size:.85rem}.scheme-table-compact th,.scheme-table-compact td{padding:.5rem .4rem;white-space:nowrap}.scheme-table-compact th:nth-child(2),.scheme-table-compact td:nth-child(2){white-space:normal;max-width:200px}.scheme-table-compact code{font-size:.75rem;padding:.15rem .3rem}.scheme-table-compact .badge{font-size:.7rem;padding:.15rem .4rem}.card-header-with-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.card-header-with-actions h3{margin:0}.export-buttons{display:flex;gap:.5rem}.btn-export{display:inline-flex;align-items:center;gap:.3rem;padding:.4rem .8rem;font-size:.8rem;background:var(--gray-100);border:1px solid var(--gray-300);border-radius:4px;cursor:pointer;transition:all .2s}.btn-export:hover{background:var(--gray-200);border-color:var(--gray-400)}.btn-export:active{transform:scale(.98)}.card-desc{font-size:.85rem;color:var(--gray-500);margin-bottom:1rem}.badge-count{display:inline-block;background:var(--danger);color:#fff;font-size:.8rem;padding:.2rem .6rem;border-radius:12px;margin-left:.5rem;font-weight:600}.pembinaan-list{max-height:400px;overflow-y:auto}.pembinaan-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem;border-bottom:1px solid var(--gray-100);cursor:pointer;transition:background .2s}.pembinaan-item:hover{background:var(--gray-50)}.pembinaan-item:last-child{border-bottom:none}.pembinaan-item.special-case{background:#fef3c7;border-left:3px solid #f59e0b}.pembinaan-item.special-case:hover{background:#fde68a}.pembinaan-info{flex:1}.pembinaan-name{font-weight:500;color:var(--gray-800);display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.special-badge{font-size:.7rem;background:#f59e0b;color:#fff;padding:.15rem .4rem;border-radius:3px;font-weight:500}.pembinaan-meta{font-size:.8rem;color:var(--gray-500);margin-top:.25rem}.pembinaan-reason{font-size:.75rem;color:var(--warning);display:flex;flex-wrap:wrap;gap:.25rem;margin-top:.25rem}.pembinaan-reason .reason-tag{background:var(--warning-light);padding:.15rem .4rem;border-radius:3px}.pembinaan-reason .reason-tag.warning{background:#fef3c7;color:#92400e}.pembinaan-stats{text-align:right;min-width:80px}.pembinaan-sinta{font-size:1.1rem;font-weight:600;color:var(--gray-400)}.pembinaan-sinta.has-score{color:var(--primary)}.settings-info{display:flex;flex-direction:column;gap:.75rem}.info-row{display:flex;align-items:flex-start;gap:1rem}.info-label{font-weight:600;color:var(--gray-600);min-width:100px}.info-value{color:var(--gray-800)}.info-note{font-size:.85rem;color:var(--gray-500);font-style:italic}.rules-meta{display:flex;gap:2rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--gray-200)}.meta-item{font-size:.9rem;color:var(--gray-600)}.rules-list{display:flex;flex-direction:column;gap:1rem}.rule-card{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:8px;padding:1rem}.rule-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.rule-code{background:var(--primary);color:#fff;padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-weight:600}.rule-name{font-weight:600;color:var(--gray-800)}.rule-type{margin-left:auto;font-size:.75rem;padding:.2rem .5rem;border-radius:4px}.rule-type.penelitian{background:#dbeafe;color:#1e40af}.rule-type.pengabdian{background:#ffedd5;color:#c2410c}.rule-notes{font-size:.85rem;color:var(--gray-600);margin-bottom:.75rem;font-style:italic}.rule-criteria{display:flex;flex-direction:column;gap:.5rem}.criteria-item{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--gray-700)}.criteria-icon{color:var(--success)}.cluster-rule-card{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:8px;padding:1rem;margin-bottom:1rem}.cluster-rule-card:last-child{margin-bottom:0}.cluster-rule-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.cluster-rule-header code{background:var(--gray-200);padding:.2rem .4rem;border-radius:4px;font-size:.8rem}.cluster-rule-content{font-size:.9rem;color:var(--gray-600)}.cluster-rule-content ul{margin:.5rem 0 0 1.5rem;padding:0}.cluster-rule-content li{margin-bottom:.25rem}.cluster-badge{display:inline-block;padding:.25rem .75rem;border-radius:4px;font-weight:600;font-size:.85rem;text-transform:capitalize}.cluster-mandiri{background:#fef3c7;color:#92400e}.cluster-utama{background:#dbeafe;color:#1e40af}.cluster-madya{background:#d1fae5;color:#065f46}.cluster-pratama{background:#e0e7ff;color:#3730a3}.cluster-binaan{background:#fce7f3;color:#9d174d}.rules-source{margin-bottom:1rem}.source-box{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #bae6fd;border-radius:8px;padding:1rem}.source-label{font-size:.8rem;color:var(--gray-500);margin-bottom:.25rem}.source-title{font-weight:600;color:var(--gray-800);margin-bottom:.25rem}.source-publisher{font-size:.9rem;color:var(--gray-600)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--gray-900) 0%,var(--gray-800) 100%)}.login-container{background:#fff;padding:3rem;border-radius:16px;box-shadow:0 25px 50px -12px #00000040;text-align:center;max-width:400px;width:90%}.login-logo{margin-bottom:1.5rem}.login-logo .logo-img{width:80px;height:auto;margin-bottom:1rem}.login-logo h1{font-size:2rem;font-weight:700;color:var(--primary);margin:0 0 .5rem}.login-logo .login-title{font-size:.9rem;color:var(--gray-700);line-height:1.4;margin:.5rem 0;font-weight:500}.login-logo .login-subtitle{font-size:.85rem;color:var(--gray-500);margin:.25rem 0 0}.login-container h2{font-size:1.5rem;color:var(--gray-800);margin-bottom:.5rem}.login-desc{color:var(--gray-500);margin-bottom:2rem}.btn-google-login{display:inline-flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:.875rem 1.5rem;font-size:1rem;font-weight:500;color:var(--gray-700);background:#fff;border:2px solid var(--gray-200);border-radius:8px;cursor:pointer;transition:all .2s}.btn-google-login:hover{background:var(--gray-50);border-color:var(--gray-300);box-shadow:0 4px 6px -1px #0000001a}.btn-google-login:active{transform:scale(.98)}.btn-google-login svg{flex-shrink:0}.login-note{margin-top:1.5rem;font-size:.85rem;color:var(--gray-500)}.login-error{margin-top:1rem;padding:.75rem 1rem;background:var(--danger-light);color:var(--danger);border-radius:8px;font-size:.9rem}.login-footer{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--gray-200);font-size:.75rem;color:var(--gray-500);text-align:center}.login-footer p{margin:.25rem 0}.login-footer .footer-dev{font-size:.7rem}.login-footer a{color:var(--primary);text-decoration:none}.login-footer a:hover{text-decoration:underline}.user-info{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--gray-800);border-radius:8px;margin:0 1rem .75rem}.user-avatar{width:36px;height:36px;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.25rem}.user-details{flex:1;min-width:0}.user-name{font-weight:500;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.75rem;color:var(--gray-400);text-transform:capitalize}.btn-logout{display:block;width:calc(100% - 2rem);margin:0 1rem 1rem;padding:.5rem;font-size:.85rem;color:var(--gray-400);background:transparent;border:1px solid var(--gray-700);border-radius:6px;cursor:pointer;transition:all .2s}.btn-logout:hover{background:var(--gray-800);color:#fff;border-color:var(--gray-600)}.users-table{width:100%;border-collapse:collapse}.users-table th,.users-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--gray-200)}.users-table th{background:var(--gray-50);font-weight:600;color:var(--gray-600);font-size:.85rem}.users-table tbody tr:hover{background:var(--gray-50)}.user-status{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-weight:500}.user-status.active{background:var(--success-light);color:var(--success)}.user-status.inactive{background:var(--gray-100);color:var(--gray-500)}.user-role-badge{display:inline-block;padding:.2rem .5rem;border-radius:4px;font-size:.8rem;font-weight:500;text-transform:capitalize}.user-role-badge.admin{background:#fef3c7;color:#92400e}.user-role-badge.direktur{background:#dbeafe;color:#1e40af}.user-actions{display:flex;gap:.5rem}.btn-icon{padding:.4rem;background:transparent;border:1px solid var(--gray-200);border-radius:4px;cursor:pointer;transition:all .2s}.btn-icon:hover{background:var(--gray-100)}.btn-icon.danger:hover{background:var(--danger-light);border-color:var(--danger);color:var(--danger)}.modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:450px;box-shadow:0 25px 50px -12px #00000040}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--gray-200)}.modal-header h3{margin:0;font-size:1.1rem}.modal-close{background:none;border:none;font-size:1.5rem;color:var(--gray-400);cursor:pointer;padding:0;line-height:1}.modal-close:hover{color:var(--gray-600)}#user-form{padding:1.5rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-weight:500;color:var(--gray-700);margin-bottom:.5rem;font-size:.9rem}.form-group input[type=text]{width:100%;padding:.625rem .875rem;font-size:.95rem;border:1px solid var(--gray-300);border-radius:6px;transition:border-color .2s,box-shadow .2s}.form-group input[type=text]:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #1a56db1a}.input-with-suffix{display:flex;align-items:stretch}.input-with-suffix input{flex:1;border-top-right-radius:0;border-bottom-right-radius:0}.input-suffix{display:flex;align-items:center;padding:0 .75rem;background:var(--gray-100);border:1px solid var(--gray-300);border-left:none;border-radius:0 6px 6px 0;font-size:.85rem;color:var(--gray-500)}.radio-group{display:flex;gap:1.5rem}.radio-label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.radio-label input[type=radio]{width:18px;height:18px;accent-color:var(--primary)}.form-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--gray-200)}.btn-primary{padding:.625rem 1.25rem;font-size:.9rem;font-weight:500;color:#fff;background:var(--primary);border:none;border-radius:6px;cursor:pointer;transition:background .2s}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{padding:.625rem 1.25rem;font-size:.9rem;font-weight:500;color:var(--gray-700);background:#fff;border:1px solid var(--gray-300);border-radius:6px;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:var(--gray-50);border-color:var(--gray-400)}.btn-logout{width:100%;padding:.75rem;margin-top:1rem;background:var(--danger-light);color:var(--danger);border:1px solid var(--danger);border-radius:6px;cursor:pointer;transition:all .2s;font-weight:600;text-align:center}.btn-logout:hover{background:var(--danger);color:#fff}.app-footer{margin-top:4rem;padding:2rem 1.5rem;background:var(--gray-50);border-top:1px solid var(--gray-200);text-align:center;font-size:.8rem;color:var(--gray-600)}.app-footer p{margin:.25rem 0}.app-footer .footer-dev{font-size:.75rem;color:var(--gray-500)}.app-footer a{color:var(--primary);text-decoration:none;font-weight:500}.app-footer a:hover{text-decoration:underline}
