/* ══════════════════════════════════════════════════════════════
   DSPanel Client Panel CSS — v3.0  (Fase 10)
   Herda design tokens do sistema admin, com identidade própria.
   ══════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');

:root {
  /* Mesmo sistema de cores do admin */
  --dsp-sidebar-w:   240px;
  --dsp-bg:          #04070f;
  --dsp-surface:     #080d1a;
  --dsp-surface2:    #0c1220;
  --dsp-surface3:    #101728;
  --dsp-card:        #0a1020;
  --dsp-border:      rgba(99,102,241,.14);
  --dsp-border-soft: rgba(255,255,255,.055);
  --dsp-text:        #e2e8f0;
  --dsp-text-dim:    #8899b4;
  --dsp-muted:       #3d5070;
  --dsp-accent:      #6366f1;
  --dsp-accent2:     #8b5cf6;
  --dsp-accent3:     #a78bfa;
  --dsp-gradient:    linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);
  --dsp-glow:        0 0 32px rgba(99,102,241,.4), 0 0 64px rgba(99,102,241,.15);
  --dsp-glow-sm:     0 0 16px rgba(99,102,241,.25);
  --dsp-green:       #10b981;
  --dsp-yellow:      #f59e0b;
  --dsp-red:         #ef4444;
  --dsp-cyan:        #06b6d4;
  /* cp-* aliases */
  --cp-bg:           var(--dsp-bg);
  --cp-surface:      var(--dsp-surface);
  --cp-surface2:     var(--dsp-surface2);
  --cp-card:         var(--dsp-card);
  --cp-border:       var(--dsp-border);
  --cp-text:         var(--dsp-text);
  --cp-text-dim:     var(--dsp-text-dim);
  --cp-muted:        var(--dsp-muted);
  --cp-accent:       var(--dsp-accent);
  --cp-gradient:     var(--dsp-gradient);
  --cp-green:        var(--dsp-green);
  --cp-yellow:       var(--dsp-yellow);
  --cp-red:          var(--dsp-red);
  --cp-cyan:         var(--dsp-cyan);
}

*, *::before, *::after { box-sizing: border-box; }

html {
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

html, body {
  min-height: 100vh;
  background: var(--dsp-bg);
  color: var(--dsp-text);
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  font-size: 14px;
  line-height: 1.6;
}

::selection { background: rgba(99,102,241,.35); color: #fff; }

::-webkit-scrollbar       { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: var(--dsp-bg); }
::-webkit-scrollbar-thumb { background: var(--dsp-surface3); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: rgba(99,102,241,.5); }

/* ── SIDEBAR ── */
.cp-sidebar {
  position: fixed; top: 0; left: 0;
  width: var(--dsp-sidebar-w); height: 100vh;
  background: linear-gradient(180deg, #080e1e 0%, #04070f 100%);
  border-right: 1px solid var(--dsp-border);
  z-index: 1000;
  display: flex; flex-direction: column;
  overflow-y: auto; overflow-x: hidden;
}

/* ── LOGO ── */
.cp-logo {
  display: flex; align-items: center; gap: .75rem;
  padding: 1.3rem 1.3rem;
  border-bottom: 1px solid var(--dsp-border-soft);
  text-decoration: none; flex-shrink: 0;
}
.cp-logo-icon {
  width: 36px; height: 36px; border-radius: 10px;
  background: var(--dsp-gradient);
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem; color: #fff;
  box-shadow: var(--dsp-glow-sm); flex-shrink: 0;
  transition: transform .3s, box-shadow .3s;
}
.cp-logo:hover .cp-logo-icon {
  transform: scale(1.08) rotate(-3deg);
  box-shadow: var(--dsp-glow);
}
.cp-logo-text { font-size: 1.1rem; font-weight: 900; letter-spacing: -.4px; color: #fff; }
.cp-logo-text span {
  background: var(--dsp-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ── User card ── */
.cp-user-card {
  padding: .9rem 1.15rem;
  border-bottom: 1px solid var(--dsp-border-soft);
  display: flex; align-items: center; gap: .65rem;
}
.cp-avatar {
  width: 32px; height: 32px; border-radius: 8px;
  background: var(--dsp-gradient);
  display: flex; align-items: center; justify-content: center;
  font-size: .8rem; font-weight: 700; color: #fff; flex-shrink: 0;
  box-shadow: 0 2px 8px rgba(99,102,241,.3);
}

/* ── Nav labels ── */
.cp-nav-label {
  font-size: .62rem; font-weight: 700; letter-spacing: 1.4px;
  text-transform: uppercase; color: var(--dsp-muted);
  padding: .9rem 1.3rem .3rem;
}

/* ── Nav links ── */
.cp-sidebar .nav-link {
  color: var(--dsp-text-dim); padding: .52rem 1.3rem;
  font-size: .845rem; font-weight: 500;
  display: flex; align-items: center; gap: .6rem;
  border-right: 2px solid transparent;
  transition: color .18s, background .18s;
  position: relative;
}
.cp-sidebar .nav-link .bi {
  font-size: 1rem; width: 18px; text-align: center; flex-shrink: 0;
  transition: color .18s, transform .18s;
}
.cp-sidebar .nav-link:hover {
  color: var(--dsp-text);
  background: rgba(99,102,241,.06);
}
.cp-sidebar .nav-link:hover .bi { transform: translateX(2px); }

.cp-sidebar .nav-link.active {
  color: #fff;
  background: linear-gradient(90deg, rgba(99,102,241,.2), rgba(99,102,241,.04));
  border-right-color: var(--dsp-accent);
}
.cp-sidebar .nav-link.active .bi {
  color: var(--dsp-accent3);
  filter: drop-shadow(0 0 4px rgba(99,102,241,.5));
}
.cp-sidebar .nav-link.active::before {
  content: '';
  position: absolute; left: 0; top: 50%; transform: translateY(-50%);
  width: 3px; height: 60%;
  background: var(--dsp-gradient); border-radius: 0 3px 3px 0;
  box-shadow: 2px 0 8px rgba(99,102,241,.4);
}
.cp-sidebar .nav-link.nav-danger { color: #f87171; }
.cp-sidebar .nav-link.nav-danger:hover { color: #ef4444; background: rgba(239,68,68,.08); }

.cp-sidebar-footer { padding: .85rem 1.3rem; border-top: 1px solid var(--dsp-border-soft); margin-top: auto; }
.cp-sidebar-backdrop { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.65); z-index: 990; backdrop-filter: blur(2px); }
.cp-sidebar-backdrop.open { display: block; animation: cpFadeIn .2s both; }

/* ── MAIN ── */
.cp-main { margin-left: var(--dsp-sidebar-w); min-height: 100vh; }

.cp-topbar {
  height: 56px;
  background: rgba(8,13,26,.9);
  backdrop-filter: blur(16px) saturate(1.4);
  -webkit-backdrop-filter: blur(16px) saturate(1.4);
  border-bottom: 1px solid var(--dsp-border-soft);
  position: sticky; top: 0; z-index: 900;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 1.5rem;
}

/* ── CARDS ── */
.cp-card {
  background: linear-gradient(145deg, rgba(12,18,32,.9) 0%, rgba(8,13,26,.95) 100%);
  border: 1px solid var(--dsp-border);
  border-radius: 14px; overflow: hidden;
  transition: border-color .25s, box-shadow .25s, transform .25s;
  position: relative;
}
.cp-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg,
    transparent 0%, rgba(99,102,241,.6) 40%,
    rgba(139,92,246,.6) 60%, transparent 100%);
  opacity: 0; transition: opacity .3s; z-index: 1;
}
.cp-card:hover {
  border-color: rgba(99,102,241,.28);
  box-shadow: 0 8px 32px rgba(0,0,0,.5), 0 0 0 1px rgba(99,102,241,.15);
  transform: translateY(-1px);
}
.cp-card:hover::before { opacity: 1; }

.cp-card-header {
  padding: .9rem 1.25rem;
  border-bottom: 1px solid var(--dsp-border-soft);
  font-size: .875rem; font-weight: 600;
  display: flex; align-items: center;
  background: rgba(255,255,255,.018);
  color: var(--dsp-text);
}
.cp-card-body { padding: 1.25rem; }

/* ── STAT ── */
.cp-stat {
  background: linear-gradient(145deg, rgba(12,18,32,.95) 0%, rgba(8,13,26,1) 100%);
  border: 1px solid var(--dsp-border); border-radius: 14px; padding: 1.1rem;
  transition: border-color .25s, transform .25s, box-shadow .25s; position: relative; overflow: hidden;
}
.cp-stat:hover {
  border-color: rgba(99,102,241,.28);
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(0,0,0,.4);
}

/* ── BADGES ── */
.dsp-badge {
  display: inline-flex; align-items: center; gap: .35rem;
  padding: .22rem .6rem; border-radius: 99px;
  font-size: .7rem; font-weight: 700;
}
.dsp-badge-green  { background: rgba(16,185,129,.12); color: #34d399; border: 1px solid rgba(16,185,129,.2); }
.dsp-badge-red    { background: rgba(239,68,68,.12);  color: #f87171; border: 1px solid rgba(239,68,68,.2); }
.dsp-badge-yellow { background: rgba(245,158,11,.12); color: #fbbf24; border: 1px solid rgba(245,158,11,.2); }
.dsp-badge-cyan   { background: rgba(6,182,212,.12);  color: #22d3ee; border: 1px solid rgba(6,182,212,.2); }
.dsp-badge-purple { background: rgba(99,102,241,.14); color: #a5b4fc; border: 1px solid rgba(99,102,241,.22); }
.dsp-badge-gray   { background: rgba(148,163,184,.08);color: #94a3b8; border: 1px solid rgba(148,163,184,.12); }

.dsp-dot { width: 6px; height: 6px; border-radius: 50%; display: inline-block; flex-shrink: 0; }
.dsp-dot-green { background: var(--dsp-green); box-shadow: 0 0 6px var(--dsp-green); animation: cpDotPulse 2s infinite; }
.dsp-dot-red   { background: var(--dsp-red);   box-shadow: 0 0 6px var(--dsp-red); }

@keyframes cpDotPulse {
  0%, 100% { box-shadow: 0 0 4px rgba(16,185,129,.6); }
  50%       { box-shadow: 0 0 10px rgba(16,185,129,.9); }
}

/* ── TABLES ── */
.cp-table { color: var(--dsp-text); --bs-table-bg: transparent; margin: 0; }
.cp-table thead th {
  background: rgba(255,255,255,.018);
  border-bottom: 1px solid var(--dsp-border-soft);
  color: var(--dsp-muted); font-size: .7rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .7px; padding: .8rem 1rem;
}
.cp-table tbody td {
  border-bottom: 1px solid var(--dsp-border-soft);
  padding: .85rem 1rem; vertical-align: middle; font-size: .855rem;
  transition: background .12s;
}
.cp-table tbody tr:last-child td { border-bottom: none; }
.cp-table tbody tr:hover td { background: rgba(99,102,241,.055); }

/* ── FORMS ── */
.cp-input {
  background: rgba(12,18,32,.8) !important;
  border-color: var(--dsp-border) !important;
  color: var(--dsp-text) !important;
  border-radius: 9px !important;
  transition: border-color .18s, box-shadow .18s !important;
}
.cp-input:focus {
  background: rgba(16,23,40,.9) !important;
  border-color: var(--dsp-accent) !important;
  box-shadow: 0 0 0 3px rgba(99,102,241,.2), 0 0 16px rgba(99,102,241,.1) !important;
  color: var(--dsp-text) !important;
}
.cp-input::placeholder { color: var(--dsp-muted) !important; }

.input-group-text {
  background: rgba(12,18,32,.8) !important;
  border-color: var(--dsp-border) !important;
  color: var(--dsp-text-dim) !important;
}
.form-label { font-size: .78rem; font-weight: 600; color: var(--dsp-text-dim); margin-bottom: .4rem; text-transform: uppercase; letter-spacing: .5px; }
.form-text  { color: var(--dsp-muted) !important; font-size: .77rem; }
.form-check-input { background-color: var(--dsp-surface2); border-color: rgba(99,102,241,.3); }
.form-check-input:checked { background-color: var(--dsp-accent); border-color: var(--dsp-accent); }

/* ── BUTTONS ── */
.btn { font-weight: 600; font-size: .845rem; border-radius: 9px; transition: all .18s cubic-bezier(.4,0,.2,1); }
.btn-xs { font-size: .75rem; padding: .25rem .65rem; border-radius: 7px; }

.btn-primary  { background: var(--dsp-gradient); border: none; color: #fff; box-shadow: 0 2px 16px rgba(99,102,241,.35); }
.btn-primary:hover  { background: linear-gradient(135deg,#4f52d8,#7c3aed); box-shadow: 0 4px 24px rgba(99,102,241,.5); transform: translateY(-1px); color: #fff; }
.btn-success  { background: linear-gradient(135deg,#059669,#10b981); border: none; color: #fff; }
.btn-success:hover  { background: linear-gradient(135deg,#047857,#059669); transform: translateY(-1px); color: #fff; }
.btn-danger   { background: linear-gradient(135deg,#dc2626,#ef4444); border: none; color: #fff; }
.btn-danger:hover   { background: linear-gradient(135deg,#b91c1c,#dc2626); transform: translateY(-1px); color: #fff; }
.btn-warning  { background: linear-gradient(135deg,#d97706,#f59e0b); border: none; color: #fff; }
.btn-warning:hover  { background: linear-gradient(135deg,#b45309,#d97706); transform: translateY(-1px); color: #fff; }
.btn-info     { background: linear-gradient(135deg,#0891b2,#06b6d4); border: none; color: #fff; }
.btn-info:hover     { background: linear-gradient(135deg,#0e7490,#0891b2); transform: translateY(-1px); color: #fff; }
.btn-secondary { background: var(--dsp-surface3); border: 1px solid var(--dsp-border); color: var(--dsp-text-dim); }
.btn-secondary:hover { background: var(--dsp-surface2); color: var(--dsp-text); transform: translateY(-1px); }
.btn-outline-success { color: #34d399; border-color: #34d399; } .btn-outline-success:hover { background: #34d399; color: #fff; border-color: #34d399; }
.btn-outline-danger  { color: #f87171; border-color: #f87171; } .btn-outline-danger:hover  { background: #ef4444; color: #fff; border-color: #ef4444; }
.btn-outline-primary { color: var(--dsp-accent); border-color: var(--dsp-accent); } .btn-outline-primary:hover { background: var(--dsp-accent); color: #fff; }
.btn-outline-secondary { color: var(--dsp-text-dim); border-color: var(--dsp-border); } .btn-outline-secondary:hover { background: var(--dsp-surface3); color: var(--dsp-text); }
.btn-outline-info    { color: #22d3ee; border-color: #22d3ee; } .btn-outline-info:hover    { background: #06b6d4; color: #fff; border-color: #06b6d4; }
.btn-outline-warning { color: #fbbf24; border-color: #fbbf24; } .btn-outline-warning:hover { background: #f59e0b; color: #fff; border-color: #f59e0b; }

/* ── MODALS ── */
.modal-content {
  background: linear-gradient(145deg, rgba(8,13,26,.97), rgba(4,7,15,.99)) !important;
  border: 1px solid rgba(99,102,241,.2) !important;
  border-radius: 18px !important;
  box-shadow: 0 40px 80px rgba(0,0,0,.7) !important;
}
.modal-header { border-bottom: 1px solid var(--dsp-border-soft) !important; }
.modal-footer { border-top:    1px solid var(--dsp-border-soft) !important; }
.modal-title  { font-weight: 700; color: var(--dsp-text); }
.btn-close-white { filter: invert(1); opacity: .45; transition: opacity .15s; }
.btn-close-white:hover { opacity: 1; }

/* ── ALERTS ── */
.alert { border-radius: 11px; font-size: .855rem; }
.alert-success { background: rgba(16,185,129,.09); border-color: rgba(16,185,129,.22); color: #6ee7b7; }
.alert-danger  { background: rgba(239,68,68,.09);  border-color: rgba(239,68,68,.22);  color: #fca5a5; }
.alert-warning { background: rgba(245,158,11,.09); border-color: rgba(245,158,11,.22); color: #fcd34d; }
.alert-info    { background: rgba(6,182,212,.09);  border-color: rgba(6,182,212,.22);  color: #67e8f9; }

/* ── PROGRESS ── */
.progress { background: rgba(255,255,255,.06); border-radius: 99px; }
.progress-bar { border-radius: 99px; }

/* ── CODE ── */
code { background: rgba(99,102,241,.12); color: #a5b4fc; padding: .15rem .45rem; border-radius: 6px; font-size: .83em; }

/* ── LIST GROUP / PAGINATION ── */
.list-group-item { background: transparent !important; border-color: var(--dsp-border-soft) !important; color: var(--dsp-text) !important; }
.list-group-item-action:hover { background: rgba(99,102,241,.06) !important; }
.page-link { background: var(--dsp-surface2); border-color: var(--dsp-border-soft); color: var(--dsp-text-dim); border-radius: 7px !important; margin: 0 2px; font-size: .82rem; }
.page-link:hover { background: var(--dsp-surface3); color: var(--dsp-text); }
.page-item.active .page-link { background: var(--dsp-gradient); border-color: transparent; color: #fff; }

/* ── SWITCH ── */
.form-switch .form-check-input { background-color: var(--dsp-surface3); border-color: var(--dsp-border); }
.form-switch .form-check-input:checked { background-color: var(--dsp-accent); border-color: var(--dsp-accent); }

/* ── LOGIN (client) ── */
.cp-login-wrap {
  min-height: 100vh; display: flex; align-items: center; justify-content: center;
  background: var(--dsp-bg); position: relative; overflow: hidden;
}
.cp-login-wrap::before {
  content: ''; position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 80% 70% at 15% 45%, rgba(99,102,241,.18) 0%, transparent 55%),
    radial-gradient(ellipse 60% 50% at 85% 25%, rgba(139,92,246,.14) 0%, transparent 50%),
    radial-gradient(ellipse 40% 60% at 50% 80%, rgba(6,182,212,.07) 0%, transparent 50%);
  animation: cpAurora 12s ease-in-out infinite alternate;
}
.cp-login-wrap::after {
  content: ''; position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(99,102,241,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(99,102,241,.04) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, black, transparent);
}
@keyframes cpAurora {
  0%   { opacity: 1; }
  50%  { opacity: .8; }
  100% { opacity: 1; }
}

.cp-login-card {
  width: 100%; max-width: 410px;
  background: rgba(8,13,26,.85);
  backdrop-filter: blur(24px) saturate(1.5);
  -webkit-backdrop-filter: blur(24px) saturate(1.5);
  border: 1px solid rgba(99,102,241,.22); border-radius: 22px;
  padding: 2.5rem 2.25rem;
  box-shadow: 0 40px 100px rgba(0,0,0,.7), 0 0 0 1px rgba(99,102,241,.08), inset 0 1px 0 rgba(255,255,255,.07);
  position: relative; z-index: 1;
}
.cp-login-card::before {
  content: '';
  position: absolute; top: 0; left: 10%; right: 10%; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(99,102,241,.8) 40%, rgba(139,92,246,.8) 60%, transparent);
}

.cp-login-logo {
  width: 70px; height: 70px; border-radius: 20px;
  background: var(--dsp-gradient);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.95rem; color: #fff; margin: 0 auto 1.2rem;
  box-shadow: 0 0 32px rgba(99,102,241,.5), 0 0 64px rgba(99,102,241,.2);
  animation: cpLogoPulse 3s ease-in-out infinite;
  position: relative;
}
.cp-login-logo::after {
  content: ''; position: absolute; inset: -3px; border-radius: 23px;
  background: var(--dsp-gradient); opacity: .3; z-index: -1;
  filter: blur(12px); animation: cpLogoPulse 3s ease-in-out infinite;
}
@keyframes cpLogoPulse {
  0%, 100% { box-shadow: 0 0 32px rgba(99,102,241,.5); }
  50%       { box-shadow: 0 0 48px rgba(99,102,241,.7), 0 0 80px rgba(99,102,241,.25); }
}

/* ── LOGIN FORM COMPONENTS ── */
.cp-login-title { font-size: 1.45rem; letter-spacing: -.4px; color: var(--cp-text) }
.cp-login-title span { color: var(--cp-accent) }
.cp-login-subtitle { color: var(--cp-muted); font-size: .84rem; margin: 0 }

.cp-login-label {
  display: block; font-size: .78rem; font-weight: 600; letter-spacing: .3px;
  text-transform: uppercase; color: var(--cp-muted); margin-bottom: .45rem;
}
.cp-input-group { position: relative; display: flex; align-items: center }
.cp-input-icon {
  position: absolute; left: .85rem; color: var(--cp-muted); font-size: .95rem;
  pointer-events: none; z-index: 2;
}
.cp-login-input {
  width: 100%; background: var(--dsp-surface2); border: 1px solid var(--cp-border);
  border-radius: 10px; padding: .6rem .9rem .6rem 2.4rem; color: var(--cp-text);
  font-size: .875rem; font-family: inherit; outline: none;
  transition: border-color .2s, box-shadow .2s;
}
.cp-login-input::placeholder { color: var(--cp-muted) }
.cp-login-input:focus {
  border-color: rgba(99,102,241,.5);
  box-shadow: 0 0 0 3px rgba(99,102,241,.12), 0 0 12px rgba(99,102,241,.08);
}
.cp-input-action {
  position: absolute; right: .7rem; background: none; border: none;
  color: var(--cp-muted); cursor: pointer; padding: .25rem; line-height: 1;
  font-size: .95rem; transition: color .15s;
}
.cp-input-action:hover { color: var(--cp-text) }

.cp-check-label { display: flex; align-items: center; gap: .5rem; cursor: pointer; font-size: .8rem; color: var(--cp-muted) }
.cp-check { accent-color: var(--cp-accent); width: 14px; height: 14px }
.cp-login-hint { font-size: .76rem; color: var(--cp-muted) }

.cp-login-btn {
  width: 100%; padding: .65rem 1rem; border-radius: 10px; border: none; cursor: pointer;
  font-size: .875rem; font-weight: 600; font-family: inherit; letter-spacing: .2px;
  background: var(--dsp-gradient); color: #fff;
  box-shadow: 0 4px 16px rgba(99,102,241,.35), 0 1px 3px rgba(0,0,0,.3);
  transition: transform .15s, box-shadow .15s;
}
.cp-login-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(99,102,241,.45), 0 2px 6px rgba(0,0,0,.3);
}
.cp-login-btn:active { transform: translateY(0); box-shadow: 0 2px 8px rgba(99,102,241,.3) }

.cp-login-divider { height: 1px; background: var(--dsp-border-soft); margin: 1.4rem 0 1rem }
.cp-login-footer { font-size: .79rem; color: var(--cp-muted) }
.cp-login-link { color: var(--cp-accent); text-decoration: none; font-weight: 600 }
.cp-login-link:hover { color: var(--dsp-accent2) }
.cp-login-alert { border-radius: 10px }
.cp-login-version {
  position: fixed; bottom: 1rem; left: 50%; transform: translateX(-50%);
  font-size: .72rem; color: var(--cp-muted); letter-spacing: .5px;
  background: rgba(8,13,26,.5); padding: .2rem .6rem; border-radius: 20px;
  border: 1px solid var(--dsp-border-soft); z-index: 2;
}

/* Floating orbs (login bg) */
.cp-orb {
  position: fixed; border-radius: 50%; pointer-events: none; z-index: 0;
  filter: blur(80px); opacity: .1;
}
.cp-orb-1 { width: 500px; height: 500px; background: #6366f1; top: -150px; left: -150px; animation: cpOrb1 14s ease-in-out infinite }
.cp-orb-2 { width: 400px; height: 400px; background: #8b5cf6; bottom: -100px; right: -100px; animation: cpOrb2 18s ease-in-out infinite }
.cp-orb-3 { width: 300px; height: 300px; background: #06b6d4; top: 40%; left: 30%; animation: cpOrb3 22s ease-in-out infinite }
@keyframes cpOrb1 { 0%,100%{transform:translate(0,0) scale(1)} 50%{transform:translate(40px,30px) scale(1.05)} }
@keyframes cpOrb2 { 0%,100%{transform:translate(0,0) scale(1)} 50%{transform:translate(-30px,-40px) scale(1.08)} }
@keyframes cpOrb3 { 0%,100%{transform:translate(0,0)} 33%{transform:translate(20px,-30px)} 66%{transform:translate(-20px,20px)} }

/* Ripple for client panel buttons */
@keyframes cpRipple { to { transform: scale(2.5); opacity: 0 } }

/* Topbar toggle button */
.cp-topbar-toggle {
  background: var(--dsp-surface2); border: 1px solid var(--cp-border); color: var(--cp-text-dim);
}

/* ── CODE EDITOR ── */
#codeEditor {
  background: #030609; color: #a5f3fc;
  border: 1px solid var(--dsp-border); border-radius: 10px;
  font-family: 'Fira Code','Cascadia Code','Courier New',monospace;
  font-size: 13px; line-height: 1.7;
}

/* ── ANIMATIONS ── */
@keyframes cpFadeIn { from{opacity:0;transform:translateY(6px)} to{opacity:1;transform:translateY(0)} }
@keyframes spin { to { transform: rotate(360deg); } }
.fade-in { animation: cpFadeIn .28s cubic-bezier(.4,0,.2,1) both; }
.spin    { animation: spin .6s linear infinite; display: inline-block; }

/* ── RESPONSIVE ── */
@media (max-width: 768px) {
  .cp-sidebar {
    transform: translateX(-100%);
    transition: transform .28s cubic-bezier(.4,0,.2,1), box-shadow .28s;
    box-shadow: none;
  }
  .cp-sidebar.open {
    transform: translateX(0);
    box-shadow: 24px 0 60px rgba(0,0,0,.6);
  }
  .cp-main { margin-left: 0; }
}
@media (max-width: 576px) {
  .cp-login-card { margin: 1rem; padding: 1.75rem 1.25rem; border-radius: 16px; }
}
