:root {
  --cp-saas-surface: rgba(255, 255, 255, 0.94);
  --cp-saas-surface-2: rgba(248, 250, 252, 0.96);
  --cp-saas-stroke: rgba(148, 163, 184, 0.35);
  --cp-saas-text: #0f172a;
  --cp-saas-muted: #475569;
  --cp-saas-primary: #0b57d0;
  --cp-saas-primary-2: #1d4ed8;
  --cp-saas-primary-soft: rgba(29, 78, 216, 0.1);
  --cp-saas-danger: #b91c1c;
  --cp-saas-danger-bg: #fff1f2;
  --cp-saas-danger-stroke: rgba(239, 68, 68, 0.32);
  --cp-saas-success: #15803d;
  --cp-saas-success-bg: #f0fdf4;
  --cp-saas-success-stroke: rgba(34, 197, 94, 0.3);
  --cp-saas-info: #1d4ed8;
  --cp-saas-info-bg: #eff6ff;
  --cp-saas-info-stroke: rgba(59, 130, 246, 0.26);
  --cp-saas-shadow: 0 28px 62px rgba(2, 6, 23, 0.34);
}

body.dark-mode {
  --cp-saas-surface: rgba(15, 23, 42, 0.9);
  --cp-saas-surface-2: rgba(15, 23, 42, 0.96);
  --cp-saas-stroke: rgba(148, 163, 184, 0.28);
  --cp-saas-text: #e2e8f0;
  --cp-saas-muted: #cbd5e1;
  --cp-saas-primary: #60a5fa;
  --cp-saas-primary-2: #2563eb;
  --cp-saas-primary-soft: rgba(96, 165, 250, 0.16);
  --cp-saas-danger: #fca5a5;
  --cp-saas-danger-bg: rgba(127, 29, 29, 0.3);
  --cp-saas-danger-stroke: rgba(248, 113, 113, 0.34);
  --cp-saas-success: #86efac;
  --cp-saas-success-bg: rgba(20, 83, 45, 0.34);
  --cp-saas-success-stroke: rgba(74, 222, 128, 0.32);
  --cp-saas-info: #93c5fd;
  --cp-saas-info-bg: rgba(30, 64, 175, 0.3);
  --cp-saas-info-stroke: rgba(96, 165, 250, 0.3);
  --cp-saas-shadow: 0 28px 66px rgba(0, 0, 0, 0.55);
}

.cp-saas-auth-entry,
.cp-saas-modal,
.cp-saas-drawer,
.cp-saas-auth-entry * ,
.cp-saas-modal * ,
.cp-saas-drawer * {
  box-sizing: border-box;
}

.cp-saas-auth-entry {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex: 0 0 auto;
  flex-shrink: 0;
  min-width: 0;
}

.cp-saas-runtime-toast {
  position: fixed;
  top: 20px;
  left: 50%;
  transform: translate(-50%, -18px);
  min-width: min(92vw, 320px);
  max-width: min(92vw, 560px);
  padding: 14px 18px;
  border-radius: 16px;
  border: 1px solid var(--cp-saas-stroke);
  background: var(--cp-saas-surface);
  color: var(--cp-saas-text);
  box-shadow: var(--cp-saas-shadow);
  font-size: 0.94rem;
  font-weight: 700;
  text-align: center;
  opacity: 0;
  pointer-events: none;
  z-index: 32000;
  transition: opacity .22s ease, transform .22s ease;
}

.cp-saas-runtime-toast.is-visible {
  opacity: 1;
  transform: translate(-50%, 0);
}

.cp-saas-runtime-toast.is-success {
  border-color: var(--cp-saas-success-stroke);
  background: linear-gradient(180deg, var(--cp-saas-success-bg), var(--cp-saas-surface));
  color: var(--cp-saas-success);
}

.cp-saas-runtime-toast.is-error {
  border-color: var(--cp-saas-danger-stroke);
  background: linear-gradient(180deg, var(--cp-saas-danger-bg), var(--cp-saas-surface));
  color: var(--cp-saas-danger);
}

.cp-saas-auth-cta {
  border: 0;
  border-radius: 999px;
  padding: 10px 18px;
  min-height: 40px;
  min-width: 96px;
  font-size: 0.92rem;
  font-weight: 700;
  color: #fff;
  background: linear-gradient(135deg, var(--cp-saas-primary), var(--cp-saas-primary-2));
  box-shadow: 0 10px 24px rgba(29, 78, 216, 0.35);
  cursor: pointer;
  transition: transform .16s ease, box-shadow .16s ease, filter .16s ease;
}

.cp-saas-auth-cta:hover {
  transform: translateY(-1px);
  box-shadow: 0 14px 26px rgba(29, 78, 216, 0.4);
  filter: brightness(1.03);
}

.cp-saas-auth-cta:active {
  transform: translateY(0);
}

.cp-saas-profile-wrap {
  display: none;
  align-items: center;
  gap: 8px;
}

.cp-saas-profile-wrap.is-visible {
  display: inline-flex;
}

.cp-saas-icon-btn,
.cp-saas-avatar-btn {
  width: 40px;
  height: 40px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: transform .15s ease, border-color .15s ease, background-color .15s ease;
}

.cp-saas-icon-btn {
  border: 1px solid var(--cp-saas-stroke);
  background: var(--cp-saas-surface);
  color: var(--cp-saas-text);
}

.cp-saas-avatar-btn {
  border: 1px solid var(--cp-saas-stroke);
  color: #fff;
  font-weight: 800;
  background: linear-gradient(135deg, #111827, #1e293b);
  overflow: hidden;
}

body.dark-mode .cp-saas-avatar-btn {
  background: linear-gradient(135deg, #0f172a, #334155);
}

.cp-saas-avatar-btn img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.cp-saas-icon-btn:hover,
.cp-saas-avatar-btn:hover {
  transform: translateY(-1px);
}

.cp-saas-modal,
.cp-saas-drawer {
  position: fixed;
  inset: 0;
  z-index: 30000;
  display: none;
}

.cp-saas-modal.is-open,
.cp-saas-drawer.is-open {
  display: block;
}

.cp-saas-modal-backdrop,
.cp-saas-drawer-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(2, 6, 23, 0.56);
}

.cp-saas-modal-card {
  position: relative;
  width: min(94vw, 560px);
  max-height: min(88vh, 880px);
  margin: 4.5vh auto 0;
  border-radius: 18px;
  border: 1px solid var(--cp-saas-stroke);
  background: var(--cp-saas-surface);
  color: var(--cp-saas-text);
  box-shadow: var(--cp-saas-shadow);
  backdrop-filter: blur(14px);
  overflow: auto;
  padding: 22px;
}

.cp-saas-upgrade-modal .cp-saas-modal-card {
  width: min(95vw, 740px);
}

.cp-saas-user-modal-card {
  width: min(96vw, 760px);
}

.cp-saas-user-card-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}

.cp-saas-user-actions {
  margin-top: 10px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.cp-saas-user-actions .cp-saas-submit,
.cp-saas-user-actions .cp-saas-link-btn {
  min-height: 40px;
}

.cp-saas-user-modal-card .cp-saas-orders-board {
  margin-top: 4px;
}

.cp-saas-user-modal-card .cp-saas-orders-table {
  min-width: 560px;
}

.cp-saas-modal-close {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  border: 1px solid var(--cp-saas-stroke);
  background: transparent;
  color: var(--cp-saas-muted);
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
}

.cp-saas-modal-head {
  display: grid;
  gap: 5px;
  margin: 0 30px 14px 0;
}

.cp-saas-modal-head h3 {
  margin: 0;
  font-size: 1.16rem;
  line-height: 1.25;
  color: var(--cp-saas-text);
}

.cp-saas-subtitle,
.cp-saas-upgrade-modal .cp-saas-modal-card > p:not(.cp-saas-msg) {
  margin: 4px 0 16px;
  font-size: 0.9rem;
  line-height: 1.45;
  color: var(--cp-saas-muted);
}

.cp-saas-auth-tabs {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin: 0 0 14px;
}

.cp-saas-auth-tab {
  border: 1px solid var(--cp-saas-stroke);
  border-radius: 11px;
  background: var(--cp-saas-surface-2);
  color: var(--cp-saas-text);
  padding: 10px 12px;
  font-weight: 700;
  cursor: pointer;
}

.cp-saas-auth-tab.is-active {
  border-color: color-mix(in srgb, var(--cp-saas-primary) 60%, #ffffff 40%);
  background: color-mix(in srgb, var(--cp-saas-primary) 14%, transparent);
  color: var(--cp-saas-primary);
}

.cp-saas-auth-panel {
  display: none;
}

.cp-saas-auth-panel.is-active {
  display: block;
}

.cp-saas-form {
  display: grid;
  gap: 10px;
  min-width: 0;
}

.cp-saas-form-grid {
  grid-template-columns: 1fr;
}

@media (min-width: 640px) {
  .cp-saas-form-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: 10px;
  }

  .cp-saas-form-grid .cp-saas-submit,
  .cp-saas-form-grid .cp-saas-auth-note,
  .cp-saas-form-grid .cp-saas-msg {
    grid-column: 1 / -1;
  }
}

.cp-saas-field {
  margin: 0;
  min-width: 0;
}

.cp-saas-field label {
  display: block;
  margin: 0 0 6px;
  font-size: 0.84rem;
  font-weight: 700;
  color: var(--cp-saas-muted);
}

.cp-saas-field input {
  width: 100%;
  min-width: 0;
  min-height: 42px;
  border-radius: 10px;
  border: 1px solid var(--cp-saas-stroke);
  background: color-mix(in srgb, var(--cp-saas-surface) 88%, #ffffff 12%);
  color: var(--cp-saas-text);
  padding: 10px 12px;
}

body.dark-mode .cp-saas-field input {
  background: rgba(15, 23, 42, 0.6);
}

.cp-saas-field input::placeholder {
  color: color-mix(in srgb, var(--cp-saas-muted) 70%, transparent);
}

.cp-saas-field-help {
  display: inline-block;
  margin-top: 5px;
  font-size: 0.75rem;
  color: var(--cp-saas-muted);
}

.cp-saas-auth-note {
  width: 100%;
  min-width: 0;
  margin: 2px 0 0;
  padding: 12px 14px;
  border: 1px solid var(--cp-saas-info-stroke);
  border-radius: 12px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--cp-saas-primary-soft) 85%, #ffffff 15%), var(--cp-saas-info-bg));
  color: var(--cp-saas-text);
  font-size: 0.82rem;
  line-height: 1.5;
  overflow-wrap: anywhere;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.35);
}

.cp-saas-submit {
  width: 100%;
  min-height: 42px;
  border: 0;
  border-radius: 10px;
  background: linear-gradient(135deg, var(--cp-saas-primary), var(--cp-saas-primary-2));
  color: #fff;
  font-weight: 700;
  cursor: pointer;
}

.cp-saas-submit.is-busy {
  opacity: 0.88;
  filter: saturate(0.94);
}

.cp-saas-submit[disabled] {
  opacity: .65;
  cursor: not-allowed;
}

.cp-saas-google {
  margin-top: 8px;
  width: 100%;
  min-height: 40px;
  border-radius: 10px;
  border: 1px solid var(--cp-saas-stroke);
  background: var(--cp-saas-surface-2);
  color: var(--cp-saas-text);
  font-weight: 700;
  cursor: pointer;
}

.cp-saas-link-btn {
  margin-top: 8px;
  min-height: 40px;
  border-radius: 10px;
  border: 1px solid var(--cp-saas-stroke);
  background: var(--cp-saas-surface-2);
  color: var(--cp-saas-text);
  font-weight: 700;
  cursor: pointer;
  padding: 0 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}

.cp-saas-link-btn[hidden] {
  display: none !important;
}

.cp-saas-auth-actions {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
}

.cp-saas-auth-actions .cp-saas-link-btn {
  margin-top: 0;
  width: 100%;
}

.cp-saas-register-secondary {
  margin-top: 0;
  width: 100%;
}

.cp-saas-link-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(2, 6, 23, 0.18);
}

.cp-saas-link-btn.is-danger {
  border-color: color-mix(in srgb, var(--cp-saas-danger) 45%, var(--cp-saas-stroke));
  background: color-mix(in srgb, var(--cp-saas-danger) 10%, var(--cp-saas-surface-2));
  color: var(--cp-saas-danger);
}

.cp-saas-btn-refresh {
  margin-top: 0;
  min-height: 34px;
  font-size: .82rem;
  padding: 0 10px;
}

.cp-saas-msg {
  display: block;
  width: 100%;
  min-width: 0;
  margin: 8px 0 0;
  padding: 11px 13px;
  border: 1px solid var(--cp-saas-info-stroke);
  border-left: 4px solid var(--cp-saas-info);
  border-radius: 12px;
  background: var(--cp-saas-info-bg);
  color: var(--cp-saas-text);
  font-size: 0.84rem;
  line-height: 1.5;
  overflow-wrap: anywhere;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

.cp-saas-msg:empty {
  display: none;
}

.cp-saas-msg.is-error {
  border-color: var(--cp-saas-danger-stroke);
  border-left-color: var(--cp-saas-danger);
  background: var(--cp-saas-danger-bg);
  color: var(--cp-saas-danger);
}

.cp-saas-msg.is-success {
  border-color: var(--cp-saas-success-stroke);
  border-left-color: var(--cp-saas-success);
  background: var(--cp-saas-success-bg);
  color: var(--cp-saas-success);
}

body.dark-mode .cp-saas-auth-note,
body.dark-mode .cp-saas-msg {
  box-shadow: none;
}

.cp-saas-drawer-panel {
  position: absolute;
  top: 0;
  right: 0;
  height: 100%;
  width: min(96vw, 440px);
  display: grid;
  gap: 12px;
  align-content: start;
  background: var(--cp-saas-surface-2);
  color: var(--cp-saas-text);
  backdrop-filter: blur(15px);
  border-left: 1px solid var(--cp-saas-stroke);
  box-shadow: -22px 0 54px rgba(2, 6, 23, 0.32);
  overflow: auto;
  padding: 16px;
}

.cp-saas-drawer-top {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 10px;
  align-items: center;
}

.cp-saas-user-meta {
  min-width: 0;
}

.cp-saas-user-meta strong,
.cp-saas-user-meta small {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.cp-saas-avatar-lg {
  width: 56px;
  height: 56px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-weight: 800;
  background: linear-gradient(135deg, #0f172a, #334155);
  overflow: hidden;
}

.cp-saas-avatar-lg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.cp-saas-drawer-close {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  border: 1px solid var(--cp-saas-stroke);
  background: transparent;
  color: var(--cp-saas-muted);
  font-size: 20px;
  cursor: pointer;
}

.cp-saas-plan-tag {
  margin-top: 6px;
  display: inline-flex;
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 0.74rem;
  font-weight: 700;
  color: var(--cp-saas-primary);
  background: color-mix(in srgb, var(--cp-saas-primary) 18%, transparent);
}

.cp-saas-section {
  border: 1px solid var(--cp-saas-stroke);
  border-radius: 12px;
  background: var(--cp-saas-surface);
  overflow: hidden;
}

.cp-saas-section h4 {
  margin: 0;
  padding: 10px 12px;
  border-bottom: 1px solid var(--cp-saas-stroke);
  font-size: 0.84rem;
  letter-spacing: .02em;
  text-transform: uppercase;
  color: var(--cp-saas-muted);
}

.cp-saas-nav-btn {
  display: flex;
  width: 100%;
  text-align: left;
  border: 0;
  border-top: 1px solid color-mix(in srgb, var(--cp-saas-stroke) 70%, transparent);
  background: transparent;
  padding: 10px 12px;
  font-weight: 600;
  color: var(--cp-saas-text);
  cursor: pointer;
}

.cp-saas-nav-btn:first-of-type {
  border-top: 0;
}

.cp-saas-nav-btn:hover {
  background: color-mix(in srgb, var(--cp-saas-primary) 11%, transparent);
}

.cp-saas-panel {
  border: 1px solid var(--cp-saas-stroke);
  border-radius: 12px;
  background: var(--cp-saas-surface);
  padding: 12px;
  color: var(--cp-saas-text);
}

.cp-saas-panel h5 {
  margin: 0 0 8px;
  font-size: .98rem;
}

.cp-saas-panel p {
  margin: 0 0 6px;
  font-size: .9rem;
  line-height: 1.45;
  color: var(--cp-saas-muted);
}

.cp-saas-balance-summary {
  border: 1px solid color-mix(in srgb, var(--cp-saas-primary) 26%, var(--cp-saas-stroke) 74%);
  border-radius: 12px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--cp-saas-primary) 10%, transparent), transparent),
    var(--cp-saas-surface);
  box-shadow: 0 12px 24px rgba(15, 23, 42, 0.14);
  padding: 10px 12px;
  display: grid;
  gap: 2px;
}

.cp-saas-balance-summary p {
  margin: 0;
  line-height: 1.35;
}

.cp-saas-balance-summary p strong {
  font-size: 0.8rem;
  color: var(--cp-saas-muted);
  letter-spacing: 0.01em;
  text-transform: uppercase;
}

.cp-saas-balance-summary p:last-child {
  font-size: 1rem;
  color: var(--cp-saas-text);
  font-weight: 800;
}

.cp-saas-session-list {
  margin: 8px 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 7px;
}

.cp-saas-session-list li {
  margin: 0;
  border: 1px solid color-mix(in srgb, var(--cp-saas-stroke) 80%, transparent);
  border-radius: 10px;
  background: color-mix(in srgb, var(--cp-saas-surface-2) 92%, transparent);
  color: var(--cp-saas-text);
  padding: 8px 10px;
  font-size: .84rem;
  line-height: 1.35;
}

body.dark-mode .cp-saas-balance-summary {
  border-color: color-mix(in srgb, var(--cp-saas-primary) 38%, var(--cp-saas-stroke) 62%);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--cp-saas-primary) 16%, transparent), transparent),
    color-mix(in srgb, var(--cp-saas-surface) 92%, #020617 8%);
  box-shadow: 0 14px 28px rgba(2, 6, 23, 0.42);
}

body.dark-mode .cp-saas-session-list li {
  border-color: color-mix(in srgb, var(--cp-saas-stroke) 72%, transparent);
  background: color-mix(in srgb, var(--cp-saas-surface-2) 88%, #020617 12%);
}

.cp-saas-plan-active-actions {
  margin: 8px 0 2px;
  display: flex;
  justify-content: flex-start;
}

.cp-saas-inline-note {
  margin: 8px 0 6px;
  border: 1px solid color-mix(in srgb, var(--cp-saas-primary) 38%, #ffffff 62%);
  border-radius: 10px;
  padding: 8px 10px;
  color: var(--cp-saas-text) !important;
  background: color-mix(in srgb, var(--cp-saas-primary) 12%, transparent);
}

.cp-saas-orders-board {
  margin-top: 12px;
  border: 1px solid color-mix(in srgb, var(--cp-saas-stroke) 82%, transparent);
  border-radius: 12px;
  background: color-mix(in srgb, var(--cp-saas-surface-2) 92%, transparent);
  padding: 10px;
}

.cp-saas-orders-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 8px;
}

.cp-saas-orders-head h6 {
  margin: 0;
  font-size: .92rem;
  color: var(--cp-saas-text);
}

.cp-saas-orders-kpis {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 9px;
}

.cp-saas-orders-kpi {
  border: 1px solid color-mix(in srgb, var(--cp-saas-stroke) 80%, transparent);
  border-radius: 10px;
  background: color-mix(in srgb, var(--cp-saas-surface) 92%, transparent);
  padding: 7px 9px;
  display: grid;
  gap: 2px;
}

.cp-saas-orders-kpi span {
  font-size: .74rem;
  color: var(--cp-saas-muted);
}

.cp-saas-orders-kpi strong {
  font-size: .95rem;
  color: var(--cp-saas-text);
}

.cp-saas-orders-table-wrap {
  overflow: auto;
  border: 1px solid color-mix(in srgb, var(--cp-saas-stroke) 80%, transparent);
  border-radius: 10px;
}

.cp-saas-orders-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 620px;
}

.cp-saas-orders-table th,
.cp-saas-orders-table td {
  padding: 8px 10px;
  border-bottom: 1px solid color-mix(in srgb, var(--cp-saas-stroke) 75%, transparent);
  text-align: left;
  font-size: .82rem;
}

.cp-saas-orders-table th {
  font-size: .74rem;
  color: var(--cp-saas-muted);
  text-transform: uppercase;
  letter-spacing: .02em;
  background: color-mix(in srgb, var(--cp-saas-surface) 90%, transparent);
}

.cp-saas-order-status-cell {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.cp-saas-order-status-text {
  font-weight: 600;
  color: var(--cp-saas-text);
}

.cp-saas-order-recover-btn {
  padding: 2px 6px;
  min-height: 24px;
  font-size: .72rem;
  border-radius: 7px;
}

.cp-saas-order-recover-btn.is-disabled,
.cp-saas-order-recover-btn[disabled] {
  background: color-mix(in srgb, #9ca3af 18%, transparent);
  color: color-mix(in srgb, var(--cp-saas-muted) 88%, #111827 12%);
  border-color: color-mix(in srgb, #9ca3af 50%, transparent);
  cursor: not-allowed;
  opacity: .9;
}

@media (max-width: 540px) {
  .cp-saas-orders-kpis {
    grid-template-columns: 1fr;
  }
}

@media (min-width: 720px) {
  .cp-saas-user-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.cp-saas-danger-zone {
  margin-top: 10px;
  border: 1px solid color-mix(in srgb, #ef4444 44%, #ffffff 56%);
  border-radius: 12px;
  padding: 10px;
  display: grid;
  gap: 7px;
  background: color-mix(in srgb, #ef4444 8%, var(--cp-saas-surface));
}

.cp-saas-danger-zone h6 {
  margin: 0;
  font-size: .88rem;
  color: color-mix(in srgb, #b91c1c 74%, var(--cp-saas-text) 26%);
}

.cp-saas-danger-zone p {
  margin: 0;
}

.cp-saas-danger-zone input {
  min-height: 38px;
  border: 1px solid color-mix(in srgb, #ef4444 44%, #ffffff 56%);
  border-radius: 10px;
  background: var(--cp-saas-surface);
  color: var(--cp-saas-text);
  padding: 0 10px;
}

body.dark-mode .cp-saas-inline-note {
  border-color: color-mix(in srgb, var(--cp-saas-primary) 58%, #0f172a 42%);
  background: color-mix(in srgb, var(--cp-saas-primary) 18%, #0f172a 82%);
}

body.dark-mode .cp-saas-danger-zone {
  border-color: color-mix(in srgb, #ef4444 52%, #0f172a 48%);
  background: color-mix(in srgb, #7f1d1d 26%, #0f172a 74%);
}

body.dark-mode .cp-saas-danger-zone h6 {
  color: #fecaca;
}

body.dark-mode .cp-saas-danger-zone input {
  border-color: color-mix(in srgb, #ef4444 62%, #0f172a 38%);
}

.cp-saas-admin-toolbar {
  display: grid;
  grid-template-columns: 1fr auto auto auto;
  gap: 8px;
  margin: 10px 0 8px;
}

.cp-saas-admin-toolbar input {
  min-width: 0;
  min-height: 40px;
  border: 1px solid var(--cp-saas-stroke);
  border-radius: 10px;
  background: var(--cp-saas-surface);
  color: var(--cp-saas-text);
  padding: 0 12px;
}

.cp-saas-admin-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 10px;
}

.cp-saas-admin-list,
.cp-saas-admin-detail {
  display: grid;
  gap: 8px;
}

.cp-admin-users-layout-v3 {
  display: grid;
  grid-template-columns: minmax(300px, 0.95fr) minmax(0, 1.35fr);
  gap: 12px;
  align-items: start;
}

.cp-admin-users-list-v3 {
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-height: 520px;
  overflow: auto;
  padding-right: 3px;
}

.cp-admin-user-row-v3 {
  display: block;
  flex: 0 0 auto;
  width: 100%;
  text-align: left;
  line-height: 1.3;
  white-space: normal;
  border: 1px solid color-mix(in srgb, var(--cp-saas-stroke) 90%, transparent);
  border-radius: 12px;
  background: color-mix(in srgb, var(--cp-saas-surface) 94%, transparent);
  color: var(--cp-saas-text);
  padding: 12px;
  cursor: pointer;
  transition: border-color .14s ease, transform .14s ease, background-color .14s ease;
}

.cp-admin-user-row-v3:hover {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--cp-saas-primary) 45%, var(--cp-saas-stroke));
}

.cp-admin-user-row-v3.is-active {
  border-color: color-mix(in srgb, var(--cp-saas-primary) 60%, #ffffff 40%);
  background: color-mix(in srgb, var(--cp-saas-primary) 10%, transparent);
}

.cp-admin-user-row-v3__head {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.cp-admin-user-row-v3__head strong,
.cp-admin-user-row-v3__head small {
  display: block;
  min-width: 0;
  overflow-wrap: anywhere;
  white-space: normal;
}

.cp-admin-user-row-v3__head strong {
  font-size: 0.95rem;
  line-height: 1.3;
}

.cp-admin-user-row-v3__head small {
  font-size: 0.78rem;
  color: var(--cp-saas-muted);
}

.cp-admin-user-row-v3__stats {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.cp-admin-user-row-v3__stats span {
  min-width: 0;
  border: 1px solid color-mix(in srgb, var(--cp-saas-stroke) 80%, transparent);
  border-radius: 10px;
  background: color-mix(in srgb, var(--cp-saas-surface-2) 92%, transparent);
  padding: 7px 8px;
  display: grid;
  gap: 2px;
}

.cp-admin-user-row-v3__stats em {
  font-style: normal;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: .02em;
  text-transform: uppercase;
  color: var(--cp-saas-muted);
}

.cp-admin-user-row-v3__stats b {
  font-size: 0.84rem;
  font-weight: 800;
  color: var(--cp-saas-text);
  min-width: 0;
  white-space: normal;
  overflow-wrap: anywhere;
}

.cp-admin-user-row-v3__foot {
  margin-top: 10px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.cp-admin-user-row-v3__foot i {
  font-style: normal;
  font-size: 0.72rem;
  color: var(--cp-saas-muted);
  border: 1px solid color-mix(in srgb, var(--cp-saas-stroke) 80%, transparent);
  border-radius: 999px;
  padding: 2px 8px;
  max-width: 100%;
  overflow-wrap: anywhere;
}

.cp-saas-admin-user {
  width: 100%;
  text-align: left;
  border: 1px solid var(--cp-saas-stroke);
  border-radius: 10px;
  background: var(--cp-saas-surface);
  color: var(--cp-saas-text);
  padding: 10px;
  cursor: pointer;
}

.cp-saas-admin-user strong,
.cp-saas-admin-user small {
  display: block;
}

.cp-saas-admin-user small {
  margin-top: 3px;
  color: var(--cp-saas-muted);
}

.cp-saas-admin-user.is-active {
  border-color: color-mix(in srgb, var(--cp-saas-primary) 60%, #ffffff 40%);
  background: color-mix(in srgb, var(--cp-saas-primary) 10%, transparent);
}

.cp-saas-admin-users-stack {
  display: grid;
  gap: 10px;
}

.cp-saas-admin-list-top {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 8px;
  max-height: 460px;
  overflow: auto;
  padding-right: 2px;
}

.cp-saas-admin-user-card {
  min-height: 0;
  width: 100%;
  min-width: 0;
  align-content: start;
  display: grid;
  grid-auto-rows: min-content;
  gap: 10px;
  padding: 14px;
  overflow: visible;
  height: auto;
  line-height: 1.35;
  white-space: normal;
}

.cp-saas-admin-user-card strong {
  font-size: 0.98rem;
  min-width: 0;
  white-space: normal;
  line-height: 1.3;
  overflow-wrap: anywhere;
}

.cp-saas-admin-user-card small {
  font-size: 0.76rem;
  min-width: 0;
  white-space: normal;
  overflow-wrap: anywhere;
  opacity: 0.84;
}

.cp-saas-admin-user-head {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.cp-saas-admin-user-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  min-width: 0;
}

.cp-saas-admin-user-stat {
  display: grid;
  gap: 2px;
  min-width: 0;
  padding: 8px 10px;
  border: 1px solid rgba(148, 163, 184, 0.24);
  border-radius: 12px;
  background: rgba(248, 250, 252, 0.88);
}

.cp-saas-admin-user-stat-label {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: rgba(71, 85, 105, 0.78);
}

.cp-saas-admin-user-stat-value {
  font-size: 0.88rem;
  font-weight: 800;
  color: #0f172a;
  min-width: 0;
  white-space: normal;
  overflow-wrap: anywhere;
}

.cp-saas-admin-user-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  min-width: 0;
}

.cp-saas-admin-user-meta em {
  font-style: normal;
  font-size: 0.72rem;
  border: 1px solid rgba(148, 163, 184, 0.36);
  border-radius: 999px;
  padding: 2px 8px;
  background: rgba(248, 250, 252, 0.9);
  color: #334155;
  max-width: 100%;
  overflow-wrap: anywhere;
}

.cp-saas-admin-card {
  border: 1px solid var(--cp-saas-stroke);
  border-radius: 10px;
  padding: 10px;
  background: var(--cp-saas-surface);
  display: grid;
  gap: 6px;
}

.cp-saas-admin-card h6 {
  margin: 0;
  font-size: .9rem;
  color: var(--cp-saas-text);
}

.cp-saas-admin-card p {
  margin: 0;
}

.cp-saas-admin-sync {
  border: 1px solid var(--cp-saas-stroke);
  border-radius: 10px;
  padding: 8px 10px;
  margin: 8px 0 10px;
  display: grid;
  gap: 2px;
  background: color-mix(in srgb, var(--cp-saas-surface) 85%, #ffffff 15%);
}

.cp-saas-admin-sync strong {
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .02em;
}

.cp-saas-admin-sync small {
  color: var(--cp-saas-muted);
}

.cp-saas-admin-sync.is-sending {
  border-color: rgba(197, 120, 18, .35);
  background: rgba(197, 120, 18, .1);
}

.cp-saas-admin-sync.is-synced {
  border-color: rgba(30, 138, 67, .35);
  background: rgba(30, 138, 67, .1);
}

.cp-saas-admin-sync.is-error {
  border-color: rgba(176, 45, 33, .35);
  background: rgba(176, 45, 33, .1);
}

.cp-saas-admin-operation-card {
  border-width: 1px;
}

.cp-saas-admin-operation-card p {
  margin: 0;
}

.cp-saas-admin-operation-card.is-idle {
  border-color: rgba(46, 71, 92, .24);
}

.cp-saas-admin-operation-card.is-sending {
  border-color: rgba(197, 120, 18, .35);
  background: rgba(197, 120, 18, .08);
}

.cp-saas-admin-operation-card.is-synced {
  border-color: rgba(30, 138, 67, .35);
  background: rgba(30, 138, 67, .08);
}

.cp-saas-admin-operation-card.is-error {
  border-color: rgba(176, 45, 33, .35);
  background: rgba(176, 45, 33, .08);
}

.cp-saas-admin-operation-steps {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 3px 0;
}

.cp-saas-admin-operation-steps span {
  border: 1px solid var(--cp-saas-stroke);
  border-radius: 999px;
  padding: 4px 10px;
  font-size: .72rem;
  font-weight: 700;
  color: var(--cp-saas-muted);
  background: color-mix(in srgb, var(--cp-saas-surface) 84%, #ffffff 16%);
}

.cp-saas-admin-operation-steps span.is-done {
  border-color: color-mix(in srgb, #16a34a 45%, var(--cp-saas-stroke));
  color: #15803d;
  background: color-mix(in srgb, #16a34a 14%, transparent);
}

body.dark-mode .cp-saas-admin-operation-steps span.is-done {
  color: #86efac;
}

.cp-saas-admin-inline-form {
  display: grid;
  gap: 6px;
  margin: 2px 0;
}

.cp-saas-admin-inline-form label {
  font-size: .82rem;
  color: var(--cp-saas-muted);
  font-weight: 700;
}

.cp-saas-admin-inline-form input {
  min-height: 36px;
  border: 1px solid var(--cp-saas-stroke);
  border-radius: 9px;
  background: var(--cp-saas-surface);
  color: var(--cp-saas-text);
  padding: 0 10px;
}

.cp-saas-admin-inline-form select {
  min-height: 36px;
  border: 1px solid var(--cp-saas-stroke);
  border-radius: 9px;
  background: var(--cp-saas-surface);
  color: var(--cp-saas-text);
  padding: 0 10px;
}

.cp-saas-admin-check {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: .82rem;
  color: var(--cp-saas-muted);
  font-weight: 700;
}

.cp-saas-admin-btn-sm {
  min-height: 30px;
  padding: 2px 8px;
  font-size: .74rem;
}

.cp-saas-admin-table-wrap {
  overflow-x: auto;
}

.cp-saas-admin-log-filter {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
}

.cp-saas-admin-log-filter input {
  min-height: 36px;
  border: 1px solid var(--cp-saas-stroke);
  border-radius: 9px;
  background: var(--cp-saas-surface);
  color: var(--cp-saas-text);
  padding: 0 10px;
}

.cp-saas-admin-log-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 6px;
}

.cp-saas-admin-log-list li {
  border: 1px solid var(--cp-saas-stroke);
  border-radius: 8px;
  padding: 8px;
  background: color-mix(in srgb, var(--cp-saas-surface) 85%, #ffffff 15%);
  font-size: .78rem;
  display: grid;
  gap: 3px;
}

.cp-saas-admin-log-list li small {
  color: var(--cp-saas-muted);
}

.cp-saas-admin-action-row {
  display: grid;
  gap: 8px;
  margin-top: 4px;
}

.cp-saas-admin-empty {
  margin: 0;
  color: var(--cp-saas-muted);
}

.cp-saas-admin-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 8px;
  margin: 10px 0;
}

.cp-saas-admin-stat {
  border: 1px solid var(--cp-saas-stroke);
  border-radius: 10px;
  padding: 10px;
  background: var(--cp-saas-surface);
  display: grid;
  gap: 4px;
}

.cp-saas-admin-stat strong {
  font-size: .78rem;
  color: var(--cp-saas-muted);
  text-transform: uppercase;
  letter-spacing: .02em;
}

.cp-saas-admin-stat span {
  font-size: 1rem;
  font-weight: 800;
  color: var(--cp-saas-text);
}

.cp-saas-admin-stat small {
  color: var(--cp-saas-muted);
}

.cp-saas-admin-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.cp-saas-admin-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  border: 1px solid var(--cp-saas-stroke);
  border-radius: 999px;
  padding: 4px 10px;
  font-size: .76rem;
  background: color-mix(in srgb, var(--cp-saas-primary) 8%, transparent);
  color: var(--cp-saas-text);
}

.cp-saas-admin-rank-grid {
  display: grid;
  gap: 8px;
  margin: 10px 0;
}

.cp-admin-overview-users-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 10px;
  margin: 10px 0;
}

.cp-admin-overview-user-card {
  border: 1px solid color-mix(in srgb, var(--cp-saas-stroke) 78%, transparent);
  border-radius: 14px;
  padding: 12px 14px;
  background: color-mix(in srgb, var(--cp-saas-surface) 84%, rgba(255,255,255,.03));
  display: grid;
  gap: 8px;
}

.cp-admin-overview-user-card__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.cp-admin-overview-user-card__top span {
  font-size: .74rem;
  color: var(--cp-saas-muted);
}

.cp-admin-overview-user-card > small {
  color: var(--cp-saas-muted);
  overflow-wrap: anywhere;
}

.cp-admin-overview-user-card__stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.cp-admin-overview-user-card__stats span {
  display: grid;
  gap: 2px;
}

.cp-admin-overview-user-card__stats strong {
  font-size: .95rem;
}

.cp-admin-overview-user-card__stats small {
  color: var(--cp-saas-muted);
  font-size: .72rem;
}

.cp-admin-rank-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 8px;
}

.cp-admin-rank-item {
  display: grid;
  grid-template-columns: 34px minmax(0, 1.8fr) minmax(88px, .9fr) minmax(88px, 1fr);
  gap: 10px;
  align-items: start;
  padding: 8px 0;
  border-bottom: 1px solid color-mix(in srgb, var(--cp-saas-stroke) 72%, transparent);
}

.cp-admin-rank-item:last-child {
  border-bottom: 0;
}

.cp-admin-rank-item.is-empty {
  grid-template-columns: minmax(0, 1fr);
  color: var(--cp-saas-muted);
}

.cp-admin-rank-item__pos {
  font-weight: 700;
  color: var(--cp-saas-muted);
}

.cp-admin-rank-item__user,
.cp-admin-rank-item__metric {
  min-width: 0;
}

.cp-admin-rank-item__user strong,
.cp-admin-rank-item__metric {
  display: block;
}

.cp-admin-rank-item__user small,
.cp-admin-rank-item__metric small {
  display: block;
  color: var(--cp-saas-muted);
  margin-top: 2px;
  overflow-wrap: anywhere;
}

.cp-admin-rank-item__plan {
  color: var(--cp-saas-muted);
  font-size: .78rem;
}

.cp-admin-settings-runtime-status {
  margin-top: 12px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid color-mix(in srgb, var(--cp-saas-primary) 26%, var(--cp-saas-stroke));
  background: color-mix(in srgb, var(--cp-saas-primary) 7%, transparent);
  display: grid;
  gap: 4px;
}

.cp-admin-settings-runtime-status strong {
  font-size: .86rem;
}

.cp-admin-settings-runtime-status small {
  color: var(--cp-saas-muted);
  line-height: 1.45;
}

.cp-saas-admin-rank-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .82rem;
}

.cp-saas-admin-rank-table th,
.cp-saas-admin-rank-table td {
  border-bottom: 1px solid color-mix(in srgb, var(--cp-saas-stroke) 75%, transparent);
  padding: 6px 4px;
  text-align: left;
  vertical-align: top;
}

.cp-saas-admin-rank-table th {
  color: var(--cp-saas-muted);
  font-size: .74rem;
  text-transform: uppercase;
  letter-spacing: .02em;
}

.cp-saas-admin-rank-table td small {
  display: block;
  color: var(--cp-saas-muted);
}

.cp-saas-upgrade-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 14px;
  margin: 12px 0;
  align-items: stretch;
}

.cp-saas-upgrade-context-notice {
  margin: 12px 0 28px;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid color-mix(in srgb, var(--cp-saas-danger) 45%, var(--cp-saas-stroke));
  background: color-mix(in srgb, var(--cp-saas-danger) 12%, transparent);
  color: color-mix(in srgb, var(--cp-saas-danger) 74%, var(--cp-saas-text));
  font-size: .84rem;
  font-weight: 600;
  line-height: 1.4;
}

.cp-saas-upgrade-plan {
  border: 1px solid color-mix(in srgb, var(--cp-saas-stroke) 76%, rgba(255, 255, 255, .28));
  border-radius: 14px;
  padding: 18px 16px 16px;
  background:
    linear-gradient(150deg, color-mix(in srgb, var(--cp-saas-primary) 11%, transparent), transparent 52%),
    linear-gradient(185deg, color-mix(in srgb, var(--cp-saas-surface) 80%, rgba(255, 255, 255, .06)), var(--cp-saas-surface-2));
  backdrop-filter: blur(10px) saturate(1.05);
  -webkit-backdrop-filter: blur(10px) saturate(1.05);
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-height: 300px;
  height: 100%;
  box-shadow:
    0 14px 24px rgba(5, 10, 30, .18),
    inset 0 1px 0 rgba(255, 255, 255, .18);
  overflow: hidden;
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease, filter .22s ease;
  will-change: transform;
  cursor: pointer;
}

.cp-saas-upgrade-plan::before {
  display: none;
}

.cp-saas-upgrade-plan:hover {
  transform: translateY(-6px) scale(1.03);
  box-shadow:
    0 28px 40px rgba(5, 10, 30, .30),
    inset 0 1px 0 rgba(255, 255, 255, .22);
  filter: saturate(1.08);
}

.cp-saas-upgrade-plan.is-selected {
  border-color: color-mix(in srgb, var(--cp-saas-primary) 45%, var(--cp-saas-stroke));
  background:
    linear-gradient(150deg, color-mix(in srgb, var(--cp-saas-primary) 20%, transparent), transparent 55%),
    linear-gradient(185deg, color-mix(in srgb, var(--cp-saas-primary) 10%, var(--cp-saas-surface)), var(--cp-saas-surface-2));
  transform: translateY(-8px) scale(1.045);
  box-shadow:
    0 0 0 2px color-mix(in srgb, var(--cp-saas-primary) 26%, transparent),
    0 16px 28px rgba(3, 10, 36, .24),
    inset 0 1px 0 rgba(255, 255, 255, .24);
}

.cp-saas-upgrade-plan.is-selected:hover {
  transform: translateY(-10px) scale(1.055);
  box-shadow:
    0 0 0 2px color-mix(in srgb, var(--cp-saas-primary) 30%, transparent),
    0 30px 42px rgba(3, 10, 36, .32),
    inset 0 1px 0 rgba(255, 255, 255, .24);
}

.cp-saas-upgrade-plan-chip {
  position: absolute;
  top: 10px;
  right: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: color-mix(in srgb, var(--cp-saas-primary) 26%, transparent);
  color: #fff;
  border: 1px solid color-mix(in srgb, var(--cp-saas-primary) 40%, var(--cp-saas-stroke));
  border-radius: 999px;
  padding: 3px 10px;
  font-size: .72rem;
  font-weight: 700;
  margin: 0;
  box-shadow: 0 8px 16px color-mix(in srgb, var(--cp-saas-primary) 30%, transparent);
  opacity: 0;
  transform: translateY(-4px) scale(.98);
  transition: opacity .16s ease, transform .16s ease;
  pointer-events: none;
}

.cp-saas-upgrade-plan-chip.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.cp-saas-upgrade-plan strong {
  font-size: clamp(.84rem, .25vw + .78rem, .98rem);
  color: var(--cp-saas-text);
  line-height: 1.35;
  white-space: normal;
  overflow-wrap: anywhere;
  padding-right: 0;
}

.cp-saas-upgrade-plan-hours {
  margin-top: 1px;
  font-size: clamp(.76rem, .2vw + .72rem, .84rem);
  font-weight: 600;
  color: color-mix(in srgb, var(--cp-saas-text) 76%, var(--cp-saas-muted));
  line-height: 1.35;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.cp-saas-upgrade-plan p {
  margin: 6px 0 0;
  font-weight: 700;
  color: var(--cp-saas-primary);
}

.cp-saas-upgrade-plan small {
  color: color-mix(in srgb, var(--cp-saas-muted) 92%, var(--cp-saas-text));
  line-height: 1.4;
  min-height: 36px;
}

.cp-saas-upgrade-meta {
  margin-top: 2px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.cp-saas-upgrade-meta span {
  display: inline-flex;
  align-items: center;
  padding: 3px 8px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--cp-saas-stroke) 80%, transparent);
  background: color-mix(in srgb, var(--cp-saas-surface-2) 88%, transparent);
  color: var(--cp-saas-muted);
  font-size: .72rem;
  line-height: 1;
}

.cp-saas-upgrade-actions {
  margin-top: auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.cp-saas-upgrade-action {
  min-height: 36px;
  border-radius: 10px;
  font-weight: 700;
  font-size: .82rem;
  cursor: pointer;
  transition: transform .12s ease, box-shadow .12s ease, opacity .12s ease;
}

.cp-saas-upgrade-action:hover {
  transform: translateY(-1px);
}

.cp-saas-upgrade-action.is-primary {
  border: 0;
  background: linear-gradient(135deg, var(--cp-saas-primary), var(--cp-saas-primary-2));
  color: #fff;
  box-shadow: 0 10px 16px color-mix(in srgb, var(--cp-saas-primary) 25%, transparent);
}

.cp-saas-upgrade-action.is-primary[disabled] {
  cursor: not-allowed;
  opacity: .5;
  box-shadow: none;
}

.cp-saas-upgrade-action.is-secondary {
  border: 1px solid color-mix(in srgb, var(--cp-saas-stroke) 78%, transparent);
  background: color-mix(in srgb, var(--cp-saas-surface-2) 90%, transparent);
  color: var(--cp-saas-text);
}

.cp-saas-selected-plan-info {
  margin: 20px 0 10px;
  border: 1px solid color-mix(in srgb, var(--cp-saas-primary) 24%, var(--cp-saas-stroke));
  border-radius: 14px;
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--cp-saas-primary) 8%, transparent), transparent 55%),
    color-mix(in srgb, var(--cp-saas-surface-2) 91%, transparent);
  box-shadow:
    0 14px 28px rgba(5, 10, 30, .16),
    inset 0 1px 0 rgba(255, 255, 255, .12);
  padding: 14px 16px;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.cp-saas-selected-plan-info p {
  margin: 0;
  font-size: .86rem;
  line-height: 1.5;
  color: var(--cp-saas-text);
}

.cp-saas-selected-plan-info p + p {
  margin-top: 6px;
}

.cp-saas-selected-plan-cta {
  margin-top: 10px !important;
  padding: 8px 10px;
  border-radius: 10px;
  border: 1px solid color-mix(in srgb, var(--cp-saas-primary) 32%, var(--cp-saas-stroke));
  background: color-mix(in srgb, var(--cp-saas-primary) 10%, transparent);
  color: color-mix(in srgb, var(--cp-saas-text) 92%, #fff);
  font-weight: 600;
  text-align: center;
}

.cp-saas-selected-plan-group {
  margin-top: 8px;
}

.cp-saas-selected-plan-group > strong {
  display: block;
  margin-bottom: 6px;
  font-size: .76rem;
  text-transform: uppercase;
  letter-spacing: .02em;
  color: var(--cp-saas-muted);
}

.cp-saas-upgrade-meta--tribunals span {
  padding: 4px 9px;
  font-size: .71rem;
}

.cp-saas-upgrade-meta--tribunals {
  max-height: 130px;
  overflow: auto;
  padding-right: 4px;
}

.cp-saas-upgrade-details-card {
  width: min(92vw, 620px);
}

.cp-saas-upgrade-details-card,
.cp-saas-upgrade-details-card * {
  -webkit-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
}

.cp-saas-upgrade-details-list {
  margin: 8px 0 0;
  padding-left: 18px;
  color: var(--cp-saas-text);
}

.cp-saas-upgrade-details-list li + li {
  margin-top: 6px;
}

.cp-saas-payment-provider-note {
  margin-top: 10px;
  padding: 8px 10px;
  border-radius: 10px;
  border: 1px solid color-mix(in srgb, var(--cp-saas-stroke) 82%, transparent);
  background: color-mix(in srgb, var(--cp-saas-surface-2) 92%, transparent);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--cp-saas-muted);
  font-size: .8rem;
  line-height: 1.35;
}

.cp-saas-payment-provider-note img {
  border-radius: 50%;
  flex: 0 0 auto;
}

.cp-saas-payment-status {
  margin: 8px 0 10px;
}

.cp-saas-payment-status-card {
  border: 1px solid var(--cp-saas-stroke);
  border-radius: 10px;
  padding: 10px 12px;
  background: color-mix(in srgb, var(--cp-saas-surface-2) 88%, transparent);
}

.cp-saas-payment-status-card.is-processing,
.cp-saas-payment-status-card.is-pending,
.cp-saas-payment-status-card.is-info {
  border-color: color-mix(in srgb, var(--cp-saas-primary) 34%, var(--cp-saas-stroke));
  background: color-mix(in srgb, var(--cp-saas-primary) 8%, transparent);
}

.cp-saas-payment-status-card.is-success {
  border-color: color-mix(in srgb, #16a34a 36%, var(--cp-saas-stroke));
  background: color-mix(in srgb, #16a34a 10%, transparent);
}

.cp-saas-payment-status-card.is-warning,
.cp-saas-payment-status-card.is-error {
  border-color: color-mix(in srgb, var(--cp-saas-danger) 36%, var(--cp-saas-stroke));
  background: color-mix(in srgb, var(--cp-saas-danger) 10%, transparent);
}

.cp-saas-payment-status-title {
  margin: 0;
  font-weight: 700;
  color: var(--cp-saas-text);
}

.cp-saas-payment-status-detail {
  margin: 4px 0 0;
  color: var(--cp-saas-text);
  font-size: .9rem;
}

.cp-saas-payment-status-meta {
  margin: 6px 0 0;
  color: var(--cp-saas-muted);
  font-size: .78rem;
}

.cp-saas-upgrade-modal.is-payment-busy .cp-saas-modal-close {
  opacity: .45;
  cursor: not-allowed;
}

.cp-saas-upgrade-footer {
  margin-top: 10px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  align-items: center;
}

.cp-saas-upgrade-footer input {
  min-width: 0;
  min-height: 40px;
  border: 1px solid var(--cp-saas-stroke);
  border-radius: 10px;
  background: var(--cp-saas-surface);
  color: var(--cp-saas-text);
  padding: 0 12px;
}

.cp-saas-logout {
  margin-top: 2px;
  width: 100%;
  min-height: 42px;
  border-radius: 10px;
  border: 1px solid color-mix(in srgb, var(--cp-saas-danger) 35%, var(--cp-saas-stroke));
  color: var(--cp-saas-danger);
  background: var(--cp-saas-danger-bg);
  font-weight: 700;
  cursor: pointer;
}

@media (max-width: 991px) {
  .cp-saas-auth-entry {
    margin-left: auto;
    max-width: 100%;
  }

  .cp-saas-auth-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 14px;
    min-height: 40px;
    min-width: 0;
    height: 40px;
    white-space: nowrap;
    font-size: 0.82rem;
    border-radius: 999px;
  }

  .cp-saas-modal-card {
    width: min(96vw, 560px);
    margin-top: 3vh;
    max-height: min(92vh, 920px);
    padding: 18px;
  }

  .cp-saas-upgrade-footer {
    grid-template-columns: 1fr;
  }

  .cp-saas-upgrade-actions {
    grid-template-columns: 1fr;
  }

  .cp-saas-admin-toolbar {
    grid-template-columns: 1fr;
  }

  .cp-saas-admin-log-filter {
    grid-template-columns: 1fr;
  }

  .cp-admin-users-layout-v3 {
    grid-template-columns: minmax(0, 1fr);
  }

  .cp-saas-admin-list-top {
    max-height: 280px;
  }

  .cp-saas-admin-user-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1100px) {
  .cp-saas-admin-grid {
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.35fr);
  }

  .cp-saas-admin-rank-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .cp-saas-modal-head h3 {
    font-size: 1.05rem;
  }

  .cp-saas-subtitle {
    font-size: .85rem;
  }

  .cp-saas-drawer-panel {
    width: 100vw;
    border-left: 0;
  }

  .cp-admin-user-row-v3__stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .cp-saas-admin-user-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .cp-admin-overview-user-card__stats,
  .cp-admin-rank-item {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 420px) {
  .cp-admin-user-row-v3__stats {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (min-width: 992px) {
  .site-header-fixed .header-right-group {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    min-width: 0;
  }

  .site-header-fixed .header-right-group .header-search {
    min-width: 0;
  }

  .site-header-fixed .header-right-group .main-nav {
    flex: 0 0 auto;
  }

  .site-header-fixed .header-right-group .main-nav .nav-item-dropdown {
    position: relative;
  }

  .site-header-fixed .header-right-group .main-nav .dropdown-menu {
    left: auto;
    right: 0;
    transform-origin: top right;
    max-width: min(92vw, 360px);
  }
}

/* ── Back button for user panel sub-views ── */
.cp-saas-back-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 0;
  margin-bottom: 4px;
  border: 0;
  background: transparent;
  color: var(--cp-saas-primary);
  font-weight: 700;
  font-size: .84rem;
  cursor: pointer;
}
.cp-saas-back-btn:hover {
  text-decoration: underline;
}

/* ── Permissions grid organized ── */
.cp-admin-permissions-grid {
  display: grid;
  gap: 10px;
  margin-top: 6px;
}
.cp-admin-perm-category {
  border: 1px solid color-mix(in srgb, var(--cp-saas-stroke) 80%, transparent);
  border-radius: 8px;
  padding: 8px 10px;
  background: color-mix(in srgb, var(--cp-saas-surface-2) 92%, transparent);
}
.cp-admin-perm-cat-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: .84rem;
  cursor: pointer;
}
.cp-admin-perm-tools {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 12px;
  margin-top: 6px;
  padding-left: 4px;
}
.cp-admin-perm-tool {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: .78rem;
  color: var(--cp-saas-muted);
  cursor: pointer;
}
.cp-admin-perm-actions {
  margin-top: 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.cp-admin-perm-actions .cp-saas-admin-action-btn {
  width: auto;
  min-height: 34px;
  padding: 0 14px;
  font-size: .82rem;
}
.cp-admin-perm-prefs {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid color-mix(in srgb, var(--cp-saas-stroke) 80%, transparent);
  display: grid;
  gap: 8px;
}
.cp-admin-perm-prefs h6 {
  margin: 0;
}

/* ── Credit control compact layout ── */
.cp-admin-credits-badges {
  display: flex;
  gap: 8px;
  margin: 4px 0;
}
.cp-admin-credits-badge {
  flex: 1;
  border: 1px solid var(--cp-saas-stroke);
  border-radius: 8px;
  padding: 8px 10px;
  text-align: center;
}
.cp-admin-credits-badge span {
  display: block;
  font-size: .72rem;
  color: var(--cp-saas-muted);
  text-transform: uppercase;
  letter-spacing: .02em;
}
.cp-admin-credits-badge strong {
  display: block;
  font-size: 1rem;
  font-weight: 800;
  color: var(--cp-saas-text);
  margin-top: 2px;
}
.cp-admin-credits-badge.is-calcs {
  border-color: color-mix(in srgb, var(--cp-saas-primary) 30%, var(--cp-saas-stroke));
  background: color-mix(in srgb, var(--cp-saas-primary) 6%, transparent);
}
.cp-admin-credits-badge.is-hours {
  border-color: color-mix(in srgb, #16a34a 30%, var(--cp-saas-stroke));
  background: color-mix(in srgb, #16a34a 6%, transparent);
}
.cp-admin-credits-fields {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 8px;
  margin: 4px 0;
}
.cp-admin-credits-fields > div {
  display: grid;
  gap: 3px;
}
.cp-admin-credits-fields input,
.cp-admin-credits-fields select {
  min-height: 34px;
  border: 1px solid var(--cp-saas-stroke);
  border-radius: 8px;
  background: var(--cp-saas-surface);
  color: var(--cp-saas-text);
  padding: 0 8px;
  font-size: .88rem;
}
.cp-admin-credits-fields label {
  font-size: .72rem;
  color: var(--cp-saas-muted);
  font-weight: 700;
}
.cp-admin-credits-help {
  margin: 0;
  font-size: .74rem;
  color: var(--cp-saas-muted);
}
.cp-admin-credits-actions-wrap {
  margin: 4px 0;
}
.cp-admin-credits-actions .cp-saas-admin-action-btn {
  min-height: 34px;
  font-size: .82rem;
  padding: 0 14px;
  width: auto;
}
.cp-admin-credits-divider {
  border-top: 1px solid var(--cp-saas-stroke);
  margin: 8px 0;
}
.cp-admin-credits-secondary-head h6 {
  margin: 0;
  font-size: .82rem;
}
.cp-admin-credits-secondary-head p {
  margin: 2px 0 0;
  font-size: .74rem;
  color: var(--cp-saas-muted);
}
.cp-admin-credits-secondary-actions {
  display: flex;
  gap: 8px;
}
.cp-admin-credits-secondary-actions .cp-saas-admin-action-btn {
  flex: 0 1 auto;
  min-height: 32px;
  font-size: .78rem;
  padding: 0 12px;
  width: auto;
}

/* ── Admin action row inline ── */
.cp-saas-admin-action-row-inline {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.cp-saas-admin-action-row-inline .cp-saas-admin-action-btn {
  width: auto;
  min-height: 34px;
  padding: 0 14px;
  font-size: .82rem;
}
.cp-saas-upgrade-context-notice {
  margin: 0 0 28px;
}
