/* =============================================================================
   Scanntoss Console - shared dashboard surface for storefront & admin areas.
   Pulls colour tokens from scanntoss.css (--marine / --purple / --teal / --grad)
   so every console matches the marketing/home palette.
   Responsive: desktop sidebar collapses into a slide-out drawer at <= 960px,
   and the layout reflows for PWA contexts via .console--pwa.
   ============================================================================= */

:root {
  --console-bg:        #f5f7fb;
  --console-surface:   #ffffff;
  --console-surface-2: #f9fafd;
  --console-ink:       #0b1020;
  --console-ink-soft:  #3a3f4e;
  --console-ink-mute:  #6b7280;
  --console-line:      #e5e7eb;
  --console-line-soft: #eef0f5;
  --console-radius:    18px;
  --console-radius-sm: 12px;
  --console-radius-pill: 999px;
  --console-shadow:    0 14px 36px rgba(11, 16, 32, 0.07);
  --console-shadow-lg: 0 30px 60px rgba(11, 16, 32, 0.12);
  --console-grad:      linear-gradient(135deg, #0b4f8a 0%, #6d28d9 52%, #0d9488 100%);
  --console-grad-soft: linear-gradient(135deg, rgba(11,79,138,0.10), rgba(109,40,217,0.10), rgba(13,148,136,0.10));
  --console-grad-text: linear-gradient(135deg, #0b4f8a, #6d28d9 60%, #0d9488);
  --console-sidebar-w: 248px;
  --console-topbar-h:  64px;
}

/* ---------------------------------------------------------------- shell */
.console {
  background: var(--console-bg);
  min-height: 100vh;
  color: var(--console-ink);
  font-family: 'Plus Jakarta Sans', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  display: grid;
  grid-template-columns: var(--console-sidebar-w) 1fr;
  grid-template-rows: var(--console-topbar-h) 1fr;
  grid-template-areas:
    "topbar topbar"
    "sidebar main";
}

.console__topbar {
  grid-area: topbar;
  position: sticky;
  top: 0;
  z-index: 40;
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0 clamp(1rem, 3vw, 1.75rem);
  background: rgba(255, 255, 255, 0.96);
  border-bottom: 1px solid var(--console-line-soft);
  backdrop-filter: saturate(160%) blur(14px);
  -webkit-backdrop-filter: saturate(160%) blur(14px);
}
.console__brand {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  text-decoration: none;
  color: var(--console-ink);
  font-family: "Fraunces", Georgia, "Times New Roman", serif;
  font-variation-settings: "opsz" 144, "SOFT" 60;
  font-weight: 500;
  font-size: 1.3rem;
  letter-spacing: -.01em;
  line-height: 1;
}
.console__brand-mark {
  width: 36px; height: 36px; border-radius: 8px;
  background: linear-gradient(135deg, #0b4f8a 0%, #6d28d9 52%, #0d9488 100%);
  display: inline-grid; place-items: center;
  color: #fff; font-weight: 600; font-family: 'Fraunces', Georgia, serif;
  font-variation-settings: "opsz" 144, "SOFT" 80;
  font-size: 1.35rem; line-height: 1;
  box-shadow: 0 6px 18px rgba(109, 40, 217, .28);
  flex: 0 0 auto;
}
.console__brand small {
  display: inline-block; margin-left: .5rem;
  font-family: "Plus Jakarta Sans", system-ui, sans-serif;
  font-size: .68rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--console-ink-mute); font-weight: 700;
  vertical-align: middle;
}
.console__topbar-spacer { flex: 1; }
.console__topbar-actions { display: flex; align-items: center; gap: .55rem; }
.console__topbar-actions .console-btn { padding: .5rem .9rem; }

/* Compact language picker shown in the admin / dashboard topbar. */
.console__lang-switch {
  display: inline-flex; align-items: center;
}
.console__lang-switch select {
  font: inherit; font-weight: 700; font-size: .8rem;
  min-height: 32px; padding: 0 .55rem;
  background: var(--console-surface, #fff);
  color: var(--console-ink, #1f2937);
  border: 1px solid var(--console-line-soft, #e5e7eb);
  border-radius: 999px;
  cursor: pointer;
}
.console__lang-switch select:focus-visible {
  outline: 2px solid var(--console-accent, #6d28d9); outline-offset: 2px;
}
.console__hamburger {
  display: none;
  appearance: none; background: transparent; border: 0;
  width: 40px; height: 40px; border-radius: 10px;
  align-items: center; justify-content: center;
  cursor: pointer;
}
.console__hamburger:hover { background: var(--console-line-soft); }
.console__hamburger span,
.console__hamburger span::before,
.console__hamburger span::after {
  display: block; width: 22px; height: 2px;
  background: var(--console-ink); border-radius: 2px;
  position: relative;
}
.console__hamburger span::before,
.console__hamburger span::after { content: ""; position: absolute; left: 0; }
.console__hamburger span::before { top: -7px; }
.console__hamburger span::after  { top:  7px; }

.console__chip {
  display: inline-flex; align-items: center; gap: .35rem;
  padding: .25rem .65rem; border-radius: var(--console-radius-pill);
  background: var(--console-grad-soft);
  color: #0b1020; font-weight: 700; font-size: .78rem; letter-spacing: .04em;
}
.console__chip strong { font-weight: 800; }
.console__chip .dot {
  width: 8px; height: 8px; border-radius: 50%; background: var(--console-grad);
  box-shadow: 0 0 0 3px rgba(13, 148, 136, .18);
}

/* ---------------------------------------------------------------- sidebar */
.console__sidebar {
  grid-area: sidebar;
  position: sticky; top: var(--console-topbar-h);
  height: calc(100vh - var(--console-topbar-h));
  background: var(--console-surface);
  border-right: 1px solid var(--console-line-soft);
  padding: 1.25rem .85rem 1.5rem;
  overflow-y: auto;
}
.console__sidebar-section {
  display: grid; gap: .35rem; padding-bottom: 1rem;
}
.console__sidebar-section + .console__sidebar-section { border-top: 1px solid var(--console-line-soft); padding-top: 1rem; }
.console__sidebar-label {
  font-size: .68rem; font-weight: 800; letter-spacing: .14em; text-transform: uppercase;
  color: var(--console-ink-mute); padding: 0 .65rem .25rem;
}
.console__nav-link {
  display: flex; align-items: center; gap: .65rem;
  padding: .55rem .75rem; border-radius: var(--console-radius-sm);
  color: var(--console-ink-soft); text-decoration: none; font-weight: 600;
  transition: background .15s ease, color .15s ease, transform .05s ease;
}
.console__nav-link:hover,
.console__nav-link:focus-visible {
  background: var(--console-grad-soft);
  color: var(--console-ink);
}
.console__nav-link.is-active {
  background: linear-gradient(135deg, rgba(11,79,138,0.14), rgba(109,40,217,0.14));
  color: #0b1020;
  box-shadow: inset 0 0 0 1px rgba(109, 40, 217, .25);
}
.console__nav-icon {
  width: 28px; height: 28px; flex: none;
  display: grid; place-items: center;
  border-radius: 8px;
  background: var(--console-line-soft); color: var(--console-ink);
  font-size: .82rem; font-weight: 800;
}
.console__nav-link.is-active .console__nav-icon {
  background: var(--console-grad); color: #fff;
  box-shadow: 0 6px 16px rgba(11, 79, 138, .35);
}
.console__nav-meta { margin-left: auto; font-size: .72rem; color: var(--console-ink-mute); font-weight: 700; }

/* mobile drawer behaviour */
.console__sidebar-scrim {
  position: fixed; inset: 0; background: rgba(11,16,32,0.45);
  opacity: 0; visibility: hidden; transition: opacity .2s ease;
  z-index: 49;
}

@media (max-width: 960px) {
  .console {
    grid-template-columns: 1fr;
    grid-template-areas: "topbar" "main";
  }
  .console__hamburger { display: inline-flex; }
  .console__sidebar {
    position: fixed; left: 0; top: var(--console-topbar-h);
    width: min(86%, 320px); height: calc(100vh - var(--console-topbar-h));
    z-index: 50; transform: translateX(-105%);
    transition: transform .25s ease;
    box-shadow: 18px 0 48px rgba(11, 16, 32, .18);
    padding-bottom: 6rem;
  }
  .console.is-drawer-open .console__sidebar { transform: translateX(0); }
  .console.is-drawer-open .console__sidebar-scrim { opacity: 1; visibility: visible; }
}

/* ---------------------------------------------------------------- main */
.console__main {
  grid-area: main;
  padding: clamp(1.25rem, 3vw, 2.25rem);
  display: grid; gap: clamp(1rem, 2.4vw, 1.75rem);
  align-content: start;
}

/* Desktop & tablet (>=961px) -- enforce exactly 25px L/R per design spec.
   Mobile (<=960px) keeps the responsive clamp() so phones don't feel cramped. */
@media (min-width: 961px) {
  .console__main {
    padding-left:  25px;
    padding-right: 25px;
  }
}
.console__hero {
  position: relative;
  padding: clamp(1.25rem, 3vw, 2rem);
  border-radius: var(--console-radius);
  background:
    radial-gradient(circle at top right, rgba(13,148,136,0.18), transparent 55%),
    radial-gradient(circle at bottom left, rgba(109,40,217,0.18), transparent 55%),
    linear-gradient(135deg, #ffffff, #f5f3ff 70%, #ecfeff);
  border: 1px solid var(--console-line-soft);
  box-shadow: var(--console-shadow);
  overflow: hidden;
}
.console__hero::after {
  content: ""; position: absolute; inset: auto -40px -120px auto;
  width: 320px; height: 320px; border-radius: 50%;
  background: var(--console-grad);
  filter: blur(80px); opacity: .35; pointer-events: none;
}
.console__hero-eyebrow {
  display: inline-flex; align-items: center; gap: .55rem;
  font-size: .76rem; font-weight: 800; letter-spacing: .14em; text-transform: uppercase;
  color: var(--console-ink-soft);
}
.console__hero-eyebrow .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--console-grad); }
.console__hero h1 {
  font-family: 'Fraunces', Georgia, serif;
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  margin: .35rem 0 .5rem; letter-spacing: -.02em; font-weight: 500;
  color: var(--console-ink);
}
.console__hero p { color: var(--console-ink-soft); max-width: 60ch; margin: 0; }
.console__hero-actions { display: flex; flex-wrap: wrap; gap: .6rem; margin-top: 1rem; }

/* ---------------------------------------------------------------- KPI grid */
.console-kpis {
  display: grid; gap: 1rem;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}
.console-kpi {
  position: relative; overflow: hidden;
  padding: 1.05rem 1.15rem;
  background: var(--console-surface);
  border: 1px solid var(--console-line-soft);
  border-radius: var(--console-radius);
  box-shadow: var(--console-shadow);
}
.console-kpi::before {
  content: ""; position: absolute; inset: 0 auto 0 0;
  width: 4px; background: var(--console-grad);
}
.console-kpi__label {
  font-size: .76rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase;
  color: var(--console-ink-mute);
}
.console-kpi__value {
  font-family: 'Fraunces', Georgia, serif;
  font-size: clamp(1.6rem, 2.4vw, 2.2rem); font-weight: 500; letter-spacing: -.02em;
  color: var(--console-ink); margin: .25rem 0 0;
  font-variant-numeric: tabular-nums;
}
.console-kpi__hint { color: var(--console-ink-mute); font-size: .85rem; margin-top: .25rem; }
.console-kpi--accent::before { background: linear-gradient(180deg, #6d28d9, #0d9488); }
.console-kpi--ok::before     { background: linear-gradient(180deg, #059669, #0d9488); }
.console-kpi--warn::before   { background: linear-gradient(180deg, #f59e0b, #b45309); }
.console-kpi--danger::before { background: linear-gradient(180deg, #dc2626, #7f1d1d); }

/* ---------------------------------------------------------------- cards */
.console-card {
  background: var(--console-surface);
  border: 1px solid var(--console-line-soft);
  border-radius: var(--console-radius);
  box-shadow: var(--console-shadow);
  padding: clamp(1rem, 2.2vw, 1.4rem);
}
.console-card__head {
  display: flex; align-items: flex-start; gap: 1rem; flex-wrap: wrap;
  margin-bottom: 1rem;
}
.console-card__head h2,
.console-card__head h3 {
  font-family: 'Fraunces', Georgia, serif;
  margin: 0;
  font-size: clamp(1.15rem, 1.7vw, 1.35rem);
  letter-spacing: -.01em; font-weight: 500;
}
.console-card__sub { color: var(--console-ink-mute); margin: .15rem 0 0; }
.console-card__actions { margin-left: auto; display: flex; gap: .4rem; flex-wrap: wrap; }
.console-grid { display: grid; gap: 1rem; }
.console-grid--2 { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.console-grid--3 { grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }

/* ---------------------------------------------------------------- buttons */
.console-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .4rem;
  padding: .55rem 1rem;
  border-radius: var(--console-radius-pill);
  border: 1px solid var(--console-line);
  background: #fff; color: var(--console-ink);
  font-weight: 700; font-size: .92rem; text-decoration: none;
  cursor: pointer; transition: transform .05s ease, background .15s ease, border-color .15s ease;
}
.console-btn:hover { background: var(--console-surface-2); }
.console-btn:active { transform: translateY(1px); }
.console-btn--primary {
  background: var(--console-grad); color: #fff; border: none;
  box-shadow: 0 10px 24px rgba(109, 40, 217, .28);
}
.console-btn--primary:hover { filter: brightness(1.04); }
.console-btn--ghost { background: transparent; }
.console-btn--lg { padding: .8rem 1.4rem; font-size: 1rem; }
.console-btn--icon { width: 38px; height: 38px; padding: 0; }

/* ---------------------------------------------------------------- tabs */
.console-tabs { display: grid; gap: 1rem; }
.console-tabs__list {
  display: flex; gap: .35rem; flex-wrap: wrap;
  padding: .35rem; background: var(--console-surface);
  border: 1px solid var(--console-line-soft);
  border-radius: var(--console-radius-pill);
  box-shadow: var(--console-shadow);
}
.console-tabs__btn {
  appearance: none; background: transparent; border: 0;
  padding: .55rem 1rem; border-radius: var(--console-radius-pill);
  color: var(--console-ink-soft); font-weight: 700; cursor: pointer;
  transition: background .15s ease, color .15s ease;
}
.console-tabs__btn:hover { background: var(--console-grad-soft); color: var(--console-ink); }
.console-tabs__btn[aria-selected="true"] {
  background: var(--console-grad); color: #fff;
  box-shadow: 0 10px 24px rgba(11, 79, 138, .28);
}
.console-tabs__panel { display: none; }
.console-tabs__panel.is-active { display: grid; gap: 1rem; }
@media (prefers-reduced-motion: no-preference) {
  .console-tabs__panel.is-active { animation: console-fade .25s ease; }
}
@keyframes console-fade {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* JS-disabled fallback: show every panel stacked */
.no-js .console-tabs__panel { display: grid; gap: 1rem; margin-top: 1rem; }
.no-js .console-tabs__list   { display: none; }

/* ---------------------------------------------------------------- pills */
.console-pill {
  display: inline-flex; align-items: center; gap: .35rem;
  padding: .2rem .6rem; border-radius: var(--console-radius-pill);
  font-size: .76rem; font-weight: 800; letter-spacing: .04em;
  background: var(--console-grad-soft); color: #0b1020;
  text-transform: capitalize;
}
.console-pill--ok      { background: rgba(5, 150, 105, .14); color: #065f46; }
.console-pill--info    { background: rgba(11, 79, 138, .14); color: #0b4f8a; }
.console-pill--warn    { background: rgba(245, 158, 11, .16); color: #92400e; }
.console-pill--danger  { background: rgba(220, 38, 38, .14); color: #991b1b; }
.console-pill--neutral { background: var(--console-line-soft); color: var(--console-ink-soft); }

/* ---------------------------------------------------------------- tables */
.console-table-wrap {
  overflow-x: auto;
  border-radius: var(--console-radius-sm);
  border: 1px solid var(--console-line-soft);
  background: var(--console-surface);
}
.console-table {
  width: 100%; border-collapse: collapse; font-size: .92rem;
  min-width: 480px;
}
.console-table thead th {
  position: sticky; top: 0;
  background: linear-gradient(180deg, #ffffff, #f5f7fb);
  text-align: left; font-weight: 800; font-size: .78rem;
  letter-spacing: .08em; text-transform: uppercase;
  color: var(--console-ink-soft);
  padding: .75rem 1rem;
  border-bottom: 1px solid var(--console-line-soft);
}
.console-table tbody td {
  padding: .75rem 1rem;
  border-bottom: 1px solid var(--console-line-soft);
  vertical-align: top;
}
.console-table tbody tr:last-child td { border-bottom: 0; }
.console-table tbody tr:hover td { background: rgba(11, 79, 138, .03); }
.console-table code {
  font-family: 'JetBrains Mono', ui-monospace, SFMono-Regular, Consolas, monospace;
  font-size: .85rem; background: var(--console-surface-2);
  padding: .12rem .4rem; border-radius: 6px; color: var(--console-ink);
}

.console-empty {
  padding: 2rem; text-align: center;
  color: var(--console-ink-mute);
  border: 1px dashed var(--console-line);
  border-radius: var(--console-radius-sm);
  background: var(--console-surface-2);
}

/* ---------------------------------------------------------------- lists */
.console-list { list-style: none; padding: 0; margin: 0; display: grid; gap: .55rem; }
.console-list li {
  display: flex; gap: .65rem; align-items: flex-start;
  padding: .65rem .75rem;
  background: var(--console-surface-2);
  border-radius: var(--console-radius-sm);
  border: 1px solid var(--console-line-soft);
}
.console-list li::before {
  content: ""; width: 8px; height: 8px; border-radius: 50%;
  background: var(--console-grad); flex: none; margin-top: .55rem;
}
.console-list a { color: var(--console-ink); text-decoration: none; font-weight: 600; }
.console-list a:hover { color: #6d28d9; text-decoration: underline; }

/* ---------------------------------------------------------------- search */
.console-search {
  display: flex; gap: .5rem; align-items: center;
  padding: .35rem .35rem .35rem 1rem;
  background: var(--console-surface);
  border: 1px solid var(--console-line);
  border-radius: var(--console-radius-pill);
  box-shadow: var(--console-shadow);
  max-width: 480px;
}
.console-search input {
  flex: 1; appearance: none; border: 0; background: transparent;
  font: inherit; color: var(--console-ink); padding: .4rem 0;
}
.console-search input:focus { outline: none; }
.console-search button {
  border: 0; padding: .55rem 1rem; border-radius: var(--console-radius-pill);
  background: var(--console-grad); color: #fff; font-weight: 700; cursor: pointer;
}

/* ---------------------------------------------------------------- alerts */
.console-alert {
  padding: .85rem 1rem;
  border-radius: var(--console-radius-sm);
  font-weight: 600; display: flex; gap: .65rem; align-items: flex-start;
  border: 1px solid var(--console-line);
}
.console-alert--info    { background: rgba(11, 79, 138, .08); color: #0b4f8a; border-color: rgba(11,79,138,.2); }
.console-alert--ok      { background: rgba(5, 150, 105, .08); color: #065f46; border-color: rgba(5,150,105,.22); }
.console-alert--warn    { background: rgba(245, 158, 11, .12); color: #92400e; border-color: rgba(245,158,11,.32); }
.console-alert--danger  { background: rgba(220, 38, 38, .08); color: #991b1b; border-color: rgba(220,38,38,.25); }

/* ---------------------------------------------------------------- embedded mode
   For pages (e.g. the customer dashboard) that render inside an existing
   storefront layout. Strips the sidebar / topbar chrome and lets the parent
   header + footer wrap the content. */
.console--embedded {
  display: block;
  background: transparent;
  min-height: auto;
  grid-template-columns: 1fr;
  grid-template-areas: "main";
}
.console--embedded > .console__topbar,
.console--embedded > .console__sidebar,
.console--embedded > .console__sidebar-scrim { display: none; }
.console--embedded > .console__main {
  padding: clamp(1rem, 3vw, 2rem) 0;
}

/* ---------------------------------------------------------------- PWA tweaks */
.console--pwa { padding-bottom: calc(64px + env(safe-area-inset-bottom)); }
.console--pwa .console__sidebar { display: none; }
.console--pwa { grid-template-columns: 1fr; grid-template-areas: "topbar" "main"; }
.console--pwa .console__topbar { padding-top: calc(.65rem + env(safe-area-inset-top)); }
.console--pwa .console__main   { padding: 1rem; gap: 1rem; }
.console--pwa .console__hero h1 { font-size: clamp(1.4rem, 5vw, 1.9rem); }
.console--pwa .console-tabs__list { overflow-x: auto; flex-wrap: nowrap; }
.console--pwa .console-tabs__btn { white-space: nowrap; }
.console--embedded.console--pwa > .console__main { padding: 1rem 0; }

/* ---------------------------------------------------------------- print */
@media print {
  .console__sidebar, .console__topbar, .console-tabs__list { display: none !important; }
  .console__main { padding: 0; }
  .console-card  { box-shadow: none; border-color: #ccc; }
}
