:root {
  --sky-400: #38bdf8;
  --sky-500: #0ea5e9;
  --sky-600: #0284c7;

  --grey-50: #f8fafc;
  --grey-100: #f1f5f9;
  --grey-200: #e5e7eb;
  --grey-500: #6b7280;
  --grey-700: #374151;

  --black: #0b0f14;
  --white: #ffffff;

  --radius-lg: 14px;
  --shadow-soft: 0 16px 40px rgba(11, 15, 20, 0.08);
}

/* Base */
html,
body {
  height: 100%;
}

body {
  background: var(--grey-50);
  color: var(--black);
}

a {
  color: var(--sky-600);
}
a:hover {
  color: var(--sky-500);
}

/* Bootstrap-ish overrides (non-invasive) */
.bg-primary {
  background-color: var(--sky-500) !important;
}
.text-primary {
  color: var(--sky-600) !important;
}
.link-primary {
  color: var(--sky-600) !important;
}
.link-primary:hover {
  color: var(--sky-500) !important;
}

.bg-dark {
  background-color: var(--black) !important;
}

.btn-primary {
  --bs-btn-color: var(--white);
  --bs-btn-bg: var(--sky-500);
  --bs-btn-border-color: var(--sky-500);
  --bs-btn-hover-color: var(--white);
  --bs-btn-hover-bg: var(--sky-600);
  --bs-btn-hover-border-color: var(--sky-600);
  --bs-btn-focus-shadow-rgb: 14, 165, 233;
  --bs-btn-active-color: var(--white);
  --bs-btn-active-bg: var(--sky-600);
  --bs-btn-active-border-color: var(--sky-600);
}

.btn-outline-primary {
  --bs-btn-color: var(--sky-600);
  --bs-btn-border-color: var(--sky-500);
  --bs-btn-hover-color: var(--white);
  --bs-btn-hover-bg: var(--sky-500);
  --bs-btn-hover-border-color: var(--sky-500);
  --bs-btn-active-color: var(--white);
  --bs-btn-active-bg: var(--sky-600);
  --bs-btn-active-border-color: var(--sky-600);
}

/* Keep semantic classes inside the palette (avoid green/red) */
.text-success,
.text-danger {
  color: var(--sky-600) !important;
}
.bg-success {
  background-color: var(--sky-500) !important;
}
.bg-danger {
  background-color: var(--black) !important;
}
.bg-warning {
  background-color: var(--grey-700) !important;
}
.text-warning {
  color: var(--grey-700) !important;
}
.btn-success {
  --bs-btn-color: var(--white);
  --bs-btn-bg: var(--sky-500);
  --bs-btn-border-color: var(--sky-500);
  --bs-btn-hover-color: var(--white);
  --bs-btn-hover-bg: var(--sky-600);
  --bs-btn-hover-border-color: var(--sky-600);
}
.btn-danger {
  --bs-btn-color: var(--white);
  --bs-btn-bg: var(--black);
  --bs-btn-border-color: var(--black);
  --bs-btn-hover-color: var(--white);
  --bs-btn-hover-bg: #111827;
  --bs-btn-hover-border-color: #111827;
}

.form-control:focus,
.form-select:focus {
  border-color: var(--sky-500);
  box-shadow: 0 0 0 4px rgba(14, 165, 233, 0.16);
}

.card {
  border-radius: var(--radius-lg);
  border-color: var(--grey-200);
}

.card-header {
  border-bottom-color: var(--grey-200);
}

.table {
  --bs-table-border-color: var(--grey-200);
}

/* Admin header / sidebar */
.navbar-brand {
  font-weight: 700;
}

.sidebar {
  background-color: var(--black) !important;
}
.sidebar .nav-link {
  color: rgba(255, 255, 255, 0.86) !important;
  border-radius: 10px;
}
.sidebar .nav-link:hover,
.sidebar .nav-link.active {
  color: var(--sky-400) !important;
  background-color: rgba(56, 189, 248, 0.12) !important;
}

/* Reusable helpers */
.theme-card {
  background: var(--white);
  border: 1px solid var(--grey-200);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
}

.theme-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.7rem 1rem;
  border-radius: 12px;
  color: var(--white);
}

.theme-badge--sky {
  background: var(--sky-500);
}
.theme-badge--dark {
  background: var(--black);
}
.theme-badge--soft {
  background: var(--grey-700);
}

/* Bands (dashboard summary bars) */
.theme-band {
  border-radius: 12px;
  color: var(--white);
}
.theme-band--sky {
  background: var(--sky-500);
}
.theme-band--dark {
  background: var(--black);
}
.theme-band--slate {
  background: var(--grey-700);
}
.theme-band--muted {
  background: var(--grey-500);
}

/* Pre/code blocks */
.theme-pre {
  font-size: 0.85rem;
  background: var(--grey-50);
  border: 1px solid var(--grey-200);
  padding: 10px;
  border-radius: 12px;
  overflow: auto;
}

/* Dashboard-specific (was in header inline styles) */
.card-stats {
  border-radius: 10px;
  border: none;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
  transition: transform 0.2s;
}
.card-stats:hover {
  transform: translateY(-5px);
}

/* Portal pages (no Bootstrap) */
.portal-page {
  font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
  padding: 20px;
  text-align: center;
  background: var(--grey-50);
  color: var(--black);
}

.portal-container {
  max-width: 420px;
  margin: 0 auto;
  padding: 22px;
}

.portal-card {
  background: var(--white);
  padding: 22px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--grey-200);
  box-shadow: var(--shadow-soft);
  border-top: 5px solid var(--sky-500);
}

.portal-logo {
  display: flex;
  justify-content: center;
  margin-bottom: 18px;
}
.portal-logo img {
  max-height: 112px;
  width: auto;
}

.portal-input {
  width: 100%;
  padding: 12px;
  margin: 10px 0;
  box-sizing: border-box;
  border: 1px solid var(--grey-200);
  border-radius: 8px;
  font-size: 16px;
  color: var(--black);
  background: var(--white);
}
.portal-input:focus {
  outline: none;
  border-color: var(--sky-500);
  box-shadow: 0 0 0 4px rgba(14, 165, 233, 0.16);
}

.portal-btn {
  width: 100%;
  padding: 12px;
  background: var(--sky-500);
  color: var(--white);
  border: none;
  border-radius: 10px;
  cursor: pointer;
  font-weight: 700;
  font-size: 1.05em;
}
.portal-btn:hover {
  background: var(--sky-600);
}

.portal-muted {
  color: var(--grey-500);
}

.portal-hr {
  margin: 26px 0;
  border: 0;
  border-top: 1px solid var(--grey-200);
}

.portal-package {
  border: 1px solid var(--grey-200);
  padding: 14px;
  margin-bottom: 10px;
  border-radius: 12px;
  background: var(--white);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.portal-package:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 20px rgba(11, 15, 20, 0.06);
}
.portal-price {
  font-weight: 800;
  font-size: 1.05em;
  color: var(--black);
}
.portal-buy {
  display: inline-block;
  margin-top: 6px;
  padding: 8px 14px;
  background: var(--black);
  color: var(--white);
  text-decoration: none;
  border-radius: 10px;
  font-size: 0.9em;
  font-weight: 700;
}
.portal-buy:hover {
  background: #111827;
  color: var(--white);
}

