/* ============================================================================
   APP.CPANEL.GRATIS — SHOPEE-STYLE ADMIN THEME
   Mirrors bookstore frontend AdminLayout: white sidebar + orange accents,
   orange gradient logo/buttons, soft amber active states with glow,
   top bar w/ backdrop blur, rounded-xl cards. Colors 100% match.
   ============================================================================ */

:root {
  /* Shopee palette */
  --sp-orange:      #ee4d2d;
  --sp-orange-dark: #d73211;
  --sp-orange-light:#fff0ed;

  /* Tailwind orange/amber scale used by AdminLayout */
  --o-50:  #fff7ed;
  --o-100: #ffedd5;
  --o-200: #fed7aa;
  --o-300: #fdba74;
  --o-400: #fb923c;
  --o-500: #f97316;
  --o-600: #ea580c;
  --o-700: #c2410c;
  --amber-50: #fffbeb;
  --amber-400:#fbbf24;

  --sp-grad:        linear-gradient(135deg, #fb923c 0%, #f97316 50%, #ea580c 100%);
  --sp-grad-soft:   linear-gradient(to right, #fff7ed 0%, #fffbeb 100%);
  --sp-grad-strip:  linear-gradient(to right, #fb923c, #f97316, #fbbf24);

  --gray-50:  #f9fafb;
  --gray-100: #f3f4f6;
  --gray-200: #e5e7eb;
  --gray-300: #d1d5db;
  --gray-400: #9ca3af;
  --gray-500: #6b7280;
  --gray-600: #4b5563;
  --gray-700: #374151;
  --gray-800: #1f2937;

  --bg:           #f9fafb;
  --surface:      #ffffff;
  --border:       #f3f4f6;
  --border-2:     #e5e7eb;
  --border-orange:#ffedd5;
  --text:         #374151;
  --text-dim:     #6b7280;
  --text-soft:    #9ca3af;

  --shadow-sm:    0 1px 2px rgba(0,0,0,.04);
  --shadow:       0 1px 3px rgba(0,0,0,.05), 0 1px 2px rgba(0,0,0,.03);
  --shadow-lg:    0 4px 12px rgba(0,0,0,.06), 0 16px 32px rgba(0,0,0,.08);
  --shadow-orange:0 0 16px rgba(249,115,22,.12), 0 0 4px rgba(249,115,22,.08);

  --radius:    12px;
  --radius-sm: 8px;
  --radius-lg: 16px;
  --radius-xl: 20px;
}

/* BASE */
html, body, body.app, body.dark-theme, body.light-theme, body.dark-mode {
  background: var(--bg) !important;
  color: var(--text) !important;
  font-family: 'Segoe UI', system-ui, -apple-system, BlinkMacSystemFont, 'Inter', sans-serif !important;
  font-size: 13.5px !important;
  line-height: 1.5 !important;
  -webkit-font-smoothing: antialiased;
}

/* ============================================================================
   SIDEBAR — WHITE BG with orange accent strip on top
   ============================================================================ */
.app-sidebar, .app-sidebar.ps {
  background: var(--surface) !important;
  border-right: 1px solid var(--border-orange) !important;
  box-shadow: none !important;
  width: 250px !important;
  position: relative !important;
}
.app-sidebar::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--sp-grad-strip);
  z-index: 1;
}

/* Logo area */
.app-sidebar__logo {
  background: var(--surface) !important;
  border-bottom: 0 !important;
  padding: 14px 20px !important;
  height: 72px !important;
  display: flex !important; align-items: center !important;
  position: relative !important; z-index: 2 !important;
}
.app-sidebar__logo .header-brand-img {
  max-height: 38px !important;
  filter: none !important;
  border-radius: 10px !important;
  box-shadow: 0 6px 16px rgba(249,115,22,.20) !important;
}
.app-sidebar__logo a, .app-sidebar__logo .header-brand {
  display: flex !important; align-items: center !important; gap: 12px !important;
  color: var(--gray-800) !important;
  font-weight: 800 !important; letter-spacing: .14em !important;
  font-size: 13px !important; text-transform: uppercase !important;
}

/* Divider after logo */
.app-sidebar > hr:first-of-type {
  margin: 0 16px !important;
  border-color: transparent !important;
  background: linear-gradient(to right, transparent, rgba(254,215,170,.6), transparent);
  height: 1px;
}

/* Menu */
.side-menu { padding: 12px !important; }

.side-menu .side-menu__item {
  color: var(--gray-500) !important;
  padding: 10px 12px !important;
  border-radius: var(--radius) !important;
  border: 0 !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  margin-bottom: 2px !important;
  transition: all .2s cubic-bezier(0.4, 0, 0.2, 1) !important;
  display: flex !important; align-items: center !important; gap: 12px !important;
}
.side-menu .side-menu__item:hover {
  background: rgba(255,247,237,.6) !important;
  color: var(--gray-700) !important;
  border: 0 !important;
}
.side-menu .side-menu__item.active,
.side-menu .slide.is-expanded > .side-menu__item {
  background: linear-gradient(to right, var(--o-50), rgba(255,251,235,.8)) !important;
  color: var(--o-600) !important;
  font-weight: 600 !important;
  box-shadow: var(--shadow-orange) !important;
}
.side-menu .side-menu__icon {
  color: var(--gray-400) !important;
  font-size: 16px !important;
  margin-right: 0 !important;
  width: 18px !important; height: 18px !important;
  text-align: center !important;
  flex-shrink: 0 !important;
}
.side-menu .side-menu__item:hover .side-menu__icon { color: var(--o-400) !important; }
.side-menu .side-menu__item.active .side-menu__icon { color: var(--o-500) !important; }

/* Section label - orange uppercase tracking */
.side-item.side-item-category {
  color: rgba(251,146,60,.7) !important;
  font-size: 10px !important;
  letter-spacing: .15em !important;
  text-transform: uppercase !important;
  padding: 18px 14px 8px !important;
  font-weight: 600 !important;
  background: transparent !important;
}

.app-sidebar hr {
  border-color: var(--o-100) !important;
  margin: 8px 16px !important;
  opacity: .6 !important;
}

/* Sub menu */
.slide-menu {
  background: transparent !important;
  margin-left: 18px !important;
  padding-left: 16px !important;
  border-left: 1px solid rgba(254,215,170,.6) !important;
  margin-top: 4px !important;
  margin-bottom: 4px !important;
}
.slide-menu li a {
  color: var(--gray-400) !important;
  padding: 8px 12px !important;
  font-size: 12.5px !important;
  border-radius: 8px !important;
  font-weight: 500 !important;
  display: block !important;
  transition: all .2s !important;
  position: relative !important;
}
.slide-menu li a:hover {
  color: var(--gray-600) !important;
  background: rgba(255,247,237,.4) !important;
}
.slide-menu li.active a {
  color: var(--o-600) !important;
  background: linear-gradient(to right, var(--o-50), rgba(255,251,235,.6)) !important;
  font-weight: 600 !important;
}
.slide-menu li.active a::before {
  content: ""; position: absolute;
  left: -17px; top: 50%; transform: translateY(-50%);
  width: 3px; height: 16px;
  background: linear-gradient(to bottom, var(--o-400), var(--amber-400));
  border-radius: 999px;
}

/* ============================================================================
   TOP HEADER — backdrop blur 80% white, 64px
   ============================================================================ */
.app-header, .header, .main-header {
  background: rgba(255,255,255,.8) !important;
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
  border-bottom: 1px solid rgba(229,231,235,.6) !important;
  box-shadow: none !important;
  height: 64px !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 20 !important;
}
.app-header .nav-link, .header .nav-link {
  color: var(--gray-600) !important;
  font-size: 13.5px !important;
  border-radius: var(--radius) !important;
  padding: 8px 12px !important;
  transition: all .2s !important;
}
.app-header .nav-link:hover { color: var(--o-600) !important; background: var(--o-50) !important; }

.app-content, .app, .page, .page-main { background: var(--bg) !important; }
.main-content { margin-left: 250px !important; padding-top: 64px !important; }
.side-app { padding: 24px 28px !important; max-width: 100% !important; }

@media (max-width: 991px) {
  .app-sidebar { transform: translateX(-100%); transition: transform .3s; z-index: 50; }
  .app.sidenav-toggled .app-sidebar { transform: translateX(0); }
  .main-content { margin-left: 0 !important; }
}

/* ============================================================================
   PAGE HEADER
   ============================================================================ */
.page-header, .page-title-box {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  padding: 0 0 18px !important;
  margin: 0 0 18px !important;
  box-shadow: none !important;
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
}
.page-header::before, .page-title-box::before { display: none !important; }
.page-header h1, .page-header h2, .page-header h3, .page-header .page-title {
  font-size: 19px !important;
  font-weight: 700 !important;
  color: var(--gray-800) !important;
  margin: 0 !important;
  line-height: 1.2 !important;
}
.breadcrumb {
  background: transparent !important;
  padding: 0 !important;
  font-size: 12.5px !important;
  margin-left: auto !important;
  margin-bottom: 0 !important;
}
.breadcrumb-item a { color: var(--o-600) !important; text-decoration: none; font-weight: 500 !important; }
.breadcrumb-item.active { color: var(--gray-400) !important; }
.breadcrumb-item + .breadcrumb-item::before { color: var(--gray-300) !important; }

/* ============================================================================
   CARDS — white rounded-xl with soft shadow
   ============================================================================ */
.card, .panel {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow) !important;
  margin-bottom: 20px !important;
}
.card-header, .panel-heading {
  background: var(--surface) !important;
  border-bottom: 1px solid var(--border) !important;
  border-radius: var(--radius-lg) var(--radius-lg) 0 0 !important;
  padding: 16px 20px !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  color: var(--gray-800) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  min-height: 52px !important;
}
.card-header h1, .card-header h2, .card-header h3, .card-header h4, .card-header h5,
.card-header .card-title {
  font-size: 14px !important; font-weight: 600 !important;
  margin: 0 !important; color: var(--gray-800) !important;
}
.card-body, .panel-body {
  padding: 20px !important;
  font-size: 13.5px !important;
  color: var(--text) !important;
}
.card-footer {
  background: var(--gray-50) !important;
  border-top: 1px solid var(--border) !important;
  padding: 12px 20px !important;
  font-size: 13px !important;
  border-radius: 0 0 var(--radius-lg) var(--radius-lg) !important;
}

/* ============================================================================
   STAT WIDGETS — gradient orange icon + bold number
   ============================================================================ */
.stat-card, .info-box, .small-box, .widget-stat {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow) !important;
  padding: 20px !important;
}
.stat-card .icon, .info-box .icon, .small-box .icon,
.widget-stat .icon, .stat-icon {
  width: 48px !important; height: 48px !important;
  border-radius: var(--radius) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 20px !important;
  background: var(--sp-grad) !important;
  color: #fff !important;
  box-shadow: 0 6px 14px rgba(249,115,22,.25) !important;
  flex-shrink: 0 !important;
}
.stat-card .stat-value, .info-box .info-box-number, .small-box h3,
.widget-stat .number, .stat-number {
  font-size: 26px !important;
  font-weight: 700 !important;
  color: var(--gray-800) !important;
  line-height: 1.1 !important;
  margin: 4px 0 !important;
}
.stat-card .stat-label, .info-box .info-box-text, .small-box p,
.widget-stat .label, .stat-label {
  font-size: 12px !important;
  color: var(--gray-400) !important;
  font-weight: 500 !important;
  text-transform: none !important;
}

/* ============================================================================
   BUTTONS — gradient orange primary
   ============================================================================ */
.btn {
  border-radius: var(--radius) !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  padding: 9px 18px !important;
  transition: all .2s ease !important;
  border: 1px solid transparent !important;
  box-shadow: none !important;
  letter-spacing: .01em !important;
}
.btn-sm { padding: 6px 13px !important; font-size: 12px !important; }
.btn-lg { padding: 12px 24px !important; font-size: 14.5px !important; }

.btn-primary, .btn-success {
  background: var(--sp-grad) !important;
  border: 0 !important;
  color: #fff !important;
  box-shadow: 0 4px 12px rgba(249,115,22,.25) !important;
}
.btn-primary:hover, .btn-success:hover {
  filter: brightness(1.05);
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(249,115,22,.35) !important;
  color: #fff !important;
}
.btn-info {
  background: linear-gradient(135deg, #38bdf8, #0ea5e9) !important;
  border: 0 !important; color: #fff !important;
  box-shadow: 0 4px 12px rgba(14,165,233,.25) !important;
}
.btn-info:hover { filter: brightness(1.05); transform: translateY(-1px); color:#fff !important; }
.btn-secondary, .btn-default, .btn-light {
  background: var(--gray-100) !important;
  color: var(--gray-700) !important;
  border: 1px solid var(--gray-200) !important;
}
.btn-secondary:hover, .btn-default:hover, .btn-light:hover {
  background: var(--o-50) !important;
  color: var(--o-700) !important;
  border-color: var(--o-200) !important;
}
.btn-danger {
  background: linear-gradient(135deg, #f87171, #ef4444) !important;
  border: 0 !important; color: #fff !important;
  box-shadow: 0 4px 12px rgba(239,68,68,.25) !important;
}
.btn-warning {
  background: linear-gradient(135deg, #fbbf24, #f59e0b) !important;
  border: 0 !important; color: #fff !important;
  box-shadow: 0 4px 12px rgba(245,158,11,.25) !important;
}
.btn-dark { background: var(--gray-800) !important; border:0 !important; color:#fff !important; }
.btn-outline-primary, .btn-outline-success {
  background: transparent !important;
  color: var(--o-600) !important;
  border: 1.5px solid var(--o-500) !important;
}
.btn-outline-primary:hover, .btn-outline-success:hover {
  background: var(--o-50) !important;
  color: var(--o-700) !important;
}
.btn-icon {
  width: 36px !important; height: 36px !important;
  padding: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* ============================================================================
   FORMS
   ============================================================================ */
.form-control, .form-select,
input.form-control, select.form-control, textarea.form-control {
  background: var(--gray-100) !important;
  border: 1px solid transparent !important;
  border-radius: var(--radius) !important;
  font-size: 13.5px !important;
  padding: 9px 13px !important;
  color: var(--text) !important;
  height: auto !important;
  box-shadow: none !important;
  transition: all .25s !important;
}
.form-control:focus, .form-select:focus {
  background: var(--surface) !important;
  border-color: rgba(253,186,116,.5) !important;
  box-shadow: 0 0 0 3px rgba(249,115,22,.10) !important;
  outline: 0 !important;
}
.form-label, label {
  font-weight: 600 !important;
  font-size: 12.5px !important;
  color: var(--gray-700) !important;
  margin-bottom: 6px !important;
}
.input-group-text {
  background: var(--gray-100) !important;
  border: 1px solid var(--gray-200) !important;
  color: var(--gray-500) !important;
  font-size: 13px !important;
}
.select2-container--default .select2-selection--single,
.select2-container--default .select2-selection--multiple {
  background: var(--gray-100) !important;
  border: 1px solid transparent !important;
  border-radius: var(--radius) !important;
  min-height: 40px !important;
}
.select2-container--default .select2-selection--single .select2-selection__rendered {
  line-height: 38px !important;
  padding-left: 13px !important;
  color: var(--text) !important;
}
.select2-container--default.select2-container--focus .select2-selection,
.select2-container--default.select2-container--open .select2-selection {
  background: var(--surface) !important;
  border-color: rgba(253,186,116,.5) !important;
  box-shadow: 0 0 0 3px rgba(249,115,22,.10) !important;
}
.select2-results__option--highlighted[aria-selected] {
  background: var(--o-500) !important;
  color: #fff !important;
}

/* ============================================================================
   TABLES
   ============================================================================ */
.table {
  background: var(--surface) !important;
  font-size: 13px !important;
  margin-bottom: 0 !important;
  color: var(--text) !important;
}
.table thead th, .table > thead > tr > th {
  background: var(--gray-50) !important;
  color: var(--gray-500) !important;
  font-weight: 600 !important;
  border-bottom: 1px solid var(--border-2) !important;
  border-top: 0 !important;
  text-transform: uppercase !important;
  font-size: 11px !important;
  letter-spacing: .07em !important;
  padding: 12px 16px !important;
}
.table tbody td, .table > tbody > tr > td {
  padding: 13px 16px !important;
  border-top: 1px solid var(--border) !important;
  vertical-align: middle !important;
  color: var(--text) !important;
}
.table tbody tr:hover td { background: var(--o-50) !important; }
.table-striped tbody tr:nth-of-type(odd) > * { background: var(--gray-50) !important; }
.dataTables_wrapper .dataTables_paginate .paginate_button {
  border-radius: var(--radius-sm) !important;
  padding: 6px 12px !important;
  margin: 0 2px !important;
  border: 1px solid var(--border-2) !important;
  color: var(--text) !important;
  font-size: 12.5px !important;
}
.dataTables_wrapper .dataTables_paginate .paginate_button.current {
  background: var(--sp-grad) !important;
  color: #fff !important;
  border: 0 !important;
}
.dataTables_wrapper .dataTables_filter input,
.dataTables_wrapper .dataTables_length select {
  background: var(--gray-100) !important;
  border: 1px solid transparent !important;
  border-radius: var(--radius-sm) !important;
  padding: 7px 12px !important;
  font-size: 13px !important;
}

/* ============================================================================
   BADGES
   ============================================================================ */
.badge, .tag, .label {
  font-size: 10.5px !important;
  font-weight: 700 !important;
  padding: 4px 10px !important;
  border-radius: 999px !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
}
.badge-primary, .badge-success, .badge.bg-primary, .badge.bg-success,
.tag-success, .label-success {
  background: var(--o-500) !important; color: #fff !important;
}
.badge-info, .badge.bg-info { background: #0ea5e9 !important; color:#fff !important; }
.badge-warning, .badge.bg-warning { background: #f59e0b !important; color:#fff !important; }
.badge-danger, .badge.bg-danger { background: #ef4444 !important; color:#fff !important; }
.badge-secondary, .badge.bg-secondary { background: var(--gray-200) !important; color: var(--gray-700) !important; }

/* ============================================================================
   ALERTS
   ============================================================================ */
.alert {
  border: 0 !important;
  border-radius: var(--radius) !important;
  border-left: 3px solid !important;
  padding: 12px 16px !important;
  font-size: 13.5px !important;
}
.alert-success { background: var(--o-50) !important; color: var(--o-700) !important; border-left-color: var(--o-500) !important; }
.alert-info    { background: #f0f9ff !important; color: #075985 !important; border-left-color: #0ea5e9 !important; }
.alert-warning { background: var(--amber-50) !important; color: #92400e !important; border-left-color: #f59e0b !important; }
.alert-danger  { background: #fef2f2 !important; color: #991b1b !important; border-left-color: #ef4444 !important; }

/* ============================================================================
   MODALS
   ============================================================================ */
.modal-content {
  border: 0 !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-lg) !important;
  overflow: hidden !important;
}
.modal-header {
  background: var(--surface) !important;
  color: var(--gray-800) !important;
  border-bottom: 1px solid var(--border) !important;
  padding: 16px 20px !important;
}
.modal-header .modal-title {
  font-weight: 700 !important;
  font-size: 15px !important;
  color: var(--gray-800) !important;
}
.modal-header .btn-close, .modal-header .close {
  filter: none !important; opacity: .55 !important;
}
.modal-body { padding: 20px !important; font-size: 13.5px !important; }
.modal-footer {
  background: var(--gray-50) !important;
  border-top: 1px solid var(--border) !important;
  padding: 12px 20px !important;
}

/* ============================================================================
   COLORED CARD VARIANTS
   ============================================================================ */
.card.bg-primary, .card.bg-success {
  background: var(--sp-grad) !important; color:#fff !important; border:0 !important;
}
.card.bg-info { background: linear-gradient(135deg,#38bdf8,#0ea5e9) !important; color:#fff !important; border:0 !important; }
.card.bg-primary *, .card.bg-success *, .card.bg-info * { color: #fff !important; }
.card.bg-warning { background: linear-gradient(135deg,#fbbf24,#f59e0b) !important; color:#fff !important; }
.card.bg-warning * { color:#fff !important; }
.card.bg-danger  { background: linear-gradient(135deg,#f87171,#ef4444) !important; color:#fff !important; }
.card.bg-danger  * { color:#fff !important; }

/* ============================================================================
   LINKS / DROPDOWN / TABS
   ============================================================================ */
a { color: var(--o-600); text-decoration: none; }
a:hover { color: var(--o-700); }

.dropdown-menu {
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-lg) !important;
  padding: 6px !important;
  font-size: 13px !important;
}
.dropdown-item {
  border-radius: var(--radius-sm) !important;
  padding: 9px 12px !important;
  color: var(--gray-600) !important;
  font-weight: 500 !important;
}
.dropdown-item:hover {
  background: var(--gray-50) !important;
  color: var(--o-600) !important;
}
.dropdown-divider { border-color: var(--border) !important; }

.nav-tabs { border-bottom: 1px solid var(--border-2) !important; }
.nav-tabs .nav-link {
  border: 0 !important;
  border-bottom: 2px solid transparent !important;
  margin-bottom: -1px !important;
  color: var(--gray-400) !important;
  font-weight: 600 !important;
  padding: 11px 16px !important;
  font-size: 13px !important;
  border-radius: 0 !important;
}
.nav-tabs .nav-link:hover {
  color: var(--o-600) !important;
  border-bottom-color: var(--o-200) !important;
}
.nav-tabs .nav-link.active {
  color: var(--o-600) !important;
  background: transparent !important;
  border-bottom-color: var(--o-500) !important;
}
.nav-pills .nav-link {
  border-radius: var(--radius) !important;
  padding: 8px 16px !important;
  font-size: 12.5px !important;
  font-weight: 600 !important;
  color: var(--gray-500) !important;
  background: transparent !important;
  margin-right: 4px !important;
}
.nav-pills .nav-link.active {
  background: var(--sp-grad) !important;
  color: #fff !important;
  box-shadow: 0 4px 12px rgba(249,115,22,.25) !important;
}

/* ============================================================================
   TYPOGRAPHY
   ============================================================================ */
h1 { font-size: 21px !important; font-weight: 700 !important; color: var(--gray-800) !important; }
h2 { font-size: 18px !important; font-weight: 700 !important; color: var(--gray-800) !important; }
h3 { font-size: 16px !important; font-weight: 700 !important; color: var(--gray-800) !important; }
h4 { font-size: 14.5px !important; font-weight: 600 !important; color: var(--gray-800) !important; }
h5 { font-size: 13.5px !important; font-weight: 600 !important; color: var(--gray-800) !important; }
h6 { font-size: 12.5px !important; font-weight: 600 !important; color: var(--gray-800) !important; }

.text-muted { color: var(--gray-400) !important; }
.text-primary, .text-success { color: var(--o-600) !important; }
.text-info { color: #0ea5e9 !important; }
.bg-light, .bg-white { background: var(--surface) !important; }

/* ============================================================================
   SCROLLBAR
   ============================================================================ */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(249,115,22,.15); border-radius: 999px; }
::-webkit-scrollbar-thumb:hover { background: rgba(249,115,22,.30); }

/* ============================================================================
   WHATSAPP FLOAT — orange gradient
   ============================================================================ */
.floating {
  width: 52px !important; height: 52px !important;
  bottom: 22px !important; right: 22px !important;
  background: var(--sp-grad) !important;
  box-shadow: 0 8px 24px rgba(249,115,22,.40) !important;
  font-size: 22px !important;
}
.fab-icon { margin-top: 14px !important; }

/* ============================================================================
   AUTH / LOGIN
   ============================================================================ */
.auth-bg, .login-page, body.login-page {
  background: var(--sp-grad) !important;
  min-height: 100vh !important;
}
.auth-bg .card, .login-page .card {
  border-radius: var(--radius-xl) !important;
  border: 0 !important;
  box-shadow: 0 24px 64px rgba(0,0,0,.18) !important;
}

/* ============================================================================
   MISC
   ============================================================================ */
hr { border-color: var(--border) !important; opacity: 1 !important; }
code, pre {
  background: var(--o-50) !important;
  color: var(--o-700) !important;
  border-radius: 6px !important;
  padding: 2px 6px !important;
  font-size: 12.5px !important;
}
.app-footer, footer.footer {
  background: var(--surface) !important;
  border-top: 1px solid var(--border) !important;
  color: var(--gray-400) !important;
  font-size: 12.5px !important;
  padding: 14px 22px !important;
  margin-left: 250px !important;
}
@media (max-width: 991px) { .app-footer, footer.footer { margin-left: 0 !important; } }

.tippy-box[data-theme~="material"] {
  background: var(--gray-800) !important;
  color: #fff !important;
  border-radius: var(--radius-sm) !important;
  font-size: 12.5px !important;
}

.pagination .page-link {
  color: var(--gray-700) !important;
  border: 1px solid var(--border-2) !important;
  margin: 0 2px;
  border-radius: var(--radius-sm) !important;
  font-size: 13px !important;
  padding: 7px 12px !important;
}
.pagination .page-item.active .page-link {
  background: var(--sp-grad) !important;
  border: 0 !important;
  color: #fff !important;
}
.pagination .page-link:hover {
  background: var(--o-50) !important;
  color: var(--o-700) !important;
}

.progress {
  height: 6px !important;
  background: var(--gray-100) !important;
  border-radius: 999px !important;
  overflow: hidden !important;
}
.progress-bar { background: var(--sp-grad) !important; border-radius: 999px !important; }
.turbo-progress-bar { background: var(--sp-grad) !important; height: 3px !important; }

.list-group-item {
  border-color: var(--border) !important;
  padding: 12px 16px !important;
  font-size: 13.5px !important;
}
.list-group-item.active {
  background: var(--sp-grad) !important;
  border: 0 !important;
  color: #fff !important;
}

.form-check-input:checked {
  background-color: var(--o-500) !important;
  border-color: var(--o-500) !important;
}
.form-check-input:focus {
  border-color: var(--o-300) !important;
  box-shadow: 0 0 0 3px rgba(249,115,22,.15) !important;
}
