/* ============================================================
   STICKALL ERP — Custom Theme Override
   Loaded after style.css to upgrade the visual design
   ============================================================ */

/* ── Google Font ─────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');

:root {
  --nav-bg:      #1a2332;
  --sidebar-bg:  #1e293b;
  --sidebar-w:   220px;
  --accent:      #3b82f6;
  --accent-dark: #1d4ed8;
  --body-bg:     #f0f4f8;
  --card-bg:     #ffffff;
  --text-main:   #1e293b;
  --text-muted:  #64748b;
  --border:      #e2e8f0;
  --radius:      10px;
  --shadow:      0 2px 12px rgba(0,0,0,.08);
  --shadow-lg:   0 8px 30px rgba(0,0,0,.12);
}

/* ── Base ───────────────────────────────────────────────── */
* { box-sizing: border-box; }

body {
  font-family: 'Inter', sans-serif !important;
  background: var(--body-bg) !important;
  color: var(--text-main) !important;
}

/* ── TOP NAVBAR ─────────────────────────────────────────── */
.navbar.navbar-default.yamm {
  background: linear-gradient(135deg, #1a2332 0%, #1e3a5f 100%) !important;
  border: none !important;
  box-shadow: 0 2px 16px rgba(0,0,0,.35) !important;
  min-height: 56px !important;
}

.navbar.navbar-default .navbar-brand {
  color: #ffffff !important;
  font-weight: 600 !important;
  font-size: 15px !important;
  line-height: 56px !important;
  padding: 0 16px !important;
  letter-spacing: 0.3px;
}

.navbar.navbar-default .navbar-brand:hover { color: #93c5fd !important; }

.navbar-minimalize {
  color: #93c5fd !important;
  background: transparent !important;
  border: none !important;
  font-size: 18px !important;
  padding: 16px 14px !important;
  line-height: 1 !important;
}

.navbar-minimalize:hover { color: #ffffff !important; }

/* Nav right items */
.navbar-top-drops > li > a {
  color: #cbd5e1 !important;
  font-size: 13px !important;
  padding: 0 12px !important;
  line-height: 56px !important;
  transition: color .2s !important;
}
.navbar-top-drops > li > a:hover { color: #ffffff !important; background: transparent !important; }

.navbar-top-drops .btn-danger {
  background: linear-gradient(135deg, #ef4444, #dc2626) !important;
  border: none !important;
  border-radius: 6px !important;
  padding: 7px 16px !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  margin-top: 11px !important;
  box-shadow: 0 2px 8px rgba(239,68,68,.35) !important;
  line-height: 1.4 !important;
}

/* ── SIDEBAR ────────────────────────────────────────────── */
.navbar-aside {
  background: var(--sidebar-bg) !important;
  border: none !important;
  box-shadow: 2px 0 16px rgba(0,0,0,.2) !important;
  width: var(--sidebar-w) !important;
}

/* Logo/brand area at top of sidebar */
.sidebar-collapse { background: var(--sidebar-bg) !important; }

/* All sidebar links */
.metismenu li a {
  color: #94a3b8 !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  padding: 11px 20px !important;
  border-radius: 0 !important;
  transition: all .2s !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  border-left: 3px solid transparent !important;
}

.metismenu li a .fa {
  font-size: 15px !important;
  width: 18px !important;
  text-align: center !important;
  flex-shrink: 0 !important;
}

.metismenu li a:hover {
  color: #ffffff !important;
  background: rgba(255,255,255,.06) !important;
  border-left-color: var(--accent) !important;
}

.metismenu li.active > a {
  color: #ffffff !important;
  background: linear-gradient(90deg, rgba(59,130,246,.25) 0%, rgba(59,130,246,.05) 100%) !important;
  border-left-color: var(--accent) !important;
}

/* Sub-menu */
.metismenu .nav-second-level {
  background: rgba(0,0,0,.2) !important;
}
.metismenu .nav-second-level li a {
  padding: 9px 20px 9px 44px !important;
  font-size: 12.5px !important;
  border-left: none !important;
}
.metismenu .nav-second-level li a:hover {
  color: #ffffff !important;
  background: rgba(255,255,255,.05) !important;
  border-left: none !important;
}
.metismenu .nav-second-level li.active > a { color: #93c5fd !important; }

/* Arrow for dropdowns */
.metismenu .arrow {
  color: #64748b !important;
  font-size: 11px !important;
  margin-left: auto !important;
}

/* Sidebar category separators (the .menu_divider) */
.menu_divider {
  border-color: rgba(255,255,255,.08) !important;
  margin: 8px 16px !important;
}

/* ── CONTENT AREA ───────────────────────────────────────── */
#wrapper {
  background: var(--body-bg) !important;
}

.content-wrapper {
  padding: 20px !important;
}

/* ── BREADCRUMB & PAGE TITLE ────────────────────────────── */
.page-title { padding-bottom: 4px !important; }

.breadcrumb {
  background: transparent !important;
  padding: 0 !important;
  font-size: 11px !important;
  font-weight: normal !important;
  color: var(--text-main) !important;
  margin-bottom: 0 !important;
}
.breadcrumb > li + li::before { color: var(--text-muted) !important; }
.breadcrumb .active { color: var(--text-main) !important; }
.breadcrumb a { color: var(--text-muted) !important; }
.breadcrumb a:hover { color: var(--accent) !important; }

/* ── KPI STAT CARDS (tiles) ──────────────────────────────── */
/* Equal-height tile rows */
.row-tiles {
  display: flex !important;
  flex-wrap: wrap !important;
}
.row-tiles > [class*="col-"] {
  display: flex !important;
  flex-direction: column !important;
  margin-bottom: 20px !important;
  padding-bottom: 0 !important;
}
.row-tiles > [class*="col-"] > a {
  display: flex !important;
  flex: 1 !important;
  text-decoration: none !important;
}
.row-tiles > [class*="col-"] > a > .tile {
  flex: 1 !important;
  width: 100% !important;
}

.tile {
  border-radius: var(--radius) !important;
  box-shadow: var(--shadow) !important;
  overflow: hidden !important;
  transition: transform .2s, box-shadow .2s !important;
  border: none !important;
  padding: 0 !important;
  display: flex !important;
  flex-direction: column !important;
}

.tile:hover {
  transform: translateY(-3px) !important;
  box-shadow: var(--shadow-lg) !important;
}

/* Default tile — neutral */
.tile:not(.blue):not(.orange):not(.green):not(.red) {
  background: var(--card-bg) !important;
}

.tile.blue {
  background: linear-gradient(135deg, #2563eb 0%, #1d4ed8 100%) !important;
}
.tile.orange {
  background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%) !important;
}
.tile.green {
  background: linear-gradient(135deg, #10b981 0%, #059669 100%) !important;
}
.tile.red {
  background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%) !important;
}

.tile .tile-title {
  color: rgba(255,255,255,.85) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: .8px !important;
  text-transform: uppercase !important;
  padding: 12px 16px 0 !important;
}

.tile:not(.blue):not(.orange):not(.green):not(.red) .tile-title {
  color: var(--text-muted) !important;
}

.tile-body {
  padding: 10px 16px 12px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  background: transparent !important;
  flex: 1 !important;
}

.tile-body .fa {
  font-size: 28px !important;
  opacity: .55 !important;
  color: #fff !important;
}

.tile:not(.blue):not(.orange):not(.green):not(.red) .tile-body .fa {
  color: var(--accent) !important;
  opacity: 1 !important;
}

.tile-body h4 {
  font-size: 28px !important;
  font-weight: 700 !important;
  color: #ffffff !important;
  margin: 0 !important;
  line-height: 1 !important;
  flex-shrink: 0 !important;
}

.tile:not(.blue):not(.orange):not(.green):not(.red) .tile-body h4 {
  color: var(--text-main) !important;
}

/* Ensure tile number is always visible even when empty string */
.tile-body h4:empty::after { content: '0'; }

.tile-footer {
  background: rgba(0,0,0,.12) !important;
  color: rgba(255,255,255,.75) !important;
  font-size: 11px !important;
  padding: 7px 16px !important;
}

.tile:not(.blue):not(.orange):not(.green):not(.red) .tile-footer {
  background: #f8fafc !important;
  color: var(--text-muted) !important;
  border-top: 1px solid var(--border) !important;
}

/* Quick action tiles (no footer, on top of dashboard) */
a > .tile:not(.blue):not(.orange) .tile-body {
  padding: 18px 16px !important;
}

/* ── PANELS ─────────────────────────────────────────────── */
.panel {
  border: none !important;
  border-radius: var(--radius) !important;
  box-shadow: var(--shadow) !important;
  background: var(--card-bg) !important;
}

.panel-heading {
  background: var(--card-bg) !important;
  border-bottom: 1px solid var(--border) !important;
  border-radius: var(--radius) var(--radius) 0 0 !important;
  padding: 14px 20px !important;
}

.panel-heading .panel-title {
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--text-main) !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
}

.panel-heading .panel-title::before {
  content: '';
  display: inline-block;
  width: 4px;
  height: 16px;
  background: var(--accent);
  border-radius: 4px;
}

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

/* ── SECTION HEADINGS inside dashboard ──────────────────── */
.section-heading {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 24px 0 12px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: .7px;
}
.section-heading::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--border);
}

/* ── DATE FILTER CARD ───────────────────────────────────── */
.filter-card {
  background: var(--card-bg);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 14px 20px;
  margin-bottom: 20px;
  display: flex;
  align-items: flex-end;
  gap: 12px;
  flex-wrap: wrap;
}

.filter-card .filter-group {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.filter-card label {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: .5px;
  margin: 0;
}

.filter-card .form-control {
  height: 36px !important;
  font-size: 13px !important;
  border: 1px solid var(--border) !important;
  border-radius: 6px !important;
  width: 150px;
  color: var(--text-main) !important;
  box-shadow: none !important;
}

.filter-card .form-control:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px rgba(59,130,246,.12) !important;
}

.filter-card .btn-primary {
  background: linear-gradient(135deg, var(--accent), var(--accent-dark)) !important;
  border: none !important;
  border-radius: 6px !important;
  height: 36px !important;
  padding: 0 18px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  box-shadow: 0 2px 8px rgba(59,130,246,.3) !important;
}

.filter-card .btn-default,
.filter-card .btn-primary.reset-btn {
  background: #f1f5f9 !important;
  border: 1px solid var(--border) !important;
  border-radius: 6px !important;
  height: 36px !important;
  padding: 0 18px !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  color: var(--text-muted) !important;
  box-shadow: none !important;
}

/* ── FORMS & INPUTS (global) ────────────────────────────── */
.form-control {
  border-radius: 6px !important;
  border: 1px solid #d1d5db !important;
  font-size: 13px !important;
  color: var(--text-main) !important;
  box-shadow: none !important;
}
.form-control:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px rgba(59,130,246,.12) !important;
}

/* ── BUTTONS ────────────────────────────────────────────── */
.btn-primary {
  background: linear-gradient(135deg, #3b82f6, #1d4ed8) !important;
  border: none !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  font-size: 13px !important;
}
.btn-success {
  background: linear-gradient(135deg, #10b981, #059669) !important;
  border: none !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
}
.btn-danger {
  background: linear-gradient(135deg, #ef4444, #dc2626) !important;
  border: none !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
}
.btn-warning {
  background: linear-gradient(135deg, #f59e0b, #d97706) !important;
  border: none !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  color: #fff !important;
}

/* ── TABLES ─────────────────────────────────────────────── */
.table {
  font-size: 13px !important;
}
.table > thead > tr > th {
  background: #f8fafc !important;
  color: var(--text-muted) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: .5px !important;
  border-bottom: 2px solid var(--border) !important;
  padding: 10px 12px !important;
}
.table > tbody > tr > td {
  padding: 9px 12px !important;
  border-top: 1px solid #f1f5f9 !important;
  vertical-align: middle !important;
  color: var(--text-main) !important;
}
.table-striped > tbody > tr:nth-of-type(odd) { background: #f9fafb !important; }
.table-hover > tbody > tr:hover { background: #eff6ff !important; }

/* ── MODALS ─────────────────────────────────────────────── */
.modal-content {
  border: none !important;
  border-radius: var(--radius) !important;
  box-shadow: 0 20px 60px rgba(0,0,0,.25) !important;
}
.modal-header {
  background: #f8fafc !important;
  border-bottom: 1px solid var(--border) !important;
  border-radius: var(--radius) var(--radius) 0 0 !important;
  padding: 16px 20px !important;
}
.modal-title { font-size: 15px !important; font-weight: 600 !important; }

/* ── ALERTS ─────────────────────────────────────────────── */
.alert {
  border: none !important;
  border-radius: 7px !important;
  font-size: 13px !important;
}
.alert-success { background: #d1fae5 !important; color: #065f46 !important; }
.alert-danger  { background: #fee2e2 !important; color: #991b1b !important; }
.alert-warning { background: #fef3c7 !important; color: #92400e !important; }
.alert-info    { background: #dbeafe !important; color: #1e40af !important; }

/* ── BADGES ─────────────────────────────────────────────── */
.badge {
  border-radius: 99px !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  padding: 3px 7px !important;
}

/* ── SCROLLBAR ──────────────────────────────────────────── */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: #cbd5e1; border-radius: 99px; }
::-webkit-scrollbar-thumb:hover { background: #94a3b8; }

/* ── TODAY DATE CHIP (navbar) ───────────────────────────── */
.navbar-top-drops .date-chip a {
  background: rgba(255,255,255,.08) !important;
  border-radius: 20px !important;
  padding: 0 14px !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  color: #93c5fd !important;
  margin-top: 13px !important;
  display: inline-block !important;
  line-height: 30px !important;
}

/* ── MINI QUICK-ACTION TILES (top of dashboard) ─────────── */
.quick-tile {
  background: var(--card-bg);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 16px 20px;
  display: flex;
  align-items: center;
  gap: 14px;
  transition: transform .2s, box-shadow .2s;
  border-left: 4px solid var(--accent);
  text-decoration: none !important;
  color: var(--text-main) !important;
}
.quick-tile:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
  text-decoration: none !important;
}
.quick-tile .qt-icon {
  width: 42px;
  height: 42px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  color: #fff;
  flex-shrink: 0;
}
.quick-tile .qt-label {
  font-size: 12px;
  color: var(--text-muted);
  font-weight: 500;
}
.quick-tile .qt-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--text-main);
  line-height: 1;
}

/* ── CHART LEGEND DOTS ──────────────────────────────────── */
.chart-legend {
  display: flex;
  gap: 16px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.chart-legend span {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--text-muted);
  font-weight: 500;
}
.chart-legend .dot {
  width: 10px;
  height: 10px;
  border-radius: 3px;
  flex-shrink: 0;
}

/* ── RESPONSIVE ─────────────────────────────────────────── */
@media (max-width: 768px) {
  .filter-card { flex-direction: column; align-items: stretch; }
  .filter-card .form-control { width: 100%; }
}

/* ── SIDEBAR HOVER FLYOUT SUBMENU ───────────────────────── */

/* Each top-level li is the anchor for its flyout */
.metismenu > li {
  position: relative !important;
}

/* Arrow — decorative only, points right to hint flyout */
.metismenu > li > a .fa.arrow {
  display: inline-block !important;
  margin-left: auto !important;
  font-size: 10px !important;
  color: #475569 !important;
  transform: rotate(-90deg) !important;
}
.metismenu > li > a .fa.arrow::before {
  content: "\f078" !important;   /* fa-chevron-down rotated = right-pointing */
}

/* Force all second-level menus hidden — JS positions and shows them on hover */
.metismenu .nav-second-level,
.metismenu .nav-second-level.collapse,
.metismenu .nav-second-level.collapse.in,
.metismenu .nav-second-level.collapsing {
  display: none !important;
  height: auto !important;
  position: fixed !important;
  min-width: 215px !important;
  /* max-height intentionally NOT set here — JS sets it per-open via inline style */
  overflow-y: auto !important;
  background: #1a2840 !important;
  border-radius: 0 8px 8px 0 !important;
  box-shadow: 6px 4px 24px rgba(0,0,0,.4) !important;
  z-index: 99999 !important;
  padding: 6px 0 !important;
  border-left: 3px solid var(--accent) !important;
  transition: none !important;
}

/* JS adds .flyout-open to show the menu.
   Use #side-menu ID (specificity 1,1,0) to beat .collapse.in (0,4,0) even with !important */
#side-menu .nav-second-level.flyout-open {
  display: block !important;
}

/* Flyout submenu items */
.metismenu .nav-second-level li a {
  padding: 10px 18px 10px 18px !important;
  font-size: 13px !important;
  color: #94a3b8 !important;
  display: flex !important;
  align-items: center !important;
  gap: 9px !important;
  border-left: none !important;
  white-space: nowrap !important;
  transition: background .15s, color .15s !important;
}

.metismenu .nav-second-level li a:hover {
  background: rgba(59,130,246,.15) !important;
  color: #ffffff !important;
  border-left: none !important;
}

.metismenu .nav-second-level li.active > a {
  color: #93c5fd !important;
  background: rgba(59,130,246,.18) !important;
}

/* Tiny flyout header label (the parent item text repeated) */
.metismenu > li:hover > a {
  background: rgba(59,130,246,.18) !important;
  color: #ffffff !important;
  border-left-color: var(--accent) !important;
}
