/* RxCloud CyberLab vNext Premium UI */
/* ═══════════════════════════════════════════════════════════════
   RXCLOUD CYBERLAB — vNEXT PREMIUM LAYER
   Loads after rxcloud.css + rxcloud-premium.css. Pure visual layer:
   no markup IDs, JS hooks, or behaviours are touched here.
   Design language: deep navy glass, electric cyan telemetry,
   Vision-Pro-style depth, SOC monitoring energy.
   ═══════════════════════════════════════════════════════════════ */

/* ── 0. DESIGN TOKENS ─────────────────────────────────────────── */
:root{
  /* base */
  --rx-bg-0:#05090f;            /* deepest */
  --rx-bg-1:#0a1422;            /* navy */

  /* glass panels */
  --rx-panel:rgba(16,24,36,.52);
  --rx-panel-strong:rgba(12,19,30,.80);

  /* signature cyan ramp */
  --rx-cyan:#1bd4f5;
  --rx-cyan-bright:#6cf0ff;
  --rx-cyan-soft:rgba(20,210,250,.12);
  --rx-cyan-deep:#0a8fb5;

  /* effects */
  --rx-glow:rgba(20,210,250,.18);
  --rx-glow-strong:rgba(20,210,250,.30);
  --rx-border:rgba(255,255,255,.10);
  --rx-border-cyan:rgba(27,212,245,.24);

  /* text */
  --rx-text:#e8f6ff;
  --rx-muted:#8ba6bd;

  /* semantic */
  --rx-danger:#ff5d6c;
  --rx-success:#2ee6a6;
  --rx-warning:#ffb443;

  /* gradients */
  --rx-grad-cyan:linear-gradient(135deg, var(--rx-cyan-bright), var(--rx-cyan) 45%, var(--rx-cyan-deep));
  --rx-grad-accent:linear-gradient(180deg, var(--rx-cyan-bright), var(--rx-cyan-deep));

  /* layered depth shadows */
  --rx-shadow-1:0 6px 18px rgba(0,0,0,.35);
  --rx-shadow-2:0 18px 48px rgba(0,0,0,.50);
  --rx-shadow-3:0 30px 80px rgba(0,0,0,.58);

  /* radii */
  --rx-r-sm:12px;
  --rx-r-md:16px;
  --rx-r-lg:22px;
  --rx-r-xl:26px;
}

/* ── 1. LIVING BACKGROUND ─────────────────────────────────────── */
/* The animated canvas is injected by rxcloud-bg.js as the first body
   child. Deepen the page base toward navy so the cyan telemetry pops. */
#rx-bg-canvas{
  position:fixed; inset:0; width:100%; height:100%;
  z-index:0; pointer-events:none; display:block;
}

body{
  background:
    radial-gradient(1200px 680px at 50% -12%, rgba(20,210,250,.14), transparent 58%),
    radial-gradient(900px 560px at 12% 8%, rgba(13,160,220,.10), transparent 52%),
    radial-gradient(1000px 640px at 88% 16%, rgba(10,120,200,.09), transparent 55%),
    radial-gradient(1300px 820px at 50% 116%, rgba(20,210,250,.10), transparent 60%),
    linear-gradient(180deg, var(--rx-bg-1) 0%, var(--rx-bg-0) 52%, #03070c 100%) !important;
  color:var(--rx-text);
  /* keep all layers viewport-fixed (the shorthand above resets this to scroll
     with !important, so the longhand must also be !important) — prevents a
     scroll seam against the fixed canvas / ambient layers */
  background-attachment:fixed !important;
}

/* faint vignette for cinematic depth */
body::after{
  content:"";
  position:fixed; inset:0; z-index:0; pointer-events:none;
  background:radial-gradient(130% 130% at 50% 38%, transparent 58%, rgba(0,0,0,.42) 100%);
}

/* Repurpose legacy ambient layers into slow, breathing cyan halos
   that complement (sit above) the particle canvas. */
.rx-grid-bg{ opacity:.9; }
.rx-grid-bg::before{
  background:radial-gradient(circle, rgba(20,210,250,.12) 0%, transparent 66%) !important;
  filter:blur(140px) !important;
  animation-duration:30s !important;
}
.rx-grid-bg::after{
  background:radial-gradient(circle, rgba(10,140,210,.10) 0%, transparent 66%) !important;
  filter:blur(150px) !important;
  animation-duration:34s !important;
}

.aura-bg{
  background:radial-gradient(circle,
    rgba(20,210,250,.08) 0%,
    rgba(20,210,250,.03) 60%,
    transparent 74%) !important;
  filter:blur(80px) !important;
  animation-duration:48s !important;
}
.core-pulse{
  width:680px !important; height:680px !important;
  background:radial-gradient(circle, rgba(20,210,250,.22) 0%, rgba(13,160,220,.06) 58%, transparent 80%) !important;
  filter:blur(120px) !important;
  animation:rxCoreBreath 9s ease-in-out infinite !important;
  opacity:.7;
}
@keyframes rxCoreBreath{
  0%,100%{ transform:translate(-50%,-50%) scale(1); opacity:.55; }
  50%    { transform:translate(-50%,-50%) scale(1.12); opacity:.85; }
}

/* keep the content above all ambient/canvas layers */
.wrap, .header, .rx-maint{ position:relative; z-index:1; }
.header{ z-index:40 !important; }

/* ── 2. LAYOUT RHYTHM ─────────────────────────────────────────── */
.wrap{ max-width:1040px !important; }
@media (min-width:900px){
  .wrap.grid{ gap:20px !important; }
}
.card h3{
  display:flex; align-items:center; gap:10px;
  font-size:15px; font-weight:800;
  letter-spacing:.4px;
  color:#f2fbff;
  margin:2px 0 14px;
  text-shadow:0 0 18px rgba(20,210,250,.18);
}
.card h3 .rx-accent-bar{ margin-right:2px; }

/* ── 3. ACCENT BAR — taller, brighter telemetry tick ─────────── */
.rx-accent-bar{
  width:3px !important;
  height:18px !important;
  border-radius:3px !important;
  background:var(--rx-grad-accent) !important;
  box-shadow:0 0 10px var(--rx-cyan), 0 0 20px rgba(20,210,250,.35) !important;
  position:relative;
}

/* ── 4. PREMIUM GLASS CARDS ───────────────────────────────────── */
.card{
  border-radius:var(--rx-r-lg) !important;
  background:
    linear-gradient(165deg, rgba(255,255,255,.07) 0%, rgba(255,255,255,0) 38%),
    linear-gradient(180deg, var(--rx-panel), rgba(10,16,26,.42)) !important;
  border:1px solid var(--rx-border) !important;
  backdrop-filter:blur(22px) saturate(160%) !important;
  -webkit-backdrop-filter:blur(22px) saturate(160%) !important;
  box-shadow:
    var(--rx-shadow-2),
    0 0 0 1px rgba(255,255,255,.04) inset,
    0 0 28px rgba(20,210,250,.06) !important;
  transition:transform .2s cubic-bezier(.22,1,.36,1), box-shadow .28s ease, border-color .28s ease !important;
}

/* top edge accent — brighter in the middle */
.card::before{
  content:"" !important;
  position:absolute !important;
  inset:0 0 auto 0 !important;
  height:1px !important;
  border-radius:var(--rx-r-lg) var(--rx-r-lg) 0 0 !important;
  background:linear-gradient(90deg,
    transparent 8%,
    rgba(108,240,255,.55) 38%,
    rgba(108,240,255,.85) 50%,
    rgba(108,240,255,.55) 62%,
    transparent 92%) !important;
  opacity:.8 !important;
  pointer-events:none !important;
  z-index:2 !important;
}

/* primary action cards: stronger cyan presence */
.card:has(#sessionBox),
.card:has(#slotForm),
.card:has(#upForm){
  border-color:var(--rx-border-cyan) !important;
  background:
    radial-gradient(120% 80% at 6% 0%, rgba(20,210,250,.10) 0%, transparent 52%),
    linear-gradient(165deg, rgba(255,255,255,.08) 0%, rgba(255,255,255,0) 40%),
    linear-gradient(180deg, rgba(14,22,34,.60), rgba(9,15,24,.44)) !important;
  box-shadow:
    var(--rx-shadow-3),
    0 0 0 1px rgba(20,210,250,.10) inset,
    0 0 36px rgba(20,210,250,.08) !important;
}

@media (hover:hover){
  .card:hover{
    transform:translateY(-3px) !important;
    border-color:var(--rx-border-cyan) !important;
    box-shadow:
      var(--rx-shadow-3),
      0 0 0 1px rgba(20,210,250,.12) inset,
      0 0 46px rgba(20,210,250,.14) !important;
  }
  .card:has(#sessionBox):hover,
  .card:has(#slotForm):hover,
  .card:has(#upForm):hover{
    border-color:rgba(27,212,245,.34) !important;
    box-shadow:
      var(--rx-shadow-3),
      0 0 0 1px rgba(20,210,250,.16) inset,
      0 0 60px rgba(20,210,250,.18) !important;
  }
}

/* staggered entrance — premium "boot up" feel */
@media (prefers-reduced-motion:no-preference){
  .wrap > .card{
    animation:rxCardIn .55s cubic-bezier(.22,1,.36,1) both;
  }
  .wrap > .card:nth-of-type(1){ animation-delay:.02s; }
  .wrap > .card:nth-of-type(2){ animation-delay:.10s; }
  .wrap > .card:nth-of-type(3){ animation-delay:.18s; }
  .wrap > .card:nth-of-type(4){ animation-delay:.26s; }
  .wrap > .card:nth-of-type(5){ animation-delay:.34s; }
}
@keyframes rxCardIn{
  0%{ opacity:0; transform:translateY(16px) scale(.985); }
  100%{ opacity:1; transform:none; }
}

/* ── 5. HEADER — deep glass + live telemetry line ─────────────── */
.header{
  padding:12px 18px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,0)),
    linear-gradient(180deg, rgba(8,14,22,.55), rgba(8,14,22,.18)) !important;
  backdrop-filter:blur(26px) saturate(170%) !important;
  -webkit-backdrop-filter:blur(26px) saturate(170%) !important;
  border-bottom:1px solid rgba(255,255,255,.07) !important;
  box-shadow:0 18px 50px rgba(0,0,0,.35), 0 0 1px rgba(255,255,255,.08) inset !important;
}
.header::after{
  content:"" !important;
  position:absolute !important;
  bottom:-1px !important; left:0 !important; right:0 !important;
  height:1px !important;
  background:linear-gradient(90deg,
    transparent 4%,
    rgba(108,240,255,.55) 22%,
    rgba(20,210,250,.30) 50%,
    rgba(108,240,255,.55) 78%,
    transparent 96%) !important;
  background-size:200% 100% !important;
  animation:rxHeaderFlow 9s linear infinite !important;
  pointer-events:none !important;
}
@keyframes rxHeaderFlow{
  0%{ background-position:0% 0; }
  100%{ background-position:200% 0; }
}
.h1{
  font-weight:900 !important;
  letter-spacing:.4px !important;
  background:linear-gradient(180deg, #ffffff, #bfefff 60%, var(--rx-cyan));
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent;
  text-shadow:0 0 24px rgba(20,210,250,.18);
}
.logo{
  background:linear-gradient(135deg, rgba(20,210,250,.22), rgba(20,210,250,0)) !important;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.10), 0 0 22px rgba(20,210,250,.26) !important;
}

/* ── 5b. HEADER DENSITY ───────────────────────────────────────── */
/* The dashboard header runs a 3-column row (brand · welcome · 6 pills).
   The inline grid stays `1fr auto 1fr` so the welcome block remains
   truly page-centered. Pills are compacted + their resting glow softened
   so the 6 pills no longer read as one bright blob; at wider viewports
   they sit on a single row, at tighter ones they wrap cleanly to a
   second row inside their column (welcome still centered on the page). */
.header .btn.btn-pill{
  padding:6px 12px !important;
  font-size:12.5px !important;
  font-weight:700 !important;
  letter-spacing:.1px !important;
  line-height:1.15 !important;
  min-height:30px;
  /* gentler resting glow so 6 pills side-by-side don't blob together */
  box-shadow:
    0 4px 12px rgba(20,210,250,.14),
    0 0 0 1px rgba(255,255,255,.10) inset !important;
}
@media (hover:hover){
  .header .btn.btn-pill:hover{
    transform:translateY(-1px) !important;
    box-shadow:
      0 10px 22px rgba(20,210,250,.26),
      0 0 22px rgba(20,210,250,.10),
      0 0 0 1px rgba(255,255,255,.18) inset !important;
  }
}

/* trim the brand box (inline sets 50×50) and the title size */
.header .logo{ height:42px !important; width:42px !important; }
.header .h1{ font-size:17px !important; }

/* center welcome block: a touch smaller, never overflow its cell */
.header > div:nth-child(2){
  font-size:13.5px !important;
  line-height:1.3 !important;
  min-width:0;
}
.header .rx-lastbadge{ padding:3px 8px !important; }
.header .rx-lastbadge__txt{ font-size:11.5px !important; }

/* right-side action group: tighter gap + wrap as a safety net */
.header > div:last-child{
  flex-wrap:wrap !important;
  row-gap:6px !important;
  column-gap:6px !important;
  justify-content:flex-end !important;
}

/* very narrow viewports: shrink the center text + pills further so the
   single-row layout survives. Below 1100px we let the whole header
   stack on two rows (the wrap above + grid flow do the work). */
@media (max-width:1300px){
  .header > div:nth-child(2){ font-size:12.5px !important; }
  .header .btn.btn-pill{ padding:5px 10px !important; font-size:12px !important; }
}
@media (max-width:1100px){
  .header[style*="grid-template-columns"]{
    grid-template-columns:1fr !important;
    row-gap:8px !important;
  }
  .header > div:last-child{ justify-content:center !important; }
}

/* ── 6. BUTTONS ───────────────────────────────────────────────── */
.btn{
  background:var(--rx-grad-cyan) !important;
  color:#04161d !important;
  border:none !important;
  border-radius:12px !important;
  font-weight:800 !important;
  letter-spacing:.2px !important;
  overflow:hidden !important;
  box-shadow:
    0 6px 18px rgba(20,210,250,.30),
    0 0 0 1px rgba(255,255,255,.18) inset !important;
  transition:transform .14s cubic-bezier(.22,1,.36,1), box-shadow .22s ease, filter .18s ease !important;
}
/* diagonal sheen sweep on hover */
.btn::before{
  content:"" !important;
  position:absolute !important;
  top:0 !important; left:-120% !important;
  width:60% !important; height:100% !important;
  background:linear-gradient(100deg, transparent, rgba(255,255,255,.45), transparent) !important;
  transform:skewX(-18deg) !important;
  transition:left .55s ease !important;
  pointer-events:none !important;
  z-index:1 !important;
}
@media (hover:hover){
  .btn:hover{
    transform:translateY(-2px) !important;
    box-shadow:
      0 12px 30px rgba(20,210,250,.42),
      0 0 36px rgba(20,210,250,.16),
      0 0 0 1px rgba(255,255,255,.26) inset !important;
    filter:brightness(1.05) !important;
  }
  .btn:hover::before{ left:140% !important; }
}
.btn:active{ transform:translateY(0) scale(.98) !important; filter:brightness(.96) !important; }

.btn.muted{
  background:linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,0)), rgba(27,34,45,.9) !important;
  color:var(--rx-muted) !important;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.06) !important;
}
.btn.muted::before{ display:none !important; }

/* pills (header actions) */
.btn.btn-pill{
  border-radius:9999px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,0)),
    var(--rx-grad-cyan) !important;
  box-shadow:
    0 8px 22px rgba(20,210,250,.22),
    0 0 0 1px rgba(255,255,255,.14) inset !important;
}
@media (hover:hover){
  .btn.btn-pill:hover{
    transform:translateY(-2px) !important;
    box-shadow:0 12px 30px rgba(20,210,250,.32), 0 0 30px rgba(20,210,250,.12), 0 0 0 1px rgba(255,255,255,.2) inset !important;
  }
}

/* JOIN — extra electric */
.btn-join{
  background:linear-gradient(135deg, #5cefff, #1bd4f5 55%, #0a8fb5) !important;
  color:#03161d !important;
  box-shadow:0 8px 24px rgba(20,210,250,.40), 0 0 30px rgba(20,210,250,.16), 0 0 0 1px rgba(255,255,255,.22) inset !important;
}

/* DANGER — translucent red glass, glow only on hover */
/* Danger button (End session, Delete confirmations) — translucent red
   glass but clearly readable, not a washed-out fade. Hover bumps to a
   strong saturated punch + halo without crossing into "gaming neon". */
.btn-end{
  background:linear-gradient(135deg, rgba(255,80,98,.48), rgba(190,38,52,.48)) !important;
  color:#fff1f3 !important;
  border:1px solid rgba(255,93,108,.62) !important;
  box-shadow:
    0 6px 18px rgba(255,60,80,.22),
    0 0 0 1px rgba(255,93,108,.20) inset !important;
  backdrop-filter:blur(8px) saturate(150%) !important;
  -webkit-backdrop-filter:blur(8px) saturate(150%) !important;
  text-shadow:0 1px 1px rgba(0,0,0,.25);
}
.btn-end::before{ display:none !important; }
@media (hover:hover){
  .btn-end:hover{
    background:linear-gradient(135deg, rgba(255,80,98,.68), rgba(200,42,58,.62)) !important;
    border-color:rgba(255,108,122,.85) !important;
    color:#ffffff !important;
    box-shadow:
      0 12px 28px rgba(255,60,80,.40),
      0 0 38px rgba(255,60,80,.28),
      0 0 0 1px rgba(255,108,122,.32) inset !important;
    transform:translateY(-2px) !important;
  }
}

/* file picker button stays in the cyan family */
.file-btn{
  background:var(--rx-grad-cyan) !important;
  color:#04161d !important;
  border:none !important;
  border-radius:12px !important;
  box-shadow:0 6px 18px rgba(20,210,250,.28), 0 0 0 1px rgba(255,255,255,.18) inset !important;
}
@media (hover:hover){
  .file-btn:hover{ filter:brightness(1.06) !important; box-shadow:0 10px 26px rgba(20,210,250,.42), 0 0 0 1px rgba(255,255,255,.24) inset !important; }
}

/* ── 7. INPUTS / SELECTS / FILE PILL ──────────────────────────── */
.input,.select,.file,.rxsel__btn{
  border-radius:12px !important;
  background:linear-gradient(180deg, rgba(8,14,22,.66), rgba(8,14,22,.50)) !important;
  border:1px solid rgba(255,255,255,.10) !important;
  color:var(--rx-text) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05) !important;
  transition:border-color .18s ease, box-shadow .22s ease, background .22s ease !important;
}
.input::placeholder{ color:rgba(160,184,202,.7) !important; }
.input:focus,.select:focus,.file:focus,.rxsel__btn:focus{
  outline:none !important;
  border-color:rgba(27,212,245,.7) !important;
  background:linear-gradient(180deg, rgba(10,18,28,.74), rgba(10,18,28,.58)) !important;
  box-shadow:
    0 0 0 3px rgba(20,210,250,.18),
    0 0 22px rgba(20,210,250,.16),
    inset 0 0 0 1px rgba(27,212,245,.20) !important;
}
.file-pill{
  border-radius:12px !important;
  background:rgba(6,12,20,.6) !important;
  border:1px solid rgba(255,255,255,.08) !important;
  color:#9fb6c8 !important;
}

/* custom dropdown surface */
.rxsel__list, .select option{
  background:linear-gradient(180deg, rgba(14,20,30,.98), rgba(10,16,24,.98)) !important;
}
.rxsel__list{
  border:1px solid var(--rx-border-cyan) !important;
  border-radius:14px !important;
  box-shadow:var(--rx-shadow-2), 0 0 22px rgba(20,210,250,.14) !important;
}
.rxsel__opt[aria-selected="true"]{ background:rgba(20,210,250,.12) !important; }

/* ── 8. BADGES ────────────────────────────────────────────────── */
/* generic plain badges only — explicitly excludes the semantic variants
   so it never competes with the colored rules below (equal specificity) */
.badge:not([style]):not(.badge--ok):not(.badge--warn):not(.badge--error):not(.badge--ending){
  border-radius:999px !important;
  background:linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.02)) !important;
  border:1px solid rgba(27,212,245,.20) !important;
  color:var(--rx-text) !important;
  box-shadow:0 2px 8px rgba(0,0,0,.15), 0 0 1px rgba(20,210,250,.10) inset !important;
  backdrop-filter:blur(8px) !important;
}
/* semantic colors use .badge.badge--X (specificity 0,2,0) so they beat
   the generic .badge:not([style]) rule above — same trick as premium.css */
.badge--ok,.badge.badge--ok{
  background:rgba(46,230,166,.14) !important;
  border:1px solid rgba(46,230,166,.40) !important;
  color:#a9f6db !important;
  box-shadow:0 0 16px rgba(46,230,166,.14) inset !important;
}
.badge--warn,.badge.badge--warn,
.badge--ending,.badge.badge--ending{
  background:rgba(255,180,67,.14) !important;
  border:1px solid rgba(255,180,67,.40) !important;
  color:#ffe0b0 !important;
  box-shadow:0 0 16px rgba(255,180,67,.14) inset !important;
}
.badge--error,.badge.badge--error{
  background:rgba(255,93,108,.14) !important;
  border:1px solid rgba(255,93,108,.42) !important;
  color:#ffc2c8 !important;
  box-shadow:0 0 16px rgba(255,93,108,.14) inset !important;
}

/* ── 9. KV ROWS / SEPARATORS / GAUGES / METERS ───────────────── */
.kv{ border-bottom:1px solid rgba(255,255,255,.06) !important; transition:background .15s ease !important; }
.kv:hover{ background:rgba(20,210,250,.025) !important; }

.rxsep{
  background:linear-gradient(90deg, transparent, rgba(27,212,245,.14) 22%, rgba(255,255,255,.08) 50%, rgba(27,212,245,.14) 78%, transparent) !important;
}

.rx-gauge-fill{ stroke:var(--rx-cyan) !important; filter:drop-shadow(0 0 5px rgba(20,210,250,.55)) !important; }
.rx-gauge-val{ color:#cdf6ff !important; text-shadow:0 0 14px rgba(20,210,250,.35) !important; }

.meter{ border:1px solid rgba(27,212,245,.18) !important; }
.meter__fill{
  background:linear-gradient(90deg, var(--rx-cyan-deep), var(--rx-cyan) 50%, var(--rx-cyan-bright)) !important;
  box-shadow:inset 0 0 8px rgba(255,255,255,.22), 0 0 14px rgba(20,210,250,.35) !important;
}

/* ── 10. REPORT ROWS ──────────────────────────────────────────── */
.rx-report-link, [data-report-row]{
  border-radius:14px !important;
  border:1px solid rgba(255,255,255,.06) !important;
  background:rgba(255,255,255,.02) !important;
  transition:transform .14s ease, background .15s ease, box-shadow .2s ease, border-color .2s ease !important;
}
@media (hover:hover){
  .rx-report-link:hover, [data-report-row]:hover{
    transform:translateX(3px) !important;
    background:rgba(20,210,250,.05) !important;
    border-color:var(--rx-border-cyan) !important;
    box-shadow:0 6px 18px rgba(0,0,0,.2), 0 0 18px rgba(20,210,250,.08) !important;
  }
}

/* ── 11. MODALS ───────────────────────────────────────────────── */
.rxmodal{
  background:rgba(2,6,12,.55) !important;
  backdrop-filter:blur(16px) saturate(140%) !important;
  -webkit-backdrop-filter:blur(16px) saturate(140%) !important;
}
.rxmodal__card{
  border-radius:var(--rx-r-xl) !important;
  background:
    radial-gradient(120% 80% at 8% 0%, rgba(20,210,250,.10) 0%, transparent 52%),
    radial-gradient(100% 80% at 92% 100%, rgba(13,140,210,.08) 0%, transparent 48%),
    linear-gradient(180deg, var(--rx-panel-strong), rgba(9,14,22,.74)) !important;
  border:1px solid rgba(255,255,255,.12) !important;
  backdrop-filter:blur(30px) saturate(180%) !important;
  -webkit-backdrop-filter:blur(30px) saturate(180%) !important;
  box-shadow:0 32px 100px rgba(0,0,0,.60), 0 0 0 1px rgba(255,255,255,.06) inset, 0 0 56px rgba(20,210,250,.10) !important;
}
.rxmodal__head{
  background:linear-gradient(180deg, rgba(255,255,255,.045), transparent) !important;
  border-bottom:1px solid rgba(27,212,245,.12) !important;
}

/* ── 12. VM POOL — SOC MONITORING PANEL ──────────────────────── */
.pool-float-card{
  border-radius:var(--rx-r-lg) !important;
  background:
    radial-gradient(100% 60% at 50% 0%, rgba(20,210,250,.10), transparent 62%),
    linear-gradient(180deg, var(--rx-panel-strong), rgba(10,16,26,.7)) !important;
  border:1px solid var(--rx-border-cyan) !important;
  backdrop-filter:blur(24px) saturate(180%) !important;
  -webkit-backdrop-filter:blur(24px) saturate(180%) !important;
  box-shadow:var(--rx-shadow-3), 0 0 36px rgba(20,210,250,.10) !important;
}
.pool-float-head{
  position:relative;
  background:linear-gradient(180deg, rgba(20,210,250,.06), transparent) !important;
  border-bottom:1px solid rgba(27,212,245,.16) !important;
}
/* scanning line at the top of the SOC panel */
.pool-float-head::after{
  content:"";
  position:absolute; left:0; right:0; bottom:-1px; height:1px;
  background:linear-gradient(90deg, transparent, var(--rx-cyan), transparent);
  background-size:50% 100%;
  background-repeat:no-repeat;
  animation:rxScanLine 3.2s linear infinite;
  opacity:.7; pointer-events:none;
}
@keyframes rxScanLine{
  0%{ background-position:-60% 0; }
  100%{ background-position:160% 0; }
}
#poolFloat .vm-row{
  border-radius:14px !important;
  background:linear-gradient(135deg, rgba(255,255,255,.05), rgba(255,255,255,.015)) !important;
  border:1px solid rgba(255,255,255,.08) !important;
  transition:transform .15s ease, border-color .18s ease, box-shadow .2s ease !important;
}
@media (hover:hover){
  #poolFloat .vm-row:hover{
    transform:translateX(4px) !important;
    border-color:var(--rx-border-cyan) !important;
    box-shadow:0 4px 16px rgba(0,0,0,.22), 0 0 16px rgba(20,210,250,.08) !important;
  }
}
#poolFloat .state-free{ background:rgba(46,230,166,.12) !important; border-color:rgba(46,230,166,.30) !important; box-shadow:0 0 16px rgba(46,230,166,.06) inset !important; }
#poolFloat .state-busy,
#poolFloat .state-occupied{ background:rgba(255,93,108,.12) !important; border-color:rgba(255,93,108,.30) !important; box-shadow:0 0 16px rgba(255,93,108,.06) inset !important; }
#poolFloat .state-allocating,
#poolFloat .state-maintenance{ background:rgba(255,180,67,.12) !important; border-color:rgba(255,180,67,.30) !important; box-shadow:0 0 16px rgba(255,180,67,.06) inset !important; }

/* FAB toggles in cyan family */
#poolFab{
  background:linear-gradient(180deg, rgba(255,255,255,.14), rgba(255,255,255,0)), var(--rx-cyan) !important;
  color:#04161d !important;
  box-shadow:0 8px 24px rgba(20,210,250,.26), 0 0 0 1px rgba(255,255,255,.16) inset !important;
}

/* ── 13. RXBOT / FLOATING ASSISTANT ──────────────────────────── */
.rxbot, .rxbotBubble{
  border-radius:var(--rx-r-lg) !important;
  background:
    radial-gradient(100% 60% at 50% 0%, rgba(20,210,250,.09), transparent 60%),
    linear-gradient(180deg, var(--rx-panel-strong), rgba(10,16,26,.72)) !important;
  border:1px solid var(--rx-border-cyan) !important;
  backdrop-filter:blur(24px) saturate(180%) !important;
  -webkit-backdrop-filter:blur(24px) saturate(180%) !important;
  box-shadow:var(--rx-shadow-3), 0 0 32px rgba(20,210,250,.12) !important;
}
#rxbotFab{
  background:linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,0)), var(--rx-cyan) !important;
  color:#04161d !important;
  box-shadow:0 8px 24px rgba(20,210,250,.26), 0 0 36px rgba(20,210,250,.10) !important;
}
.rxbotMsg--user{
  background:linear-gradient(135deg, rgba(20,210,250,.18), rgba(20,210,250,.06)) !important;
  border-color:rgba(27,212,245,.26) !important;
}

/* ── 14. TOASTS ───────────────────────────────────────────────── */
.rxtoast{
  border-radius:16px !important;
  backdrop-filter:blur(18px) saturate(160%) !important;
  box-shadow:var(--rx-shadow-2), 0 0 22px rgba(20,210,250,.20) !important;
}

/* ── 15. CUSTOM CURSOR — sharper signature glow ───────────────── */
#rx-cursor-dot{
  background:var(--rx-cyan-bright) !important;
  box-shadow:0 0 10px var(--rx-cyan-bright), 0 0 22px rgba(20,210,250,.85) !important;
}
#rx-cursor-ring{
  border-color:rgba(108,240,255,.55) !important;
  box-shadow:0 0 14px rgba(20,210,250,.28) !important;
}

/* ── 16. SCROLLBAR ────────────────────────────────────────────── */
::-webkit-scrollbar-thumb{
  background:linear-gradient(180deg, rgba(27,212,245,.5), rgba(20,210,250,.28)) !important;
}
::-webkit-scrollbar-thumb:hover{
  background:linear-gradient(180deg, rgba(108,240,255,.7), rgba(20,210,250,.45)) !important;
  box-shadow:0 0 10px rgba(20,210,250,.35) !important;
}

/* ── 17. ACCESSIBILITY ────────────────────────────────────────── */
:focus-visible{
  outline:2px solid rgba(27,212,245,.65) !important;
  outline-offset:2px !important;
}

@media (prefers-reduced-motion:reduce){
  .core-pulse, .aura-bg, .rx-grid-bg::before, .rx-grid-bg::after{ animation:none !important; }
  .header::after, .pool-float-head::after{ animation:none !important; }
  .wrap > .card{ animation:none !important; }
  .card, .btn, .badge{ transition:none !important; }
}
