:root{--font-primary: "Outfit", "Sarabun", sans-serif;--bg-primary: #0b0f19;--bg-secondary: #111827;--bg-card: rgba(17, 24, 39, .65);--bg-card-hover: rgba(31, 41, 55, .85);--primary: #3b82f6;--primary-glow: rgba(59, 130, 246, .35);--secondary: #6366f1;--secondary-glow: rgba(99, 102, 241, .35);--accent: #10b981;--accent-glow: rgba(16, 185, 129, .25);--warning: #f59e0b;--danger: #ef4444;--text-primary: #ffffff;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--border-color: rgba(255, 255, 255, .08);--border-color-active: rgba(59, 130, 246, .5);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 8px 24px rgba(0, 0, 0, .5);--shadow-lg: 0 16px 40px rgba(0, 0, 0, .7);--radius-sm: 8px;--radius-md: 16px;--radius-lg: 24px;--transition: all .3s cubic-bezier(.4, 0, .2, 1)}.light-theme{--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-card: #ffffff;--bg-card-hover: #ffffff;--primary: #1d4ed8;--primary-glow: rgba(29, 78, 216, .15);--secondary: #4f46e5;--secondary-glow: rgba(79, 70, 229, .15);--accent: #059669;--accent-glow: rgba(5, 150, 105, .15);--warning: #d97706;--danger: #dc2626;--text-primary: #0f172a;--text-secondary: #334155;--text-muted: #64748b;--border-color: #e2e8f0;--border-color-active: #3b82f6;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .05)}.light-theme .gradient-bg{background:radial-gradient(circle at 10% 20%,rgba(99,102,241,.05) 0%,transparent 40%),radial-gradient(circle at 90% 80%,rgba(59,130,246,.05) 0%,transparent 40%),var(--bg-primary)}.light-theme h1{background:linear-gradient(to right,#0f172a,#334155);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.light-theme h2,.light-theme h3{color:var(--text-primary)}.light-theme .navbar{background:#ffffffd9;border-bottom:1px solid #e2e8f0}.light-theme .profile-bar{background:#f1f5f9;border-color:#e2e8f0}.light-theme th{background:#f8fafc;color:#475569;border-bottom:2px solid #e2e8f0}.light-theme td{border-bottom:1px solid #e2e8f0;color:#0f172a}.light-theme tr:hover td{background:#f8fafc}.light-theme .user-badge{background:#f1f5f9;border-color:#cbd5e1;color:#0f172a}.light-theme .eval-question-card{background:#f8fafc;border-color:#e2e8f0}.light-theme .score-option{background:#f1f5f9;border-color:#cbd5e1;color:#334155}.light-theme .score-option:hover{background:#e2e8f0;color:#0f172a;border-color:#94a3b8}.light-theme .score-option.selected{background:var(--primary);color:#fff;border-color:var(--primary)}.light-theme .history-item,.light-theme .topic-item-row{background:#f8fafc;border-color:#e2e8f0}.light-theme .input-control{background:#fff;border-color:#cbd5e1;color:#0f172a}.light-theme .input-control:focus{background:#fff;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.light-theme .input-control::placeholder{color:#94a3b8}.light-theme .stat-value{color:#0f172a}.light-theme .stat-value.primary{background:none;-webkit-background-clip:initial;-webkit-text-fill-color:initial;color:var(--primary)}.light-theme .stat-value.warning{background:none;-webkit-background-clip:initial;-webkit-text-fill-color:initial;color:var(--warning)}.light-theme .stat-value.accent{background:none;-webkit-background-clip:initial;-webkit-text-fill-color:initial;color:var(--accent)}.light-theme .btn-secondary{background:#f1f5f9;border-color:#cbd5e1;color:#334155}.light-theme .btn-secondary:hover{background:#e2e8f0;border-color:#94a3b8;color:#0f172a}.light-theme .btn-danger{background:#dc262614;border-color:#dc262640;color:#dc2626}.light-theme .btn-danger:hover{background:#dc262626;border-color:#dc262666;color:#b91c1c}.light-theme .alert-success{background:#0596690f;border-color:#05966933;color:#047857}.light-theme .alert-error{background:#dc26260f;border-color:#dc262633;color:#b91c1c}.light-theme .alert-info{background:#1d4ed80f;border-color:#1d4ed833;color:#1d4ed8}.light-theme .badge-success{background:#05966914;border-color:#05966940;color:#047857}.light-theme .badge-warning{background:#d9770614;border-color:#d9770640;color:#b45309}.light-theme .badge-danger{background:#dc262614;border-color:#dc262640;color:#b91c1c}.light-theme .badge-info{background:#1d4ed814;border-color:#1d4ed840;color:#1d4ed8}.light-theme .user-role-tag.admin{background:#dc262614;border-color:#dc262640;color:#b91c1c}.light-theme .user-role-tag.evaluator{background:#d9770614;border-color:#d9770640;color:#b45309}.light-theme .user-role-tag.employee{background:#05966914;border-color:#05966940;color:#047857}.light-theme .score-circle{background:conic-gradient(var(--primary) calc(var(--score-pct) * 1%),#e2e8f0 0);box-shadow:0 0 20px #1d4ed826}.light-theme input.score-value-badge{background:#f1f5f9!important;color:#0f172a!important;border-color:#cbd5e1!important}*{margin:0;padding:0;box-sizing:border-box}body{background-color:var(--bg-primary);color:var(--text-primary);font-family:var(--font-primary);min-height:100vh;overflow-x:hidden;line-height:1.6}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:#1f2937;border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:#374151}.app-container{display:flex;flex-direction:column;min-height:100vh}.gradient-bg{position:fixed;top:0;left:0;right:0;bottom:0;z-index:-1;pointer-events:none;background:radial-gradient(circle at 10% 20%,rgba(99,102,241,.15) 0%,transparent 40%),radial-gradient(circle at 90% 80%,rgba(59,130,246,.15) 0%,transparent 40%),#090d16}.sidebar{width:280px;min-width:280px;height:100vh;position:sticky;top:0;background:#111827bf;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-right:1px solid var(--border-color);display:flex;flex-direction:column;padding:1.5rem;z-index:100}.light-theme .sidebar{background:#ffffffd9;border-right:1px solid #e2e8f0}.sidebar-brand{margin-bottom:2rem;display:flex;justify-content:flex-start;align-items:center;padding-left:.5rem}.brand{display:flex;align-items:center;gap:.75rem;font-size:1.4rem;font-weight:700;background:linear-gradient(135deg,#60a5fa,#818cf8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;text-decoration:none}.sidebar-profile{display:flex;align-items:center;gap:1rem;padding:1rem;background:#ffffff08;border:1px solid var(--border-color);border-radius:var(--radius-sm);margin-bottom:2rem}.light-theme .sidebar-profile{background:#f8fafc;border-color:#e2e8f0}.sidebar-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--secondary));display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.2rem}.sidebar-user-details{display:flex;flex-direction:column;gap:.15rem;overflow:hidden;flex:1}.sidebar-username{font-weight:600;font-size:.9rem;color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.sidebar-position{font-size:.75rem;color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden;margin-bottom:.25rem}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:.5rem}.sidebar-nav-section-title{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:.5rem;font-weight:600;padding-left:.5rem}.sidebar-nav-btn{display:flex;align-items:center;gap:.75rem;width:100%;padding:.8rem 1rem;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--text-secondary);font-family:var(--font-primary);font-size:.95rem;font-weight:500;cursor:pointer;text-align:left;transition:var(--transition);outline:none}.sidebar-nav-btn:hover{background:#ffffff0d;color:var(--text-primary)}.light-theme .sidebar-nav-btn:hover{background:#f1f5f9}.sidebar-nav-btn.active{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;box-shadow:0 4px 12px var(--primary-glow)}.sidebar-footer{border-top:1px solid var(--border-color);padding-top:1.5rem;margin-top:auto}.light-theme .sidebar-footer{border-top-color:#e2e8f0}.user-role-tag{font-size:.75rem;padding:.2rem .5rem;border-radius:4px;text-transform:uppercase;font-weight:700;width:fit-content}.user-role-tag.admin{background:#ef444426;color:#f87171;border:1px solid rgba(239,68,68,.3)}.user-role-tag.evaluator{background:#f59e0b26;color:#fbbf24;border:1px solid rgba(245,158,11,.3)}.user-role-tag.employee{background:#10b98126;color:#34d399;border:1px solid rgba(16,185,129,.3)}@media (max-width: 768px){.sidebar{width:100%!important;min-width:100%!important;height:auto!important;position:relative!important;border-right:none!important;border-bottom:1px solid var(--border-color)!important;padding:1rem!important}.sidebar-brand{margin-bottom:1rem!important;justify-content:center!important}.sidebar-profile{display:none!important}.sidebar-nav{flex-direction:row!important;flex-wrap:wrap!important;gap:.25rem!important}.sidebar-nav-section-title{display:none!important}.sidebar-nav-btn{width:auto!important;padding:.5rem .75rem!important;font-size:.85rem!important}.sidebar-footer{border-top:none!important;padding-top:0!important;margin-top:.5rem!important;display:flex!important;gap:.5rem!important}.sidebar-footer button{margin-bottom:0!important;font-size:.85rem!important;padding:.5rem!important}}.card{background:var(--bg-card);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:2rem;box-shadow:var(--shadow-md);transition:var(--transition)}.card:hover{border-color:#ffffff26;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.main-content{flex:1;padding:2.5rem 2rem;max-width:1400px;width:100%;margin:0 auto}h1{font-size:2.2rem;font-weight:700;margin-bottom:1.5rem;letter-spacing:-.025em;background:linear-gradient(to right,#fff,#d1d5db);-webkit-background-clip:text;-webkit-text-fill-color:transparent}h2{font-size:1.5rem;font-weight:600;margin-bottom:1.25rem;color:var(--text-primary)}h3{font-size:1.15rem;font-weight:600;color:var(--text-primary)}p{color:var(--text-secondary)}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-size:.9rem;font-weight:500;color:var(--text-secondary);margin-bottom:.5rem}.input-control{width:100%;padding:.8rem 1rem;background:#ffffff0a;border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-primary);font-size:.95rem;transition:var(--transition)}.input-control:focus{outline:none;background:#ffffff14;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.input-control::placeholder{color:var(--text-muted);opacity:.85}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:var(--radius-sm);font-family:var(--font-primary);font-size:.95rem;font-weight:500;cursor:pointer;transition:var(--transition);border:1px solid transparent;outline:none}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;box-shadow:0 4px 14px var(--primary-glow)}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #3b82f680;background:linear-gradient(135deg,#2563eb,#4f46e5)}.btn-secondary{background:#ffffff0f;border-color:var(--border-color);color:var(--text-primary)}.btn-secondary:hover{background:#ffffff1f;border-color:#fff3}.btn-danger{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#f87171}.btn-danger:hover{background:#ef44444d;border-color:#ef444480}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}.auth-page{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 120px);padding:2rem}.auth-card{width:100%;max-width:460px}.auth-header{text-align:center;margin-bottom:2rem}.auth-logo{font-size:3rem;margin-bottom:.5rem}.auth-toggle{text-align:center;margin-top:1.5rem;font-size:.9rem;color:var(--text-secondary)}.auth-toggle span{color:var(--primary);cursor:pointer;font-weight:500;text-decoration:underline}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2.5rem}.stat-card{display:flex;flex-direction:column;justify-content:space-between}.stat-label{font-size:.9rem;color:var(--text-secondary);font-weight:500;margin-bottom:.5rem}.stat-value{font-size:2.5rem;font-weight:700;color:#fff;line-height:1.1;margin-bottom:.5rem}.stat-value.accent{background:linear-gradient(135deg,#10b981,#34d399);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.stat-value.primary{background:linear-gradient(135deg,#3b82f6,#6366f1);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.stat-value.warning{background:linear-gradient(135deg,#f59e0b,#fbbf24);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.profile-bar{display:flex;justify-content:space-between;align-items:center;background:#ffffff05;border:1px solid var(--border-color);padding:1.5rem 2rem;border-radius:var(--radius-md);margin-bottom:2.5rem}.profile-info{display:flex;align-items:center;gap:1.25rem}.profile-avatar{width:54px;height:54px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--secondary));display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;font-weight:700;box-shadow:0 0 15px #6366f166}.profile-details h3{font-size:1.3rem;font-weight:600}.profile-meta{display:flex;gap:1rem;font-size:.85rem;color:var(--text-secondary);margin-top:.25rem}.profile-meta span{background:#ffffff0a;padding:.2rem .6rem;border-radius:4px;border:1px solid var(--border-color)}.tabs{display:flex;border-bottom:1px solid var(--border-color);margin-bottom:2rem;gap:.5rem}.tab-btn{padding:.8rem 1.5rem;background:transparent;border:none;color:var(--text-secondary);font-family:var(--font-primary);font-size:.95rem;font-weight:500;cursor:pointer;position:relative;transition:var(--transition)}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:var(--primary);font-weight:600}.tab-btn.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background-color:var(--primary);box-shadow:0 0 8px var(--primary)}.eval-section{margin-bottom:2.5rem}.eval-section h3{border-left:4px solid var(--primary);padding-left:.75rem;margin-bottom:1.5rem;font-size:1.2rem}.eval-question-card{background:#ffffff05;border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:1.5rem;margin-bottom:1rem;transition:var(--transition)}.eval-question-card:hover{border-color:#ffffff1f;background:#ffffff08}.eval-question-header{display:flex;justify-content:space-between;margin-bottom:1rem}.eval-question-name{font-weight:500;font-size:1rem}.eval-question-max{font-size:.85rem;color:var(--text-secondary);background:#ffffff0d;padding:.1rem .5rem;border-radius:4px;border:1px solid var(--border-color)}.score-selection{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.score-option{width:42px;height:42px;border-radius:var(--radius-sm);background:#ffffff0a;border:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;font-weight:600;cursor:pointer;transition:var(--transition);color:var(--text-secondary)}.score-option:hover{background:#ffffff1a;color:var(--text-primary);border-color:#fff3}.score-option.selected{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 0 12px var(--primary-glow)}.score-number-input{display:flex;align-items:center;gap:1rem}.score-slider{flex:1;accent-color:var(--primary);height:6px;border-radius:3px;outline:none}.score-value-badge{font-size:1.2rem;font-weight:700;background:#3b82f61a;color:var(--primary);border:1px solid var(--primary-glow);padding:.25rem .75rem;border-radius:var(--radius-sm);min-width:60px;text-align:center}.table-responsive{width:100%;overflow-x:auto;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-card)}table{width:100%;border-collapse:collapse;text-align:left;font-size:.9rem}th{background:#ffffff05;color:var(--text-secondary);font-weight:600;padding:1rem;border-bottom:1px solid var(--border-color)}td{padding:1rem;border-bottom:1px solid var(--border-color);color:var(--text-primary);vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:#ffffff04}.badge{padding:.25rem .6rem;border-radius:4px;font-size:.75rem;font-weight:600;display:inline-flex}.badge-success{background:#10b98126;color:#34d399;border:1px solid rgba(16,185,129,.3)}.badge-warning{background:#f59e0b26;color:#fbbf24;border:1px solid rgba(245,158,11,.3)}.badge-danger{background:#ef444426;color:#f87171;border:1px solid rgba(239,68,68,.3)}.badge-info{background:#3b82f626;color:#60a5fa;border:1px solid rgba(59,130,246,.3)}.admin-filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem;background:#ffffff03;padding:1.25rem;border:1px solid var(--border-color);border-radius:var(--radius-sm)}.admin-pair-panel{display:grid;grid-template-columns:1fr 1fr auto;gap:1.5rem;align-items:flex-end;background:#6366f10d;border:1px solid rgba(99,102,241,.15);border-radius:var(--radius-md);padding:1.5rem;margin-bottom:2rem}@media (max-width: 768px){.admin-pair-panel{grid-template-columns:1fr}}.settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem}.history-item{display:flex;justify-content:space-between;align-items:center;padding:.85rem 1.25rem;border-radius:var(--radius-sm);background:#ffffff05;border:1px solid var(--border-color);margin-bottom:.75rem}.history-label{font-weight:500}.history-score{font-weight:600;color:var(--primary)}.history-date{font-size:.75rem;color:var(--text-muted)}.progress-bar-container{width:100%;height:8px;background:#ffffff0d;border-radius:4px;overflow:hidden;margin-top:.5rem}.progress-bar-fill{height:100%;background:linear-gradient(to right,var(--primary),var(--secondary));border-radius:4px;transition:width 1s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeInUp .4s ease-out forwards}.score-circle-wrapper{display:flex;justify-content:center;align-items:center;padding:1.5rem 0}.score-circle{width:150px;height:150px;border-radius:50%;background:conic-gradient(var(--primary) calc(var(--score-pct) * 1%),rgba(255,255,255,.05) 0);display:flex;align-items:center;justify-content:center;position:relative;box-shadow:0 0 20px #3b82f626}.score-circle:before{content:"";position:absolute;width:130px;height:130px;background:var(--bg-secondary);border-radius:50%}.score-circle-text{position:relative;z-index:2;text-align:center}.score-circle-value{font-size:2rem;font-weight:800;color:var(--text-primary)}.score-circle-label{font-size:.8rem;color:var(--text-secondary);text-transform:uppercase}.alert{padding:1rem 1.25rem;border-radius:var(--radius-sm);margin-bottom:1.5rem;font-size:.95rem;display:flex;align-items:center;gap:.75rem}.alert-success{background:#10b9811a;border:1px solid rgba(16,185,129,.25);color:#34d399}.alert-error{background:#ef44441a;border:1px solid rgba(239,68,68,.25);color:#f87171}.alert-info{background:#3b82f61a;border:1px solid rgba(59,130,246,.25);color:#60a5fa}.topic-item-actions{display:flex;gap:.5rem}.mapping-container{display:grid;grid-template-columns:1fr 1.5fr;gap:2rem;margin-top:1.5rem;margin-bottom:2.5rem}@media (max-width: 1024px){.mapping-container{grid-template-columns:1fr}}.mapping-column{display:flex;flex-direction:column;height:600px}.mapping-list{flex:1;overflow-y:auto;padding-right:.5rem;margin-top:1rem}.draggable-employee-card{background:#ffffff05;border:1px dashed var(--border-color);border-radius:var(--radius-sm);padding:1rem;margin-bottom:.75rem;cursor:grab;-webkit-user-select:none;user-select:none;transition:var(--transition);display:flex;justify-content:space-between;align-items:center}.draggable-employee-card:hover{border-style:solid;border-color:var(--primary);background:#3b82f614;transform:scale(1.02)}.draggable-employee-card:active{cursor:grabbing;opacity:.6}.drag-handle{color:var(--text-muted);font-size:1.2rem;cursor:grab}.evaluator-drop-card{background:#ffffff05;border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1.5rem;margin-bottom:1.25rem;transition:var(--transition)}.evaluator-drop-card.drag-over{border-color:var(--primary);background:#3b82f60d;box-shadow:0 0 15px var(--primary-glow);transform:translateY(-2px)}.dropzone-area{border:2px dashed rgba(255,255,255,.1);border-radius:var(--radius-sm);padding:1rem;text-align:center;color:var(--text-muted);font-size:.85rem;margin-top:1rem;transition:var(--transition)}.evaluator-drop-card.drag-over .dropzone-area{border-color:var(--primary);color:var(--primary);background:#3b82f61a}.assigned-subordinate-tag{display:inline-flex;align-items:center;gap:.5rem;background:#ffffff0d;border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:.4rem .8rem;margin-right:.5rem;margin-top:.5rem;font-size:.85rem;transition:var(--transition)}.assigned-subordinate-tag:hover{background:#ef44440d;border-color:#ef44444d}.assigned-subordinate-remove{color:var(--text-muted);cursor:pointer;font-weight:700;font-size:.9rem;transition:var(--transition)}.assigned-subordinate-remove:hover{color:var(--danger)}.light-theme .draggable-employee-card{background:#0f172a03}.light-theme .draggable-employee-card:hover{background:#3b82f60d}.light-theme .evaluator-drop-card{background:#0f172a03}.light-theme .evaluator-drop-card.drag-over{background:#3b82f60a}.light-theme .dropzone-area{border-color:#0f172a1a}.light-theme .assigned-subordinate-tag{background:#0f172a08}
