/* ═══════════════════════════════════════════════════════════════
   NyxVips — Theme 2026 · Gradient + Glow · Verde
   ═══════════════════════════════════════════════════════════════ */

/* ── Tokens ───────────────────────────────────────────────────── */
:root{
  --bg:#050a0e;
  --surface:rgba(12,18,26,.82);
  --surface2:rgba(18,26,36,.72);
  --border:rgba(255,255,255,.07);
  --text:rgba(246,248,252,.96);
  --muted:rgba(246,248,252,.62);
  --muted2:rgba(246,248,252,.44);
  --accent:#22c55e;
  --accent2:#10b981;
  --accent-glow:rgba(34,197,94,.35);
  --danger:#fb7185;
  --radius:16px;
  --shadow:0 12px 40px rgba(0,0,0,.45);
  --glow:0 0 40px rgba(34,197,94,.12);
  --transition:.25s cubic-bezier(.4,0,.2,1);
}
[data-theme="light"]{
  --bg:#f4f6f9;
  --surface:rgba(255,255,255,.88);
  --surface2:rgba(241,243,248,.82);
  --border:rgba(11,18,32,.09);
  --text:#0b1220;
  --muted:rgba(6,25,52,.64);
  --muted2:rgba(6,25,52,.46);
  --accent:#16a34a;
  --accent2:#15803d;
  --accent-glow:rgba(22,163,74,.18);
  --danger:#e11d48;
  --shadow:0 12px 36px rgba(11,18,32,.08);
  --glow:0 0 32px rgba(22,163,74,.08);
}
[data-theme="dark"]{
  --bg:#050a0e;
  --surface:rgba(12,18,26,.82);
  --surface2:rgba(18,26,36,.72);
  --border:rgba(255,255,255,.07);
  --text:rgba(246,248,252,.96);
  --muted:rgba(246,248,252,.62);
  --muted2:rgba(246,248,252,.44);
  --accent:#22c55e;
  --accent2:#10b981;
  --accent-glow:rgba(34,197,94,.35);
  --danger:#fb7185;
  --shadow:0 12px 40px rgba(0,0,0,.45);
  --glow:0 0 40px rgba(34,197,94,.12);
}

/* ── Reset / Base ─────────────────────────────────────────────── */
*{box-sizing:border-box}
html{height:100%;color-scheme:light dark}
body{
  min-height:100%;margin:0;
  font-family:'Inter',ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial;
  background:var(--bg);color:var(--text);
  overflow-y:auto;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
body:before{
  content:"";position:fixed;inset:-280px;pointer-events:none;z-index:-1;transform:translateZ(0);
  background:
    radial-gradient(900px 600px at 8% 14%, rgba(34,197,94,.10), transparent 58%),
    radial-gradient(700px 500px at 92% 22%, rgba(16,185,129,.06), transparent 56%),
    radial-gradient(800px 600px at 50% 105%, rgba(34,197,94,.05), transparent 60%);
  opacity:1;
  animation:glowDrift 18s ease-in-out infinite alternate;
}
@keyframes glowDrift{
  0%{transform:translateZ(0) translate(0,0) scale(1)}
  50%{transform:translateZ(0) translate(12px,-18px) scale(1.03)}
  100%{transform:translateZ(0) translate(-8px,10px) scale(.98)}
}
a{color:inherit}
.hint{color:var(--muted2);font-size:12px;line-height:1.5}
.empty{color:var(--muted);font-size:14px}
.btn-row-right{justify-content:flex-end}

/* ── Page (no sidebar) ────────────────────────────────────────── */
.page{min-height:100%;padding:38px 18px}

/* ── Scrollbar ────────────────────────────────────────────────── */
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-thumb{background:linear-gradient(180deg,rgba(34,197,94,.28),rgba(34,197,94,.12));border:1px solid rgba(34,197,94,.10);border-radius:10px}
::-webkit-scrollbar-track{background:rgba(5,10,14,.6)}

/* ── App shell ────────────────────────────────────────────────── */
.app-shell{display:grid;grid-template-columns:280px 1fr;min-height:100vh}
@media (min-width:941px){
  body.with-sidebar{height:100%;overflow:hidden}
  body.with-sidebar .app-shell{display:block;height:100vh}
  body.with-sidebar .sidebar{
    position:fixed;top:12px;left:12px;bottom:12px;width:272px;
    border:1px solid var(--border);border-radius:var(--radius);
    background:var(--surface);
    backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
    padding:16px;display:flex;flex-direction:column;
    box-shadow:var(--shadow),inset 0 1px 0 rgba(255,255,255,.04);
    transition:box-shadow var(--transition);
  }
  body.with-sidebar .sidebar:hover{box-shadow:var(--shadow),var(--glow),inset 0 1px 0 rgba(255,255,255,.06)}
  body.with-sidebar .nav{flex:1;overflow:auto;padding-right:4px}
  body.with-sidebar .nav::-webkit-scrollbar{width:0;height:0}
  body.with-sidebar .sidebar-footer{margin-top:12px}
  body.with-sidebar .main{
    margin-left:296px;height:100vh;overflow:auto;padding:22px 18px;
    scrollbar-gutter:stable;scrollbar-width:thin;
    scrollbar-color:rgba(34,197,94,.18) rgba(5,10,14,.5);
  }
  body.with-sidebar .main::-webkit-scrollbar{width:10px}
  body.with-sidebar .main::-webkit-scrollbar-thumb{background:linear-gradient(180deg,rgba(34,197,94,.22),rgba(34,197,94,.08));border:1px solid rgba(34,197,94,.10);border-radius:10px}
  body.with-sidebar .main::-webkit-scrollbar-track{background:rgba(5,10,14,.5)}
}

/* ── Overlay + Nav toggle ─────────────────────────────────────── */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.60);backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:opacity .22s ease;z-index:40}
[data-theme="light"] .overlay{background:rgba(0,0,0,.22)}
.nav-toggle{
  position:fixed;top:14px;left:14px;width:46px;height:46px;border-radius:14px;
  border:1px solid var(--border);background:var(--surface2);
  backdrop-filter:blur(12px);
  color:var(--text);display:none;align-items:center;justify-content:center;z-index:60;
  box-shadow:var(--shadow);transition:border-color var(--transition),box-shadow var(--transition);
}
.nav-toggle:hover{border-color:rgba(34,197,94,.22);box-shadow:var(--shadow),var(--glow)}
.nav-toggle svg{width:20px;height:20px}
body.sidebar-open .nav-toggle{opacity:0;pointer-events:none}

/* ── Sidebar ──────────────────────────────────────────────────── */
.sidebar{position:sticky;top:0;padding:16px;border-right:1px solid var(--border);background:var(--surface);backdrop-filter:blur(20px)}
.brand{display:flex;align-items:center;justify-content:center;gap:12px;padding:8px 8px 14px;border-bottom:1px solid var(--border);margin-bottom:12px;text-align:center}
.brand .logo-img{display:block;height:36px;width:auto;max-width:100%;margin:0 auto}
.brand .logo-light{display:none}
[data-theme="light"] .brand .logo-light{display:block}
[data-theme="light"] .brand .logo-dark{display:none}
[data-theme="light"] .brand.has-logo-light .logo-text{display:none}
[data-theme="dark"] .brand.has-logo-dark .logo-text{display:none}
.logo-text{display:inline-flex;align-items:baseline;justify-content:center;gap:6px;font-weight:800;letter-spacing:-.04em;line-height:1;font-size:18px;text-transform:lowercase;width:100%}
.logo-nyx{background:linear-gradient(135deg,#22c55e,#34d399);-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 0 24px rgba(34,197,94,.25)}
.logo-vips{color:var(--text);opacity:.92}
.bot-switch{padding:0 8px 12px}

/* ── Nav ──────────────────────────────────────────────────────── */
.nav{display:flex;flex-direction:column;gap:8px}
.nav-group{display:flex;flex-direction:column;gap:4px}
.nav-group-title{padding:4px 10px 2px;margin-top:4px;color:var(--muted2);font-weight:700;font-size:10px;letter-spacing:.14em;text-transform:uppercase}
.nav-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:calc(var(--radius) - 4px);
  border:1px solid transparent;
  background:transparent;color:var(--text);opacity:.85;
  text-decoration:none;font-weight:600;font-size:13.5px;
  transition:all var(--transition);
}
.nav-ic{
  width:28px;height:28px;border-radius:9px;
  display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;
  border:1px solid rgba(255,255,255,.06);background:rgba(255,255,255,.03);
  color:rgba(246,248,252,.78);transition:all var(--transition);
}
.nav-ic svg{width:15px;height:15px;display:block}
.nav-t{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nav-item:hover{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.08);opacity:1}
.nav-item.active{
  background:rgba(34,197,94,.10);
  border-color:rgba(34,197,94,.22);
  color:var(--text);opacity:1;
  box-shadow:0 0 20px rgba(34,197,94,.08);
}
.nav-item.active .nav-ic{border-color:rgba(34,197,94,.30);background:rgba(34,197,94,.14);color:#34d399}
[data-theme="light"] .nav-ic{background:rgba(255,255,255,.72);color:rgba(11,18,32,.68)}

/* ── Sidebar footer ───────────────────────────────────────────── */
.sidebar-footer{margin-top:18px;display:flex;flex-direction:column;gap:10px;border-top:1px solid var(--border);padding-top:12px}
.user-pill{
  padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);
  background:rgba(255,255,255,.02);color:var(--muted);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px;
}
.sidebar-footer .btn{width:100%}

/* ── Main ─────────────────────────────────────────────────────── */
.main{padding:22px 10px;overflow-x:hidden}
.main-inner{width:min(1320px,100%);max-width:1320px;margin:0 auto;overflow-x:hidden}

/* ── Typography ───────────────────────────────────────────────── */
.title{font-size:56px;line-height:1.02;font-weight:800;letter-spacing:-.03em;margin:0}
.subtitle{margin:10px 0 0;color:var(--muted);font-size:18px}

/* ── Dash top ─────────────────────────────────────────────────── */
.dash-top{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:14px}
.dash-greet{font-size:22px;font-weight:800;letter-spacing:-.02em}
.dash-sub{margin-top:6px;color:var(--muted2);font-size:13px}
.dash-actions{display:flex;align-items:center;justify-content:flex-end;gap:12px;flex-wrap:wrap}
.dash-range{display:flex;gap:8px;flex-wrap:wrap}
@media (max-width:820px){.dash-top{flex-direction:column;align-items:stretch}.dash-actions{justify-content:flex-start}.dash-actions>.dash-card{width:100%}}

/* ── Analytics filters ────────────────────────────────────────── */
.ana-filters{padding:12px}
.ana-filters-row{display:grid;grid-template-columns:repeat(5,minmax(0,1fr)) auto;gap:10px;align-items:center}
@media (max-width:1100px){.ana-filters-row{grid-template-columns:repeat(2,minmax(0,1fr)) auto}}
@media (max-width:680px){.ana-filters-row{grid-template-columns:1fr}}
.ana-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-top:12px}
@media (min-width:1100px){.ana-grid{grid-template-columns:1.45fr .55fr}}
.ana-wide,.ana-side{min-width:0}
.ana-chart{margin-top:8px}
.ana-legend{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:10px}
.ana-legend .lg{display:flex;align-items:center;gap:8px;color:var(--muted2);font-weight:700;font-size:12px}
.ana-legend .dot{width:10px;height:10px;border-radius:999px;display:inline-flex}

/* ── Calendar ─────────────────────────────────────────────────── */
.ana-cal{display:flex;flex-direction:column;gap:10px}
.ana-cal-head{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px}
.ana-cal-d{font-size:11px;color:var(--muted2);font-weight:700;text-align:center}
.ana-cal-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px}
.ana-cal-cell{
  height:34px;border-radius:calc(var(--radius) - 6px);
  border:1px solid var(--border);background:var(--surface);
  display:flex;align-items:center;justify-content:center;
  font-weight:700;color:rgba(244,245,245,.80);text-decoration:none;cursor:pointer;user-select:none;
  transition:all var(--transition);
}
.ana-cal-cell:hover{border-color:rgba(34,197,94,.18);background:rgba(34,197,94,.04)}
.ana-cal-cell:active{transform:translateY(1px)}
.ana-cal-cell.is-today{border-color:rgba(34,197,94,.40);box-shadow:0 0 12px rgba(34,197,94,.12)}
.ana-cal-cell.is-in-range{background:rgba(34,197,94,.08);border-color:rgba(34,197,94,.18);color:rgba(244,245,245,.92)}
.ana-cal-cell.is-selected{background:rgba(34,197,94,.14);border-color:rgba(34,197,94,.35);color:rgba(244,245,245,.96);box-shadow:0 0 16px rgba(34,197,94,.14)}
.ana-cal-cell.is-empty{border-color:transparent;background:transparent}
.ana-cal-help{color:var(--muted2);font-size:12px}
.ana-cal-nav{display:flex;align-items:center;gap:10px}
.ana-cal-month{font-size:12px;color:var(--muted2);font-weight:700;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}
.ana-cal-btn{
  width:34px;height:34px;border-radius:calc(var(--radius) - 6px);
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--border);background:var(--surface);
  color:rgba(244,245,245,.86);text-decoration:none;font-weight:800;transition:all var(--transition);
}
.ana-cal-btn:hover{border-color:rgba(34,197,94,.20);background:rgba(34,197,94,.06)}
.ana-note-form{margin-bottom:10px}
.ana-note-row{display:grid;grid-template-columns:160px 1fr auto;gap:10px;align-items:center}
@media (max-width:680px){.ana-note-row{grid-template-columns:1fr}.ana-note-row .btn{width:100%}}
.ana-grid-4{display:grid;grid-template-columns:1fr;gap:12px;margin-top:12px}
@media (min-width:1100px){.ana-grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}}
@media (max-width:1100px){.ana-grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:680px){.ana-grid-4{grid-template-columns:1fr}}

/* ── Chart legend ─────────────────────────────────────────────── */
.dash-chart{overflow:visible}
.dash-chart-wrap{min-height:220px;overflow:visible}
.dash-chart-legend .lg{border:0;background:transparent;padding:0;cursor:pointer}
.dash-chart-legend .lg.is-off{opacity:.45}

/* ── KPI cards ────────────────────────────────────────────────── */
.kpi-card{position:relative;overflow:hidden}
.dash-kpi-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.kpi-with-ic{display:flex;align-items:center;gap:8px}
.kpi-ic{
  width:20px;height:20px;border-radius:8px;
  border:1px solid rgba(255,255,255,.08);
  display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;
  color:rgba(244,245,245,.92);transition:box-shadow var(--transition);
}
.kpi-ic svg{width:14px;height:14px;display:block}
.kpi-ic-green{background:rgba(34,197,94,.14);box-shadow:0 0 12px rgba(34,197,94,.12)}
.kpi-ic-blue{background:rgba(59,130,246,.14);box-shadow:0 0 12px rgba(59,130,246,.10)}
.kpi-ic-gray{background:rgba(255,255,255,.06)}
.kpi-ic-yellow{background:rgba(250,204,21,.12);box-shadow:0 0 12px rgba(250,204,21,.10)}
.kpi-card .kpi-spark{display:none}
.kpi-delta{
  display:inline-flex;align-items:center;justify-content:center;height:22px;padding:0 10px;
  border-radius:999px;border:1px solid var(--border);
  background:rgba(255,255,255,.02);font-weight:700;font-size:12px;color:var(--muted);
}
.kpi-delta.up{border-color:rgba(34,197,94,.28);background:rgba(34,197,94,.10);color:#34d399}
.kpi-delta.down{border-color:rgba(251,113,133,.28);background:rgba(251,113,133,.10);color:rgba(251,113,133,.92)}
.kpi-delta.neutral{background:rgba(255,255,255,.02);color:var(--muted2)}
.kpi-spark{position:absolute;right:12px;top:10px;width:140px;height:44px;opacity:.85;pointer-events:none}
[data-theme="light"] .kpi-spark{opacity:.55}

/* ── Dash chips ───────────────────────────────────────────────── */
.dash-chip{
  display:inline-flex;align-items:center;justify-content:center;height:34px;padding:0 14px;
  border-radius:calc(var(--radius) - 2px);border:1px solid var(--border);
  background:var(--surface);color:var(--text);text-decoration:none;
  font-weight:600;font-size:12px;letter-spacing:.02em;opacity:.88;
  transition:all var(--transition);
}
.dash-chip.active{
  border-color:rgba(34,197,94,.35);
  box-shadow:0 0 20px rgba(34,197,94,.14),0 0 4px rgba(34,197,94,.18);
  background:rgba(34,197,94,.10);color:var(--text);opacity:1;
}

/* ── Dash hero & KPI grid ─────────────────────────────────────── */
.dash-hero{display:grid;grid-template-columns:1fr;gap:12px;margin-top:12px}
.dash-kpis{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:0}
@media (min-width:1100px){.dash-hero{grid-template-columns:1fr 1.45fr;align-items:stretch}.dash-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}}
.dash-hero #__rtGrid,.dash-hero #__rtGrid .dash-grid,.dash-hero #__rtGrid .dash-chart{height:100%}
.dash-hero #__rtGrid .dash-grid{margin-top:0}
.dash-hero #__rtGrid .dash-card.dash-chart{display:flex;flex-direction:column}
.dash-hero #__rtGrid .dash-chart-wrap{flex:1;min-height:240px}
.dash-hero #__rtKpis{height:100%}
.dash-hero #__rtKpis .dash-kpis{height:100%;grid-auto-rows:1fr;align-content:stretch}
.dash-hero #__rtKpis .dash-kpis > .dash-card{height:100%}

/* ── Cards (glass) ────────────────────────────────────────────── */
.dash-card{
  border-radius:calc(var(--radius) + 2px);
  border:1px solid var(--border);
  background:var(--surface);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  box-shadow:var(--shadow);
  padding:18px;
  transition:border-color var(--transition),box-shadow var(--transition),transform var(--transition);
}
.dash-card:hover{
  border-color:rgba(34,197,94,.16);
  box-shadow:var(--shadow),0 0 28px rgba(34,197,94,.08);
  transform:translateY(-1px);
}
[data-theme="light"] .dash-card{background:var(--surface);box-shadow:var(--shadow)}
[data-theme="light"] .dash-card:hover{border-color:rgba(22,163,74,.16);box-shadow:var(--shadow),var(--glow)}

/* ── Dash grid ────────────────────────────────────────────────── */
.dash-grid{display:grid;grid-template-columns:1fr;gap:12px;align-items:start;margin-top:12px}
@media (min-width:1100px){.dash-grid{grid-template-columns:1.25fr .75fr}}
@media (min-width:1200px){.dash-grid{grid-template-columns:1.4fr .6fr}}
.dash-chart{grid-column:1/-1}

/* ── KPI labels ───────────────────────────────────────────────── */
.dash-kpi-label{color:var(--muted);font-size:12px;letter-spacing:.02em;font-weight:600}
.dash-kpi-value{margin-top:8px;font-size:32px;font-weight:800;letter-spacing:-.03em}
.dash-kpi-sub{margin-top:6px;color:var(--muted2);font-size:12px}
.dash-kpis .dash-card{padding:16px}

/* ── Gauge ────────────────────────────────────────────────────── */
.dash-gauge{margin-top:10px;width:100%;height:104px;display:flex;align-items:flex-end;justify-content:center;position:relative}
.dash-gauge-svg{position:absolute;left:50%;top:2px;transform:translateX(-50%);width:min(250px,100%);height:100px;overflow:visible}
.dash-gauge-track{stroke:rgba(255,255,255,.08);stroke-width:12;fill:none;stroke-linecap:round}
.dash-gauge-fill{
  stroke:var(--accent);stroke-width:12;fill:none;stroke-linecap:round;
  stroke-dasharray:100;stroke-dashoffset:calc(100*(1 - var(--p)));
  filter:drop-shadow(0 0 8px rgba(34,197,94,.30));
  transition:stroke-dashoffset .4s cubic-bezier(.4,0,.2,1);
}
[data-theme="light"] .dash-gauge-track{stroke:rgba(11,18,32,.08)}
.dash-gauge-center{position:relative;z-index:2;text-align:center;padding-bottom:12px}
.dash-gauge-center .dash-kpi-value{font-size:30px;line-height:1.05;letter-spacing:-.02em}
.dash-gauge-center .dash-kpi-sub{margin-top:6px;opacity:.9;font-weight:700}

/* ── Card head ────────────────────────────────────────────────── */
.dash-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}
.dash-card-head.is-wrap{flex-wrap:wrap;align-items:center}
.dash-card-head.is-wrap>form{margin-left:auto}
@media (max-width:520px){.dash-card-head.is-wrap>form{width:100%;margin-left:0}.dash-card-head.is-wrap>form .input{width:100%}}
.dash-card-title{font-weight:800;letter-spacing:-.02em;font-size:18px}
.dash-card-sub{margin-top:6px;color:var(--muted2);font-size:12px}

/* ── Finance grid ─────────────────────────────────────────────── */
.finance-grid{display:grid;grid-template-columns:1fr;gap:12px;align-items:start;margin-top:12px}
.finance-grid>*{min-width:0}
@media (min-width:1100px){.finance-grid{grid-template-columns:1.4fr .6fr}}
.finance-side{display:flex;flex-direction:column;gap:12px;min-width:0}
.finance-tx-card{display:flex;flex-direction:column;min-width:0}
@media (min-width:1100px){.finance-tx-card{min-height:420px}}
.finance-tx-list{flex:1;min-height:0}
@media (max-width:940px){.finance-tx-list{overflow:visible;padding-right:0}}

/* ── Chart wrap ───────────────────────────────────────────────── */
.dash-chart-wrap{
  min-height:240px;border-radius:calc(var(--radius) + 2px);
  border:1px solid var(--border);
  background:var(--surface);
  backdrop-filter:blur(12px);
  overflow:visible;
}
.dash-card.dash-chart{padding:16px}
.dash-card.dash-chart .dash-card-head{margin-bottom:10px}
.dash-card.dash-chart .dash-card-title{font-size:16px}
.dash-card.dash-chart .dash-card-sub{font-size:11px;letter-spacing:.02em;text-transform:uppercase}
[data-theme="light"] .dash-chart-wrap{background:var(--surface2)!important;border-color:rgba(11,18,32,.08)!important}
[data-theme="light"] .dash-chart-gridline{stroke:rgba(11,18,32,.08)!important}
[data-theme="light"] .dash-chart-baseline{fill:rgba(11,18,32,.08)!important}
[data-theme="light"] .dash-chart-ytick,[data-theme="light"] .dash-chart-xtick{fill:rgba(11,18,32,.56)!important}
[data-theme="light"] .dash-chart-vline{stroke:rgba(11,18,32,.18)!important}
[data-theme="light"] .dash-chart-focus{fill:rgba(255,255,255,.92)!important;stroke:rgba(11,18,32,.22)!important}
[data-theme="light"] .dash-chart-tip{background:rgba(255,255,255,.92)!important;color:rgba(11,18,32,.92)!important;border-color:rgba(11,18,32,.12)!important;box-shadow:0 18px 50px rgba(11,18,32,.14)!important}
[data-theme="light"] .dash-chart-tip .t-date{color:rgba(11,18,32,.54)!important}
[data-theme="light"] .dash-chart-tip .t-k{color:rgba(11,18,32,.56)!important}
.dash-chart-controls{
  display:inline-flex;align-items:center;gap:4px;padding:4px;
  border:1px solid var(--border);border-radius:calc(var(--radius) - 4px);
  background:var(--surface);
}
.dash-chart-controls .pill{margin:0;min-width:40px;line-height:1;text-decoration:none}
.dash-chart-controls .pill:hover,
.dash-chart-controls .pill:focus,
.dash-chart-controls .pill:active{text-decoration:none}

/* ── Panels (Log, Premiações, Ranking) ────────────────────────── */
.dash-panels{display:grid;grid-template-columns:1fr;gap:12px;margin-top:12px}
@media (min-width:1100px){.dash-panels{grid-template-columns:repeat(3,minmax(0,1fr));align-items:stretch}}
.panel-card{padding:16px;display:flex;flex-direction:column;background:var(--surface);backdrop-filter:blur(12px)}
@media (min-width:1100px){.dash-panels .panel-card{height:320px}}
.panel-head{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.panel-ic{
  width:34px;height:34px;border-radius:calc(var(--radius) - 4px);
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid rgba(34,197,94,.14);
  background:rgba(34,197,94,.06);color:rgba(246,248,252,.92);
  box-shadow:0 0 12px rgba(34,197,94,.06);transition:box-shadow var(--transition);
}
.panel-ic svg{width:18px;height:18px;display:block}
.panel-title{font-weight:800;letter-spacing:-.02em}
.panel-sub{margin-top:2px;color:var(--muted2);font-weight:600;font-size:12px}
.panel-list{display:flex;flex-direction:column;gap:8px;flex:1;min-height:0;overflow:auto;padding-right:8px;padding-bottom:8px}
.panel-item{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:12px;border-radius:calc(var(--radius) - 2px);
  border:1px solid var(--border);background:rgba(255,255,255,.02);
  transition:all var(--transition);
}
.panel-item:hover{border-color:rgba(34,197,94,.18);background:rgba(34,197,94,.03);box-shadow:0 0 16px rgba(34,197,94,.06)}
.panel-item-left{display:flex;align-items:center;gap:10px;min-width:0;flex:1 1 auto;overflow:hidden}
.panel-item-mid{min-width:0;display:flex;flex-direction:column;gap:2px;flex:1 1 auto}
.panel-item-title{font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.panel-item-sub{color:var(--muted2);font-size:12px;font-weight:600}
.panel-item-right{display:flex;align-items:center;gap:10px;flex:0 0 auto;justify-content:flex-end}
.panel-amt{font-weight:800;white-space:nowrap}
@media (max-width:420px){.panel-item{flex-direction:column;align-items:stretch}.panel-item-right{justify-content:space-between}}
.panel-pill{
  height:22px;padding:0 10px;border-radius:999px;
  border:1px solid rgba(255,255,255,.08);
  display:inline-flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:700;color:var(--muted);
}
.panel-pill.ok{border-color:rgba(34,197,94,.28);background:rgba(34,197,94,.12);color:#34d399;box-shadow:0 0 10px rgba(34,197,94,.10)}
.panel-pill.muted{background:rgba(255,255,255,.02);color:var(--muted2)}
.panel-rank{
  width:30px;height:30px;border-radius:10px;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid rgba(34,197,94,.14);background:rgba(34,197,94,.06);
  font-weight:800;color:#34d399;flex:0 0 auto;
}
.panel-bar{margin-top:8px;height:6px;border-radius:999px;background:rgba(255,255,255,.04);overflow:hidden;border:1px solid rgba(255,255,255,.06)}
.panel-bar-in{height:100%;border-radius:999px;background:linear-gradient(90deg,#10b981,#22c55e,#34d399);box-shadow:0 0 12px rgba(34,197,94,.20)}
[data-theme="light"] .panel-ic{border-color:rgba(22,163,74,.14);background:rgba(22,163,74,.06);color:rgba(11,18,32,.78)}
[data-theme="light"] .panel-item{border-color:rgba(11,18,32,.08);background:rgba(255,255,255,.82)}
[data-theme="light"] .panel-rank{border-color:rgba(22,163,74,.18);background:rgba(22,163,74,.06);color:var(--accent)}
[data-theme="light"] .panel-bar{background:rgba(11,18,32,.04);border-color:rgba(11,18,32,.08)}

/* ── Funnel / Bots grid ───────────────────────────────────────── */
.dash-funnel{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.dash-f-step{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:14px}
.dash-bots{margin-top:12px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.dash-bot{
  display:block;text-decoration:none;border:1px solid var(--border);border-radius:var(--radius);
  background:var(--surface);padding:14px;transition:all var(--transition);
}
.dash-bot:hover{border-color:rgba(34,197,94,.18);box-shadow:0 0 24px rgba(34,197,94,.08),var(--shadow);transform:translateY(-1px)}
[data-theme="light"] .dash-bot:hover{box-shadow:var(--shadow),var(--glow)}
.dash-ana-mid{display:flex;flex-direction:column;gap:4px;min-width:0}
.dash-ana-bar{margin-top:8px;height:6px;border-radius:999px;background:rgba(255,255,255,.04);overflow:hidden;border:1px solid rgba(255,255,255,.06)}
.dash-ana-bar-in{height:100%;border-radius:999px;background:linear-gradient(90deg,#10b981,#22c55e);box-shadow:0 0 10px rgba(34,197,94,.18)}
[data-theme="light"] .dash-ana-bar{background:rgba(11,18,32,.04);border-color:rgba(11,18,32,.08)}
[data-theme="light"] .dash-ana-bar-in{background:linear-gradient(90deg,rgba(22,163,74,.80),rgba(22,163,74,.40))}
.ana-ic svg{width:16px;height:16px;display:block}

/* ── Grid helpers ─────────────────────────────────────────────── */
.row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.row>*{max-width:100%;min-width:0}
.grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.grid-4{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
@media (max-width:1100px){.grid-3{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}}

/* ── Forms ────────────────────────────────────────────────────── */
.form{display:flex;flex-direction:column;gap:12px;margin-top:14px}
.field{display:flex;flex-direction:column;gap:6px}
.label{font-size:13px;color:var(--muted);font-weight:500}
.input{
  height:46px;border-radius:calc(var(--radius) - 2px);
  border:1px solid var(--border);
  background:rgba(5,10,14,.50);
  color:var(--text);padding:0 14px;outline:none;
  font-size:14px;font-family:inherit;
  transition:border-color var(--transition),box-shadow var(--transition),background var(--transition);
  box-shadow:none;
}
.input:focus{
  border-color:rgba(34,197,94,.45);
  box-shadow:0 0 0 4px rgba(34,197,94,.12),0 0 20px rgba(34,197,94,.08);
  background:rgba(5,10,14,.65);
}
.input:disabled{opacity:.65;cursor:not-allowed}
textarea.input{height:auto;min-height:120px;padding:12px 14px;resize:vertical}
.input::placeholder{color:var(--muted2)}

/* ── File input ───────────────────────────────────────────────── */
.file{position:relative}
.file-native{position:absolute;inset:0;opacity:0;cursor:pointer}
.file-ui{
  display:flex;align-items:center;gap:10px;
  border:1px solid var(--border);border-radius:var(--radius);
  background:rgba(5,10,14,.40);padding:10px 12px;min-height:46px;
}
.file-btn{
  display:inline-flex;align-items:center;justify-content:center;height:30px;padding:0 10px;
  border-radius:calc(var(--radius) - 6px);border:1px solid var(--border);
  background:rgba(255,255,255,.03);font-weight:700;font-size:12px;letter-spacing:.02em;
}
.file-name{color:var(--text);opacity:.9;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.file:focus-within .file-ui{border-color:rgba(34,197,94,.35);box-shadow:0 0 0 4px rgba(34,197,94,.10),0 0 16px rgba(34,197,94,.06)}

/* ── Toggle ───────────────────────────────────────────────────── */
.toggle{display:inline-flex;align-items:center;gap:10px;cursor:pointer;user-select:none;position:relative}
.toggle input{position:absolute;opacity:0;pointer-events:none;width:1px;height:1px}
.toggle-ui{
  width:48px;height:28px;border-radius:999px;
  border:1px solid var(--border);background:var(--surface2);
  position:relative;flex:0 0 auto;
  transition:background var(--transition),border-color var(--transition),box-shadow var(--transition);
}
.toggle-ui:after{
  content:"";position:absolute;top:50%;left:3px;width:20px;height:20px;border-radius:999px;
  transform:translateY(-50%);
  background:linear-gradient(180deg,rgba(246,248,252,.96),rgba(246,248,252,.82));
  box-shadow:0 4px 12px rgba(0,0,0,.28);transition:left var(--transition);
}
.toggle input:checked+.toggle-ui{background:rgba(34,197,94,.18);border-color:rgba(34,197,94,.40);box-shadow:0 0 14px rgba(34,197,94,.12)}
.toggle input:checked+.toggle-ui:after{left:25px;background:linear-gradient(180deg,#34d399,#22c55e);box-shadow:0 0 10px rgba(34,197,94,.30)}
.toggle input:focus+.toggle-ui{box-shadow:0 0 0 4px rgba(34,197,94,.14)}

/* ── Buttons ──────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:10px 14px;border-radius:calc(var(--radius) - 2px);
  border:1px solid var(--border);background:var(--surface2);
  color:var(--text);text-decoration:none;font-weight:600;font-family:inherit;
  transition:all var(--transition);cursor:pointer;
}
.btn:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.12);transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn:focus-visible{outline:none;box-shadow:0 0 0 4px rgba(34,197,94,.14)}
.btn-sm{padding:8px 10px;border-radius:var(--radius);font-size:13px}
.btn-primary{
  background:linear-gradient(135deg,#22c55e,#10b981);
  border-color:rgba(34,197,94,.45);
  color:#071a0e;font-weight:700;
  box-shadow:0 8px 28px rgba(34,197,94,.22),0 0 20px rgba(34,197,94,.10);
}
.btn-primary:hover{
  background:linear-gradient(135deg,#34d399,#22c55e);
  box-shadow:0 12px 36px rgba(34,197,94,.30),0 0 28px rgba(34,197,94,.16);
}
.btn-secondary{background:var(--surface);border-color:var(--border)}
.btn-secondary:hover{border-color:rgba(34,197,94,.16);box-shadow:0 0 16px rgba(34,197,94,.06)}
.btn-ghost{background:transparent;border-color:var(--border)}
.btn-danger{background:rgba(251,113,133,.10);border-color:rgba(251,113,133,.30);color:rgba(251,113,133,.92)}
.btn-danger-ghost{background:transparent;border-color:rgba(251,113,133,.25);color:rgba(251,113,133,.85)}
.btn-row{display:flex;gap:10px;flex-wrap:wrap}

/* ── Create bot actions ───────────────────────────────────────── */
.create-bot-actions{gap:12px}
.create-bot-actions .btn{height:42px;padding:0 16px;border-radius:calc(var(--radius) - 4px)}
.create-bot-actions .btn-secondary{background:var(--surface)}
.create-bot-actions .btn-primary{box-shadow:0 8px 24px rgba(34,197,94,.18),0 0 14px rgba(34,197,94,.10)}

/* ── Pills ────────────────────────────────────────────────────── */
.pill{
  border:1px solid var(--border);border-radius:calc(var(--radius) - 2px);
  padding:8px 10px;background:var(--surface);
  color:var(--muted);font-size:13px;display:inline-flex;gap:6px;align-items:center;
}
.pill-sm{padding:6px 8px;font-size:12px;border-radius:calc(var(--radius) - 4px)}
.pill-gray{border-color:var(--border);background:var(--surface);color:var(--muted)}
.pill-green{border-color:rgba(34,197,94,.28);background:rgba(34,197,94,.08);color:#34d399;box-shadow:0 0 8px rgba(34,197,94,.08)}
.pill-yellow{border-color:rgba(250,204,21,.30);background:rgba(250,204,21,.08);color:rgba(254,249,195,.92)}
.pill-purple{border-color:rgba(168,85,247,.30);background:rgba(168,85,247,.08);color:rgba(243,232,255,.92)}

/* ── Setup card / steps ───────────────────────────────────────── */
.setup-card .dash-card-head{margin-bottom:10px}
.setup-steps{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.setup-step{
  border-radius:calc(var(--radius) - 2px);border:1px solid var(--border);
  background:var(--surface);padding:12px;text-decoration:none;color:var(--text);
  display:flex;flex-direction:column;gap:6px;transition:all var(--transition);
}
.setup-step-n{
  width:28px;height:28px;border-radius:10px;
  display:inline-flex;align-items:center;justify-content:center;
  font-weight:800;background:rgba(255,255,255,.03);border:1px solid var(--border);
  color:var(--muted);
}
.setup-step-t{font-weight:800;letter-spacing:-.01em}
.setup-step-s{color:var(--muted2);font-weight:600;font-size:12px}
.setup-step:hover{border-color:rgba(34,197,94,.18);box-shadow:0 0 16px rgba(34,197,94,.06)}
.setup-step.active{border-color:rgba(34,197,94,.28);background:rgba(34,197,94,.06);box-shadow:0 0 20px rgba(34,197,94,.10)}
.setup-step.active .setup-step-n{border-color:rgba(34,197,94,.30);background:rgba(34,197,94,.14);color:#34d399}
[data-theme="light"] .setup-step{background:rgba(255,255,255,.65)}
[data-theme="light"] .setup-step-n{background:rgba(255,255,255,.92)}
@media (max-width:900px){.setup-steps{grid-template-columns:1fr}}

/* ── Mini table ───────────────────────────────────────────────── */
.mini-table{display:flex;flex-direction:column;gap:10px;margin-top:12px}
.mini-row{
  display:flex;justify-content:space-between;align-items:flex-start;gap:14px;
  padding:12px;border:1px solid var(--border);
  background:var(--surface);border-radius:calc(var(--radius) - 2px);
}
.mini-title{font-weight:700;letter-spacing:-.01em}

/* ── Flash / Error ────────────────────────────────────────────── */
.flash,.error{
  margin:12px 0;padding:12px;border-radius:calc(var(--radius) - 2px);
  border:1px solid var(--border);background:var(--surface);
}
.error{border-color:rgba(251,113,133,.30);background:rgba(251,113,133,.08);color:rgba(251,113,133,.92)}

/* ── Tabs ─────────────────────────────────────────────────────── */
.tabs{display:flex;gap:8px;flex-wrap:wrap}
.tab{
  display:inline-flex;align-items:center;justify-content:center;height:34px;padding:0 14px;
  border-radius:calc(var(--radius) - 2px);border:1px solid var(--border);
  background:var(--surface);color:var(--text);opacity:.88;
  text-decoration:none;font-weight:600;font-size:12px;letter-spacing:.02em;
  transition:all var(--transition);
}
.tab:hover{opacity:1;background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.10)}
.tab.active{
  border-color:rgba(34,197,94,.35);
  box-shadow:0 0 16px rgba(34,197,94,.12),0 0 4px rgba(34,197,94,.16);
  background:rgba(34,197,94,.10);opacity:1;
}

/* ── Redirectors ──────────────────────────────────────────────── */
.r-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}
.r-item{border:1px solid var(--border);background:var(--surface);border-radius:var(--radius);padding:14px;margin-top:12px;transition:border-color var(--transition)}
.r-item:hover{border-color:rgba(34,197,94,.14)}
.r-head{display:flex;align-items:center;justify-content:space-between;gap:12px}
.r-title{font-weight:800;letter-spacing:-.02em}
.r-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.r-small{margin-top:10px;color:var(--muted2);font-size:12px}
.r-actions{margin-top:12px;display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.r-edit{margin-top:12px}

/* ── Chips ────────────────────────────────────────────────────── */
.chips{display:flex;flex-wrap:wrap;gap:8px;padding:10px;border:1px dashed rgba(34,197,94,.12);border-radius:var(--radius);background:rgba(5,10,14,.40)}
.chip-empty{color:var(--muted2);font-size:12px}
.chip{
  display:inline-flex;align-items:center;gap:8px;padding:8px 10px;
  border-radius:var(--radius);border:1px solid var(--border);
  background:var(--surface2);font-weight:700;font-size:12px;letter-spacing:.02em;
}
.chip-btn{
  width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;
  border-radius:6px;border:1px solid var(--border);
  background:transparent;color:var(--text);cursor:pointer;line-height:1;
  transition:all var(--transition);
}
.chip-btn:hover{background:rgba(251,113,133,.10);border-color:rgba(251,113,133,.25)}

/* ── Responsive ───────────────────────────────────────────────── */
@media (max-width:1100px){.dash-grid{grid-template-columns:1fr}.dash-kpis{grid-template-columns:1fr 1fr}.dash-funnel{grid-template-columns:1fr}.dash-bots{grid-template-columns:1fr}}
@media (max-width:640px){
  .dash-top{flex-direction:column;align-items:stretch}
  .dash-actions{justify-content:flex-start}
  .dash-actions .dash-card{width:100%}
  .dash-kpis{grid-template-columns:1fr;gap:16px}
  .dash-kpi-value{font-size:28px}
  .dash-grid{gap:16px}
  .dash-chart-wrap{height:200px}
}
@media (max-width:940px){
  .app-shell{grid-template-columns:1fr}
  .sidebar{
    position:fixed;inset:0 auto 0 0;width:min(320px,86vw);height:100%;
    transform:translateX(-100%);transition:transform .28s cubic-bezier(.4,0,.2,1);
    border-right:none;z-index:50;
    background:linear-gradient(180deg,rgba(8,14,20,.97),rgba(5,10,14,.95));
    backdrop-filter:blur(24px);
    overflow-y:auto;box-shadow:20px 0 60px rgba(0,0,0,.40);
  }
  [data-theme="light"] .sidebar{background:linear-gradient(180deg,rgba(244,246,249,.97),rgba(241,243,248,.95))}
  .nav-toggle{display:flex}
  body.sidebar-open .overlay{opacity:1;pointer-events:auto}
  body.sidebar-open .sidebar{transform:translateX(0)}
  body.sidebar-open{overflow:hidden}
  .main{padding:22px 14px}
  .main-inner{width:100%}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
}
@media (max-width:520px){.title{font-size:40px}.subtitle{font-size:16px}}
