.hero-panel{position:relative;display:grid;grid-template-columns:minmax(0,1.6fr) minmax(320px,.95fr);gap:18px;border-radius:28px;padding:24px;border:1px solid var(--border);background:linear-gradient(180deg,#2563eb0d,#10b98108 26%,#fff 66%);box-shadow:var(--shadow);overflow:hidden}.hero-panel:before{content:"";position:absolute;left:0;right:0;top:0;height:4px;background:linear-gradient(90deg,var(--blue) 0%,var(--green) 56%,var(--orange) 100%)}.evaluation-hero,.ranking-hero,.berakhlak-hero{color:#0f172a}.hero-copy{display:flex;flex-direction:column;gap:14px}.hero-eyebrow{display:inline-flex;align-self:flex-start;border-radius:999px;padding:6px 12px;background:#2563eb1a;color:var(--blue);font-size:.8rem;font-weight:800;letter-spacing:.04em}.hero-copy h2{margin:0;font-size:1.9rem;line-height:1.2;letter-spacing:-.03em}.hero-copy p{margin:0;color:var(--text-soft);max-width:760px}.hero-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.hero-metric-card,.hero-side-card{border-radius:22px;background:#fff;border:1px solid var(--border)}.hero-metric-card{padding:16px;display:flex;flex-direction:column;gap:6px}.hero-metric-card small,.hero-metric-card span{color:var(--text-soft)}.hero-metric-card strong{font-size:1.45rem;letter-spacing:-.03em}.hero-side-card{padding:18px;box-shadow:inset 0 1px #fff9}.hero-side-card .panel-heading h3{color:#0f172a}.hero-side-card .panel-heading p{color:var(--text-soft)}.stats-grid-four{grid-template-columns:repeat(4,minmax(0,1fr))}.stats-grid-single{grid-template-columns:1fr}.analytics-grid{display:grid;gap:18px}.analytics-grid-wide{grid-template-columns:minmax(0,1.32fr) minmax(320px,.92fr)}.analytics-grid-balanced{grid-template-columns:repeat(2,minmax(0,1fr))}.panel-stack{display:flex;flex-direction:column;gap:18px}.panel-heading.compact{margin-bottom:16px}.panel-heading-split{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.chart-rows{display:flex;flex-direction:column;gap:14px}.chart-row{display:flex;flex-direction:column;gap:8px}.chart-row-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.chart-row-head small{display:block;color:var(--text-soft);margin-top:2px}.bar-track{position:relative;width:100%;height:10px;border-radius:999px;background:#ebf2fb;overflow:hidden}.bar-track.small{height:8px}.bar-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--blue) 0%,var(--green) 60%,var(--orange) 100%)}.insight-panel{background:linear-gradient(180deg,#fff,#fbfdff)}.insight-list{display:flex;flex-direction:column;gap:12px}.insight-item{padding:14px 16px;border-radius:18px;border:1px solid #e4eef9;background:linear-gradient(180deg,#fff,#f9fbff)}.insight-item.compact{padding:12px 14px}.insight-item strong{display:block;margin-bottom:6px}.insight-item p{margin:0;color:var(--text-soft)}.band-list,.mini-trend-list{display:flex;flex-direction:column;gap:14px}.band-row,.mini-trend-item{display:flex;flex-direction:column;gap:8px}.band-row-head,.mini-trend-head{display:flex;justify-content:space-between;gap:12px}.band-row-head span,.band-row-head strong,.mini-trend-head span,.mini-trend-head strong,.mini-trend-item small{color:inherit}.podium-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.podium-card{padding:18px;border-radius:22px;border:1px solid #dfeaf7;background:#fff;display:flex;flex-direction:column;gap:8px;min-height:190px}.podium-rank-1{background:linear-gradient(180deg,#2563eb14,#fff)}.podium-rank-2{background:linear-gradient(180deg,#10b98114,#fff)}.podium-rank-3{background:linear-gradient(180deg,#f59e0b1c,#fff)}.podium-badge{align-self:flex-start;padding:6px 10px;border-radius:999px;background:#0f172a;color:#fff;font-weight:700;font-size:.84rem}.podium-card span{color:var(--text-soft)}.podium-score{font-size:1.9rem;font-weight:800;color:#0f172a;margin-top:auto}.table-row-highlight{background:#2563eb08}.berakhlak-menu-card{background:linear-gradient(180deg,#fffffffa,#fff)}.quick-tabs-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.quick-tab{min-height:122px;border-radius:18px;border:1px solid #dbe7f5;background:linear-gradient(180deg,#fff,#f9fbff);color:#0f172a;padding:14px 12px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;text-align:center;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}.quick-tab:hover,.quick-tab.active{border-color:#2563eb42;box-shadow:0 14px 24px #2563eb14;transform:translateY(-1px)}.quick-tab.active{background:linear-gradient(180deg,#2563eb14,#10b9810d,#f59e0b0d)}.quick-tab-icon{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;font-size:1.15rem;background:linear-gradient(135deg,#2563eb1f,#10b9811f,#f59e0b1f)}.quick-tab small{color:var(--text-soft)}.question-group-stack{display:flex;flex-direction:column;gap:18px}.question-card{border:1px solid #dfeaf7;background:linear-gradient(180deg,#fff,#fbfdff);border-radius:22px;padding:18px}.question-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px}.question-card-title{display:flex;gap:12px}.question-card-title h4{margin:0 0 4px}.question-card-title p{margin:0;color:var(--text-soft)}.question-card-icon{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,var(--blue) 0%,var(--green) 62%,var(--orange) 100%);color:#fff;font-weight:800}.question-list{display:flex;flex-direction:column;gap:16px}.range-field{padding:14px 16px;border-radius:18px;background:#f9fbff;border:1px solid #dfeaf7}.range-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.range-head span{color:#0f172a;font-size:.95rem}.range-head strong{color:var(--blue)}.range-field input[type=range]{padding:0;background:transparent;border:0;box-shadow:none;accent-color:var(--green)}.range-field input[type=range]:focus{box-shadow:none}.range-scale{display:flex;justify-content:space-between;margin-top:8px}.range-scale small{color:var(--text-soft)}.preview-strip{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 18px;border-radius:18px;background:linear-gradient(90deg,#2563eb14,#10b9810f,#f59e0b0f);border:1px solid #dbe7f5}.preview-strip small{display:block;color:var(--text-soft)}.preview-strip strong{font-size:1.75rem;color:#0f172a}.mini-filter-inline{min-width:240px}.empty-state,.empty-state-cell{color:var(--text-soft);text-align:center;padding:20px 12px}@media (max-width: 1200px){.hero-panel,.analytics-grid-wide,.analytics-grid-balanced{grid-template-columns:1fr}}@media (max-width: 900px){.hero-metrics,.stats-grid-four,.podium-grid,.quick-tabs-grid{grid-template-columns:1fr}.panel-heading-split,.question-card-head,.preview-strip{flex-direction:column;align-items:stretch}}.form-dashboard-panel{background:linear-gradient(180deg,#fff,#fbfdff)}.filter-toolbar{display:grid;grid-template-columns:160px 160px minmax(240px,1fr);gap:14px;margin-bottom:18px}.filter-toolbar label{display:flex;flex-direction:column;gap:8px}.filter-toolbar span{font-size:.92rem;font-weight:700;color:var(--text-soft)}.filter-search-field{min-width:0}.compact-stats-grid .stat-card{min-height:132px}.summary-banner{display:flex;align-items:center;justify-content:space-between;gap:16px;border-radius:18px;padding:14px 16px;background:linear-gradient(90deg,#2563eb14,#10b9810f,#f59e0b14);border:1px solid #dbe7f5;color:#0f172a}.summary-banner span{color:var(--text-soft)}.berakhlak-dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a6b;display:flex;justify-content:center;align-items:flex-start;padding:24px;z-index:1200;overflow-y:auto}.berakhlak-dialog{width:min(1080px,100%);background:#fff;border-radius:28px;border:1px solid #dbe7f5;box-shadow:0 24px 60px #0f172a2e;overflow:hidden;margin:24px 0}.berakhlak-dialog-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:22px 24px;border-bottom:1px solid #e7eef8;background:linear-gradient(180deg,#2563eb0d,#10b9810a,#fff)}.berakhlak-dialog-header h3{margin:10px 0 6px}.berakhlak-dialog-header p{margin:0;color:var(--text-soft)}.dialog-close{width:40px;height:40px;border-radius:12px;background:#eef5ff;color:#0f172a;font-size:1rem;display:grid;place-items:center}.berakhlak-form-dialog{padding:24px}.berakhlak-form-dialog .question-card{box-shadow:0 8px 18px #2563eb0a}@media (max-width: 900px){.filter-toolbar,.summary-banner{grid-template-columns:1fr;flex-direction:column;align-items:stretch}.berakhlak-dialog-backdrop{padding:12px}.berakhlak-dialog{border-radius:22px}.berakhlak-dialog-header{flex-direction:column}}.dashboard-table-panel{background:linear-gradient(180deg,#fff,#fcfdff)}.dashboard-table-panel .table-wrapper,.dashboard-table-panel .data-table-wrapper{overflow-x:auto}.form-dashboard-panel .panel-heading p,.dashboard-table-panel .panel-heading p{max-width:760px}@media (max-width: 900px){.compact-stats-grid{grid-template-columns:1fr}.summary-banner{padding:12px 14px}}.form-dashboard-widgets{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;align-items:stretch}.form-dashboard-widgets .stat-card{min-height:104px;padding:14px 16px;border-radius:18px}.form-dashboard-widgets .stat-card h3,.form-dashboard-widgets .stat-card .stat-title{margin-bottom:4px}.form-dashboard-widgets .stat-card p,.form-dashboard-widgets .stat-card .stat-caption{font-size:.82rem;line-height:1.35}.form-dashboard-widgets .stat-card strong,.form-dashboard-widgets .stat-card .stat-value{font-size:1.35rem}@media (max-width: 1200px){.form-dashboard-widgets{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 640px){.form-dashboard-widgets{grid-template-columns:1fr}.form-dashboard-widgets .stat-card{min-height:96px}}.progress-summary-strip{display:flex;align-items:center;gap:10px;margin-bottom:14px;padding:14px 16px;border-radius:14px;background:#edf7ee;color:#0f172a;font-size:.92rem}.progress-summary-icon{font-size:.92rem;line-height:1}.progress-summary-good{color:#16a34a;font-weight:700}.progress-summary-danger{color:#ef4444;font-weight:700}.progress-summary-complete{color:#2563eb;font-weight:700}.progress-summary-separator{color:#94a3b8}.progress-table-wrap{border:0;border-radius:18px;box-shadow:0 14px 28px #94a3b824}.progress-table{min-width:980px;border-collapse:separate;border-spacing:0}.progress-table thead{background:#3b82f6}.progress-table th{color:#fff;font-size:.82rem;font-weight:800;text-align:center;border-bottom:0;white-space:nowrap}.progress-table th:nth-child(2),.progress-table td:nth-child(2){text-align:left}.progress-table td{padding:12px 14px;border-bottom:1px solid #e5e7eb;vertical-align:middle}.progress-no-cell{width:58px;text-align:center;font-weight:700}.progress-row td:first-child{border-left-width:4px;border-left-style:solid}.progress-row-danger td{background:#fff1f1}.progress-row-warning td{background:#fff8ed}.progress-row-caution td{background:#fffbee}.progress-row-success td{background:#f3fbf5}.progress-row-danger td:first-child{border-left-color:#ef4444;color:#ef4444}.progress-row-warning td:first-child{border-left-color:#f97316;color:#f97316}.progress-row-caution td:first-child{border-left-color:#f59e0b;color:#f59e0b}.progress-row-success td:first-child{border-left-color:#22c55e;color:#22c55e}.progress-reviewer{display:flex;align-items:flex-start;gap:12px}.progress-reviewer strong{display:block;color:#1f3b68;font-size:.95rem;line-height:1.3}.progress-score-dot{width:40px;height:40px;border-radius:999px;display:inline-grid;place-items:center;flex-shrink:0;color:#fff;font-size:.82rem;font-weight:800;box-shadow:inset 0 1px #ffffff47}.progress-score-dot-danger{background:linear-gradient(180deg,#fb7185,#ef4444)}.progress-score-dot-warning{background:linear-gradient(180deg,#fb923c,#f97316)}.progress-score-dot-caution{background:linear-gradient(180deg,#fbbf24,#f59e0b)}.progress-score-dot-success{background:linear-gradient(180deg,#4ade80,#22c55e)}.progress-note{display:inline-flex;align-items:center;gap:6px;margin-top:4px;font-size:.78rem;line-height:1.35}.progress-note-danger{color:#ef4444}.progress-note-warning{color:#f97316}.progress-note-caution{color:#d97706}.progress-note-success{color:#16a34a}.progress-note-icon{font-size:.78rem}.progress-count-cell{text-align:center;white-space:nowrap}.progress-count-value{font-size:1.6rem;line-height:1}.progress-count-value-danger{color:#ef4444}.progress-count-value-warning{color:#f97316}.progress-count-value-caution{color:#d97706}.progress-count-value-success{color:#16a34a}.progress-count-icon{margin-left:6px;font-size:1rem;vertical-align:middle}.progress-count-icon-empty{color:#ef4444}.progress-count-icon-done{color:#65a30d}.progress-target-text{color:#64748b;font-size:.84rem;white-space:nowrap}.progress-percent-cell{display:flex;flex-direction:column;gap:8px;min-width:210px}.progress-percent-cell strong{color:#ef4444;font-size:.9rem}.progress-row-warning .progress-percent-cell strong{color:#f97316}.progress-row-caution .progress-percent-cell strong{color:#d97706}.progress-row-success .progress-percent-cell strong{color:#16a34a}.progress-bar-row{display:flex;align-items:center;gap:10px}.progress-bar-track{position:relative;overflow:hidden;flex:1;height:10px;border-radius:999px;background:#d1d5db}.progress-bar-fill{display:block;height:100%;border-radius:999px}.progress-bar-fill-danger{background:linear-gradient(90deg,#fb7185,#ef4444)}.progress-bar-fill-warning{background:linear-gradient(90deg,#fbbf24,#f59e0b)}.progress-bar-fill-caution{background:linear-gradient(90deg,#facc15,#eab308)}.progress-bar-fill-success{background:linear-gradient(90deg,#4ade80,#22c55e)}.progress-percent-cell small{color:#0f172a;font-weight:700;white-space:nowrap}.progress-badge{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 14px;border-radius:999px;font-size:.78rem;font-weight:700;white-space:nowrap}.progress-badge.danger{background:#fee2e2;color:#ef4444}.progress-badge.warning{background:#ffedd5;color:#f97316}.progress-badge.caution{background:#fef3c7;color:#d97706}.progress-badge.success{background:#dcfce7;color:#16a34a}.progress-last-cell{color:#64748b;font-size:.8rem;white-space:nowrap}.progress-row:hover td{filter:brightness(.99)}@media (max-width: 900px){.progress-percent-cell{min-width:180px}.progress-table{min-width:900px}}@media (max-width: 640px){.progress-summary-strip{align-items:flex-start}.progress-reviewer{gap:10px}.progress-score-dot{width:34px;height:34px;font-size:.76rem}.progress-percent-cell{min-width:150px}}.hero-panel,.hero-metrics,.analytics-grid,.panel-stack,.filter-toolbar,.summary-banner,.form-dashboard-widgets,.compact-stats-grid{min-width:0}.dashboard-table-panel .table,.dashboard-table-panel table{min-width:760px}@media (max-width: 1200px){.filter-toolbar{grid-template-columns:repeat(2,minmax(0,1fr))}.filter-search-field{grid-column:1 / -1}}@media (max-width: 900px){.dashboard-table-panel .table,.dashboard-table-panel table{min-width:680px}.question-card,.range-field{padding:14px}}@media (max-width: 640px){.hero-copy h2{font-size:1.5rem}.hero-panel,.question-card,.hero-side-card{border-radius:20px;padding:16px}.filter-toolbar{grid-template-columns:1fr}.mini-filter-inline{min-width:0}.summary-banner{padding:12px 14px}.dashboard-table-panel .table,.dashboard-table-panel table{min-width:620px}}.attendance-count-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.attendance-hero .hero-copy p{max-width:760px}.attendance-index-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.attendance-index-item{padding:12px 14px;border-radius:16px;border:1px solid #dbe8f7;background:linear-gradient(180deg,#fff,#f8fbff);display:flex;align-items:center;justify-content:space-between;gap:10px}.attendance-index-item strong{color:#0f172a}.attendance-index-item span{color:var(--text-soft);font-size:.9rem}.attendance-form-grid{align-items:start}.attendance-inline-group{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.attendance-inline-field{min-width:0}.attendance-form-actions{justify-content:flex-end}.attendance-preview-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.attendance-preview-card{padding:16px;border-radius:20px;border:1px solid #dce7f8;background:linear-gradient(180deg,#fff,#f7fbff);display:flex;flex-direction:column;gap:6px}.attendance-preview-card small,.attendance-filter-note,.table-muted-text{color:var(--text-soft)}.attendance-preview-card strong{font-size:1.45rem;letter-spacing:-.03em}.attendance-feedback{margin-bottom:14px;padding:13px 14px;border-radius:16px;font-weight:600}.attendance-feedback.success{background:#ecfdf5;color:#047857;border:1px solid #bbf7d0}.attendance-feedback.danger{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.attendance-filter-toolbar{grid-template-columns:160px 180px minmax(240px,1fr) auto;margin-bottom:14px}.attendance-toggle-button{align-self:end;min-height:48px;white-space:nowrap}.attendance-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200;background:#0f172a6b;display:flex;align-items:center;justify-content:center;padding:24px}.attendance-modal{width:min(1080px,100%);max-height:calc(100vh - 48px);overflow:hidden;border-radius:24px;border:1px solid #dce7f8;background:linear-gradient(180deg,#fff,#f7fbff);box-shadow:0 24px 60px #0f172a2e}.attendance-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:22px 22px 0}.attendance-modal-body{max-height:calc(100vh - 170px);overflow-y:auto;padding:18px 22px 22px}.attendance-modal-close{width:42px;height:42px;border:none;border-radius:999px;background:#e2e8f0;color:#0f172a;font-size:1.6rem;line-height:1;cursor:pointer;flex-shrink:0}.attendance-modal-close:hover{background:#cbd5e1}.attendance-filter-actions{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:14px}.attendance-filter-banner strong{white-space:nowrap}.attendance-filter-note{margin-top:14px;padding:12px 14px;border-radius:16px;background:#f7fbff;border:1px solid #dce7f8}.empty-state-cell{text-align:center;color:var(--text-soft)}@media (max-width: 1100px){.attendance-preview-grid,.attendance-filter-toolbar{grid-template-columns:1fr}.attendance-count-grid,.attendance-inline-group{grid-template-columns:repeat(2,minmax(0,1fr))}.attendance-filter-banner{align-items:flex-start}.attendance-filter-banner strong{white-space:normal}}@media (max-width: 760px){.attendance-index-grid{grid-template-columns:1fr}.attendance-filter-actions{flex-direction:column}.attendance-filter-actions .button-primary,.attendance-filter-actions .button-secondary,.attendance-toggle-button{width:100%}.attendance-modal-backdrop{padding:12px}.attendance-modal{max-height:calc(100vh - 24px)}.attendance-modal-header{padding:16px 16px 0}.attendance-modal-body{max-height:calc(100vh - 140px);padding:16px}}@media (max-width: 560px){.attendance-count-grid,.attendance-inline-group{grid-template-columns:1fr}}.attendance-progress-table .table{min-width:1080px;border-collapse:separate;border-spacing:0 10px}.attendance-progress-table thead th{background:linear-gradient(180deg,#4f8ff7,#3779ea);color:#fff;border:0;padding:13px 14px;font-size:.78rem}.attendance-progress-table thead th:first-child{border-top-left-radius:14px}.attendance-progress-table thead th:last-child{border-top-right-radius:14px}.attendance-progress-table tbody td{padding:14px;vertical-align:middle;background:#fff;border-top:1px solid #e6edf7;border-bottom:1px solid #e6edf7}.attendance-progress-table tbody td:first-child{border-left:4px solid #cbd5e1;border-top-left-radius:16px;border-bottom-left-radius:16px}.attendance-progress-table tbody td:last-child{border-right:1px solid #e6edf7;border-top-right-radius:16px;border-bottom-right-radius:16px}.attendance-table-row{box-shadow:0 10px 24px #0f172a0f}.attendance-table-row.tone-danger td{background:#fff1f2}.attendance-table-row.tone-danger td:first-child{border-left-color:#ef4444}.attendance-table-row.tone-warning td{background:#fff7ed}.attendance-table-row.tone-warning td:first-child{border-left-color:#f97316}.attendance-table-row.tone-progress td{background:#fffbeb}.attendance-table-row.tone-progress td:first-child{border-left-color:#f59e0b}.attendance-table-row.tone-success td{background:#ecfdf5}.attendance-table-row.tone-success td:first-child{border-left-color:#22c55e}.attendance-cell-number,.attendance-cell-action{text-align:center}.attendance-cell-number{width:72px}.attendance-cell-action{width:120px}.attendance-row-number{width:34px;height:34px;border-radius:999px;display:inline-grid;place-items:center;font-weight:800;font-size:.88rem;color:#fff}.attendance-row-number.tone-danger{background:#ef4444}.attendance-row-number.tone-warning{background:#f97316}.attendance-row-number.tone-progress{background:#f59e0b}.attendance-row-number.tone-success{background:#16a34a}.attendance-cell-employee strong,.attendance-cell-period strong,.attendance-cell-index strong,.attendance-cell-score strong,.attendance-cell-updated strong{display:block}.attendance-inline-pills{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:6px}.attendance-mini-pill{display:inline-flex;align-items:center;justify-content:center;min-width:62px;padding:6px 10px;border-radius:999px;background:#ffffffd1;border:1px solid rgba(148,163,184,.24);font-size:.78rem;font-weight:700;color:#334155}.attendance-cell-index strong,.attendance-cell-score strong{font-size:1rem}.attendance-score-bar{position:relative;margin-top:8px;width:100%;height:8px;border-radius:999px;overflow:hidden;background:#94a3b859}.attendance-score-bar-fill{display:block;height:100%;border-radius:inherit}.attendance-score-bar-fill.tone-danger{background:linear-gradient(90deg,#ef4444,#f87171)}.attendance-score-bar-fill.tone-warning{background:linear-gradient(90deg,#f97316,#fb923c)}.attendance-score-bar-fill.tone-progress{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.attendance-score-bar-fill.tone-success{background:linear-gradient(90deg,#16a34a,#22c55e)}.attendance-table-action{min-width:88px}@media (max-width: 900px){.attendance-progress-table .table{min-width:960px}}.competency-hero .hero-copy p{max-width:780px}.competency-side-card{display:flex;flex-direction:column;gap:14px}.competency-index-grid .attendance-index-item{min-height:78px;align-items:flex-start}.competency-filter-toolbar{grid-template-columns:160px 180px minmax(240px,1fr) auto}.competency-modal{width:min(1120px,100%)}.competency-form-grid{align-items:start}.competency-form-grid input[type=file]{padding:12px;background:#fff}.competency-field-help{display:block;margin-top:6px;color:var(--text-soft);font-size:.84rem}.competency-filter-note{margin-bottom:14px}.competency-preview-grid .attendance-preview-card span{color:var(--text-soft)}.competency-progress-table .table{min-width:1120px}.competency-activity-cell strong,.competency-hours-cell strong,.competency-score-cell strong{display:block}.competency-document-stack{display:flex;flex-direction:column;gap:8px}.competency-file-link{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:var(--blue)}.competency-file-link:hover{text-decoration:underline}.competency-name-stack{display:flex;flex-direction:column;gap:4px}.competency-name-stack small{color:var(--text-soft)}@media (max-width: 1100px){.competency-filter-toolbar{grid-template-columns:1fr}}@media (max-width: 760px){.competency-modal{width:100%}}:root{font-family:Inter,Arial,sans-serif;color:#0f172a;background:#f5f8fc;line-height:1.5;font-weight:400;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--blue: #2563eb;--green: #10b981;--orange: #f59e0b;--primary: #2563eb;--primary-soft: #dbeafe;--success-bg: #ecfdf5;--success-text: #047857;--warning-bg: #fff7ed;--warning-text: #c2410c;--danger: #dc2626;--panel: #ffffff;--panel-soft: #f8fbff;--border: #d9e6f5;--border-strong: #bfdbfe;--text-soft: #5b6778;--shadow: 0 14px 36px rgba(15, 23, 42, .07);--shadow-soft: 0 8px 20px rgba(15, 23, 42, .05)}*{box-sizing:border-box}html,body,#root{min-height:100%;width:100%}body{margin:0;min-width:320px;min-height:100vh;overflow-x:hidden;background:radial-gradient(circle at top right,rgba(245,158,11,.08),transparent 24%),radial-gradient(circle at top left,rgba(16,185,129,.08),transparent 20%),linear-gradient(180deg,#f9fbff,#f3f7fc);color:#0f172a}button,input,select,textarea{font:inherit}button{cursor:pointer;border:0}a{color:inherit;text-decoration:none}.app-shell{position:relative;display:grid;grid-template-columns:288px minmax(0,1fr);min-height:100vh;width:100%}.sidebar{padding:18px 10px 14px;background:radial-gradient(circle at top left,rgba(255,255,255,.07),transparent 24%),linear-gradient(180deg,#211816,#171211);color:#f8fafc;display:flex;flex-direction:column;gap:8px;border-right:1px solid rgba(255,255,255,.06);min-width:0;z-index:1100}.settings-shell{grid-template-columns:332px minmax(0,1fr)}.settings-sidebar{box-shadow:inset -1px 0 #ffffff08}.sidebar-profile{display:grid;grid-template-columns:74px minmax(0,1fr);align-items:center;gap:14px;padding:10px 8px 18px}.sidebar-profile-avatar{width:74px;height:74px;border-radius:999px;overflow:hidden;box-shadow:0 10px 24px #00000047}.sidebar-profile-avatar svg{display:block;width:100%;height:100%}.sidebar-profile-meta{min-width:0;display:grid;gap:1px}.sidebar-profile-meta strong,.sidebar-profile-meta span,.sidebar-profile-meta small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-profile-meta strong{font-size:1.02rem;font-weight:700;color:#fff}.sidebar-profile-meta span{color:#ffffffe6;font-size:.94rem}.sidebar-profile-meta small{margin-top:3px;color:#ffffff80;font-size:.71rem;letter-spacing:.08em}.settings-nav{display:flex;flex-direction:column;gap:4px}.settings-link,.settings-group-toggle{position:relative;width:100%;display:flex;align-items:center;gap:14px;min-height:56px;padding:10px 14px;border-radius:12px;background:transparent;color:#fffffff0;text-align:left;transition:background .18s ease,color .18s ease,transform .18s ease}.settings-link:before,.settings-group-toggle:before,.settings-sublink:before{content:"";position:absolute;left:0;top:9px;bottom:9px;width:4px;border-radius:999px;background:transparent}.settings-link:hover,.settings-group-toggle:hover,.settings-sublink:hover{background:#ffffff0d}.settings-link.active,.settings-group-toggle.active,.settings-group.active>.settings-group-toggle{background:#ffffff14;color:#fff}.settings-link.active:before,.settings-group-toggle.active:before,.settings-group.active>.settings-group-toggle:before,.settings-sublink.active:before{background:#35c8ff}.settings-link-icon{width:28px;height:28px;flex:0 0 28px;display:inline-grid;place-items:center;border-radius:8px;color:#fff;box-shadow:inset 0 1px #ffffff29}.settings-link-icon svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.settings-link-icon[data-tone=home]{background:linear-gradient(180deg,#ffb34d,#f57c00)}.settings-link-icon[data-tone=system]{background:linear-gradient(180deg,#5ad9ff,#0f8fe6)}.settings-link-icon[data-tone=settings]{background:linear-gradient(180deg,#a78bfa,#7c3aed)}.settings-link-icon[data-tone=evaluation]{background:linear-gradient(180deg,#93c5fd,#2563eb)}.settings-link-icon[data-tone=berakhlak]{background:linear-gradient(180deg,#5eead4,#0f766e)}.settings-link-icon[data-tone=attendance]{background:linear-gradient(180deg,#fdba74,#ea580c)}.settings-link-icon[data-tone=employees]{background:linear-gradient(180deg,#86efac,#16a34a)}.settings-link-icon[data-tone=accounts]{background:linear-gradient(180deg,#f0abfc,#c026d3)}.settings-link-icon[data-tone=logout]{background:linear-gradient(180deg,#fda4af,#e11d48)}.settings-link-icon[data-tone=default]{background:linear-gradient(180deg,#94a3b8,#475569)}.settings-link-label{min-width:0;flex:1;font-size:.98rem;line-height:1.3}.settings-group{display:flex;flex-direction:column;gap:4px}.settings-group-arrow{width:18px;height:18px;flex:0 0 18px;color:#ffffffa3;transition:transform .18s ease,color .18s ease}.settings-group-arrow svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}.settings-group-toggle.open .settings-group-arrow{transform:rotate(90deg);color:#fff}.settings-submenu{margin:0 0 4px 54px;padding-left:14px;border-left:1px solid rgba(255,255,255,.12);display:flex;flex-direction:column;gap:2px}.settings-sublink{position:relative;display:block;padding:10px 12px;border-radius:10px;color:#ffffffd6;transition:background .18s ease,color .18s ease}.settings-sublink:before{left:-15px;width:3px;top:7px;bottom:7px}.settings-sublink.active{background:#ffffff14;color:#fff}.settings-sublink-label{display:block;font-size:.92rem;line-height:1.35}.settings-sidebar-footer{margin-top:auto;padding-top:10px;border-top:1px solid rgba(255,255,255,.05)}.settings-link-button{border:0}.brand,.brand-chip,.sidebar-user-panel,.nav-menu,.sidebar-card,.sidebar-brand-desktop,.settings-section,.settings-section-title,.settings-section-items,.settings-app-meta{display:none}.settings-mobile-title{color:#fff;font-size:.95rem;font-weight:700}.content{min-width:0;padding:28px}.page-stack{display:flex;flex-direction:column;gap:22px}.section-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.section-header h1{margin:0 0 6px;font-size:1.8rem;letter-spacing:-.02em}.section-header p{margin:0;color:var(--text-soft);max-width:900px}.stats-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.stats-card,.panel{background:var(--panel);border:1px solid var(--border);border-radius:24px;box-shadow:var(--shadow-soft)}.stats-card{padding:20px;display:flex;flex-direction:column;gap:8px;position:relative;overflow:hidden}.stats-card:before,.panel:before{content:"";position:absolute;left:0;right:0;top:0;height:4px;background:linear-gradient(90deg,var(--blue) 0%,var(--green) 60%,var(--orange) 100%)}.panel{padding:22px;position:relative;overflow:hidden}.stats-card strong{font-size:1.9rem;letter-spacing:-.03em}.stats-label,.stats-card small{color:var(--text-soft)}.two-column{display:grid;grid-template-columns:minmax(320px,430px) 1fr;gap:18px}.panel-heading{margin-bottom:18px}.panel-heading h3{margin:0 0 4px;font-size:1.08rem}.panel-heading p{margin:0;color:var(--text-soft)}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.form-grid label{display:flex;flex-direction:column;gap:8px}.form-grid span{font-size:.92rem;font-weight:600;color:var(--text-soft)}input,select,textarea{width:100%;border:1px solid var(--border);background:linear-gradient(180deg,#fff,#f8fbff);border-radius:14px;padding:12px 14px;color:#0f172a;outline:none}input:focus,select:focus,textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px #2563eb1f}.field-full{grid-column:1 / -1}.form-actions{grid-column:1 / -1;display:flex;gap:10px;justify-content:flex-start}.button-primary,.button-secondary,.button-danger{border-radius:14px;padding:11px 16px;font-weight:700}.button-primary{color:#fff;background:linear-gradient(90deg,var(--blue) 0%,var(--green) 72%,var(--orange) 100%);box-shadow:0 10px 20px #2563eb2e}.button-secondary{background:#edf5ff;color:#0f172a}.button-danger{background:#fef2f2;color:var(--danger)}.action-buttons{display:flex;gap:8px;flex-wrap:wrap}.table-wrap{overflow-x:auto;border:1px solid #e8eff9;border-radius:18px}.table{width:100%;border-collapse:collapse;background:#fff}.table thead{background:linear-gradient(90deg,#2563eb14,#10b98114,#f59e0b14)}.table th,.table td{padding:14px 12px;text-align:left;border-bottom:1px solid #edf2f7;vertical-align:top}.table th{font-size:.88rem;color:var(--text-soft);font-weight:800}.table td{font-size:.95rem}.table tbody tr:hover{background:#fbfdff}.badge{display:inline-flex;align-items:center;border-radius:999px;padding:6px 10px;font-size:.82rem;font-weight:700}.badge-neutral{background:#eaf2ff;color:#1d4ed8}.badge-success{background:var(--success-bg);color:var(--success-text)}.badge-warning{background:var(--warning-bg);color:var(--warning-text)}.department-list{display:flex;flex-direction:column;gap:12px}.department-item{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border:1px solid var(--border);border-radius:18px;background:var(--panel-soft)}.department-item strong{display:block;margin-bottom:2px}.department-item small{color:var(--text-soft)}.department-score{min-width:72px;text-align:center;background:linear-gradient(90deg,#2563eb1f,#10b9811f);color:var(--blue);border-radius:14px;padding:8px 12px;font-weight:700}.loading-state{padding:28px;background:#fff;border-radius:24px;border:1px solid var(--border)}.score-preview{grid-column:1 / -1;display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-radius:16px;background:linear-gradient(90deg,#2563eb1a,#10b98114,#f59e0b14);color:#1d4ed8;font-weight:700}.score-preview strong{font-size:1.2rem}.muted-text{color:var(--text-soft);font-size:.86rem}@media (max-width: 1100px){.two-column,.stats-grid{grid-template-columns:1fr}}@media (max-width: 900px){.app-shell{grid-template-columns:1fr}.sidebar{gap:18px}.content{padding:18px}}@media (max-width: 640px){.form-grid{grid-template-columns:1fr}.section-header h1{font-size:1.5rem}.panel,.stats-card{border-radius:18px;padding:18px}}img,svg,canvas{max-width:100%}.page-stack,.panel-stack,.analytics-grid,.hero-panel,.panel,.stats-card,.table-wrap,.table-wrapper,.data-table-wrapper,.section-header,.form-grid,.two-column{min-width:0}.table-wrap,.table-wrapper,.data-table-wrapper{width:100%;-webkit-overflow-scrolling:touch}.table{min-width:720px}.mobile-topbar,.mobile-menu-button,.sidebar-overlay,.sidebar-mobile-head,.sidebar-close-button{display:none}.brand-mobile{padding:0;border:0;background:transparent}.section-header,.panel-heading-split,.form-actions,.action-buttons{flex-wrap:wrap}@media (max-width: 1280px){.stats-grid,.stats-grid-four,.hero-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 1100px){.hero-panel,.analytics-grid-wide,.analytics-grid-balanced,.two-column,.stats-grid,.stats-grid-four{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:stretch}}@media (max-width: 900px){.app-shell{display:block}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a6b;border:0;opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:1090}.sidebar-overlay.open{opacity:1;pointer-events:auto}.sidebar{position:fixed;inset:0 auto 0 0;width:min(332px,88vw);max-width:88vw;transform:translate(-100%);transition:transform .24s ease;overflow-y:auto;box-shadow:18px 0 40px #0f172a3d}.sidebar.open{transform:translate(0)}.sidebar-mobile-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.sidebar-brand-desktop{display:none}.sidebar-close-button{display:inline-grid;place-items:center;width:40px;height:40px;border-radius:12px;background:#ffffff14;color:#fff}.settings-submenu{margin-left:52px;padding-left:12px}.settings-link,.settings-group-toggle{min-height:54px}.mobile-topbar{display:flex;align-items:center;gap:12px;margin-bottom:18px;padding:12px 14px;border-radius:18px;background:#ffffffe0;border:1px solid var(--border);box-shadow:var(--shadow-soft)}.mobile-menu-button{display:inline-grid;place-items:center;width:44px;height:44px;border-radius:14px;background:linear-gradient(135deg,var(--blue),var(--green));color:#fff;font-size:1.15rem;box-shadow:0 12px 20px #2563eb38}.mobile-topbar-title{min-width:0;display:grid;gap:2px}.mobile-topbar-title strong,.mobile-topbar-title span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-topbar-title span{color:var(--text-soft);font-size:.88rem}.content{padding:18px}.hero-metrics,.quick-tabs-grid,.podium-grid{grid-template-columns:1fr}}@media (max-width: 640px){.content{padding:14px}.form-grid,.stats-grid,.stats-grid-four{grid-template-columns:1fr}.section-header h1{font-size:1.5rem}.panel,.stats-card{border-radius:18px;padding:18px}.button-primary,.button-secondary,.button-danger{width:100%;justify-content:center}.form-actions>*,.action-buttons>*{flex:1 1 100%}.table{min-width:640px}}.auth-loading-screen,.login-page{min-height:100vh;background:radial-gradient(circle at top left,rgba(59,130,246,.18),transparent 30%),radial-gradient(circle at bottom right,rgba(249,115,22,.14),transparent 28%),linear-gradient(135deg,#eff6ff,#f0fdf4 55%,#fff7ed)}.auth-loading-screen{display:flex;align-items:center;justify-content:center;padding:24px}.auth-loading-card{min-width:280px;padding:28px;border-radius:24px;background:#fffffff5;box-shadow:0 20px 50px #0f172a14;text-align:center}.auth-loading-spinner{width:42px;height:42px;margin:0 auto 16px;border-radius:50%;border:3px solid rgba(59,130,246,.18);border-top-color:#2563eb;animation:authSpin .9s linear infinite}@keyframes authSpin{to{transform:rotate(360deg)}}.login-page{display:flex;align-items:center;justify-content:center;padding:32px 20px}.login-shell{width:100%;max-width:1160px;display:grid;grid-template-columns:1.15fr .95fr;gap:28px}.login-hero,.login-card{background:#fffffff0;border:1px solid rgba(148,163,184,.14);box-shadow:0 24px 60px #0f172a14}.login-hero{padding:40px;border-radius:32px;position:relative;overflow:hidden}.login-hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#2563eb0f,#16a34a0d,#f973160d);pointer-events:none}.login-brand-mark{width:62px;height:62px;border-radius:20px;display:grid;place-items:center;font-size:1.2rem;font-weight:800;color:#fff;background:linear-gradient(135deg,#2563eb,#16a34a,#f97316);margin-bottom:22px}.login-hero h1,.login-hero p,.login-card{position:relative;z-index:1}.login-hero h1{margin:0 0 14px;font-size:clamp(2rem,3vw,2.85rem);line-height:1.1;color:#0f172a}.login-hero>p{margin:0;max-width:560px;color:#475569;font-size:1rem;line-height:1.7}.login-hero-points{margin-top:28px;display:grid;gap:16px}.login-hero-point{display:flex;gap:14px;align-items:flex-start;padding:16px 18px;border-radius:22px;background:#fff;border:1px solid rgba(226,232,240,.9)}.login-point-dot{width:14px;height:14px;border-radius:999px;margin-top:6px;flex-shrink:0}.login-point-dot.blue{background:#2563eb}.login-point-dot.green{background:#16a34a}.login-point-dot.orange{background:#f97316}.login-hero-point strong{display:block;margin-bottom:4px;color:#0f172a}.login-hero-point p{margin:0;color:#64748b;line-height:1.6}.login-card-wrap{display:flex;align-items:center}.login-card{width:100%;padding:34px;border-radius:30px}.login-card-header h2{margin:0 0 6px;color:#0f172a}.login-card-header p{margin:0 0 22px;color:#64748b}.login-form{display:grid;gap:16px}.login-field{display:grid;gap:8px}.login-field span{font-size:.92rem;font-weight:700;color:#334155}.login-field input{width:100%;height:50px;padding:0 16px;border-radius:16px;border:1px solid #cbd5e1;outline:none;background:#fff;color:#0f172a;transition:border-color .2s ease,box-shadow .2s ease}.login-field input:focus{border-color:#2563eb;box-shadow:0 0 0 4px #2563eb1f}.login-alert{padding:12px 14px;border-radius:14px;font-size:.92rem}.login-alert.error{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.login-submit,.sidebar-logout-button{border:none;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,opacity .18s ease}.login-submit{height:52px;border-radius:18px;font-size:1rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#2563eb,#16a34a,#f97316);box-shadow:0 16px 28px #2563eb2e}.login-submit:hover,.sidebar-logout-button:hover{transform:translateY(-1px)}.login-submit:disabled{opacity:.72;cursor:wait}.login-helper-card{margin-top:20px;padding:18px 18px 8px;border-radius:22px;background:linear-gradient(135deg,#2563eb0f,#16a34a0d,#f973160d);border:1px solid rgba(148,163,184,.15)}.login-helper-card h3{margin:0 0 10px;color:#0f172a;font-size:1rem}.login-helper-card ul{margin:0;padding-left:18px;color:#475569;line-height:1.7}.sidebar-user-panel{display:flex;align-items:center;gap:12px;padding:14px;margin-bottom:16px;border-radius:22px;background:linear-gradient(135deg,#2563eb1a,#16a34a14,#f9731614);border:1px solid rgba(148,163,184,.16)}.sidebar-user-avatar{width:46px;height:46px;flex-shrink:0;display:grid;place-items:center;border-radius:16px;background:linear-gradient(135deg,#2563eb,#16a34a);color:#fff;font-size:1rem;font-weight:800}.sidebar-user-meta{min-width:0;flex:1;display:grid;gap:2px}.sidebar-user-meta strong,.sidebar-user-meta span,.sidebar-user-meta small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user-meta strong{color:#0f172a}.sidebar-user-meta span{color:#475569;font-size:.86rem}.sidebar-user-meta small{color:#2563eb;font-size:.74rem;font-weight:800;letter-spacing:.05em}.sidebar-logout-button{padding:10px 14px;border-radius:14px;background:#fff;color:#0f172a;font-weight:700;box-shadow:0 8px 18px #0f172a14}@media (max-width: 980px){.login-shell{grid-template-columns:1fr}.login-hero,.login-card{padding:28px}}@media (max-width: 640px){.login-page{padding:18px}.login-hero,.login-card{border-radius:24px;padding:22px}.sidebar-user-panel{flex-wrap:wrap}.sidebar-logout-button{width:100%}}@media (max-width: 900px){.login-shell{gap:20px}.login-hero-points{grid-template-columns:1fr}}@media (max-width: 640px){.auth-loading-card{min-width:0;width:100%}.login-hero h1{font-size:1.7rem}.login-hero-point{padding:14px 15px}.login-helper-card{padding:16px}}
