/* ============================================================
   FIRST OCEAN • Admin Panel — Black & White Neon Design
   ============================================================ */

/* ---- Google Fonts ---- */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600&family=Manrope:wght@400;500;600;700;800&display=swap&subset=cyrillic');

/* ============ Root / Tokens ============ */
:root {
  /* Backgrounds */
  --bg:   #050505;
  --bg2:  #080808;
  --bg3:  #0b0b0b;
  --panel:  rgba(18,18,18,.98);
  --panel2: rgba(22,22,22,.96);
  --card:   #1a1a1a;

  /* Strokes */
  --stroke:  rgba(255,255,255,.18);
  --stroke2: rgba(255,255,255,.08);
  --stroke3: rgba(255,255,255,.04);

  /* Text */
  --text:  rgba(245,245,245,.96);
  --muted: rgba(160,160,160,.80);
  --dim:   rgba(120,120,120,.65);

  /* Neon accents */
  --neon:  #ffffff;
  --neon2: #00e5ff;
  --neon3: rgba(255,255,255,.85);

  /* States */
  --danger: #ff3b5c;
  --warn:   #ffcc44;
  --ok:     #00e5a0;

  /* Shadows / Glow */
  --shadow:    0 20px 60px rgba(0,0,0,.90);
  --glow-sm:   0 0 12px rgba(255,255,255,.12);
  --glow-md:   0 0 24px rgba(255,255,255,.14);
  --glow-lg:   0 0 40px rgba(255,255,255,.10);
  --glow-neon: 0 0 18px rgba(255,255,255,.25), 0 0 36px rgba(255,255,255,.10);

  /* Shape */
  --radius:  16px;
  --radius2: 22px;
  --radius3: 12px;

  /* Typography */
  --sans: "Space Grotesk", "Manrope", "Inter", ui-sans-serif, system-ui, -apple-system, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;

  /* Easing */
  --ease-out: cubic-bezier(.22,.68,0,1.2);
  --ease-smooth: cubic-bezier(.4,0,.2,1);
}

/* Alternate themes just keep same neon palette */
:root[data-theme="midnight"],
:root[data-theme="onyx"] {
  --bg:  #000000;
  --bg2: #020204;
  --text: rgba(248,248,255,.96);
}

/* ============ Base Reset ============ */
*, *::before, *::after { box-sizing: border-box; }

html, body { height: 100%; }

body {
  margin: 0;
  background:
    radial-gradient(ellipse 80vw 50vh at 50% -10%, rgba(255,255,255,.03), transparent 70%),
    radial-gradient(ellipse 60vw 40vh at 100% 5%, rgba(0,229,255,.025), transparent 65%),
    var(--bg);
  color: var(--text);
  font-family: var(--sans);
  font-size: 14px;
  line-height: 1.5;
  letter-spacing: .01em;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  scroll-behavior: smooth;
}

/* ---- Scrollbar ---- */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(255,255,255,.14); border-radius: 99px; }
::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,.24); }
* { scrollbar-width: thin; scrollbar-color: rgba(255,255,255,.14) transparent; }

/* ---- Background orbs (very subtle) ---- */
.bg-orb {
  position: fixed;
  width: 50vmax;
  height: 50vmax;
  border-radius: 50%;
  filter: blur(90px);
  opacity: .05;
  pointer-events: none;
  z-index: -1;
  animation: orbFloat 20s ease-in-out infinite;
}
.bg-orb--left {
  left: -18vmax;
  top: -15vmax;
  background: radial-gradient(circle, rgba(255,255,255,.5), transparent 65%);
}
.bg-orb--right {
  right: -16vmax;
  bottom: -20vmax;
  background: radial-gradient(circle, rgba(0,229,255,.4), transparent 65%);
  animation-delay: -8s;
}

/* ============ Boot Screen ============ */
.boot {
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  z-index: 50;
  background: var(--bg);
}
.boot-card {
  width: min(540px, 92vw);
  background: rgba(10,10,10,.96);
  border: 1px solid rgba(255,255,255,.16);
  border-radius: var(--radius2);
  box-shadow: var(--shadow), inset 0 1px 0 rgba(255,255,255,.06);
  padding: 28px 28px 22px;
}
.boot-title {
  font-family: var(--sans);
  font-weight: 700;
  letter-spacing: .14em;
  font-size: 13px;
  text-transform: uppercase;
  color: rgba(245,245,245,.95);
}
.boot-sub {
  margin-top: 10px;
  color: var(--muted);
  font-size: 13px;
}
.boot-bar {
  height: 2px;
  border-radius: 99px;
  background: rgba(255,255,255,.06);
  overflow: hidden;
  margin-top: 18px;
}
.boot-bar__fill {
  width: 0%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.8), #ffffff);
  box-shadow: 0 0 12px rgba(255,255,255,.5), 0 0 24px rgba(255,255,255,.2);
  transition: width .3s var(--ease-smooth);
}
.boot-pct {
  margin-top: 12px;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--dim);
}
.boot-hint {
  margin-top: 16px;
  color: var(--dim);
  font-size: 12px;
  letter-spacing: .04em;
}

.hidden { display: none !important; }

/* ============ App Shell ============ */
.app {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

/* ============ Top Bar ============ */
.topbar {
  position: sticky;
  top: 0;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 18px;
  background: rgba(4,4,4,.92);
  border-bottom: 1px solid rgba(255,255,255,.08);
  backdrop-filter: blur(20px) saturate(1.2);
  -webkit-backdrop-filter: blur(20px) saturate(1.2);
  transition: border-color .3s var(--ease-smooth), background .3s var(--ease-smooth);
}

/* ---- Brand ---- */
.brand { display: flex; align-items: center; gap: 12px; }
.brand__logo {
  width: 40px;
  height: 40px;
  border-radius: 13px;
  overflow: hidden;
  display: grid;
  place-items: center;
  background: rgba(10,10,10,.9);
  border: 1px solid rgba(255,255,255,.20);
  box-shadow: 0 0 18px rgba(255,255,255,.08), inset 0 1px 0 rgba(255,255,255,.08);
  transition: box-shadow .3s var(--ease-smooth), border-color .3s var(--ease-smooth);
}
.brand__logo:hover {
  box-shadow: 0 0 26px rgba(255,255,255,.18), inset 0 1px 0 rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.30);
}
.brand__logo-img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}
.brand__name {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .10em;
  text-transform: uppercase;
  color: rgba(255,255,255,.95);
}
.brand__tag {
  margin-top: 2px;
  color: var(--dim);
  font-size: 11px;
  font-family: var(--mono);
  letter-spacing: .04em;
}

/* ---- Top Actions ---- */
.top-actions { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }

/* ============ Layout Grid ============ */
.layout {
  display: grid;
  grid-template-columns: 270px 1fr;
  gap: 0;
  min-height: calc(100vh - 66px);
}

/* ============ Sidebar ============ */
.sidebar {
  position: sticky;
  top: 66px;
  height: calc(100vh - 66px);
  overflow-y: auto;
  overflow-x: hidden;
  padding: 14px 12px 28px;
  border-right: 1px solid rgba(255,255,255,.07);
  background: rgba(10,10,10,.85);
  backdrop-filter: blur(12px);
}

.sidebar__section {
  background: #181818;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: var(--radius);
  padding: 12px;
  margin-bottom: 10px;
  transition: border-color .25s var(--ease-smooth);
}
.sidebar__section:hover { border-color: rgba(255,255,255,.15); }

.sidebar__title {
  font-size: 10px;
  color: var(--dim);
  letter-spacing: .16em;
  text-transform: uppercase;
  font-family: var(--mono);
  margin-bottom: 10px;
}

/* ---- Nav Buttons ---- */
.nav { display: flex; flex-direction: column; gap: 2px; }

.navbtn {
  width: 100%;
  text-align: left;
  border: 1px solid transparent;
  background: transparent;
  color: rgba(200,200,200,.85);
  border-radius: var(--radius3);
  padding: 9px 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  cursor: pointer;
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 500;
  transition:
    border-color .2s var(--ease-smooth),
    background .2s var(--ease-smooth),
    color .2s var(--ease-smooth),
    box-shadow .2s var(--ease-smooth),
    transform .15s var(--ease-smooth);
}
.navbtn:hover {
  border-color: rgba(255,255,255,.14);
  background: rgba(255,255,255,.05);
  color: rgba(255,255,255,.96);
  transform: translateX(2px);
}
.navbtn:active { transform: translateX(0) scale(.985); }
.navbtn.active {
  border-color: rgba(255,255,255,.22);
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,1);
  box-shadow: 0 0 0 1px rgba(255,255,255,.06) inset, var(--glow-sm);
}
.navbtn__left { display: flex; align-items: center; gap: 9px; }
.navbtn__ico { width: 20px; text-align: center; font-size: 15px; line-height: 1; }
.navbtn__meta { font-size: 10px; color: var(--dim); font-family: var(--mono); letter-spacing: .04em; }

/* ---- Quick Actions ---- */
.quick { display: grid; gap: 6px; }

/* ---- Key-Value rows ---- */
.kv { display: grid; gap: 6px; }
.kv__row { display: flex; justify-content: space-between; align-items: center; gap: 10px; }
.kv__k { color: var(--dim); font-size: 11px; font-family: var(--mono); }
.kv__v { color: rgba(220,220,220,.92); font-size: 12px; }
.mono { font-family: var(--mono); }

/* ============ Main Content Area ============ */
.main { padding: 18px 20px 32px; }

/* ---- Page Header ---- */
.page-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
  flex-wrap: wrap;
}
.page-head__left { display: flex; flex-direction: column; gap: 4px; }
.page-head__right {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  flex-wrap: nowrap;
}

/* Breadcrumbs */
.crumbs {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 10px;
  color: var(--dim);
  font-family: var(--mono);
  text-transform: uppercase;
  letter-spacing: .10em;
  margin-bottom: 4px;
}
.crumbs__item { color: rgba(140,140,140,.80); }
.crumbs__sep { color: rgba(80,80,80,.70); }

.page-title {
  margin: 0;
  font-size: 26px;
  font-weight: 700;
  letter-spacing: .01em;
  color: rgba(255,255,255,.97);
  line-height: 1.2;
}
.page-hint {
  color: var(--muted);
  font-size: 12px;
  max-width: 760px;
  line-height: 1.6;
}

/* ---- Date Range Controls ---- */
.range {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.range__chips {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-wrap: wrap;
}

.chip {
  border: 1px solid rgba(255,255,255,.09);
  background: rgba(255,255,255,.03);
  color: rgba(200,200,200,.88);
  padding: 6px 11px;
  border-radius: 99px;
  cursor: pointer;
  font-size: 12px;
  font-family: var(--sans);
  font-weight: 500;
  transition:
    border-color .2s var(--ease-smooth),
    background .2s var(--ease-smooth),
    color .2s var(--ease-smooth),
    transform .15s var(--ease-smooth),
    box-shadow .2s var(--ease-smooth);
}
.chip:hover {
  border-color: rgba(255,255,255,.22);
  background: rgba(255,255,255,.07);
  color: rgba(255,255,255,.97);
  transform: translateY(-1px);
}
.chip:active { transform: translateY(0); }
.chip.active {
  border-color: rgba(255,255,255,.30);
  background: rgba(255,255,255,.10);
  color: rgba(255,255,255,1);
  box-shadow: var(--glow-sm);
}

.range__dates {
  display: flex;
  align-items: flex-end;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

/* ---- Form Fields ---- */
.field { display: grid; gap: 5px; }
.field__label {
  font-size: 10px;
  color: var(--dim);
  font-family: var(--mono);
  text-transform: uppercase;
  letter-spacing: .08em;
}

input[type="date"],
input[type="text"],
input[type="number"],
input[type="email"],
input[type="password"],
input[type="search"],
textarea,
select {
  background: rgba(10,10,10,.80);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: var(--radius3);
  padding: 9px 12px;
  color: rgba(240,240,240,.95);
  font-family: var(--sans);
  font-size: 13px;
  outline: none;
  transition: border-color .2s var(--ease-smooth), box-shadow .2s var(--ease-smooth);
  appearance: none;
  -webkit-appearance: none;
}
textarea { min-height: 110px; resize: vertical; }
input:focus, textarea:focus, select:focus {
  border-color: rgba(255,255,255,.32);
  box-shadow: 0 0 0 3px rgba(255,255,255,.07), var(--glow-sm);
}
select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='rgba(180,180,180,0.7)' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  padding-right: 30px;
}
.filter-select {
  min-width: 150px;
  padding: 8px 30px 8px 12px;
  border-radius: var(--radius3);
  border: 1px solid rgba(255,255,255,.10);
  background-color: rgba(10,10,10,.80);
  color: var(--text);
  font-size: 13px;
}

/* ============ Buttons ============ */
.btn,
.ghost-btn,
.icon-btn {
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: rgba(225,225,225,.92);
  border-radius: var(--radius3);
  padding: 9px 14px;
  cursor: pointer;
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 500;
  line-height: 1;
  white-space: nowrap;
  transition:
    transform .18s var(--ease-smooth),
    border-color .2s var(--ease-smooth),
    background .2s var(--ease-smooth),
    box-shadow .2s var(--ease-smooth),
    color .2s var(--ease-smooth);
}
.btn:hover, .ghost-btn:hover, .icon-btn:hover {
  border-color: rgba(255,255,255,.28);
  background: rgba(255,255,255,.09);
  color: rgba(255,255,255,1);
  box-shadow: 0 4px 20px rgba(0,0,0,.4), var(--glow-sm);
}
.btn:active, .ghost-btn:active, .icon-btn:active {
  transform: translateY(1px) scale(.98);
  box-shadow: none;
}

.ghost-btn { padding: 9px 13px; }
.ghost-btn.danger {
  border-color: rgba(255,59,92,.20);
  color: rgba(255,100,120,.85);
}
.ghost-btn.danger:hover {
  border-color: rgba(255,59,92,.40);
  background: rgba(255,59,92,.08);
  color: rgba(255,100,120,1);
  box-shadow: 0 0 14px rgba(255,59,92,.12);
}

.icon-btn {
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border-radius: var(--radius3);
  padding: 0;
  font-size: 16px;
}

.btn--primary,
.btn.primary,
.btn.btn--primary {
  border-color: rgba(255,255,255,.30);
  background: rgba(255,255,255,.10);
  color: rgba(255,255,255,1);
  font-weight: 600;
}
.btn--primary:hover,
.btn.primary:hover {
  border-color: rgba(255,255,255,.45);
  background: rgba(255,255,255,.16);
  box-shadow: 0 0 24px rgba(255,255,255,.12), 0 6px 20px rgba(0,0,0,.4);
}
.btn:disabled, .btn.is-loading {
  opacity: .45;
  cursor: not-allowed;
  pointer-events: none;
}

/* ============ API Status Pill ============ */
.pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 11px;
  border-radius: 99px;
  border: 1px solid rgba(255,255,255,.09);
  background: rgba(10,10,10,.60);
}
.pill__label {
  font-size: 10px;
  color: var(--dim);
  font-family: var(--mono);
  text-transform: uppercase;
  letter-spacing: .08em;
}
.pill__value {
  font-size: 11px;
  color: rgba(220,220,220,.90);
  font-family: var(--mono);
}

/* ============ Content Area ============ */
.content {
  display: grid;
  gap: 14px;
  transition:
    opacity .25s var(--ease-smooth),
    transform .25s var(--ease-smooth),
    filter .25s var(--ease-smooth);
}
.content.is-loading {
  opacity: .60;
  transform: translateY(2px) scale(.998);
  filter: blur(.3px);
  pointer-events: none;
}
.content.route-enter { opacity: 1; }
.content.route-enter .card {
  opacity: 0;
  transform: translateY(10px);
  animation: cardIn .32s var(--ease-smooth) forwards;
}
.content.route-enter .card:nth-child(1) { animation-delay: .02s; }
.content.route-enter .card:nth-child(2) { animation-delay: .05s; }
.content.route-enter .card:nth-child(3) { animation-delay: .08s; }
.content.route-enter .card:nth-child(4) { animation-delay: .11s; }
.content.route-enter .card:nth-child(5) { animation-delay: .14s; }
.content.route-enter .card:nth-child(n+6) { animation-delay: .17s; }
@keyframes cardIn { to { opacity:1; transform:translateY(0); } }

/* ============ Grid System ============ */
.grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 14px;
}

/* ============ Cards ============ */
.card {
  grid-column: span 12;
  background: #1c1c1c;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--radius2);
  box-shadow: 0 4px 28px rgba(0,0,0,.80), inset 0 1px 0 rgba(255,255,255,.06);
  padding: 16px;
  overflow: hidden;
  transition:
    transform .24s var(--ease-smooth),
    border-color .24s var(--ease-smooth),
    box-shadow .24s var(--ease-smooth);
}
.card:hover {
  transform: translateY(-2px);
  border-color: rgba(255,255,255,.22);
  box-shadow: 0 16px 48px rgba(0,0,0,.85), 0 0 0 1px rgba(255,255,255,.06);
}
.card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}
.card__title {
  font-weight: 700;
  font-size: 14px;
  letter-spacing: .02em;
  color: rgba(240,240,240,.96);
}
.card__sub {
  color: var(--dim);
  font-size: 11px;
  margin-top: 3px;
  font-family: var(--mono);
}
.card__tools {
  display: flex;
  align-items: center;
  gap: 7px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

/* ============ KPI Tiles ============ */
.kpi {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 14px;
  border-radius: var(--radius);
  background: #222222;
  border: 1px solid rgba(255,255,255,.10);
  position: relative;
  overflow: hidden;
  transition: border-color .22s var(--ease-smooth), box-shadow .22s var(--ease-smooth);
}
.kpi:hover {
  border-color: rgba(255,255,255,.16);
  box-shadow: var(--glow-sm);
}
.kpi::after {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.08), transparent);
  pointer-events: none;
}
.kpi__k {
  font-size: 11px;
  color: var(--dim);
  font-family: var(--mono);
  text-transform: uppercase;
  letter-spacing: .08em;
}
.kpi__v {
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -.01em;
  color: rgba(255,255,255,.97);
  line-height: 1;
}
.kpi__h {
  font-size: 11px;
  color: var(--dim);
  font-family: var(--mono);
}

/* ============ Table ============ */
.table-wrap { overflow-x: auto; border-radius: var(--radius); }
.table {
  width: 100%;
  border-collapse: collapse;
  border-radius: var(--radius);
  overflow: hidden;
}
.table th, .table td {
  padding: 10px 12px;
  border-bottom: 1px solid rgba(255,255,255,.05);
  vertical-align: top;
  font-size: 13px;
  text-align: left;
}
.table th {
  color: var(--dim);
  font-size: 10px;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-family: var(--mono);
  font-weight: 500;
  position: sticky;
  top: 0;
  background: rgba(6,6,6,.92);
  backdrop-filter: blur(8px);
}
.table tr:hover td { background: rgba(255,255,255,.025); }
.table td a {
  color: rgba(200,200,200,.85);
  text-decoration: none;
  transition: color .2s var(--ease-smooth);
}
.table td a:hover { color: rgba(255,255,255,1); text-decoration: underline; }

/* ============ Charts ============ */
.chart-canvas {
  width: 100%;
  height: 320px;
  min-height: 280px;
  display: block;
  border-radius: var(--radius3);
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(6,6,6,.60);
}

/* ============ Badges ============ */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 10px;
  border-radius: 99px;
  font-size: 11px;
  font-family: var(--mono);
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  transition: border-color .2s var(--ease-smooth), box-shadow .2s var(--ease-smooth);
}
.badge.ok {
  border-color: rgba(0,229,160,.28);
  background: rgba(0,229,160,.06);
  color: rgba(0,229,160,.90);
}
.badge.warn {
  border-color: rgba(255,204,68,.28);
  background: rgba(255,204,68,.06);
  color: rgba(255,204,68,.90);
}
.badge.bad {
  border-color: rgba(255,59,92,.28);
  background: rgba(255,59,92,.06);
  color: rgba(255,59,92,.90);
}

/* ============ Modal ============ */
.modal { position: fixed; inset: 0; z-index: 40; }
.modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.75);
  backdrop-filter: blur(10px);
}
.modal__card {
  position: relative;
  width: min(840px, 95vw);
  margin: 5vh auto;
  max-height: 90vh;
  background: rgba(8,8,8,.98);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: var(--radius2);
  box-shadow: 0 40px 100px rgba(0,0,0,.90), var(--glow-sm);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  animation: modalIn .22s var(--ease-smooth);
}
.modal__head {
  padding: 14px 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  border-bottom: 1px solid rgba(255,255,255,.07);
}
.modal__title {
  font-weight: 700;
  font-size: 15px;
  letter-spacing: .02em;
  color: rgba(245,245,245,.97);
}
.modal__body {
  padding: 16px;
  overflow: auto;
  flex: 1 1 auto;
  min-height: 0;
}
.modal__foot {
  padding: 12px 16px;
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
  border-top: 1px solid rgba(255,255,255,.07);
}

/* ============ Toasts ============ */
.toasts {
  position: fixed;
  right: 16px;
  bottom: 16px;
  display: grid;
  gap: 8px;
  z-index: 60;
  pointer-events: none;
}
.toast {
  width: min(400px, 92vw);
  padding: 13px 14px;
  border-radius: var(--radius);
  background: rgba(10,10,10,.97);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: var(--shadow);
  animation: toastIn .22s var(--ease-smooth);
  pointer-events: all;
}
.toast__t { font-weight: 700; font-size: 13px; }
.toast__m { margin-top: 5px; color: var(--muted); font-size: 12px; line-height: 1.5; }
.toast.ok  { border-color: rgba(0,229,160,.25); }
.toast.warn { border-color: rgba(255,204,68,.25); }
.toast.bad  { border-color: rgba(255,59,92,.25); }

/* ============ Quick Rail ============ */
.quick-rail {
  position: fixed;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 20;
  display: grid;
  gap: 6px;
}
.quick-rail .icon-btn {
  width: 38px;
  height: 38px;
  background: rgba(8,8,8,.90);
  border-color: rgba(255,255,255,.14);
  backdrop-filter: blur(8px);
}
.quick-rail .icon-btn:hover {
  border-color: rgba(255,255,255,.30);
  box-shadow: var(--glow-sm);
}

/* ============ Command Palette ============ */
.cmdk {
  position: fixed;
  inset: 0;
  z-index: 70;
}
.cmdk__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.72);
  backdrop-filter: blur(12px);
}
.cmdk__dialog {
  position: relative;
  width: min(720px, 94vw);
  margin: 8vh auto 0;
  border-radius: var(--radius2);
  background: rgba(8,8,8,.98);
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: 0 40px 100px rgba(0,0,0,.85), var(--glow-sm);
  overflow: hidden;
  animation: fadeInUp .2s var(--ease-smooth);
}
.cmdk__head {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border-bottom: 1px solid rgba(255,255,255,.07);
}
.cmdk__input {
  width: 100%;
  border: none !important;
  background: transparent !important;
  border-radius: 0 !important;
  outline: none;
  color: rgba(240,240,240,.96);
  font-family: var(--sans);
  font-size: 15px;
  font-weight: 500;
  padding: 6px 8px !important;
}
.cmdk__kbd {
  padding: 5px 9px;
  border-radius: 7px;
  border: 1px solid rgba(255,255,255,.16);
  font-family: var(--mono);
  font-size: 11px;
  color: var(--dim);
  flex-shrink: 0;
}
.cmdk__list {
  max-height: 50vh;
  overflow: auto;
  padding: 8px;
  display: grid;
  gap: 4px;
}
.cmdk__item {
  border: 1px solid transparent;
  border-radius: var(--radius3);
  background: transparent;
  color: rgba(210,210,210,.90);
  text-align: left;
  padding: 10px 12px;
  cursor: pointer;
  font-family: var(--sans);
  font-size: 13px;
  transition: all .15s var(--ease-smooth);
}
.cmdk__item:hover, .cmdk__item.active {
  border-color: rgba(255,255,255,.16);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,1);
}
.cmdk__title { font-weight: 600; }
.cmdk__hint { margin-top: 3px; color: var(--dim); font-size: 11px; font-family: var(--mono); }

/* ============ Loading States ============ */
.loading-card { display: grid; gap: 12px; }
.skeleton {
  position: relative;
  overflow: hidden;
  border-radius: 10px;
  background: rgba(20,20,20,.80);
}
.skeleton::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent 25%, rgba(255,255,255,.05) 50%, transparent 75%);
  background-size: 200% 100%;
  animation: shimmer 1.4s linear infinite;
}
.skeleton--title  { height: 20px; width: min(280px, 60%); }
.skeleton--line   { height: 12px; width: 100%; }
.skeleton--line.short { width: 55%; }
.skeleton--grid   { display: grid; gap: 8px; grid-template-columns: repeat(3, minmax(0,1fr)); }
.skeleton--tile   { height: 80px; border-radius: 14px; }

/* ============ Route Progress Bar ============ */
.route-loader {
  position: fixed;
  left: 0; top: 0;
  width: 100%; height: 2px;
  z-index: 120;
  opacity: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.80), rgba(255,255,255,1), transparent);
  background-size: 30% 100%;
  box-shadow: 0 0 8px rgba(255,255,255,.40);
  transition: opacity .2s var(--ease-smooth);
}
body[data-busy="1"] .route-loader {
  opacity: 1;
  animation: routeFlow 1.1s linear infinite;
}

/* ============ Animations ============ */
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes modalIn {
  from { opacity: 0; transform: translateY(14px) scale(.98); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes toastIn {
  from { opacity: 0; transform: translateY(12px) translateX(6px); }
  to   { opacity: 1; transform: translateY(0) translateX(0); }
}
@keyframes shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
@keyframes routeFlow {
  from { background-position: 130% 0; }
  to   { background-position: -30% 0; }
}
@keyframes orbFloat {
  0%, 100% { transform: translate3d(0,0,0); }
  50%       { transform: translate3d(0,-2.5vmax,0); }
}

/* ============ Responsive ============ */
@media (max-width: 1000px) {
  .layout { grid-template-columns: 240px 1fr; }
}
@media (max-width: 800px) {
  .layout { grid-template-columns: 1fr; }
  .sidebar {
    position: relative;
    top: auto;
    height: auto;
    border-right: none;
    border-bottom: 1px solid rgba(255,255,255,.06);
  }
  .main { padding: 12px 12px 24px; }
  .quick-rail {
    right: 10px;
    top: auto;
    bottom: 14px;
    transform: none;
    grid-auto-flow: column;
  }
}
@media (max-width: 520px) {
  .top-actions { gap: 6px; }
  .brand__tag { display: none; }
  .range__dates { width: 100%; }
  input[type="date"] { width: 150px; }
  .page-title { font-size: 20px; }
}

/* ============ Accessibility ============ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation: none !important;
    transition: none !important;
    scroll-behavior: auto !important;
  }
  .bg-orb { display: none; }
  .route-loader { display: none; }
}

/* ============ Selection ============ */
::selection {
  background: rgba(255,255,255,.18);
  color: rgba(255,255,255,1);
}
