/* InT-Labels Theme - Medium Grey and Dark Yellow with Orange Glows */
:root {
    --primary-grey: #6c757d;
    --dark-grey: #495057;
    --primary-yellow: #ffc107;
    --dark-yellow: #d4930a;
    --medium-dark-yellow: #b8860b; /* New color for InT-Labels brand */
    --orange-glow: #ff8c00;
    --orange-light: #ffa500;
    --text-dark: #212529;
    --text-light: #ffffff;
    --background-light: #f8f9fa;
    --background-white: #ffffff;
    --border-light: #e9ecef;
    --success: #28a745;
    --danger: #dc3545;
    --warning: #ffc107;
    --info: #17a2b8;
    --font-weight-normal: 400;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
}

body {
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    color: var(--text-dark);
    background-color: var(--background-light);
    font-weight: var(--font-weight-normal);
}

/* Brand Color for InT-Labels */
.brand-color, .int-labels-brand {
    color: var(--medium-dark-yellow) !important;
}

/* Sidebar Styling */
.sidebar, .sidebar-col {
    background: linear-gradient(135deg, var(--primary-grey) 0%, var(--dark-grey) 100%);
    min-height: 100vh;
    color: var(--text-light);
    box-shadow: 4px 0 15px rgba(255, 165, 0, 0.2);
}

.sidebar .nav-link, .sidebar-col .nav-link {
    color: rgba(255, 255, 255, 0.8);
    padding: 12px 20px;
    border-radius: 8px;
    margin: 2px 0;
    transition: all 0.3s ease;
    font-weight: var(--font-weight-normal);
}

.sidebar .nav-link:hover,
.sidebar .nav-link.active,
.sidebar-col .nav-link:hover,
.sidebar-col .nav-link.active {
    color: var(--text-light);
    background: linear-gradient(135deg, var(--dark-yellow) 0%, var(--orange-glow) 100%);
    box-shadow: 0 4px 15px rgba(255, 140, 0, 0.3);
}

/* Dark mode adjustments for .sidebar-col too */
html[data-theme="dark"] .sidebar, html[data-theme="dark"] .sidebar-col { background-color: #111827; color: var(--text-light); border-right: 1px solid var(--border-color); }
html[data-theme="dark"] .sidebar .nav-link, html[data-theme="dark"] .sidebar-col .nav-link { color: #cbd5e1; }
html[data-theme="dark"] .sidebar .nav-link.active, html[data-theme="dark"] .sidebar .nav-link:hover,
html[data-theme="dark"] .sidebar-col .nav-link.active, html[data-theme="dark"] .sidebar-col .nav-link:hover { color: #fff; background-color: rgba(255,255,255,0.06); }

/* System preference dark applies same to .sidebar-col via existing selectors */

/* Mobile layout helpers ensuring content is accessible when sidebar slides in */
@media (max-width: 991.98px) {
  body.sidebar-open { overflow: hidden; }
}

/* Card Styling */
.card {
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.08), 0 0 20px rgba(255, 165, 0, 0.1);
    border: 2px solid rgba(255, 165, 0, 0.1);
    border-radius: 15px;
}

.card-header {
    background: linear-gradient(135deg, var(--primary-grey) 0%, var(--dark-grey) 100%);
    color: var(--text-light);
    border-bottom: 2px solid rgba(255, 165, 0, 0.3);
    border-radius: 15px 15px 0 0 !important;
    font-weight: var(--font-weight-semibold);
}

/* Button Styling */
.btn-primary {
    background: linear-gradient(135deg, var(--primary-yellow), var(--dark-yellow));
    border: none;
    color: var(--text-dark);
    font-weight: var(--font-weight-semibold);
    transition: all 0.3s ease;
    box-shadow: 0 4px 15px rgba(255, 193, 7, 0.3);
    border-radius: 8px;
}

.btn-primary:hover {
    background: linear-gradient(135deg, var(--dark-yellow), var(--orange-glow));
    color: var(--text-light);
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(255, 193, 7, 0.4);
}

.btn-primary:focus {
    background: linear-gradient(135deg, var(--dark-yellow), var(--orange-glow));
    color: var(--text-light);
    box-shadow: 0 0 0 0.2rem rgba(255, 193, 7, 0.5);
}

.btn-outline-primary {
    border-color: var(--dark-yellow);
    color: var(--dark-yellow);
    border-radius: 8px;
    font-weight: var(--font-weight-semibold);
    transition: all 0.3s ease;
}

.btn-outline-primary:hover {
    background: var(--dark-yellow);
    border-color: var(--dark-yellow);
    color: var(--text-light);
}

.btn-secondary {
    background: var(--primary-grey);
    border-color: var(--primary-grey);
    color: var(--text-light);
    font-weight: var(--font-weight-semibold);
}

.btn-secondary:hover {
    background: var(--dark-grey);
    border-color: var(--dark-grey);
    color: var(--text-light);
}

/* Form Styling */
.form-control {
    border: 2px solid var(--border-light);
    color: var(--text-dark);
    border-radius: 8px;
    font-weight: var(--font-weight-normal);
}

.form-control:focus {
    border-color: var(--primary-yellow);
    box-shadow: 0 0 0 0.2rem rgba(255, 193, 7, 0.25);
    color: var(--text-dark);
}

.form-select {
    border: 2px solid var(--border-light);
    color: var(--text-dark);
    border-radius: 8px;
    font-weight: var(--font-weight-normal);
}

.form-select:focus {
    border-color: var(--primary-yellow);
    box-shadow: 0 0 0 0.2rem rgba(255, 193, 7, 0.25);
    color: var(--text-dark);
}

.input-group-text {
    background: var(--background-light);
    border: 2px solid var(--border-light);
    color: var(--primary-grey);
    font-weight: var(--font-weight-normal);
}

/* Text Colors */
h1, h2, h3, h4, h5, h6 {
    color: var(--dark-grey);
    font-weight: var(--font-weight-semibold);
}

.text-primary {
    color: var(--orange-glow) !important;
}

/* Alert Styling */
.alert-danger {
    color: var(--text-dark);
    background-color: rgba(220, 53, 69, 0.1);
    border-color: rgba(220, 53, 69, 0.2);
}

.alert-success {
    color: var(--text-dark);
    background-color: rgba(40, 167, 69, 0.1);
    border-color: rgba(40, 167, 69, 0.2);
}

.alert-warning {
    color: var(--text-dark);
    background-color: rgba(255, 193, 7, 0.1);
    border-color: rgba(255, 193, 7, 0.2);
}

/* Stat Cards */
.stat-card {
    background: var(--background-white);
    border-radius: 15px;
    padding: 1.5rem;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.08), 0 0 20px rgba(255, 165, 0, 0.1);
    transition: transform 0.3s ease;
    border: 2px solid rgba(255, 165, 0, 0.1);
}

.stat-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15), 0 0 30px rgba(255, 165, 0, 0.2);
}

.stat-icon {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    color: var(--text-light);
}

/* Gradient Backgrounds */
.bg-primary-gradient {
    background: linear-gradient(135deg, var(--primary-grey) 0%, var(--dark-grey) 100%);
}

.bg-success-gradient {
    background: linear-gradient(135deg, var(--success) 0%, #20c997 100%);
}

.bg-warning-gradient {
    background: linear-gradient(135deg, var(--dark-yellow) 0%, var(--orange-glow) 100%);
}

.bg-info-gradient {
    background: linear-gradient(135deg, var(--info) 0%, #6f42c1 100%);
}

.bg-danger-gradient {
    background: linear-gradient(135deg, var(--danger) 0%, #c82333 100%);
}

/* Table Styling */
.table th {
    color: var(--dark-grey);
    font-weight: var(--font-weight-semibold);
    border-color: var(--border-light);
}

.table td {
    color: var(--text-dark);
    font-weight: var(--font-weight-normal);
    border-color: var(--border-light);
}

.table-hover tbody tr:hover {
    background-color: rgba(255, 193, 7, 0.05);
}

/* Badge Styling */
.badge {
    font-weight: var(--font-weight-semibold);
}

.bg-primary {
    background-color: var(--primary-yellow) !important;
    color: var(--text-dark) !important;
}

.bg-secondary {
    background-color: var(--primary-grey) !important;
    color: var(--text-light) !important;
}

/* Navigation Pills */
.nav-pills .nav-link.active {
    background-color: var(--primary-yellow);
    color: var(--text-dark);
}

.nav-pills .nav-link {
    color: var(--primary-grey);
    font-weight: var(--font-weight-normal);
}

.nav-pills .nav-link:hover {
    color: var(--dark-yellow);
}

/* Dropdown Styling */
.dropdown-menu {
    border: 1px solid rgba(255, 193, 7, 0.2);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}

.dropdown-item:hover {
    background-color: rgba(255, 193, 7, 0.1);
    color: var(--text-dark);
}

/* Main Content */
.main-content {
    background: var(--background-light);
    min-height: 100vh;
}

/* Special Cards */
.dashboard-card, .user-card, .pricing-card, .login-card, .signup-card {
    background: var(--background-white);
    border-radius: 15px;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.08), 0 0 20px rgba(255, 165, 0, 0.1);
    border: 2px solid rgba(255, 165, 0, 0.1);
}

/* Progress Bars */
.progress {
    background-color: var(--border-light);
}

.progress-bar {
    background: linear-gradient(135deg, var(--primary-yellow), var(--dark-yellow));
}

/* Links */
a {
    color: var(--dark-yellow);
    text-decoration: none;
}

a:hover {
    color: var(--orange-glow);
    text-decoration: underline;
}

/* Text Muted */
.text-muted {
    color: #6c757d !important;
    font-weight: var(--font-weight-normal);
}

/* Small Text */
small, .small {
    font-weight: var(--font-weight-normal);
}

/* Pagination */
.page-link {
    color: var(--dark-yellow);
}

.page-link:hover {
    color: var(--orange-glow);
    background-color: rgba(255, 193, 7, 0.1);
    border-color: var(--primary-yellow);
}

.page-item.active .page-link {
    background-color: var(--primary-yellow);
    border-color: var(--primary-yellow);
    color: var(--text-dark);
}

/* Close Button */
.btn-close {
    filter: invert(1);
}

/* Full-width mode: completely hide sidebar and reclaim space */
.sidebar-hidden .main-sidebar { width: 0 !important; min-width: 0 !important; overflow: hidden !important; }
.sidebar-hidden .brand-link { display: none !important; }
.sidebar-hidden .main-sidebar .sidebar { display: none !important; }
.sidebar-hidden .content-wrapper,
.sidebar-hidden .main-header,
.sidebar-hidden .main-footer { margin-left: 0 !important; }
/* Also reclaim space when AdminLTE applies .sidebar-collapse */
.sidebar-collapse .main-sidebar { width: 0 !important; min-width: 0 !important; overflow: hidden !important; }
.sidebar-collapse .brand-link { display: none !important; }
.sidebar-collapse .main-sidebar .sidebar { display: none !important; }
.sidebar-collapse .content-wrapper,
.sidebar-collapse .main-header,
.sidebar-collapse .main-footer { margin-left: 0 !important; }

/* Yellow highlight for dashboard widgets/cards */
.dashboard-widgets .card {
  background: #ffffff;
  border: 1px solid var(--border-light);
  box-shadow: 0 6px 18px rgba(0,0,0,0.08);
}
.dashboard-widgets .card .card-title { color: var(--dark-yellow); font-weight: var(--font-weight-semibold); }
.dashboard-widgets .card .h2, .dashboard-widgets .card .display-4 { color: #7a5a00; }

/* Enhance stat cards across dashboards */
.stat-card {
  background: #ffffff;
  border: 1px solid var(--border-light);
  box-shadow: 0 6px 18px rgba(0,0,0,0.08);
}
.stat-card .stat-value, .stat-card h3, .stat-card .h2 { color: #7a5a00; }
/* Ensure equal heights for KPI cards */
.stat-card {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 80px;
  height: 100%;
}

/* =====================
   Dark Mode (Server-side)
   - explicit: html[data-theme="dark"]
   - system: html[data-theme="system"] + prefers-color-scheme: dark
   ===================== */

/* Variables for explicit dark */
html[data-theme="dark"] {
  --bg-color: #0f1115;
  --text-color: #e6e6e6;
  --border-color: #2a2f3a;
}

/* Apply component colors for explicit dark */
html[data-theme="dark"] body { background-color: var(--bg-color); color: var(--text-color); }
html[data-theme="dark"] .sidebar { background-color: #111827; color: var(--text-color); border-right: 1px solid var(--border-color); }
html[data-theme="dark"] .sidebar .nav-link { color: #cbd5e1; }
html[data-theme="dark"] .sidebar .nav-link.active, html[data-theme="dark"] .sidebar .nav-link:hover { color: #fff; background-color: rgba(255,255,255,0.06); }
html[data-theme="dark"] .main-content { background-color: var(--bg-color); color: var(--text-color); }
html[data-theme="dark"] .card, html[data-theme="dark"] .dashboard-card { background-color: #141922; color: var(--text-color); border: 1px solid var(--border-color); }
html[data-theme="dark"] .card-header { background-color: transparent; border-bottom: 1px solid var(--border-color); }
html[data-theme="dark"] .form-control, html[data-theme="dark"] .form-select { background-color: #0f1720; color: var(--text-color); border: 1px solid var(--border-color); }
html[data-theme="dark"] .form-control::placeholder { color: #9aa4b2; }
html[data-theme="dark"] .table { color: var(--text-color); }
html[data-theme="dark"] .table thead th { background-color: #111827; color: #cbd5e1; border-color: var(--border-color); }
html[data-theme="dark"] .table tbody td { border-color: var(--border-color); }
html[data-theme="dark"] .dropdown-menu { background-color: #111827; color: var(--text-color); border-color: var(--border-color); }
html[data-theme="dark"] .dropdown-item { color: var(--text-color); }
html[data-theme="dark"] .dropdown-item:hover { background-color: rgba(255,255,255,0.08); }
html[data-theme="dark"] .alert { border-color: var(--border-color); }
html[data-theme="dark"] .text-muted { color: #9aa4b2 !important; }
html[data-theme="dark"] .badge.bg-light { background-color: #222a35 !important; color: #d1d5db; }

/* System preference: apply same overrides when OS is dark */
@media (prefers-color-scheme: dark) {
  html[data-theme="system"] {
    --bg-color: #0f1115;
    --text-color: #e6e6e6;
    --border-color: #2a2f3a;
  }
  html[data-theme="system"] body { background-color: var(--bg-color); color: var(--text-color); }
  html[data-theme="system"] .sidebar { background-color: #111827; color: var(--text-color); border-right: 1px solid var(--border-color); }
  html[data-theme="system"] .sidebar .nav-link { color: #cbd5e1; }
  html[data-theme="system"] .sidebar .nav-link.active, html[data-theme="system"] .sidebar .nav-link:hover { color: #fff; background-color: rgba(255,255,255,0.06); }
  html[data-theme="system"] .main-content { background-color: var(--bg-color); color: var(--text-color); }
  html[data-theme="system"] .card, html[data-theme="system"] .dashboard-card { background-color: #141922; color: var(--text-color); border: 1px solid var(--border-color); }
  html[data-theme="system"] .card-header { background-color: transparent; border-bottom: 1px solid var(--border-color); }
  html[data-theme="system"] .form-control, html[data-theme="system"] .form-select { background-color: #0f1720; color: var(--text-color); border: 1px solid var(--border-color); }
  html[data-theme="system"] .form-control::placeholder { color: #9aa4b2; }
  html[data-theme="system"] .table { color: var(--text-color); }
  html[data-theme="system"] .table thead th { background-color: #111827; color: #cbd5e1; border-color: var(--border-color); }
  html[data-theme="system"] .table tbody td { border-color: var(--border-color); }
  html[data-theme="system"] .dropdown-menu { background-color: #111827; color: var(--text-color); border-color: var(--border-color); }
  html[data-theme="system"] .dropdown-item { color: var(--text-color); }
  html[data-theme="system"] .dropdown-item:hover { background-color: rgba(255,255,255,0.08); }
  html[data-theme="system"] .alert { border-color: var(--border-color); }
  html[data-theme="system"] .text-muted { color: #9aa4b2 !important; }
  html[data-theme="system"] .badge.bg-light { background-color: #222a35 !important; color: #d1d5db; }
}

/* Admin sidebar transitions and overlay backdrop */
.main-sidebar,
.content-wrapper,
.main-header,
.main-footer {
  transition: margin-left 280ms ease;
}

/* Backdrop hidden by default; only used on small screens when sidebar is open */
#adminSidebarBackdrop {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0, 0, 0, 0.28);
  z-index: 1030; /* above content, below AdminLTE sidebars */
  opacity: 0;
  visibility: hidden;
  transition: opacity 200ms ease, visibility 0s linear 200ms;
  pointer-events: none; /* disabled by default */
}

@media (max-width: 991.98px) {
  #adminSidebarBackdrop { pointer-events: auto; }
  body.sidebar-open #adminSidebarBackdrop {
    opacity: 1;
    visibility: visible;
    transition: opacity 200ms ease;
  }
}

/* Adjustable Admin Sidebar dimensions/transition */
:root {
  --admin-sidebar-width: 240px; /* adjust width here */
  --admin-sidebar-transition: 240ms; /* adjust animation duration */
  --admin-backdrop-opacity: 0.32; /* adjust backdrop opacity */
}

/* Apply width and margins on desktop only */
@media (min-width: 992px) {
  .main-sidebar { width: var(--admin-sidebar-width) !important; }
  body:not(.sidebar-collapse) .content-wrapper,
  body:not(.sidebar-collapse) .main-header,
  body:not(.sidebar-collapse) .main-footer { margin-left: var(--admin-sidebar-width) !important; }
}

/* Transition duration hook */
.main-sidebar,
.content-wrapper,
.main-header,
.main-footer { transition: margin-left var(--admin-sidebar-transition) ease; }

/* Backdrop opacity + transition tied to variable */
#adminSidebarBackdrop { background: rgba(0,0,0,var(--admin-backdrop-opacity)); transition: opacity var(--admin-sidebar-transition) ease, visibility 0s linear var(--admin-sidebar-transition); }
@media (max-width: 991.98px) { body.sidebar-open #adminSidebarBackdrop { transition: opacity var(--admin-sidebar-transition) ease; } }
/* ===== Frontend-only: hide generic “rows/pages per” length controls =====
   Purpose: Some table libraries render a length selector with labels like
   "Rows per page" or "Pages per". We do not use client-side length controls
   on frontend pages. Scope to non-admin pages using the `frontend-has-sidebar`
   class injected by startThemeOutputBuffer(). */
.frontend-has-sidebar .dataTables_length,
.frontend-has-sidebar .dt-length,
.frontend-has-sidebar .datatable-top .datatable-dropdown,
.frontend-has-sidebar .datatable-dropdown,
.frontend-has-sidebar .gridjs-pagesize,
.frontend-has-sidebar .gridjs-footer .gridjs-pagesize,
.frontend-has-sidebar .table-pagination .page-size,
.frontend-has-sidebar .pagination .page-size,
.frontend-has-sidebar .pagination-rows-per-page,
.frontend-has-sidebar .rows-per-page,
.frontend-has-sidebar .page-length,
.frontend-has-sidebar .page-size,
.frontend-has-sidebar [aria-label="rows per page"],
.frontend-has-sidebar [aria-label="Rows per page"],
.frontend-has-sidebar label[for="rows-per-page"] {
  display: none !important;
}