/* ====================================
   Monny — Finance Dashboard CSS
   Design System v3.0 (Performance-Optimized)
   ==================================== */

/* === CSS Custom Properties === */
:root {
  --mn-primary: #6366f1;
  --mn-primary-dark: #4f46e5;
  --mn-primary-light: #a5b4fc;
  --mn-primary-bg: rgba(99,102,241,.08);
  --mn-secondary: #8b5cf6;
  --mn-success: #10b981;
  --mn-success-bg: rgba(16,185,129,.1);
  --mn-danger: #ef4444;
  --mn-danger-bg: rgba(239,68,68,.1);
  --mn-warning: #f59e0b;
  --mn-warning-bg: rgba(245,158,11,.1);
  --mn-info: #06b6d4;
  --mn-body-bg: #f1f5f9;
  --mn-surface: #fff;
  --mn-surface-hover: #f8fafc;
  --mn-border: #e2e8f0;
  --mn-text: #0f172a;
  --mn-text-secondary: #64748b;
  --mn-text-muted: #94a3b8;
  --mn-sidebar-width: 260px;
  --mn-sidebar-bg: #0f172a;
  --mn-sidebar-text: rgba(255,255,255,.65);
  --mn-sidebar-active: #fff;
  --mn-navbar-height: 60px;
  --mn-radius: 10px;
  --mn-radius-lg: 14px;
  --mn-radius-sm: 8px;
  --mn-shadow-sm: 0 1px 2px rgba(0,0,0,.04);
  --mn-shadow: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
  --mn-shadow-md: 0 4px 6px -1px rgba(0,0,0,.05), 0 2px 4px -2px rgba(0,0,0,.04);
  --mn-shadow-lg: 0 10px 15px -3px rgba(0,0,0,.06), 0 4px 6px -4px rgba(0,0,0,.04);
  --mn-transition-fast: .15s ease;
  --mn-gradient: linear-gradient(135deg, #6366f1, #8b5cf6);
  --mn-gradient-success: linear-gradient(135deg, #10b981, #059669);
  --mn-gradient-danger: linear-gradient(135deg, #ef4444, #dc2626);
  --mn-gradient-warning: linear-gradient(135deg, #f59e0b, #d97706);
}

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

body {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  background: var(--mn-body-bg);
  color: var(--mn-text);
  font-size: .9375rem;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeSpeed;
}

h1, h2, h3, h4, h5, h6 {
  font-weight: 700;
  color: var(--mn-text);
  letter-spacing: -.02em;
}

a { text-decoration: none; color: inherit; }

/* === Scrollbar === */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--mn-border); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--mn-text-muted); }

/* === Navbar === */
.mn-navbar {
  height: var(--mn-navbar-height);
  background: var(--mn-surface);
  border-bottom: 1px solid var(--mn-border);
  z-index: 1040;
  padding: 0 1.5rem;
  display: flex;
  align-items: center;
  position: fixed;
  top: 0;
  right: 0;
  left: var(--mn-sidebar-width);
  transition: left .2s ease;
  contain: layout style;
}

.mn-navbar .navbar-brand { display: none; }
.mn-navbar .mn-search { flex: 1; max-width: 400px; }

.mn-navbar .mn-search .form-control {
  background: var(--mn-body-bg);
  border: 1px solid transparent;
  border-radius: 50px;
  padding: .5rem 1rem .5rem 2.5rem;
  font-size: .8125rem;
  transition: border-color var(--mn-transition-fast), box-shadow var(--mn-transition-fast);
}
.mn-navbar .mn-search .form-control:focus {
  background: var(--mn-surface);
  border-color: var(--mn-primary);
  box-shadow: 0 0 0 3px var(--mn-primary-bg);
}

.mn-navbar .mn-user-menu .dropdown-toggle {
  display: flex;
  align-items: center;
  gap: .5rem;
  padding: .25rem .625rem;
  border-radius: 50px;
  background: var(--mn-body-bg);
  border: 1px solid var(--mn-border);
  color: var(--mn-text);
  font-weight: 500;
  font-size: .8125rem;
  transition: border-color var(--mn-transition-fast), background-color var(--mn-transition-fast);
}
.mn-navbar .mn-user-menu .dropdown-toggle::after { display: none; }
.mn-navbar .mn-user-menu .dropdown-toggle:hover {
  background: var(--mn-surface);
  border-color: var(--mn-primary-light);
}

.mn-navbar .mn-user-menu .mn-avatar {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: var(--mn-gradient);
  display: grid;
  place-items: center;
  color: #fff;
  font-weight: 700;
  font-size: .7rem;
}

.mn-navbar .dropdown-menu {
  border: 1px solid var(--mn-border);
  border-radius: var(--mn-radius);
  box-shadow: var(--mn-shadow-lg);
  padding: .375rem;
  min-width: 200px;
  margin-top: .375rem;
}
.mn-navbar .dropdown-item {
  border-radius: 6px;
  padding: .4375rem .625rem;
  font-size: .8125rem;
  font-weight: 500;
  transition: background-color var(--mn-transition-fast), color var(--mn-transition-fast);
}
.mn-navbar .dropdown-item:hover { background: var(--mn-primary-bg); color: var(--mn-primary); }
.mn-navbar .dropdown-item.text-danger:hover { background: var(--mn-danger-bg); color: var(--mn-danger); }

.mn-navbar .mn-badge-role {
  font-size: .6rem;
  padding: .125rem .4375rem;
  border-radius: 50px;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
}

/* === Sidebar === */
.mn-sidebar {
  position: fixed;
  inset: 0 auto 0 0;
  width: var(--mn-sidebar-width);
  background: var(--mn-sidebar-bg);
  z-index: 1050;
  overflow-y: auto;
  overflow-x: hidden;
  transition: transform .25s ease;
  display: flex;
  flex-direction: column;
  contain: layout style;
  will-change: transform;
}

.mn-sidebar-brand {
  padding: 1rem 1.25rem;
  display: flex;
  align-items: center;
  gap: .625rem;
  border-bottom: 1px solid rgba(255,255,255,.06);
  flex-shrink: 0;
}
.mn-sidebar-brand .mn-logo {
  width: 36px;
  height: 36px;
  border-radius: var(--mn-radius-sm);
  background: var(--mn-gradient);
  display: grid;
  place-items: center;
  font-size: 1.125rem;
}
.mn-sidebar-brand h5 {
  color: #fff;
  font-weight: 800;
  font-size: 1.125rem;
  margin: 0;
  letter-spacing: -.02em;
}
.mn-sidebar-brand small {
  color: rgba(255,255,255,.35);
  font-size: .65rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: .1em;
}

.mn-sidebar-nav { padding: .75rem .625rem; flex: 1; }
.mn-sidebar .mn-nav-section { margin-bottom: 1.25rem; }

.mn-sidebar .mn-nav-label {
  font-size: .625rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: rgba(255,255,255,.25);
  padding: 0 .75rem;
  margin-bottom: .375rem;
}

.mn-sidebar .nav-link {
  display: flex;
  align-items: center;
  gap: .625rem;
  padding: .5rem .75rem;
  border-radius: 6px;
  color: var(--mn-sidebar-text);
  font-weight: 500;
  font-size: .8125rem;
  transition: color var(--mn-transition-fast), background-color var(--mn-transition-fast);
  position: relative;
  margin-bottom: 1px;
}
.mn-sidebar .nav-link i {
  font-size: 1rem;
  width: 20px;
  text-align: center;
  opacity: .6;
  transition: opacity var(--mn-transition-fast);
}
.mn-sidebar .nav-link:hover { color: var(--mn-sidebar-active); background: rgba(255,255,255,.07); }
.mn-sidebar .nav-link:hover i { opacity: 1; }
.mn-sidebar .nav-link.active {
  color: var(--mn-sidebar-active);
  background: rgba(99,102,241,.2);
  font-weight: 600;
}
.mn-sidebar .nav-link.active i { opacity: 1; }
.mn-sidebar .nav-link.active::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 3px;
  height: 55%;
  background: var(--mn-primary-light);
  border-radius: 0 3px 3px 0;
}

.mn-sidebar .mn-nav-badge {
  margin-left: auto;
  font-size: .6rem;
  padding: .125rem .4375rem;
  border-radius: 50px;
  background: rgba(99,102,241,.25);
  color: var(--mn-primary-light);
  font-weight: 600;
}

.mn-sidebar-footer {
  padding: .75rem 1rem;
  border-top: 1px solid rgba(255,255,255,.06);
  flex-shrink: 0;
}

.mn-sidebar::-webkit-scrollbar { width: 3px; }
.mn-sidebar::-webkit-scrollbar-track { background: transparent; }
.mn-sidebar::-webkit-scrollbar-thumb { background: rgba(255,255,255,.1); border-radius: 3px; }

/* === Main Content === */
.mn-main {
  margin-left: var(--mn-sidebar-width);
  padding-top: var(--mn-navbar-height);
  min-height: 100vh;
  transition: margin-left .25s ease;
}

.mn-content {
  padding: 1.5rem 1.75rem;
  max-width: 1400px;
}

/* === Page Header === */
.mn-page-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1.5rem;
  flex-wrap: wrap;
  gap: .75rem;
}
.mn-page-header h2 {
  font-size: 1.5rem;
  font-weight: 800;
  margin: 0;
  display: flex;
  align-items: center;
  gap: .4375rem;
}
.mn-page-header h2 i { color: var(--mn-primary); font-size: 1.25rem; }
.mn-page-header .mn-actions { display: flex; gap: .375rem; align-items: center; }

/* === Cards === */
.card {
  border: 1px solid var(--mn-border);
  border-radius: var(--mn-radius);
  background: var(--mn-surface);
  box-shadow: var(--mn-shadow-sm);
  transition: box-shadow var(--mn-transition-fast);
  overflow: hidden;
}
.card:hover { box-shadow: var(--mn-shadow); }

.card-header {
  background: var(--mn-surface);
  border-bottom: 1px solid var(--mn-border);
  padding: .875rem 1.125rem;
  font-weight: 600;
}
.card-body { padding: 1.125rem; }
.card-footer {
  background: var(--mn-surface-hover);
  border-top: 1px solid var(--mn-border);
  padding: .625rem 1.125rem;
}

/* Stat Cards */
.mn-stat-card {
  border: none;
  border-radius: var(--mn-radius-lg);
  padding: 1.125rem 1.25rem;
  position: relative;
  overflow: hidden;
  color: #fff;
  box-shadow: var(--mn-shadow);
  contain: content;
}
.mn-stat-card::before,
.mn-stat-card::after {
  content: '';
  position: absolute;
  border-radius: 50%;
  background: rgba(255,255,255,.1);
  pointer-events: none;
}
.mn-stat-card::before { top: -30%; right: -15%; width: 100px; height: 100px; }
.mn-stat-card::after { bottom: -35%; right: -8%; width: 70px; height: 70px; background: rgba(255,255,255,.06); }

.mn-stat-card.income { background: var(--mn-gradient-success); }
.mn-stat-card.expense { background: var(--mn-gradient-danger); }
.mn-stat-card.balance { background: var(--mn-gradient); }
.mn-stat-card.warning { background: var(--mn-gradient-warning); }

.mn-stat-card .mn-stat-icon {
  width: 44px;
  height: 44px;
  border-radius: var(--mn-radius-sm);
  background: rgba(255,255,255,.18);
  display: grid;
  place-items: center;
  font-size: 1.25rem;
}
.mn-stat-card .mn-stat-label {
  font-size: .7rem;
  font-weight: 600;
  opacity: .85;
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: .125rem;
}
.mn-stat-card .mn-stat-value {
  font-size: 1.5rem;
  font-weight: 800;
  letter-spacing: -.02em;
  line-height: 1.2;
}
.mn-stat-card .mn-stat-change { font-size: .7rem; opacity: .75; margin-top: .125rem; }

/* Chart Card */
.mn-chart-card { border-radius: var(--mn-radius-lg); }
.mn-chart-card .card-header { padding: 1rem 1.25rem; border-bottom: none; }
.mn-chart-card .card-header h5 { font-size: .9375rem; font-weight: 700; }

/* === Tables === */
.mn-table-card { border-radius: var(--mn-radius-lg); }

.table { margin-bottom: 0; }
.table thead th {
  font-weight: 600;
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--mn-text-secondary);
  border-bottom: 2px solid var(--mn-border);
  padding: .75rem 1rem;
  white-space: nowrap;
  background: var(--mn-surface-hover);
}
.table tbody td {
  padding: .6875rem 1rem;
  vertical-align: middle;
  border-bottom: 1px solid var(--mn-border);
  font-size: .8125rem;
}
.table tbody tr { transition: background-color var(--mn-transition-fast); }
.table tbody tr:hover { background: var(--mn-primary-bg); }
.table tbody tr:last-child td { border-bottom: none; }

/* === Buttons (GPU: transform + opacity only) === */
.btn {
  font-weight: 600;
  border-radius: var(--mn-radius-sm);
  transition: transform var(--mn-transition-fast), box-shadow var(--mn-transition-fast), background-color var(--mn-transition-fast), opacity var(--mn-transition-fast);
  font-size: .8125rem;
  padding: .4375rem 1rem;
  display: inline-flex;
  align-items: center;
  gap: .3125rem;
  border: none;
  cursor: pointer;
}
.btn:active { transform: scale(.97); }

.btn-primary { background: var(--mn-gradient); color: #fff; box-shadow: 0 2px 6px rgba(99,102,241,.2); }
.btn-primary:hover { box-shadow: 0 4px 12px rgba(99,102,241,.3); transform: translateY(-1px); color: #fff; }

.btn-success { background: var(--mn-gradient-success); color: #fff; box-shadow: 0 2px 6px rgba(16,185,129,.2); }
.btn-success:hover { box-shadow: 0 4px 12px rgba(16,185,129,.3); transform: translateY(-1px); color: #fff; }

.btn-danger { background: var(--mn-gradient-danger); color: #fff; box-shadow: 0 2px 6px rgba(239,68,68,.2); }
.btn-danger:hover { box-shadow: 0 4px 12px rgba(239,68,68,.3); transform: translateY(-1px); color: #fff; }

.btn-warning { background: var(--mn-gradient-warning); color: #fff; box-shadow: 0 2px 6px rgba(245,158,11,.2); }
.btn-warning:hover { color: #fff; transform: translateY(-1px); }

.btn-outline-primary { border: 1.5px solid var(--mn-primary); color: var(--mn-primary); background: transparent; }
.btn-outline-primary:hover { background: var(--mn-primary); color: #fff; }

.btn-outline-secondary { border: 1.5px solid var(--mn-border); color: var(--mn-text-secondary); background: transparent; }
.btn-outline-secondary:hover { background: var(--mn-body-bg); border-color: var(--mn-text-muted); color: var(--mn-text); }

.btn-outline-success { border: 1.5px solid var(--mn-success); color: var(--mn-success); background: transparent; }
.btn-outline-success:hover { background: var(--mn-success); color: #fff; }

.btn-outline-danger { border: 1.5px solid var(--mn-danger); color: var(--mn-danger); background: transparent; }
.btn-outline-danger:hover { background: var(--mn-danger); color: #fff; }

.btn-sm { font-size: .75rem; padding: .3125rem .625rem; border-radius: 6px; }

.btn-ghost { background: transparent; color: var(--mn-text-secondary); padding: .3125rem .5rem; }
.btn-ghost:hover { background: var(--mn-body-bg); color: var(--mn-text); }

/* === Forms === */
.form-control,
.form-select {
  border: 1.5px solid var(--mn-border);
  border-radius: var(--mn-radius-sm);
  padding: .5625rem .75rem;
  font-size: .8125rem;
  color: var(--mn-text);
  transition: border-color var(--mn-transition-fast), box-shadow var(--mn-transition-fast);
  background: var(--mn-surface);
}
.form-control:focus,
.form-select:focus { border-color: var(--mn-primary); box-shadow: 0 0 0 3px var(--mn-primary-bg); }
.form-control::placeholder { color: var(--mn-text-muted); }

.form-label {
  font-weight: 600;
  font-size: .75rem;
  margin-bottom: .3125rem;
  color: var(--mn-text-secondary);
  text-transform: uppercase;
  letter-spacing: .04em;
}
.form-text { font-size: .75rem; color: var(--mn-text-muted); }

.form-control-sm,
.form-select-sm { padding: .375rem .625rem; font-size: .75rem; border-radius: 6px; }

.input-group-text {
  background: var(--mn-body-bg);
  border: 1.5px solid var(--mn-border);
  border-radius: var(--mn-radius-sm);
  color: var(--mn-text-secondary);
  font-size: .8125rem;
  padding: .5625rem .75rem;
}

.form-check-input:checked { background-color: var(--mn-primary); border-color: var(--mn-primary); }
.form-control-color { border-radius: var(--mn-radius-sm); height: auto; padding: .4375rem; }

/* Filter card */
.mn-filter-card {
  border-radius: var(--mn-radius-lg);
  border: 1px dashed var(--mn-border);
  background: var(--mn-surface-hover);
}
.mn-filter-card .card-body { padding: .875rem 1rem; }

/* === Badges === */
.badge {
  font-weight: 600;
  font-size: .65rem;
  padding: .25rem .5rem;
  border-radius: 50px;
  letter-spacing: .02em;
}
.mn-badge-paid { background: var(--mn-success-bg); color: var(--mn-success); }
.mn-badge-pending { background: var(--mn-warning-bg); color: var(--mn-warning); }
.mn-badge-type { background: var(--mn-primary-bg); color: var(--mn-primary); }

/* === Alerts === */
.alert {
  border: none;
  border-radius: var(--mn-radius);
  font-size: .8125rem;
  font-weight: 500;
  padding: .75rem 1rem;
  display: flex;
  align-items: center;
  gap: .4375rem;
}
.alert-success { background: var(--mn-success-bg); color: #065f46; border-left: 3px solid var(--mn-success); }
.alert-danger { background: var(--mn-danger-bg); color: #991b1b; border-left: 3px solid var(--mn-danger); }
.alert-warning { background: var(--mn-warning-bg); color: #92400e; border-left: 3px solid var(--mn-warning); }
.alert-info { background: rgba(6,182,212,.08); color: #155e75; border-left: 3px solid var(--mn-info); }

/* === Progress === */
.progress { border-radius: 50px; background: var(--mn-body-bg); overflow: hidden; height: 8px; }
.progress-bar { border-radius: 50px; transition: width .6s ease; }

/* === Pagination === */
.pagination { gap: 3px; }
.pagination .page-link {
  border-radius: 6px;
  border: 1.5px solid var(--mn-border);
  color: var(--mn-text-secondary);
  font-weight: 600;
  font-size: .75rem;
  padding: .3125rem .625rem;
  transition: background-color var(--mn-transition-fast), border-color var(--mn-transition-fast), color var(--mn-transition-fast);
}
.pagination .page-item.active .page-link {
  background: var(--mn-gradient);
  border-color: transparent;
  color: #fff;
}
.pagination .page-link:hover { background: var(--mn-primary-bg); border-color: var(--mn-primary-light); color: var(--mn-primary); }

/* === Goals === */
.mn-goal-card {
  border-radius: var(--mn-radius-lg);
  border: 1px solid var(--mn-border);
  transition: box-shadow var(--mn-transition-fast), border-color var(--mn-transition-fast);
}
.mn-goal-card:hover { box-shadow: var(--mn-shadow-md); border-color: var(--mn-primary-light); }
.mn-goal-card .mn-goal-icon { font-size: 1.75rem; line-height: 1; }
.mn-goal-card .progress { height: 10px; }

/* === Category List === */
.mn-category-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: .75rem 1rem;
  border-bottom: 1px solid var(--mn-border);
  transition: background-color var(--mn-transition-fast);
}
.mn-category-item:last-child { border-bottom: none; }
.mn-category-item:hover { background: var(--mn-surface-hover); }
.mn-category-icon {
  width: 34px;
  height: 34px;
  border-radius: var(--mn-radius-sm);
  display: grid;
  place-items: center;
  font-size: 1rem;
}

/* === Auth Pages === */
.mn-auth-wrapper { min-height: 100vh; display: flex; background: var(--mn-body-bg); }

.mn-auth-left {
  flex: 1;
  background: var(--mn-gradient);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 2.5rem;
  position: relative;
  overflow: hidden;
}
.mn-auth-left::before {
  content: '';
  position: absolute;
  top: -20%;
  left: -20%;
  width: 60%;
  height: 60%;
  border-radius: 50%;
  background: rgba(255,255,255,.04);
}
.mn-auth-left::after {
  content: '';
  position: absolute;
  bottom: -15%;
  right: -15%;
  width: 50%;
  height: 50%;
  border-radius: 50%;
  background: rgba(255,255,255,.02);
}
.mn-auth-left h1 { color: #fff; font-size: 2.25rem; font-weight: 800; margin-bottom: .75rem; position: relative; z-index: 1; }
.mn-auth-left p { color: rgba(255,255,255,.75); font-size: 1rem; max-width: 380px; text-align: center; position: relative; z-index: 1; }

.mn-auth-features { list-style: none; padding: 0; margin: 1.5rem 0 0; position: relative; z-index: 1; }
.mn-auth-features li { color: rgba(255,255,255,.8); font-size: .875rem; padding: .375rem 0; display: flex; align-items: center; gap: .4375rem; }
.mn-auth-features li i { color: rgba(255,255,255,.85); }

.mn-auth-right { flex: 1; display: flex; align-items: center; justify-content: center; padding: 1.5rem; }
.mn-auth-card { width: 100%; max-width: 420px; }
.mn-auth-card .card { border: none; border-radius: var(--mn-radius-lg); box-shadow: var(--mn-shadow-lg); overflow: visible; }
.mn-auth-card .card-body { padding: 2.25rem; }
.mn-auth-card h2 { font-size: 1.5rem; margin-bottom: .25rem; }
.mn-auth-card .mn-auth-subtitle { color: var(--mn-text-muted); font-size: .8125rem; margin-bottom: 1.75rem; }
.mn-auth-card .form-control { padding: .625rem .875rem; font-size: .875rem; }
.mn-auth-card .btn-primary { padding: .625rem; font-size: .9375rem; }

.mn-auth-divider {
  display: flex;
  align-items: center;
  gap: .75rem;
  margin: 1.25rem 0;
  color: var(--mn-text-muted);
  font-size: .75rem;
}
.mn-auth-divider::before,
.mn-auth-divider::after { content: ''; flex: 1; height: 1px; background: var(--mn-border); }

/* === Empty States === */
.mn-empty-state { text-align: center; padding: 2.5rem 1.5rem; color: var(--mn-text-muted); }
.mn-empty-state i { font-size: 3rem; margin-bottom: .75rem; display: block; opacity: .35; }
.mn-empty-state h5 { color: var(--mn-text-secondary); font-weight: 600; margin-bottom: .375rem; }
.mn-empty-state p { font-size: .8125rem; margin-bottom: 1rem; }

/* === Footer === */
.mn-footer {
  margin-left: var(--mn-sidebar-width);
  padding: 1rem 1.75rem;
  text-align: center;
  color: var(--mn-text-muted);
  font-size: .75rem;
  border-top: 1px solid var(--mn-border);
  transition: margin-left .25s ease;
}

/* === Utility Classes === */
.amount-positive { color: var(--mn-success); font-weight: 700; }
.amount-negative { color: var(--mn-danger); font-weight: 700; }
.amount-neutral { color: var(--mn-primary); font-weight: 700; }

.text-truncate-2 {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.mn-tag {
  display: inline-flex;
  align-items: center;
  gap: .1875rem;
  padding: .1875rem .4375rem;
  border-radius: 50px;
  font-size: .65rem;
  font-weight: 600;
  background: var(--mn-body-bg);
  color: var(--mn-text-secondary);
}

/* === Loading State === */
.btn[disabled] { opacity: .6; pointer-events: none; }
.mn-skeleton {
  background: linear-gradient(90deg, var(--mn-body-bg) 25%, var(--mn-surface-hover) 50%, var(--mn-body-bg) 75%);
  background-size: 200% 100%;
  animation: skeleton .8s ease infinite;
  border-radius: var(--mn-radius-sm);
}
@keyframes skeleton { to { background-position: -200% 0; } }

/* === Animations (GPU: transform + opacity only) === */
@keyframes fadeInUp {
  from { opacity: 0; transform: translate3d(0, 10px, 0); }
  to { opacity: 1; transform: translate3d(0, 0, 0); }
}
.mn-animate-in { animation: fadeInUp .3s ease both; }
.mn-stagger-1 { animation-delay: .04s; }
.mn-stagger-2 { animation-delay: .08s; }
.mn-stagger-3 { animation-delay: .12s; }
.mn-stagger-4 { animation-delay: .16s; }

/* Instant-feel navigation */
.mn-sidebar .nav-link:active { transform: scale(.98); }

/* === Responsive === */
@media (max-width: 991.98px) {
  .mn-sidebar { transform: translateX(-100%); width: 280px; }
  .mn-sidebar.show { transform: translateX(0); box-shadow: var(--mn-shadow-lg); }
  .mn-navbar { left: 0; }
  .mn-navbar .navbar-brand { display: flex !important; }
  .mn-main { margin-left: 0; }
  .mn-footer { margin-left: 0; }
  .mn-content { padding: 1rem .875rem; }
  .mn-auth-left { display: none; }
  .mn-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.4);
    z-index: 1045;
    display: none;
  }
  .mn-overlay.show { display: block; }
}

@media (max-width: 575.98px) {
  .mn-page-header h2 { font-size: 1.25rem; }
  .mn-stat-card .mn-stat-value { font-size: 1.25rem; }
  .mn-content { padding: .875rem .625rem; }
  .mn-auth-card .card-body { padding: 1.5rem; }
}

/* === Print === */
@media print {
  .mn-sidebar, .mn-navbar, .mn-footer, .btn { display: none !important; }
  .mn-main { margin-left: 0 !important; padding-top: 0 !important; }
}
