/* Baltrix – Exceptional Pack
   Goal: make the UI feel "AAA / premium" without breaking layout.
   Works on top of Arena Gold + Brand SUPER.
*/

:root{
  --bx-glass: rgba(255,255,255,.055);
  --bx-glass2: rgba(255,255,255,.030);
  --bx-stroke: rgba(148,163,184,.14);
  --bx-stroke2: rgba(240,215,138,.18);
  --bx-shadow: 0 30px 120px rgba(0,0,0,.55);

  --spot-x: 0px;
  --spot-y: 0px;
  --halo-x: 60vw;
  --halo-y: 48px;
  --halo-a: 0;
}


/* ============ Subtle top progress while routing ============ */
body.route-loading header.topbar::before{
  content:"";
  position:absolute;
  left:0; right:0; top:0;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(240,215,138,.85), transparent);
  animation: bx-progress 1.1s ease-in-out infinite;
  opacity: .95;
}
@keyframes bx-progress{
  0%{ transform: translateX(-35%); }
  50%{ transform: translateX(0%); }
  100%{ transform: translateX(35%); }
}

/* ============ Hero header ============ */
.bx-hero{
  position: relative;
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap: 18px;
  padding: 18px 18px;
  border-radius: 22px;
  border: 1px solid var(--bx-stroke);
  background: linear-gradient(180deg, var(--bx-glass), var(--bx-glass2));
  box-shadow: var(--bx-shadow);
  overflow:hidden;
}

/* gradient edge */
.bx-hero::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(135deg,
    rgba(240,215,138,.48),
    rgba(78,93,163,.22),
    rgba(240,215,138,.14)
  );
  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  pointer-events:none;
  opacity: .85;
}

/* spotlight */
.bx-hero::after{
  content:"";
  position:absolute;
  inset:-40px -40px auto -40px;
  height: 190px;
  background:
    radial-gradient(420px 160px at 24% 28%, rgba(240,215,138,.22), transparent 70%),
    radial-gradient(420px 160px at 74% 18%, rgba(78,93,163,.18), transparent 72%);
  filter: blur(1px);
  opacity: .8;
  pointer-events:none;
}

.bx-hero-main{ position: relative; z-index:1; }
.bx-hero-kicker{ margin-bottom: 6px; }

.bx-hero-title{
  margin: 0;
  font-size: 34px;
  line-height: 1.06;
  font-weight: 950;
  letter-spacing: .2px;
  background: linear-gradient(90deg, rgba(240,215,138,.95), #ffffff, rgba(240,215,138,.70));
  -webkit-background-clip:text;
  background-clip:text;
  color: transparent;
  text-shadow: 0 10px 40px rgba(0,0,0,.45);
}

.bx-hero-sub{
  margin-top: 10px;
  font-size: 13px;
  color: rgba(234,240,255,.62);
  max-width: 52ch;
}

.bx-hero-side{ position: relative; z-index:1; display:flex; flex-direction:column; align-items:flex-end; gap: 12px; }

.bx-stats{ display:flex; gap: 10px; flex-wrap:wrap; justify-content:flex-end; }
.bx-stat{
  min-width: 98px;
  padding: 10px 12px;
  border-radius: 16px;
  border: 1px solid rgba(148,163,184,.16);
  background: rgba(2,6,23,.42);
  box-shadow: 0 0 0 1px rgba(0,0,0,.25) inset, 0 18px 45px rgba(0,0,0,.35);
}
.bx-stat-label{
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(203,213,225,.72);
  margin-bottom: 6px;
}
.bx-stat-value{
  font-size: 22px;
  font-weight: 950;
  line-height: 1;
  letter-spacing: .2px;
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(240,215,138,.80));
  -webkit-background-clip:text;
  background-clip:text;
  color: transparent;
}

.bx-actions{ display:flex; gap:10px; align-items:center; justify-content:flex-end; }

/* Softer primary (still gold) for reload */
.bx-btn-primary-soft{
  padding: 10px 14px !important;
  border-radius: 14px !important;
  box-shadow: 0 14px 45px rgba(0,0,0,.44), 0 0 0 1px rgba(255,255,255,.10) inset !important;
}

/* ============ Controls row ============ */
.bx-controls{
  margin: 14px 0 10px;
  gap: 12px;
  flex-wrap: wrap;
  align-items: center;
}

.bx-search{
  flex: 1;
  min-width: 240px;
  max-width: 420px;
  border-radius: 14px;
  padding: 12px 14px;
  background: rgba(2,6,23,.42);
  border-color: rgba(148,163,184,.16);
  box-shadow: 0 0 0 1px rgba(0,0,0,.25) inset;
}
.bx-search:focus{
  border-color: rgba(240,215,138,.30);
  box-shadow: 0 0 0 3px rgba(240,215,138,.10), 0 0 0 1px rgba(0,0,0,.25) inset;
}

.bx-chips{ display:flex; gap: 8px; flex-wrap: wrap; }
.bx-chip{
  border: 1px solid rgba(148,163,184,.18);
  background: rgba(255,255,255,.04);
  color: rgba(226,232,240,.92);
  border-radius: 999px;
  padding: 8px 12px;
  font-weight: 800;
  font-size: 12px;
  letter-spacing: .2px;
  cursor: pointer;
  transition: transform .12s ease, background .12s ease, border-color .12s ease, box-shadow .12s ease;
}
.bx-chip:hover{ transform: translateY(-1px); border-color: rgba(240,215,138,.22); box-shadow: 0 12px 34px rgba(0,0,0,.32); }
.bx-chip.active{
  border-color: rgba(240,215,138,.34);
  background: linear-gradient(180deg, rgba(240,215,138,.18), rgba(240,215,138,.07));
  box-shadow: 0 0 0 1px rgba(0,0,0,.25) inset, 0 16px 40px rgba(0,0,0,.40);
}

/* ============ Device cards (layout polish) ============ */
.bx-device-grid{ margin-top: 10px; }

.bx-device-card{
  display:flex;
  flex-direction:column;
  gap: 8px;
  min-height: 150px;
}

.bx-device-top{ margin-bottom: 2px; }
.bx-device-name{ display:flex; align-items:center; gap: 10px; }
.bx-device-title{
  font-weight: 800;
  letter-spacing: .10em;
  text-transform: uppercase;
  font-size: 13px;
  line-height: 1.1;
  background: linear-gradient(180deg, rgba(240,215,138,.95), rgba(240,215,138,.55));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  text-shadow: 0 0 18px rgba(240,215,138,.10);
}
.bx-device-title::after{
  content:'';
  display:block;
  height:1px;
  width: 34px;
  margin-top: 6px;
  background: linear-gradient(90deg, rgba(240,215,138,.65), transparent);
  opacity:.55;
}
.bx-device-ico{
  width: 28px;
  height: 28px;
  border-radius: 10px;
  display:grid;
  place-items:center;
  background: rgba(240,215,138,.08);
  border: 1px solid rgba(240,215,138,.16);
  box-shadow: 0 10px 30px rgba(0,0,0,.30);
}

/* put the button at the bottom */
.bx-device-actions{ margin-top: auto; }

.bx-btn-ghost{
  border-radius: 12px !important;
  border-color: rgba(240,215,138,.18) !important;
  background: rgba(2,6,23,.34) !important;
  box-shadow: 0 0 0 1px rgba(0,0,0,.25) inset;
}
.bx-btn-ghost:hover{
  border-color: rgba(240,215,138,.28) !important;
  background: rgba(2,6,23,.44) !important;
  box-shadow: 0 0 0 1px rgba(240,215,138,.10), 0 16px 42px rgba(0,0,0,.45);
}


/* Badge glow pulse (sync with dot pulse) */
.badge.online{
  animation: bx-badgeGlow 1.6s ease-in-out infinite;
}
@keyframes bx-badgeGlow{
  0%,100%{ box-shadow: 0 0 0 1px rgba(34,197,94,.22) inset, 0 0 0 0 rgba(34,197,94,0); }
  50%{ box-shadow: 0 0 0 1px rgba(34,197,94,.30) inset, 0 0 18px 2px rgba(34,197,94,.10); }
}

/* Badge dot animations */
.badge.online .dot{ animation: bx-pulse 1.6s ease-in-out infinite; }
@keyframes bx-pulse{
  0%,100%{ transform: scale(1); box-shadow: 0 0 0 0 rgba(34,197,94,.0); }
  50%{ transform: scale(1.08); box-shadow: 0 0 0 8px rgba(34,197,94,.08); }
}

/* Offline: cooler, subtler glow (keeps meaning, feels premium) */
.badge.offline{
  /* neutral-cool inner ring so it doesn't look "dead" */
  box-shadow: 0 0 0 1px rgba(148,163,184,.18) inset;
  border-color: rgba(148,163,184,.18) !important;
  background: rgba(2,6,23,.34) !important;
  animation: bx-badgeOfflineGlow 2.6s ease-in-out infinite;
}
@keyframes bx-badgeOfflineGlow{
  0%,100%{ box-shadow: 0 0 0 1px rgba(148,163,184,.18) inset, 0 0 0 0 rgba(59,130,246,0); }
  50%{ box-shadow: 0 0 0 1px rgba(148,163,184,.22) inset, 0 0 16px 2px rgba(59,130,246,.06); }
}

.badge.offline .dot{ animation: bx-pulseCool 2.6s ease-in-out infinite; }
@keyframes bx-pulseCool{
  0%,100%{ transform: scale(1); box-shadow: 0 0 0 0 rgba(59,130,246,0); }
  50%{ transform: scale(1.04); box-shadow: 0 0 0 10px rgba(59,130,246,.05); }
}

/* Make watermark blend nicer behind content */
body.bg::after{
  opacity: .095;
  filter: blur(.15px);
}

/* Responsive: hero stacks */
@media (max-width: 720px){
  .bx-hero{ flex-direction:column; align-items:flex-start; }
  .bx-hero-side{ width:100%; align-items:flex-start; }
  .bx-stats{ justify-content:flex-start; }
}


/* ============ Dashboard panels (Training / Activate / Account) ============ */
.bx-panel{
  display:grid;
  grid-template-columns: 380px minmax(0,1fr);
  gap: 14px;
  margin-top: 14px;
  align-items:start;
}
.bx-panel-activate{ grid-template-columns: 420px minmax(0,1fr); }
.bx-sidebar{
  padding: 14px;
  border-radius: 22px;
  border: 1px solid var(--bx-stroke);
  background: linear-gradient(180deg, var(--bx-glass), var(--bx-glass2));
  box-shadow: var(--bx-shadow);
  overflow:hidden;
  min-height: 0;
}
.bx-main{
  display:flex;
  flex-direction:column;
  gap: 14px;
  min-width:0;
  min-height:0;
}
.card.bx-card{
  border: 1px solid rgba(240,215,138,.14);
  background: linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.026));
  box-shadow: 0 24px 90px rgba(0,0,0,.42);
}
.bx-section-title{
  font-weight: 820;
  letter-spacing: .2px;
  font-size: 15px;
}
.bx-muted{
  color: rgba(226,232,240,.72);
  font-size: 12px;
  line-height: 1.35;
}

/* Sidebar header */
.bx-sidebar-head{ margin-bottom: 10px; }
.bx-controls{ display:flex; gap: 10px; flex-wrap:wrap; align-items:center; }

/* List */
.bx-list{
  margin-top: 12px;
  display:flex;
  flex-direction:column;
  gap: 10px;
  max-height: calc(100vh - 360px);
  overflow:auto;
  padding-right: 4px;
}
.bx-empty-mini{
  padding: 14px;
  border-radius: 18px;
  border: 1px dashed rgba(148,163,184,.22);
  color: rgba(226,232,240,.65);
  text-align:center;
}

/* Satellite item */
.bx-item{
  padding: 12px 12px;
  border-radius: 18px;
  border: 1px solid rgba(148,163,184,.16);
  background: rgba(255,255,255,.028);
  cursor: pointer;
  transition: transform .14s ease, border-color .14s ease, background .14s ease, box-shadow .14s ease, filter .14s ease;
}
.bx-item:hover{
  transform: translateY(-1px);
  border-color: rgba(240,215,138,.26);
  background: rgba(255,255,255,.036);
}
.bx-item.active{
  border-color: rgba(240,215,138,.42);
  box-shadow: 0 0 0 2px rgba(240,215,138,.10), 0 10px 30px rgba(0,0,0,.28);
}
.bx-item.dragging{ opacity: .65; transform: scale(.99); filter: saturate(.9); }
.bx-item-top{ display:flex; align-items:center; justify-content:space-between; gap: 10px; }
.bx-item-title{ font-weight: 780; letter-spacing: .2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width: 210px; }
.bx-item-meta{ margin-top: 4px; font-size: 12px; color: rgba(226,232,240,.72); }

.bx-order{
  width: 28px; height: 28px;
  border-radius: 999px;
  display:flex; align-items:center; justify-content:center;
  font-weight: 860;
  border: 1px solid rgba(240,215,138,.22);
  background: rgba(240,215,138,.10);
  color: rgba(240,215,138,.92);
  flex: 0 0 auto;
}
.bx-dot{ width: 8px; height: 8px; border-radius: 999px; box-shadow: 0 0 0 7px rgba(255,255,255,.04); flex:0 0 auto; }
.bx-dot.on{ background: #22c55e; box-shadow: 0 0 0 7px rgba(34,197,94,.08); }
.bx-dot.off{ background: #ef4444; box-shadow: 0 0 0 7px rgba(239,68,68,.08); }

.bx-handle{
  width: 28px; height: 28px;
  border-radius: 10px;
  display:flex; align-items:center; justify-content:center;
  border: 1px solid rgba(148,163,184,.16);
  background: rgba(255,255,255,.03);
  color: rgba(226,232,240,.70);
  cursor: grab;
  user-select:none;
}
.bx-handle:active{ cursor: grabbing; }

.bx-toggle{
  width: 36px; height: 22px;
  border-radius: 999px;
  border: 1px solid rgba(148,163,184,.18);
  background: rgba(255,255,255,.06);
  position: relative;
  flex: 0 0 auto;
}
.bx-toggle::after{
  content:"";
  position:absolute;
  top: 3px; left: 3px;
  width: 14px; height: 14px;
  border-radius: 999px;
  background: rgba(226,232,240,.78);
  transition: left .16s ease, background .16s ease, transform .16s ease;
}
.bx-toggle.on{
  border-color: rgba(240,215,138,.34);
  background: rgba(240,215,138,.14);
}
.bx-toggle.on::after{
  left: 19px;
  background: rgba(240,215,138,.92);
}

/* Scan */
.bx-scan{
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 10;
  border-radius: 18px;
  overflow:hidden;
  border: 1px solid rgba(148,163,184,.16);
  background: #000;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.55);
}
.bx-scan-video{ width:100%; height:100%; object-fit:cover; filter: contrast(1.06) saturate(1.05); }
.bx-scan-frame{
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  pointer-events:none;
}
.bx-scan-frame::before{
  content:"";
  width: 62%;
  height: 62%;
  border-radius: 18px;
  border: 2px solid rgba(240,215,138,.72);
  box-shadow: 0 0 0 8px rgba(240,215,138,.10), 0 18px 60px rgba(0,0,0,.30);
  background: rgba(0,0,0,.08);
}

/* Tips */
.bx-tip{
  display:flex;
  gap: 10px;
  padding: 12px 12px;
  border-radius: 18px;
  border: 1px solid rgba(148,163,184,.14);
  background: rgba(255,255,255,.024);
}
.bx-tip-dot{
  width: 20px; height: 20px;
  border-radius: 999px;
  display:flex; align-items:center; justify-content:center;
  font-weight: 900;
  font-size: 12px;
  color: rgba(240,215,138,.95);
  border: 1px solid rgba(240,215,138,.24);
  background: rgba(240,215,138,.10);
  flex: 0 0 auto;
}

/* Live */
.bx-live-wrap{ display:flex; flex-direction:column; gap: 14px; }
.bx-progress{
  height: 10px;
  border-radius: 999px;
  border: 1px solid rgba(148,163,184,.16);
  background: rgba(255,255,255,.03);
  overflow:hidden;
}
.bx-progress-bar{
  height:100%;
  width:0%;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--brand-3), var(--brand-2));
  box-shadow: 0 0 0 6px rgba(240,215,138,.08);
}
.bx-kpis{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.bx-kpi{
  padding: 12px 14px;
  border-radius: 18px;
  border: 1px solid rgba(148,163,184,.14);
  background: rgba(255,255,255,.024);
}
.bx-kpi-l{ font-size: 12px; color: rgba(226,232,240,.68); }
.bx-kpi-v{ font-size: 18px; font-weight: 900; letter-spacing: .2px; }
.bx-live-info{ color: rgba(226,232,240,.74); font-size: 12px; }

.bx-score-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.bx-score-card{
  padding: 12px 12px;
  border-radius: 18px;
  border: 1px solid rgba(148,163,184,.14);
  background: rgba(255,255,255,.024);
  transition: transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.bx-score-card.active{
  border-color: rgba(240,215,138,.40);
  box-shadow: 0 0 0 2px rgba(240,215,138,.10);
  transform: translateY(-1px);
}
.bx-score-card.hit{
  box-shadow: 0 0 0 2px rgba(240,215,138,.18), 0 0 0 10px rgba(240,215,138,.05);
}
.bx-score-name{ font-weight: 780; }
.bx-score-badge{
  min-width: 34px;
  height: 24px;
  border-radius: 999px;
  padding: 0 10px;
  display:flex; align-items:center; justify-content:center;
  font-weight: 900;
  border: 1px solid rgba(240,215,138,.20);
  background: rgba(240,215,138,.10);
  color: rgba(240,215,138,.95);
}

@media (max-width: 980px){
  .bx-panel{ grid-template-columns: 1fr; }
  .bx-list{ max-height: none; }
  .bx-item-title{ max-width: 100%; }
}
@media (max-width: 720px){
  .bx-kpis{ grid-template-columns: 1fr; }
  .bx-score-grid{ grid-template-columns: 1fr; }
}

/* Account KV */
.bx-kv{ display:flex; flex-direction:column; gap: 10px; margin-top: 10px; }
.bx-kv-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  padding: 12px 12px;
  border-radius: 18px;
  border: 1px solid rgba(148,163,184,.14);
  background: rgba(255,255,255,.024);
}
.bx-kv-key{ color: rgba(226,232,240,.68); font-size: 12px; }
.bx-kv-right{ display:flex; align-items:center; gap: 10px; min-width: 0; }
.bx-kv-val{ font-weight: 800; letter-spacing: .1px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width: 52vw; }
.bx-mini-btn{
  width: 34px; height: 28px;
  border-radius: 12px;
  border: 1px solid rgba(148,163,184,.18);
  background: rgba(255,255,255,.04);
  color: rgba(226,232,240,.86);
  cursor: pointer;
  transition: transform .12s ease, border-color .12s ease, background .12s ease;
}
.bx-mini-btn:hover{
  transform: translateY(-1px);
  border-color: rgba(240,215,138,.26);
  background: rgba(255,255,255,.06);
}
.bx-input-lg{ padding: 12px 12px; border-radius: 16px; }


/* ============ Motion: page transitions (hash routes) ============ */
body.bg #app{
  transition: opacity 180ms ease, transform 180ms ease, filter 180ms ease;
  will-change: opacity, transform, filter;
}
body.bg.page-transitioning #app{
  opacity: 0;
  transform: translateY(10px) scale(.996);
  filter: blur(1px);
}

/* route-enter hook: gentle pop-in for key elements */
@keyframes bx-fade-up{
  from{ opacity: 0; transform: translateY(10px); }
  to  { opacity: 1; transform: translateY(0); }
}
body.bg.route-enter #app .bx-hero,
body.bg.route-enter #app .bx-panel,
body.bg.route-enter #app .card,
body.bg.route-enter #app .bx-card,
body.bg.route-enter #app .bx-item,
body.bg.route-enter #app .bx-stat{
  animation: bx-fade-up .36s ease both;
}

/* small stagger on device cards only */
body.bg.route-enter[data-route="/devices"] #app .grid .card{ animation-duration: .38s; }
body.bg.route-enter[data-route="/devices"] #app .grid .card:nth-child(1){ animation-delay: 30ms; }
body.bg.route-enter[data-route="/devices"] #app .grid .card:nth-child(2){ animation-delay: 60ms; }
body.bg.route-enter[data-route="/devices"] #app .grid .card:nth-child(3){ animation-delay: 90ms; }
body.bg.route-enter[data-route="/devices"] #app .grid .card:nth-child(4){ animation-delay: 120ms; }
body.bg.route-enter[data-route="/devices"] #app .grid .card:nth-child(5){ animation-delay: 150ms; }
body.bg.route-enter[data-route="/devices"] #app .grid .card:nth-child(6){ animation-delay: 180ms; }

/* reduce motion */
@media (prefers-reduced-motion: reduce){
  body.bg #app{ transition: none; }
  body.bg.page-transitioning #app{ opacity: 1; transform: none; filter: none; }
  body.bg.route-enter #app *{ animation: none !important; }
}

/* ============ Accent glows (hover) ============ */
@media (hover:hover){
  /* buttons */
  body.bg .btn,
  body.bg button,
  body.bg .nav .nav-link{
    transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease, background-color 160ms ease;
  }
  body.bg .btn:hover,
  body.bg button:hover{
    transform: translateY(-1px);
    box-shadow:
      0 18px 45px rgba(0,0,0,.45),
      0 0 0 1px rgba(240,215,138,.18) inset,
      0 0 22px rgba(240,215,138,.10);
    border-color: rgba(240,215,138,.22);
  }
  body.bg .btn.primary:hover{
    box-shadow:
      0 22px 60px rgba(0,0,0,.55),
      0 0 0 1px rgba(240,215,138,.35) inset,
      0 0 28px rgba(240,215,138,.16);
  }

  /* nav pills */
  body.bg .nav .nav-link:hover{
    transform: translateY(-1px);
    box-shadow:
      0 14px 38px rgba(0,0,0,.42),
      0 0 0 1px rgba(240,215,138,.16) inset;
  }
  body.bg .nav .nav-link.active,
  body.bg .ant-nav-link.active{
    box-shadow:
      0 18px 46px rgba(0,0,0,.50),
      0 0 0 1px rgba(240,215,138,.22) inset,
      0 0 26px rgba(240,215,138,.12);
  }

  /* cards */
  body.bg .card{
    transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
  }
  body.bg .card:hover{
    transform: translateY(-2px);
    border-color: rgba(240,215,138,.20);
    box-shadow:
      0 26px 80px rgba(0,0,0,.56),
      0 0 0 1px rgba(240,215,138,.10) inset;
  }
}

/* ============ Active tab: gold capsule (stronger) ============ */
body.bg .nav .nav-link.active,
body.bg .ant-nav-link.active{
  color: rgba(255,255,255,.96);
  border-color: rgba(240,215,138,.26);
  background:
    radial-gradient(120px 70px at 30% 20%, rgba(240,215,138,.22), transparent 62%),
    linear-gradient(180deg, rgba(240,215,138,.16), rgba(255,255,255,.04));
}

/* Underline sweep also for injected Training link */
header.topbar .ant-nav-link{ position: relative; overflow:hidden; }
header.topbar .ant-nav-link::after{
  content:"";
  position:absolute;
  left:12px; right:12px; bottom:6px;
  height:2px;
  border-radius: 99px;
  background: linear-gradient(90deg, rgba(240,215,138,0), rgba(240,215,138,.70), rgba(240,215,138,0));
  transform: translateX(-140%);
  opacity: 0;
  transition: transform .38s ease, opacity .28s ease;
}
header.topbar .ant-nav-link:hover::after,
header.topbar .ant-nav-link.active::after{
  transform: translateX(0);
  opacity: 1;
}

/* ============ Toasts: premium glass + accent bar ============ */
body.bg .toast-wrap{
  right: max(16px, env(safe-area-inset-right));
  bottom: max(16px, env(safe-area-inset-bottom));
}
body.bg .toast{
  position: relative;
  overflow: hidden;
  cursor: pointer;
  background: rgba(2,6,23,.72);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(148,163,184,.16);
  border-radius: 14px;
  padding: 11px 12px 11px 14px;
  box-shadow: 0 18px 50px rgba(0,0,0,.55);
  animation: bx-toast-in .22s ease both;
}
@keyframes bx-toast-in{
  from{ opacity: 0; transform: translateY(10px); }
  to{ opacity: 1; transform: translateY(0); }
}
body.bg .toast::before{
  content:"";
  position:absolute;
  left:0; top:0; bottom:0;
  width: 3px;
  background: linear-gradient(180deg, rgba(240,215,138,.95), rgba(240,215,138,.35));
  opacity: .95;
}
body.bg .toast.ok::before{
  background: linear-gradient(180deg, rgba(52,211,153,.95), rgba(16,185,129,.35));
}
body.bg .toast.err::before{
  background: linear-gradient(180deg, rgba(251,113,133,.95), rgba(239,68,68,.35));
}
@media (hover:hover){
  body.bg .toast:hover{
    transform: translateY(-1px);
    box-shadow: 0 22px 60px rgba(0,0,0,.62), 0 0 24px rgba(240,215,138,.10);
  }
}

/* === Brand mark (monochrome gold) === */
:root{
  --bx-gold-1: rgba(240,215,138,1);
  --bx-gold-2: rgba(198,164,92,1);
}
.brand-lockup{
  display:flex;
  align-items:center;
  gap: 14px;
  padding: 10px 14px;
  border-radius: 18px;
  min-width: 260px;
  background: radial-gradient(120% 120% at 25% 10%, rgba(240,215,138,.14), rgba(240,215,138,0) 55%),
              linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,0));
  border: 1px solid rgba(240,215,138,.16);
  box-shadow: 0 18px 60px rgba(0,0,0,.55), inset 0 1px 0 rgba(255,255,255,.06);
}

.brand-lockup .brand-name{
  font-weight: 800;
  font-size: 18px;
  letter-spacing: .4px;
  color: rgba(255,255,255,.92);
  text-shadow: 0 10px 28px rgba(0,0,0,.55);
}
.brand-lockup:hover .brand-name{
  color: rgba(255,255,255,.98);
}

.brand-mark{
  width: 42px;
  height: 42px;
  display:inline-block;
  border-radius: 999px;
  position: relative;
  background: radial-gradient(120% 120% at 30% 25%, rgba(240,215,138,.22), rgba(240,215,138,0) 55%),
              linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,0));
  border: 1px solid rgba(240,215,138,.18);
  box-shadow: 0 16px 46px rgba(0,0,0,.58), 0 0 18px rgba(240,215,138,.12);
  overflow:hidden;
}
.brand-mark::before{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(180deg, var(--bx-gold-1), var(--bx-gold-2));
  -webkit-mask-image: url("logo-mask-128.png");
  mask-image: url("logo-mask-128.png");
  -webkit-mask-size: 78% 78%;
  mask-size: 78% 78%;
  -webkit-mask-repeat:no-repeat;
  mask-repeat:no-repeat;
  -webkit-mask-position:center;
  mask-position:center;
  opacity:.95;
}
.brand-mark::after{
  content:"";
  position:absolute;
  top:-55%;
  left:-60%;
  width:60%;
  height:210%;
  transform: rotate(18deg);
  background: linear-gradient(90deg, rgba(255,255,255,0), rgba(255,255,255,.22), rgba(255,255,255,0));
  opacity:0;
  filter: blur(.2px);
  pointer-events:none;
}
.brand-lockup:hover .brand-mark::after{
  opacity:1;
  animation: bxShine .65s ease-out 1;
}
@keyframes bxShine{
  0%{ transform: translateX(-40%) rotate(18deg); opacity:0; }
  20%{ opacity:.9; }
  100%{ transform: translateX(260%) rotate(18deg); opacity:0; }
}

.brand-mark::before{
  content:"";
  position:absolute;
  inset: 6px;
  background: linear-gradient(180deg, var(--bx-gold-1), var(--bx-gold-2));
  -webkit-mask-image: url("logo-mask-64.png");
  mask-image: url("logo-mask-64.png");
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: contain;
  mask-size: contain;
  filter: drop-shadow(0 6px 10px rgba(0,0,0,.35));
  opacity: .95;
}
@media (hover:hover){
  .brand-lockup:hover .brand-mark{
    box-shadow: 0 18px 46px rgba(0,0,0,.62), 0 0 26px rgba(240,215,138,.16);
    border-color: rgba(240,215,138,.26);
  }
  .brand-lockup:hover .brand-name{
    text-shadow: 0 0 16px rgba(240,215,138,.16);
  }
}

/* Device icon replaced with brand mark */
.bx-device-ico.bx-mark{
  width: 18px;
  height: 18px;
  display:inline-block;
  flex: 0 0 18px;
  margin-right: 8px;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--bx-gold-1), var(--bx-gold-2));
  -webkit-mask-image: url("logo-mask-64.png");
  mask-image: url("logo-mask-64.png");
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: contain;
  mask-size: contain;
  opacity: .92;
  filter: drop-shadow(0 3px 6px rgba(0,0,0,.45));
}
.empty-ico.bx-mark{
  width: 52px;
  height: 52px;
  margin-bottom: 10px;
  border-radius: 18px;
  background: radial-gradient(120% 120% at 30% 20%, rgba(240,215,138,.22), rgba(240,215,138,0) 55%),
              linear-gradient(180deg, rgba(240,215,138,.95), rgba(198,164,92,.85));
  -webkit-mask-image: url("logo-mask-256.png");
  mask-image: url("logo-mask-256.png");
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: contain;
  mask-size: contain;
  filter: drop-shadow(0 10px 18px rgba(0,0,0,.55));
}


/* Center nav, keep brand left and language right */
header.topbar{ gap: 14px; }
header.topbar .nav{ flex: 1; display:flex; justify-content:center; gap: 10px; }
#bx-lang-widget{ margin-left: 12px; }
@media (max-width: 900px){
  header.topbar .nav{ justify-content:flex-end; flex: 0 1 auto; }
  .brand-lockup{ min-width: 210px; }
}



/* === Brand subtitle + separator === */
.brand-lockup{ min-width: 330px; padding: 12px 16px; gap: 14px; }
.brand-lockup .brand-text{ display:flex; flex-direction:column; line-height:1.05; }
.brand-lockup .brand-name{ font-size: 20px; }
.brand-lockup .brand-sub{
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(240,215,138,.78);
  opacity: .0;
  transform: translateY(2px);
  transition: opacity .22s ease, transform .22s ease;
}
.brand-lockup:hover .brand-sub{
  opacity: 1;
  transform: translateY(0);
}
.brand-sep{
  width: 1px;
  height: 42px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(240,215,138,0), rgba(240,215,138,.30), rgba(148,163,184,.20), rgba(240,215,138,0));
  box-shadow: 0 0 18px rgba(240,215,138,.12);
  margin-left: 10px;
  margin-right: 10px;
}

/* === Extra motion / micro-interactions === */
@keyframes bxFloat { 0%,100%{ transform: translateY(0);} 50%{ transform: translateY(-2px);} }
@media (hover:hover){
  .brand-lockup:hover .brand-mark{ animation: bxFloat 1.6s ease-in-out infinite; }
}
header.topbar .nav-link{
  position: relative;
  overflow: hidden;
}
header.topbar .nav-link::after{
  content:"";
  position:absolute;
  left:12px; right:12px; bottom:6px;
  height:2px;
  border-radius: 99px;
  background: linear-gradient(90deg, rgba(240,215,138,0), rgba(240,215,138,.70), rgba(240,215,138,0));
  transform: translateX(-140%);
  opacity: .0;
  transition: transform .38s ease, opacity .28s ease;
}
header.topbar .nav-link:hover::after{
  transform: translateX(0);
  opacity: 1;
}

/* Hero shimmer */
.bx-hero::after{
  content:"";
  position:absolute; inset:-2px;
  border-radius: inherit;
  pointer-events:none;
  background: linear-gradient(120deg,
    rgba(240,215,138,0) 0%,
    rgba(240,215,138,.10) 12%,
    rgba(255,255,255,.06) 20%,
    rgba(240,215,138,0) 32%,
    rgba(240,215,138,0) 100%);
  transform: translateX(-55%) translate(var(--spot-x), var(--spot-y));
  opacity:.45;
  filter: blur(.2px);
  animation: bxHeroShimmer 10s ease-in-out infinite;
}

/* Offline drama (scanline + status text) */
.bx-hero-status{
  margin-top: 10px;
  font: 600 12px/1.2 system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: rgba(240,215,138,.92);
  text-shadow: 0 0 16px rgba(240,215,138,.18);
}
.bx-hero.bx-hero-offline::before{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius: inherit;
  pointer-events:none;
  background:
    linear-gradient(180deg, rgba(59,130,246,.00), rgba(59,130,246,.06), rgba(59,130,246,.00));
  mix-blend-mode: screen;
  opacity: .55;
  animation: bxScanLine 2.6s linear infinite;
}
@keyframes bxScanLine{
  0%{ transform: translateY(-80%); opacity:.00; }
  12%{ opacity:.55; }
  70%{ opacity:.28; }
  100%{ transform: translateY(80%); opacity:.00; }
}

/* Card hover: specular highlight sweep */
.bx-device-card{ position: relative; overflow:hidden; }
.bx-device-card::before{
  content:"";
  position:absolute;
  top:-40%; left:-60%;
  width: 60%; height: 180%;
  background: linear-gradient(120deg,
    rgba(255,255,255,0),
    rgba(240,215,138,.18),
    rgba(255,255,255,.10),
    rgba(255,255,255,0));
  transform: translateX(-30%) rotate(12deg);
  opacity: 0;
  pointer-events:none;
}
@media (hover:hover){
  .bx-device-card:hover::before{
    opacity: .85;
    animation: bxSpecular 700ms ease-out forwards;
  }
}
@keyframes bxSpecular{
  from{ transform: translateX(-40%) rotate(12deg); }
  to{ transform: translateX(220%) rotate(12deg); }
}
@keyframes bxHeroShimmer{
  0%{ transform: translateX(-55%); opacity:.15; }
  35%{ opacity:.55; }
  60%{ opacity:.30; }
  100%{ transform: translateX(55%); opacity:.12; }
}

/* Card enter animation (only when class is present) */
.bx-anim-in{
  animation: bxPopIn .46s ease-out both;
}
@keyframes bxPopIn{
  from{ opacity:0; transform: translateY(10px) scale(.985); filter: blur(.5px); }
  to{ opacity:1; transform: translateY(0) scale(1); filter: blur(0); }
}

/* Cursor halo (header only) */
.bx-cursor-halo{
  position: fixed;
  inset: 0 0 auto 0;
  height: 140px;
  pointer-events:none;
  z-index: 40;
  opacity: var(--halo-a);
  transition: opacity .18s ease;
  background:
    radial-gradient(220px 160px at var(--halo-x) var(--halo-y),
      rgba(240,215,138,.16),
      rgba(240,215,138,.06) 35%,
      rgba(78,93,163,.06) 55%,
      transparent 72%);
  mix-blend-mode: screen;
  filter: blur(0.2px);
}

/* Reduce motion: disable halo & parallax */
@media (prefers-reduced-motion: reduce){
  .bx-cursor-halo{ display:none !important; }
  :root{ --spot-x:0px; --spot-y:0px; --wm-x:0px; --wm-y:0px; --halo-a:0; }
}


/* ===== Stability / Lite mode (used on /account) ===== */
body.bx-lite .bx-cursor-halo{ display:none !important; }
body.bx-lite.bg::after{ opacity: 0 !important; filter:none !important; }
body.bx-lite .bx-topbar,
body.bx-lite .bx-hero,
body.bx-lite .bx-card,
body.bx-lite .bx-panel,
body.bx-lite .bx-sidebar{
  -webkit-backdrop-filter: none !important;
  backdrop-filter: none !important;
}



/* ===== iOS Safari perf guardrails ===== */
@supports (-webkit-touch-callout: none){
  /* iOS tends to struggle with big blurred fixed layers */
  .bx-halo{ display:none !important; } /* halo is desktop candy */
  .bx-wm{ will-change: auto; }
}
/* If user prefers reduced motion, kill cinematic transforms */
@media (prefers-reduced-motion: reduce){
  .bx-wm, .bx-spotlight, .bx-halo, .bx-scanline{
    animation: none !important;
    transform: none !important;
  }
}



/* ===== Mobile Safari/Chrome form zoom fix =====
   iOS Safari auto-zooms inputs when font-size < 16px.
   Also avoid OTP letter-spacing leaking to normal inputs.
*/
html{ -webkit-text-size-adjust: 100%; }
@supports (-webkit-touch-callout: none){
  /* iOS specific: ensure form controls never trigger focus zoom */
  input, textarea, select{ font-size:16px !important; }
}

/* General mobile: keep inputs readable and stop zoom */
@media (max-width: 680px){
  input, textarea, select{ font-size:16px !important; }
  /* Normal text inputs must not inherit OTP styling */
  .bx-input:not(.bx-otp-input){
    letter-spacing: normal !important;
    text-align: left !important;
  }
  /* OTP can stay cinematic, but still >=16px */
  .bx-otp-input{
    font-size:18px !important;
    letter-spacing: .35em !important;
    text-align: center !important;
  }
  /* Long emails must wrap on small screens */
  .bx-step-caption, .bx-login-subtitle{
    overflow-wrap: anywhere;
    word-break: break-word;
  }
}


/* prevent iOS zoom on focus (Safari/Chrome iOS) */
@supports (-webkit-touch-callout: none){
  input, textarea, select{font-size:16px !important;}
}
