/* Axon Design System — Bootstrap 5 Warm & Approachable Theme */

/* ── Design Tokens ─────────────────────────────────────────── */
:root {
  --axon-primary:        #4A90D9;
  --axon-primary-dark:   #3578C7;
  --axon-primary-light:  #EBF4FF;
  --axon-secondary:      #6C9E7B;
  --axon-accent:         #F4A261;
  --axon-bg:             #F8F6F3;
  --axon-surface:        #FFFFFF;
  --axon-text:           #2D3748;
  --axon-muted:          #718096;
  --axon-danger:         #E05252;
  --axon-success:        #38A169;
  --axon-warning:        #D69E2E;
  --axon-border:         #E8E4E0;
  --axon-radius-card:    12px;
  --axon-radius-btn:     8px;
  --axon-radius-pill:    50px;
  --axon-shadow:         0 2px 12px rgba(0,0,0,0.06);
  --axon-shadow-md:      0 4px 20px rgba(0,0,0,0.10);
}

/* ── Typography ────────────────────────────────────────────── */
body {
  font-family: 'Nunito', 'Segoe UI', sans-serif;
  font-size: 14px;
  line-height: 1.6;
  color: var(--axon-text);
  background-color: var(--axon-bg);
}

h1, h2, h3, h4, h5, h6 {
  font-family: 'Nunito', 'Segoe UI', sans-serif;
  font-weight: 600;
  color: var(--axon-text);
}

/* ── Bootstrap 5 Token Overrides ───────────────────────────── */
.btn-primary {
  background-color: var(--axon-primary);
  border-color: var(--axon-primary);
  border-radius: var(--axon-radius-btn);
}
.btn-primary:hover, .btn-primary:focus {
  background-color: var(--axon-primary-dark);
  border-color: var(--axon-primary-dark);
}
.btn-success { background-color: var(--axon-secondary); border-color: var(--axon-secondary); border-radius: var(--axon-radius-btn); }
.btn-danger  { background-color: var(--axon-danger);    border-color: var(--axon-danger);    border-radius: var(--axon-radius-btn); }
.btn-warning { background-color: var(--axon-warning);   border-color: var(--axon-warning);   border-radius: var(--axon-radius-btn); }
.btn-outline-secondary { border-radius: var(--axon-radius-btn); }

.form-control, .form-select {
  border-radius: var(--axon-radius-btn);
  border-color: var(--axon-border);
  color: var(--axon-text);
}
.form-control:focus, .form-select:focus {
  border-color: var(--axon-primary);
  box-shadow: 0 0 0 0.2rem rgba(74,144,217,0.2);
}

/* ── Cards (replace panels) ────────────────────────────────── */
.card {
  border: none;
  border-radius: var(--axon-radius-card);
  box-shadow: var(--axon-shadow);
  background-color: var(--axon-surface);
  margin-bottom: 1.5rem;
}
.card-header {
  background-color: var(--axon-surface);
  border-bottom: 1px solid var(--axon-border);
  border-radius: var(--axon-radius-card) var(--axon-radius-card) 0 0 !important;
  font-weight: 600;
  padding: 0.85rem 1.25rem;
}
.card-body { padding: 1.25rem; }

/* ── Sidebar ────────────────────────────────────────────────── */
.sidebar {
  width: 240px;
  background-color: var(--axon-surface);
  box-shadow: 2px 0 12px rgba(0,0,0,0.05);
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  overflow-y: auto;
  z-index: 1000;
}
.sidebar .sidebar-brand {
  display: flex;
  align-items: center;
  padding: 1.2rem 1.5rem;
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--axon-primary);
  border-bottom: 1px solid var(--axon-border);
}
.sidebar .nav-link {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.6rem 1.2rem;
  border-radius: var(--axon-radius-btn);
  margin: 2px 8px;
  color: var(--axon-text);
  font-weight: 500;
  transition: background 0.15s, color 0.15s;
}
.sidebar .nav-link:hover {
  background-color: var(--axon-primary-light);
  color: var(--axon-primary);
}
.sidebar .nav-link.active, .sidebar .nav-link.active-link {
  background-color: var(--axon-primary);
  color: #fff;
}
.sidebar .nav-link i { width: 18px; text-align: center; font-size: 0.95rem; }
.sidebar .nav-section { font-size: 0.7rem; font-weight: 700; text-transform: uppercase; color: var(--axon-muted); padding: 0.8rem 1.5rem 0.3rem; letter-spacing: 0.08em; }
.sidebar .sub-menu { list-style: none; padding: 0; }
.sidebar .sub-menu .nav-link { padding-left: 2.8rem; font-size: 0.875rem; }

/* Override styles.css #sidebar ID rules (ID specificity would otherwise win) */
#sidebar {
  width: 240px !important;
  float: none !important;
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  bottom: auto !important;
  margin-top: 0 !important;         /* override styles.css @media min-width:992px margin-top:65px */
  height: 100vh !important;
  background-color: var(--axon-surface) !important;
  box-shadow: 2px 0 12px rgba(0,0,0,0.05) !important;
  overflow-y: hidden !important;
  z-index: 1000 !important;
  /* Flex column: brand pinned at top, nav scrolls below */
  display: flex !important;
  flex-direction: column !important;
  transition: transform 0.25s ease, width 0.25s ease;
}

/* styles.css sets #sidebar > div { height:100% } — collapses brand to full height */
#sidebar > div {
  height: auto !important;
  flex-shrink: 0 !important;
}

/* Brand block: same height as topbar so they visually align */
#sidebar .sidebar-brand {
  height: 60px !important;
  min-height: 60px !important;
  flex-shrink: 0 !important;
  padding: 0 1.5rem !important;
}

/* Nav area fills remaining height and scrolls independently */
#sidebar nav {
  flex: 1 1 auto !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
}

/* Override styles.css #app .app-content — ensure our margins apply */
#app .app-content {
  margin-left: 240px !important;
  margin-top: 60px !important;
  padding: 1.5rem !important;
  min-height: calc(100vh - 60px) !important;
  height: auto !important;
}

/* ── Top Navbar ─────────────────────────────────────────────── */
.app-topbar {
  height: 60px;
  background-color: var(--axon-surface);
  box-shadow: 0 1px 8px rgba(0,0,0,0.07);
  display: flex;
  align-items: center;
  padding: 0 1.5rem;
  position: fixed;
  top: 0;
  left: 240px;
  right: 0;
  z-index: 999;
  transition: left 0.25s ease;
}
.app-topbar .org-name { font-weight: 600; color: var(--axon-muted); font-size: 0.9rem; }

/* ── Main Content Area ──────────────────────────────────────── */
.app-content {
  margin-left: 240px;
  margin-top: 60px;
  padding: 1.5rem;
  min-height: calc(100vh - 60px);
  transition: margin-left 0.25s ease;
}

/* ── Sidebar collapsed state ────────────────────────────────── */
#app.sidebar-collapsed #sidebar {
  transform: translateX(-240px) !important;
}
#app.sidebar-collapsed .app-topbar {
  left: 0 !important;
}
#app.sidebar-collapsed .app-content,
#app.sidebar-collapsed #app .app-content {
  margin-left: 0 !important;
}

/* ── Page Title ─────────────────────────────────────────────── */
.page-title { font-size: 1.3rem; font-weight: 700; color: var(--axon-text); margin-bottom: 0.2rem; }
.page-subtitle { font-size: 0.85rem; color: var(--axon-muted); margin-bottom: 1.5rem; }

/* ── Badges (replace label label-*) ────────────────────────── */
.badge { border-radius: var(--axon-radius-pill); font-weight: 600; font-size: 0.75rem; }
.badge.bg-primary { background-color: var(--axon-primary) !important; }
.badge.bg-success { background-color: var(--axon-secondary) !important; }
.badge.bg-danger  { background-color: var(--axon-danger) !important; }
.badge.bg-warning { background-color: var(--axon-warning) !important; color: #fff; }

/* ── Tables ─────────────────────────────────────────────────── */
.table { font-size: 0.875rem; }
.table thead th { font-weight: 600; color: var(--axon-muted); font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.05em; background-color: var(--axon-bg); border-bottom: 2px solid var(--axon-border); }
.table tbody tr:hover { background-color: var(--axon-primary-light); }
.table td { vertical-align: middle; }

/* ── Login Page ─────────────────────────────────────────────── */
.login-page {
  position: fixed;
  inset: 0;
  z-index: 1050;
  overflow-y: auto;
  background: linear-gradient(135deg, #EBF4FF 0%, #F8F6F3 60%, #FDF3EC 100%);
  display: flex;
  align-items: center;
  justify-content: center;
}
.login-card {
  width: 100%;
  max-width: 420px;
  border-radius: 16px;
  box-shadow: var(--axon-shadow-md);
}
.login-card .card-header { text-align: center; padding: 2rem 1.5rem 1rem; }
.login-card .brand-logo { font-size: 2rem; font-weight: 800; color: var(--axon-primary); letter-spacing: -0.03em; }
.login-card .brand-tagline { font-size: 0.85rem; color: var(--axon-muted); }

/* ── Alerts ─────────────────────────────────────────────────── */
.alert { border: none; border-radius: var(--axon-radius-btn); }
.alert-danger  { background-color: #FFF5F5; color: var(--axon-danger); }
.alert-success { background-color: #F0FFF4; color: var(--axon-success); }
.alert-warning { background-color: #FFFBEB; color: var(--axon-warning); }
.alert-info    { background-color: var(--axon-primary-light); color: var(--axon-primary); }

/* ── Modals ─────────────────────────────────────────────────── */
.modal-content { border: none; border-radius: var(--axon-radius-card); box-shadow: var(--axon-shadow-md); }
.modal-header { border-bottom: 1px solid var(--axon-border); }
.modal-footer { border-top: 1px solid var(--axon-border); }

/* ── Pagination ─────────────────────────────────────────────── */
.page-link { color: var(--axon-primary); border-color: var(--axon-border); }
.page-item.active .page-link { background-color: var(--axon-primary); border-color: var(--axon-primary); }

/* ── Responsive sidebar collapse ───────────────────────────── */
@media (max-width: 768px) {
  .sidebar { transform: translateX(-240px); transition: transform 0.25s; }
  .sidebar.open { transform: translateX(0); }
  .app-topbar { left: 0; }
  .app-content { margin-left: 0; }
}

/* ── Dashboard ──────────────────────────────────────────────── */
.dash-stat-icon {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 1.25rem;
}
.dash-stat-value {
  font-size: 1.75rem;
  font-weight: 700;
  line-height: 1;
  color: var(--axon-text);
}
.dash-stat-label {
  font-size: 0.78rem;
  color: var(--axon-muted);
  margin-top: 0.2rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.quick-link-card {
  color: var(--axon-text) !important;
  transition: box-shadow 0.15s, transform 0.15s;
}
.quick-link-card:hover {
  box-shadow: var(--axon-shadow-md) !important;
  transform: translateY(-2px);
  color: var(--axon-primary) !important;
}

/* ── Icon-only buttons ──────────────────────────────────────── */
.btn-icon {
  width: 32px;
  height: 32px;
  padding: 0 !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

/* ── Content area full-width helpers ────────────────────────── */
.container-fullw {
  margin-left: 0 !important;
  margin-right: 0 !important;
}
.container-fullw.bg-white,
.container-fluid.bg-white {
  background-color: transparent !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* ── Utilities ──────────────────────────────────────────────── */
.text-primary { color: var(--axon-primary) !important; }
.text-success { color: var(--axon-secondary) !important; }
.text-danger  { color: var(--axon-danger) !important; }
.bg-primary   { background-color: var(--axon-primary) !important; }
.border-light { border-color: var(--axon-border) !important; }
