html:root {
  --bg-body: #050505;
  --bg-panel: linear-gradient(160deg, #161616, #0e0e0e);
  --bg-raised: #161616;
  --bg-sidebar: linear-gradient(180deg, #0b0b0b, #070707);
  --bg-input: #0e0e0e;
  --bg-hover: rgba(245, 180, 0, 0.08);
  --bg-active: rgba(245, 180, 0, 0.14);
  --sidebar-hover-bg: rgba(255, 255, 255, 0.05);
  --sidebar-active-bg: linear-gradient(90deg, rgba(245, 180, 0, 0.16), rgba(245, 180, 0, 0.02));
  --sidebar-active-text: #ffffff;
  --sidebar-active-icon-bg: rgba(245, 180, 0, 0.1);
  --sidebar-active-dot: #f5b400;
  --select-trigger-bg: #101010;
  --select-menu-bg: #161616;
  --select-menu-border: rgba(245, 180, 0, 0.2);
  --select-menu-shadow: 0 20px 50px rgba(0, 0, 0, 0.65);
  --select-option-active-bg: rgba(245, 180, 0, 0.12);
  --text-primary: #ffffff;
  --text-secondary: #c4c4c4;
  --text-muted: #8c8c8c;
  --border-color: rgba(255, 255, 255, 0.075);
  --accent: #f5b400;
  --accent-color: #f5b400;
  --accent-hover: #ffc533;
  --accent-alt: #c98a00;
  --accent-blue: #f5b400;
  --accent-warning: #f5b400;
  --bg-surface: #0d0d0d;
  --status-success: #3ecf8e;
  --status-warning: #f5b400;
  --status-info: #f5b400;
  --status-danger: #ff5468;
  --status-purple: #ffc533;
  --radius-sm: 7px;
  --radius-md: 10px;
  --radius-lg: 14px;
  --shadow-panel: 0 12px 30px rgba(0, 0, 0, 0.42);
  --panel-shadow: 0 1px 0 rgba(255, 255, 255, 0.03) inset, 0 12px 30px rgba(0, 0, 0, 0.42);
  --glass-03: rgba(255, 255, 255, 0.025);
  --glass-06: rgba(255, 255, 255, 0.055);
  --hairline-07: rgba(255, 255, 255, 0.07);
  --hairline-08: rgba(255, 255, 255, 0.08);
}

html,
body,
button,
input,
textarea,
select {
  font-family: "Poppins", sans-serif !important;
}

body {
  background: radial-gradient(120% 80% at 50% -10%, #101010, #050505 60%) !important;
  color: var(--text-primary);
}

html body.light-mode {
  --bg-body: #050505;
  --bg-panel: linear-gradient(160deg, #161616, #0e0e0e);
  --bg-raised: #161616;
  --bg-sidebar: linear-gradient(180deg, #0b0b0b, #070707);
  --bg-input: #0e0e0e;
  --bg-hover: rgba(245, 180, 0, 0.08);
  --bg-active: rgba(245, 180, 0, 0.14);
  --text-primary: #ffffff;
  --text-secondary: #c4c4c4;
  --text-muted: #8c8c8c;
  --border-color: rgba(255, 255, 255, 0.075);
  --accent-color: #f5b400;
  --accent-hover: #ffc533;
}

body.light-mode,
body.light-mode button,
body.light-mode input,
body.light-mode textarea,
body.light-mode select,
body.light-mode table th,
body.light-mode table td,
body.light-mode table th :where(span, div, code, strong, small, a),
body.light-mode table td :where(span, div, code, strong, small, a) {
  color: var(--text-primary) !important;
}

body.light-mode .pl-card,
body.light-mode .pl-stats__card,
body.light-mode .pl-whyus__card,
body.light-mode .pl-teamCard,
body.light-mode .pl-markets__card,
body.light-mode .pl-faq__item,
body.light-mode .pl-advantage__card,
body.light-mode .pl-copyBtn,
body.light-mode .pl-btn,
body.light-mode .pl-nav,
body.light-mode .pl-cookie__inner,
body.light-mode .pl-mobilemenu__panel {
  background: linear-gradient(160deg, #161616, #0e0e0e) !important;
  border-color: var(--border-color) !important;
  color: var(--text-primary) !important;
}

#root {
  background: transparent !important;
}

table {
  border-collapse: collapse;
}

table thead th {
  color: #777 !important;
  font-size: 11px !important;
  letter-spacing: 0.7px;
  text-transform: uppercase;
}

table tbody tr {
  transition: background 0.16s ease;
}

table tbody tr:hover {
  background: rgba(245, 180, 0, 0.04) !important;
}

input,
textarea,
select {
  background-color: #0e0e0e !important;
  border-color: var(--border-color) !important;
  color: #e6e6e6 !important;
}

input:focus,
textarea:focus,
select:focus {
  border-color: rgba(245, 180, 0, 0.55) !important;
  box-shadow: 0 0 0 3px rgba(245, 180, 0, 0.1) !important;
}

button {
  letter-spacing: 0.01em;
}

.ps-sidebar-nav button:hover {
  background: rgba(255, 255, 255, 0.05) !important;
}

.pl-section-header-icon {
  color: var(--accent-color) !important;
  background: rgba(245, 180, 0, 0.1) !important;
  border-color: rgba(245, 180, 0, 0.22) !important;
}

.pl-ui-btn--primary,
.pl-btn--primary,
.login-btn {
  background: linear-gradient(180deg, #ffc533, #c98a00) !important;
  border-color: transparent !important;
  color: #1a1200 !important;
  box-shadow: 0 8px 24px rgba(245, 180, 0, 0.22) !important;
}

.pl-ui-btn--primary:hover,
.pl-btn--primary:hover,
.login-btn:hover {
  background: linear-gradient(180deg, #ffd05a, #e09b00) !important;
  box-shadow: 0 12px 30px rgba(245, 180, 0, 0.32) !important;
  transform: translateY(-1px);
}

.login-input {
  background: #0e0e0e !important;
  border-color: var(--border-color) !important;
}

.login-input:focus-within {
  border-color: rgba(245, 180, 0, 0.55) !important;
  box-shadow: 0 0 0 3px rgba(245, 180, 0, 0.1) !important;
}

html body .login-input:focus {
  border-color: rgba(245, 180, 0, 0.55) !important;
  background: rgba(245, 180, 0, 0.03) !important;
}

.login-forgot,
.pl-copyBtn,
a {
  color: var(--accent-color);
}

.pl-dashboard-vanta {
  background:
    radial-gradient(900px 520px at 85% -10%, rgba(245, 180, 0, 0.09), transparent 62%),
    radial-gradient(700px 500px at 10% 100%, rgba(245, 180, 0, 0.04), transparent 64%),
    #050505 !important;
}

/* Public website */
.pl-header {
  background: rgba(5, 5, 5, 0.82) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.07) !important;
  backdrop-filter: blur(18px);
}

.pl-navlink {
  color: #d0d0d0 !important;
}

.pl-navlink:hover,
.pl-navlink--active {
  color: var(--accent-color) !important;
}

.pl-hero {
  background:
    radial-gradient(700px 520px at 78% 48%, rgba(245, 180, 0, 0.16), transparent 64%),
    radial-gradient(900px 600px at 12% 20%, rgba(245, 180, 0, 0.055), transparent 68%),
    #050505 !important;
}

.pl-h1,
.pl-h2,
.pl-whyus__title,
.pl-advantage__title,
.pl-stats__title {
  font-family: "Fredoka", "Poppins", sans-serif !important;
  font-weight: 500 !important;
  letter-spacing: -0.025em;
}

.pl-h1 {
  color: #fff !important;
}

.pl-eyebrow,
.pl-shiny,
.pl-stats__num,
.pl-stats__eyebrow {
  color: var(--accent-color) !important;
}

.pl-card,
.pl-stats__card,
.pl-whyus__card,
.pl-markets__card,
.pl-faq__item,
.pl-advantage__card,
.pl-show,
.pl-teamCard,
.pl-compare__row {
  background: linear-gradient(160deg, #161616, #0d0d0d) !important;
  border-color: rgba(255, 255, 255, 0.075) !important;
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.38) !important;
}

.pl-card:hover,
.pl-stats__card:hover,
.pl-whyus__card:hover,
.pl-markets__card:hover,
.pl-advantage__card:hover,
.pl-show:hover {
  border-color: rgba(245, 180, 0, 0.38) !important;
  box-shadow: 0 22px 52px rgba(0, 0, 0, 0.5), 0 0 38px rgba(245, 180, 0, 0.06) !important;
}

.pl-icbox,
.pl-whyus__cardIcon,
.pl-miniIco,
.pl-bulletIco {
  color: var(--accent-color) !important;
  background: rgba(245, 180, 0, 0.1) !important;
  border-color: rgba(245, 180, 0, 0.22) !important;
}

.pl-footer {
  background: #060606 !important;
  border-color: var(--border-color) !important;
}

.pl-cookie__inner {
  background: linear-gradient(160deg, #181818, #0e0e0e) !important;
  border-color: rgba(245, 180, 0, 0.22) !important;
}

.pl-cookie__titleIcon {
  color: var(--accent-color) !important;
  background: rgba(245, 180, 0, 0.1) !important;
  border-color: rgba(245, 180, 0, 0.22) !important;
}

.pl-cookie__btn--primary {
  background: linear-gradient(180deg, #ffc533, #c98a00) !important;
  border-color: transparent !important;
  color: #1a1200 !important;
}

@media (max-width: 767px) {
  .pl-header {
    background: rgba(5, 5, 5, 0.94) !important;
  }

  .pl-mobilemenu__panel {
    background: linear-gradient(160deg, #181818, #0d0d0d) !important;
    border-color: rgba(245, 180, 0, 0.2) !important;
  }
}

/* =========================================================
   DASHBOARD / APP SHELL — PlaySlot gold-on-black treatment
   The app renders via inline styles bound to CSS variables
   (defined above). These rules harden the non-variable bits:
   sidebar active state, tables, stat cards, scrollbars, chips.
   ========================================================= */

/* Sidebar brand logo sizing for the wide PlaySlot wordmark */
.ps-sidebar img[src*="logo"],
nav img[src*="logo.webp"] {
  object-fit: contain;
}

/* Sidebar nav items */
.ps-sidebar-nav button,
nav button[class*="nav"] {
  transition: background 0.16s ease, color 0.16s ease !important;
}
.ps-sidebar-nav button:hover {
  background: rgba(255, 255, 255, 0.05) !important;
  color: #fff !important;
}

/* Tables — gold-accented headers, hairline rows, hover glow */
table thead th {
  color: #777 !important;
  font-size: 11px !important;
  letter-spacing: 0.7px;
  text-transform: uppercase;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
}
table tbody td {
  border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
}
table tbody tr:hover {
  background: rgba(245, 180, 0, 0.05) !important;
}

/* Stat / KPI cards inside the dashboard */
[class*="stat"][class*="card"],
[class*="kpi"],
.pl-card {
  border-radius: 14px;
}
[class*="stat"][class*="card"]:hover {
  border-color: rgba(245, 180, 0, 0.35) !important;
}

/* Numeric accents / deltas / positive trends use gold or green */
[class*="positive"],
[class*="--up"],
[class*="trend-up"] {
  color: var(--status-success) !important;
}
[class*="negative"],
[class*="--down"],
[class*="trend-down"] {
  color: var(--status-danger) !important;
}

/* Badges, pills and chips */
[class*="badge"],
[class*="chip"],
[class*="pill"] {
  border-color: rgba(245, 180, 0, 0.25);
}

/* Progress bars / meters */
progress::-webkit-progress-value,
[class*="progress"] > [style*="width"],
[role="progressbar"] > * {
  background: linear-gradient(90deg, #ffc533, #f5b400) !important;
}

/* Links and active accents fall back to gold */
a:hover,
[class*="link"]:hover {
  color: var(--accent-color) !important;
}

/* Tabs active underline / segmented controls */
[class*="tab"][class*="active"],
[aria-selected="true"] {
  color: var(--accent-color) !important;
  border-color: var(--accent-color) !important;
}

/* Custom scrollbars to match the PlaySlot static site */
* {
  scrollbar-width: thin;
  scrollbar-color: #3a3a3a transparent;
}
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}
::-webkit-scrollbar-track {
  background: transparent;
}
::-webkit-scrollbar-thumb {
  background: #333;
  border-radius: 20px;
  border: 2px solid transparent;
  background-clip: padding-box;
}
::-webkit-scrollbar-thumb:hover {
  background: #4a4a4a;
  background-clip: padding-box;
}

/* Toggles / switches use the gold gradient when on */
[class*="switch"][class*="on"],
[class*="toggle"][aria-checked="true"],
input:checked + [class*="slider"] {
  background: linear-gradient(180deg, #ffc533, #c98a00) !important;
}

/* =========================================================
   AFFILIATE SIGN-UP (register form) — Country / Traffic Sources
   The register bundle ships its own embedded CSS using the old
   blue-grey palette (#1e2028 / #1e293b). Re-skin to PlaySlot
   gold-on-black so the dropdowns match the static site.
   ========================================================= */
.reg-field,
.reg-first-name,
.reg-last-name,
.reg-email,
.reg-phone,
.reg-password,
.reg-password-confirm,
.reg-country,
.reg-ct-btn > input,
.reg-ct-btn > button {
  background: #0e0e0e !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  color: #e6e6e6 !important;
  border-radius: 10px !important;
}
.reg-field:focus,
.reg-country:focus,
.reg-email:focus,
.reg-phone:focus,
.reg-password:focus,
.reg-password-confirm:focus,
.reg-first-name:focus,
.reg-last-name:focus {
  border-color: rgba(245, 180, 0, 0.55) !important;
  box-shadow: 0 0 0 3px rgba(245, 180, 0, 0.1) !important;
}

/* Country / Traffic Sources dropdown panel */
.reg-ct-dd,
.reg-dropdown {
  background: linear-gradient(160deg, #1c1c1c, #111) !important;
  border: 1px solid rgba(245, 180, 0, 0.2) !important;
  border-radius: 12px !important;
  box-shadow: 0 22px 50px rgba(0, 0, 0, 0.6) !important;
}
.reg-ct-dd .reg-dd-item,
.reg-dropdown .reg-dd-item {
  color: #cfd5e0 !important;
  border-radius: 8px !important;
  transition: background 0.14s, color 0.14s !important;
}
.reg-ct-dd .reg-dd-item:hover,
.reg-dropdown .reg-dd-item:hover,
.reg-dd-item.active,
.reg-dd-item[aria-selected="true"] {
  background: rgba(245, 180, 0, 0.1) !important;
  color: #fff !important;
}

/* Selected traffic-source chips */
.reg-tag {
  background: rgba(245, 180, 0, 0.12) !important;
  border: 1px solid rgba(245, 180, 0, 0.3) !important;
  color: #ffd564 !important;
  border-radius: 20px !important;
}
.reg-tag button {
  color: var(--accent-color) !important;
}

/* =========================================================
   DASHBOARD — closer parity with the PlaySlot static demo
   ========================================================= */
/* KPI / metric cards — fully flat (no background / border / shadow) */
[class*="kpi"],
[class*="metric"],
[class*="stat-card"],
.pl-card {
  background: transparent !important;
  border: 1px solid transparent !important;
  box-shadow: none !important;
}
[class*="kpi"]:hover,
[class*="metric"]:hover,
[class*="stat-card"]:hover {
  border-color: transparent !important;
  transform: none !important;
}

/* Sidebar nav items — match the PlaySlot static dashboard exactly */
.ps-sidebar-nav .ps-nav-item {
  position: relative;
  color: #b0b0b0 !important;
  font-weight: 500 !important;
}
.ps-sidebar-nav .ps-nav-item:hover {
  background: rgba(255, 255, 255, 0.05) !important;
  color: #fff !important;
}
.ps-sidebar-nav .ps-nav-item--active {
  background: linear-gradient(90deg, rgba(245, 180, 0, 0.15), rgba(245, 180, 0, 0.02)) !important;
  color: #fff !important;
  font-weight: 600 !important;
}
/* Gold left bar with glow — the signature PlaySlot active indicator */
.ps-sidebar-nav .ps-nav-item--active::before {
  content: "";
  position: absolute;
  left: -8px;
  top: 50%;
  transform: translateY(-50%);
  width: 4px;
  height: 22px;
  border-radius: 0 4px 4px 0;
  background: #f5b400;
  box-shadow: 0 0 12px rgba(245, 180, 0, 0.7);
}
/* PlaySlot has no right-side dot on the active item — hide it */
.ps-sidebar-nav .ps-nav-item--active > div:last-child {
  display: none !important;
}
/* Active icon glows gold */
.ps-sidebar-nav .ps-nav-item--active > div:first-child {
  background: rgba(245, 180, 0, 0.1) !important;
}

/* Charts: nudge default series strokes/fills toward gold where exposed */
.apexcharts-line,
.apexcharts-area-series .apexcharts-area + path,
svg [class*="chart"] path[stroke="#3ecf8e"],
svg [class*="chart"] path[stroke="#3ecf8e"] {
  stroke: #f5b400 !important;
}
.apexcharts-gridline {
  stroke: rgba(255, 255, 255, 0.05) !important;
}

/* Belt-and-braces: never render the light theme even if class slips in */
body.light-mode {
  background: radial-gradient(120% 80% at 50% -10%, #101010, #050505 60%) !important;
  color: #fff !important;
}

/* =========================================================
   DASHBOARD — exact PlaySlot static-dashboard look, scoped
   under .psdash so it never leaks into the rest of the app.
   Mirrors PlaySlot/assets/css/app.css + dashboard.html styles.
   ========================================================= */
.psdash{
  --gold:#F5B400;--gold-bright:#FFC533;--gold-deep:#C98A00;
  --green:#3ECf8E;--red:#ef5b6e;--muted:#8c8c8c;--label:#777;
  --line:rgba(255,255,255,0.07);--card-grad:linear-gradient(160deg,#161616,#0e0e0e);
  color:#fff;font-family:'Poppins',sans-serif;
}
.psdash .card{background:var(--card-grad);border:1px solid rgba(255,255,255,0.06);border-radius:14px;box-shadow:0 1px 0 rgba(255,255,255,0.03) inset,0 12px 30px rgba(0,0,0,0.4);}
.psdash svg{display:block;}
.psdash .kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:18px;}
.psdash .kpi{background:transparent;border:1px solid transparent;border-radius:14px;padding:18px 18px 0;position:relative;overflow:hidden;box-shadow:none;transition:transform .2s,border-color .2s;}
.psdash .kpi:hover{transform:none;border-color:transparent;}
/* Defensive: no inner outline boxes inside KPI cards (flat look) */
.psdash .kpi .dash-kpi-card,
.psdash .kpi .dash-motion-card,
.psdash .kpi > div[style*="border"]{border:none!important;box-shadow:none!important;background:transparent!important;border-radius:0!important;padding:0!important;}
.psdash .kpi-top{display:flex;align-items:center;gap:13px;margin-bottom:4px;}
.psdash .kpi .ring{width:44px;height:44px;border-radius:50%;flex-shrink:0;border:1.5px solid rgba(245,180,0,.5);display:flex;align-items:center;justify-content:center;color:var(--gold);}
.psdash .kpi.white .ring{border-color:rgba(255,255,255,.35);color:#fff;}
.psdash .kpi .klabel{font-size:11px;color:var(--label);letter-spacing:1.2px;font-weight:500;}
.psdash .kpi .knum{font-size:30px;font-weight:700;letter-spacing:-.5px;margin-top:1px;font-variant-numeric:tabular-nums;color:#fff;}
.psdash .kpi .kdelta{display:flex;align-items:center;gap:6px;font-size:12.5px;margin:9px 0 6px;}
.psdash .kpi .kdelta .up{color:var(--green);font-weight:600;display:flex;align-items:center;gap:3px;}
.psdash .kpi .kdelta .vs{color:#7a7a7a;}
.psdash .kpi .spark{margin:14px -18px 0;}
.psdash .grid-mid{display:grid;grid-template-columns:1fr 360px;gap:18px;margin-bottom:18px;}
.psdash .card-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;}
.psdash .card-head .ti{display:flex;align-items:center;gap:8px;font-size:13px;letter-spacing:1px;color:#cfcfcf;font-weight:600;}
.psdash .card-head .ti .info{color:#6a6a6a;}
.psdash .mini-pill{display:flex;align-items:center;gap:8px;background:#161616;border:1px solid var(--line);border-radius:8px;padding:8px 12px;font-size:12.5px;color:#d0d0d0;cursor:pointer;}
.psdash .mini-pill .chev{color:#7a7a7a;}
.psdash .dots-btn{width:34px;height:34px;border-radius:8px;background:#161616;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:#bbb;cursor:pointer;}
.psdash .head-actions{display:flex;align-items:center;gap:9px;}
.psdash .legend{display:flex;gap:18px;padding:0 20px 6px;}
.psdash .legend .lg{display:flex;align-items:center;gap:7px;font-size:12px;color:#bdbdbd;}
.psdash .legend .d{width:8px;height:8px;border-radius:50%;}
.psdash .donut-wrap{display:flex;align-items:center;gap:20px;padding:6px 20px 14px;}
.psdash .donut-box{position:relative;flex-shrink:0;}
.psdash .donut-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none;}
.psdash .donut-center b{font-size:24px;font-weight:700;}
.psdash .donut-center small{font-size:11px;color:#888;}
.psdash .clist{flex:1;display:flex;flex-direction:column;gap:9px;}
.psdash .crow{display:flex;align-items:center;gap:9px;font-size:12.5px;}
.psdash .crow .cd{width:9px;height:9px;border-radius:50%;flex-shrink:0;}
.psdash .crow .cn{color:#dcdcdc;}
.psdash .crow .cv{margin-left:auto;color:#9a9a9a;font-size:12px;}
.psdash .crow .cv b{color:#e6e6e6;font-weight:600;}
.psdash .card-foot-link{display:flex;align-items:center;justify-content:flex-end;gap:6px;padding:14px 20px;border-top:1px solid var(--line);color:var(--gold);font-size:12.5px;font-weight:500;cursor:pointer;}
.psdash .grid-bot{display:grid;grid-template-columns:1fr 360px;gap:18px;}
.psdash .ra-table{width:100%;border-collapse:collapse;}
.psdash .ra-table thead th{text-align:left;font-size:10.5px;letter-spacing:.8px;color:#6f6f6f;font-weight:600;padding:6px 12px 12px;border-bottom:1px solid var(--line);}
.psdash .ra-table tbody td{padding:11px 12px;border-bottom:1px solid rgba(255,255,255,0.04);vertical-align:middle;font-size:12.5px;}
.psdash .ra-table tbody tr:last-child td{border-bottom:none;}
.psdash .ttype{display:flex;align-items:center;gap:9px;font-weight:500;}
.psdash .tav{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.psdash .tav.ftd{border:1.3px solid rgba(245,180,0,.55);color:var(--gold);}
.psdash .tav.signup{border:1.3px solid rgba(96,165,250,.6);color:#7fb4ff;}
.psdash .uname{font-weight:500;color:#eaeaea;}
.psdash .uemail{font-size:11px;color:#7a7a7a;}
.psdash .country{display:flex;align-items:center;gap:8px;color:#d4d4d4;}
.psdash .flag{font-size:15px;line-height:1;}
.psdash .badge-ok{display:inline-flex;align-items:center;background:rgba(62,207,142,0.13);color:#3ecf8e;font-size:11px;font-weight:500;padding:4px 12px;border-radius:5px;}
.psdash .amt{color:#e0e0e0;font-variant-numeric:tabular-nums;}
.psdash .comm{color:var(--gold);font-weight:600;font-variant-numeric:tabular-nums;}
.psdash .time{color:#cfcfcf;}
.psdash .time small{display:block;color:#7a7a7a;font-size:10.5px;margin-top:1px;}
.psdash .dash{color:#5a5a5a;}
.psdash .payouts{position:relative;overflow:hidden;display:flex;flex-direction:column;}
.psdash .payouts .ph{padding:18px 20px 4px;font-size:13px;letter-spacing:1px;color:#cfcfcf;font-weight:600;}
.psdash .payouts .pbody{padding:8px 20px 0;position:relative;z-index:2;}
.psdash .payouts .plabel{font-size:11.5px;color:#8a8a8a;letter-spacing:.4px;}
.psdash .payouts .pbal{font-size:34px;font-weight:700;letter-spacing:-1px;margin:2px 0 16px;font-variant-numeric:tabular-nums;}
.psdash .payouts .pending{font-size:11.5px;color:#8a8a8a;display:flex;align-items:center;gap:6px;}
.psdash .payouts .pamt{font-size:18px;font-weight:600;margin-top:2px;}
.psdash .payouts .wallet{position:absolute;top:6px;right:-4px;z-index:1;}
.psdash .payouts .pactions{padding:18px 20px;margin-top:auto;}
.psdash .req-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;background:linear-gradient(180deg,var(--gold-bright),var(--gold-deep));color:#1a1200;font-weight:700;font-size:15px;border:none;border-radius:10px;padding:15px;cursor:pointer;box-shadow:0 8px 24px rgba(245,180,0,.2);transition:transform .15s;}
.psdash .req-btn:hover{transform:translateY(-1px);}
.psdash .hist-link{width:100%;text-align:center;display:flex;align-items:center;justify-content:center;gap:7px;color:var(--gold);font-size:13px;font-weight:500;margin-top:14px;cursor:pointer;}
@media(max-width:1240px){.psdash .kpis{gap:14px;}.psdash .grid-mid,.psdash .grid-bot{grid-template-columns:1fr 320px;}}
@media(max-width:1024px){.psdash .grid-mid,.psdash .grid-bot{grid-template-columns:1fr;}.psdash .kpis{grid-template-columns:repeat(2,1fr);gap:16px;}}
@media(max-width:520px){.psdash .kpis{grid-template-columns:1fr;}.psdash .kpi .knum{font-size:27px;}.psdash .donut-wrap{flex-direction:column;align-items:flex-start;}.psdash .clist{width:100%;}}

/* ============================================================
   PS DASHBOARD REFRESH — clean/flat, no rings, no shadows,
   functional rounded filters, fixed footer, sidebar fixes.
   Appended override layer (wins by source order).
   ============================================================ */

/* 1) Clean surfaces: kill shadows site-wide for a sharp, flat look */
:root { --panel-shadow: none !important; }
.psdash .card,
.psdash .kpi,
.dash-scope-card,
.ps-filter-card,
.dash-panel,
.dash-motion-card,
.card,
.panel { box-shadow: none !important; }
.psdash .kpi:hover { transform: none; border-color: transparent; }
.psdash .req-btn { box-shadow: none !important; }
.psdash .req-btn:hover { transform: translateY(-1px); }

/* 2) KPI cards — no ring around icons, tidy subline */
.psdash .kpi { padding: 18px 18px 16px; }
.psdash .kpi .ring { display: none !important; }
.psdash .kpi .kico {
  width: 34px; height: 34px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  color: var(--gold); border: none; border-radius: 0;
}
.psdash .kpi .kico svg { width: 26px; height: 26px; }
.psdash .kpi-top { gap: 11px; margin-bottom: 6px; }
.psdash .kpi .ksub {
  display: flex; align-items: center; gap: 8px;
  font-size: 12.5px; margin: 8px 0 2px; color: #8a8a8a;
}
.psdash .kpi .ksub .kmeta { color: #b9b9b9; font-weight: 500; }
.psdash .kpi .kchip {
  display: inline-flex; align-items: center; gap: 3px;
  font-weight: 600; font-variant-numeric: tabular-nums;
}
.psdash .kpi .kchip.up { color: var(--green, #3ecf8e); }
.psdash .kpi .kchip.down { color: #ef6b6b; }
.psdash .kpi .kchip.flat { color: #8a8a8a; }
.psdash .kpi .spark { margin: 12px -18px 0; }

/* 3) Filters — custom, rounded, layout colours (top strip + in-card pills) */
.ps-filter-card {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px; border-radius: 12px;
  background: var(--bg-panel); border: 1px solid var(--border-color);
}
.ps-filter-card .ps-filter-ic {
  width: 30px; height: 30px; flex-shrink: 0; border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(245,180,0,0.10); color: var(--accent-color);
}
.ps-filter-label {
  font-size: 11px; color: var(--text-muted); text-transform: uppercase;
  letter-spacing: 0.09em; font-weight: 600; margin-bottom: 2px;
}
.ps-filter-static {
  font-size: 13px; color: var(--text-primary); font-weight: 600;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.ps-filter-select {
  appearance: none; -webkit-appearance: none; -moz-appearance: none;
  width: 100%; cursor: pointer;
  font-family: inherit; font-size: 13px; font-weight: 600;
  color: var(--text-primary); background: transparent;
  border: none; outline: none; padding: 0 22px 0 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23F5B400' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><path d='m6 9 6 6 6-6'/></svg>");
  background-repeat: no-repeat; background-position: right center;
}
.ps-filter-select option { background: #141414; color: #e6e6e6; }

/* In-card rounded pill selects (Performance / Top Countries) */
.psdash .ps-pill-wrap {
  display: inline-flex; align-items: center;
  background: #161616;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 8px 12px;
  transition: border-color .2s;
}
.psdash .ps-pill-wrap:hover { border-color: rgba(245,180,0,0.28); }
.psdash .ps-pill {
  appearance: none; -webkit-appearance: none; -moz-appearance: none;
  font-family: inherit; font-size: 12.5px; font-weight: 500;
  color: #d0d0d0; background: transparent; border: none; outline: none;
  cursor: pointer; padding: 0 20px 0 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='13' height='13' viewBox='0 0 24 24' fill='none' stroke='%237a7a7a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='m6 9 6 6 6-6'/></svg>");
  background-repeat: no-repeat; background-position: right center;
}
.psdash .ps-pill option { background: #141414; color: #e6e6e6; }
.psdash .ps-link { cursor: pointer; }
.psdash .ps-link:hover, .psdash .card-foot-link:hover { color: var(--gold-bright, #ffc533); }

/* 4) Performance Overview + Top Countries: equal height, aligned */
.psdash .grid-mid { align-items: stretch; }
.psdash .grid-mid > .card,
.psdash .grid-mid > section.card {
  display: flex; flex-direction: column;
  min-height: 360px; height: 100%; align-self: stretch;
  border-radius: 14px;
}
.psdash .grid-mid .legend { flex: 0 0 auto; }
.psdash #psPerf { flex: 1 1 auto; min-height: 0; max-height: none; }
.psdash .grid-mid .donut-wrap { flex: 1 1 auto; align-items: center; }
.psdash .grid-mid .card-foot-link { margin-top: auto; }

/* 5) Sidebar — collapsed bolt logo + free-hover flyouts (no stuck state) */
.sidebar.rail .side-logo img { display: none !important; }
.sidebar.rail .side-logo .bolt-only { display: block !important; height: 30px; }
.nav-group > .flyout { transition: opacity .14s ease, transform .14s ease; }
/* Invisible hover bridge: fills the gap between the nav item and the flyout so
   moving the mouse across it doesn't drop the hover and close the bubble. */
.nav-group > .flyout::after {
  content: ""; position: absolute; top: -8px; bottom: -8px;
  left: -20px; width: 22px; background: transparent;
}
.nav-group:not(:hover) > .flyout {
  opacity: 0 !important; transform: translateX(6px) scale(.98) !important;
  pointer-events: none !important;
  /* small close delay so a brief mouse slip doesn't snap it shut */
  transition-delay: .22s, .22s !important;
}
.nav-group:hover > .flyout {
  opacity: 1 !important; transform: translateX(0) scale(1) !important;
  pointer-events: auto !important;
  transition-delay: 0s, 0s !important;
}
/* After selecting a flyout item, force the bubble closed even though the cursor
   is still over it. Cleared on mouseleave (see clearFlyDismiss) so a fresh hover reopens it. */
.nav-group.pl-fly-dismiss > .flyout {
  opacity: 0 !important; transform: translateX(6px) scale(.98) !important;
  pointer-events: none !important;
  transition-delay: 0s, 0s !important;
}

/* 6) Public pages footer pinned to bottom (even with little content) */
.pl-site { display: flex; flex-direction: column; min-height: 100vh; }
.pl-footer { margin-top: auto; }

/* 7) Dashboard top bar (Welcome, Partner + date / bell / user) — matches print */
.psdash .ps-dashtop {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; margin: 0 0 20px; flex-wrap: wrap;
}
.psdash .ps-dashtop-left { min-width: 0; }
.psdash .ps-dashtop-title {
  display: flex; align-items: center; gap: 10px;
  margin: 0; font-size: 26px; font-weight: 800; letter-spacing: -0.02em;
  color: #fff; line-height: 1.15;
}
.psdash .ps-dashtop-title .ps-wave { color: var(--gold); line-height: 0; display: inline-flex; transform-origin:70% 80%; animation:ps-wave 2.4s ease-in-out infinite; }
@keyframes ps-wave{0%,60%,100%{transform:rotate(0)}70%{transform:rotate(14deg)}80%{transform:rotate(-8deg)}90%{transform:rotate(12deg)}}
@media (prefers-reduced-motion:reduce){.psdash .ps-dashtop-title .ps-wave{animation:none}}
.psdash .ps-dashtop-sub {
  margin-top: 4px; font-size: 13.5px; color: #8c8c8c; font-weight: 500;
}
.psdash .ps-dashtop-right { display: flex; align-items: center; gap: 12px; flex-shrink: 0; }
.psdash .ps-top-pill {
  display: flex; align-items: center; gap: 9px;
  background: #161616; border: 1px solid var(--line);
  border-radius: 10px; padding: 10px 14px;
  font-size: 13px; color: #e2e2e2; font-weight: 500; cursor: pointer;
  transition: border-color .2s;
}
.psdash .ps-top-pill:hover { border-color: rgba(245,180,0,0.28); }
.psdash .ps-top-pill .ps-top-cal { color: var(--gold); line-height: 0; display: inline-flex; }
.psdash .ps-top-pill .ps-top-chev,
.psdash .ps-top-userpill .ps-top-chev { color: #7a7a7a; line-height: 0; display: inline-flex; }
.psdash .ps-top-iconbtn {
  position: relative; width: 42px; height: 42px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  background: #161616; border: 1px solid var(--line); border-radius: 10px;
  color: #cdcdcd; cursor: pointer; transition: border-color .2s, color .2s;
}
.psdash .ps-top-iconbtn:hover { border-color: rgba(245,180,0,0.28); color: #fff; }
.psdash .ps-top-badge {
  position: absolute; top: -6px; right: -6px;
  min-width: 18px; height: 18px; padding: 0 5px;
  display: flex; align-items: center; justify-content: center;
  background: var(--gold); color: #1a1200;
  font-size: 11px; font-weight: 700; border-radius: 10px;
  border: 2px solid var(--bg-base, #0e0e0e);
}
.psdash .ps-top-userpill {
  display: flex; align-items: center; gap: 9px;
  background: #161616; border: 1px solid var(--line);
  border-radius: 10px; padding: 8px 12px;
  font-size: 13px; color: #e2e2e2; font-weight: 500; cursor: pointer;
  transition: border-color .2s;
}
.psdash .ps-top-userpill:hover { border-color: rgba(245,180,0,0.28); }
.psdash .ps-top-userpill .ps-top-uav {
  width: 26px; height: 26px; flex-shrink: 0; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  border: 1.4px solid rgba(245,180,0,0.5); color: var(--gold);
}
@media (max-width: 760px) {
  .psdash .ps-dashtop { flex-direction: column; align-items: flex-start; gap: 14px; }
  .psdash .ps-dashtop-right { width: 100%; flex-wrap: wrap; }
  .psdash .ps-dashtop-title { font-size: 22px; }
}

/* 8) Dashboard scroll reveal (same spirit as the public index reveals) */
.psdash.has-reveal .ps-reveal {
  opacity: 0;
  transform: translateY(34px) scale(.985);
  filter: blur(5px);
  transition:
    opacity .7s cubic-bezier(.22,1,.36,1),
    transform .85s cubic-bezier(.16,1,.3,1),
    filter .6s ease;
  will-change: opacity, transform, filter;
}
.psdash.has-reveal .ps-reveal.in {
  opacity: 1;
  transform: none;
  filter: none;
}
@media (prefers-reduced-motion: reduce) {
  .psdash.has-reveal .ps-reveal {
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
  }
}


/* 2026-06-16 v8 — remove leftover old SPA accent on filters + footer spacing polish */
:root{--filter-accent:#f5b400;--filter-accent-weak:rgba(245,180,0,.10);--filter-accent-border:rgba(245,180,0,.30);}
.pl-footer{padding-top:18px!important;margin-top:28px!important;}
.ps-filter-card .ps-filter-ic{background:var(--filter-accent-weak)!important;color:var(--filter-accent)!important;border:1px solid rgba(245,180,0,.18)!important;}
.ps-filter-card{border-color:rgba(255,255,255,.08)!important;}
.ps-filter-select{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23F5B400' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><path d='m6 9 6 6 6-6'/></svg>")!important;}
.psdash .ps-pill-wrap:hover,.psdash .ps-pill-wrap:focus-within,.psdash .ps-pill-wrap.is-open{border-color:var(--filter-accent-border)!important;box-shadow:0 10px 26px rgba(0,0,0,.24),0 0 0 1px rgba(245,180,0,.08) inset!important;}
.psdash .ps-link:hover,.psdash .card-foot-link:hover{color:var(--filter-accent)!important;}
.reg-field:focus,.reg-country:focus,.reg-email:focus,.reg-phone:focus,.reg-password:focus,.reg-password-confirm:focus,.reg-first-name:focus,.reg-last-name:focus{border-color:rgba(245,180,0,.55)!important;box-shadow:0 0 0 3px rgba(245,180,0,.10)!important;}
.reg-ct-dd,.reg-dropdown{border-color:rgba(245,180,0,.24)!important;}
.reg-ct-dd .reg-dd-item:hover,.reg-dropdown .reg-dd-item:hover,.reg-dd-item.active,.reg-dd-item[aria-selected="true"]{background:rgba(245,180,0,.12)!important;color:#fff!important;}
.reg-tag{background:rgba(245,180,0,.12)!important;border-color:rgba(245,180,0,.28)!important;color:#ffd978!important;}
