/* ============================================================================
   TCP 3.0 — Admin Portal "Continental Control"
   Dark graphite engineering control room. Extends shared/tokens.css.
   ========================================================================== */

:root {
  --page: var(--conti-ink);            /* #16181d */
  --panel: #1b1f27;
  --panel-2: #21262f;
  --panel-3: #272d38;
  --hair: rgba(255,255,255,.08);
  --hair-2: rgba(255,255,255,.05);
  --tx: #e7e3da;
  --tx-mut: #9a958c;
  --tx-faint: #6b6760;
  --sidebar-w: 248px;
}

html, body { height: 100%; }
body {
  background: var(--page);
  color: var(--tx);
  font-family: var(--body);
  overflow: hidden;
}

.app { display: grid; grid-template-columns: var(--sidebar-w) 1fr; height: 100vh; }

/* ===================== SIDEBAR ===================== */
.sidebar {
  position: relative;
  display: flex; flex-direction: column;
  background: linear-gradient(180deg, #14161b, #101216);
  border-right: 1px solid var(--hair);
  padding: 22px 16px 16px;
  z-index: 5;
}
.sidebar::before {
  content:''; position:absolute; top:0; right:0; width:2px; height:100%;
  background: linear-gradient(180deg, transparent, rgba(255,122,0,.5), transparent);
  opacity:.5;
}
.brand { display:flex; align-items:center; gap:11px; padding: 4px 8px 22px; }
.horse { width: 30px; height: 33px; filter: drop-shadow(0 2px 8px rgba(255,122,0,.4)); }
.brand-tx { display:flex; flex-direction:column; line-height:1.1; }
.brand-name { font-family: var(--display); font-weight:700; font-size:18px; letter-spacing:-.02em; color:#fff; }
.brand-sub { font-size:9.5px; letter-spacing:.16em; color: var(--conti-orange); margin-top:3px; }

.nav { display:flex; flex-direction:column; gap:3px; flex:1; }
.nav-label {
  font-family: var(--mono); font-size:10px; letter-spacing:.18em; text-transform:uppercase;
  color: var(--tx-faint); margin: 16px 10px 7px;
}
.nav-item {
  display:flex; align-items:center; gap:11px;
  background: transparent; border:0; cursor:pointer;
  font-family: var(--body); font-weight:600; font-size:14px; color: var(--tx-mut);
  padding: 10px 12px; border-radius: 11px; text-align:left; width:100%;
  position:relative; transition: background .2s var(--ease), color .2s, transform .15s var(--ease);
}
.nav-item .ni { font-size:15px; width:18px; text-align:center; opacity:.7; }
.nav-item:hover { background: var(--hair-2); color: var(--tx); }
.nav-item.active { background: linear-gradient(90deg, rgba(255,122,0,.16), rgba(255,122,0,.04)); color:#fff; }
.nav-item.active::before {
  content:''; position:absolute; left:-16px; top:50%; transform:translateY(-50%);
  width:3px; height:20px; border-radius:0 3px 3px 0; background: var(--conti-orange);
}
.badge {
  margin-left:auto; font-family: var(--mono); font-size:10.5px; font-weight:600;
  min-width:18px; height:18px; padding:0 5px; border-radius:999px;
  background: var(--conti-orange); color:#fff; display:none; align-items:center; justify-content:center;
}
.badge.show { display:inline-flex; }

.side-foot { padding: 10px 8px 4px; }
.side-stat { display:flex; flex-direction:column; gap:2px; margin-bottom:12px; }
.ss-val { font-size:18px; font-weight:600; color: var(--ok); }
.ss-lab { font-size:11px; color: var(--tx-faint); }
.side-tread { height:34px; border-radius:10px; border:1px solid var(--hair); opacity:.6; }

/* ===================== TOPBAR ===================== */
.main { display:flex; flex-direction:column; min-width:0; height:100vh; }
.topbar {
  display:flex; align-items:center; justify-content:space-between;
  padding: 18px 30px; border-bottom:1px solid var(--hair);
  background: linear-gradient(180deg, #1a1d24, #16181d);
  background-blend-mode: overlay; flex-shrink:0;
}
.tb-left { display:flex; flex-direction:column; gap:3px; }
.tb-title { font-size:25px; color:#fff; }
.tb-crumb { font-size:11px; letter-spacing:.1em; color: var(--tx-faint); text-transform:uppercase; }

.tb-right { display:flex; align-items:center; gap:14px; }
.market-sel { display:flex; background: var(--panel); border:1px solid var(--hair); border-radius:999px; padding:3px; }
.mkt {
  border:0; background:transparent; cursor:pointer; font-family:var(--mono); font-weight:600; font-size:12px;
  color: var(--tx-mut); padding:6px 13px; border-radius:999px; transition: all .2s var(--ease);
}
.mkt.active { background: var(--conti-orange); color:#fff; }
.live-ind { display:flex; align-items:center; gap:7px; font-size:11px; letter-spacing:.14em; color: var(--ok); font-weight:600; }
.btn-reset {
  border:1px solid var(--hair); background: var(--panel); color: var(--tx-mut); cursor:pointer;
  font-family:var(--body); font-weight:600; font-size:13px; padding:8px 14px; border-radius:999px;
  transition: all .2s var(--ease);
}
.btn-reset:hover { border-color: rgba(255,122,0,.5); color: var(--conti-orange); }
.user-chip { display:flex; align-items:center; gap:9px; padding-left:14px; border-left:1px solid var(--hair); }
.avatar {
  width:34px; height:34px; border-radius:10px; display:flex; align-items:center; justify-content:center;
  font-family:var(--mono); font-weight:600; font-size:12px; color:#fff;
  background: linear-gradient(135deg, var(--conti-orange), var(--conti-orange-deep));
}
.uc-tx { display:flex; flex-direction:column; line-height:1.2; }
.uc-name { font-size:13px; font-weight:600; color: var(--tx); }
.uc-role { font-size:10px; color: var(--tx-faint); }

/* ===================== STAGE ===================== */
.stage { flex:1; overflow-y:auto; padding: 28px 30px 48px; }
.stage::-webkit-scrollbar { width:10px; }
.stage::-webkit-scrollbar-thumb { background: var(--panel-3); border-radius:6px; border:2px solid var(--page); }

/* generic panel */
.panel {
  background: var(--panel); border:1px solid var(--hair); border-radius: var(--r-md);
  padding: 20px;
}
.panel-h { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.panel-h h2 { font-family:var(--display); font-size:17px; color:#fff; margin:0; letter-spacing:-.01em; }
.panel-h .sub { font-size:12px; color: var(--tx-mut); }

.eyebrow { color: var(--conti-amber); }

/* ===================== DASHBOARD ===================== */
.kpi-grid { display:grid; grid-template-columns: repeat(4, 1fr); gap:16px; margin-bottom:20px; }
@media (max-width:1180px){ .kpi-grid { grid-template-columns: repeat(2,1fr); } }
.kpi {
  position:relative; overflow:hidden;
  background: linear-gradient(165deg, var(--panel-2), var(--panel));
  border:1px solid var(--hair); border-radius: var(--r-md); padding:18px 18px 16px;
}
.kpi::after {
  content:''; position:absolute; right:-30px; top:-30px; width:110px; height:110px; border-radius:50%;
  background: radial-gradient(circle, rgba(255,122,0,.14), transparent 70%);
}
.kpi-lab { font-family:var(--mono); font-size:10.5px; letter-spacing:.12em; text-transform:uppercase; color: var(--tx-mut); }
.kpi-val { font-family:var(--mono); font-weight:600; font-size:38px; color:#fff; margin:8px 0 4px; line-height:1; }
.kpi-val .u { font-size:16px; color: var(--conti-orange); margin-left:3px; }
.kpi-delta { font-size:12px; color: var(--ok); display:flex; align-items:center; gap:5px; }
.kpi-delta.flat { color: var(--tx-faint); }

.dash-cols { display:grid; grid-template-columns: 1.3fr 1fr; gap:20px; }
@media (max-width:980px){ .dash-cols { grid-template-columns:1fr; } }

/* bar mini-chart */
.bars { display:flex; align-items:flex-end; gap:10px; height:140px; padding-top:8px; }
.bar-col { flex:1; display:flex; flex-direction:column; align-items:center; gap:8px; height:100%; justify-content:flex-end; }
.bar {
  width:100%; border-radius:7px 7px 3px 3px;
  background: linear-gradient(180deg, var(--conti-orange), var(--conti-orange-deep));
  transition: height 1s var(--ease-bounce); min-height:4px;
}
.bar.muted { background: linear-gradient(180deg, #3a4150, #2c313c); }
.bar-x { font-family:var(--mono); font-size:10px; color: var(--tx-faint); }

/* segmented gauge */
.gauge-row { display:flex; flex-direction:column; gap:14px; }
.gauge { }
.gauge-top { display:flex; justify-content:space-between; align-items:baseline; margin-bottom:7px; }
.gauge-top .g-name { font-size:13px; color: var(--tx); font-weight:600; }
.gauge-top .g-num { font-family:var(--mono); font-size:13px; color: var(--conti-amber); }
.gauge-track { height:9px; border-radius:999px; background: var(--panel-3); overflow:hidden; }
.gauge-fill { height:100%; border-radius:999px; background: linear-gradient(90deg, var(--conti-orange-deep), var(--conti-amber)); transition: width 1.1s var(--ease); }

/* live activity feed */
.feed-panel { display:flex; flex-direction:column; }
.feed { display:flex; flex-direction:column; gap:1px; overflow-y:auto; max-height: 460px; margin: -4px -6px 0; padding: 0 6px; }
.feed::-webkit-scrollbar { width:8px; }
.feed::-webkit-scrollbar-thumb { background: var(--panel-3); border-radius:6px; }
.feed-row {
  display:flex; gap:12px; align-items:flex-start; padding:11px 6px;
  border-bottom:1px solid var(--hair-2);
}
.feed-row.new { animation: feedIn .55s var(--ease-bounce); }
@keyframes feedIn {
  from { opacity:0; transform: translateX(-12px); background: rgba(255,122,0,.12); }
  to { opacity:1; transform:none; background:transparent; }
}
.feed-ic {
  flex-shrink:0; width:30px; height:30px; border-radius:9px; display:flex; align-items:center; justify-content:center;
  font-size:14px; background: var(--panel-3); border:1px solid var(--hair);
}
.feed-tx { flex:1; min-width:0; }
.feed-main { font-size:13px; color: var(--tx); line-height:1.35; }
.feed-meta { font-family:var(--mono); font-size:10.5px; color: var(--tx-faint); margin-top:3px; letter-spacing:.04em; }
.feed-empty { color: var(--tx-faint); font-size:13px; padding:30px 6px; text-align:center; }

/* ===================== PRODUCTS ===================== */
.prod-grid { display:grid; grid-template-columns: repeat(auto-fill, minmax(248px,1fr)); gap:16px; }
.prod-card {
  background: var(--panel); border:1px solid var(--hair); border-radius: var(--r-md);
  padding:16px; cursor:pointer; transition: transform .25s var(--ease), border-color .25s, box-shadow .25s;
  display:flex; flex-direction:column; gap:10px;
}
.prod-card:hover { transform: translateY(-4px); border-color: rgba(255,122,0,.45); box-shadow: 0 14px 30px rgba(0,0,0,.4); }
.pc-top { display:flex; align-items:center; gap:12px; }
.pc-glyph {
  width:46px; height:46px; border-radius:13px; display:flex; align-items:center; justify-content:center; font-size:24px;
  background: hsl(var(--h,28) 70% 50% / .16); border:1px solid hsl(var(--h,28) 70% 55% / .3);
}
.pc-name { font-family:var(--display); font-size:15px; color:#fff; line-height:1.15; }
.pc-cat { font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color: var(--tx-faint); margin-top:2px; }
.pc-blurb { font-size:12.5px; color: var(--tx-mut); line-height:1.4; min-height:34px; }
.pc-foot { display:flex; align-items:center; justify-content:space-between; padding-top:10px; border-top:1px solid var(--hair-2); }
.pc-price { font-family:var(--mono); font-weight:600; font-size:15px; color: var(--conti-amber); }
.pc-edit { font-size:11px; color: var(--conti-orange); font-weight:600; font-family:var(--mono); }

/* ===================== TABLE / QUEUE ===================== */
.q-list { display:flex; flex-direction:column; gap:10px; }
.q-row {
  display:grid; grid-template-columns: 140px 1fr 150px 130px auto; align-items:center; gap:16px;
  background: var(--panel); border:1px solid var(--hair); border-radius: var(--r-sm); padding:14px 18px;
  transition: border-color .25s;
}
.q-row:hover { border-color: var(--hair); }
.q-id { font-family:var(--mono); font-size:13px; color:#fff; font-weight:600; }
.q-id .when { display:block; font-size:10px; color: var(--tx-faint); font-weight:400; margin-top:3px; }
.q-prod { font-size:13.5px; color: var(--tx); font-weight:600; }
.q-prod .slot { display:block; font-family:var(--mono); font-size:11px; color: var(--tx-mut); margin-top:3px; }
.q-veh { font-size:12.5px; color: var(--tx-mut); }
.q-veh .plate { display:inline-block; font-family:var(--mono); font-size:11px; color: var(--tx); background: var(--panel-3); padding:2px 7px; border-radius:5px; margin-top:4px; border:1px solid var(--hair); }
.q-actions { display:flex; gap:8px; justify-content:flex-end; }
.q-btn {
  border:1px solid var(--hair); background: var(--panel-2); color: var(--tx); cursor:pointer;
  font-family:var(--body); font-weight:600; font-size:12.5px; padding:8px 14px; border-radius:9px;
  transition: all .18s var(--ease);
}
.q-btn:hover { border-color: var(--conti-orange); color: var(--conti-orange); }
.q-btn.primary { background: var(--conti-orange); color:#fff; border-color: transparent; }
.q-btn.primary:hover { filter: brightness(1.08); color:#fff; }
.q-btn:disabled { opacity:.35; cursor:default; }
.q-btn:disabled:hover { border-color: var(--hair); color: var(--tx); }

/* status chips (dark) */
.st {
  display:inline-flex; align-items:center; gap:6px; font-family:var(--mono);
  font-size:11px; font-weight:600; padding:6px 11px; border-radius:999px; letter-spacing:.03em;
}
.st::before { content:''; width:6px; height:6px; border-radius:50%; background: currentColor; }
.st-submitted { background: rgba(154,149,140,.14); color:#b8b2a8; }
.st-accepted  { background: rgba(43,108,176,.18); color:#6fb0ee; }
.st-progress  { background: rgba(255,122,0,.18); color: var(--conti-amber); }
.st-completed { background: rgba(31,157,99,.18); color:#46c98a; }
.st-pending   { background: rgba(217,138,0,.18); color:#e9b44c; }
.st-approved  { background: rgba(31,157,99,.18); color:#46c98a; }
.st-cancelled { background: rgba(154,149,140,.16); color:#9a958c; }
.st-flip { animation: stFlip .6s var(--ease-bounce); }
@keyframes stFlip { 0%{ transform: scale(.6) rotateX(80deg); opacity:0;} 100%{ transform:none; opacity:1;} }

/* empty state */
.empty {
  text-align:center; padding:60px 20px; border:1px dashed var(--hair); border-radius: var(--r-md);
  background: var(--panel);
}
.empty .e-ic { font-size:44px; opacity:.5; }
.empty h3 { font-family:var(--display); color:#fff; font-size:18px; margin:14px 0 6px; }
.empty p { color: var(--tx-mut); font-size:13.5px; margin:0; }

/* ===================== SERVICE CARDS ===================== */
.sc-wrap { display:grid; grid-template-columns: 360px 1fr; gap:20px; align-items:start; }
@media (max-width:900px){ .sc-wrap { grid-template-columns:1fr; } }
.sc-card {
  position:relative; overflow:hidden;
  background: linear-gradient(150deg, #232936, #191d25);
  border:1px solid var(--hair); border-radius: var(--r-lg); padding:24px;
}
.sc-card::before { content:''; position:absolute; inset:0; opacity:.5;
  background: repeating-linear-gradient(135deg, rgba(255,122,0,.05) 0 6px, transparent 6px 16px); }
.sc-top { display:flex; justify-content:space-between; align-items:flex-start; position:relative; }
.sc-name { font-family:var(--display); font-size:18px; color:#fff; }
.sc-ret { font-size:12px; color: var(--tx-mut); margin-top:4px; }
.sc-dots { display:flex; gap:10px; margin:26px 0 22px; position:relative; }
.punch {
  width:38px; height:38px; border-radius:50%; border:2px solid var(--hair);
  display:flex; align-items:center; justify-content:center; font-size:15px; color: var(--tx-faint);
  background: rgba(0,0,0,.2); transition: all .4s var(--ease-bounce);
}
.punch.used { border-color: var(--conti-orange); color:#fff; background: linear-gradient(135deg, var(--conti-orange), var(--conti-orange-deep)); box-shadow: 0 4px 14px rgba(255,122,0,.4); }
.sc-meter { display:flex; align-items:baseline; gap:8px; position:relative; }
.sc-rem { font-family:var(--mono); font-size:34px; font-weight:600; color: var(--conti-amber); }
.sc-of { font-size:13px; color: var(--tx-mut); }
.sc-qr-row { display:flex; align-items:center; gap:8px; margin-top:16px; position:relative; }
.sc-qr-lab { font-family:var(--mono); font-size:10px; letter-spacing:.1em; color: var(--tx-faint); text-transform:uppercase; }
.sc-qr { font-family:var(--mono); font-size:12px; color: var(--tx); background: rgba(0,0,0,.3); padding:5px 10px; border-radius:7px; border:1px solid var(--hair); }
.sc-scan-btn { margin-top:22px; position:relative; width:100%; }

/* ===================== CAMPAIGN ===================== */
.camp-grid { display:grid; grid-template-columns: 1fr 1fr; gap:20px; align-items:start; }
@media (max-width:980px){ .camp-grid { grid-template-columns:1fr; } }
.camp-hero {
  position:relative; overflow:hidden;
  background: linear-gradient(150deg, #2a2030, #1a1620);
  border:1px solid rgba(255,122,0,.25); border-radius: var(--r-lg); padding:26px;
}
.camp-hero::after { content:'◎'; position:absolute; right:-20px; bottom:-40px; font-size:170px; color: rgba(255,122,0,.07); }
.camp-code { font-family:var(--mono); font-size:11px; letter-spacing:.14em; color: var(--conti-orange); }
.camp-name { font-family:var(--display); font-size:26px; color:#fff; margin:8px 0 4px; }
.camp-reward { font-size:13px; color: var(--tx-mut); }
.camp-state { display:inline-flex; align-items:center; gap:8px; margin-top:18px; padding:7px 14px; border-radius:999px; font-family:var(--mono); font-size:12px; font-weight:600; }
.camp-state.on { background: rgba(31,157,99,.18); color:#46c98a; }
.camp-state.off { background: rgba(154,149,140,.16); color: var(--tx-mut); }
.camp-metrics { display:flex; gap:30px; margin:24px 0; position:relative; }
.cm { }
.cm-v { font-family:var(--mono); font-size:30px; font-weight:600; color:#fff; }
.cm-l { font-size:11px; color: var(--tx-mut); margin-top:2px; }
.camp-toggle { position:relative; }

.rule-list { display:flex; flex-direction:column; gap:10px; }
.rule {
  display:flex; align-items:center; gap:13px; padding:12px 14px;
  background: var(--panel-2); border:1px solid var(--hair); border-radius: var(--r-sm);
}
.rule-g { width:38px; height:38px; border-radius:11px; display:flex; align-items:center; justify-content:center; font-size:18px;
  background: hsl(var(--h,28) 65% 50% / .15); border:1px solid hsl(var(--h,28) 65% 55% / .3); }
.rule-tx { flex:1; }
.rule-t { font-size:13.5px; color: var(--tx); font-weight:600; }
.rule-p { font-family:var(--mono); font-size:11px; color: var(--conti-amber); margin-top:2px; }

.coupon-list { display:flex; flex-direction:column; gap:8px; margin-top:14px; }
.coupon {
  display:flex; align-items:center; gap:12px; padding:11px 14px; border-radius: var(--r-sm);
  border:1px dashed var(--hair); background: var(--panel-2);
}
.coupon-code { font-family:var(--mono); font-size:12px; color:#fff; }
.coupon-lab { font-size:12px; color: var(--tx-mut); flex:1; }

/* ===================== WARRANTY ===================== */
.case-list { display:flex; flex-direction:column; gap:10px; }
.case-row {
  display:grid; grid-template-columns: 160px 1fr 150px 130px auto; align-items:center; gap:16px;
  background: var(--panel); border:1px solid var(--hair); border-radius: var(--r-sm); padding:15px 18px;
}
.case-no { font-family:var(--mono); font-size:13px; color:#fff; font-weight:600; }
.case-consumer { font-size:13.5px; color: var(--tx); font-weight:600; }
.case-consumer .acc { display:block; font-family:var(--mono); font-size:11px; color: var(--tx-mut); margin-top:3px; }
.case-dot { font-family:var(--mono); font-size:12px; color: var(--tx-mut); }
.case-dot .l { display:block; font-size:9px; letter-spacing:.1em; text-transform:uppercase; color: var(--tx-faint); }

/* ===================== DRAWER ===================== */
.drawer-scrim {
  position:fixed; inset:0; background: rgba(8,9,12,.6); backdrop-filter: blur(2px);
  opacity:0; pointer-events:none; transition: opacity .3s var(--ease); z-index:40;
}
.drawer-scrim.open { opacity:1; pointer-events:auto; }
.drawer {
  position:fixed; top:0; right:0; height:100vh; width:420px; max-width:92vw; z-index:50;
  background: linear-gradient(180deg, #1d212a, #16181d); border-left:1px solid var(--hair);
  box-shadow: -30px 0 60px rgba(0,0,0,.5);
  transform: translateX(100%); transition: transform .4s var(--ease); padding:26px; overflow-y:auto;
}
.drawer.open { transform: none; }
.dr-h { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:22px; }
.dr-h h2 { font-family:var(--display); font-size:21px; color:#fff; margin:0; }
.dr-h .eyebrow { display:block; margin-bottom:6px; }
.dr-close { background: var(--panel-2); border:1px solid var(--hair); color: var(--tx-mut); width:34px; height:34px; border-radius:10px; cursor:pointer; font-size:16px; }
.dr-close:hover { color:#fff; border-color: var(--conti-orange); }
.dr-preview {
  display:flex; align-items:center; gap:14px; padding:16px; border-radius: var(--r-sm);
  background: var(--panel-2); border:1px solid var(--hair); margin-bottom:22px;
}
.dr-pg { width:52px; height:52px; border-radius:14px; display:flex; align-items:center; justify-content:center; font-size:27px;
  background: hsl(var(--h,28) 70% 50% / .16); border:1px solid hsl(var(--h,28) 70% 55% / .3); }
.field { margin-bottom:18px; }
.field label { display:block; font-family:var(--mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color: var(--tx-mut); margin-bottom:7px; }
.field input, .field textarea {
  width:100%; background: var(--page); border:1px solid var(--hair); border-radius:11px; padding:12px 14px;
  color: var(--tx); font-family:var(--body); font-size:14px; transition: border-color .2s;
}
.field textarea { resize:vertical; min-height:78px; font-size:13.5px; line-height:1.45; }
.field input:focus, .field textarea:focus { outline:none; border-color: var(--conti-orange); }
.dr-actions { display:flex; gap:10px; margin-top:26px; }
.dr-save { flex:1; background: var(--conti-orange); color:#fff; border:0; border-radius:12px; padding:14px; font-family:var(--body); font-weight:700; font-size:15px; cursor:pointer; box-shadow: var(--sh-orange); transition: filter .2s; }
.dr-save:hover { filter: brightness(1.06); }
.dr-cancel { background: var(--panel-2); color: var(--tx-mut); border:1px solid var(--hair); border-radius:12px; padding:14px 20px; font-family:var(--body); font-weight:600; cursor:pointer; }
.dr-note { font-size:12px; color: var(--tx-faint); margin-top:16px; display:flex; gap:8px; line-height:1.4; }
.dr-note b { color: var(--conti-amber); }

/* ===================== TOASTS ===================== */
.toast-host { position:fixed; bottom:26px; right:26px; z-index:80; display:flex; flex-direction:column; gap:10px; }
.toast {
  display:flex; align-items:center; gap:12px; min-width:280px; max-width:380px;
  background: var(--panel-2); border:1px solid var(--hair); border-left:3px solid var(--conti-orange);
  border-radius:13px; padding:14px 16px; box-shadow: 0 18px 40px rgba(0,0,0,.5);
  animation: toastIn .45s var(--ease-bounce);
}
.toast.out { animation: toastOut .35s var(--ease) forwards; }
@keyframes toastIn { from { opacity:0; transform: translateX(40px); } to { opacity:1; transform:none; } }
@keyframes toastOut { to { opacity:0; transform: translateX(40px); } }
.toast-ic { font-size:18px; }
.toast-tx { flex:1; }
.toast-t { font-size:13.5px; font-weight:600; color:#fff; }
.toast-s { font-size:12px; color: var(--tx-mut); margin-top:2px; }

/* utility */
.reveal { opacity:0; animation: rise .55s var(--ease) forwards; animation-delay: var(--d,0s); }
.flow > * { margin-bottom:20px; }
.flow > *:last-child { margin-bottom:0; }

/* ============================================================================
   §4.10 Loyalty & Membership · §4.11 Analytics & Reporting
   Authentic LIGHT "report surface" — mirrors the real Continental TCP Admin
   Portal (white data tables, filter rows, KPI MoM/QoQ deltas, pie/bar charts)
   rendered inside the dark ops shell. All selectors scoped under .report.
   ========================================================================== */
.report {
  --r-tx:#1f2430; --r-mut:#6b7280; --r-faint:#9aa1ad; --r-line:#e7e9ee;
  --r-up:#1f9d63; --r-down:#e23b3b;
  background:#eef0f3; border:1px solid #e2e4e9; border-radius:var(--r-md);
  padding:18px; color:var(--r-tx);
}
.report .r-head { display:flex; align-items:flex-start; justify-content:space-between; margin-bottom:16px; gap:16px; flex-wrap:wrap; }
.report .r-head h2 { font-family:var(--display); font-size:20px; color:var(--r-tx); margin:4px 0 4px; letter-spacing:-.01em; }
.report .r-head .r-sub { font-size:13px; color:var(--r-mut); max-width:560px; line-height:1.45; }
.report .r-eyebrow { font-family:var(--mono); font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--conti-orange); }

/* filter / query bar */
.fbar { display:flex; align-items:flex-end; gap:12px; flex-wrap:wrap; background:#fff; border:1px solid var(--r-line); border-radius:12px; padding:13px 15px; margin-bottom:16px; }
.fbar .fld { display:flex; flex-direction:column; gap:5px; }
.fbar label { font-size:10px; letter-spacing:.05em; text-transform:uppercase; color:var(--r-faint); }
.fbar input, .fbar select { border:1px solid var(--r-line); border-radius:8px; padding:8px 11px; font-family:var(--body); font-size:13px; color:var(--r-tx); background:#fff; min-width:150px; }
.fbar input:focus, .fbar select:focus { outline:none; border-color:var(--conti-orange); }
.fbar .sp { flex:1; }
.btn-q { background:var(--conti-orange); color:#fff; border:0; border-radius:8px; padding:9px 20px; font-family:var(--body); font-weight:700; font-size:13px; cursor:pointer; transition:filter .15s; }
.btn-q:hover { filter:brightness(1.06); }
.btn-ghost { background:#fff; color:var(--r-mut); border:1px solid var(--r-line); border-radius:8px; padding:9px 16px; font-family:var(--body); font-weight:600; font-size:13px; cursor:pointer; }
.btn-ghost:hover { border-color:var(--conti-orange); color:var(--conti-orange); }

/* export dropdown */
.exp { position:relative; display:inline-block; }
.exp-menu { position:absolute; right:0; top:calc(100% + 6px); background:#fff; border:1px solid var(--r-line); border-radius:10px; box-shadow:0 14px 34px rgba(20,24,32,.18); padding:6px; display:none; z-index:6; min-width:158px; }
.exp.open .exp-menu { display:block; }
.exp-menu button { display:flex; width:100%; align-items:center; gap:9px; background:transparent; border:0; padding:9px 11px; border-radius:7px; font-family:var(--body); font-size:13px; color:var(--r-tx); cursor:pointer; text-align:left; }
.exp-menu button:hover { background:#f3f4f6; }
.exp-menu .x { font-family:var(--mono); font-size:10px; color:var(--r-faint); width:34px; }

/* light KPI cards with MoM/QoQ deltas */
.rkpi-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:18px; }
@media(max-width:1180px){ .rkpi-grid { grid-template-columns:repeat(2,1fr);} }
.rkpi { background:#fff; border:1px solid var(--r-line); border-radius:12px; padding:15px 17px; }
.rkpi-lab { font-size:10.5px; letter-spacing:.05em; text-transform:uppercase; color:var(--r-mut); display:flex; align-items:center; justify-content:space-between; gap:8px; }
.rkpi-q { width:15px; height:15px; border-radius:50%; border:1px solid var(--r-line); color:var(--r-faint); font-size:9px; font-weight:700; display:inline-flex; align-items:center; justify-content:center; cursor:help; flex-shrink:0; }
.rkpi-val { font-family:var(--mono); font-weight:600; font-size:29px; color:var(--r-tx); margin:9px 0 9px; line-height:1; }
.rkpi-val .u { font-size:15px; color:var(--conti-orange); margin-left:2px; }
.rkpi-deltas { display:flex; gap:18px; }
.rkpi-d { font-size:11px; color:var(--r-mut); display:flex; align-items:center; gap:4px; letter-spacing:.02em; }
.rkpi-d b { font-family:var(--mono); font-weight:600; }
.rkpi-d.up b { color:var(--r-up); } .rkpi-d.down b { color:var(--r-down); }

/* data table */
.r-tablewrap { background:#fff; border:1px solid var(--r-line); border-radius:12px; overflow:hidden; margin-bottom:16px; }
.r-tabletop { display:flex; align-items:center; justify-content:space-between; gap:12px; padding:13px 16px; border-bottom:1px solid var(--r-line); flex-wrap:wrap; }
.r-tabletop h3 { font-size:14px; font-weight:700; color:var(--r-tx); margin:0; }
.r-tabletop .tt-tools { display:flex; align-items:center; gap:8px; }
.r-scroll { overflow-x:auto; }
table.dt { width:100%; border-collapse:collapse; font-size:13px; }
table.dt th { text-align:left; font-size:10.5px; letter-spacing:.04em; text-transform:uppercase; color:var(--r-mut); font-weight:600; padding:11px 16px; border-bottom:1px solid var(--r-line); background:#fafbfc; white-space:nowrap; }
table.dt td { padding:12px 16px; border-bottom:1px solid #f1f2f5; color:var(--r-tx); white-space:nowrap; }
table.dt tr:last-child td { border-bottom:0; }
table.dt tbody tr:hover { background:#fafbfc; }
table.dt td.num, table.dt th.num { text-align:right; font-family:var(--mono); }
.r-name { color:var(--conti-orange); font-weight:600; }
.r-rank { font-family:var(--mono); color:var(--r-faint); width:26px; }

/* light status pills */
.pill { display:inline-flex; align-items:center; gap:6px; font-size:11px; font-weight:600; padding:4px 10px; border-radius:999px; white-space:nowrap; }
.pill::before { content:''; width:6px; height:6px; border-radius:50%; background:currentColor; }
.pill.ok { background:rgba(31,157,99,.12); color:#1f9d63; }
.pill.warn { background:rgba(217,138,0,.16); color:#b9770b; }
.pill.mut { background:rgba(107,114,128,.13); color:#6b7280; }
.pill.bad { background:rgba(226,59,59,.12); color:#e23b3b; }
.pill.info { background:rgba(43,108,176,.12); color:#2b6cb0; }

/* report card grid */
.r-cols { display:grid; grid-template-columns:1fr 1.45fr; gap:16px; margin-bottom:16px; align-items:stretch; }
@media(max-width:980px){ .r-cols { grid-template-columns:1fr; } }
.r-card { background:#fff; border:1px solid var(--r-line); border-radius:12px; padding:16px 18px; }
.r-card h3 { font-size:14px; font-weight:700; margin:0 0 14px; color:var(--r-tx); display:flex; align-items:center; justify-content:space-between; gap:10px; }
.r-card h3 .hint { font-size:11px; font-weight:500; color:var(--r-faint); }

/* pie (conic) + legend */
.pie-wrap { display:flex; align-items:center; gap:22px; flex-wrap:wrap; }
.pie { width:138px; height:138px; border-radius:50%; flex-shrink:0; position:relative; }
.pie::after { content:''; position:absolute; inset:30px; border-radius:50%; background:#fff; }
.legend { display:flex; flex-direction:column; gap:9px; flex:1; min-width:160px; }
.legend .lg { display:flex; align-items:center; gap:9px; font-size:12.5px; color:var(--r-tx); }
.legend .sw { width:11px; height:11px; border-radius:3px; flex-shrink:0; }
.legend .lp { margin-left:auto; font-family:var(--mono); color:var(--r-mut); padding-left:14px; }

/* light bar chart */
.lbars { display:flex; align-items:flex-end; gap:12px; height:172px; padding-top:10px; }
.lbar-col { flex:1; display:flex; flex-direction:column; align-items:center; gap:7px; height:100%; justify-content:flex-end; }
.lbar { width:62%; max-width:34px; border-radius:5px 5px 0 0; background:linear-gradient(180deg,#5b8def,#3f6fd0); transition:height .9s var(--ease-bounce); min-height:3px; }
.lbar.accent { background:linear-gradient(180deg,var(--conti-orange),var(--conti-orange-deep)); }
.lbar-x { font-size:10.5px; color:var(--r-faint); font-family:var(--mono); }
.lbar-v { font-size:10px; color:var(--r-mut); font-family:var(--mono); }

/* loyalty earn-rule / reward toggle rows */
.lr-list { display:flex; flex-direction:column; }
.lr { display:grid; grid-template-columns:1fr auto auto; gap:16px; align-items:center; padding:13px 0; border-bottom:1px solid #f1f2f5; }
.lr:last-child { border-bottom:0; }
.lr-t { font-size:13.5px; font-weight:600; color:var(--r-tx); }
.lr-s { font-size:11.5px; color:var(--r-mut); margin-top:2px; }
.lr-pts { font-family:var(--mono); font-weight:600; color:var(--conti-orange); font-size:14px; white-space:nowrap; }

/* toggle switch */
.tgl { width:42px; height:24px; border-radius:999px; background:#d4d7dd; border:0; cursor:pointer; position:relative; transition:background .25s; flex-shrink:0; padding:0; }
.tgl::after { content:''; position:absolute; top:3px; left:3px; width:18px; height:18px; border-radius:50%; background:#fff; box-shadow:0 1px 3px rgba(0,0,0,.25); transition:transform .25s var(--ease); }
.tgl.on { background:var(--conti-orange); }
.tgl.on::after { transform:translateX(18px); }

/* membership tiers (Future Phase) */
.tier-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
@media(max-width:900px){ .tier-grid { grid-template-columns:1fr; } }
.tier { background:#fff; border:1px solid var(--r-line); border-radius:12px; padding:18px; position:relative; }
.tier.silver { border-top:3px solid #9aa1ad; }
.tier.gold { border-top:3px solid #d8a738; }
.tier.platinum { border-top:3px solid #6b7686; }
.tier-name { font-family:var(--display); font-size:18px; color:var(--r-tx); }
.tier-th { font-family:var(--mono); font-size:12px; color:var(--r-mut); margin:2px 0 14px; }
.tier-members { font-family:var(--mono); font-size:26px; font-weight:600; color:var(--r-tx); }
.tier-members .ml { font-size:11px; color:var(--r-mut); font-family:var(--body); margin-left:6px; }
.tier-perks { list-style:none; padding:0; margin:13px 0 0; display:flex; flex-direction:column; gap:7px; }
.tier-perks li { font-size:12.5px; color:var(--r-mut); padding-left:18px; position:relative; }
.tier-perks li::before { content:'✓'; position:absolute; left:0; color:var(--r-up); font-weight:700; }
.future-ribbon { display:inline-block; font-family:var(--mono); font-size:9.5px; letter-spacing:.1em; text-transform:uppercase; color:#b9770b; background:rgba(217,138,0,.16); padding:3px 9px; border-radius:999px; }

/* section heading inside a report */
.r-section { font-family:var(--display); font-size:15px; color:var(--r-tx); margin:22px 0 12px; display:flex; align-items:center; gap:10px; }
.r-section .tag { font-family:var(--mono); font-size:9.5px; color:var(--r-mut); border:1px solid var(--r-line); border-radius:999px; padding:3px 9px; letter-spacing:.07em; text-transform:uppercase; }

/* warranty-ops mini stats */
.mini-stats { display:grid; grid-template-columns:repeat(6,1fr); gap:12px; }
@media(max-width:900px){ .mini-stats { grid-template-columns:repeat(3,1fr); } }
.mini { text-align:center; padding:6px 4px; }
.mini-v { font-family:var(--mono); font-size:24px; font-weight:600; color:var(--r-tx); }
.mini-l { font-size:10.5px; color:var(--r-mut); margin-top:3px; letter-spacing:.02em; }
