/* QuantumHost – The Orbital Command Design System */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&family=Inter:wght@300;400;500;600;700&display=swap');

/* ── Design Tokens ─────────────────────────────────────────── */
:root {
  --qh-bg:          #090e1b;
  --qh-surface-lo:  #0d1321;
  --qh-surface:     #131929;
  --qh-surface-hi:  #191f31;
  --qh-surface-top: #1e2538;
  --qh-primary:     #62d0ff;
  --qh-primary-dim: #00b6ea;
  --qh-primary-ct:  #00c4fd;
  --qh-secondary:   #ac89ff;
  --qh-secondary-ct:#7000ff;
  --qh-tertiary:    #aaffdc;
  --qh-error:       #ff716c;
  --qh-on-surface:  #e4e7fb;
  --qh-muted:       #a6aabc;
  --qh-outline:     #707586;
  --qh-outline-var: #434857;
  --qh-font-head:   'Space Grotesk', sans-serif;
  --qh-font-body:   'Inter', sans-serif;

  /* Bootstrap overrides */
  --bs-body-bg:              var(--qh-bg);
  --bs-body-color:           var(--qh-on-surface);
  --bs-primary:              var(--qh-primary);
  --bs-primary-rgb:          98, 208, 255;
  --bs-secondary-rgb:        172, 137, 255;
  --bs-success-rgb:          170, 255, 220;
  --bs-danger-rgb:           255, 113, 108;
  --bs-link-color:           var(--qh-primary-dim);
  --bs-link-hover-color:     var(--qh-primary);
  --bs-border-color:         rgba(112,117,134,0.15);
  --bs-card-bg:              rgba(30,37,56,0.4);
  --bs-input-bg:             var(--qh-surface-lo);
  --bs-input-border-color:   rgba(112,117,134,0.15);
  --bs-input-focus-border-color: var(--qh-primary);
  --bs-input-color:          var(--qh-on-surface);
  --bs-input-placeholder-color: var(--qh-muted);
  --bs-navbar-color:         var(--qh-muted);
  --bs-navbar-hover-color:   var(--qh-on-surface);
  --bs-navbar-active-color:  var(--qh-primary);
  --bs-dropdown-bg:          var(--qh-surface-hi);
  --bs-dropdown-border-color: rgba(112,117,134,0.1);
  --bs-dropdown-link-color:  var(--qh-on-surface);
  --bs-dropdown-link-hover-bg: var(--qh-surface-top);
  --bs-dropdown-link-hover-color: var(--qh-primary);
  --bs-table-color:          var(--qh-on-surface);
  --bs-table-striped-bg:     rgba(30,37,56,0.3);
  --bs-table-hover-bg:       rgba(98,208,255,0.05);
  --bs-modal-bg:             var(--qh-surface-hi);
  --bs-modal-header-border-color: rgba(112,117,134,0.1);
  --bs-badge-bg:             var(--qh-surface-top);
  --bs-badge-color:          var(--qh-on-surface);
}

/* ── Global ───────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

html, body {
  font-family: var(--qh-font-body);
  background: var(--qh-bg);
  color: var(--qh-on-surface);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

h1,h2,h3,h4,h5,h6 { font-family: var(--qh-font-head); color: var(--qh-on-surface); }

a { color: var(--qh-primary-dim); text-decoration: none; transition: color .2s; }
a:hover { color: var(--qh-primary); }

/* ── Starfield background ─────────────────────────────────── */
body::before {
  content: '';
  position: fixed; inset: 0; z-index: -1;
  background:
    radial-gradient(ellipse at 20% 20%, rgba(0,196,253,.08) 0%, transparent 50%),
    radial-gradient(ellipse at 80% 80%, rgba(112,0,255,.06) 0%, transparent 50%),
    var(--qh-bg);
  pointer-events: none;
}

/* ── Topbar navbar ────────────────────────────────────────── */
.navbar {
  background: rgba(9,14,27,.7) !important;
  backdrop-filter: blur(20px) !important;
  border-bottom: 1px solid rgba(112,117,134,.08) !important;
  padding: .25rem 0 !important;
  min-height: 108px;
}
.navbar-brand {
  font-family: var(--qh-font-head);
  font-weight: 700;
  font-size: 1.35rem;
  letter-spacing: -.02em;
  background: linear-gradient(135deg, var(--qh-primary), var(--qh-primary-ct));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  padding: 0;
}
.navbar-brand img { filter: brightness(1.05); display: block; }
.nav-link { color: var(--qh-muted) !important; font-size: .875rem; letter-spacing: .01em; transition: color .2s; }
.nav-link:hover, .nav-link.active { color: var(--qh-on-surface) !important; }
.navbar-toggler { border-color: rgba(112,117,134,.2); }
.navbar-toggler-icon { filter: invert(1); }

/* ── Sidebar ──────────────────────────────────────────────── */
.offcanvas-md { background: var(--qh-surface-lo) !important; border-right: 1px solid rgba(112,117,134,.08) !important; }
#sidebarMenu { padding-top: .5rem; }
#sidebarMenu .nav-link {
  border-radius: 10px;
  padding: .6rem .85rem;
  margin: .1rem 0;
  color: var(--qh-muted) !important;
  font-size: .845rem;
  transition: background .2s, color .2s;
}
#sidebarMenu .nav-link:hover {
  background: rgba(98,208,255,.06);
  color: var(--qh-on-surface) !important;
}
#sidebarMenu .nav-link.active,
#sidebarMenu .nav-link[aria-current="page"] {
  background: rgba(98,208,255,.1);
  color: var(--qh-primary) !important;
}
#sidebarMenu .svg-icon { width: 16px; height: 16px; fill: currentColor; opacity: .7; }
#sidebarMenu .nav-link:hover .svg-icon,
#sidebarMenu .nav-link.active .svg-icon { opacity: 1; }

/* Balance / note in sidebar */
#sidebarMenu h5.text-secondary { color: var(--qh-muted) !important; font-size: .75rem; text-transform: uppercase; letter-spacing: .08em; }
#sidebarMenu h4 { color: var(--qh-primary); font-family: var(--qh-font-head); }

/* ── Main layout ──────────────────────────────────────────── */
.container { max-width: 1400px; }
#wrapper { min-height: 80vh; }

/* ── Cards / panels ──────────────────────────────────────── */
.card, .content-block > div, table { border-radius: 14px !important; }
.card {
  background: rgba(30,37,56,.45) !important;
  backdrop-filter: blur(12px);
  border: 1px solid rgba(112,117,134,.1) !important;
  box-shadow: 0 4px 24px rgba(0,0,0,.3);
  transition: transform .3s, box-shadow .3s;
}
.card:hover { transform: translateY(-1px); box-shadow: 0 8px 32px rgba(0,0,0,.4); }
.card-header {
  background: rgba(30,37,56,.6) !important;
  border-bottom: 1px solid rgba(112,117,134,.1) !important;
  font-family: var(--qh-font-head);
  font-weight: 600;
  letter-spacing: -.01em;
}
.card-footer {
  background: rgba(30,37,56,.4) !important;
  border-top: 1px solid rgba(112,117,134,.1) !important;
}

/* ── Buttons ──────────────────────────────────────────────── */
.btn { border-radius: 50px !important; font-weight: 600; letter-spacing: .02em; font-size: .85rem; transition: transform .2s, box-shadow .2s; }
.btn:hover { transform: translateY(-1px); }
.btn-primary {
  background: linear-gradient(135deg, var(--qh-primary), var(--qh-primary-ct)) !important;
  border: none !important;
  color: #00394d !important;
  box-shadow: 0 0 18px rgba(98,208,255,.2);
}
.btn-primary:hover { box-shadow: 0 0 28px rgba(98,208,255,.35) !important; }
.btn-secondary { background: rgba(172,137,255,.12) !important; border: 1px solid rgba(172,137,255,.2) !important; color: var(--qh-secondary) !important; }
.btn-outline-primary { border-color: var(--qh-primary) !important; color: var(--qh-primary) !important; background: transparent !important; }
.btn-outline-primary:hover { background: rgba(98,208,255,.1) !important; }
.btn-success { background: linear-gradient(135deg,#00edb4,#00b6ea) !important; border: none !important; color: #004734 !important; }
.btn-danger { background: rgba(255,113,108,.15) !important; border: 1px solid rgba(255,113,108,.3) !important; color: var(--qh-error) !important; }
.btn-warning { background: rgba(255,200,80,.12) !important; border: 1px solid rgba(255,200,80,.25) !important; color: #ffd760 !important; }
.btn-light, .btn-dark { background: rgba(30,37,56,.6) !important; border: 1px solid rgba(112,117,134,.15) !important; color: var(--qh-on-surface) !important; }
.btn-sm { font-size: .78rem !important; padding: .3rem .85rem !important; }
.btn-big, .btn-lg { padding: .75rem 2rem !important; font-size: .95rem !important; }

/* ── Forms ────────────────────────────────────────────────── */
.form-control, .form-select {
  background: var(--qh-surface-lo) !important;
  border: 1px solid rgba(112,117,134,.15) !important;
  color: var(--qh-on-surface) !important;
  border-radius: 10px !important;
  transition: border-color .2s, box-shadow .2s;
}
.form-control:focus, .form-select:focus {
  border-color: rgba(98,208,255,.4) !important;
  box-shadow: 0 0 0 3px rgba(98,208,255,.08) !important;
  background: var(--qh-surface) !important;
}
.form-control::placeholder { color: var(--qh-muted) !important; }
.form-label { font-size: .83rem; font-weight: 500; color: var(--qh-muted); letter-spacing: .01em; margin-bottom: .35rem; }
.form-check-input { background-color: var(--qh-surface-hi) !important; border-color: rgba(112,117,134,.3) !important; }
.form-check-input:checked { background-color: var(--qh-primary) !important; border-color: var(--qh-primary) !important; }
.form-text { color: var(--qh-muted) !important; font-size: .78rem; }
.input-group-text { background: var(--qh-surface-hi) !important; border-color: rgba(112,117,134,.15) !important; color: var(--qh-muted) !important; border-radius: 10px 0 0 10px !important; }

/* ── Tables ───────────────────────────────────────────────── */
.table {
  color: var(--qh-on-surface);
  border-color: rgba(112,117,134,.1);
  font-size: .875rem;
}
.table thead th {
  background: rgba(30,37,56,.6);
  color: var(--qh-muted);
  font-size: .75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .08em;
  border-bottom: 1px solid rgba(112,117,134,.15);
  padding: .85rem 1rem;
}
.table tbody tr { border-color: rgba(112,117,134,.07); transition: background .15s; }
.table tbody tr:hover { background: rgba(98,208,255,.03); }
.table td, .table th { vertical-align: middle; padding: .8rem 1rem; }
.table-borderless td, .table-borderless th { border: none; }

/* ── Badges / pills ───────────────────────────────────────── */
.badge {
  font-family: var(--qh-font-head);
  font-weight: 600;
  font-size: .72rem;
  letter-spacing: .04em;
  border-radius: 50px !important;
  padding: .28rem .75rem;
}
.badge.bg-success, .badge.bg-active, .text-success { color: var(--qh-tertiary) !important; }
.badge.bg-success { background: rgba(0,237,180,.12) !important; border: 1px solid rgba(0,237,180,.2); }
.badge.bg-danger  { background: rgba(255,113,108,.12) !important; border: 1px solid rgba(255,113,108,.2); color: var(--qh-error) !important; }
.badge.bg-warning { background: rgba(255,200,80,.1) !important; border: 1px solid rgba(255,200,80,.2); color: #ffd760 !important; }
.badge.bg-info    { background: rgba(98,208,255,.12) !important; border: 1px solid rgba(98,208,255,.2); color: var(--qh-primary) !important; }
.badge.bg-primary { background: linear-gradient(135deg,var(--qh-primary),var(--qh-primary-ct)) !important; color: #00394d !important; }
.badge.bg-secondary { background: rgba(172,137,255,.12) !important; border: 1px solid rgba(172,137,255,.2); color: var(--qh-secondary) !important; }

/* ── Alerts ───────────────────────────────────────────────── */
.alert { border-radius: 12px !important; border: 1px solid; font-size: .875rem; }
.alert-success { background: rgba(0,237,180,.08) !important; border-color: rgba(0,237,180,.2) !important; color: var(--qh-tertiary) !important; }
.alert-danger, .alert-error { background: rgba(255,113,108,.08) !important; border-color: rgba(255,113,108,.2) !important; color: var(--qh-error) !important; }
.alert-warning { background: rgba(255,200,80,.07) !important; border-color: rgba(255,200,80,.2) !important; color: #ffd760 !important; }
.alert-info { background: rgba(98,208,255,.08) !important; border-color: rgba(98,208,255,.2) !important; color: var(--qh-primary) !important; }

/* ── Dropdowns ────────────────────────────────────────────── */
.dropdown-menu {
  background: var(--qh-surface-hi) !important;
  border: 1px solid rgba(112,117,134,.12) !important;
  border-radius: 14px !important;
  box-shadow: 0 8px 32px rgba(0,0,0,.5) !important;
  backdrop-filter: blur(12px);
  overflow: hidden;
}
.dropdown-item { color: var(--qh-on-surface) !important; font-size: .875rem; padding: .6rem 1rem; transition: background .15s; }
.dropdown-item:hover { background: rgba(98,208,255,.07) !important; color: var(--qh-primary) !important; }
.dropdown-divider { border-color: rgba(112,117,134,.1) !important; }

/* ── Breadcrumb ───────────────────────────────────────────── */
.breadcrumb { font-size: .78rem; }
.breadcrumb-item a { color: var(--qh-muted); }
.breadcrumb-item a:hover { color: var(--qh-primary); }
.breadcrumb-item.active { color: var(--qh-on-surface); }
.breadcrumb-item + .breadcrumb-item::before { color: var(--qh-outline); }

/* ── Pagination ───────────────────────────────────────────── */
.pagination .page-link {
  background: var(--qh-surface-hi) !important;
  border-color: rgba(112,117,134,.1) !important;
  color: var(--qh-muted) !important;
  border-radius: 8px !important;
  margin: 0 2px;
  transition: all .2s;
}
.pagination .page-link:hover { background: rgba(98,208,255,.1) !important; color: var(--qh-primary) !important; }
.pagination .page-item.active .page-link { background: linear-gradient(135deg,var(--qh-primary),var(--qh-primary-ct)) !important; border: none !important; color: #00394d !important; }

/* ── Tabs ─────────────────────────────────────────────────── */
.nav-tabs { border-bottom: 1px solid rgba(112,117,134,.12) !important; }
.nav-tabs .nav-link { color: var(--qh-muted); border: none !important; border-bottom: 2px solid transparent !important; border-radius: 0 !important; padding: .6rem 1rem; font-size: .875rem; }
.nav-tabs .nav-link:hover { color: var(--qh-on-surface); }
.nav-tabs .nav-link.active { color: var(--qh-primary) !important; border-bottom-color: var(--qh-primary) !important; background: none !important; }
.nav-pills .nav-link { border-radius: 50px !important; color: var(--qh-muted); }
.nav-pills .nav-link.active { background: linear-gradient(135deg,var(--qh-primary),var(--qh-primary-ct)) !important; color: #00394d !important; }

/* ── Modals ───────────────────────────────────────────────── */
.modal-content {
  background: var(--qh-surface-hi) !important;
  border: 1px solid rgba(112,117,134,.12) !important;
  border-radius: 18px !important;
  box-shadow: 0 24px 80px rgba(0,0,0,.6);
  backdrop-filter: blur(20px);
}
.modal-header { border-bottom: 1px solid rgba(112,117,134,.1) !important; }
.modal-footer { border-top: 1px solid rgba(112,117,134,.1) !important; }
.modal-title { font-family: var(--qh-font-head); }
.btn-close { filter: invert(1) brightness(.7); }

/* ── Toasts ───────────────────────────────────────────────── */
.toast {
  background: var(--qh-surface-hi) !important;
  border: 1px solid rgba(112,117,134,.15) !important;
  border-radius: 12px !important;
  backdrop-filter: blur(12px);
  color: var(--qh-on-surface) !important;
}
.toast-header { background: rgba(30,37,56,.6) !important; border-bottom: 1px solid rgba(112,117,134,.1) !important; color: var(--qh-on-surface) !important; }

/* ── Progress bars ────────────────────────────────────────── */
.progress { background: var(--qh-surface-hi) !important; border-radius: 50px !important; height: 8px !important; }
.progress-bar { background: linear-gradient(90deg, var(--qh-primary), var(--qh-primary-ct)) !important; border-radius: 50px !important; }

/* ── List group ───────────────────────────────────────────── */
.list-group-item {
  background: transparent !important;
  border-color: rgba(112,117,134,.1) !important;
  color: var(--qh-on-surface) !important;
  transition: background .15s;
}
.list-group-item:hover { background: rgba(98,208,255,.04) !important; }
.list-group-item.active { background: rgba(98,208,255,.1) !important; border-color: rgba(98,208,255,.2) !important; color: var(--qh-primary) !important; }
.list-group-item-action:hover { background: rgba(98,208,255,.05) !important; }

/* ── Status pulse ─────────────────────────────────────────── */
.status-pulse {
  display: inline-block; width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--qh-tertiary);
  box-shadow: 0 0 8px var(--qh-tertiary);
  animation: pulse 2s infinite;
}
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.6;transform:scale(1.3)} }

/* ── Section page headers ─────────────────────────────────── */
.page-header, .content-block h3.h4, .content-block > h2, .content-block > h3 {
  font-family: var(--qh-font-head);
  font-weight: 700;
  letter-spacing: -.02em;
}

/* ── Footer ───────────────────────────────────────────────── */
#footer {
  background: transparent !important;
  border-top: 1px solid rgba(112,117,134,.08) !important;
  color: var(--qh-muted) !important;
  font-size: .78rem;
  padding: 1.5rem 0 !important;
  text-align: center;
}
#footer a { color: var(--qh-muted) !important; }
#footer a:hover { color: var(--qh-primary) !important; }

/* ── Back-to-top ──────────────────────────────────────────── */
.position-fixed.btn-primary.bottom-0 { right: 1.5rem; bottom: 1.5rem; border-radius: 50% !important; width: 44px; height: 44px; padding: 0 !important; display: flex; align-items: center; justify-content: center; box-shadow: 0 0 16px rgba(98,208,255,.2); }

/* ── Loading spinner ──────────────────────────────────────── */
.wait { background: rgba(9,14,27,.85) !important; backdrop-filter: blur(6px); }
.spinner-border { color: var(--qh-primary) !important; }

/* ── glow glass utility ───────────────────────────────────── */
.glass-card {
  background: rgba(30,37,56,.4);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(112,117,134,.1);
  border-radius: 16px;
}

/* ── Dashboard stat cards ─────────────────────────────────── */
.stat-card {
  background: rgba(30,37,56,.4);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(112,117,134,.1);
  border-radius: 16px;
  padding: 1.5rem;
  transition: transform .3s, box-shadow .3s;
}
.stat-card:hover { transform: translateY(-2px); box-shadow: 0 12px 40px rgba(0,0,0,.4); }
.stat-card .stat-icon { width: 42px; height: 42px; border-radius: 12px; display: flex; align-items: center; justify-content: center; }
.stat-card .stat-value { font-family: var(--qh-font-head); font-size: 1.75rem; font-weight: 700; color: var(--qh-on-surface); }
.stat-card .stat-label { font-size: .78rem; color: var(--qh-muted); text-transform: uppercase; letter-spacing: .06em; margin-top: .25rem; }

/* ── Gradient text ────────────────────────────────────────── */
.text-gradient {
  background: linear-gradient(135deg, var(--qh-primary) 0%, var(--qh-primary-ct) 50%, var(--qh-secondary) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ── Misc overrides ───────────────────────────────────────── */
hr { border-color: rgba(112,117,134,.12) !important; }
code, pre { background: var(--qh-surface-lo) !important; color: var(--qh-tertiary) !important; border-radius: 8px !important; }
blockquote { border-left: 3px solid var(--qh-primary); padding-left: 1rem; color: var(--qh-muted); }
.text-muted { color: var(--qh-muted) !important; }
.text-primary { color: var(--qh-primary) !important; }
.text-success { color: var(--qh-tertiary) !important; }
.text-danger  { color: var(--qh-error) !important; }
.text-secondary { color: var(--qh-secondary) !important; }
.bg-primary { background: linear-gradient(135deg,var(--qh-primary),var(--qh-primary-ct)) !important; }
.bg-secondary { background: rgba(172,137,255,.12) !important; }
.border { border-color: rgba(112,117,134,.12) !important; }
.shadow, .shadow-sm, .shadow-lg { box-shadow: 0 8px 32px rgba(0,0,0,.4) !important; }
.rounded, .rounded-2, .rounded-3 { border-radius: 12px !important; }
.rounded-pill { border-radius: 50px !important; }

/* ── Login / Register public pages ───────────────────────── */
.qh-auth-wrap {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem 1rem;
  position: relative;
}
.qh-auth-wrap::before {
  content: '';
  position: fixed; inset: 0; z-index: -1;
  background:
    radial-gradient(ellipse at 30% 30%, rgba(0,196,253,.1) 0%, transparent 60%),
    radial-gradient(ellipse at 70% 70%, rgba(112,0,255,.08) 0%, transparent 60%),
    var(--qh-bg);
}
.qh-auth-card {
  width: 100%;
  max-width: 440px;
  background: rgba(30,37,56,.55);
  backdrop-filter: blur(20px);
  border: 1px solid rgba(112,117,134,.12);
  border-radius: 22px;
  padding: 2.5rem;
  box-shadow: 0 24px 80px rgba(0,0,0,.5);
}
.qh-auth-logo { text-align: center; margin-bottom: 2rem; }
.qh-auth-logo img { max-height: 52px; }
.qh-auth-logo span {
  display: block;
  font-family: var(--qh-font-head);
  font-size: 1.5rem;
  font-weight: 700;
  background: linear-gradient(135deg, var(--qh-primary), var(--qh-primary-ct));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-top: .5rem;
}
.qh-auth-title { font-family: var(--qh-font-head); font-size: 1.5rem; font-weight: 700; margin-bottom: .25rem; }
.qh-auth-subtitle { color: var(--qh-muted); font-size: .875rem; margin-bottom: 1.75rem; }

/* ── Responsive ───────────────────────────────────────────── */
@media (max-width: 767px) {
  .qh-auth-card { padding: 1.75rem; }
  .navbar-brand { font-size: 1.1rem; }
}

/* ── Scrollbar ────────────────────────────────────────────── */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--qh-bg); }
::-webkit-scrollbar-thumb { background: rgba(112,117,134,.3); border-radius: 50px; }
::-webkit-scrollbar-thumb:hover { background: rgba(98,208,255,.3); }

/* ── Order/product page ───────────────────────────────────── */
.pricing-card {
  background: rgba(30,37,56,.45);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(112,117,134,.1);
  border-radius: 18px;
  transition: transform .3s, box-shadow .3s, border-color .3s;
}
.pricing-card:hover, .pricing-card.popular {
  border-color: rgba(98,208,255,.25);
  box-shadow: 0 12px 48px rgba(98,208,255,.08);
}
.pricing-card.popular { transform: scale(1.01); }

/* ── Accordion ────────────────────────────────────────────── */
.accordion-item { background: rgba(30,37,56,.4) !important; border: 1px solid rgba(112,117,134,.1) !important; border-radius: 12px !important; margin-bottom: .5rem; overflow: hidden; }
.accordion-button { background: rgba(30,37,56,.6) !important; color: var(--qh-on-surface) !important; font-family: var(--qh-font-head); }
.accordion-button::after { filter: invert(1); }
.accordion-button:not(.collapsed) { color: var(--qh-primary) !important; box-shadow: none !important; }
.accordion-body { background: rgba(19,25,41,.5) !important; color: var(--qh-on-surface) !important; }

/* ── Invoice page ─────────────────────────────────────────── */
.invoice-logo img { max-height: 50px; }

/* ── Landing page animations ────────────────────────────────── */
@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: .6; transform: scale(.85); }
}
@keyframes spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ── Landing page body reset ─────────────────────────────────── */
body { padding-top: 0 !important; }

/* ── Order flow accordion overrides ─────────────────────────── */
.qh-order-panel .accordion-button {
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}
.qh-order-panel .accordion-button::after { display: none !important; }
.qh-order-panel { background: rgba(30,37,56,.45) !important; border-radius: 20px !important; }
.qh-order-panel .accordion-body { background: transparent !important; padding: 0 !important; }
.qh-panel-header:focus { outline: none; box-shadow: none; }

/* ── Product configuration form ─────────────────────────────── */
#product-configuration .form-label { font-size: .75rem; text-transform: uppercase; letter-spacing: .07em; font-weight: 600; color: var(--qh-muted); }
#product-configuration .form-control, #product-configuration .form-select {
  background: rgba(13,19,33,.6) !important;
  border: 1px solid rgba(112,117,134,.12) !important;
  border-radius: 12px !important;
  color: var(--qh-on-surface) !important;
}
#product-configuration .form-control:focus, #product-configuration .form-select:focus {
  border-color: rgba(98,208,255,.4) !important;
  box-shadow: 0 0 0 3px rgba(98,208,255,.05) !important;
}

/* ── Full width for public layout ────────────────────────────── */
.layout-public-full { padding: 0; margin: 0; }
