:root{--font-primary: "Sarabun", "Outfit", system-ui, -apple-system, sans-serif;--sidebar-width: 280px;--header-height: 80px;--border-radius-lg: 16px;--border-radius-md: 12px;--border-radius-sm: 8px;--transition-fast: .2s ease;--transition-normal: .3s ease;--color-success: #10b981;--color-success-soft: rgba(16, 185, 129, .15);--color-warning: #f59e0b;--color-warning-soft: rgba(245, 158, 11, .15);--color-danger: #ef4444;--color-danger-soft: rgba(239, 68, 68, .15);--color-info: #3b82f6;--color-info-soft: rgba(59, 130, 246, .15)}body.dark-theme{--bg-app: #0b0f19;--bg-sidebar: #111827;--bg-card: #1f2937;--bg-card-hover: #2d3748;--bg-body: #0f172a;--bg-input: #1e293b;--bg-input-focus: #334155;--bg-dark-soft: #111827;--border-color: #374151;--border-color-soft: rgba(255, 255, 255, .05);--text-main: #f3f4f6;--text-muted: #9ca3af;--text-white: #ffffff;--primary-color: #6366f1;--primary-color-hover: #4f46e5;--primary-gradient: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);--primary-glow: 0 0 15px rgba(99, 102, 241, .4);--table-stripe: #263043;--table-hover: #2e3a50;--modal-backdrop: rgba(0, 0, 0, .75)}body.light-theme{--bg-app: #f1f5f9;--bg-sidebar: #ffffff;--bg-card: #ffffff;--bg-card-hover: #f8fafc;--bg-body: #f8fafc;--bg-input: #f1f5f9;--bg-input-focus: #e2e8f0;--bg-dark-soft: #f8fafc;--border-color: #e2e8f0;--border-color-soft: rgba(0, 0, 0, .03);--text-main: #1e293b;--text-muted: #64748b;--text-white: #ffffff;--primary-color: #4f46e5;--primary-color-hover: #4338ca;--primary-gradient: linear-gradient(135deg, #4f46e5 0%, #6366f1 100%);--primary-glow: 0 4px 12px rgba(79, 70, 229, .2);--table-stripe: #f8fafc;--table-hover: #f1f5f9;--modal-backdrop: rgba(15, 23, 42, .4)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-primary);background-color:var(--bg-body);color:var(--text-main);min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden;transition:background-color var(--transition-normal),color var(--transition-normal)}button,input,select,textarea{font-family:inherit;color:inherit}a{text-decoration:none;color:var(--primary-color);transition:color var(--transition-fast)}a:hover{color:var(--primary-color-hover)}.app-container{display:flex;min-height:100vh;position:relative}.sidebar{width:var(--sidebar-width);background-color:var(--bg-sidebar);border-right:1px solid var(--border-color);display:flex;flex-direction:column;padding:24px;position:fixed;top:0;bottom:0;left:0;z-index:100;transition:background-color var(--transition-normal),border-right var(--transition-normal)}.sidebar-header{display:flex;align-items:center;gap:12px;margin-bottom:40px}.logo-icon{width:42px;height:42px;background:var(--primary-gradient);color:var(--text-white);border-radius:var(--border-radius-md);display:flex;align-items:center;justify-content:center;box-shadow:var(--primary-glow)}.logo-icon svg{width:24px;height:24px}.logo-text h2{font-size:1.15rem;font-weight:700;letter-spacing:.5px}.logo-text p{font-size:.75rem;color:var(--text-muted)}.nav-menu{display:flex;flex-direction:column;gap:8px;flex-grow:1}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:transparent;border:none;border-radius:var(--border-radius-md);color:var(--text-muted);font-weight:500;text-align:left;cursor:pointer;transition:all var(--transition-fast)}.nav-item svg{width:20px;height:20px;stroke-width:2;transition:stroke var(--transition-fast)}.nav-item:hover{background-color:var(--border-color-soft);color:var(--text-main)}.nav-item.active{background:var(--primary-gradient);color:var(--text-white);box-shadow:var(--primary-glow)}.nav-item.active svg{stroke:var(--text-white)}.sidebar-footer{border-top:1px solid var(--border-color);padding-top:20px;display:flex;flex-direction:column;gap:16px}.theme-toggle-container{display:flex;align-items:center;justify-content:space-between}.theme-label{font-size:.85rem;font-weight:500;color:var(--text-muted)}.switch{position:relative;display:inline-block;width:46px;height:22px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#cbd5e1;transition:.4s}.slider:before{position:absolute;content:"";height:16px;width:16px;left:3px;bottom:3px;background-color:#fff;transition:.4s}input:checked+.slider{background:var(--primary-gradient)}input:checked+.slider:before{transform:translate(24px)}.slider.round{border-radius:34px}.slider.round:before{border-radius:50%}.backup-restore button{width:100%}.main-content{margin-left:var(--sidebar-width);flex-grow:1;min-height:100vh;display:flex;flex-direction:column;padding:40px}.main-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;border-bottom:1px solid var(--border-color);padding-bottom:20px}.header-title-wrapper h1{font-size:1.75rem;font-weight:700;margin-bottom:4px}.header-actions{display:flex;align-items:center;gap:16px}.current-role-badge{display:flex;align-items:center;gap:8px;background-color:var(--bg-card);border:1px solid var(--border-color);padding:8px 16px;border-radius:50px;font-size:.85rem;font-weight:600}.badge-dot{width:8px;height:8px;background-color:var(--color-success);border-radius:50%;display:inline-block}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.5}}.animate-pulse{animation:pulse 2s infinite ease-in-out}.view-section{display:none;animation:fadeIn .4s ease forwards}.view-section.active{display:block}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008;margin-bottom:24px;overflow:hidden;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-normal)}.card-header{padding:20px 24px;border-bottom:1px solid var(--border-color);display:flex;align-items:center}.card-header.justify-between{justify-content:space-between}.card-title{font-size:1.15rem;font-weight:700}.card-subtitle{font-size:.85rem;margin-top:4px}.card-content{padding:24px}.card-footer{padding:18px 24px;background-color:var(--border-color-soft);border-top:1px solid var(--border-color)}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-bottom:24px}.summary-card{margin-bottom:0}.summary-card .card-body{padding:24px;display:flex;align-items:center;gap:20px}.card-icon{width:56px;height:56px;border-radius:var(--border-radius-md);display:flex;align-items:center;justify-content:center}.card-icon svg{width:28px;height:28px}.bg-primary-soft{background-color:var(--color-info-soft);color:var(--color-info)}.bg-success-soft{background-color:var(--color-success-soft);color:var(--color-success)}.bg-warning-soft{background-color:var(--color-warning-soft);color:var(--color-warning)}.card-label{font-size:.85rem;color:var(--text-muted);font-weight:500;display:block;margin-bottom:4px}.card-value{font-size:1.75rem;font-weight:700}.table-responsive{width:100%;overflow-x:auto}.max-h-300{max-height:300px;overflow-y:auto}.table{width:100%;border-collapse:collapse;text-align:left}.table th,.table td{padding:14px 18px;font-size:.95rem;border-bottom:1px solid var(--border-color);vertical-align:middle}.table th{background-color:var(--bg-dark-soft);color:var(--text-muted);font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.table-bordered th,.table-bordered td{border:1px solid var(--border-color)}.table-striped tbody tr:nth-of-type(odd){background-color:var(--border-color-soft)}.table tbody tr:hover{background-color:var(--table-hover)}.total-row-highlight{background-color:var(--bg-dark-soft)!important;font-weight:700}.total-row-highlight td{border-top:2px solid var(--primary-color)!important;font-size:1.05rem}.text-center{text-align:center}.text-right{text-align:right}.text-bold{font-weight:700}.text-semibold{font-weight:600}.text-muted{color:var(--text-muted)}.text-danger{color:var(--color-danger)}.text-success{color:var(--color-success)}.text-primary-color{color:var(--primary-color)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:600;font-size:.9rem;padding:10px 20px;border-radius:var(--border-radius-md);border:1px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.btn-sm{padding:6px 12px;font-size:.8rem;border-radius:var(--border-radius-sm)}.btn-primary{background:var(--primary-gradient);color:var(--text-white);box-shadow:var(--primary-glow)}.btn-primary:hover{background:var(--primary-gradient);opacity:.9;transform:translateY(-1px)}.btn-secondary{background-color:var(--bg-input);border-color:var(--border-color);color:var(--text-main)}.btn-secondary:hover{background-color:var(--bg-input-focus)}.btn-outline-primary{background-color:transparent;border-color:var(--primary-color);color:var(--text-main);justify-content:flex-start;width:100%}.btn-outline-primary:hover{background-color:var(--border-color-soft);border-color:var(--primary-color)}.btn-outline-primary.active{background:var(--primary-gradient);border-color:transparent;color:var(--text-white);box-shadow:var(--primary-glow)}.btn-danger-link{background:transparent;border:none;color:var(--color-danger);cursor:pointer;padding:4px 8px;font-size:.85rem;font-weight:500;border-radius:var(--border-radius-sm);transition:background var(--transition-fast)}.btn-danger-link:hover{background-color:var(--color-danger-soft)}.btn-edit-link{background:transparent;border:none;color:var(--color-info);cursor:pointer;padding:4px 8px;font-size:.85rem;font-weight:500;border-radius:var(--border-radius-sm);transition:background var(--transition-fast)}.btn-edit-link:hover{background-color:var(--color-info-soft)}.btn-full-height{height:42px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:.85rem;font-weight:600;color:var(--text-main)}.form-control{background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--border-radius-md);padding:10px 14px;font-size:.95rem;outline:none;width:100%;transition:border-color var(--transition-fast),background-color var(--transition-fast)}.form-control:focus{border-color:var(--primary-color);background-color:var(--bg-input-focus)}.form-control-sm{padding:8px 12px;font-size:.85rem;border-radius:var(--border-radius-sm)}.form-select{background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--border-radius-md);padding:8px 14px;font-size:.9rem;outline:none;cursor:pointer}.form-select:focus{border-color:var(--primary-color)}.form-radio-group{display:flex;flex-direction:column}.radio-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.9rem}.grid-3-fields{display:flex;align-items:flex-end;gap:16px}.flex-2{flex:2}.flex-1{flex:1}.flex-align-end{display:flex;align-items:flex-end;gap:8px}.grid-2-1{display:grid;grid-template-columns:2fr 1fr;align-items:start}.grid-1-3{display:grid;grid-template-columns:1fr 3fr;align-items:start}.gap-sm{gap:8px}.gap-md{gap:16px}.gap-lg{gap:24px}.col-span-2{grid-column:span 2}.employee-selector-bar{padding:16px 24px;margin-bottom:24px}.flex-between{display:flex;justify-content:space-between;align-items:center}.flex-align-center{display:flex;align-items:center}.flex-wrap{flex-wrap:wrap}.badge{display:inline-block;padding:6px 12px;font-size:.75rem;font-weight:700;border-radius:50px;text-transform:uppercase}.badge-success{background-color:var(--color-success-soft);color:var(--color-success)}.badge-warning{background-color:var(--color-warning-soft);color:var(--color-warning)}.badge-danger{background-color:var(--color-danger-soft);color:var(--color-danger)}.committee-select-btn{display:flex;align-items:center;gap:16px;padding:16px;border-radius:var(--border-radius-lg)}.btn-avatar{width:40px;height:40px;border-radius:50%;background-color:var(--bg-input-focus);color:var(--text-main);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem}.active .btn-avatar{background-color:#ffffff40;color:var(--text-white)}.btn-text{display:flex;flex-direction:column;text-align:left}.role-title{font-weight:700;font-size:.95rem}.role-desc{font-size:.75rem;opacity:.8}.raw-scores-list{display:flex;flex-direction:column;gap:16px}.committee-score-card{background-color:var(--bg-dark-soft);border:1px solid var(--border-color);border-radius:var(--border-radius-md);padding:14px}.csc-header{display:flex;justify-content:space-between;align-items:center;font-weight:700;font-size:.9rem;border-bottom:1px solid var(--border-color);padding-bottom:8px;margin-bottom:10px}.csc-tasks{display:flex;flex-direction:column;gap:8px}.csc-task-row{display:flex;justify-content:space-between;font-size:.8rem}.score-input-wrapper{display:flex;align-items:center;gap:12px}.score-slider{flex-grow:1;accent-color:var(--primary-color)}.score-number-input{width:65px;text-align:center;background-color:#f59e0b1a!important;border:1px solid var(--color-warning)!important;color:var(--color-warning)!important;font-weight:700;font-size:1.05rem}.empty-state{text-align:center;padding:40px 20px;color:var(--text-muted)}.empty-state svg{margin-bottom:16px;opacity:.4}.modal-backdrop{position:fixed;top:0;bottom:0;left:0;right:0;background-color:var(--modal-backdrop);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;z-index:200;animation:fadeInModal .25s ease forwards}.modal-backdrop.open{display:flex}.modal{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:0 20px 25px -5px #0000004d,0 10px 10px -5px #0003;width:90%;max-width:500px;display:flex;flex-direction:column;overflow:hidden;animation:slideUpModal .3s cubic-bezier(.16,1,.3,1) forwards}.modal-lg{max-width:800px}@keyframes fadeInModal{0%{opacity:0}to{opacity:1}}@keyframes slideUpModal{0%{transform:translateY(30px)}to{transform:translateY(0)}}.modal-header{padding:20px 24px;border-bottom:1px solid var(--border-color);display:flex;align-items:flex-start;justify-content:space-between}.modal-close{background:transparent;border:none;font-size:1.75rem;color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast);line-height:.8}.modal-close:hover{color:var(--text-main)}.modal-body{padding:24px;overflow-y:auto}.modal-footer{padding:16px 24px;background-color:var(--border-color-soft);border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:12px}.alert{padding:12px 16px;border-radius:var(--border-radius-md);font-size:.85rem;line-height:1.5;border:1px solid transparent}.alert-warning{background-color:var(--color-warning-soft);border-color:#f59e0b4d;color:var(--color-warning)}.alert-success{background-color:var(--color-success-soft);border-color:#10b9814d;color:var(--color-success)}.alert-danger{background-color:var(--color-danger-soft);border-color:#ef44444d;color:var(--color-danger)}.toast-container{position:fixed;bottom:24px;right:24px;z-index:1000;display:flex;flex-direction:column;gap:8px}.toast{background-color:var(--bg-card);border:1px solid var(--border-color);box-shadow:0 10px 15px -3px #0003;border-left:4px solid var(--primary-color);border-radius:var(--border-radius-sm);padding:12px 20px;min-width:280px;display:flex;align-items:center;justify-content:space-between;animation:slideInToast .3s ease forwards}.toast-success{border-left-color:var(--color-success)}.toast-error{border-left-color:var(--color-danger)}.toast-text{font-size:.85rem;font-weight:500}.toast-close{background:transparent;border:none;cursor:pointer;opacity:.5}.toast-close:hover{opacity:1}@keyframes slideInToast{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media (max-width: 1024px){.app-container{flex-direction:column}.sidebar{width:100%;position:relative;height:auto;border-right:none;border-bottom:1px solid var(--border-color);padding:16px}.sidebar-header{margin-bottom:16px}.nav-menu{flex-direction:row;flex-wrap:wrap;margin-bottom:16px}.sidebar-footer{display:none}.main-content{margin-left:0;padding:24px}.grid-2-1,.grid-1-3{grid-template-columns:1fr}.col-span-2{grid-column:span 1}.grid-3-fields{flex-direction:column;align-items:stretch}.btn-full-height{height:auto;padding:12px}}.border-left-warning{border-left:4px solid var(--color-warning)!important}.border-left-success{border-left:4px solid var(--color-success)!important}.border-left-danger{border-left:4px solid var(--color-danger)!important}.text-gap-positive{color:var(--color-success)!important;font-weight:700}.text-gap-negative{color:var(--color-danger)!important;font-weight:700}.text-gap-neutral{color:var(--text-muted)!important;font-weight:600}.badge-grade-outstanding{background-color:#8b5cf633!important;color:#c084fc!important;border:1px solid rgba(139,92,246,.4)}.badge-grade-verygood{background-color:#10b9811a!important;color:#10b981!important;border:1px solid rgba(16,185,129,.2)}.badge-grade-good{background-color:#3b82f626!important;color:#60a5fa!important;border:1px solid rgba(59,130,246,.3)}.badge-grade-fair{background-color:#f59e0b26!important;color:#fbbf24!important;border:1px solid rgba(245,158,11,.3)}.badge-grade-poor{background-color:#ef444426!important;color:#f87171!important;border:1px solid rgba(239,68,68,.3)}.score-btn-group{display:inline-flex;justify-content:center;gap:4px}.score-btn{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-color);padding:6px 12px;font-size:.85rem;font-weight:700;border-radius:var(--border-radius-sm);cursor:pointer;transition:all var(--transition-fast) ease;min-width:34px;text-align:center}.score-btn:hover{background:#ffffff1a;border-color:var(--primary-color)}.score-btn.active{background:linear-gradient(135deg,var(--primary-color),var(--accent-color));color:#fff!important;border-color:transparent!important;box-shadow:0 0 10px #3b82f64d;transform:translateY(-1px)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.cloud-sync-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;font-size:.8rem;font-weight:600;transition:all .3s ease}.cloud-sync-badge.sync-loading{background-color:#3b82f61a!important;border:1px solid rgba(59,130,246,.2)!important;color:#60a5fa!important}.cloud-sync-badge.sync-loading svg{animation:spin 1s linear infinite}.cloud-sync-badge.sync-saving{background-color:#f59e0b1a!important;border:1px solid rgba(245,158,11,.2)!important;color:#fbbf24!important}.cloud-sync-badge.sync-saving svg{animation:spin 1s linear infinite}.cloud-sync-badge.sync-success{background-color:#10b9811a!important;border:1px solid rgba(16,185,129,.2)!important;color:#34d399!important}.cloud-sync-badge.sync-error{background-color:#ef44441a!important;border:1px solid rgba(239,68,68,.2)!important;color:#f87171!important}
