/* =============================================
   CUSTOM.CSS - REDESIGN TRACERSTUDY
   Bootstrap 5 + Design System Ungu-Magenta
   ============================================= */

/* =============================================
   1. CSS VARIABLES - DESIGN SYSTEM
   ============================================= */
:root {
  --primary-dark: #6317c3;
  --primary-gradient: linear-gradient(135deg, #6317c3 0%, #9333ea 60%, #d942c0 100%);
  --primary-light: #9333ea;
  --neutral-dark: #1e2937;
  --neutral-light: #f8fafc;
  --text-light: #f8fafc;
  --text-dark: #1e2937;

  --shadow-sm: 0 1px 3px rgba(99, 23, 195, 0.08), 0 1px 2px rgba(99, 23, 195, 0.06);
  --shadow-md: 0 4px 16px rgba(99, 23, 195, 0.12), 0 2px 6px rgba(99, 23, 195, 0.08);
  --shadow-lg: 0 10px 30px rgba(99, 23, 195, 0.18), 0 4px 10px rgba(99, 23, 195, 0.10);

  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 14px;
  --radius-xl: 20px;

  --transition-fast: 0.15s ease;
  --transition-base: 0.25s ease;
  --transition-slow: 0.4s ease;

  --sidebar-width: 240px;
  --topbar-height: 60px;
}

/* =============================================
   2. BASE & TYPOGRAPHY
   ============================================= */
html {
  color-scheme: light;
}

body {
  font-family: 'Poppins', 'Segoe UI', system-ui, -apple-system, sans-serif;
  background-color: var(--neutral-light);
  color: var(--text-dark);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
  font-weight: 700;
  color: var(--neutral-dark);
  line-height: 1.3;
  letter-spacing: -0.01em;
}

h1, .h1 { font-size: clamp(1.5rem, 3vw, 2.25rem); }
h2, .h2 { font-size: clamp(1.3rem, 2.5vw, 1.875rem); }
h3, .h3 { font-size: clamp(1.1rem, 2vw, 1.5rem); }
h4, .h4 { font-size: clamp(1rem, 1.5vw, 1.25rem); font-weight: 600; }

a {
  color: var(--primary-light);
  text-decoration: none;
  transition: color var(--transition-fast);
}
a:hover { color: var(--primary-dark); }

/* =============================================
   3. TOPBAR / NAVBAR
   ============================================= */

/* Landing page navbar (assetshome) */
#header,
#topbar {
  background: var(--primary-gradient) !important;
  box-shadow: var(--shadow-md);
}

#topbar {
  padding: 8px 0;
  font-size: 0.8rem;
}

#topbar .contact-info a,
#topbar .contact-info span,
#topbar .contact-info i {
  color: rgba(255, 255, 255, 0.88) !important;
}

#header .logo h1,
#header .logo h1 a,
#header .logo h4 a {
  color: var(--text-light) !important;
  font-weight: 700;
  letter-spacing: -0.02em;
}

#header .logo h1 a span,
#header .logo h4 a span {
  color: rgba(255, 255, 255, 0.75) !important;
}

#navbar ul li a.nav-link,
#navbar ul > li > a {
  color: rgba(255, 255, 255, 0.9) !important;
  font-weight: 500;
  font-size: 0.875rem;
  padding: 6px 14px;
  border-radius: var(--radius-sm);
  transition: background var(--transition-fast), color var(--transition-fast);
}

#navbar ul li a.nav-link:hover,
#navbar ul > li > a:hover,
#navbar ul li a.nav-link.active {
  color: #fff !important;
  background: rgba(255, 255, 255, 0.15);
}

/* Old topbar — hidden completely on all sizes */
.page-header.navbar {
  display: none !important;
}
/* Remove margin-top that page-header-fixed body class would normally add */
.page-container {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* ── Mobile sidebar toggle — hidden on desktop, in-flow on mobile ── */
.mob-sidebar-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: #f4f0ff;
  border: none;
  color: #3e2583;
  cursor: pointer;
  transition: background .15s ease;
}
.mob-sidebar-toggle:hover { background: #ede9fe; }
.mob-sidebar-toggle .material-icons {
  font-size: 20px !important;
  line-height: 1;
  margin: 0 !important;
  color: #3e2583 !important;
}

@media (max-width: 991.98px) {
  .mob-sidebar-toggle {
    display: flex !important;
  }
}


/* =============================================
   4. SIDEBAR / LEFT MENU  — light theme
   ============================================= */
.sidebar-container,
.sidemenu-container,
.left-sidemenu,
#remove-scroll,
.fixed-menu {
  background: #3e2583 !important;
  box-shadow: 3px 0 20px rgba(0,0,0,.18) !important;
  border-right: none !important;
  color: rgba(255,255,255,.8);
}
/* Desktop-only: full-height sidebar, no topbar offset */
/* Mobile: sidebar off-screen by default, slides in when toggled */
@media (max-width: 991.98px) {
  .sidebar-container {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 235px !important;
    height: 100vh !important;
    z-index: 1050 !important;
    transform: translateX(-100%) !important;
    transition: transform .28s ease !important;
  }
  body.sidebar-open .sidebar-container {
    transform: translateX(0) !important;
  }
  .sidemenu-container {
    height: 100% !important;
    overflow-y: auto !important;
    margin: 0 !important;
    display: block !important; /* override collapse hide */
  }
  /* Overlay backdrop */
  #mob-sidebar-overlay {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 1049;
    background: rgba(0,0,0,.4);
  }
  body.sidebar-open #mob-sidebar-overlay {
    display: block;
  }
}

/* Desktop: full-height sidebar, no topbar offset */
@media (min-width: 992px) {
  .left-sidemenu,
  #remove-scroll {
    min-height: 100% !important;
  }
  .sidemenu-container,
  .sidemenu-container.fixed-menu {
    margin-top: 0 !important;
    top: 0 !important;
    height: 100vh !important;
  }
}

.sidebar-container .sidemenu-container {
  border-right: none !important;
}

/* .hide is Bootstrap 3 — not recognized in BS5, so force-hide this theme toggle */
.sidebar-toggler-wrapper {
  display: none !important;
}

/* Sidebar menu items — dark purple sidebar */
.sidemenu .nav-item > .nav-link {
  display: flex !important;
  align-items: center !important;
  color: rgba(255,255,255,.7) !important;
  font-size: 0.85rem !important;
  font-weight: 500;
  border-radius: 10px;
  margin: 1px 10px;
  padding: 11px 14px;
  transition: background var(--transition-base), color var(--transition-base);
}

/* Title takes remaining space; arrow stays right-aligned, centered */
.sidemenu .nav-item > .nav-link .title {
  flex: 1;
  white-space: nowrap;
}
.sidemenu .nav-item > .nav-link .arrow {
  flex-shrink: 0;
  margin-left: auto;
  line-height: 1;
}

/* Log Out / Keluar — pinned at bottom with separator */
.sidemenu .sb-logout-item {
  margin-top: 8px;
  border-top: 1px solid rgba(255,255,255,.1);
  padding-top: 6px;
}
.sidemenu .sb-logout-item > .nav-link {
  color: rgba(255,255,255,.55) !important;
  display: block !important;
  text-align: left !important;
}
.sidemenu .sb-logout-item > .nav-link:hover {
  color: #fff !important;
  background: rgba(220,38,38,.2) !important;
}
.sidemenu .sb-logout-item > .nav-link .material-icons {
  color: rgba(255,255,255,.55) !important;
}
.sidemenu .sb-logout-item > .nav-link:hover .material-icons {
  color: rgba(255,255,255,.9) !important;
}

.sidemenu .nav-item > .nav-link:hover {
  color: #fff !important;
  background: rgba(255,255,255,.1) !important;
}

.sidemenu .nav-item.active > .nav-link,
.sidemenu .nav-item > .nav-link.active {
  color: #fff !important;
  background: #6f43cc !important;
  font-weight: 600;
}

/* Override theme white-sidebar-color: open state MUST stay dark */
.white-sidebar-color .sidemenu-container .sidemenu > li.open > aoke ,
.white-sidebar-color .sidemenu-container .sidemenu > li:hover > a,
.white-sidebar-color .sidemenu-closed.sidemenu-container-fixed .sidemenu-container:hover .sidemenu > li.open > a,
.white-sidebar-color .sidemenu-closed.sidemenu-container-fixed .sidemenu-container:hover .sidemenu > li:hover > a {
  background-color: rgba(255,255,255,.1) !important;
  color: #fff !important;
}

/* Open parent keeps a distinct tint — not white */
.sidemenu .nav-item.open > .nav-link {
  color: #fff !important;
  background: rgba(111,67,204,.35) !important;
}

/* ── Sub-menu accordion redesign ── */
.sidemenu .sub-menu {
  background: transparent !important;
  border: none !important;
  margin: 2px 10px 4px 14px !important;
  padding: 0 !important;
  border-left: 2px solid rgba(255,255,255,.15) !important;
  padding-left: 0 !important;
}

.sidemenu .sub-menu .nav-item > .nav-link {
  display: flex !important;
  align-items: center !important;
  gap: 8px;
  color: rgba(255,255,255,.5) !important;
  font-size: 0.78rem !important;
  font-weight: 400;
  padding: 7px 12px 7px 16px !important;
  margin: 1px 0 !important;
  border-radius: 8px;
  white-space: normal;
  transition: color .15s ease, background .15s ease;
}

/* Small dot before each sub-item */
.sidemenu .sub-menu .nav-item > .nav-link::before {
  content: '';
  display: inline-block;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: rgba(255,255,255,.3);
  flex-shrink: 0;
  transition: background .15s ease;
}

.sidemenu .sub-menu .nav-item > .nav-link:hover {
  color: #fff !important;
  background: rgba(255,255,255,.08) !important;
}
.sidemenu .sub-menu .nav-item > .nav-link:hover::before {
  background: rgba(255,255,255,.8);
}
.sidemenu .sub-menu .nav-item.active > .nav-link {
  color: #fff !important;
  background: rgba(111,67,204,.3) !important;
  font-weight: 500;
}
.sidemenu .sub-menu .nav-item.active > .nav-link::before {
  background: #fff;
}

/* Sidebar brand header */
.sidebar-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 18px 16px 14px;
  border-bottom: 1px solid #e8edf5;
  margin-bottom: 4px;
}
.sidebar-brand-icon {
  width: 34px;
  height: 34px;
  background: var(--primary-gradient);
  border-radius: 9px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.sidebar-brand-icon .material-icons {
  font-size: 18px !important;
  color: #fff !important;
  margin: 0 !important;
  opacity: 1 !important;
}
.sidebar-brand-text {
  font-size: .88rem;
  font-weight: 800;
  color: var(--neutral-dark);
  letter-spacing: -.02em;
  line-height: 1;
}
.sidebar-brand-text span {
  color: #94a3b8;
  font-weight: 400;
}

/* Sidebar icons (Material Icons) — dark sidebar */
.sidemenu .material-icons {
  font-size: 18px !important;
  vertical-align: middle;
  margin-right: 8px;
  opacity: 1;
  color: rgba(255,255,255,.6) !important;
}

.sidemenu .nav-item.active .material-icons,
.sidemenu .nav-item > .nav-link:hover .material-icons {
  color: rgba(255,255,255,.9) !important;
}

/* Sidebar arrow (sub-menu caret) — white on dark bg */
.sidemenu .nav-item > .nav-link .arrow:before,
.sidemenu .nav-item > .nav-link .arrow.open:before {
  color: rgba(255,255,255,.4) !important;
}
.sidemenu .nav-item > .nav-link:hover .arrow:before,
.sidemenu .nav-item.active > .nav-link .arrow:before,
.sidemenu .nav-item.open > .nav-link .arrow:before {
  color: rgba(255,255,255,.8) !important;
}

/* Prevent sub-menu hover from shifting padding too */
.sidemenu .sub-menu .nav-item > .nav-link:hover {
  padding-left: 20px !important;
}

/* User panel in sidebar — dark bg */
.sidebar-user-panel .user-panel {
  background: rgba(255,255,255,.05);
  border-bottom: 1px solid rgba(255,255,255,.08);
  padding: 16px;
}

.sidebar-user-panel .user-panel .info p {
  color: rgba(255,255,255,.9) !important;
  font-size: 0.8rem;
  font-weight: 600;
  margin-bottom: 2px;
}

.sidebar-user-panel .user-panel .info a {
  color: rgba(255,255,255,.5) !important;
  font-size: 0.75rem;
}

.sidebar-user-panel .user-panel .img-rectangle {
  width: 44px !important;
  height: 44px !important;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,.2);
  object-fit: cover;
}

/* =============================================
   5. BUTTONS
   ============================================= */
.btn {
  font-weight: 600;
  font-size: 0.85rem;
  border-radius: var(--radius-md);
  padding: 8px 20px;
  transition:
    transform var(--transition-fast),
    box-shadow var(--transition-fast),
    filter var(--transition-fast);
  letter-spacing: 0.01em;
  border: none;
}

.btn:active {
  transform: scale(0.97) !important;
}

/* Primary button */
.btn-primary,
.btn-get-started {
  background: var(--primary-gradient) !important;
  color: #fff !important;
  border: none !important;
  box-shadow: 0 3px 10px rgba(147, 51, 234, 0.35);
}

.btn-primary:hover,
.btn-get-started:hover {
  filter: brightness(1.1);
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(147, 51, 234, 0.40) !important;
  color: #fff !important;
}

.btn-primary:focus,
.btn-primary:focus-visible {
  outline: 3px solid rgba(147, 51, 234, 0.45);
  outline-offset: 2px;
  box-shadow: none !important;
}

/* Secondary / outline */
.btn-secondary {
  background: #e2e8f0 !important;
  color: var(--neutral-dark) !important;
  border: none !important;
}
.btn-secondary:hover {
  background: #cbd5e1 !important;
  transform: translateY(-1px);
}

.btn-outline-primary {
  border: 2px solid var(--primary-light) !important;
  color: var(--primary-light) !important;
  background: transparent !important;
}
.btn-outline-primary:hover {
  background: var(--primary-light) !important;
  color: #fff !important;
  transform: translateY(-1px);
}

/* Danger / success */
.btn-danger  { box-shadow: 0 2px 8px rgba(220, 38, 38, 0.28); }
.btn-success { box-shadow: 0 2px 8px rgba(22, 163, 74, 0.28); }
.btn-warning { box-shadow: 0 2px 8px rgba(234, 179, 8, 0.28); }

.btn-sm { padding: 5px 14px; font-size: 0.78rem; border-radius: var(--radius-sm); }
.btn-lg { padding: 12px 28px; font-size: 0.95rem; border-radius: var(--radius-lg); }

/* =============================================
   6. CARDS
   ============================================= */
.card,
.info-box {
  border: none !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-sm) !important;
  transition: box-shadow var(--transition-base), transform var(--transition-base);
  background: #fff;
  overflow: hidden;
}

.card:hover {
  box-shadow: var(--shadow-md) !important;
  transform: translateY(-2px);
}

.card-head,
.card-header {
  background: #fff !important;
  border-bottom: 1px solid #e8edf5 !important;
  padding: 14px 20px !important;
  font-weight: 600;
  color: var(--neutral-dark);
}

.card-head header {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--primary-dark);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.card-body {
  padding: 20px !important;
}

.card-footer {
  background: #f8fafc !important;
  border-top: 1px solid #e8edf5 !important;
  padding: 12px 20px !important;
}

/* Colored topline cards (existing theme) */
.card-topline-purple { border-top: 3px solid var(--primary-dark) !important; }
.card-topline-blue   { border-top: 3px solid var(--primary-light) !important; }
.card-topline-green  { border-top: 3px solid #16a34a !important; }
.card-topline-red    { border-top: 3px solid #dc2626 !important; }

/* Stat / info boxes */
.info-box {
  display: flex;
  align-items: center;
  padding: 16px 20px !important;
  border-radius: var(--radius-lg) !important;
}

.info-box .info-box-icon {
  font-size: 2.2rem;
  opacity: 0.85;
}

.info-box .info-box-number {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.1;
}

.info-box .info-box-text {
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  opacity: 0.85;
}

/* =============================================
   7. TABLES
   ============================================= */
.table,
table.dataTable {
  border-collapse: separate !important;
  border-spacing: 0 !important;
  font-size: 0.85rem;
  width: 100% !important;
}

.table thead th,
table.dataTable thead th {
  background: var(--primary-dark) !important;
  color: #fff !important;
  font-weight: 600;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border: none !important;
  padding: 12px 14px !important;
  white-space: nowrap;
}

.table thead tr:first-child th:first-child,
table.dataTable thead tr:first-child th:first-child {
  border-radius: var(--radius-sm) 0 0 0;
}

.table thead tr:first-child th:last-child,
table.dataTable thead tr:first-child th:last-child {
  border-radius: 0 var(--radius-sm) 0 0;
}

.table tbody tr {
  transition: background var(--transition-fast);
}

.table tbody tr:hover {
  background: rgba(147, 51, 234, 0.06) !important;
}

.table tbody td {
  border-bottom: 1px solid #edf2f7 !important;
  border-top: none !important;
  padding: 11px 14px !important;
  vertical-align: middle;
  color: var(--text-dark);
}

.table-striped tbody tr:nth-child(odd) {
  background: #f8fafc !important;
}

.table-striped tbody tr:nth-child(even) {
  background: #fff !important;
}

/* Fix: Bootstrap p-0 must override custom card-body padding */
.card-body.p-0 { padding: 0 !important; }

/* DataTables controls inside table cards */
.table-responsive .dataTables_length,
.table-responsive .dataTables_filter {
  padding: 10px 16px 8px;
}
.table-responsive .dataTables_info,
.table-responsive .dataTables_paginate {
  padding: 10px 20px 14px;
  background: #f8fafc;
  border-top: 1px solid #f1f5f9;
}

/* DataTables wrapper */
.dataTables_wrapper .dataTables_filter input {
  border: 1.5px solid #cbd5e1;
  border-radius: var(--radius-md);
  padding: 6px 12px;
  font-size: 0.85rem;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.dataTables_wrapper .dataTables_filter input:focus {
  border-color: var(--primary-light);
  box-shadow: 0 0 0 3px rgba(147, 51, 234, 0.18);
  outline: none;
}

.dataTables_wrapper .dataTables_length select {
  border: 1.5px solid #cbd5e1;
  border-radius: var(--radius-sm);
  padding: 4px 8px;
}

/* Text contrast in table cell content (headings/lists inside td) */
.table tbody td h1, .table tbody td h2, .table tbody td h3,
.table tbody td h4, .table tbody td h5, .table tbody td h6 {
  color: #1a202c !important;
  font-size: inherit;
  font-weight: 700;
  margin-bottom: 4px;
}
.table tbody td p,
.table tbody td li {
  color: #374151;
  line-height: 1.65;
  margin-bottom: 4px;
}

/* =============================================
   8. FORM ELEMENTS
   ============================================= */
.form-control,
.form-select,
.mdl-textfield__input,
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="tel"],
select,
textarea {
  border: 1.5px solid #cbd5e1 !important;
  border-radius: var(--radius-md) !important;
  padding: 9px 14px !important;
  font-size: 0.875rem !important;
  color: var(--text-dark) !important;
  background-color: #fff !important;
  transition:
    border-color var(--transition-fast),
    box-shadow var(--transition-fast) !important;
  box-shadow: none !important;
}

.form-control:focus,
.form-select:focus,
.mdl-textfield__input:focus,
input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="number"]:focus,
input[type="tel"]:focus,
select:focus,
textarea:focus {
  border-color: var(--primary-light) !important;
  box-shadow: 0 0 0 3px rgba(147, 51, 234, 0.18) !important;
  outline: none !important;
}

.form-control[readonly],
input[readonly] {
  background-color: #f1f5f9 !important;
  color: #64748b !important;
  cursor: not-allowed;
}

.form-label,
label {
  font-size: 0.82rem;
  font-weight: 600;
  color: #475569;
  margin-bottom: 5px;
  display: inline-block;
}

.form-group {
  margin-bottom: 16px;
}

.input-group .btn {
  border-radius: 0 var(--radius-md) var(--radius-md) 0 !important;
}

.input-group .form-control {
  border-radius: var(--radius-md) 0 0 var(--radius-md) !important;
}

/* Select2 */
.select2-container--default .select2-selection--single {
  border: 1.5px solid #cbd5e1 !important;
  border-radius: var(--radius-md) !important;
  height: 40px !important;
  display: flex !important;
  align-items: center !important;
}

.select2-container--default .select2-selection--single:focus,
.select2-container--default.select2-container--focus .select2-selection--single {
  border-color: var(--primary-light) !important;
  box-shadow: 0 0 0 3px rgba(147, 51, 234, 0.18) !important;
}

.select2-dropdown {
  border: 1.5px solid var(--primary-light) !important;
  border-radius: var(--radius-md) !important;
  box-shadow: var(--shadow-md) !important;
}

.select2-container--default .select2-results__option--highlighted[aria-selected] {
  background-color: var(--primary-light) !important;
}

/* =============================================
   9. ALERTS / BADGES / PILLS
   ============================================= */
.alert {
  border: none;
  border-radius: var(--radius-md);
  font-size: 0.875rem;
  font-weight: 500;
  padding: 12px 16px;
  box-shadow: var(--shadow-sm);
}

.alert-success { background: #dcfce7; color: #166534; border-left: 4px solid #16a34a; }
.alert-danger  { background: #fee2e2; color: #991b1b; border-left: 4px solid #dc2626; }
.alert-warning { background: #fef9c3; color: #854d0e; border-left: 4px solid #ca8a04; }
.alert-info    { background: #f3e8ff; color: #6317c3; border-left: 4px solid var(--primary-light); }

.badge {
  font-weight: 600;
  font-size: 0.72rem;
  border-radius: 20px;
  padding: 4px 10px;
  letter-spacing: 0.03em;
}

.badge.bg-primary { background: var(--primary-gradient) !important; }

/* =============================================
   10. PAGE CONTENT & LAYOUT
   ============================================= */

/* Override theme_style.css which sets .page-container { background: #222c3c } */
.page-container,
.tab-content,
.tab-pane {
  background-color: var(--neutral-light) !important;
}

/* Reset top spacing only — do NOT touch margin-left (responsive.css sets 235px for sidebar offset) */
.tab-content > .tab-pane > .row {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

.page-content-wrapper {
  background: var(--neutral-light) !important;
  min-height: 100vh;
  padding: 0 !important;
}

.page-content {
  background: var(--neutral-light) !important;
  min-height: 100vh;
  padding: 0 !important;
  margin-top: 0 !important;
  /* Keep margin-left: 235px from responsive.css — do NOT override with margin: 0 */
}

/* Hamburger / sidebar-toggler alignment */
.page-header .nav.navbar-left {
  padding-left: 18px;
}

.page-bar {
  background: #fff;
  border-radius: var(--radius-md);
  padding: 12px 20px;
  margin-bottom: 18px;
  box-shadow: var(--shadow-sm);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.page-title {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--primary-dark);
}

/* Breadcrumb */
.breadcrumb {
  background: transparent;
  padding: 0;
  margin: 0;
  font-size: 0.8rem;
}

.breadcrumb-item a {
  color: var(--primary-light);
  font-weight: 500;
}

.breadcrumb-item.active {
  color: #64748b;
  font-weight: 600;
}

.breadcrumb-item + .breadcrumb-item::before {
  color: #94a3b8;
}

/* =============================================
   11. FOOTER
   ============================================= */
.page-footer {
  background: var(--neutral-dark) !important;
  color: rgba(248, 250, 252, 0.7) !important;
  font-size: 0.8rem;
  padding: 12px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.page-footer a {
  color: var(--primary-light) !important;
}

/* Landing page footer */
#footer {
  background: var(--neutral-dark) !important;
  color: rgba(248, 250, 252, 0.7) !important;
}

#footer .copyright {
  font-size: 0.82rem;
}

/* =============================================
   12. SCROLL TO TOP & MISC UI
   ============================================= */
.back-to-top {
  background: var(--primary-gradient) !important;
  border-radius: 50%;
  width: 42px;
  height: 42px;
  box-shadow: var(--shadow-md);
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

.back-to-top:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-lg);
}

/* Scroll-to-top inside page-footer */
.scroll-to-top {
  background: var(--primary-light);
  border-radius: 50%;
  width: 34px;
  height: 34px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background var(--transition-fast);
}

.scroll-to-top:hover {
  background: var(--primary-dark);
}

/* =============================================
   13. LOGIN PAGE
   ============================================= */
.login-wrapper,
.login-container {
  min-height: 100vh;
  background: linear-gradient(135deg, #0f172a 0%, var(--primary-dark) 60%, #7c1fd1 100%);
  display: flex;
  align-items: center;
  justify-content: center;
}

.login-card {
  background: #fff;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
  padding: 36px 32px;
  width: 100%;
  max-width: 420px;
}

.login-card .login-title {
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--primary-dark);
  text-align: center;
  margin-bottom: 6px;
}

.login-card .login-subtitle {
  font-size: 0.82rem;
  color: #64748b;
  text-align: center;
  margin-bottom: 24px;
}

/* =============================================
   14. HERO SECTION (Landing Page)
   ============================================= */
#hero {
  background: var(--primary-gradient) !important;
  min-height: 420px;
  display: flex;
  align-items: center;
}

#hero h1 {
  color: #fff !important;
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: 800;
  line-height: 1.2;
}

#hero h1 span {
  color: rgba(255, 255, 255, 0.75) !important;
}

#hero h2 {
  color: rgba(255, 255, 255, 0.82) !important;
  font-size: clamp(0.9rem, 2vw, 1.1rem);
  font-weight: 400;
  margin-bottom: 24px;
}

/* =============================================
   21. SIDEBAR LOGO BLOCK (dark sidebar)
   ============================================= */
.sb-logo-item {
  padding: 20px 16px 16px;
  border-bottom: 1px solid rgba(255,255,255,.1);
  margin-bottom: 6px;
  list-style: none;
}
.sb-logo-inner {
  display: flex;
  align-items: center;
  gap: 12px;
}
.sb-logo-icon-box {
  width: 48px;
  height: 48px;
  background: rgba(255,255,255,.2);
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.sb-logo-icon-box .material-icons {
  font-size: 24px !important;
  color: #fff !important;
  margin: 0 !important;
  opacity: 1 !important;
}
.sb-logo-title {
  font-size: .82rem;
  font-weight: 800;
  color: #fff;
  letter-spacing: .06em;
  line-height: 1.2;
  text-transform: uppercase;
}
.sb-logo-tagline {
  font-size: .7rem;
  color: rgba(255,255,255,.45);
  font-weight: 400;
  margin-top: 3px;
}

/* ── Sidebar section labels (dark sidebar) ── */
.sidebar-section-label {
  font-size: .6rem !important;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: rgba(255,255,255,.3) !important;
  padding: 14px 20px 5px;
  line-height: 1;
  list-style: none;
}

/* =============================================
   15. RESPONSIVE UTILITIES
   ============================================= */
@media (max-width: 991.98px) {
  .sidemenu-container {
    width: var(--sidebar-width);
  }

  .card-body { padding: 16px !important; }

  .table thead th { font-size: 0.72rem; padding: 10px 10px !important; }
  .table tbody td { padding: 9px 10px !important; font-size: 0.82rem; }

  h1, .h1 { font-size: 1.5rem; }
  h2, .h2 { font-size: 1.25rem; }
}

@media (max-width: 767.98px) {
  .page-bar {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }

  .breadcrumb { font-size: 0.75rem; }

  .btn { padding: 7px 16px; }
  .btn-sm { padding: 4px 12px; }

  .info-box { flex-direction: column; text-align: center; gap: 8px; }
  .info-box .info-box-icon { font-size: 1.8rem; }

  .login-card { padding: 24px 20px; }

  #hero h1 { font-size: 1.6rem; }
}

@media (max-width: 575.98px) {
  .card-body { padding: 12px !important; }

  .table-responsive { font-size: 0.78rem; }

  .page-header .page-logo { padding: 0 12px; }
}

/* =============================================
   16. COLOR SCHEME — force light mode
   Design system ini fixed light theme.
   ============================================= */
/* (dark mode support dihapus — site menggunakan fixed light theme) */

/* =============================================
   18. DASHBOARD — see assets/css/dashboard.css
   ============================================= */

/* =============================================
   19. SIDEBAR USER PANEL — clean labels
   ============================================= */
.sb-user-name {
  font-size: .82rem;
  font-weight: 700;
  color: rgba(255,255,255,.9) !important;
  line-height: 1.25;
}
.sb-user-role {
  font-size: .72rem;
  color: rgba(255,255,255,.5) !important;
  margin-top: 2px;
}
.sb-user-status {
  display: flex;
  align-items: center;
  gap: 5px;
  margin-top: 6px;
  font-size: .7rem;
  color: rgba(255,255,255,.4) !important;
}
.sb-status-dot {
  display: inline-block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #4ade80;
  flex-shrink: 0;
}

/* =============================================
   20. LOWONGAN ACCORDION — truncate & expand
   ============================================= */
.lowongan-content {
  color: #2D3748;
  line-height: 1.65;
  font-size: .855rem;
}
/* Force ALL text inside lowongan content to dark neutral — covers inline styles */
.lowongan-content,
.lowongan-content * {
  color: #2D3748 !important;
}
/* Links remain colored */
.lowongan-content a,
.lowongan-content a * {
  color: var(--primary-dark) !important;
}
.lowongan-content.collapsed {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  max-height: 3.6em;
}
/* Headings inside lowongan content */
.lowongan-content h1, .lowongan-content h2, .lowongan-content h3,
.lowongan-content h4, .lowongan-content h5, .lowongan-content h6 {
  color: var(--primary-dark) !important;
  font-weight: 700;
  margin: 10px 0 4px;
}
.lowongan-content p,
.lowongan-content li {
  color: #2D3748 !important;
  line-height: 1.65;
  margin-bottom: 4px;
}

.expand-toggle {
  background: none;
  border: none;
  color: var(--primary-dark);
  font-size: .72rem;
  font-weight: 600;
  cursor: pointer;
  padding: 5px 0 0;
  display: flex;
  align-items: center;
  gap: 5px;
  transition: opacity var(--transition-fast);
}
.expand-toggle:hover { opacity: .72; }

/* Expanded row — subtle accordion bg */
.table tbody tr.row-expanded > td {
  background: #f8fafc !important;
}

/* =============================================
   17. UTILITY OVERRIDES
   ============================================= */

/* Smooth page transitions */
.page-content-wrapper { animation: fadeIn 0.2s ease; }

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Progress bars */
.progress {
  height: 6px;
  border-radius: 99px;
  background: rgba(255,255,255,0.25);
  overflow: hidden;
}

.progress-bar {
  background: rgba(255,255,255,0.75);
  border-radius: 99px;
}

/* Avatar / profile photo */
.user-img-rectangle,
.img-rectangle {
  border-radius: var(--radius-md) !important;
  object-fit: cover;
}

/* Divider */
hr {
  border-color: #e2e8f0;
  opacity: 1;
  margin: 16px 0;
}

/* Focus-visible global */
*:focus-visible {
  outline: 2px solid var(--primary-light);
  outline-offset: 2px;
}

/* ── Flash Alert — toast notification ── */
.md-flash-alert {
  position: fixed;
  top: 80px;
  right: 24px;
  z-index: 9999;
  min-width: 300px;
  max-width: 440px;
  background: #fff !important;
  border: none !important;
  border-radius: 14px !important;
  padding: 16px 18px !important;
  box-shadow: 0 8px 28px rgba(0,0,0,.14) !important;
  display: flex !important;
  align-items: center;
  gap: 12px;
  animation: mdFlashIn .3s cubic-bezier(.21,1.02,.73,1) both;
}

@keyframes mdFlashIn {
  from { opacity: 0; transform: translateY(-16px) scale(.96); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

.md-flash-alert.alert-success { border-left: 4px solid #16a34a !important; }
.md-flash-alert.alert-danger  { border-left: 4px solid #dc2626 !important; }
.md-flash-alert.alert-warning { border-left: 4px solid #d97706 !important; }

.md-flash-icon-success,
.md-flash-icon-danger,
.md-flash-icon-warning {
  font-size: 22px !important;
  flex-shrink: 0;
  margin: 0 !important;
}

.md-flash-alert.alert-success .md-flash-icon-success { color: #16a34a !important; display: block; }
.md-flash-alert.alert-success .md-flash-icon-danger  { display: none; }
.md-flash-alert.alert-success .md-flash-icon-warning { display: none; }

.md-flash-alert.alert-danger  .md-flash-icon-danger  { color: #dc2626 !important; display: block; }
.md-flash-alert.alert-danger  .md-flash-icon-success { display: none; }
.md-flash-alert.alert-danger  .md-flash-icon-warning { display: none; }

.md-flash-alert.alert-warning .md-flash-icon-warning { color: #d97706 !important; display: block; }
.md-flash-alert.alert-warning .md-flash-icon-success { display: none; }
.md-flash-alert.alert-warning .md-flash-icon-danger  { display: none; }

.md-flash-msg {
  flex: 1;
  font-size: .84rem;
  color: #1e2937;
  line-height: 1.55;
}

.md-flash-close {
  background: none;
  border: none;
  cursor: pointer;
  color: #94a3b8;
  padding: 4px;
  display: flex;
  align-items: center;
  border-radius: 6px;
  flex-shrink: 0;
  transition: color .15s, background .15s;
  align-self: flex-start;
}

.md-flash-close:hover { color: #374151; background: #f1f5f9; }

.md-flash-close .material-icons {
  font-size: 16px !important;
  margin: 0 !important;
}

@media (max-width: 575.98px) {
  .md-flash-alert {
    right: 12px;
    left: 12px;
    min-width: unset;
    max-width: unset;
    top: 70px;
  }
}
