/* ==========================================================================
   科技熊 · 深空终端 — user-center re-skin (P0 baseline)
   Override layer loaded AFTER the Metronic bundle (see include/global/head.tpl).
   Scoped under body.kt-deepspace so it only touches /user pages; the 2.24MB
   compiled Metronic bundle is NEVER edited. This re-skins EXISTING markup only
   (no .tpl markup changes) — the bespoke hero/ring/count-up + per-class bear
   crest land in P1/P2 (see docs/user-center-deepspace/PLAN.md).
   Rollback: delete the one <link> line in head.tpl -> 100% revert.
   ========================================================================== */

/* ====================== 1. FOUNDATION ====================== */
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:400 700;font-display:swap;
  src:url('/theme/deepspace/fonts/spacegrotesk.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+2000-206F,U+2074,U+20AC,U+2212,U+2215;}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:400 700;font-display:swap;
  src:url('/theme/deepspace/fonts/jetbrainsmono.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+2000-206F,U+2074,U+20AC,U+2212,U+2215;}

:root{
  --bg:#07080C;--bg-elev:#0C0E16;--panel:#11141F;--hair:rgba(255,255,255,.08);
  --text:#EAEEF7;--muted:#8A93A6;--cyan:#38E1FF;--iris:#6E7BFF;--mint:#34F5C5;--gold:#E8C37A;
  --fsans:-apple-system,BlinkMacSystemFont,"PingFang SC","Microsoft YaHei","Noto Sans SC",sans-serif;
  --fdisp:"Space Grotesk",-apple-system,"PingFang SC",system-ui,sans-serif;
  --fmono:"JetBrains Mono",ui-monospace,Menlo,Consolas,monospace;
  --r-card:18px;--r-bar:20px;--r-field:13px;--r-pill:999px;--gap:24px;}

/* ====================== 2. BASE BODY + TYPOGRAPHY ====================== */
body.kt-deepspace{
  font-family:var(--fsans)!important;color:var(--text);
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;}

/* display headings -> Space Grotesk */
body.kt-deepspace #kt_subheader h2,
body.kt-deepspace .card.card-custom .card-label,
body.kt-deepspace .wizard .wizard-nav h3,
body.kt-deepspace .card-body h3.animated{
  font-family:var(--fdisp)!important;letter-spacing:-.01em;color:var(--text)!important;}

/* numbers / specs / code -> JetBrains Mono (CJK falls through to system stack
   via the unicode-range trick, so mixed strings like "2026-07-15 到期" work) */
body.kt-deepspace .counter,
body.kt-deepspace .font-size-h2,body.kt-deepspace .font-size-h3,body.kt-deepspace .font-size-h4,
body.kt-deepspace .display-1,body.kt-deepspace .display-2,
body.kt-deepspace .display-3,body.kt-deepspace .display-4,body.kt-deepspace .display-5,
body.kt-deepspace code,body.kt-deepspace kbd,body.kt-deepspace pre,
body.kt-deepspace .copy-text{font-family:var(--fmono)!important;font-feature-settings:"tnum" 1;}
/* inline <code> (shop coupon codes, inline link chips like 用户首页/节点列表) ->
   deepspace chip. Bootstrap's default <code> is light-pink, off-theme on dark. */
body.kt-deepspace code{
  background:var(--bg-elev)!important;color:var(--cyan)!important;
  border:1px solid var(--hair)!important;border-radius:6px;padding:2px 7px;}
body.kt-deepspace code a,body.kt-deepspace code a:hover{color:var(--cyan)!important;}
body.kt-deepspace pre{
  background:var(--bg-elev)!important;color:var(--text)!important;
  border:1px solid var(--hair)!important;border-radius:10px;padding:14px 16px;}

/* KPI hero numbers (membership .counter / traffic+device+balance strong>a) */
body.kt-deepspace .card.card-custom .font-size-h4 .counter,
body.kt-deepspace .card.card-custom .font-size-h4 strong,
body.kt-deepspace .card.card-custom .font-size-h4 strong a{
  font-family:var(--fmono)!important;font-weight:700!important;letter-spacing:-.02em;
  font-variant-numeric:tabular-nums;text-decoration:none!important;}

/* KPI sub-text (expiry / speed limit / next reset) — CN labels stay system, digits go mono */
/* KPI sub-labels only (.text-dark-50) — NOT every card-body <p> (that muted +
   mono'd prose like the tutorial steps, hurting readability). */
body.kt-deepspace .card.card-custom .card-body p.text-dark-50,
body.kt-deepspace .card.card-custom .card-body .font-size-sm{
  font-family:var(--fmono)!important;color:var(--muted)!important;}

/* ====================== 3. CANVAS + BACKGROUND FIELD ====================== */
/* body keeps its inline background-image (user_bg_top.jpg header band, head.tpl:21);
   we only set background-color underneath it. */
body.kt-deepspace{
  background-color:var(--bg)!important;
  background-repeat:no-repeat!important;background-position:top center!important;
  background-size:100% 520px!important;}

/* grid layer (::before) — strongest at top, masked out below */
body.kt-deepspace::before{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background-image:
    linear-gradient(var(--hair) 1px,transparent 1px),
    linear-gradient(90deg,var(--hair) 1px,transparent 1px);
  background-size:54px 54px;opacity:.3;
  -webkit-mask-image:radial-gradient(120% 90% at 50% 0%,#000 30%,transparent 78%);
          mask-image:radial-gradient(120% 90% at 50% 0%,#000 30%,transparent 78%);}

/* aurora layer (::after) — soft radial stops fake blur(100px), cheap on GPU.
   NOTE: shares ::after with the loading splash (§19); while body.page-loading is
   present the splash wins (more specific); after DOM-ready the aurora shows. */
body.kt-deepspace::after{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(680px 560px at 30% -180px,rgba(42,59,255,.30),transparent 62%),
    radial-gradient(560px 460px at 60% -100px,rgba(0,224,255,.20),transparent 60%),
    radial-gradient(480px 400px at -6% 40%,rgba(110,123,255,.13),transparent 60%);}

/* let the field show through structural shells */
body.kt-deepspace .d-flex.flex-column.flex-root,
body.kt-deepspace .page,
body.kt-deepspace #kt_wrapper,
body.kt-deepspace #kt_content,
body.kt-deepspace .subheader{background:transparent!important;}

/* ====================== 4. CARDS / KILL MACARONS / TEXT / SVG ====================== */
/* generic panel -> deepspace glass (solid + hairline + inner top highlight) */
body.kt-deepspace .card.card-custom{
  background:linear-gradient(180deg,rgba(255,255,255,.03),transparent),var(--panel)!important;
  border:1px solid var(--hair)!important;border-radius:var(--r-card)!important;
  box-shadow:0 16px 40px rgba(0,0,0,.40),inset 0 1px 0 rgba(255,255,255,.05)!important;}
body.kt-deepspace .card.card-custom.shadow-lg,
body.kt-deepspace .shadow-lg{box-shadow:0 16px 40px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.05)!important;}
body.kt-deepspace .card.card-custom .card-header{background:transparent!important;}
/* respect Metronic's .border-0 (shop/agent use an empty .card-header.border-0 as a
   top spacer — drawing a hairline there floats a weird divider above the title). */
body.kt-deepspace .card.card-custom .card-header:not(.border-0){border-bottom:1px solid var(--hair)!important;}
body.kt-deepspace .card-label,body.kt-deepspace .card-title{color:var(--text)!important;}
/* bare .card (NOT .card-custom): onboarding wizard + node-list class accordion
   group headers ("白金会员" etc.). Metronic leaves these white, so force dark
   (needs !important + :not to beat the bundle's .card{background:#fff}). */
body.kt-deepspace .card:not(.card-custom){
  background:var(--panel)!important;color:var(--text)!important;border:1px solid var(--hair)!important;}
body.kt-deepspace .card:not(.card-custom) > .card-header{background:transparent!important;border-color:var(--hair)!important;}
/* accordion group cards (node-list class headers "白金会员" etc.): the visible chip
   IS the .card-header.rounded-xl.shadow-lg. Styling the wrapper .card too drew a
   second, smaller-radius (5px) border around the rounded (16px) header = doubled
   corner. Make the wrapper transparent and let the header be the single chip. */
body.kt-deepspace .accordion .card{background:transparent!important;border:0!important;box-shadow:none!important;}
body.kt-deepspace .accordion .card > .card-header{
  background:var(--panel)!important;border:1px solid var(--hair)!important;border-radius:16px!important;}
/* the .accordion-svg-toggle .card-title carries the white bg (not .card/.card-header) */
body.kt-deepspace .accordion .card-title{background:transparent!important;color:var(--text)!important;}
body.kt-deepspace .accordion .card-title .card-label{color:var(--text)!important;}
/* the accordion chevron is an uncolored .svg-icon (fill #000000 -> invisible on dark) */
body.kt-deepspace .accordion .card-header .svg-icon svg g [fill]{fill:var(--muted)!important;}

/* pastel corner art (abstract-2.svg), inline-tinted cards (#663259 purple),
   photo cards (img-16.jpg) -> flat panel; !important flattens both image & color */
body.kt-deepspace .card.bgi-no-repeat{
  background-image:linear-gradient(180deg,rgba(255,255,255,.03),transparent)!important;
  background-color:var(--panel)!important;}

/* 4 KPI macaron tints + assorted light fills + agent solid cards -> flat panel.
   Use .card.bg-* (not bare .bg-*) so progress-bar/label bg-primary stays untouched. */
body.kt-deepspace .bg-diagonal,
body.kt-deepspace .bg-diagonal-light-primary,
body.kt-deepspace .bg-diagonal-light-success,
body.kt-deepspace .bg-diagonal-light-warning,
body.kt-deepspace .bg-diagonal-light-danger,
body.kt-deepspace .bg-white,
body.kt-deepspace .card.bg-primary,
body.kt-deepspace .card.bg-success,
body.kt-deepspace .card.bg-info,
body.kt-deepspace .card.bg-warning,
body.kt-deepspace .card.bg-danger,
body.kt-deepspace [class*="bg-radial-gradient"]{
  background-image:none!important;background-color:var(--panel)!important;}
/* the diagonal macaron is painted by ::before/::after pseudo overlays
   (style.white.css ~21727) that sit ON TOP of the card bg — kill them so the
   dark panel shows through. This is what actually flattens the 4 KPI cards. */
body.kt-deepspace .bg-diagonal:before,
body.kt-deepspace .bg-diagonal:after{display:none!important;}
body.kt-deepspace .card.bg-primary .text-white,
body.kt-deepspace .card.bg-primary .text-inverse-primary{color:var(--text)!important;}

/* text utilities -> deepspace text/muted; separators -> hair */
body.kt-deepspace .text-dark,body.kt-deepspace .text-dark-75,
body.kt-deepspace h1,body.kt-deepspace h2,body.kt-deepspace h3,
body.kt-deepspace h4,body.kt-deepspace h5,body.kt-deepspace .text-white{color:var(--text)!important;}
body.kt-deepspace .text-dark-50,body.kt-deepspace .text-muted{color:var(--muted)!important;opacity:1;}
body.kt-deepspace .text-primary{color:var(--cyan)!important;}
body.kt-deepspace .separator,body.kt-deepspace .separator-dashed,
body.kt-deepspace .separator-border-4{border-color:var(--hair)!important;}

/* symbol bricks (client logos, avatars) -> sunken bg-elev well */
body.kt-deepspace .symbol .symbol-label,
body.kt-deepspace .symbol.symbol-light .symbol-label,
body.kt-deepspace .bg-light-primary{
  background-color:var(--bg-elev)!important;border:1px solid var(--hair)!important;}

/* SVG icon recolor (Metronic drives fill via CSS on inline <svg> <g> [fill]) */
body.kt-deepspace .svg-icon.svg-icon-primary svg g [fill]{fill:var(--cyan)!important;}
body.kt-deepspace .svg-icon.svg-icon-success svg g [fill]{fill:var(--mint)!important;}
body.kt-deepspace .svg-icon.svg-icon-warning svg g [fill]{fill:var(--gold)!important;}
body.kt-deepspace .svg-icon.svg-icon-danger  svg g [fill]{fill:var(--iris)!important;}
body.kt-deepspace .svg-icon.svg-icon-white   svg g [fill]{fill:var(--text)!important;}

/* ====================== 5. KPI SEMANTIC COLORS ====================== */
/* KPI number row -> mono + bold at NATIVE size. The oversized hero numbers are a
   P1 job (they need restructured markup with one number per card); forcing 30px
   here made cells like "0 / 无限制" wrap onto a second line. */
body.kt-deepspace .card-custom .font-size-h4 strong a,
body.kt-deepspace .card-custom .font-size-h4 .counter{
  font-family:var(--fmono)!important;font-weight:700!important;
  color:var(--text)!important;text-decoration:none!important;}
body.kt-deepspace .card-custom .font-size-h4 a:hover{color:var(--cyan)!important;}

/* per-card semantic color via the sibling svg-icon-* (modern engines only; old X5
   webviews lacking :has() fall back to --text — readable, still mono/flat). */
body.kt-deepspace .card-custom:has(.svg-icon-primary) .font-size-h4 .counter,
body.kt-deepspace .card-custom:has(.ds-class-crest) .font-size-h4 .counter{color:var(--cyan)!important;}
body.kt-deepspace .card-custom:has(.svg-icon-success) .font-size-h4 strong a{color:var(--mint)!important;}
/* card 2 lost its svg-icon-success (now a .ds-ring) — keep its number mint */
body.kt-deepspace .card-custom:has(.ds-ring) .font-size-h4 strong a{color:var(--mint)!important;}
body.kt-deepspace .card-custom:has(.svg-icon-warning) .font-size-h4 strong a{color:var(--iris)!important;}
body.kt-deepspace .card-custom:has(.svg-icon-danger)  .font-size-h4 strong a{color:var(--gold)!important;}

/* KPI 4x glyph -> faint hairline tile */
/* KPI icon slot: all 4 (bear / ring / phone / wallet) = bare 52px glyphs, top-aligned,
   no tile -> one cohesive, balanced set (was: tiles on cards 3-4, 3 different sizes). */
body.kt-deepspace .card-custom .svg-icon-4x{align-self:flex-start;}
body.kt-deepspace .card-custom .svg-icon-4x svg{width:52px!important;height:52px!important}

/* "advance reset" chip */
body.kt-deepspace #advance_reset_flow_onclick.label,
body.kt-deepspace .label-success{
  background:rgba(52,245,197,.12)!important;color:var(--mint)!important;border:1px solid var(--hair)!important;}

/* ====================== 6. HEADER / TOPBAR / MOBILE / OFFCANVAS ====================== */
body.kt-deepspace #kt_header{
  background:rgba(12,14,22,.72)!important;border-bottom:1px solid var(--hair)!important;
  -webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);
  box-shadow:0 8px 30px rgba(0,0,0,.45)!important;}
body.kt-deepspace #kt_header_mobile{
  background:rgba(12,14,22,.92)!important;border-bottom:1px solid var(--hair)!important;}
@supports not ((backdrop-filter:blur(1px)) or (-webkit-backdrop-filter:blur(1px))){
  body.kt-deepspace #kt_header,body.kt-deepspace #kt_header_mobile{background:#0e1119!important;}}
/* MOBILE OFFCANVAS FIX: #kt_header contains the position:fixed header-menu offcanvas
   wrapper. backdrop-filter on #kt_header creates a containing block that traps the fixed
   offcanvas inside the short header box (height collapses to 0 -> the hamburger menu
   "opened" but stayed invisible off-screen). Below 992px (offcanvas active; #kt_header_mobile
   is the visible bar) drop the filter so the offcanvas positions against the viewport. */
@media (max-width:991.98px){
  body.kt-deepspace #kt_header{
    -webkit-backdrop-filter:none!important;backdrop-filter:none!important;}}

/* keep light logo in both states (sticky logo is a black PNG -> invisible on dark) */
body.kt-deepspace .header-logo .logo-default{display:inline-block!important;}
body.kt-deepspace .header-logo .logo-sticky{display:none!important;}

/* main nav links */
body.kt-deepspace .menu-nav > .menu-item > .menu-link .menu-text,
body.kt-deepspace .menu-nav > .menu-item > .menu-link .menu-text strong{color:var(--text)!important;font-weight:600;}
body.kt-deepspace .menu-nav > .menu-item > .menu-link:hover .menu-text strong,
body.kt-deepspace .menu-nav > .menu-item.menu-item-here > .menu-link .menu-text strong,
body.kt-deepspace .menu-nav > .menu-item.menu-item-active > .menu-link .menu-text strong{color:var(--cyan)!important;}
body.kt-deepspace .menu-nav > .menu-item:hover > .menu-link{background:rgba(56,225,255,.06)!important;}
body.kt-deepspace .menu-nav > .menu-item > .menu-link .menu-arrow{color:var(--muted)!important;}

/* desktop: nav wrapper MUST stay transparent so the whole header reads as one
   glass bar. A solid bg here is only as wide as the menu -> visible seam vs the
   translucent topbar (the cutoff between 管理面板 and 你好). */
body.kt-deepspace .header-menu-wrapper{background:transparent!important;}
/* mobile offcanvas drawer -> solid ONLY when opened (.header-menu-wrapper-on) */
body.kt-deepspace #kt_header_menu_wrapper.header-menu-wrapper-on,
body.kt-deepspace .offcanvas.offcanvas-on{
  background:var(--bg-elev)!important;border-right:1px solid var(--hair)!important;
  box-shadow:0 0 60px rgba(0,0,0,.6)!important;}
/* the INNER .header-menu-mobile is painted #fff by style.white.css @media (max-width:991.98px)
   -> on a real phone the open drawer was white (and my light menu-text vanished on it). Make
   the inner menu + nav list transparent so the wrapper's bg-elev shows through -> dark drawer. */
body.kt-deepspace .header-menu-mobile,
body.kt-deepspace .header-menu-mobile .menu-nav{background:transparent!important;}
body.kt-deepspace .offcanvas-overlay{background:rgba(7,8,12,.6)!important;}
body.kt-deepspace .header-menu-mobile .menu-nav > .menu-item > .menu-link .menu-text,
body.kt-deepspace .header-menu-mobile .menu-nav > .menu-item > .menu-link .menu-text strong{color:var(--text)!important;}
body.kt-deepspace .header-menu-mobile .menu-nav > .menu-item.menu-item-open > .menu-link,
body.kt-deepspace .header-menu-mobile .menu-nav > .menu-item:hover > .menu-link,
body.kt-deepspace .header-menu-mobile .menu-nav > .menu-item.menu-item-active > .menu-link{background:rgba(56,225,255,.06)!important;}
body.kt-deepspace .header-menu-mobile .menu-nav .menu-submenu{background:var(--bg-elev)!important;}

/* mobile topbar user dropdown (body.topbar-mobile-on) */
body.kt-deepspace.topbar-mobile-on .topbar{
  background:rgba(12,14,22,.97)!important;border-bottom:1px solid var(--hair)!important;}

/* submenu / dropdown panels -> glass */
/* dropdown panels: only the OUTER container gets border/radius/bg. The nested inner
   list (.menu-subnav inside .menu-submenu — the "我的账号" nav dropdown) must be flat,
   else it double-corners (same nesting issue as bootstrap-select's inner). */
body.kt-deepspace .menu-submenu,
body.kt-deepspace .dropdown-menu{
  background:var(--panel)!important;border:1px solid var(--hair)!important;
  border-radius:14px!important;box-shadow:0 24px 60px rgba(0,0,0,.6)!important;}
body.kt-deepspace .menu-submenu{overflow:hidden;}
body.kt-deepspace .menu-submenu .menu-subnav{
  background:transparent!important;border:0!important;border-radius:0!important;box-shadow:none!important;}
body.kt-deepspace .menu-subnav .menu-link .menu-text{color:var(--text)!important;}
body.kt-deepspace .menu-subnav .menu-link:hover{background:rgba(56,225,255,.06)!important;}
body.kt-deepspace .menu-subnav .menu-icon svg g [fill]{fill:var(--muted)!important;}
body.kt-deepspace .menu-subnav .menu-link:hover .menu-icon svg g [fill]{fill:var(--cyan)!important;}

/* topbar user dropdown */
body.kt-deepspace .topbar .text-white{color:var(--text)!important;}
/* 头像左侧「你好, 用户名」问候语可读性修复。
   根因：Metronic 在页面滚动后给 <body> 加 [data-header-scroll="on"]，并把 .topbar 文字强制成深色
   #464E5F（为它默认的浅色迷你头设计）；但深空主题顶栏始终是深色，于是深字配深底 → 对比度仅 2.3。
   用更高优先级把「滚动态」文字色恢复为 var(--text)，并去掉 opacity-70/90 的半透明。 */
body.kt-deepspace .topbar-item .text-white.opacity-70,
body.kt-deepspace .topbar-item .text-white.opacity-90{opacity:1!important;}
@media (min-width:992px){
  body.kt-deepspace[data-header-scroll="on"] .topbar .btn.btn-icon .text-white{color:var(--text)!important;}
}
body.kt-deepspace .topbar .symbol.symbol-35 img,
body.kt-deepspace .dropdown-menu .symbol img{border:1px solid var(--hair)!important;border-radius:50%;}
body.kt-deepspace .navi-separator,body.kt-deepspace .navi-footer{border-color:var(--hair)!important;}
body.kt-deepspace .btn-light-primary{background:rgba(56,225,255,.1)!important;color:var(--cyan)!important;border:1px solid var(--hair)!important;}

/* ====================== 6b. SETTINGS SIDEBAR NAV (.navi) ====================== */
/* the settings/invite left menu (账号记录/流量记录/资料编辑…) uses Metronic .navi,
   whose :hover and .active states paint a light (#F3F6F9) background. */
body.kt-deepspace .navi .navi-link{color:var(--text)!important;border-radius:10px!important;}
body.kt-deepspace .navi .navi-text{color:var(--text)!important;}
body.kt-deepspace .navi.navi-hover .navi-item:hover > .navi-link,
body.kt-deepspace .navi .navi-link:hover{background:rgba(56,225,255,.08)!important;}
body.kt-deepspace .navi.navi-active .navi-item.active > .navi-link,
body.kt-deepspace .navi .navi-item.active > .navi-link,
body.kt-deepspace .navi .navi-link.active{background:rgba(56,225,255,.12)!important;}
body.kt-deepspace .navi .navi-link:hover .navi-text,
body.kt-deepspace .navi .navi-item.active > .navi-link .navi-text,
body.kt-deepspace .navi .navi-link.active .navi-text{color:var(--cyan)!important;}
body.kt-deepspace .navi .navi-icon svg g [fill]{fill:var(--muted)!important;}
body.kt-deepspace .navi .navi-link:hover .navi-icon svg g [fill],
body.kt-deepspace .navi .navi-item.active > .navi-link .navi-icon svg g [fill]{fill:var(--cyan)!important;}

/* ====================== 7. SUBHEADER + CHECK-IN ====================== */
body.kt-deepspace .subheader h2,body.kt-deepspace #kt_subheader h2{
  font-family:var(--fdisp)!important;color:var(--text)!important;
  font-weight:700;letter-spacing:-.4px;text-shadow:0 2px 18px rgba(0,0,0,.5);}
/* daily check-in active (btn-white) -> cyan->iris pill */
body.kt-deepspace #checkin,
body.kt-deepspace #checkin.btn,
body.kt-deepspace .subheader .btn-white{
  color:#04121b!important;font-weight:700!important;border:none!important;border-radius:var(--r-pill)!important;
  background:linear-gradient(120deg,var(--cyan),var(--iris))!important;
  box-shadow:0 8px 24px rgba(56,225,255,.28)!important;transition:transform .2s,box-shadow .2s;}
body.kt-deepspace #checkin:hover{transform:translateY(-1px);box-shadow:0 12px 32px rgba(56,225,255,.42)!important;}
/* signed-in -> muted ghost */
body.kt-deepspace .subheader .btn-transparent-white.disabled{
  color:var(--muted)!important;border:1px solid var(--hair)!important;background:transparent!important;
  border-radius:var(--r-pill)!important;opacity:1!important;box-shadow:none!important;}

/* ====================== 8. FOOTER ====================== */
body.kt-deepspace #kt_footer{border-top:1px solid var(--hair)!important;background:transparent!important;}
body.kt-deepspace #kt_footer .text-muted,
body.kt-deepspace #kt_footer .text-dark,
body.kt-deepspace #kt_footer .text-dark-75,
body.kt-deepspace .footer .text-muted,body.kt-deepspace .footer a.text-dark-75{color:var(--muted)!important;}
body.kt-deepspace #kt_footer a:hover,body.kt-deepspace .footer a:hover{color:var(--cyan)!important;}
body.kt-deepspace #kt_footer span.text-muted{font-family:var(--fmono)!important;}

/* ====================== 9. CLIENT CARDS + TABS ====================== */
body.kt-deepspace .dashboard-tabs .nav-link{
  color:var(--muted)!important;border:1px solid var(--hair)!important;border-radius:12px!important;background:transparent!important;}
body.kt-deepspace .dashboard-tabs .nav-link.active,
body.kt-deepspace .dashboard-tabs .nav-link:hover{
  color:var(--cyan)!important;border-color:rgba(56,225,255,.4)!important;background:rgba(56,225,255,.06)!important;}
body.kt-deepspace .dashboard-tabs .nav-link .nav-icon i{color:inherit!important;}
body.kt-deepspace .nav-pills .nav-link.active{background:rgba(56,225,255,.12)!important;color:var(--cyan)!important;border:1px solid var(--hair)!important;}
body.kt-deepspace .symbol + * .text-primary,
body.kt-deepspace .font-size-h5.text-primary{color:var(--text)!important;font-family:var(--fdisp)!important;}
body.kt-deepspace .font-size-sm.text-muted{font-family:var(--fmono)!important;color:var(--muted)!important;}
/* install tutorial -> in-card ghost pill */
body.kt-deepspace .card-custom .btn-primary.btn-pill{
  background:transparent!important;color:var(--cyan)!important;border:1px solid var(--hair)!important;box-shadow:none!important;}

/* ====================== 10. ANNOUNCEMENT ====================== */
body.kt-deepspace .fa-bullhorn{color:var(--cyan)!important;}
body.kt-deepspace .card-custom .card-body .text-dark-50.font-size-lg-h4{color:var(--text)!important;}

/* ====================== 11. SUBSCRIPTION PILLS + DROPDOWN ====================== */
body.kt-deepspace .btn-pill.btn-ssr,
body.kt-deepspace .btn-pill.btn-clash,
body.kt-deepspace .btn-pill.btn-surge,
body.kt-deepspace .btn-pill.btn-shadowrocket,
body.kt-deepspace .btn-pill.btn-surfboard,
body.kt-deepspace .btn-pill.btn-quantumult,
body.kt-deepspace .btn-pill.btn-quantumultx,
body.kt-deepspace .btn-pill.btn-v2ray,
body.kt-deepspace .btn-pill.btn-kitsunebi{
  background:var(--bg-elev)!important;background-image:none!important;color:var(--text)!important;
  border:1px solid var(--hair)!important;font-family:var(--fdisp)!important;font-weight:600!important;
  box-shadow:none!important;transition:border-color .2s,transform .2s;}
body.kt-deepspace .btn-pill[class*="btn-"]:hover{border-color:rgba(56,225,255,.4)!important;transform:translateY(-1px);}
body.kt-deepspace .btn-pill [class^="metron-"]{color:var(--cyan)!important;}
body.kt-deepspace .dropdown-item{color:var(--text)!important;}
body.kt-deepspace .dropdown-item:hover{background:rgba(56,225,255,.08)!important;color:var(--cyan)!important;}
body.kt-deepspace .dropdown-divider{border-top-color:var(--hair)!important;}

/* ====================== 12. INJECTED ALERTS ====================== */
body.kt-deepspace .alert.alert-custom.alert-white{
  background:rgba(232,195,122,.1)!important;border:1px solid var(--hair)!important;
  border-left:3px solid var(--gold)!important;color:var(--text)!important;box-shadow:none!important;}
body.kt-deepspace .alert.alert-custom.alert-danger{
  background:rgba(255,90,90,.1)!important;border:1px solid var(--hair)!important;
  border-left:3px solid #ff6b6b!important;color:var(--text)!important;}
body.kt-deepspace .alert .flaticon-warning{color:var(--gold)!important;}
body.kt-deepspace .alert.alert-danger .flaticon-warning{color:#ff6b6b!important;}
body.kt-deepspace .alert .alert-text font{color:var(--text)!important;}
body.kt-deepspace .alert .alert-text a{color:var(--cyan)!important;}
/* standard Bootstrap alert variants (shop intro "科技熊的套餐选择" = .alert-primary, etc.) */
body.kt-deepspace .alert.alert-primary{background:rgba(56,225,255,.08)!important;border:1px solid var(--hair)!important;border-left:3px solid var(--cyan)!important;color:var(--text)!important;}
body.kt-deepspace .alert.alert-success{background:rgba(52,245,197,.08)!important;border:1px solid var(--hair)!important;border-left:3px solid var(--mint)!important;color:var(--text)!important;}
body.kt-deepspace .alert.alert-info{background:rgba(110,123,255,.08)!important;border:1px solid var(--hair)!important;border-left:3px solid var(--iris)!important;color:var(--text)!important;}
body.kt-deepspace .alert.alert-warning{background:rgba(232,195,122,.08)!important;border:1px solid var(--hair)!important;border-left:3px solid var(--gold)!important;color:var(--text)!important;}
body.kt-deepspace .alert .alert-heading,
body.kt-deepspace .alert .alert-text,
body.kt-deepspace .alert .alert-text p,
body.kt-deepspace .alert .alert-text li,
body.kt-deepspace .alert .alert-text ol,
body.kt-deepspace .alert .alert-text ul{color:var(--text)!important;}

/* ====================== 13. ONBOARDING WIZARD (class == -1) ====================== */
body.kt-deepspace .card .animated.tada[style],
body.kt-deepspace .card h3[style*="191d21"],
body.kt-deepspace .card h5[style*="191d21"]{color:var(--text)!important;}
body.kt-deepspace h3.animated.tada{font-family:var(--fdisp)!important;}
body.kt-deepspace .wizard-step{background:var(--bg-elev)!important;border:1px solid var(--hair)!important;border-radius:14px;}
body.kt-deepspace .wizard-step-active,body.kt-deepspace .wizard-step-success{border-color:rgba(56,225,255,.35)!important;}
body.kt-deepspace .wizard-step-icon{background:transparent!important;}
body.kt-deepspace .wizard-step-icon i{color:var(--cyan)!important;}
body.kt-deepspace .wizard-step-label{color:var(--text)!important;}

/* ====================== 14. TABLES ====================== */
/* KTDatatable is a DIV-based virtual table (.datatable-table / .datatable-row /
   .datatable-cell), NOT a real <table>. The white band was the .datatable-table
   container (#ffffff @ style.white.css:44186) showing through the transparent rows. */
body.kt-deepspace .datatable.datatable-default > .datatable-table,
body.kt-deepspace .datatable .datatable-table,
body.kt-deepspace .datatable .datatable-body,
body.kt-deepspace .datatable .datatable-body .datatable-row{background:transparent!important;}
body.kt-deepspace .datatable .datatable-head,
body.kt-deepspace .datatable .datatable-head .datatable-row{background:var(--bg-elev)!important;}
body.kt-deepspace .datatable .datatable-row{border-bottom:1px solid var(--hair)!important;}
body.kt-deepspace .datatable .datatable-body .datatable-row:hover{background:rgba(56,225,255,.05)!important;}
body.kt-deepspace .datatable .datatable-cell,
body.kt-deepspace .datatable .datatable-cell > span{
  color:var(--text)!important;font-family:var(--fmono)!important;border-color:var(--hair)!important;}
body.kt-deepspace .datatable .datatable-head .datatable-cell,
body.kt-deepspace .datatable .datatable-head .datatable-cell > span{
  color:var(--muted)!important;font-family:var(--fdisp)!important;}
/* real <table> (Bootstrap) variants used on other pages (node streaming table, etc.) */
body.kt-deepspace .datatable table,body.kt-deepspace table.table{background:transparent!important;}
body.kt-deepspace .datatable table > thead > tr > th,
body.kt-deepspace table.table > thead > tr > th{color:var(--muted)!important;font-family:var(--fdisp)!important;border-color:var(--hair)!important;background:transparent!important;}
body.kt-deepspace .datatable table > tbody > tr > td,
body.kt-deepspace table.table > tbody > tr > td{color:var(--text)!important;border-color:var(--hair)!important;background:transparent!important;font-family:var(--fmono)!important;}
body.kt-deepspace .datatable table > tbody > tr:hover > td,
body.kt-deepspace table.table > tbody > tr:hover > td{background:rgba(56,225,255,.04)!important;}
/* pager + page-size selector (KTDatatable uses .selectric) */
body.kt-deepspace .datatable .datatable-pager .datatable-pager-link{
  color:var(--muted)!important;background:transparent!important;border:1px solid var(--hair)!important;}
body.kt-deepspace .datatable .datatable-pager-link.datatable-pager-link-active{
  background:rgba(56,225,255,.12)!important;color:var(--cyan)!important;}
body.kt-deepspace .selectric{background:var(--bg-elev)!important;border:1px solid var(--hair)!important;}
body.kt-deepspace .selectric .label{color:var(--text)!important;}
body.kt-deepspace .selectric-items{background:var(--panel)!important;border:1px solid var(--hair)!important;}
body.kt-deepspace .selectric-items li{color:var(--text)!important;}
body.kt-deepspace .selectric-items li.highlighted,
body.kt-deepspace .selectric-items li:hover{background:rgba(56,225,255,.12)!important;color:var(--cyan)!important;}

/* ====================== 15. MODALS + PLUGIN CONTROLS ====================== */
body.kt-deepspace .modal-content{
  background:linear-gradient(180deg,rgba(255,255,255,.035),transparent),rgba(12,14,22,.92)!important;
  -webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);
  border:1px solid var(--hair)!important;border-radius:18px!important;color:var(--text)!important;
  box-shadow:0 30px 80px rgba(0,0,0,.6)!important;}
@supports not ((backdrop-filter:blur(1px)) or (-webkit-backdrop-filter:blur(1px))){
  body.kt-deepspace .modal-content{background:#0e1119!important;}}
body.kt-deepspace .modal-header,body.kt-deepspace .modal-footer{border-color:var(--hair)!important;}
body.kt-deepspace .modal-title,body.kt-deepspace .modal-title.text-dark{color:var(--text)!important;font-family:var(--fdisp)!important;}
body.kt-deepspace .modal-body code{
  font-family:var(--fmono)!important;color:var(--cyan)!important;
  background:var(--bg-elev)!important;border:1px solid var(--hair)!important;border-radius:6px;padding:2px 7px;}
body.kt-deepspace .kt-divider span:nth-child(2){color:var(--muted)!important;}

/* SweetAlert2 (mswal: check-in reward / copy toast / coupon) */
body.kt-deepspace .swal2-popup{background:var(--panel)!important;color:var(--text)!important;
  border:1px solid var(--hair)!important;border-radius:18px!important;}
body.kt-deepspace .swal2-title,body.kt-deepspace .swal2-html-container{color:var(--text)!important;}
body.kt-deepspace .swal2-html-container{font-family:var(--fmono)!important;}
body.kt-deepspace .swal2-styled.swal2-confirm{
  background:linear-gradient(120deg,var(--cyan),var(--iris))!important;color:#04121b!important;}
body.kt-deepspace .swal2-success-ring{border-color:rgba(52,245,197,.5)!important;}
body.kt-deepspace .swal2-success [class^="swal2-success-line"]{background-color:var(--mint)!important;}
/* select2 */
body.kt-deepspace .select2-container--default .select2-selection{
  background:var(--bg-elev)!important;border:1px solid var(--hair)!important;color:var(--text)!important;}
body.kt-deepspace .select2-dropdown{background:var(--panel)!important;border:1px solid var(--hair)!important;}
body.kt-deepspace .select2-results__option{color:var(--text)!important;}
body.kt-deepspace .select2-results__option--highlighted{background:rgba(56,225,255,.12)!important;color:var(--cyan)!important;}
/* bootstrap-select (the 状态 "全部" filter on code.tpl + node filter modal). The native
   <select> is hidden (tabindex -98); the VISIBLE widget is .bootstrap-select > button. */
body.kt-deepspace .bootstrap-select.form-control{
  background:transparent!important;border:0!important;padding:0!important;min-height:0!important;height:auto!important;}
body.kt-deepspace .bootstrap-select > .dropdown-toggle,
body.kt-deepspace .bootstrap-select button.dropdown-toggle{
  background:var(--bg-elev)!important;color:var(--text)!important;border:1px solid var(--hair)!important;
  border-radius:12px!important;min-height:48px;}
body.kt-deepspace .bootstrap-select .dropdown-toggle:focus,
body.kt-deepspace .bootstrap-select .dropdown-toggle:active{
  border-color:var(--cyan)!important;box-shadow:0 0 0 3px rgba(56,225,255,.14)!important;outline:none!important;}
body.kt-deepspace .bootstrap-select .filter-option-inner-inner{color:var(--text)!important;}
body.kt-deepspace .bootstrap-select .dropdown-toggle .caret{border-top-color:var(--muted)!important;color:var(--muted)!important;}
/* outer menu = the ONE bordered/rounded panel (overflow:hidden so item hovers clip
   to the radius). bootstrap-select nests an inner <ul class="dropdown-menu inner">
   that ALSO matches .dropdown-menu -> it must be flattened or it double-corners. */
body.kt-deepspace .bootstrap-select .dropdown-menu{
  background:var(--panel)!important;border:1px solid var(--hair)!important;border-radius:12px!important;
  color:var(--text)!important;overflow:hidden!important;}
body.kt-deepspace .bootstrap-select .dropdown-menu.inner,
body.kt-deepspace .bootstrap-select .dropdown-menu .inner,
body.kt-deepspace .bootstrap-select .dropdown-menu .inner > .dropdown-menu{
  background:transparent!important;border:0!important;border-radius:0!important;box-shadow:none!important;}
/* options were inheriting #464E5F (low contrast) — force --text on every variant */
body.kt-deepspace .bootstrap-select .dropdown-menu li,
body.kt-deepspace .bootstrap-select .dropdown-menu li a,
body.kt-deepspace .bootstrap-select .dropdown-menu .dropdown-item,
body.kt-deepspace .bootstrap-select .dropdown-menu li a .text,
body.kt-deepspace .bootstrap-select .dropdown-menu .dropdown-item .text{color:var(--text)!important;}
body.kt-deepspace .bootstrap-select .dropdown-menu li a:hover,
body.kt-deepspace .bootstrap-select .dropdown-menu li.selected a,
body.kt-deepspace .bootstrap-select .dropdown-menu li a.active,
body.kt-deepspace .bootstrap-select .dropdown-menu li a.selected,
body.kt-deepspace .bootstrap-select .dropdown-menu .dropdown-item:hover,
body.kt-deepspace .bootstrap-select .dropdown-menu .dropdown-item.active,
body.kt-deepspace .bootstrap-select .dropdown-menu .dropdown-item.selected{
  background:rgba(56,225,255,.14)!important;color:var(--cyan)!important;}
body.kt-deepspace .bootstrap-select .dropdown-menu li a:hover .text,
body.kt-deepspace .bootstrap-select .dropdown-menu li.selected a .text,
body.kt-deepspace .bootstrap-select .dropdown-menu .dropdown-item:hover .text{color:var(--cyan)!important;}
/* KTDatatable page-size selector: the bundle styles its toggle at 7-class specificity
   (.datatable.datatable-default > .datatable-pager > .datatable-pager-info
   .datatable-pager-size .btn.dropdown-toggle) with background-color:#ecf1f6 !important,
   which out-specifies the generic .bootstrap-select rules above -> the toggle stayed
   light and the selected number was light-on-light (invisible). Match that depth. */
body.kt-deepspace .datatable.datatable-default .datatable-pager .datatable-pager-info .datatable-pager-size .btn.dropdown-toggle{
  background-color:var(--bg-elev)!important;color:var(--text)!important;
  border:1px solid var(--hair)!important;border-radius:8px!important;min-height:32px!important;}
body.kt-deepspace .datatable.datatable-default .datatable-pager .datatable-pager-info .datatable-pager-size .btn.dropdown-toggle .filter-option,
body.kt-deepspace .datatable.datatable-default .datatable-pager .datatable-pager-info .datatable-pager-size .btn.dropdown-toggle .filter-option-inner-inner{color:var(--text)!important;}
body.kt-deepspace .datatable.datatable-default .datatable-pager .datatable-pager-info .datatable-pager-size .btn.dropdown-toggle:after{color:var(--muted)!important;border-top-color:var(--muted)!important;}
body.kt-deepspace .datatable.datatable-default .datatable-pager .datatable-pager-info .datatable-pager-size .dropdown-menu{
  background:var(--panel)!important;border:1px solid var(--hair)!important;}
body.kt-deepspace .datatable.datatable-default .datatable-pager .datatable-pager-info .datatable-pager-size .dropdown-menu li a,
body.kt-deepspace .datatable.datatable-default .datatable-pager .datatable-pager-info .datatable-pager-size .dropdown-menu .dropdown-item,
body.kt-deepspace .datatable.datatable-default .datatable-pager .datatable-pager-info .datatable-pager-size .dropdown-menu li a .text{color:var(--text)!important;background:transparent!important;}
body.kt-deepspace .datatable.datatable-default .datatable-pager .datatable-pager-info .datatable-pager-size .dropdown-menu li.selected > a,
body.kt-deepspace .datatable.datatable-default .datatable-pager .datatable-pager-info .datatable-pager-size .dropdown-menu li a:hover,
body.kt-deepspace .datatable.datatable-default .datatable-pager .datatable-pager-info .datatable-pager-size .dropdown-menu .dropdown-item:hover{background:rgba(56,225,255,.12)!important;color:var(--cyan)!important;}
/* flatpickr */
body.kt-deepspace .flatpickr-calendar{background:var(--panel)!important;border:1px solid var(--hair)!important;color:var(--text);}
body.kt-deepspace .flatpickr-day{color:var(--text)!important;}
body.kt-deepspace .flatpickr-day.selected{background:var(--cyan)!important;border-color:var(--cyan)!important;color:#04121b!important;}
body.kt-deepspace .flatpickr-months .flatpickr-month{color:var(--text)!important;}
/* pretty-checkbox (if any JS-injected .pretty controls exist) */
body.kt-deepspace .pretty .state label:before{border-color:var(--hair)!important;background:var(--bg-elev)!important;}
body.kt-deepspace .pretty.p-default input:checked ~ .state label:after,
body.kt-deepspace .pretty input:checked ~ .state label:after{background:var(--cyan)!important;}
body.kt-deepspace .pretty .state label{color:var(--text)!important;}

/* ====================== 16. FORMS + BUTTONS + SWITCHES + PROGRESS ====================== */
body.kt-deepspace .form-control,
body.kt-deepspace .input-group-solid .form-control{
  height:auto;min-height:48px;border:1px solid var(--hair)!important;border-radius:12px!important;
  background:var(--bg-elev)!important;color:var(--text)!important;padding:0 16px!important;
  -webkit-backdrop-filter:none;backdrop-filter:none;transition:border-color .2s,box-shadow .2s;}
body.kt-deepspace .input-group-solid{background:var(--bg-elev)!important;border-radius:12px!important;}
body.kt-deepspace .form-control::placeholder{color:#6b7488!important;opacity:1;}
body.kt-deepspace .form-control:focus{
  border-color:var(--cyan)!important;box-shadow:0 0 0 3px rgba(56,225,255,.14)!important;background:var(--bg-elev)!important;}
/* icon-inputs (.input-icon, e.g. agent 客户列表 search): the magnifier <span> is
   absolutely positioned at left:0, so the input needs left room. My blanket
   padding:0 16px collapsed it -> text overlapped the icon. Restore the clearance. */
body.kt-deepspace .input-icon > .form-control{padding-left:42px!important;}
body.kt-deepspace .input-icon.input-icon-right > .form-control{padding-left:16px!important;padding-right:42px!important;}
body.kt-deepspace .input-icon > span i,
body.kt-deepspace .input-icon > span svg g [fill]{color:var(--muted)!important;fill:var(--muted)!important;}
body.kt-deepspace .input-group-text{background:var(--bg-elev)!important;border:1px solid var(--hair)!important;color:var(--muted)!important;}
/* Bootstrap .input-group (e.g. /user/help search = magnifier + input + 搜索 button):
   children must join into ONE pill. My blanket .form-control/.btn radius:12px made
   each child a separate rounded box -> mismatched square/rounded corners. Round +
   border the GROUP (clip children), flatten the children, show focus on the group
   (its own box-shadow isn't clipped by its own overflow:hidden). */
body.kt-deepspace .input-group{
  border:1px solid var(--hair)!important;border-radius:12px!important;overflow:hidden;
  box-shadow:none!important;transition:border-color .2s,box-shadow .2s;}
body.kt-deepspace .input-group:focus-within{
  border-color:var(--cyan)!important;box-shadow:0 0 0 3px rgba(56,225,255,.14)!important;}
body.kt-deepspace .input-group > .form-control,
body.kt-deepspace .input-group .input-group-text,
body.kt-deepspace .input-group .btn{border-radius:0!important;}
body.kt-deepspace .input-group .form-control,
body.kt-deepspace .input-group .input-group-text{border:0!important;}
body.kt-deepspace .input-group .form-control:focus{box-shadow:none!important;}
body.kt-deepspace select.form-control option{background:var(--panel)!important;color:var(--text);}
body.kt-deepspace .col-form-label,body.kt-deepspace label{color:var(--text)!important;}
body.kt-deepspace input.form-control[readonly],
body.kt-deepspace .input-group-solid input[type="text"]{font-family:var(--fmono)!important;}

/* primary CTA = cyan->iris (auth.css signature) */
body.kt-deepspace .btn-primary{
  color:#04121b!important;font-weight:700!important;border:none!important;border-radius:12px!important;
  background:linear-gradient(120deg,var(--cyan),var(--iris))!important;
  box-shadow:0 8px 24px rgba(56,225,255,.26)!important;transition:transform .2s,box-shadow .2s;}
body.kt-deepspace .btn-primary:hover{transform:translateY(-1px);box-shadow:0 12px 32px rgba(56,225,255,.42)!important;}
/* small action buttons (e.g. agent 客户列表 row "操作" dropdown): the big 0 8px 24px
   CTA glow is far too heavy behind a tiny .btn-sm and reads as a weird dark halo on
   the row. Use a tight, subtle shadow. */
/* .btn-sm action buttons live inside KTDatatable cells whose wrapping <span> and
   .datatable-table are overflow:hidden -> any box-shadow gets clipped to a SQUARE
   (ugly on a rounded button). So no shadow at all; hover feedback = lift + brighten. */
body.kt-deepspace .btn-primary.btn-sm{box-shadow:none!important;}
body.kt-deepspace .btn-primary.btn-sm:hover{box-shadow:none!important;transform:translateY(-1px);filter:brightness(1.08);}
body.kt-deepspace .btn-light-primary,body.kt-deepspace .btn-secondary,
body.kt-deepspace .bg-light-primary{background:rgba(56,225,255,.08)!important;color:var(--cyan)!important;border:1px solid var(--hair)!important;}
body.kt-deepspace .btn-transparent-white{background:transparent!important;color:var(--muted)!important;border:1px solid var(--hair)!important;}
/* clean/icon action buttons (e.g. the datatable row gear ⚙ action menu). Their
   hover/focus/open (.show / aria-expanded) state paints a light #F3F6F9 box and
   turns the icon brand-blue — both clash on dark. Make it a subtle cyan highlight. */
body.kt-deepspace .btn.btn-clean{background:transparent!important;color:var(--muted)!important;}
body.kt-deepspace .btn.btn-clean:hover,
body.kt-deepspace .btn.btn-clean:focus,
body.kt-deepspace .btn.btn-clean:active,
body.kt-deepspace .btn.btn-clean.active,
body.kt-deepspace .btn.btn-clean[aria-expanded="true"],
body.kt-deepspace .show > .btn.btn-clean{background:rgba(56,225,255,.12)!important;color:var(--cyan)!important;}
body.kt-deepspace .btn.btn-clean .svg-icon svg g [fill]{fill:currentColor!important;}

/* colored CTAs -> deepspace semantic ghosts (no stock Metronic solid blocks) */
body.kt-deepspace .btn-danger{
  background:rgba(255,107,107,.12)!important;color:#ff8a8a!important;
  border:1px solid rgba(255,107,107,.4)!important;box-shadow:none!important;}
body.kt-deepspace .btn-danger:hover{background:rgba(255,107,107,.2)!important;}
body.kt-deepspace .btn-success{background:rgba(52,245,197,.12)!important;color:var(--mint)!important;border:1px solid var(--hair)!important;box-shadow:none!important;}
body.kt-deepspace .btn-warning{background:rgba(232,195,122,.12)!important;color:var(--gold)!important;border:1px solid var(--hair)!important;box-shadow:none!important;}

/* progress bars (bare bg-* keep their semantic gradients) */
body.kt-deepspace .progress{background:var(--bg-elev)!important;}
body.kt-deepspace .progress-bar.bg-primary{background:linear-gradient(90deg,var(--cyan),var(--iris))!important;}
body.kt-deepspace .progress-bar.bg-danger{background:#ff6b6b!important;}
/* kt-switch (shop auto-renew) */
body.kt-deepspace .kt-switch input:checked ~ span:after{background:var(--cyan)!important;}
body.kt-deepspace .kt-switch span:before{background:var(--bg-elev)!important;border:1px solid var(--hair)!important;}
/* status colors: success/online -> mint; warning -> gold; offline -> calm muted */
body.kt-deepspace .text-success,body.kt-deepspace .label-success{color:var(--mint)!important;background:transparent!important;}
body.kt-deepspace .label-success.label-inline{background:rgba(52,245,197,.1)!important;border:1px solid var(--hair)!important;}
body.kt-deepspace .label-dot.label-success,body.kt-deepspace .bullet.bg-success{background:var(--mint)!important;}
body.kt-deepspace .label-dot.label-danger,body.kt-deepspace .bullet.bg-danger{background:var(--muted)!important;}
body.kt-deepspace .text-warning,body.kt-deepspace .label-warning{color:var(--gold)!important;}
/* light label pills (coupon codes on shop, rebate badges on agent/invite) -> dark chips */
body.kt-deepspace .label.label-light,
body.kt-deepspace .label.label-light-primary,
body.kt-deepspace .label.label-light-success,
body.kt-deepspace .label.label-light-warning,
body.kt-deepspace .label.label-light-danger,
body.kt-deepspace .label.label-light-info{
  background:var(--bg-elev)!important;color:var(--text)!important;border:1px solid var(--hair)!important;}

/* ====================== 17. CHART CONTAINERS (CSS-only bits) ====================== */
/* NodeTrafficChart bar colors come from config/style.php (P1, not CSS); here only
   the container/axis/gridline + empty state. */
body.kt-deepspace #NodeTrafficChart text{fill:var(--muted)!important;font-family:var(--fmono)!important;}
body.kt-deepspace #NodeTrafficChart .apexcharts-gridline{stroke:var(--hair)!important;}
body.kt-deepspace #kt_tiles_widget_1_chart text{fill:var(--muted)!important;font-family:var(--fmono)!important;}
/* ApexCharts tooltips (both charts) default to a light theme -> dark-theme them. */
body.kt-deepspace .apexcharts-tooltip.apexcharts-theme-light,
body.kt-deepspace .apexcharts-tooltip{
  background:var(--panel)!important;border:1px solid var(--hair)!important;color:var(--text)!important;
  box-shadow:0 8px 30px rgba(0,0,0,.55)!important;border-radius:10px!important;}
body.kt-deepspace .apexcharts-tooltip.apexcharts-theme-light .apexcharts-tooltip-title,
body.kt-deepspace .apexcharts-tooltip .apexcharts-tooltip-title{
  background:var(--bg-elev)!important;border-bottom:1px solid var(--hair)!important;
  color:var(--text)!important;font-family:var(--fmono)!important;}
body.kt-deepspace .apexcharts-tooltip-text,
body.kt-deepspace .apexcharts-tooltip-text-y-label,
body.kt-deepspace .apexcharts-tooltip-text-y-value,
body.kt-deepspace .apexcharts-tooltip-series-group{color:var(--text)!important;}
body.kt-deepspace .apexcharts-tooltip-series-group .apexcharts-tooltip-text{font-family:var(--fmono)!important;}
/* x/y-axis crosshair tooltips (the date box under the chart) */
body.kt-deepspace .apexcharts-xaxistooltip,
body.kt-deepspace .apexcharts-yaxistooltip,
body.kt-deepspace .apexcharts-xaxistooltip.apexcharts-theme-light,
body.kt-deepspace .apexcharts-yaxistooltip.apexcharts-theme-light{
  background:var(--bg-elev)!important;border:1px solid var(--hair)!important;color:var(--text)!important;font-family:var(--fmono)!important;}
body.kt-deepspace .apexcharts-xaxistooltip-bottom:before{border-bottom-color:var(--hair)!important;}
body.kt-deepspace .apexcharts-xaxistooltip-bottom:after{border-bottom-color:var(--bg-elev)!important;}
body.kt-deepspace .apexcharts-xaxistooltip-top:before{border-top-color:var(--hair)!important;}
body.kt-deepspace .apexcharts-xaxistooltip-top:after{border-top-color:var(--bg-elev)!important;}

/* ====================== 17b. WALLET BALANCE (code.tpl, P0 dignity touch) ====================== */
/* The colorful taieri.svg backdrop is intentionally flattened by P0 (deepspace
   replaces stock Metronic decorations). Give the balance a gold mono treatment so
   it reads premium, not a sad gray number. Full bespoke wallet hero (treatment +
   recharge-button recolor) is a P2 item. */
body.kt-deepspace #code-getmoney .display-2,
body.kt-deepspace #code-getmoney .display-2 strong,
body.kt-deepspace #code-getmoney .display-2 .display-4 strong{
  color:var(--gold)!important;font-family:var(--fmono)!important;font-weight:700!important;}
/* the stock taieri.svg art was flattened by P0, leaving the big wallet card bare.
   Fill it with a faint guardian-bear watermark (matches the gold balance), clipped
   to the card's rounded corner. */
body.kt-deepspace #code-getmoney{position:relative;overflow:hidden}
body.kt-deepspace #code-getmoney::after{
  content:"";position:absolute;right:-24px;bottom:-36px;width:340px;height:340px;
  background:url('/images/kejibear/mark_gold.png') center/contain no-repeat;
  opacity:.08;pointer-events:none;z-index:0;
  filter:drop-shadow(0 0 30px rgba(232,195,122,.15))}
body.kt-deepspace #code-getmoney > *{position:relative;z-index:1}
/* reusable faint guardian-bear watermark for other large bare cards (agent 代理商详情) */
body.kt-deepspace .ds-bear-bg{position:relative;overflow:hidden}
body.kt-deepspace .ds-bear-bg::after{
  content:"";position:absolute;right:-24px;bottom:-36px;width:300px;height:300px;
  background:url('/images/kejibear/mark_white.png') center/contain no-repeat;
  opacity:.06;pointer-events:none;z-index:0}
body.kt-deepspace .ds-bear-bg > *{position:relative;z-index:1}
/* gold variant (cards with a gold balance: agent 可提金额, etc.) */
body.kt-deepspace .ds-bear-bg.ds-bear-bg-gold::after{
  background-image:url('/images/kejibear/mark_gold.png')!important;
  opacity:.09!important;filter:drop-shadow(0 0 26px rgba(232,195,122,.18))}
/* fit variant for short cards (~175px): a smaller, vertically-centered bear so the
   WHOLE bear (head + globe) shows instead of the 300px one clipping to just the globe. */
body.kt-deepspace .ds-bear-bg.ds-bear-bg-sm::after{
  width:150px;height:150px;right:24px;left:auto;bottom:auto;top:50%;transform:translateY(-50%)}

/* ====================== node list name / description readability ====================== */
/* the node NAME (.media-title) was #34395E (dark navy, dark-on-dark = nearly invisible)
   -> bright primary text. The tiny description (.media .text-job) was plain --muted
   -> lift it a notch so it stays legible at 10px. */
body.kt-deepspace .media-title{color:var(--text)!important;font-weight:600!important}
body.kt-deepspace .media .text-job,
body.kt-deepspace .text-job{color:#aab3c4!important}

/* node 流媒体检测表 (#node_unlocak): <th> 标签无宽度、<td> 值 inline width:13% +
   datatable-cell 内联块 -> 标签与值对不齐、值还参差换行。强制成一张 8 等分定宽表、
   居中；并让 JS 加的 text-success/danger/warning/info 用深空色呈现(原被 §datatables 抹掉)。
   Yes=薄荷绿 / No=红 / Unknow=金 / 仅限自制=青。 */
body.kt-deepspace #node_unlocak{display:table!important;width:100%!important;table-layout:fixed!important;margin:4px 0 2px!important}
body.kt-deepspace #node_unlocak thead,
body.kt-deepspace #node_unlocak tbody{display:table-row-group!important}
body.kt-deepspace #node_unlocak tr{display:table-row!important;left:0!important}
body.kt-deepspace #node_unlocak th,
body.kt-deepspace #node_unlocak td{display:table-cell!important;width:12.5%!important;text-align:center!important;
  vertical-align:middle!important;padding:6px 2px!important;border:0!important;background:transparent!important}
body.kt-deepspace #node_unlocak th span,
body.kt-deepspace #node_unlocak td span{display:inline!important;width:auto!important;max-width:none!important;
  white-space:normal!important;overflow:visible!important;line-height:1.3!important;font-size:11px!important}
body.kt-deepspace #node_unlocak th span{color:var(--muted)!important;font-weight:600!important}
body.kt-deepspace #node_unlocak td span{color:var(--muted)!important;font-weight:700!important}
body.kt-deepspace #node_unlocak td span.text-success{color:var(--mint)!important}
body.kt-deepspace #node_unlocak td span.text-danger{color:#ff6b6b!important}
body.kt-deepspace #node_unlocak td span.text-warning{color:var(--gold)!important}
body.kt-deepspace #node_unlocak td span.text-info{color:var(--cyan)!important}

/* ====================== dashboard 大熊座节点网 ambient backdrop ====================== */
/* decorative URSA MAJOR constellation behind the KPI area (landing motif, faint). z-index:-1
   keeps it behind the opaque cards; #kt_content gets its own stacking context to contain it.
   No transform/filter on #kt_content -> safe for the fixed offcanvas in #kt_header. */
body.kt-deepspace #kt_content{position:relative;z-index:0}
body.kt-deepspace .ds-cons-ambient{position:absolute;top:-78px;left:0;right:0;height:430px;
  z-index:-1;pointer-events:none;overflow:hidden}
body.kt-deepspace .ds-cons-ambient .ds-cons{position:absolute;top:0;right:24px;left:auto;transform:none;
  width:740px;max-width:82%;height:auto;opacity:.30;
  filter:drop-shadow(0 0 24px rgba(56,225,255,.20));animation:dsConsTwinkle 6.5s ease-in-out infinite}
@keyframes dsConsTwinkle{0%,100%{opacity:.26}50%{opacity:.38}}
@media (prefers-reduced-motion:reduce){
  body.kt-deepspace .ds-cons-ambient .ds-cons{animation:none!important;opacity:.15}}
@media (max-width:991.98px){
  body.kt-deepspace .ds-cons-ambient{top:40px;height:460px}
  body.kt-deepspace .ds-cons-ambient .ds-cons{width:660px}}
/* reusable gold mono number (agent 可提金额 hero, settings/invite 返利余额). The
   high-specificity variant beats §4.4 .card-custom .card-body p{color:muted}. */
body.kt-deepspace .ds-num-gold,
body.kt-deepspace .card.card-custom .card-body p.ds-num-gold,
body.kt-deepspace .card.card-custom .card-body p.ds-num-gold strong{
  color:var(--gold)!important;font-family:var(--fmono)!important;font-weight:700!important;}

/* ====================== 17c. SHARED ACCOUNT (Metronic kanban board) ====================== */
/* shared_account.tpl uses a kanban board: a light-* pastel header + a WHITE
   .kanban-drag body. The account/password boxes (bg-white) are already flattened
   by §4, but the header + drag body + <label>s were light islands. */
body.kt-deepspace .kanban-board{background:transparent!important;}
body.kt-deepspace .kanban-board-header,
body.kt-deepspace .kanban-board-header[class*="light-"]{
  background:var(--bg-elev)!important;background-color:var(--bg-elev)!important;
  border:1px solid var(--hair)!important;border-bottom:none!important;}
body.kt-deepspace .kanban-title-board{color:var(--text)!important;font-family:var(--fdisp)!important;}
body.kt-deepspace .kanban-drag{
  background:var(--panel)!important;border:1px solid var(--hair)!important;border-top:none!important;}
body.kt-deepspace .kanban-drag label,
body.kt-deepspace .kanban-board label{color:var(--muted)!important;}
/* item wells sit a step darker than the drag body for contrast */
body.kt-deepspace .kanban-item{
  background:var(--bg-elev)!important;border:1px solid var(--hair)!important;color:var(--text)!important;}
body.kt-deepspace .kanban-item a{color:var(--cyan)!important;}

/* ====================== 18. MOTION (P0 subset — no JS needed) ====================== */
/* card hover lift (GPU, transform/opacity) */
body.kt-deepspace .card.card-custom{transition:transform .2s ease,box-shadow .2s ease;}
body.kt-deepspace .card.card-custom:hover{transform:translateY(-2px);
  box-shadow:0 18px 48px rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.06);}
/* (Removed the #checkin breathing-pulse: its animated box-shadow fought the :hover
   box-shadow, causing a one-frame flash on hover — inconsistent with other primary
   buttons like 购买流量包. The check-in button already stands out via the gradient.) */

/* ====================== 19. BRAND: LOGO BEAR / EMPTY / SPINNER ====================== */
/* nav logo: the wordmark PNG (kejibear_logo.png) ALREADY contains the bear glyph,
   so we do NOT prefix another mark here (that produced two bears). We only keep
   the light/sticky-logo swap in section 6 so the black sticky logo stays hidden. */

/* empty state (#NodeTrafficChart_null) -> faint bear + muted copy */
body.kt-deepspace #NodeTrafficChart_null{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:48px 20px;color:var(--muted)!important;text-align:center;}
body.kt-deepspace #NodeTrafficChart_null::before{
  content:"";width:72px;height:72px;margin-bottom:16px;opacity:.40;
  background:url('/images/kejibear/mark_white.png') center/contain no-repeat;}
body.kt-deepspace #NodeTrafficChart_null h3,
body.kt-deepspace #NodeTrafficChart_null .display-5{color:var(--muted)!important;font-family:var(--fdisp)!important;}

/* AJAX loading overlay -> clean dark wash only. We deliberately do NOT inject a
   bear background: the Metronic block message renders MULTIPLE <span>s, so a
   `.blockui > span` background image duplicated into two bears (and fought the
   native spinner). The native spinner shows in muted on the dark wash. The
   full-page loading splash bear is also dropped (it shared ::after with the
   aurora and added little). A single tasteful loading bear can return in P1. */
body.kt-deepspace .blockUI.blockOverlay{background:var(--bg)!important;opacity:.72!important;}
body.kt-deepspace .blockUI.blockMsg,
body.kt-deepspace .blockUI .blockui{
  background:transparent!important;border:none!important;box-shadow:none!important;color:var(--muted)!important;}

/* ====================== 21. P1 MOTION: reveal / count-up / ring / crest ====================== */
/* entrance reveal — gated by .js-on (user.js adds it) so no-JS users never see hidden content */
.js-on body.kt-deepspace .ds-reveal{opacity:0;transform:translateY(18px)}
.js-on body.kt-deepspace .ds-reveal.in{opacity:1;transform:none;
  transition:opacity .45s cubic-bezier(.16,1,.3,1),transform .45s cubic-bezier(.16,1,.3,1)}

/* copy-success flash (paired with a .ds-copied class added in the clipboard callback) */
@keyframes ds-flash{0%{background:rgba(52,245,197,.22)}100%{background:transparent}}
body.kt-deepspace .copy-text.ds-copied{animation:ds-flash .6s ease-out}

/* 剩余流量径向环 (SVG r=52 -> circumference 2*pi*r = 326.726). Sits in the KPI
   icon slot (~64px). It is NOT hidden by .ds-reveal (the card already fades it in);
   .ds-reveal is only used so user.js adds .in to trigger the stroke sweep. */
body.kt-deepspace .ds-ring{position:relative;width:52px;height:52px;flex:none;align-self:flex-start}
body.kt-deepspace .ds-ring svg{width:52px;height:52px;display:block}
.js-on body.kt-deepspace .ds-ring.ds-reveal{opacity:1;transform:none}
body.kt-deepspace .ds-ring-track{fill:none;stroke:var(--hair);stroke-width:8}
body.kt-deepspace .ds-ring-fill{fill:none;stroke:var(--mint);stroke-width:8;stroke-linecap:round;
  transform:rotate(-90deg);transform-origin:60px 60px;stroke-dasharray:326.726;
  stroke-dashoffset:calc(326.726px * (1 - var(--ring-p,0)))} /* default = final (no-JS / reduced) */
.js-on body.kt-deepspace .ds-ring-fill{stroke-dashoffset:326.726px}      /* JS present -> start empty */
.js-on body.kt-deepspace .ds-ring.in .ds-ring-fill{
  stroke-dashoffset:calc(326.726px * (1 - var(--ring-p,0)));
  transition:stroke-dashoffset .9s cubic-bezier(.16,1,.3,1)}
body.kt-deepspace .ds-ring-val{position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;font-family:var(--fmono)!important;font-weight:700;
  color:var(--mint)!important;text-decoration:none!important;font-size:15px;line-height:1.15;text-align:center}
body.kt-deepspace .ds-ring-val:hover{color:#7af0d4!important}

/* P1: the membership card grew taller with the bear crest -> keep the 4 KPI cards
   (col-xl-3 + mb-8, mb-8 = 2rem) equal height so the row stays aligned. */
body.kt-deepspace .col-xl-3 > .card.card-custom.mb-8{height:calc(100% - 2rem)!important}

/* 按等级守护熊徽记 (membership card crest, keyed to User.class) — now in the top icon
   slot (replaces the generic person icon), top-aligned to match the KPI number. */
body.kt-deepspace .ds-class-crest{width:52px;height:52px;object-fit:contain;flex:none;align-self:flex-start}
body.kt-deepspace .ds-tier-expired .ds-class-crest{opacity:.42}
body.kt-deepspace .ds-tier-trial .ds-class-crest{opacity:.6}
body.kt-deepspace .ds-tier-diamond .ds-class-crest{filter:drop-shadow(0 6px 16px rgba(56,225,255,.3))}
body.kt-deepspace .ds-tier-flag .ds-class-crest{filter:drop-shadow(0 6px 18px rgba(232,195,122,.4))}
body.kt-deepspace .ds-tier-diamond{border-color:rgba(56,225,255,.30)!important}
body.kt-deepspace .ds-tier-flag{border-color:rgba(232,195,122,.55)!important;
  box-shadow:0 24px 60px rgba(232,195,122,.14),inset 0 1px 0 rgba(232,195,122,.2)!important}

/* shop package cards: per-class guardian-bear crest (in the empty card-header) +
   per-tier title color (白金白 / 钻石青 / 御玺金). */
body.kt-deepspace .ds-shop-crest{height:48px;width:auto;display:block;margin:0 auto}
body.kt-deepspace .ds-tier-diamond .ds-shop-crest{filter:drop-shadow(0 6px 16px rgba(56,225,255,.35))}
body.kt-deepspace .ds-tier-flag .ds-shop-crest{filter:drop-shadow(0 6px 18px rgba(232,195,122,.45))}
body.kt-deepspace h3.ds-shop-title-diamond{color:var(--cyan)!important}
body.kt-deepspace h3.ds-shop-title-flag{color:var(--gold)!important}

/* ====================== 22. /user/help client-card title ====================== */
/* The title is float-based (icon = <li style="float:left">, 安装教程 = .pull-r) inside
   an <h2> -> icon/title/button land on inconsistent baselines + a loose mb-8 gap.
   Make it one clean flex row: icon+name left (centered), button right (centered). */
body.kt-deepspace .card-custom .card-body .p-6 > h2.text-primary{
  display:flex!important;align-items:center;gap:10px;flex-wrap:wrap;
  margin-bottom:1.5rem!important;line-height:1.2;}
body.kt-deepspace .card-custom .card-body .p-6 > h2.text-primary > li,
body.kt-deepspace .card-custom .card-body .p-6 > h2.text-primary > li[class]{
  float:none!important;margin:0!important;line-height:1;display:inline-flex;align-items:center;}
body.kt-deepspace .card-custom .card-body .p-6 > h2.text-primary .card-toolbar.pull-r{
  margin:0 0 0 auto!important;float:none!important;}

/* ====================== 20. REDUCED MOTION ====================== */
@media (prefers-reduced-motion:reduce){
  body.kt-deepspace #checkin.btn-white:not(.disabled),
  body.kt-deepspace .card.card-custom,
  .js-on body.kt-deepspace .ds-reveal.in,
  .js-on body.kt-deepspace .ds-ring.in .ds-ring-fill,
  body.kt-deepspace .copy-text.ds-copied{animation:none!important;transition:none!important;}
}
