:root {
  --admin-bg: #f4f0e8;
  --admin-surface: #ffffff;
  --admin-surface-soft: #f7f3eb;
  --admin-text: #1b2230;
  --admin-muted: #5f6b7c;
  --admin-line: rgba(22, 35, 62, 0.12);
  --admin-primary: #1f3556;
  --admin-primary-strong: #12223c;
  --admin-accent: #b58a44;
  --admin-accent-soft: rgba(181, 138, 68, 0.12);
  --admin-success: #1f6b4b;
  --admin-danger: #a63838;
  --admin-warning: #946200;
  --admin-radius: 22px;
  --admin-shadow: 0 18px 42px rgba(17, 35, 62, 0.08);
}

html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: linear-gradient(180deg, #faf8f3 0%, var(--admin-bg) 100%);
  color: var(--admin-text);
  font: 16px/1.65 "Segoe UI", Arial, sans-serif;
}

a { color: var(--admin-primary); text-decoration: none; }
a:hover { color: var(--admin-primary-strong); }
img { max-width: 100%; }

.panel-navbar {
  position: sticky;
  top: 0;
  z-index: 1040;
  background: rgba(250, 248, 243, 0.9);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--admin-line);
}
.panel-navbar .container-fluid {
  width: min(1320px, calc(100% - 28px));
  margin: 0 auto;
  padding: 14px 0;
}

.panel-navbar-meta {
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 1;
}
.panel-navbar-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 16px;
  border-radius: 999px;
  background: rgba(31,53,86,.08);
  color: var(--admin-primary-strong);
  font-size: .84rem;
  font-weight: 700;
}
.panel-brand {
  display: flex;
  align-items: center;
  gap: 14px;
  color: var(--admin-text);
  min-width: 0;
}
.panel-brand img {
  width: 52px;
  height: 52px;
  object-fit: contain;
  border-radius: 14px;
  background: var(--admin-surface);
  padding: 4px;
  box-shadow: 0 8px 18px rgba(17, 35, 62, 0.08);
}
.panel-brand strong {
  display: block;
  font: 700 1.08rem/1.1 Georgia, "Times New Roman", serif;
  color: var(--admin-primary-strong);
}
.panel-brand small {
  display: block;
  color: var(--admin-muted);
  font-size: .82rem;
}
.panel-user {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 8px 12px 8px 8px;
  border-radius: 999px;
  border: 1px solid var(--admin-line);
  background: var(--admin-surface);
  box-shadow: 0 8px 18px rgba(17, 35, 62, 0.06);
}
.panel-user img {
  width: 42px;
  height: 42px;
  object-fit: cover;
  border-radius: 50%;
  border: 2px solid rgba(181,138,68,.25);
}
.panel-user strong {
  display: block;
  font-size: .95rem;
  color: var(--admin-primary-strong);
}
.panel-user small {
  display: block;
  color: var(--admin-muted);
  font-size: .78rem;
}

.main-body,
.dashboard-wrap {
  width: min(1320px, calc(100% - 28px));
  margin: 26px auto 0;
}
.container,
.container-fluid {
  max-width: 1320px;
}
.admin-hero,
.dashboard-hero {
  background: linear-gradient(135deg, rgba(31,53,86,1), rgba(18,34,60,.96));
  color: #fff;
  border-radius: calc(var(--admin-radius) + 6px);
  box-shadow: var(--admin-shadow);
  overflow: hidden;
  position: relative;
  margin-bottom: 22px;
}
.admin-hero::after,
.dashboard-hero::after {
  content: '';
  position: absolute;
  inset: auto -60px -80px auto;
  width: 240px;
  height: 240px;
  background: radial-gradient(circle, rgba(181,138,68,.32) 0%, rgba(181,138,68,0) 70%);
}
.admin-hero .hero-inner,
.dashboard-hero .hero-inner {
  padding: 34px;
  position: relative;
  z-index: 1;
}
.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(181,138,68,.18);
  color: #f2d2a0;
  padding: 8px 12px;
  border-radius: 999px;
  font-size: .8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.dashboard-hero h1,
.admin-hero h1 {
  margin: 14px 0 14px;
  font: 700 clamp(2rem, 4vw, 3.35rem)/1.05 Georgia, "Times New Roman", serif;
}
.dashboard-hero p,
.admin-hero p {
  margin: 0;
  max-width: 70ch;
  color: rgba(255,255,255,.82);
}
.hero-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 24px;
}
.hero-actions .btn,
.hero-actions .button-link {
  border-radius: 14px;
  padding: 13px 18px;
  font-weight: 700;
  text-decoration: none;
}
.hero-actions .btn-light {
  background: rgba(255,255,255,.12);
  color: #fff;
  border: 1px solid rgba(255,255,255,.18);
}
.hero-actions .btn-light:hover {
  background: rgba(255,255,255,.18);
  color: #fff;
}

.card,
.bg-light,
.bg-body,
.rounded,
.shadow-sm,
.main-box,
.list-group,
.dropdown-menu,
.form-signin,
.login-card,
.table-responsive,
.bootstrap.snippets.bootdey,
.card-body {
  border-radius: var(--admin-radius) !important;
}
.card,
.bg-light,
.bg-body,
.main-box,
.form-signin,
.dropdown-menu {
  background: var(--admin-surface) !important;
  border: 1px solid rgba(17, 35, 62, 0.06) !important;
  box-shadow: var(--admin-shadow);
}
.card { overflow: hidden; }
.card-body,
.main-box-body,
.bg-light,
.bg-body {
  padding: 26px !important;
}

.list-group {
  display: grid;
  gap: 10px;
  padding: 12px;
  background: linear-gradient(180deg, #fff, #f8f4eb);
}
.list-group-item {
  border: 1px solid rgba(17,35,62,.08) !important;
  border-radius: 16px !important;
  background: #fff !important;
  color: var(--admin-text) !important;
  font-weight: 600;
  padding: 14px 16px !important;
  transition: all .2s ease;
}
.list-group-item:hover,
.list-group-item.active {
  background: var(--admin-primary) !important;
  color: #fff !important;
  border-color: var(--admin-primary) !important;
  transform: translateY(-1px);
  box-shadow: 0 14px 26px rgba(17,35,62,.14);
}
.list-group-item.disabled,
.list-group-item:disabled {
  opacity: .55;
}
.list-group hr {
  margin: 4px 0;
  border-color: rgba(17,35,62,.08);
}
.sidebar-note {
  margin-top: 18px;
  padding: 16px;
  border-radius: 18px;
  background: var(--admin-accent-soft);
  color: var(--admin-primary-strong);
}
.sidebar-note strong {
  display: block;
  font-size: .94rem;
  margin-bottom: 4px;
}

h1, h2, h3, h4, h5, h6 {
  color: var(--admin-primary-strong);
}
h5.border-bottom,
h6.border-bottom {
  border-bottom: 1px solid var(--admin-line) !important;
  font: 700 1.25rem/1.25 Georgia, "Times New Roman", serif;
  padding-bottom: 12px;
  margin-bottom: 18px !important;
}
.lead { color: var(--admin-muted); }
.text-secondary,
.text-muted,
.text-gray-dark,
small,
.small { color: var(--admin-muted) !important; }

.btn,
.button-link,
input[type='submit'],
button {
  border-radius: 14px !important;
  font-weight: 700;
  padding: 12px 18px;
}
.btn-success,
.btn-primary {
  background: var(--admin-primary) !important;
  border-color: var(--admin-primary) !important;
  color: #fff !important;
}
.btn-success:hover,
.btn-primary:hover {
  background: var(--admin-primary-strong) !important;
  border-color: var(--admin-primary-strong) !important;
}
.btn-outline-secondary {
  border-color: var(--admin-line);
  color: var(--admin-primary);
}
.btn-outline-secondary:hover {
  background: var(--admin-surface-soft);
  color: var(--admin-primary-strong);
}

.form-control,
.form-select {
  border-radius: 14px !important;
  border: 1px solid var(--admin-line) !important;
  min-height: 48px;
  background: #fff;
  color: var(--admin-text);
  box-shadow: none !important;
}
.form-control:focus,
.form-select:focus {
  border-color: rgba(31,53,86,.36) !important;
  box-shadow: 0 0 0 4px rgba(31,53,86,.08) !important;
}
textarea.form-control { min-height: 140px; }
.form-floating > label { color: var(--admin-muted); }

.table {
  margin-bottom: 0;
  --bs-table-bg: transparent;
}
.table thead th {
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--admin-muted);
  border-bottom: 1px solid var(--admin-line);
  white-space: nowrap;
}
.table td,
.table th {
  padding: 16px 14px;
  vertical-align: middle;
  border-color: rgba(17,35,62,.08);
}
.table tbody tr:hover {
  background: rgba(181,138,68,.07);
}
.user-subhead { font-weight: 700; color: var(--admin-primary-strong); }
.label,
.badge-status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 10px;
  border-radius: 999px;
  font-size: .74rem;
  font-weight: 700;
  text-transform: uppercase;
  background: rgba(31,107,75,.12);
  color: var(--admin-success);
}
.table-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 12px;
  background: var(--admin-surface-soft);
  border: 1px solid rgba(17,35,62,.08);
  color: var(--admin-primary);
  margin-right: 6px;
  transition: all .2s ease;
}
.table-link:hover {
  transform: translateY(-1px);
  background: var(--admin-primary);
  color: #fff !important;
}
.table-link.danger:hover { background: var(--admin-danger); }
.table-link.text-info:hover { background: var(--admin-primary); }
.fa-stack { font-size: .75rem; }
.fa-stack .fa-square { color: transparent; }

.alert {
  border-radius: 16px !important;
  padding: 15px 18px;
  border: 1px solid transparent;
}
.alert-danger {
  background: rgba(166,56,56,.10) !important;
  color: var(--admin-danger) !important;
  border-color: rgba(166,56,56,.18) !important;
}
.alert-success {
  background: rgba(31,107,75,.10) !important;
  color: var(--admin-success) !important;
  border-color: rgba(31,107,75,.18) !important;
}
.alert-warning {
  background: rgba(148,98,0,.10) !important;
  color: var(--admin-warning) !important;
  border-color: rgba(148,98,0,.18) !important;
}
.alert-link { color: inherit; font-weight: 700; }

.dashboard-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
  margin-bottom: 18px;
}
.metric-card {
  background: linear-gradient(180deg, #fff, #fbf8f1);
  border: 1px solid rgba(17,35,62,.06);
  border-radius: var(--admin-radius);
  padding: 22px;
  box-shadow: var(--admin-shadow);
}
.metric-card span {
  display: block;
  font-size: .84rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--admin-muted);
}
.metric-card strong {
  display: block;
  margin-top: 6px;
  font: 700 2.05rem/1 Georgia, "Times New Roman", serif;
  color: var(--admin-primary-strong);
}
.metric-card small {
  display: block;
  margin-top: 10px;
}
.dashboard-columns {
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 18px;
}
.dashboard-list {
  display: grid;
  gap: 14px;
}
.dashboard-item {
  display: grid;
  gap: 5px;
  padding: 18px;
  border: 1px solid rgba(17,35,62,.08);
  border-radius: 18px;
  background: linear-gradient(180deg, #fff, #fcfaf6);
}
.dashboard-item strong {
  font-size: 1rem;
  color: var(--admin-primary-strong);
}
.dashboard-item span {
  color: var(--admin-muted);
  font-size: .92rem;
}

.login-shell {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 28px;
  background: radial-gradient(circle at top, rgba(181,138,68,.16), transparent 30%), linear-gradient(180deg, #f8f5ef, #ece7de);
}
.login-card {
  width: min(470px, 100%);
  background: #fff;
  border-radius: 28px;
  box-shadow: 0 22px 50px rgba(17,35,62,.1);
  border: 1px solid rgba(17,35,62,.06);
  padding: 34px;
}
.login-brand {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  text-align: left;
  margin-bottom: 18px;
}
.login-brand img {
  width: 60px;
  height: 60px;
  object-fit: contain;
}
.login-brand strong {
  display: block;
  font: 700 1.1rem Georgia, "Times New Roman", serif;
  color: var(--admin-primary-strong);
}
.login-brand small {
  display: block;
  color: var(--admin-muted);
}
.login-card h1 {
  margin: 0 0 8px;
  text-align: center;
  font: 700 2.05rem/1.1 Georgia, "Times New Roman", serif;
  color: var(--admin-primary-strong);
}
.login-card p {
  text-align: center;
  color: var(--admin-muted);
  margin: 0 0 22px;
}
.login-card .field {
  display: grid;
  gap: 8px;
  margin-bottom: 16px;
}
.login-card label {
  font-weight: 700;
  color: var(--admin-primary-strong);
}
.login-meta {
  margin-top: 22px;
  text-align: center;
  color: var(--admin-muted);
  font-size: .88rem;
}
.login-back {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  margin-top: 10px;
  padding: 12px 16px;
  border-radius: 14px;
  background: var(--admin-surface-soft);
  color: var(--admin-primary);
  border: 1px solid var(--admin-line);
  font-weight: 700;
}
.login-back:hover {
  background: #fff;
}

.panel-footer {
  width: min(1320px, calc(100% - 28px));
  margin: 24px auto 34px;
  color: var(--admin-muted);
  font-size: .92rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
}
.panel-footer a { font-weight: 700; }


.sidebar-card {
  position: sticky;
  top: 94px;
}
.admin-sidebar-menu {
  display: grid;
  gap: 12px;
}
.menu-section-title {
  font-size: .78rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--admin-primary-strong);
  padding: 0 4px;
}
.list-group.compact .list-group-item {
  font-size: .95rem;
}

.admin-hero,
.dashboard-hero,
.bg-primary,
.btn-primary,
.btn-success,
.list-group-item.active,
.table-link:hover,
.panel-navbar .nav-link.accent {
  color: #fff !important;
}
.admin-hero *,
.dashboard-hero *,
.bg-primary *,
.btn-primary *,
.btn-success *,
.list-group-item.active *,
.table-link:hover * {
  color: inherit !important;
}
.admin-hero .hero-eyebrow,
.dashboard-hero .hero-eyebrow,
.admin-hero p,
.dashboard-hero p,
.admin-hero .btn-light,
.dashboard-hero .btn-light {
  color: #fff !important;
}
.btn-primary,
.btn-success {
  color: #fff !important;
}
.btn-primary:hover,
.btn-success:hover,
.btn-primary:focus,
.btn-success:focus,
.btn-primary:active,
.btn-success:active {
  color: #fff !important;
}
.list-group-item.active small,
.list-group-item.active span,
.list-group-item.active strong {
  color: #fff !important;
}

@media (max-width: 992px) {
  .dashboard-grid,
  .dashboard-columns { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .panel-navbar .container-fluid { width: calc(100% - 20px); }
  .main-body,
  .dashboard-wrap,
  .panel-footer { width: calc(100% - 20px); }
  .sidebar-card { position: static; }
}

@media (max-width: 768px) {
  .panel-brand strong { font-size: .98rem; }
  .panel-user span { display: none; }
  .panel-navbar-meta { order: 3; width: 100%; justify-content: flex-start; }
  .panel-navbar-badge { width: 100%; justify-content: flex-start; }
  .card-body,
  .main-box-body,
  .bg-light,
  .bg-body,
  .login-card { padding: 22px !important; }
  .dashboard-grid,
  .dashboard-columns { grid-template-columns: 1fr; }
  .panel-footer,
  .hero-actions { flex-direction: column; align-items: stretch; }
  .panel-navbar .nav { margin-top: 10px; }
}
