/* =========================================================
   PAPI Kostick - Tema Scorecard Professional Dark Sidebar
   Update 2026-06-01 login-daftar:
   - Tema meniru gaya scorecard profesional: sidebar gelap, konten terang.
   - Sidebar dibuat tanpa kartu/statistik agar lebih bersih dan cepat.
   - Ukuran header, panel, tabel, tombol, dan kartu dibuat compact.
   - Hanya mengatur tampilan CSS, tidak mengubah logika aplikasi.
   ========================================================= */
:root {
    --brand-black: #0B0D0E;
    --brand-charcoal: #1E2225;
    --brand-graphite: #303234;
    --brand-silver: #8C908D;
    --brand-gold: #F2B500;
    --brand-orange: #E49A00;

    --primary-color: #F2B500;
    --primary-hover: #D89400;
    --primary-dark: #8A5A00;
    --primary-soft: #FFF6DD;
    --primary-light: #FFF9EA;
    --accent-color: #F2B500;
    --accent-soft: #FFF7E2;

    --bg-body: #EEF1F0;
    --bg-card: #FFFFFF;
    --bg-soft: #F7F7F4;

    --text-main: #25292C;
    --text-muted: #6F787B;
    --text-soft: #A2A6A3;

    --border-color: #DFE3E1;
    --border-strong: #C9CECB;

    --success-color: #EEF0EC;
    --success-dark: #303234;
    --warning-color: #FFF0C9;
    --danger-color: #D34A4A;
    --danger-soft: #FFF1F1;

    --sidebar-bg: #15191C;
    --sidebar-bg-2: #24282B;
    --sidebar-bg-3: #0F1214;
    --sidebar-active: #F2B500;
    --sidebar-text: #E5E7E5;
    --sidebar-muted: #9A9F9C;

    --shadow-soft: 0 1px 2px rgba(17, 24, 39, .08);
    --shadow-card: 0 1px 2px rgba(17, 24, 39, .06);

    --radius-lg: 6px;
    --radius-md: 5px;
    --radius-sm: 4px;
}

* { box-sizing: border-box; }
html, body { min-height: 100%; }

body {
    margin: 0 !important;
    background: var(--bg-body) !important;
    color: var(--text-main) !important;
    font-family: "Inter", "Segoe UI", Arial, sans-serif !important;
    font-size: 13px !important;
    line-height: 1.48 !important;
}

a { color: inherit; }

.app-layout {
    display: flex !important;
    min-height: 100vh !important;
    background: var(--bg-body) !important;
}

.main-content {
    flex: 1 !important;
    min-width: 0 !important;
    padding: 0 !important;
    background: var(--bg-body) !important;
}

.content-shell {
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 14px 16px 22px !important;
}

/* =========================================================
   SIDEBAR - gaya seperti scorecard, tanpa kartu statistik
   ========================================================= */
.sidebar {
    width: 268px !important;
    min-height: 100vh !important;
    position: sticky !important;
    top: 0 !important;
    align-self: flex-start !important;
    background: var(--sidebar-bg) !important;
    border-right: 1px solid rgba(0, 0, 0, .22) !important;
    box-shadow: none !important;
    padding: 0 !important;
    z-index: 30 !important;
    color: var(--sidebar-text) !important;
}

.sidebar::before { display: none !important; content: none !important; }

.brand-card {
    display: flex !important;
    gap: 10px !important;
    align-items: center !important;
    padding: 12px 16px !important;
    margin: 0 !important;
    min-height: 46px !important;
    border-radius: 0 !important;
    background: var(--sidebar-bg-3) !important;
    border: 0 !important;
    border-bottom: 1px solid rgba(255,255,255,.06) !important;
    box-shadow: none !important;
}

.brand-icon {
    width: 24px !important;
    height: 24px !important;
    min-width: 24px !important;
    display: grid !important;
    place-items: center !important;
    border-radius: 4px !important;
    background: transparent !important;
    color: var(--sidebar-muted) !important;
    border: 1px solid rgba(255,255,255,.13) !important;
    box-shadow: none !important;
    font-size: .82rem !important;
    font-weight: 800 !important;
}

.brand-title {
    color: #EEF3F6 !important;
    font-size: .98rem !important;
    line-height: 1.1 !important;
    font-weight: 700 !important;
    letter-spacing: .01em !important;
}

.brand-subtitle {
    color: var(--sidebar-muted) !important;
    font-size: .68rem !important;
    line-height: 1.15 !important;
    font-weight: 500 !important;
    letter-spacing: 0 !important;
    text-transform: none !important;
    margin-top: 2px !important;
}

.sidebar-menu {
    display: grid !important;
    gap: 0 !important;
    padding: 12px 0 !important;
    border: 0 !important;
}

.sidebar-link {
    width: 100% !important;
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    min-height: 42px !important;
    padding: 10px 18px !important;
    border-radius: 0 !important;
    background: transparent !important;
    border: 0 !important;
    border-left: 4px solid transparent !important;
    color: var(--sidebar-text) !important;
    font-size: .86rem !important;
    font-weight: 600 !important;
    letter-spacing: 0 !important;
    text-transform: none !important;
    text-decoration: none !important;
    transition: background .14s ease, color .14s ease, border-color .14s ease !important;
    position: relative !important;
}

.sidebar-link::before { display: none !important; content: none !important; }

.sidebar-link:hover {
    background: rgba(255,255,255,.045) !important;
    color: #FFFFFF !important;
    border-left-color: rgba(242,181,0,.55) !important;
}

.sidebar-link.active {
    background: rgba(242,181,0,.13) !important;
    color: #FFFFFF !important;
    border-left-color: var(--sidebar-active) !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.02), inset 0 -1px 0 rgba(0,0,0,.06) !important;
}

.sidebar-icon {
    width: 20px !important;
    height: 20px !important;
    min-width: 20px !important;
    display: grid !important;
    place-items: center !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    color: var(--sidebar-muted) !important;
    font-size: .9rem !important;
    line-height: 1 !important;
}

.sidebar-link:hover .sidebar-icon,
.sidebar-link.active .sidebar-icon {
    color: var(--sidebar-active) !important;
}

/* Kartu/sidebar statistik dihilangkan sesuai request agar sidebar bersih */
.sidebar-stat,
.sidebar .sidebar-stat,
.sidebar-stat-label,
.sidebar-stat-value {
    display: none !important;
}

/* =========================================================
   HEADER / TOP AREA
   ========================================================= */
.admin-header {
    min-height: 52px !important;
    background: #FFFFFF !important;
    border-bottom: 1px solid var(--border-color) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 10px !important;
    padding: 8px 16px !important;
    position: sticky !important;
    top: 0 !important;
    z-index: 25 !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
}

.admin-header-left,
.admin-header-right {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    min-width: 0 !important;
}

.admin-hamburger,
.admin-notif {
    width: 32px !important;
    height: 32px !important;
    min-width: 32px !important;
    display: grid !important;
    place-items: center !important;
    border: 1px solid var(--border-color) !important;
    background: #FFFFFF !important;
    color: var(--text-muted) !important;
    cursor: pointer !important;
    border-radius: var(--radius-sm) !important;
    font-size: .92rem !important;
    box-shadow: none !important;
}

.admin-hamburger:hover,
.admin-notif:hover {
    color: var(--primary-dark) !important;
    border-color: #F2D27A !important;
    background: var(--primary-soft) !important;
}

.admin-notif::after {
    content: '' !important;
    position: absolute !important;
    top: 7px !important;
    right: 7px !important;
    width: 6px !important;
    height: 6px !important;
    border-radius: 50% !important;
    background: var(--primary-color) !important;
    border: 1px solid #FFFFFF !important;
}

.admin-page-title {
    font-size: 1rem !important;
    font-weight: 600 !important;
    color: #4B555E !important;
    white-space: nowrap !important;
    letter-spacing: 0 !important;
}

.admin-search {
    width: min(280px, 28vw) !important;
    height: 32px !important;
    min-height: 32px !important;
    border: 1px solid var(--border-color) !important;
    background: #FFFFFF !important;
    border-radius: var(--radius-sm) !important;
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    padding: 0 10px !important;
    color: var(--text-muted) !important;
    box-shadow: none !important;
}

.admin-search input {
    border: 0 !important;
    outline: none !important;
    flex: 1 !important;
    min-width: 0 !important;
    font-size: .82rem !important;
    color: var(--text-main) !important;
    background: transparent !important;
    padding: 0 !important;
    min-height: unset !important;
}

.admin-user {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    min-width: 132px !important;
    border-left: 1px solid var(--border-color) !important;
    padding-left: 10px !important;
}

.admin-avatar {
    width: 30px !important;
    height: 30px !important;
    min-width: 30px !important;
    border-radius: 50% !important;
    display: grid !important;
    place-items: center !important;
    background: var(--primary-soft) !important;
    color: var(--primary-dark) !important;
    font-weight: 700 !important;
    font-size: .8rem !important;
    border: 1px solid #F2D27A !important;
}

.admin-user strong {
    display: block !important;
    font-size: .78rem !important;
    line-height: 1.15 !important;
    color: var(--text-main) !important;
    font-weight: 650 !important;
    letter-spacing: 0 !important;
    text-transform: none !important;
}

.admin-user a,
.admin-user span {
    display: block !important;
    color: var(--text-muted) !important;
    font-size: .7rem !important;
    font-weight: 500 !important;
    text-decoration: none !important;
    line-height: 1.15 !important;
}

.admin-user a:hover { color: var(--primary-dark) !important; }

/* =========================================================
   RINGKASAN / METRIC dibuat compact, tidak seperti kartu besar
   ========================================================= */
.dashboard-metrics {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 10px !important;
    margin-bottom: 12px !important;
}

.dash-metric-card {
    background: #FFFFFF !important;
    border: 1px solid var(--border-color) !important;
    border-top: 3px solid var(--primary-color) !important;
    border-radius: var(--radius-md) !important;
    box-shadow: var(--shadow-card) !important;
    padding: 10px 12px !important;
    display: flex !important;
    align-items: center !important;
    gap: 9px !important;
    min-height: 56px !important;
    position: relative !important;
    overflow: hidden !important;
}

.dash-metric-card::after { display: none !important; content: none !important; }

.dash-metric-icon {
    width: 28px !important;
    height: 28px !important;
    min-width: 28px !important;
    border-radius: var(--radius-sm) !important;
    background: #F5F7F8 !important;
    color: var(--primary-dark) !important;
    display: grid !important;
    place-items: center !important;
    font-size: .86rem !important;
    border: 1px solid var(--border-color) !important;
}

.dash-metric-label,
.metric-label {
    display: block !important;
    color: var(--text-muted) !important;
    font-size: .68rem !important;
    font-weight: 650 !important;
    margin-bottom: 1px !important;
    letter-spacing: .01em !important;
    text-transform: none !important;
}

.dash-metric-value,
.metric-value {
    display: block !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
    color: var(--text-main) !important;
    line-height: 1.12 !important;
    word-break: break-word !important;
}

.dash-metric-hint {
    color: var(--primary-dark) !important;
    font-size: .68rem !important;
    font-weight: 600 !important;
    margin-top: 1px !important;
}

/* =========================================================
   PANEL UMUM - flat, profesional, mirip area konten scorecard
   ========================================================= */
.topbar,
.question-panel,
.review-panel,
.setting-panel,
.auth-card,
.participant-card,
.review-card,
.review-action-card,
.metric-card,
.resume-panel,
.modal-card,
.question-card,
.category-item,
.empty-review,
.empty-state,
.resume-box,
.analysis-card,
.human-review-card,
.resume-story-card {
    border-radius: var(--radius-lg) !important;
    border: 1px solid var(--border-color) !important;
    box-shadow: var(--shadow-card) !important;
    background: #FFFFFF !important;
}

.topbar {
    padding: 12px 14px !important;
    margin-bottom: 12px !important;
    border-top: 3px solid var(--primary-color) !important;
}

.topbar h1 {
    color: #4B555E !important;
    letter-spacing: 0 !important;
    font-size: clamp(1.08rem, 1.45vw, 1.35rem) !important;
    line-height: 1.2 !important;
    margin: 0 0 4px !important;
    font-weight: 600 !important;
}

.topbar p,
.panel-subtitle,
.footer-note,
.note,
.auth-head p {
    color: var(--text-muted) !important;
    font-size: .82rem !important;
    line-height: 1.4 !important;
}

.question-panel,
.review-panel,
.setting-panel {
    overflow: hidden !important;
    margin-bottom: 12px !important;
}

.panel-header,
.review-modal-header {
    background: #FFFFFF !important;
    border-bottom: 1px solid var(--border-color) !important;
    color: var(--text-main) !important;
    padding: 11px 14px !important;
}

.panel-header .panel-title,
.panel-header .panel-subtitle,
.panel-header .panel-topline,
.panel-header h1,
.panel-header h2,
.panel-header h3,
.review-modal-header h3,
.review-modal-header p {
    color: var(--text-main) !important;
}

.panel-title {
    font-size: .96rem !important;
    font-weight: 650 !important;
    letter-spacing: 0 !important;
}

.panel-header .panel-subtitle,
.review-modal-header p { color: var(--text-muted) !important; }

.panel-header .progress-pill,
.progress-pill {
    background: var(--primary-soft) !important;
    border: 1px solid #F2D27A !important;
    color: var(--primary-dark) !important;
    border-radius: 999px !important;
    min-height: 26px !important;
    padding: 4px 9px !important;
    font-size: .7rem !important;
    font-weight: 650 !important;
}

.progress-bar-wrap,
.category-progress,
.score-bar { background: #E5E9EB !important; border-radius: 999px !important; }
.progress-bar,
.category-progress span,
.score-bar span { background: var(--primary-color) !important; }

.question-jump { padding-top: 2px !important; }
.jump-btn {
    min-width: 28px !important;
    min-height: 27px !important;
    border-radius: var(--radius-sm) !important;
    border-color: var(--border-color) !important;
    color: var(--text-muted) !important;
    background: #FFFFFF !important;
    font-size: .72rem !important;
    box-shadow: none !important;
}
.jump-btn:hover,
.jump-btn.answered {
    background: var(--primary-soft) !important;
    color: var(--primary-dark) !important;
    border-color: #F2D27A !important;
}

.question-scroll,
.review-content {
    background: #FFFFFF !important;
    padding: 12px !important;
}

.question-card {
    padding: 12px !important;
    margin-bottom: 10px !important;
    transition: border-color .14s ease, box-shadow .14s ease !important;
}

.question-card:hover,
.analysis-card:hover,
.review-action-card:hover {
    transform: none !important;
    box-shadow: var(--shadow-soft) !important;
    border-color: #C8D9AA !important;
}

.question-number,
.analysis-card-icon,
.code-badge,
.human-review-icon {
    background: var(--primary-soft) !important;
    color: var(--primary-dark) !important;
    border: 1px solid #F2D27A !important;
}

.question-number {
    width: 28px !important;
    height: 28px !important;
    min-width: 28px !important;
    border-radius: var(--radius-sm) !important;
    font-size: .76rem !important;
}

.options-grid,
.summary-cards,
.resume-columns,
.resume-story-grid,
.human-review-grid,
.human-review-detail-grid,
.participant-form-grid,
.form-grid { gap: 10px !important; }

.option-box {
    border-radius: var(--radius-md) !important;
    border-color: var(--border-color) !important;
    padding: 10px 12px !important;
    box-shadow: none !important;
}

.option-box:hover {
    border-color: #C8D9AA !important;
    background: var(--primary-light) !important;
}

.option-wrapper input[type='radio']:checked + .option-box {
    border-color: var(--primary-color) !important;
    background: var(--primary-soft) !important;
}

.option-wrapper input[type='radio']:checked + .option-box .option-letter {
    background: var(--primary-color) !important;
    color: #FFFFFF !important;
}

.option-letter {
    border-radius: 50% !important;
    min-width: 28px !important;
    width: 28px !important;
    height: 28px !important;
    font-size: .74rem !important;
}

.option-text { font-size: .86rem !important; line-height: 1.42 !important; }

/* =========================================================
   REVIEW / ANALISA
   ========================================================= */
.analysis-grid { gap: 10px !important; }
.analysis-card,
.human-review-card,
.resume-story-card,
.category-item,
.metric-card,
.review-action-card,
.resume-box { padding: 12px !important; }
.analysis-card::before { display: none !important; content: none !important; }

.analysis-card-title,
.analysis-card h3,
.human-review-lead,
.resume-highlight {
    color: var(--text-main) !important;
    font-size: .96rem !important;
    line-height: 1.3 !important;
    font-weight: 650 !important;
}

.analysis-card-text,
.analysis-card p,
.human-review-detail,
.resume-paragraphs,
.mini-text {
    color: var(--text-muted) !important;
    font-size: .82rem !important;
}

.analysis-card-kicker,
.resume-kicker {
    color: var(--primary-dark) !important;
    font-size: .68rem !important;
    letter-spacing: .04em !important;
    text-transform: uppercase !important;
}

.metric-card { min-height: unset !important; }
.category-list,
.mini-list { gap: 8px !important; }
.category-item { background: #FFFFFF !important; }
.category-top { color: var(--text-main) !important; font-size: .84rem !important; }
.resume-panel { border-left: 0 !important; }
.resume-box { background: var(--bg-soft) !important; }

.chart-wrap,
.chart-preview-wrap,
.chart-wrap-modal {
    background: #FFFFFF !important;
    border: 1px solid var(--border-color) !important;
    border-radius: var(--radius-lg) !important;
    box-shadow: var(--shadow-card) !important;
    min-height: 300px !important;
}

/* =========================================================
   FORM / TOMBOL
   ========================================================= */
.field span,
.form-field span {
    font-size: .76rem !important;
    font-weight: 650 !important;
    color: var(--text-main) !important;
}

.field input,
.field select,
.form-field input,
.form-field select,
.status-select,
textarea,
select,
input[type='text'],
input[type='email'],
input[type='password'] {
    border-radius: var(--radius-sm) !important;
    border-color: var(--border-color) !important;
    min-height: 34px !important;
    padding: 7px 10px !important;
    font-size: .83rem !important;
    box-shadow: none !important;
}

.field input:focus,
.field select:focus,
.form-field input:focus,
.form-field select:focus,
.status-select:focus,
.admin-search:focus-within,
textarea:focus,
select:focus,
input:focus {
    border-color: var(--primary-color) !important;
    box-shadow: 0 0 0 3px rgba(130, 196, 0, .14) !important;
    outline: none !important;
}

.btn,
.btn-submit,
.btn-soft,
.btn-danger,
.btn-print,
.btn-print-review {
    border-radius: var(--radius-sm) !important;
    min-height: 34px !important;
    padding: 7px 12px !important;
    font-size: .82rem !important;
    font-weight: 650 !important;
    letter-spacing: 0 !important;
    box-shadow: none !important;
    text-decoration: none !important;
}

.btn,
.btn-submit,
.btn-print,
.btn-print-review {
    background: var(--primary-color) !important;
    color: #FFFFFF !important;
    border: 1px solid var(--primary-color) !important;
}

.btn:hover,
.btn-submit:hover,
.btn-print:hover,
.btn-print-review:hover {
    background: var(--primary-hover) !important;
    border-color: var(--primary-hover) !important;
}

.btn-soft {
    background: #FFFFFF !important;
    color: var(--text-main) !important;
    border: 1px solid var(--border-color) !important;
}

.btn-soft:hover {
    background: var(--primary-soft) !important;
    color: var(--primary-dark) !important;
    border-color: #F2D27A !important;
}

.btn-danger {
    background: var(--danger-color) !important;
    color: #FFFFFF !important;
    border: 1px solid #B83C3C !important;
}

.btn-row,
.action-row,
.panel-footer,
.top-links { gap: 8px !important; }
.panel-footer {
    padding: 11px 14px !important;
    border-top: 1px solid var(--border-color) !important;
}

/* =========================================================
   TABEL
   ========================================================= */
.review-table-wrap,
.table-wrap,
.modal-table-wrap {
    border-radius: var(--radius-lg) !important;
    box-shadow: var(--shadow-card) !important;
    border: 1px solid var(--border-color) !important;
    background: #FFFFFF !important;
    overflow: auto !important;
}

table,
.review-table {
    border-collapse: collapse !important;
    font-size: .8rem !important;
}

table th,
.review-table th {
    background: #F4F6F7 !important;
    color: #5A646D !important;
    border-color: var(--border-color) !important;
    letter-spacing: 0 !important;
    font-size: .72rem !important;
    font-weight: 650 !important;
    text-transform: none !important;
    padding: 8px 10px !important;
}

table td,
.review-table td {
    background: #FFFFFF !important;
    border-color: var(--border-color) !important;
    padding: 8px 10px !important;
}

table tr:hover td,
.review-table tr:hover td { background: #F8FAFA !important; }

.result-badge,
.code-badge,
.level-badge,
.reverse-badge,
.status-badge {
    border-radius: 999px !important;
    font-size: .7rem !important;
    padding: 3px 7px !important;
    font-weight: 650 !important;
}
.level-badge.level-high { background: #FFF1F1 !important; color: #B83C3C !important; }
.level-badge.level-mid { background: #FFF6DE !important; color: #A86C00 !important; }
.level-badge.level-low { background: #F0F3F4 !important; color: #5E6972 !important; }

/* =========================================================
   MODAL / ALERT
   ========================================================= */
.review-modal-backdrop { background: rgba(31, 37, 43, .58) !important; }
.review-modal-dialog {
    border-radius: var(--radius-lg) !important;
    border: 1px solid var(--border-color) !important;
    box-shadow: 0 18px 48px rgba(31, 37, 43, .28) !important;
}
.review-modal-close {
    background: #FFFFFF !important;
    border: 1px solid var(--border-color) !important;
    color: var(--text-muted) !important;
    border-radius: var(--radius-sm) !important;
}
.review-modal-close:hover,
.review-modal-close:focus-visible {
    background: var(--primary-soft) !important;
    color: var(--primary-dark) !important;
}
.review-modal-body { background: #FFFFFF !important; }

.alert,
.success-alert {
    border-radius: var(--radius-md) !important;
    box-shadow: none !important;
    padding: 10px 12px !important;
    font-size: .82rem !important;
}
.alert { background: var(--danger-soft) !important; border-color: #F5C9C9 !important; color: #B83C3C !important; }
.success-alert { background: #F2FAE8 !important; border-color: #F2D27A !important; color: var(--success-dark) !important; }

/* =========================================================
   LOGIN / DAFTAR USER tetap bersih dan sederhana
   ========================================================= */
body.auth-page {
    min-height: 100vh !important;
    background: var(--bg-body) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 16px !important;
}

.auth-shell { width: 100% !important; max-width: 700px !important; }
.auth-card {
    display: block !important;
    overflow: hidden !important;
    border-radius: var(--radius-lg) !important;
    max-width: 700px !important;
    margin: 0 auto !important;
}
.auth-card:has(.auth-links) { max-width: 430px !important; }
.auth-head {
    background: #FFFFFF !important;
    color: var(--text-main) !important;
    border-top: 3px solid var(--primary-color) !important;
    border-bottom: 1px solid var(--border-color) !important;
    padding: 15px 16px !important;
    display: block !important;
}
.auth-head .brand { margin-bottom: 10px !important; }
.auth-head .brand-icon {
    width: 34px !important;
    height: 34px !important;
    background: var(--primary-soft) !important;
    color: var(--primary-dark) !important;
    border: 1px solid #F2D27A !important;
}
.auth-head strong,
.auth-head h1 { color: var(--text-main) !important; }
.auth-head h1 {
    font-size: 1.16rem !important;
    line-height: 1.25 !important;
    letter-spacing: 0 !important;
}
.auth-head p,
.auth-head span { color: var(--text-muted) !important; }
.auth-body { padding: 16px !important; background: #FFFFFF !important; }
.auth-links {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
    margin-top: 12px !important;
}
.top-links {
    display: flex !important;
    gap: 8px !important;
    flex-wrap: wrap !important;
    margin-top: 12px !important;
}

/* =========================================================
   PRINT
   ========================================================= */
@media print {
    .sidebar,
    .admin-header,
    .dashboard-metrics,
    .btn,
    .btn-soft,
    .btn-danger,
    .btn-submit,
    .btn-print,
    .btn-print-review,
    .admin-search,
    .admin-notif {
        display: none !important;
    }

    .main-content,
    .content-shell {
        padding: 0 !important;
        background: #FFFFFF !important;
    }

    .topbar,
    .review-panel,
    .question-panel,
    .setting-panel,
    .review-table-wrap,
    .table-wrap {
        box-shadow: none !important;
        border-color: #C9D1D6 !important;
    }

    .panel-header,
    .review-modal-header,
    table th,
    .review-table th {
        background: #FFFFFF !important;
        color: #2F363D !important;
        border-color: #C9D1D6 !important;
    }
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 1180px) {
    .dashboard-metrics { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
    .admin-search { width: min(240px, 24vw) !important; }
}

@media (max-width: 960px) {
    .app-layout { display: block !important; }
    .sidebar {
        position: relative !important;
        width: 100% !important;
        min-height: unset !important;
        box-shadow: none !important;
        border-right: 0 !important;
        border-bottom: 1px solid rgba(0,0,0,.22) !important;
    }
    .brand-card { min-height: 44px !important; }
    .sidebar-menu {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        padding: 6px !important;
        gap: 4px !important;
    }
    .sidebar-link {
        border-left: 0 !important;
        border-radius: var(--radius-sm) !important;
        padding: 9px 11px !important;
    }
    .sidebar-link.active { background: rgba(130,196,0,.16) !important; }
    .admin-header {
        position: relative !important;
        flex-direction: column !important;
        align-items: stretch !important;
        padding: 10px !important;
    }
    .admin-header-left,
    .admin-header-right {
        width: 100% !important;
        justify-content: space-between !important;
    }
    .admin-search { width: 100% !important; }
    .content-shell { padding: 10px !important; }
    .dashboard-metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 8px !important;
    }
    .auth-card,
    .auth-card:has(.auth-links) { max-width: 100% !important; }
}

@media (max-width: 620px) {
    body { font-size: 12.8px !important; }
    .sidebar-menu,
    .dashboard-metrics,
    .form-grid,
    .options-grid,
    .summary-cards,
    .resume-columns,
    .resume-story-grid,
    .human-review-grid,
    .human-review-detail-grid,
    .participant-form-grid {
        grid-template-columns: 1fr !important;
    }
    .admin-header-right {
        flex-wrap: wrap !important;
        justify-content: flex-start !important;
    }
    .admin-user {
        width: 100% !important;
        border-left: 0 !important;
        padding-left: 0 !important;
    }
    .dash-metric-card { min-height: 52px !important; }
    .panel-header,
    .question-scroll,
    .review-content,
    .auth-body,
    .auth-head { padding: 11px !important; }
}


/* =========================================================
   UPDATE LOGIN & DAFTAR USER TERINTEGRASI
   - Login dibuat sederhana.
   - Icon show/hide password.
   - Daftar user baru tampil sebagai module di dalam sidebar.
   ========================================================= */
.login-simple-page .auth-shell-login,
.auth-shell-login { max-width: 390px !important; }
.login-simple-page .login-card,
.login-card { max-width: 390px !important; }
.login-simple-page .auth-card:has(.auth-links) { max-width: 390px !important; }
.login-simple-page .auth-head,
.login-simple-page .auth-body { padding: 16px !important; }
.login-simple-page .brand { margin-bottom: 0 !important; }
.login-simple-page .brand strong { color: var(--text-main) !important; }
.login-simple-page .brand span { color: var(--text-muted) !important; }

.password-wrap {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
    width: 100% !important;
}
.password-wrap input {
    width: 100% !important;
    padding-right: 40px !important;
}
.password-toggle {
    position: absolute !important;
    right: 5px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    width: 28px !important;
    height: 28px !important;
    min-width: 28px !important;
    display: grid !important;
    place-items: center !important;
    border: 0 !important;
    border-radius: var(--radius-sm) !important;
    background: transparent !important;
    color: var(--text-muted) !important;
    cursor: pointer !important;
    box-shadow: none !important;
    padding: 0 !important;
}
.password-toggle:hover,
.password-toggle:focus-visible {
    background: var(--primary-soft) !important;
    color: var(--primary-dark) !important;
    outline: none !important;
}
.password-toggle svg {
    width: 16px !important;
    height: 16px !important;
    display: block !important;
    pointer-events: none !important;
}
.register-user-panel .participant-form-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}
.register-user-panel .panel-footer {
    justify-content: flex-end !important;
}
.register-user-panel .footer-note {
    margin-right: auto !important;
}

@media (max-width: 620px) {
    .register-user-panel .participant-form-grid {
        grid-template-columns: 1fr !important;
    }
}

.password-toggle.is-visible::after {
    content: '' !important;
    position: absolute !important;
    width: 18px !important;
    height: 2px !important;
    background: currentColor !important;
    border-radius: 999px !important;
    transform: rotate(-38deg) !important;
}


/* =========================================================
   Override Tema Saribumi dari logo BPR Saribumi
   Palet: charcoal, graphite, silver, gold, orange.
   ========================================================= */
.sidebar {
    background: linear-gradient(180deg, var(--sidebar-bg-3) 0%, var(--sidebar-bg) 52%, var(--sidebar-bg-2) 100%) !important;
    border-right-color: rgba(242,181,0,.23) !important;
}
.brand-card {
    background: linear-gradient(135deg, #0F1214 0%, #25292C 100%) !important;
    border-bottom-color: rgba(242,181,0,.20) !important;
}
.brand-icon,
.admin-avatar,
.option-wrapper input[type="radio"]:checked + .option-box .option-letter,
.score-status-filter-trigger.active {
    background: linear-gradient(135deg, var(--brand-gold), var(--brand-orange)) !important;
    color: #15191C !important;
    border-color: rgba(242,181,0,.45) !important;
}
.sidebar-link:hover,
.sidebar-link.active {
    background: rgba(242,181,0,.13) !important;
    color: #FFFFFF !important;
    border-left-color: var(--sidebar-active) !important;
}
.sidebar-link:hover .sidebar-icon,
.sidebar-link.active .sidebar-icon,
.sidebar-sublink:hover,
.sidebar-sublink.active { color: var(--sidebar-active) !important; }
.sidebar-sublink:hover,
.sidebar-sublink.active {
    background: rgba(242,181,0,.10) !important;
    border-color: rgba(242,181,0,.24) !important;
}
.admin-header,
.dash-metric-card,
.score-summary-card,
.auth-head { border-top-color: var(--brand-gold) !important; }
.admin-hamburger:hover,
.admin-notif:hover,
.admin-refresh-btn,
.btn-soft,
.score-icon-action,
.question-number,
.status-pill.role {
    background: var(--primary-light) !important;
    color: var(--primary-dark) !important;
    border-color: rgba(242,181,0,.30) !important;
}
.btn,
.btn-submit,
.score-icon-action.primary,
.score-status-filter-actions button {
    background: linear-gradient(135deg, var(--brand-gold), var(--brand-orange)) !important;
    color: #15191C !important;
    border-color: var(--brand-gold) !important;
    box-shadow: 0 10px 20px rgba(242,181,0,.20) !important;
}
.btn:hover,
.btn-submit:hover,
.score-icon-action.primary:hover {
    background: linear-gradient(135deg, var(--brand-orange), #C78300) !important;
}
.progress-bar { background: linear-gradient(90deg, var(--brand-gold), var(--brand-orange), var(--brand-silver)) !important; }
.field input:focus,
.field select:focus,
.option-wrapper input[type="radio"]:checked + .option-box {
    border-color: var(--brand-gold) !important;
    box-shadow: 0 0 0 3px rgba(242,181,0,.16) !important;
}
.panel-header,
.score-group-table-headbar { background: linear-gradient(135deg, #FFFFFF 0%, #FFF9EA 100%) !important; }
.score-group-table th { background: #F4F1E8 !important; color: #34383A !important; }
.success-alert { background: #F7F7F4 !important; border-color: #D8DCD9 !important; color: var(--success-dark) !important; }
