/* ==========================================================================
   Braveway 2026 — WHMCS theme overlay
   Brings the marketing-site design tokens (navy + cyan + Inter Tight)
   onto the existing bravewaywhmcs/delton WHMCS theme.

   Loads via templates/bravewaywhmcs/includes/head.tpl → {assetExists file="custom.css"}
   No template surgery required — pure CSS overlay over delton's stylesheet.
   ========================================================================== */

/* Google Fonts — match the marketing site exactly */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=Inter+Tight:wght@500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

/* --- Design tokens (lifted from marketing site tokens.css) --- */
:root {
  --bw-bg:           #fafbfc;
  --bw-bg-elev:      #ffffff;
  --bw-bg-soft:      #f4f6fa;
  --bw-bg-inset:     #eef1f7;
  --bw-border:       #e3e7ef;
  --bw-border-strong:#d2d8e3;
  --bw-ink:          #0a1230;
  --bw-ink-2:        #1c2547;
  --bw-ink-3:        #4a5170;
  --bw-muted:        #6b7390;
  --bw-navy:         #0a1230;
  --bw-navy-2:       #0f1a45;
  --bw-accent:       #00b4ff;
  --bw-accent-2:     #0084d4;
  --bw-accent-soft:  #e6f6ff;
  --bw-success:      #16a34a;
  --bw-danger:       #dc2626;
  --bw-shadow-sm: 0 1px 2px rgba(10,18,48,.06), 0 1px 1px rgba(10,18,48,.04);
  --bw-shadow-md: 0 4px 12px rgba(10,18,48,.06), 0 2px 4px rgba(10,18,48,.04);
}

/* --- Typography: replace Poppins/Arimo with marketing-site stack --- */
html, body {
  font-family: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif !important;
  color: var(--bw-ink-3);
  background: var(--bw-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-feature-settings: "ss01", "cv11";
}

h1, h2, h3, h4, h5, .h1, .h2, .h3, .h4, .h5,
.section-title, .page-header h1, .breadcrumb-section h2 {
  font-family: "Inter Tight", "Inter", system-ui, sans-serif !important;
  font-weight: 600 !important;
  letter-spacing: -0.02em;
  color: var(--bw-ink) !important;
}

code, pre, .mono, .order-summary .price-amount {
  font-family: "JetBrains Mono", "SF Mono", ui-monospace, monospace !important;
  font-feature-settings: "zero", "ss02";
}

/* --- Footer: marketing-site footer is dark navy with cream text --- */
footer.footer {
  background-color: var(--bw-navy) !important;
  color: rgba(248, 244, 236, 0.78) !important;
  border-top: 1px solid var(--bw-border);
}
footer.footer .nav-link,
footer.footer a { color: rgba(248, 244, 236, 0.78) !important; }
footer.footer .nav-link:hover,
footer.footer a:hover { color: #fff !important; }
footer.footer .btn {
  background-color: var(--bw-accent) !important;
  color: #00263c !important;
  border-color: var(--bw-accent) !important;
  font-weight: 600;
}
footer.footer .btn:hover {
  background-color: var(--bw-accent-2) !important;
  border-color: var(--bw-accent-2) !important;
  color: #fff !important;
}

/* --- Top bar / topbar (was solid #000) --- */
header.header .topbar {
  background-color: var(--bw-navy) !important;
  color: rgba(255, 255, 255, 0.85) !important;
}
header.header .topbar .btn,
header.header .topbar .active-client .input-group-text,
header.header .topbar .active-client .btn { color: #fff !important; }

/* --- Main nav bar (was #13258c) --- */
.navbar-light,
.main-navbar-wrapper {
  background-color: var(--bw-bg-elev) !important;
  color: var(--bw-ink-2) !important;
  border-bottom: 1px solid var(--bw-border);
  box-shadow: var(--bw-shadow-sm);
}
.navbar-light a, .navbar a { color: var(--bw-ink-2) !important; }
.navbar li a:hover, .navbar li a:focus,
.navbar-light a:hover, .navbar-light a:focus {
  color: var(--bw-accent-2) !important;
}
.navbar li a.active,
.navbar-light a.active { color: var(--bw-accent-2) !important; }

.dropdown-menu {
  margin-top: 8px;
  border: 1px solid var(--bw-border) !important;
  border-radius: 10px !important;
  box-shadow: var(--bw-shadow-md);
  padding: 6px 0;
}
.dropdown-menu a:link,
.dropdown-menu a:active,
.dropdown-menu a:visited { color: var(--bw-ink-2) !important; }
.dropdown-menu a:hover {
  background-color: var(--bw-bg-soft) !important;
  color: var(--bw-accent-2) !important;
}

/* --- Cards (was #081969 dark blue header) --- */
.card { border-radius: 14px !important; border: 1px solid var(--bw-border); }
.card-header,
.client-home-cards .card-header {
  background-color: var(--bw-bg-elev) !important;
  color: var(--bw-ink) !important;
  border-bottom: 1px solid var(--bw-border) !important;
  font-family: "Inter Tight", sans-serif;
  font-weight: 600;
  letter-spacing: -0.01em;
}
.card-header h3, .card-header .card-title {
  color: var(--bw-ink) !important;
}
.client-home-cards .card-body { padding-top: 20px; }

/* --- Sidebar (active item was #000) --- */
.sidebar .list-group-item.active,
.sidebar .list-group-item.active:focus,
.sidebar .list-group-item.active:hover {
  background-color: var(--bw-accent-soft) !important;
  border-color: var(--bw-accent-soft) !important;
  color: var(--bw-accent-2) !important;
  border-left: 3px solid var(--bw-accent) !important;
}

/* --- Tables (was #081969) --- */
.dataTables_wrapper table.table-list thead th.sorting_asc,
.dataTables_wrapper table.table-list thead th.sorting_desc,
table.table-list thead th {
  background-color: var(--bw-bg-soft) !important;
  border-bottom: 1px solid var(--bw-border-strong) !important;
  color: var(--bw-ink) !important;
  font-family: "Inter Tight", sans-serif;
  font-weight: 600;
  text-transform: none;
  letter-spacing: -0.005em;
}
table.table-list tbody tr:hover { background-color: var(--bw-bg-soft) !important; }

/* --- Pagination (was #081969) --- */
.page-item.active .page-link,
.pagination > .active > a,
.pagination > .active > a:focus,
.pagination > .active > a:hover,
.pagination > .active > span,
.pagination > .active > span:focus,
.pagination > .active > span:hover {
  background-color: var(--bw-accent) !important;
  border-color: var(--bw-accent) !important;
  color: #00263c !important;
}
.page-link {
  color: var(--bw-accent-2);
  border-color: var(--bw-border);
}

/* --- Buttons: align with marketing-site button system --- */
.btn-primary {
  background-color: var(--bw-ink) !important;
  border-color: var(--bw-ink) !important;
  color: #fff !important;
  font-family: "Inter", sans-serif;
  font-weight: 500;
  border-radius: 10px !important;
  padding: 10px 18px !important;
  transition: background .15s, transform .15s, box-shadow .15s;
}
.btn-primary:hover, .btn-primary:focus, .btn-primary:active {
  background-color: var(--bw-navy-2) !important;
  border-color: var(--bw-navy-2) !important;
  color: #fff !important;
}

.btn-success, .btn-info, .btn-cta,
.btn-buy, .btn-add-to-cart {
  background-color: var(--bw-accent) !important;
  border-color: var(--bw-accent) !important;
  color: #00263c !important;
  font-weight: 600;
  border-radius: 10px !important;
  box-shadow: 0 6px 22px -6px rgba(0, 180, 255, 0.4);
}
.btn-success:hover, .btn-info:hover {
  background-color: var(--bw-accent-2) !important;
  border-color: var(--bw-accent-2) !important;
  color: #fff !important;
}

.btn-default, .btn-secondary, .btn-outline {
  background-color: transparent !important;
  border: 1px solid var(--bw-border-strong) !important;
  color: var(--bw-ink) !important;
  border-radius: 10px !important;
}
.btn-default:hover, .btn-secondary:hover {
  border-color: var(--bw-ink) !important;
  background-color: var(--bw-bg-soft) !important;
}

/* --- Alerts / notices --- */
.alert {
  border-radius: 10px;
  border: 1px solid;
}
.alert-info {
  background-color: var(--bw-accent-soft);
  border-color: rgba(0, 180, 255, 0.25);
  color: var(--bw-ink-2);
}
.alert-success {
  background-color: rgba(22, 163, 74, 0.08);
  border-color: rgba(22, 163, 74, 0.25);
  color: #135f30;
}
.alert-danger {
  background-color: rgba(220, 38, 38, 0.06);
  border-color: rgba(220, 38, 38, 0.25);
  color: #8a1313;
}

/* --- Form inputs: rounded, modern --- */
.form-control, .form-select, input.form-control, textarea.form-control {
  border-radius: 10px !important;
  border: 1px solid var(--bw-border-strong) !important;
  background-color: var(--bw-bg-elev) !important;
  color: var(--bw-ink) !important;
  font-family: "Inter", sans-serif;
  transition: border-color .15s, box-shadow .15s;
}
.form-control:focus, input.form-control:focus {
  border-color: var(--bw-accent) !important;
  box-shadow: 0 0 0 3px var(--bw-accent-soft) !important;
  outline: none;
}

/* --- Links --- */
a { color: var(--bw-accent-2); }
a:hover { color: var(--bw-accent); text-decoration: none; }

/* --- Breadcrumb / page-header --- */
.breadcrumb-section,
.page-header,
.bread-crumb-bg {
  background: linear-gradient(135deg, var(--bw-navy) 0%, var(--bw-navy-2) 100%) !important;
  color: rgba(255, 255, 255, 0.92) !important;
}
.breadcrumb-section h2,
.page-header h1 { color: #fff !important; }
.breadcrumb a, .breadcrumb-section a { color: var(--bw-accent) !important; }

/* --- Login + register pages: subtle gradient bg + clean card --- */
.client-login-area,
.login-page-wrapper {
  background: var(--bw-bg) !important;
}
.client-login-area .login-form,
.login-form .card,
.login-page-wrapper .login-card {
  border-radius: 14px !important;
  border: 1px solid var(--bw-border) !important;
  box-shadow: var(--bw-shadow-md) !important;
  background-color: var(--bw-bg-elev) !important;
}

/* --- Service / invoice status pills --- */
.label-active, .badge-active, .status-active,
.status-online, .status-paid {
  background-color: rgba(22, 163, 74, 0.12) !important;
  color: var(--bw-success) !important;
  border: 1px solid rgba(22, 163, 74, 0.25);
  border-radius: 999px;
  padding: 4px 10px;
  font-weight: 500;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.label-pending, .badge-pending, .status-pending {
  background-color: rgba(217, 119, 6, 0.12) !important;
  color: #b45c00 !important;
  border: 1px solid rgba(217, 119, 6, 0.25);
  border-radius: 999px;
  padding: 4px 10px;
  font-weight: 500;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* --- Misc cleanup --- */
hr { border-color: var(--bw-border); }
.text-muted, small.text-muted { color: var(--bw-muted) !important; }
.primary-content .card-body { overflow: inherit; }

/* --- Fix legacy custom.css overrides we are replacing entirely --- */
.navbar a:focus, .navbar li a:focus,
.navbar li a:hover { color: var(--bw-accent-2) !important; text-decoration: none; }


/* ==========================================================================
   2026 marketing-site CHROME — sticky header + footer
   Matches braveway.com static site exactly. Selectors are unprefixed so the
   WHMCS portal renders with the same rules as the marketing pages.
   Collision-prone names (.nav-link) are scoped to .site-header / .mobile-menu
   so WHMCS native pages keep their bootstrap styles.
   ========================================================================== */

/* --- Header --- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 1050;
  background: rgba(250, 251, 252, 0.85);
  backdrop-filter: saturate(140%) blur(12px);
  -webkit-backdrop-filter: saturate(140%) blur(12px);
  border-bottom: 1px solid var(--bw-border);
}
.site-header .container.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 68px;
  gap: 24px;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
}
.site-header .brand {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: "Inter Tight", system-ui, sans-serif;
  font-weight: 600;
  letter-spacing: -0.02em;
  font-size: 17px;
  color: var(--bw-ink);
  text-decoration: none;
}
.site-header .brand:hover { color: var(--bw-ink); text-decoration: none; }
.site-header .brand-mark {
  display: inline-flex;
  width: 30px;
  height: 30px;
}
.site-header .brand-mark svg { width: 100%; height: 100%; display: block; }

.site-header .nav-links {
  display: flex;
  align-items: center;
  gap: 4px;
  margin: 0;
  padding: 0;
}
.site-header .nav-link,
.mobile-menu .nav-link {
  padding: 8px 14px;
  font-size: 14px;
  font-weight: 500;
  color: var(--bw-ink-3);
  border-radius: 8px;
  text-decoration: none;
  transition: color 0.15s ease, background 0.15s ease;
  font-family: "Inter", system-ui, sans-serif;
}
.site-header .nav-link:hover,
.mobile-menu .nav-link:hover {
  color: var(--bw-ink);
  background: var(--bw-bg-soft);
  text-decoration: none;
}
.site-header .nav-link.active,
.mobile-menu .nav-link.active { color: var(--bw-ink); }

.site-header .nav-tools {
  display: flex;
  align-items: center;
  gap: 10px;
}
.site-header .uptime-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 11px;
  background: var(--bw-bg-soft);
  border: 1px solid var(--bw-border);
  border-radius: 999px;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  color: var(--bw-ink-2);
  letter-spacing: 0.02em;
  white-space: nowrap;
}
.site-header .uptime-pill .dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--bw-success);
  box-shadow: 0 0 0 3px rgba(22, 163, 74, 0.2);
  animation: bw-pulse 2.4s ease-in-out infinite;
}
@keyframes bw-pulse {
  0%, 100% { box-shadow: 0 0 0 3px rgba(22, 163, 74, 0.2); }
  50%      { box-shadow: 0 0 0 6px rgba(22, 163, 74, 0.06); }
}

/* My Portal CTA — bw-prefixed to avoid bootstrap .btn collision */
.bw-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 9px 16px;
  border-radius: 8px;
  font-family: "Inter", sans-serif;
  font-size: 14px;
  font-weight: 500;
  text-decoration: none;
  border: 1px solid transparent;
  transition: background-color .15s, transform .15s, box-shadow .15s;
  cursor: pointer;
}
.bw-btn-primary {
  background-color: var(--bw-ink);
  border-color: var(--bw-ink);
  color: #fff;
}
.bw-btn-primary:hover {
  background-color: var(--bw-navy-2);
  border-color: var(--bw-navy-2);
  color: #fff;
  text-decoration: none;
}

/* responsive: collapse nav on small screens */
@media (max-width: 880px) {
  .site-header .nav-links { display: none; }
  .site-header .uptime-pill { display: none; }
  .site-header .container.nav { padding: 0 16px; height: 60px; }
}

/* --- Footer --- */
.site-footer {
  background: var(--bw-navy);
  color: #cbd2eb;
  padding: 80px 0 40px;
  margin-top: 80px;
  position: relative;
  overflow: hidden;
}
.site-footer::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle at 1px 1px, rgba(255,255,255,0.05) 1px, transparent 0);
  background-size: 24px 24px;
  pointer-events: none;
}
.site-footer .container {
  max-width: 1200px;
  padding: 0 24px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.3fr 1fr 1fr 1.4fr;
  gap: 60px;
  margin-bottom: 56px;
  align-items: start;
}
.footer-brand .brand {
  color: white;
  font-size: 19px;
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: "Inter Tight", system-ui, sans-serif;
  font-weight: 600;
  letter-spacing: -0.02em;
  text-decoration: none;
}
.footer-brand .brand-mark {
  display: inline-flex;
  width: 30px;
  height: 30px;
}
.footer-brand .brand-mark svg { width: 100%; height: 100%; display: block; }
.footer-brand p {
  color: #8b94b8;
  font-size: 14px;
  line-height: 1.6;
  max-width: 280px;
}
.footer-col h5 {
  color: white !important;
  font-family: "Inter Tight", sans-serif;
  font-size: 13px !important;
  font-weight: 600 !important;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin: 0 0 18px !important;
}
.footer-col ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.footer-col ul li,
.footer-col ul li a {
  color: #8b94b8;
  font-size: 14px;
  text-decoration: none;
  transition: color 0.15s;
  line-height: 1.5;
}
.footer-col ul li a:hover { color: white; text-decoration: none; }

.contact-line {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  color: #8b94b8;
  font-size: 14px;
  line-height: 1.5;
}
.contact-line svg { flex: 0 0 16px; margin-top: 3px; opacity: 0.7; }
.contact-line .mono { font-family: "JetBrains Mono", monospace; }

.footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 28px;
  border-top: 1px solid rgba(255,255,255,0.08);
  font-size: 13px;
  color: #6b7398;
  flex-wrap: wrap;
  gap: 12px;
}

@media (max-width: 880px) {
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 40px; }
  .site-footer { padding: 56px 0 32px; }
}
@media (max-width: 520px) {
  .footer-grid { grid-template-columns: 1fr; }
}

/* --- Hide the OLD WordPress wrapper if any leftover markup is still bleeding through --- */
.em40_header_area_main,
.delton-main-menu,
.mobile_logo_area,
.footerx-middle,
.footerx-bottom { display: none !important; }
