/* ============================================================
   Codeator — Bootstrap 5.3 bridge + admin chrome
   Maps Bootstrap CSS variables to Codeator tokens, then defines the
   admin shell components (sidebar, KPI cards, table cards, badges,
   login). Load order: bootstrap.css -> site.css -> codeator-tokens.css
   -> THIS FILE (last, so it wins). Tokens live in codeator-tokens.css.
   ============================================================ */

/* ---- Bootstrap global variable mapping ------------------------------- */
:root {
  --bs-body-bg: var(--bg);
  --bs-body-color: var(--fg);
  --bs-body-font-family: var(--font-sans);
  --bs-body-font-size: var(--fs-md);
  --bs-emphasis-color: var(--fg);
  --bs-secondary-color: var(--fg-muted);
  --bs-tertiary-color: var(--fg-subtle);
  --bs-border-color: var(--border);

  --bs-primary: var(--accent);
  --bs-primary-rgb: 195, 18, 46;

  --bs-border-radius: var(--radius-md);
  --bs-border-radius-sm: var(--radius-sm);
  --bs-border-radius-lg: var(--radius-lg);
  --bs-border-radius-xl: var(--radius-lg);

  --bs-link-color: var(--accent);
  --bs-link-color-rgb: 195, 18, 46;
  --bs-link-hover-color: var(--accent-hover);
}

body { font-family: var(--font-sans); }

/* ---- Buttons -------------------------------------------------------- */
.btn {
  --bs-btn-font-weight: 600;
  --bs-btn-border-radius: var(--radius-md);
  --bs-btn-border-width: 1.5px;
  letter-spacing: .01em;
  border-bottom: none;            /* cancel the token <a> underline transition */
}
.btn:focus-visible { box-shadow: var(--shadow-crimson-glow); }

.btn-primary {
  --bs-btn-color: var(--on-accent);
  --bs-btn-bg: var(--accent);
  --bs-btn-border-color: var(--accent);
  --bs-btn-hover-color: var(--on-accent);
  --bs-btn-hover-bg: var(--accent-hover);
  --bs-btn-hover-border-color: var(--accent-hover);
  --bs-btn-active-color: var(--on-accent);
  --bs-btn-active-bg: var(--accent-pressed);
  --bs-btn-active-border-color: var(--accent-pressed);
  --bs-btn-disabled-color: var(--on-accent);
  --bs-btn-disabled-bg: var(--accent);
  --bs-btn-disabled-border-color: var(--accent);
}

.btn-outline-secondary {
  --bs-btn-color: var(--fg);
  --bs-btn-border-color: var(--border-strong);
  --bs-btn-bg: transparent;
  --bs-btn-hover-color: var(--on-accent);
  --bs-btn-hover-bg: var(--brand-navy);
  --bs-btn-hover-border-color: var(--brand-navy);
  --bs-btn-active-color: var(--on-accent);
  --bs-btn-active-bg: var(--brand-navy-core);
  --bs-btn-active-border-color: var(--brand-navy-core);
}

.btn-dark {
  --bs-btn-bg: var(--brand-navy);
  --bs-btn-border-color: var(--brand-navy);
  --bs-btn-hover-bg: var(--brand-navy-core);
  --bs-btn-hover-border-color: var(--brand-navy-core);
  --bs-btn-color: var(--brand-bone);
  --bs-btn-hover-color: var(--brand-bone);
}

/* ---- Forms --------------------------------------------------------- */
.form-control, .form-select {
  background-color: var(--bg-raised);
  border-color: var(--border-strong);
  color: var(--fg);
  border-radius: var(--radius-md);
}
.form-control:focus, .form-select:focus {
  background-color: var(--bg-raised);
  color: var(--fg);
  border-color: var(--accent);
  box-shadow: var(--shadow-crimson-glow);
}
.form-control::placeholder { color: var(--fg-subtle); }
.form-label { color: var(--fg-muted); font-size: var(--fs-sm); font-weight: 600; }
.form-text { color: var(--fg-subtle); }

/* Kill the default template's blue focus ring (from site.css). */
.btn:focus, .btn:active:focus, .btn-link.nav-link:focus,
.form-control:focus, .form-check-input:focus {
  box-shadow: var(--shadow-crimson-glow);
}

/* ---- Alerts -------------------------------------------------------- */
.alert { border-radius: var(--radius-md); border-width: 1px; }
.alert-success { --bs-alert-bg: rgba(47,143,94,.10);  --bs-alert-border-color: rgba(47,143,94,.30);  --bs-alert-color: #1f6b44; }
.alert-danger  { --bs-alert-bg: rgba(195,18,46,.08);  --bs-alert-border-color: rgba(195,18,46,.30);  --bs-alert-color: var(--accent-pressed); }
.alert-warning { --bs-alert-bg: rgba(201,162,74,.12); --bs-alert-border-color: rgba(201,162,74,.45); --bs-alert-color: #8A6B1A; }
.alert-info    { --bs-alert-bg: rgba(60,107,181,.10); --bs-alert-border-color: rgba(60,107,181,.30); --bs-alert-color: #2c5390; }

/* ---- Modal --------------------------------------------------------- */
.modal-content { background: var(--bg-raised); border: 1px solid var(--border); border-radius: var(--radius-lg); color: var(--fg); }
.modal-header, .modal-footer { border-color: var(--border); }

/* ============================================================
   Admin shell
   ============================================================ */
.app-sidebar {
  width: 248px; position: fixed; inset: 0 auto 0 0; height: 100vh;
  background: var(--brand-navy); border-right: 1px solid var(--border-inverse);
  display: flex; flex-direction: column; z-index: 100;
}
.app-sidebar .brand { display: flex; align-items: center; gap: .65rem; padding: 1.05rem 1.25rem; border-bottom: 1px solid rgba(255,255,255,.07); }
.app-sidebar .brand img { width: 30px; height: 30px; filter: drop-shadow(0 0 9px rgba(195,18,46,.5)); }
.app-sidebar .brand .brand-name { font-weight: 700; font-size: .9rem; letter-spacing: .03em; color: var(--brand-bone); line-height: 1.15; }
.app-sidebar .brand .brand-sub { display: block; font-size: .6rem; letter-spacing: .22em; text-transform: uppercase; color: var(--brand-slate); margin-top: 1px; }

.app-nav { display: flex; flex-direction: column; padding: .75rem 0; gap: 2px; }
.app-nav .nav-link {
  display: flex; align-items: center; gap: .7rem;
  color: var(--gray-400); padding: .6rem 1.25rem; font-size: .88rem; font-weight: 500;
  border-left: 2px solid transparent; border-bottom: none;
  transition: color var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out);
}
.app-nav .nav-link svg { width: 18px; height: 18px; stroke-width: 1.5; }
.app-nav .nav-link:hover { color: var(--brand-bone); background: rgba(255,255,255,.04); }
.app-nav .nav-link.active { color: var(--brand-bone); background: rgba(195,18,46,.14); border-left-color: var(--brand-crimson); }
.app-nav .nav-link.active svg { color: var(--brand-crimson-bright); }

.app-sidebar-footer { margin-top: auto; padding: .9rem 1.25rem; border-top: 1px solid rgba(255,255,255,.07); font-size: .75rem; }
.app-sidebar-footer a { color: var(--gray-400); border-bottom: none; }
.app-sidebar-footer a:hover { color: var(--brand-crimson-bright); }

.app-main { margin-left: 248px; padding: 1.75rem 2rem; min-height: 100vh; }

/* ---- Page header --------------------------------------------------- */
.page-title { font-size: var(--fs-2xl); font-weight: 700; margin: 0; letter-spacing: -.02em; color: var(--fg); }
.page-sub { color: var(--fg-muted); font-size: var(--fs-sm); margin: .2rem 0 0; }

/* ---- KPI cards ----------------------------------------------------- */
.kpi-card { background: var(--bg-raised); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 1.2rem 1.35rem; box-shadow: var(--shadow-sm); height: 100%; }
.kpi-label { color: var(--fg-subtle); font-size: var(--fs-xs); font-weight: 600; text-transform: uppercase; letter-spacing: .1em; }
.kpi-value { font-family: var(--font-display); font-size: var(--fs-3xl); font-weight: 700; color: var(--fg); line-height: 1.1; margin-top: .3rem; }
.kpi-value.accent { color: var(--accent); }
.kpi-value.gold { color: #8A6B1A; }

/* ---- Generic surface card (plan tiles, etc.) ----------------------- */
.surface-card { background: var(--bg-raised); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 1.2rem 1.35rem; box-shadow: var(--shadow-sm); }

/* ---- Table card ---------------------------------------------------- */
.table-card { background: var(--bg-raised); border: 1px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-sm); }
.table-card .table { margin: 0; color: var(--fg); --bs-table-bg: transparent; }
.table-card thead th {
  background: var(--bg-sunken); color: var(--fg-subtle);
  font-size: var(--fs-xs); font-weight: 700; text-transform: uppercase; letter-spacing: .08em;
  border-bottom: 1px solid var(--border); padding: .7rem 1rem; white-space: nowrap;
}
.table-card tbody td { border-bottom: 1px solid var(--border); padding: .7rem 1rem; vertical-align: middle; }
.table-card tbody tr:last-child td { border-bottom: 0; }
.table-card tbody tr:hover td { background: rgba(14,17,36,.025); }

/* ---- Badges (pill style — matches design-system preview) ----------- */
.badge {
  font-family: var(--font-sans); font-weight: 600; font-size: 11px;
  letter-spacing: .07em; text-transform: uppercase;
  padding: .36em .7em; border-radius: var(--radius-pill);
  border: 1px solid currentColor; display: inline-flex; align-items: center; gap: 6px; line-height: 1;
}
.badge .dot { width: 6px; height: 6px; border-radius: 999px; background: currentColor; }
.badge-active   { color: var(--accent);    background: rgba(195,18,46,.07); }
.badge-inactive { color: var(--fg-subtle); background: transparent; }
.badge-success  { color: var(--success);   background: rgba(47,143,94,.09); }
.badge-trial    { color: var(--info);      background: rgba(60,107,181,.09); }
.badge-warning  { color: #8A6B1A;          background: rgba(201,162,74,.12); border-color: rgba(201,162,74,.5); }
.badge-neutral  { color: var(--brand-navy); background: rgba(14,17,36,.05); }

/* ============================================================
   Login (standalone page, no sidebar)
   ============================================================ */
.login-shell { min-height: 100vh; display: flex; align-items: center; justify-content: center; background: var(--brand-navy); padding: 1.5rem; }
.login-card { width: 100%; max-width: 400px; background: var(--bg-raised); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 2.25rem; box-shadow: var(--shadow-xl); }
.login-logo { display: flex; align-items: center; gap: .65rem; margin-bottom: 1.6rem; }
.login-logo img { width: 36px; height: 36px; filter: drop-shadow(0 0 10px rgba(195,18,46,.45)); }
.login-logo .brand-name { font-weight: 700; font-size: .95rem; letter-spacing: .03em; color: var(--fg); line-height: 1.15; }
.login-logo .brand-sub { display: block; font-size: .6rem; letter-spacing: .22em; text-transform: uppercase; color: var(--fg-subtle); margin-top: 1px; }
