
/* Speedoo Dashboard PRO - App Styles */
:root{
  /* Bridge variables coming from PHP (no-code settings) */
  --spd-primary: var(--spdpro-primary, #51122F);
  --spd-primary-2:#8B2D4C;

  /* LIGHT (default) */
  --spd-bg: var(--spdpro-bg, #f4f6f8);
  --spd-panel: var(--spdpro-panel, #ffffff);
  --spd-panel-2: var(--spdpro-panel-2, #f7f8fa);
  --spd-border: var(--spdpro-border, rgba(15,23,42,.10));
  --spd-text: var(--spdpro-text, #0f172a);
  --spd-muted: var(--spdpro-muted, rgba(15,23,42,.70));
  --spd-shadow: var(--spdpro-shadow, 0 10px 30px rgba(15,23,42,.08));

  --spd-success:#16a34a;
  --spd-warning:#f59e0b;
  --spd-danger:#ef4444;

  --spd-radius: var(--spdpro-card-radius, 14px);
  --spd-radius-btn: var(--spdpro-btn-radius, 12px);
  --spd-space: var(--spdpro-spacing, 14px);
  --spd-font: var(--spdpro-font-size, 14px);

  --spd-sidebar-bg: var(--spdpro-sidebar-bg, #ffffff);
  --spd-topbar-bg: var(--spdpro-topbar-bg, #ffffff);
  --spd-sidebar-text: var(--spdpro-sidebar-text, #ffffff);
  --spd-sidebar-active-bg: var(--spdpro-sidebar-active-bg, rgba(255,255,255,.14));
  --spd-sidebar-active-text: var(--spdpro-sidebar-active-text, #ffffff);
  --spd-sidebar-hover-bg: var(--spdpro-sidebar-hover-bg, rgba(255,255,255,.10));
  --spd-sidebar-hover-text: var(--spdpro-sidebar-hover-text, #ffffff);
  --spd-table-head-bg: var(--spdpro-th-bg, #eef2f6);
  --spd-table-head-text: var(--spdpro-th-text, #0f172a);

  /* Buttons & hover */
  --spd-btn-bg: var(--spdpro-btn-bg, var(--spd-soft));
  --spd-btn-text: var(--spdpro-btn-text, var(--spd-text));
  --spd-btn-hover-bg: var(--spdpro-btn-hover-bg, var(--spd-soft-2));
  --spd-btn-hover-text: var(--spdpro-btn-hover-text, var(--spd-text));
  --spd-btn-primary-bg: var(--spdpro-btn-primary-bg, var(--spd-primary));
  --spd-btn-primary-text: var(--spdpro-btn-primary-text, #ffffff);
  --spd-btn-primary-hover-bg: var(--spdpro-btn-primary-hover-bg, var(--spd-primary));
  --spd-btn-primary-hover-text: var(--spdpro-btn-primary-hover-text, #ffffff);
  --spd-card-hover-bg: var(--spdpro-card-hover-bg, color-mix(in srgb, var(--spd-panel) 92%, var(--spd-primary) 8%));
  --spd-card-hover-border: var(--spdpro-card-hover-border, color-mix(in srgb, var(--spd-primary) 55%, var(--spd-border) 45%));

  --spd-radius-sm: clamp(6px, calc(var(--spd-radius-btn) - 2px), 16px);

  /* Theme-aware UI surfaces */
  --spd-soft: rgba(15,23,42,.04);
  --spd-soft-2: rgba(15,23,42,.06);
  --spd-input-bg: var(--spd-panel);
  --spd-input-border: rgba(15,23,42,.12);
  --spd-divider: rgba(15,23,42,.08);
}

/* DARK theme override */
body.spd-theme-dark{
  --spd-sidebar-bg: var(--spdpro-sidebar-bg, #0f1220);
  --spd-topbar-bg: var(--spdpro-topbar-bg, #11152a);
  --spd-bg: var(--spdpro-bg, #0b0e17);
  --spd-panel: var(--spdpro-panel, #0f1324);
  --spd-panel-2: var(--spdpro-panel-2, #121735);
  --spd-border: var(--spdpro-border, rgba(255,255,255,.08));
  --spd-text: var(--spdpro-text, #f3f5ff);
  --spd-muted: var(--spdpro-muted, rgba(243,245,255,.72));
  --spd-shadow: var(--spdpro-shadow, 0 18px 36px rgba(0,0,0,.35));
  --spd-table-head-bg: var(--spdpro-th-bg, #151a33);
  --spd-table-head-text: var(--spdpro-th-text, #ffffff);

  --spd-soft: rgba(255,255,255,.06);
  --spd-soft-2: rgba(255,255,255,.08);
  --spd-input-bg: color-mix(in srgb, var(--spd-panel) 92%, #000 8%);
  --spd-input-border: rgba(255,255,255,.14);
  --spd-divider: rgba(255,255,255,.08);
}

/* Settings tabs */
.spdpro-tabs{display:flex; flex-wrap:wrap; gap:8px; margin:10px 0 14px}
.spdpro-tab-btn{
  border:1px solid var(--spd-border);
  background:var(--spd-soft);
  color:var(--spd-text);
  padding:8px 12px;
  border-radius:999px;
  cursor:pointer;
  transition:.15s;
}
.spdpro-tab-btn:hover{background:var(--spd-soft-2)}
.spdpro-tab-btn.active{border-color:var(--spd-primary); box-shadow:0 0 0 3px rgba(81,18,47,.18)}
.spdpro-tab-panel{display:none}
.spdpro-tab-panel.active{display:block}

/* Settings save bar */
.spdpro-settings-savebar{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px;
  border:1px dashed var(--spd-border);
  border-radius:var(--spd-radius);
  background:var(--spd-soft);
  margin:8px 0 14px;
}

html,body{height:100%}
body.spdpro-app{
  margin:0;
  font-family: system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";
  font-size: var(--spd-font);
  /* Force dashboard theme colors even if the active WP theme sets body colors with high specificity */
  background: var(--spd-bg) !important;
  color:var(--spd-text) !important;
}

/* Some WP themes paint wrappers instead of body. Force our surfaces too. */
.spdpro-shell{background:var(--spd-bg) !important; color:var(--spd-text) !important;}
.spdpro-main{background:transparent !important; color:inherit;}
.spdpro-content{background:transparent !important;}

.spdpro-rtl{direction:rtl}
.spdpro-ltr{direction:ltr}

a{color:inherit}
a:hover{opacity:.9}
code{background:rgba(255,255,255,.06); padding:2px 6px; border-radius:8px}

.spdpro-loader{
  position:fixed; inset:0; display:flex; align-items:center; justify-content:center;
  background:rgba(0,0,0,.35); backdrop-filter: blur(6px);
  z-index:9999; opacity:0; pointer-events:none; transition:.2s;
}
.spdpro-loader.on{opacity:1; pointer-events:auto}
.spdpro-spinner{
  width:42px; height:42px; border-radius:50%;
  border:3px solid rgba(255,255,255,.2); border-top-color: var(--spd-primary);
  animation: spdspin 1s linear infinite;
}
@keyframes spdspin{to{transform:rotate(360deg)}}

.spdpro-shell{
  display:flex;
  min-height:100vh;
}
.spdpro-sidebar{
  width:260px; flex:0 0 260px;
  background: var(--spd-sidebar-bg);
  border-inline-end:1px solid var(--spd-border);
  padding:16px;
  position:sticky;
  top:0;
  height:100vh;
  overflow:auto;
}
.spdpro-embed-mode .spdpro-main{padding:0}

.spdpro-brand{
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  padding:8px 8px 14px 8px;
}
.spdpro-logo{max-width:170px; height:auto; display:block; filter: drop-shadow(0 10px 18px rgba(0,0,0,.25))}
.spdpro-sidebar-toggle{
  display:none;
  border:1px solid var(--spd-border);
  background:rgba(255,255,255,.04);
  color:var(--spd-text);
  border-radius:var(--spd-radius-sm);
  padding:8px 10px;
  cursor:pointer;
}
.spdpro-nav{display:flex; flex-direction:column; gap:6px; padding-top:8px}
.spdpro-nav-item{
  display:flex; align-items:center; gap:10px;
  padding:10px 12px;
  border-radius:var(--spd-radius-btn);
  text-decoration:none;
  color:var(--spd-muted);
  border:1px solid transparent;
}
.spdpro-nav-item:hover{
  background:rgba(255,255,255,.04);
  color:var(--spd-text);
  border-color:rgba(255,255,255,.06);
}
.spdpro-nav-item.active{
  background: linear-gradient(180deg, rgba(81,18,47,.28), rgba(81,18,47,.12));
  border-color: rgba(81,18,47,.55);
  color: var(--spd-text);
}

.spdpro-main{
  flex:1;
  display:flex;
  flex-direction:column;
  min-width:0;
}


.spdpro-topbar-menu{
  display:none;
  align-items:center;
  justify-content:center;
  width:40px;height:40px;
  border-radius: var(--spd-radius-btn);
  border:1px solid var(--spd-border);
  background: var(--spd-soft);
  color: var(--spd-text);
  cursor:pointer;
}
.spdpro-backdrop{
  display:none;
  position:fixed;
  inset:0;
  background: rgba(0,0,0,.35);
  z-index:99;
}
.spdpro-backdrop.show{display:block;}

.spdpro-topbar{
  background: linear-gradient(180deg, rgba(255,255,255,.03), transparent 60%), var(--spd-topbar-bg);
  border-bottom:1px solid var(--spd-border);
  padding:14px 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  position:sticky;
  top:0;
  z-index:50;
}
.spdpro-page-title{font-size:16px; font-weight:800; letter-spacing:.2px}
.spdpro-user{display:flex; align-items:center; gap:10px}
.spdpro-user-name{color:var(--spd-muted); font-weight:600}
.spdpro-lang{
  display:inline-flex; align-items:center; justify-content:center;
  padding:6px 10px;
  border-radius:var(--spd-radius-sm);
  text-decoration:none;
  border:1px solid var(--spd-border);
  color:var(--spd-muted);
  margin-inline-start:6px;
}
.spdpro-lang:hover{color:var(--spd-text); border-color:color-mix(in srgb, var(--spd-text) 18%, transparent)}

.spdpro-content{
  padding:18px;
}
.spdpro-footer{
  padding:16px 18px;
  color:var(--spd-muted);
  border-top:1px solid var(--spd-border);
  opacity:.9;
}

.spdpro-card{
  background: linear-gradient(180deg, rgba(255,255,255,.03), transparent 40%), var(--spd-panel) !important;
  border:1px solid var(--spd-border);
  border-radius: var(--spd-radius);
  padding:16px;
  box-shadow: 0 20px 55px rgba(0,0,0,.26);
  color: var(--spd-text) !important;
  transition: background .15s ease, border-color .15s ease, transform .15s ease;
}
.spdpro-card:hover{
  background: linear-gradient(180deg, rgba(255,255,255,.05), transparent 40%), var(--spd-card-hover-bg);
  border-color: var(--spd-card-hover-border);
}
.spdpro-card.inner{
  background: var(--spd-panel-2) !important;
  box-shadow:none;
}
.spdpro-card + .spdpro-card{margin-top:14px}
.spdpro-card-head{
  display:flex; align-items:flex-start; justify-content:space-between; gap:12px; margin-bottom:12px;
}
.spdpro-card-title{
  font-weight:800;
  letter-spacing:.2px;
}
.spdpro-h1{font-size:18px; font-weight:900}
.spdpro-muted{color:var(--spd-muted); line-height:1.5}
.spdpro-hint{color:var(--spd-muted); font-size:13px; margin-top:10px}
.spdpro-divider{height:1px; background:var(--spd-border); margin:14px 0}

.spdpro-grid{
  display:grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap:14px;
  margin-bottom:14px;
}
.spdpro-grid-2{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:14px;
}
.spdpro-grid > * ,
.spdpro-grid-2 > *{min-width:0}
@media (max-width: 1100px){
  .spdpro-grid{grid-template-columns: repeat(3, minmax(0, 1fr))}
  .spdpro-grid-2{grid-template-columns:1fr}
}
@media (max-width: 600px){
  .spdpro-grid{grid-template-columns: repeat(2, minmax(0, 1fr))}
  .spdpro-card-big{font-size:22px}
  .spdpro-content{padding:14px}
}
@media (max-width: 1024px){
  .spdpro-topbar-menu{display:inline-flex}

  /* Make layout single-column on small screens */
  .spdpro-shell{display:block;}
  .spdpro-main{width:100%;}

    /* Off-canvas sidebar for phones & tablets
     Fix: some mobile browsers + RTL layouts were leaving a visible strip.
     This implementation uses left/right positioning instead of % transforms,
     ensuring the sidebar is FULLY off-screen when closed. */
  :root{ --spdpro-mobile-sidebar-w: min(86vw, 340px); }

  .spdpro-sidebar{
    position:fixed !important;
    top:0 !important;
    bottom:0 !important;
    width: var(--spdpro-mobile-sidebar-w) !important;
    max-width:340px !important;
    height:100vh !important;
    z-index:1000 !important;
    box-shadow: 0 18px 40px rgba(0,0,0,.18);
    transition:left .22s ease, right .22s ease;
    transform:none !important;
  }
  /* Closed state */
  html[dir="rtl"] body.spdpro-app .spdpro-sidebar{
    right: calc(-1 * var(--spdpro-mobile-sidebar-w)) !important;
    left: auto !important;
  }
  html[dir="ltr"] body.spdpro-app .spdpro-sidebar{
    left: calc(-1 * var(--spdpro-mobile-sidebar-w)) !important;
    right: auto !important;
  }
  /* Open state */
  html[dir="rtl"] body.spdpro-app .spdpro-sidebar.open{ right:0 !important; }
  html[dir="ltr"] body.spdpro-app .spdpro-sidebar.open{ left:0 !important; }

  .spdpro-sidebar.open{ pointer-events:auto; }
  .spdpro-sidebar:not(.open){ pointer-events:none; }
  .spdpro-sidebar-toggle{display:inline-flex}
}
.spdpro-card-big{font-size:26px; font-weight:900; margin-top:10px}

.spdpro-actions{display:flex; flex-wrap:wrap; gap:8px; align-items:center; justify-content:flex-end}
.spdpro-btn{
  appearance:none;
  border:1px solid var(--spd-border);
  background:var(--spd-btn-bg);
  color:var(--spd-btn-text);
  padding:10px 12px;
  border-radius: var(--spd-radius-btn);
  cursor:pointer;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  font-weight:700;
}
.spdpro-btn:hover{background:var(--spd-btn-hover-bg); color:var(--spd-btn-hover-text); border-color:color-mix(in srgb, var(--spd-btn-hover-text) 16%, transparent)}
.spdpro-btn.primary{
  background: var(--spd-btn-primary-bg);
  color: var(--spd-btn-primary-text);
  border-color: color-mix(in srgb, var(--spd-btn-primary-bg) 70%, transparent 30%);
}
.spdpro-btn.primary:hover{
  background: var(--spd-btn-primary-hover-bg);
  color: var(--spd-btn-primary-hover-text);
  border-color: color-mix(in srgb, var(--spd-btn-primary-hover-bg) 76%, transparent 24%);
}
.spdpro-btn.danger{
  background: rgba(239,68,68,.12);
  border-color: rgba(239,68,68,.5);
}
.spdpro-btn.tiny{padding:6px 9px; border-radius:var(--spd-radius-sm); font-weight:800; font-size:12px}

.spdpro-form label{display:block; margin:10px 0 6px; color:var(--spd-muted); font-weight:700}
.spdpro-form input[type="text"],
.spdpro-form input[type="email"],
.spdpro-form input[type="url"],
.spdpro-form input[type="number"],
.spdpro-form input[type="date"],
.spdpro-form input[type="datetime-local"],
.spdpro-form input[type="password"],
.spdpro-form select,
.spdpro-form textarea{
  width:100%;
  box-sizing:border-box;
  border-radius:var(--spd-radius-btn);
  border:1px solid var(--spd-input-border);
  background: var(--spd-input-bg);
  color: var(--spd-text);
  padding:10px 12px;
  outline:none;
}
.spdpro-form input:focus,
.spdpro-form select:focus,
.spdpro-form textarea:focus{
  border-color: color-mix(in srgb, var(--spd-primary) 70%, transparent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--spd-primary) 20%, transparent);
}
.spdpro-form input:focus, .spdpro-form select:focus, .spdpro-form textarea:focus{
  border-color: rgba(139,45,76,.8);
  box-shadow:0 0 0 3px rgba(139,45,76,.18);
}
.spdpro-form textarea{resize:vertical}

.spdpro-row{display:flex; gap:12px; align-items:center}
.spdpro-row > *{flex:1; min-width:0}
@media (max-width: 1024px){ .spdpro-row{flex-direction:column; align-items:stretch} }

.spdpro-check{display:flex; align-items:center; gap:8px; cursor:pointer; user-select:none}
.spdpro-check input{width:16px; height:16px}

.spdpro-alert{
  padding:10px 12px;
  border-radius:var(--spd-radius-btn);
  border:1px solid var(--spd-border);
  background: var(--spd-soft);
  margin:10px 0;
}
.spdpro-alert.error{border-color:rgba(239,68,68,.6); background:rgba(239,68,68,.10)}
.spdpro-alert.success{border-color:rgba(34,197,94,.6); background:rgba(34,197,94,.10)}
.spdpro-alert.warning{border-color:rgba(245,158,11,.6); background:rgba(245,158,11,.10)}

.spdpro-table-wrap{overflow:auto; border-radius:var(--spd-radius); border:1px solid var(--spd-border); max-width:100%; -webkit-overflow-scrolling:touch}
.spdpro-table{width:100%; border-collapse:collapse; min-width: 900px}
.spdpro-table thead th{
  position:sticky; top:0;
  background: var(--spd-table-head-bg);
  color: var(--spd-table-head-text);
  text-align:start;
  font-size:12px;
  letter-spacing:.4px;
  text-transform:uppercase;
  padding:12px 10px;
}
.spdpro-table tbody td{
  padding:12px 10px;
  border-top:1px solid var(--spd-divider);
  vertical-align:top;
}
.spdpro-table tbody tr:hover{background:color-mix(in srgb, var(--spd-text) 6%, transparent)}
.spdpro-empty{color:var(--spd-muted); padding:18px !important; text-align:center}

.spdpro-badge{
  display:inline-flex; align-items:center; justify-content:center;
  padding:4px 10px;
  border-radius:999px;
  border:1px solid color-mix(in srgb, var(--spd-text) 14%, transparent);
  background:var(--spd-soft);
  font-size:12px;
  font-weight:900;
}
.spdpro-badge.danger{border-color:rgba(239,68,68,.6); background:rgba(239,68,68,.12)}
.spdpro-badge.warning{border-color:rgba(245,158,11,.6); background:rgba(245,158,11,.12)}
.spdpro-note-cell{max-width:220px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}

.spdpro-pagination{
  display:flex; justify-content:space-between; align-items:center; gap:12px;
  margin-top:12px;
  color:var(--spd-muted);
}
.spdpro-pages{display:flex; gap:6px; flex-wrap:wrap}
.spdpro-page{
  display:inline-flex; padding:6px 10px; border-radius:var(--spd-radius-sm);
  border:1px solid var(--spd-border);
  text-decoration:none; color:var(--spd-muted);
}
.spdpro-page.active{background:rgba(255,255,255,.06); color:var(--spd-text); border-color:rgba(255,255,255,.18)}

.spdpro-bulkbar{
  display:flex; flex-wrap:wrap; gap:10px; align-items:center;
  padding:10px 0 14px;
}
.spdpro-bulkbar select{max-width:220px}
.spdpro-filters{
  display:flex; flex-wrap:wrap; gap:8px; align-items:center;
}
.spdpro-filters input, .spdpro-filters select{min-width:160px}

.spdpro-toasts{
  position:fixed;
  inset-inline-end:16px;
  inset-block-end:16px;
  display:flex;
  flex-direction:column;
  gap:10px;
  z-index:99999;
}
.spdpro-toast{
  max-width:360px;
  border:1px solid var(--spd-border);
  background: color-mix(in srgb, var(--spd-panel) 94%, transparent 6%);
  border-radius: var(--spd-radius);
  padding:12px 12px;
  box-shadow:0 14px 34px rgba(15,23,42,.14);
  color:var(--spd-text);
}
.spdpro-toast-title{font-weight:900; margin-bottom:4px; color:var(--spd-text)}
.spdpro-toast-msg{color:var(--spd-muted); line-height:1.4}
.spdpro-toast.success{border-color:rgba(34,197,94,.6)}
.spdpro-toast.error{border-color:rgba(239,68,68,.6)}

.spdpro-login-wrap{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px;
}
.spdpro-login-card{
  width: min(460px, 94vw);
  border-radius: 18px;
  border:1px solid var(--spd-border);
  background: linear-gradient(180deg, rgba(255,255,255,.03), transparent 40%), var(--spd-panel);
  padding:22px;
  box-shadow:0 25px 70px rgba(0,0,0,.35);
}
.spdpro-login-brand{text-align:center; margin-bottom:12px}
.spdpro-login-brand img{max-width:180px; height:auto}
.spdpro-login-title{font-weight:900; font-size:18px; margin-top:8px}
.spdpro-login-tagline{color:var(--spd-muted); margin-top:4px}
.spdpro-login-foot{margin-top:12px; text-align:center; color:var(--spd-muted)}
.spdpro-login-foot a{text-decoration:none}

.spdpro-wallets{display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:10px}
@media (max-width: 1024px){ .spdpro-wallets{grid-template-columns:1fr} }
.spdpro-wallet{
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
  border-radius:var(--spd-radius);
  padding:12px;
}
.spdpro-wallet-name{font-weight:900}
.spdpro-wallet-balance{font-size:18px; font-weight:900; margin-top:6px}

.spdpro-kv{display:grid; grid-template-columns: 1fr 1fr; gap:10px; margin-top:10px}
.spdpro-kv span{display:inline-block; min-width:140px; color:var(--spd-muted); font-weight:700}
@media (max-width: 1024px){ .spdpro-kv{grid-template-columns:1fr} }

.spdpro-timeline{margin-top:10px; display:flex; flex-direction:column; gap:10px}
.spdpro-timeline-item{display:flex; gap:10px; align-items:flex-start}
.spdpro-timeline-dot{width:10px; height:10px; border-radius:50%; background:var(--spd-primary); margin-top:6px; box-shadow:0 0 0 4px rgba(139,45,76,.18)}
.spdpro-timeline-body{flex:1}
.spdpro-timeline-text{font-weight:800}
.spdpro-timeline-meta{color:var(--spd-muted); font-size:12px; margin-top:4px}

.spdpro-prose{color:var(--spd-muted); line-height:1.7}
.spdpro-prose h1,.spdpro-prose h2,.spdpro-prose h3{color:var(--spd-text)}
.spdpro-prose ul{padding-inline-start:22px}
.spdpro-prose li{margin:6px 0}

.spdpro-map{border:1px solid rgba(255,255,255,.08); border-radius:var(--spd-radius); padding:12px; margin-top:12px; background:rgba(255,255,255,.03)}
.spdpro-map-title{font-weight:900; margin-bottom:10px}
.spdpro-map-grid{display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:10px}
@media (max-width: 1024px){ .spdpro-map-grid{grid-template-columns:1fr} }
.spdpro-map-item label{margin:0 0 6px}

.spdpro-actions-cell{white-space:nowrap}


@media print{
  body.spdpro-app{background:#fff !important; color:#000 !important}
  .spdpro-sidebar, .spdpro-topbar, .spdpro-footer, #spdpro-loader, .spdpro-toasts{display:none !important}
  .spdpro-card{box-shadow:none !important; background:#fff !important; border-color:#ddd !important; color:#000 !important}
  .spdpro-muted{color:#444 !important}
  .spdpro-table thead th{background:#f3f3f3 !important; color:#000 !important}
  .spdpro-btn{display:none !important}
}

/* Embed mode: keep navigation visible */
.spdpro-embed-mode .spdpro-topbar-menu{display:inline-flex}
.spdpro-embed-mode .spdpro-sidebar-toggle{display:inline-flex}
.spdpro-embed-mode .spdpro-sidebar{width:240px;flex:0 0 240px}

/* Sidebar menu colors */
.spdpro-sidebar{color: var(--spd-sidebar-text);}
.spdpro-sidebar .spdpro-nav-item{color: var(--spd-sidebar-text);}
.spdpro-sidebar .spdpro-nav-item:hover{background: var(--spd-sidebar-hover-bg); color: var(--spd-sidebar-hover-text);}
.spdpro-sidebar .spdpro-nav-item.active{background: var(--spd-sidebar-active-bg); color: var(--spd-sidebar-active-text); border-color: transparent;}


/* SPDPRO_ENFORCE_THEME_SURFACES */

/* Strongly link appearance settings (background/panel/text) to real UI surfaces */
.spdpro-shell,
.spdpro-main,
.spdpro-content{
  background: var(--spd-bg) !important;
  color: var(--spd-text) !important;
}
.spdpro-table,
.spdpro-table thead th{
  color: var(--spd-text) !important;
}
.spdpro-table thead th{
  background: var(--spd-th-bg) !important;
  color: var(--spd-th-text) !important;
}
.spdpro-card,
.spdpro-card-small,
.spdpro-card-big,
.spdpro-box,
.spdpro-panel,
.spdpro-form,
.spdpro-table-wrap{
  background: var(--spd-panel) !important;
  color: var(--spd-text) !important;
}

/* Enhanced dashboard cards / wallet filters / credential blocks */
.spdpro-stat-card{
  display:block;
  text-decoration:none;
  position:relative;
  overflow:hidden;
  cursor:pointer;
}
.spdpro-stat-card::after{
  content:"";
  position:absolute;
  inset-inline-start:0;
  inset-block:0;
  width:6px;
  background:var(--spdpro-stat-color, var(--spd-primary));
}
.spdpro-stat-card.is-total::after{background:var(--spd-primary)}
.spdpro-stat-card .spdpro-card-title,
.spdpro-stat-card .spdpro-card-big,
.spdpro-stat-card .spdpro-muted{position:relative; z-index:1}
.spdpro-stat-card:hover{transform:translateY(-2px)}
.spdpro-stat-grid .spdpro-card-big{margin-top:8px}

.spdpro-collection-badge{
  white-space:normal;
  line-height:1.35;
  justify-content:flex-start;
  text-align:start;
}

.spdpro-wallets-clickable .spdpro-wallet{
  display:block;
  text-decoration:none;
  color:var(--spd-text);
  border-color:var(--spd-border);
  transition:border-color .15s ease, transform .15s ease, box-shadow .15s ease;
}
.spdpro-wallets-clickable .spdpro-wallet:hover,
.spdpro-wallets-clickable .spdpro-wallet.active{
  border-color:color-mix(in srgb, var(--spd-primary) 60%, var(--spd-border) 40%);
  box-shadow:0 12px 24px rgba(15,23,42,.08);
  transform:translateY(-2px);
}
.spdpro-wallet-options{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:10px;
}
.spdpro-wallet-option{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border:1px solid var(--spd-border);
  border-radius:999px;
  background:var(--spd-soft);
  cursor:pointer;
}
.spdpro-wallet-option.active,
.spdpro-wallet-option:has(input:checked){
  border-color:color-mix(in srgb, var(--spd-primary) 60%, var(--spd-border) 40%);
  background:color-mix(in srgb, var(--spd-primary) 10%, var(--spd-panel) 90%);
}
.spdpro-wallet-option input{margin:0}

.spdpro-account-box{
  border-style:dashed;
}
.spdpro-account-box .spdpro-card-title{margin-bottom:6px}
.spdpro-account-box .spdpro-hint{margin-top:8px}

@supports not selector(:has(*)){
  .spdpro-wallet-option.active{border-color:color-mix(in srgb, var(--spd-primary) 60%, var(--spd-border) 40%); background:color-mix(in srgb, var(--spd-primary) 10%, var(--spd-panel) 90%)}
}
.spdpro-viewonly .spdpro-bulkbar,
.spdpro-viewonly .spdpro-row-check,
.spdpro-viewonly #spdpro-select-all{
  display:none !important;
}


/* v4.2.0 tailored UI upgrades */
.spdpro-stat-card{
  min-height:140px;
  background:var(--spdpro-stat-color, var(--spd-primary)) !important;
  color:#fff !important;
  border-color:transparent !important;
  box-shadow:0 18px 40px rgba(15,23,42,.12);
}
.spdpro-stat-card::after{display:none !important}
.spdpro-stat-card::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(135deg, rgba(255,255,255,.18), rgba(255,255,255,.04) 55%, rgba(0,0,0,.08));
  pointer-events:none;
}
.spdpro-stat-card .spdpro-card-title,
.spdpro-stat-card .spdpro-card-big,
.spdpro-stat-card .spdpro-muted{
  color:#fff !important;
}
.spdpro-stat-card .spdpro-muted{opacity:.95}
.spdpro-stat-grid .spdpro-card-big{font-size:clamp(28px, 2.6vw, 42px); font-weight:900}
.spdpro-stat-card:hover{transform:translateY(-4px); box-shadow:0 24px 48px rgba(15,23,42,.18)}

.spdpro-wallets-clickable .spdpro-wallet{
  color:#fff !important;
  border-color:transparent !important;
  box-shadow:0 14px 30px rgba(15,23,42,.10);
}
.spdpro-wallets-clickable .spdpro-wallet:nth-child(1){background:linear-gradient(135deg, #51122F, #7a1e48)}
.spdpro-wallets-clickable .spdpro-wallet:nth-child(2){background:linear-gradient(135deg, #2563eb, #1d4ed8)}
.spdpro-wallets-clickable .spdpro-wallet:nth-child(3){background:linear-gradient(135deg, #f59e0b, #d97706)}
.spdpro-wallets-clickable .spdpro-wallet:nth-child(4){background:linear-gradient(135deg, #22c55e, #16a34a)}
.spdpro-wallets-clickable .spdpro-wallet:nth-child(5){background:linear-gradient(135deg, #8b5cf6, #7c3aed)}
.spdpro-wallets-clickable .spdpro-wallet:nth-child(6){background:linear-gradient(135deg, #0ea5e9, #0284c7)}
.spdpro-wallets-clickable .spdpro-wallet .spdpro-badge{background:rgba(255,255,255,.18); color:#fff; border-color:rgba(255,255,255,.25)}
.spdpro-wallets-clickable .spdpro-wallet:hover,
.spdpro-wallets-clickable .spdpro-wallet.active{box-shadow:0 22px 42px rgba(15,23,42,.18); transform:translateY(-3px)}

.spdpro-smart-collect{display:flex; flex-wrap:wrap; gap:8px; margin:8px 0 10px}
.spdpro-smart-collect .spdpro-btn{border-style:dashed}
.spdpro-smart-collect .spdpro-btn.active,
.spdpro-smart-collect .spdpro-btn:hover{border-style:solid}

/* v4.3.0 live polish */
.spdpro-card-big{
  background:transparent !important;
  box-shadow:none !important;
}

.spdpro-stat-card{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.spdpro-stat-card .spdpro-card-title,
.spdpro-stat-card .spdpro-card-big,
.spdpro-stat-card .spdpro-muted{
  background:transparent !important;
}
.spdpro-stat-card .spdpro-card-big{
  line-height:1;
  padding:0;
  margin-top:0;
}
.spdpro-stat-card .spdpro-muted{
  margin-top:auto;
}

.spdpro-treasury-summary{
  margin-top:0;
}
.spdpro-treasury-mini-stats{
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:12px;
}
@media (max-width: 768px){
  .spdpro-treasury-mini-stats{grid-template-columns:1fr;}
}

/* v4.6.0 settings help, reset tools, and treasury polish */
.spdpro-settings-savebar{flex-wrap:wrap}
.spdpro-settings-savebar .spdpro-btn{white-space:nowrap}

.spdpro-help-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:22px;
  height:22px;
  margin-inline-start:8px;
  border-radius:999px;
  border:1px solid color-mix(in srgb, var(--spd-primary) 28%, var(--spd-border) 72%);
  background:color-mix(in srgb, var(--spd-primary) 10%, var(--spd-panel) 90%);
  color:var(--spd-primary);
  cursor:pointer;
  font-weight:900;
  font-size:12px;
  vertical-align:middle;
  transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.spdpro-help-icon:hover{
  transform:translateY(-1px);
  border-color:color-mix(in srgb, var(--spd-primary) 55%, var(--spd-border) 45%);
  box-shadow:0 10px 18px rgba(15,23,42,.08);
}
.spdpro-help-icon span{pointer-events:none; line-height:1}

.spdpro-help-modal{
  position:fixed;
  inset:0;
  z-index:10020;
  opacity:0;
  pointer-events:none;
  transition:opacity .18s ease;
}
.spdpro-help-modal.show{opacity:1; pointer-events:auto}
.spdpro-help-backdrop{
  position:absolute;
  inset:0;
  background:rgba(15,23,42,.46);
  backdrop-filter:blur(6px);
}
.spdpro-help-dialog{
  position:relative;
  width:min(540px, calc(100vw - 24px));
  margin:8vh auto 0;
  background:var(--spd-panel);
  color:var(--spd-text);
  border:1px solid var(--spd-border);
  border-radius:calc(var(--spd-radius) + 4px);
  box-shadow:0 30px 80px rgba(15,23,42,.28);
  padding:18px 18px 16px;
}
.spdpro-help-close{
  position:absolute;
  inset-inline-end:14px;
  inset-block-start:12px;
  width:34px;
  height:34px;
  border-radius:999px;
  border:1px solid var(--spd-border);
  background:var(--spd-soft);
  color:var(--spd-text);
  cursor:pointer;
  font-size:22px;
  line-height:1;
}
.spdpro-help-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 10px;
  border-radius:999px;
  background:color-mix(in srgb, var(--spd-primary) 10%, var(--spd-panel) 90%);
  color:var(--spd-primary);
  font-weight:800;
  margin-bottom:10px;
}
.spdpro-help-dialog h3{margin:0 42px 10px 0; font-size:20px; font-weight:900}
.spdpro-help-body{line-height:1.75; color:var(--spd-text)}
.spdpro-help-example{
  margin-top:14px;
  padding:12px 14px;
  border-radius:14px;
  background:color-mix(in srgb, var(--spd-primary) 8%, var(--spd-panel) 92%);
  border:1px dashed color-mix(in srgb, var(--spd-primary) 25%, var(--spd-border) 75%);
  color:var(--spd-muted);
  line-height:1.7;
}
.spdpro-help-example strong{color:var(--spd-text)}

.spdpro-codebox{
  margin-top:10px;
  padding:12px 14px;
  border-radius:14px;
  background:color-mix(in srgb, var(--spd-panel) 88%, var(--spd-primary) 12%);
  border:1px dashed color-mix(in srgb, var(--spd-primary) 20%, var(--spd-border) 80%);
  overflow:auto;
  white-space:pre-wrap;
  word-break:break-word;
  font-size:12px;
  line-height:1.7;
}

.spdpro-treasury-mini-stats{grid-template-columns:repeat(4, minmax(0,1fr))}
@media (max-width: 1100px){
  .spdpro-treasury-mini-stats{grid-template-columns:repeat(2, minmax(0,1fr))}
}
@media (max-width: 700px){
  .spdpro-treasury-mini-stats{grid-template-columns:1fr}
}

/* v4.7.0 production polish: contextual help, spacing, and responsive hardening */
.spdpro-topbar-left,
.spdpro-topbar-right{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  min-width:0;
}

.spdpro-topbar{
  padding:12px clamp(14px, 2vw, 22px);
}

.spdpro-page-title{
  font-size:clamp(16px, 1.5vw, 21px);
  line-height:1.35;
  word-break:break-word;
}

.spdpro-content{
  padding:clamp(14px, 2vw, 24px);
}

.spdpro-card,
.spdpro-table-wrap,
.spdpro-form{
  border-radius:calc(var(--spd-radius) + 2px);
}

.spdpro-card{
  padding:clamp(14px, 1.6vw, 20px);
}

.spdpro-card-title{
  line-height:1.4;
}

.spdpro-card-head{
  flex-wrap:wrap;
  align-items:flex-start;
}

.spdpro-grid.spdpro-stat-grid{
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:16px;
}

.spdpro-stat-card{
  min-height:164px;
  padding:18px !important;
  border:1px solid rgba(255,255,255,.16) !important;
  isolation:isolate;
}

.spdpro-stat-card::before{
  background:
    radial-gradient(circle at 100% 0%, rgba(255,255,255,.18), transparent 42%),
    linear-gradient(135deg, rgba(255,255,255,.14), rgba(255,255,255,.05) 52%, rgba(0,0,0,.08));
}

.spdpro-stat-card .spdpro-card-title{
  font-size:14px;
  font-weight:800;
}

.spdpro-stat-card .spdpro-card-big{
  font-size:clamp(30px, 3vw, 46px) !important;
  font-weight:900;
  line-height:1;
}

.spdpro-stat-card .spdpro-muted{
  font-size:13px;
  line-height:1.5;
}

.spdpro-settings-form .spdpro-grid-2{
  align-items:start;
}

.spdpro-settings-form .spdpro-tab-panel > h3{
  margin:4px 0 14px;
  font-size:clamp(18px, 1.4vw, 22px);
  line-height:1.35;
}

.spdpro-settings-form label:not(.spdpro-check){
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}

.spdpro-settings-form .spdpro-check{
  align-items:flex-start;
}

.spdpro-settings-form .spdpro-check > span:last-child,
.spdpro-settings-form .spdpro-check span:last-child{
  line-height:1.5;
}

.spdpro-settings-form input[type="text"],
.spdpro-settings-form input[type="email"],
.spdpro-settings-form input[type="url"],
.spdpro-settings-form input[type="number"],
.spdpro-settings-form input[type="date"],
.spdpro-settings-form input[type="datetime-local"],
.spdpro-settings-form input[type="password"],
.spdpro-settings-form select{
  min-height:44px;
}

.spdpro-settings-form textarea{
  min-height:112px;
}

.spdpro-help-meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:10px;
}

.spdpro-help-section{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 10px;
  border-radius:999px;
  background:color-mix(in srgb, var(--spd-panel) 82%, var(--spd-primary) 18%);
  border:1px solid color-mix(in srgb, var(--spd-primary) 16%, var(--spd-border) 84%);
  color:var(--spd-text);
  font-weight:800;
}

.spdpro-help-dialog{
  width:min(620px, calc(100vw - 28px));
  max-height:min(84vh, 760px);
  overflow:auto;
  padding:20px 20px 18px;
}

.spdpro-help-dialog h3{
  margin:0 52px 12px 0;
  line-height:1.4;
}

html[dir="rtl"] .spdpro-help-dialog h3{
  margin:0 0 12px 52px;
}

.spdpro-help-close{
  z-index:2;
}

.spdpro-help-body{
  line-height:1.85;
  font-size:15px;
}

.spdpro-help-example{
  margin-top:16px;
}

.spdpro-field-help-inline{
  display:flex;
  justify-content:flex-end;
  margin-top:8px;
}

.spdpro-help-icon-inline{
  width:20px;
  height:20px;
  margin-inline-start:0;
  font-size:11px;
  border-style:dashed;
}

.spdpro-table td .spdpro-field-help-inline,
.spdpro-table th .spdpro-field-help-inline{
  justify-content:flex-start;
}

@media (max-width: 1024px){
  .spdpro-settings-form .spdpro-grid-2{
    grid-template-columns:1fr;
  }
}

@media (max-width: 768px){
  .spdpro-grid.spdpro-stat-grid{
    grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));
    gap:14px;
  }

  .spdpro-stat-card{
    min-height:148px;
  }

  .spdpro-help-dialog{
    margin:4vh auto 0;
    width:min(100vw - 20px, 620px);
    max-height:min(88vh, 800px);
    padding:18px 16px 16px;
  }

  .spdpro-help-dialog h3{
    margin-inline-end:42px;
    margin-inline-start:0;
    font-size:19px;
  }
}

@media (max-width: 560px){
  .spdpro-topbar-right{
    justify-content:flex-start;
  }

  .spdpro-grid.spdpro-stat-grid{
    grid-template-columns:1fr;
  }

  .spdpro-stat-card{
    min-height:140px;
  }

  .spdpro-card,
  .spdpro-table-wrap,
  .spdpro-form{
    padding:14px;
  }

  .spdpro-settings-savebar{
    padding:12px;
  }

  .spdpro-help-meta{
    align-items:flex-start;
  }

  .spdpro-help-section{
    font-size:12px;
  }
}

/* v4.8.0 final settings polish: only contextual help, cleaner spacing, stronger responsive layout */
.spdpro-tabs{
  gap:10px;
  padding-bottom:4px;
}

.spdpro-tab-btn{
  min-height:42px;
  white-space:nowrap;
  font-weight:800;
}

.spdpro-settings-form .spdpro-grid-2{
  gap:clamp(16px, 2vw, 24px);
}

.spdpro-settings-form .spdpro-grid-2 > div,
.spdpro-settings-form .spdpro-row > *{
  min-width:0;
}

.spdpro-settings-form .spdpro-card-title{
  margin:4px 0 10px;
  line-height:1.45;
}

.spdpro-settings-form .spdpro-hint,
.spdpro-settings-form .spdpro-alert{
  line-height:1.75;
}

.spdpro-settings-form input[type="color"]{
  width:100%;
  min-height:46px;
  padding:6px;
  border-radius:var(--spd-radius-btn);
  border:1px solid var(--spd-input-border);
  background:var(--spd-input-bg);
  cursor:pointer;
}

.spdpro-settings-form input[readonly]{
  background:color-mix(in srgb, var(--spd-panel) 86%, var(--spd-primary) 14%);
}

.spdpro-settings-form .spdpro-row{
  gap:10px;
  align-items:stretch;
}

.spdpro-settings-form .spdpro-row .spdpro-btn{
  min-height:44px;
}

.spdpro-help-icon{
  flex:0 0 auto;
}

.spdpro-help-dialog{
  border-radius:24px;
}

.spdpro-help-dialog::before{
  content:'';
  position:absolute;
  inset-block:14px 14px;
  inset-inline-start:0;
  width:4px;
  border-radius:0 999px 999px 0;
  background:linear-gradient(180deg, var(--spd-primary), color-mix(in srgb, var(--spd-primary) 35%, #ffffff 65%));
  opacity:.9;
}

html[dir="rtl"] .spdpro-help-dialog::before{
  inset-inline-start:auto;
  inset-inline-end:0;
  border-radius:999px 0 0 999px;
}

.spdpro-help-body,
.spdpro-help-example{
  word-break:break-word;
}

@media (max-width: 760px){
  .spdpro-tabs{
    flex-wrap:nowrap;
    overflow-x:auto;
    overscroll-behavior-x:contain;
    scroll-snap-type:x proximity;
    -webkit-overflow-scrolling:touch;
    margin-inline:-4px;
    padding-inline:4px;
  }

  .spdpro-tab-btn{
    flex:0 0 auto;
    scroll-snap-align:start;
  }

  .spdpro-settings-savebar .spdpro-actions{
    width:100%;
  }

  .spdpro-settings-savebar .spdpro-muted{
    margin-inline-start:0 !important;
  }

  .spdpro-help-dialog{
    border-radius:20px;
  }
}
