/* ──────────────────────────────────────────────────────────────────────────
   FAMS Custom CSS  |  Bootstrap 5.3 Override Layer
   Primary: #1a3c5e  Accent: #f0a500
   ────────────────────────────────────────────────────────────────────────── */

:root {
  --fams-primary:       #1a3c5e;
  --fams-primary-light: #2a5685;
  --fams-accent:        #f0a500;
  --fams-accent-dark:   #c98900;
  --fams-sidebar-w:     260px;
  --fams-topbar-h:      56px;
  --fams-bg:            #f4f6f9;
  --fams-text:          #2c3e50;
  --fams-border:        #dee2e6;
}

/* ── Reset / Base ────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

body.fams-body {
  margin: 0;
  font-family: 'Segoe UI', system-ui, -apple-system, sans-serif;
  background: var(--fams-bg);
  color: var(--fams-text);
  overflow-x: hidden;
}

/* ── Sidebar ─────────────────────────────────────────────────────────────── */
.fams-sidebar {
  position: fixed;
  top: 0; left: 0;
  width: var(--fams-sidebar-w);
  height: 100vh;
  background: var(--fams-primary);
  z-index: 1040;
  overflow-y: auto;
  overflow-x: hidden;
  transition: transform 0.25s ease;
  display: flex;
  flex-direction: column;
}

.sidebar-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 18px 20px 14px;
  border-bottom: 1px solid rgba(255,255,255,.1);
  flex-shrink: 0;
}
.sidebar-logo      { height: 32px; width: auto; }
.sidebar-brand-text { color: #fff; font-size: 1.2rem; font-weight: 700; letter-spacing: .04em; }

.sidebar-nav { padding: 12px 0; flex: 1; }

.nav-section-label {
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .1em;
  color: rgba(255,255,255,.4);
  padding: 18px 20px 4px;
  text-transform: uppercase;
}

.sidebar-nav .nav-link {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 20px;
  color: rgba(255,255,255,.75);
  font-size: .875rem;
  border-radius: 0 4px 4px 0;
  margin-right: 8px;
  transition: background .15s, color .15s;
  text-decoration: none;
}
.sidebar-nav .nav-link:hover {
  background: rgba(255,255,255,.1);
  color: #fff;
}
.sidebar-nav .nav-link.active {
  background: var(--fams-accent);
  color: #fff;
  font-weight: 600;
}
.sidebar-nav .nav-link i { font-size: 1rem; flex-shrink: 0; }
.sidebar-nav .nav-link span { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ── Topbar ──────────────────────────────────────────────────────────────── */
.fams-topbar {
  height: var(--fams-topbar-h);
  background: var(--fams-primary);
  border-bottom: 3px solid var(--fams-accent);
  position: sticky;
  top: 0;
  z-index: 1030;
}

/* ── Main Content Area ──────────────────────────────────────────────────── */
.fams-main {
  margin-left: var(--fams-sidebar-w);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  transition: margin-left .25s ease;
}

.fams-content {
  flex: 1;
  padding: 0;
  background: var(--fams-bg);
}

/* ── Footer ─────────────────────────────────────────────────────────────── */
.fams-footer {
  background: #fff;
  font-size: .78rem;
  color: #6c757d;
}

/* ── KPI Cards ───────────────────────────────────────────────────────────── */
.fams-kpi-card {
  background: #fff;
  border-radius: 10px;
  transition: transform .15s, box-shadow .15s;
  cursor: pointer;
}
.fams-kpi-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0,0,0,.08) !important;
}
.fams-kpi-icon {
  min-width: 52px;
  min-height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.fams-kpi-value { line-height: 1.2; }
.fams-kpi-label { font-size: .78rem; }

/* ── Settings Cards ─────────────────────────────────────────────────────── */
.fams-setting-card { transition: transform .15s, box-shadow .15s; }
.fams-setting-card:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(0,0,0,.08) !important; }

/* ── Login Page ─────────────────────────────────────────────────────────── */
body.fams-login-bg {
  background: linear-gradient(135deg, var(--fams-primary) 0%, var(--fams-primary-light) 100%);
  min-height: 100vh;
}
.fams-login-card { border-radius: 16px; }

/* ── Tables ──────────────────────────────────────────────────────────────── */
.table thead th { font-size: .78rem; font-weight: 600; letter-spacing: .03em; color: #495057; }
.table td { vertical-align: middle; font-size: .875rem; }

/* ── Cards ───────────────────────────────────────────────────────────────── */
.card { border-radius: 10px; }
.card-header { font-size: .875rem; }

/* ── Badge enhancements ─────────────────────────────────────────────────── */
.badge { font-weight: 500; }

/* ── Flatpickr override ──────────────────────────────────────────────────── */
.flatpickr-calendar { font-family: inherit; }

/* ── Responsive: sidebar collapse on mobile ─────────────────────────────── */
@media (max-width: 991.98px) {
  .fams-sidebar { transform: translateX(-100%); }
  .fams-sidebar.sidebar-open { transform: translateX(0); }
  .fams-main { margin-left: 0; }
}

/* ── Receipt Print Styles (inline here, also in print.css) ──────────────── */
@media print {
  .fams-sidebar, .fams-topbar, .fams-footer, .d-print-none { display: none !important; }
  .fams-main { margin-left: 0 !important; }
  .fams-content { padding: 0 !important; }
}
