/* Pogoda_PL PRO — Admin Panel (CSP-safe)
   Scoped to .admin-page so it won't affect the public site. */

.admin-page{
  --bg:#0b1220;
  --bg2:#0f1a2f;
  --card:rgba(10,16,30,.70);
  --card2:rgba(10,16,30,.82);
  --stroke:rgba(255,255,255,.12);
  --text:#e8eefc;
  --muted:#b9c6e4;
  --accent:#7dd3fc;
  --ok:#2dd4bf;
  --warn:#fbbf24;
  --bad:#fb7185;
  --r:18px;
  --shadow:0 18px 45px rgba(0,0,0,.35);
  width:100%;
  max-width:1400px;
  margin:0 auto;
  padding:18px 18px 28px;
  color:var(--text);
  position: relative;
}

/* Solid background for admin even when global site-bg exists */
.admin-page::before{
  content:"";
  position:fixed;
  inset:0;
  background: var(--bg);
  z-index:-1;
}

.admin-page *{box-sizing:border-box}
.admin-page .muted{color:var(--muted)}

.admin-page .admin-topbar{display:flex;gap:14px;justify-content:space-between;align-items:flex-start;margin:18px 0 14px}
.admin-page .admin-topbar h1{margin:0;font-size:1.45rem}
.admin-page .admin-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}

/* Mobile menu button – hidden on desktop */
.admin-page .admin-navbtn{display:none}

/* topbar toggles */
.admin-page .admin-toggle{min-width:132px}
.admin-page .admin-toggle.active{background:rgba(45,212,191,.12);border-color:rgba(45,212,191,.35)}

.admin-page .admin-shell{display:grid;width:100%;grid-template-columns:270px minmax(0,1fr);gap:16px;align-items:start}
.admin-page .admin-nav{position:sticky;top:84px;background:var(--card);border:1px solid var(--stroke);border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden}
.admin-page .admin-nav__head{padding:14px;border-bottom:1px solid var(--stroke);background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,0))}
.admin-page .nav-list{padding:10px;display:flex;flex-direction:column;gap:8px}
.admin-page .nav-item{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:10px;border-radius:12px;border:1px solid transparent}
.admin-page .nav-item:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.10)}
.admin-page .nav-item.active{background:rgba(125,211,252,.10);border-color:rgba(125,211,252,.25)}

.admin-page .badge{padding:.18rem .5rem;border-radius:999px;font-size:.82rem;border:1px solid var(--stroke);background:rgba(0,0,0,.12);color:rgba(255,255,255,.85)}
.admin-page .badge.ok{border-color:rgba(45,212,191,.45);background:rgba(45,212,191,.12)}
.admin-page .badge.warn{border-color:rgba(251,191,36,.45);background:rgba(251,191,36,.12)}
.admin-page .badge.bad{border-color:rgba(251,113,133,.45);background:rgba(251,113,133,.12)}

.admin-page .admin-main{min-width:0;display:flex;flex-direction:column;gap:16px}
.admin-page .grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.admin-page .grid-4{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}
@media (max-width:1080px){.admin-page .admin-shell{grid-template-columns:1fr}.admin-page .admin-nav{position:relative;top:auto}.admin-page .grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:640px){.admin-page .grid-2{grid-template-columns:1fr}.admin-page .grid-4{grid-template-columns:1fr}}

/* ----------------------------
   Mobile admin navigation (off-canvas)
---------------------------- */
@media (max-width:1080px){
  .admin-page{padding:0 10px}
  .admin-page .admin-topbar{position:sticky;top:0;z-index:50;padding:14px 0 10px;background:linear-gradient(180deg, rgba(11,18,32,.96), rgba(11,18,32,.70));backdrop-filter: blur(10px)}
  .admin-page.theme-light .admin-topbar{background:linear-gradient(180deg, rgba(246,248,255,.96), rgba(246,248,255,.72));}

  .admin-page .admin-navbtn{display:inline-flex}

  .admin-page .admin-shell{grid-template-columns:1fr}
  .admin-page .admin-nav{
    position:fixed;
    top:0;
    left:0;
    height:100vh;
    width:min(86vw, 340px);
    z-index:80;
    transform: translateX(-110%);
    transition: transform .22s ease;
    border-radius:0 18px 18px 0;
    overflow:auto;
  }
  .admin-page.nav-open .admin-nav{ transform: translateX(0); }

  .admin-backdrop{
    position:fixed;
    inset:0;
    z-index:70;
    background: rgba(0,0,0,.52);
    opacity:0;
    pointer-events:none;
    transition: opacity .22s ease;
  }
  .admin-page.nav-open .admin-backdrop{ opacity:1; pointer-events:auto; }
}

.admin-page .card{background:var(--card);border:1px solid var(--stroke);border-radius:var(--r);box-shadow:var(--shadow);padding:14px}
.admin-page .card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}
.admin-page .card-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.admin-page .btn.btn-export{padding:8px 10px;border-radius:12px;font-size:.92rem}
.admin-page .kpi-num{font-size:2.05rem;font-weight:800;letter-spacing:.3px;margin:.25rem 0 .1rem}
.admin-page .kpi-sub{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0 0}
.admin-page .pill{display:inline-flex;align-items:center;gap:6px;padding:.24rem .55rem;border-radius:999px;font-size:.86rem;border:1px solid var(--stroke);background:rgba(0,0,0,.10)}
.admin-page .pill.ok{border-color:rgba(45,212,191,.45);background:rgba(45,212,191,.10)}
.admin-page .pill.warn{border-color:rgba(251,191,36,.45);background:rgba(251,191,36,.10)}
.admin-page .pill.bad{border-color:rgba(251,113,133,.45);background:rgba(251,113,133,.10)}

/* API badges */
.admin-page .api-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.admin-page .api-badges{display:flex;align-items:center;gap:8px}
.admin-page .api-badge{padding:.2rem .45rem;border-radius:999px;font-size:.75rem;font-weight:800;letter-spacing:.4px;border:1px solid var(--stroke);background:rgba(0,0,0,.12);opacity:.92}
.admin-page .api-badge.live{border-color:rgba(45,212,191,.45);background:rgba(45,212,191,.10)}
.admin-page .api-badge.warn{border-color:rgba(251,191,36,.45);background:rgba(251,191,36,.10)}
.admin-page .api-badge.err{border-color:rgba(251,113,133,.45);background:rgba(251,113,133,.10)}

/* Page width modes */
.admin-page{max-width:1280px;margin:0 auto;padding:0 14px}
.admin-page.mode-wide{max-width:1600px}

/* Density */
.admin-page.mode-compact .card{padding:12px}
.admin-page.mode-compact .admin-shell{gap:12px}
.admin-page.mode-compact .admin-nav{border-radius:16px}
.admin-page.mode-compact .nav-item{padding:9px}
.admin-page.mode-compact .table th,.admin-page.mode-compact .table td{padding:8px 9px}
.admin-page.mode-compact .kpi-num{font-size:1.9rem}

/* Light theme (admin-only) */
.admin-page.theme-light{
  --bg:#f6f8fe;
  --bg2:#ffffff;
  --card:rgba(255,255,255,.92);
  --card2:rgba(255,255,255,.96);
  --stroke:rgba(25,40,70,.14);
  --text:#0b1220;
  --muted:#475569;
  --accent:#0284c7;
  --shadow:0 18px 40px rgba(15,23,42,.08);
}
.admin-page.theme-light .table th{background:rgba(255,255,255,.95)}
.admin-page.theme-light .table-wrap{background:rgba(2,8,23,.03)}
.admin-page.theme-light .chart-canvas{background:rgba(2,8,23,.03)}

.admin-page details.collapsible{border:1px solid var(--stroke);border-radius:var(--r);overflow:hidden;background:var(--card);box-shadow:var(--shadow)}
.admin-page details.collapsible summary{list-style:none;cursor:pointer;padding:12px 14px;display:flex;justify-content:space-between;gap:10px;background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,0));border-bottom:1px solid var(--stroke)}
.admin-page details.collapsible summary::-webkit-details-marker{display:none}
.admin-page .collapsible__hint{color:rgba(255,255,255,.64)}
.admin-page .collapsible__body{padding:14px}

.admin-page .table-head{display:flex;gap:10px;align-items:center;justify-content:space-between;flex-wrap:wrap;margin-bottom:10px}
.admin-page .table-search{width:min(520px,100%);padding:10px 12px;border-radius:12px;border:1px solid var(--stroke);background:rgba(0,0,0,.16);color:var(--text);outline:none}
.admin-page .table-search:focus{border-color:rgba(125,211,252,.35);box-shadow:0 0 0 3px rgba(125,211,252,.14)}
.admin-page .table-wrap{overflow:auto;border-radius:14px;border:1px solid var(--stroke);background:rgba(0,0,0,.12)}
.admin-page .table{width:100%;border-collapse:separate;border-spacing:0;min-width:720px}
.admin-page .table th,.admin-page .table td{padding:10px 10px;border-bottom:1px solid rgba(255,255,255,.08);vertical-align:top}
.admin-page .table th{position:sticky;top:0;background:rgba(10,16,30,.92);text-align:left;font-size:.9rem;color:rgba(255,255,255,.82);z-index:1}
.admin-page .table tr:hover td{background:rgba(255,255,255,.04)}
.admin-page .table tr.selected td{background:rgba(125,211,252,.09);outline:1px solid rgba(125,211,252,.18)}
.admin-page .ua{max-width:520px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:.92}
.admin-page .hidden{display:none}

.admin-page .btn{appearance:none;border:1px solid rgba(125,211,252,.28);background:rgba(125,211,252,.12);color:var(--text);padding:10px 12px;border-radius:12px;cursor:pointer;font-weight:700;display:inline-flex;align-items:center;justify-content:center;gap:8px}
.admin-page .btn:hover{background:rgba(125,211,252,.16);border-color:rgba(125,211,252,.42)}
.admin-page .btn.secondary{border-color:rgba(255,255,255,.16);background:rgba(255,255,255,.06)}
.admin-page .btn.secondary:hover{background:rgba(255,255,255,.10)}
.admin-page .btn.danger{border-color:rgba(251,113,133,.30);background:rgba(251,113,133,.12)}
.admin-page .btn.danger:hover{background:rgba(251,113,133,.16);border-color:rgba(251,113,133,.42)}

.admin-page .chart-canvas{width:100%;height:auto;border-radius:14px;border:1px solid var(--stroke);background:rgba(0,0,0,.12)}

.admin-page .flash-list{display:flex;flex-direction:column;gap:10px;margin:0 0 12px}
.admin-page .flash{padding:10px 12px;border-radius:14px;border:1px solid var(--stroke);background:rgba(0,0,0,.14)}
.admin-page .flash.success{border-color:rgba(45,212,191,.30);background:rgba(45,212,191,.10)}
.admin-page .flash.error{border-color:rgba(251,113,133,.30);background:rgba(251,113,133,.10)}
.admin-page .flash.warning{border-color:rgba(251,191,36,.30);background:rgba(251,191,36,.10)}

.admin-page .admin-wrap{min-height:60vh;display:grid;place-items:center;padding:22px 0}
.admin-page .admin-card{width:min(520px,100%);background:var(--card2);border:1px solid var(--stroke);border-radius:var(--r);box-shadow:var(--shadow);padding:18px}
.admin-page .admin-card form{display:flex;flex-direction:column;gap:10px}
.admin-page .admin-card label{font-weight:700;font-size:.92rem;color:rgba(255,255,255,.82)}
.admin-page input{padding:10px 12px;border-radius:12px;border:1px solid var(--stroke);background:rgba(0,0,0,.16);color:var(--text);outline:none}
.admin-page input:focus{border-color:rgba(125,211,252,.35);box-shadow:0 0 0 3px rgba(125,211,252,.14)}

/* ----------------------------
   Header rows (cards)
---------------------------- */
.admin-page .card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:10px}
.admin-page .card-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.admin-page .btn.btn-xs{padding:8px 10px;border-radius:10px;font-weight:800}

/* ----------------------------
   API badges
---------------------------- */
.admin-page .api-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.admin-page .api-badges{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.admin-page .api-badge{font-size:.78rem;font-weight:900;letter-spacing:.35px;padding:.18rem .52rem;border-radius:999px;border:1px solid var(--stroke);background:rgba(0,0,0,.12);opacity:.95}
.admin-page .api-badge.live{border-color:rgba(45,212,191,.45);background:rgba(45,212,191,.12)}
.admin-page .api-badge.warn{border-color:rgba(251,191,36,.45);background:rgba(251,191,36,.12)}
.admin-page .api-badge.err{border-color:rgba(251,113,133,.45);background:rgba(251,113,133,.12)}

/* Featured API (WeatherAPI + Open‑Meteo) */
.admin-page .api-feature{position:relative;overflow:hidden}
.admin-page .api-feature:before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(800px 260px at 20% 10%, rgba(125,211,252,.12), transparent 55%)}
.admin-page .api-feature .api-desc{margin:.35rem 0 0;font-weight:700}
.admin-page .api-feature .api-help{margin:.35rem 0 0;line-height:1.35}
.admin-page .api-feature .api-error{margin-top:.55rem}

/* ----------------------------
   Layout width + density modes
---------------------------- */
.admin-page{max-width:1280px;margin:0 auto;padding:0 14px}
.admin-page.mode-wide{max-width:1620px}
.admin-page.mode-wide .admin-shell{grid-template-columns:310px minmax(0,1fr)}

.admin-page.mode-compact .card{padding:12px}
.admin-page.mode-compact .kpi-num{font-size:1.85rem}
.admin-page.mode-compact .pill{font-size:.82rem}
.admin-page.mode-compact .table th,.admin-page.mode-compact .table td{padding:8px 10px}
.admin-page.mode-compact .table-search{padding:9px 11px}
.admin-page.mode-compact .btn{padding:9px 11px}

/* ----------------------------
   Theme: light (admin only)
---------------------------- */
.admin-page.theme-light{
  --bg:#f6f8ff;
  --bg2:#ffffff;
  --card:rgba(255,255,255,.92);
  --card2:rgba(255,255,255,.96);
  --stroke:rgba(15,23,42,.12);
  --text:#0b1220;
  --muted:#415070;
  --shadow:0 16px 42px rgba(2,6,23,.12);
}
.admin-page.theme-light .badge{background:rgba(2,6,23,.04);color:rgba(2,6,23,.75)}
.admin-page.theme-light .table-wrap{background:rgba(2,6,23,.03)}
.admin-page.theme-light .table th{background:rgba(255,255,255,.95);color:rgba(2,6,23,.78)}
.admin-page.theme-light .chart-canvas{background:rgba(2,6,23,.03)}


/* Timestamp (czytelna godzina) */
.admin-page .ts{font-variant-numeric:tabular-nums;white-space:nowrap}



/* -------------------------
   API Monitoring (PRO+)
------------------------- */
.apiGrid{
  display:grid;
  grid-template-columns: repeat( auto-fit, minmax(240px, 1fr) );
  gap: 12px;
}
.apiCard{
  display:block;
  text-decoration:none;
  color: inherit;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(0,0,0,0.18);
  border-radius: 16px;
  padding: 12px 12px 10px;
  position: relative;
  overflow: hidden;
}
.admin2.theme-light .apiCard{
  background: rgba(255,255,255,0.78);
  border-color: rgba(0,0,0,0.10);
}
.apiCard__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.apiCard__title{
  font-weight: 700;
  letter-spacing: .2px;
}
.apiDot{
  width: 12px; height: 12px; border-radius: 99px;
  background: rgba(255,255,255,0.35);
  box-shadow: 0 0 0 4px rgba(255,255,255,0.06);
  flex: 0 0 auto;
}
.apiDot.ok{ background: rgba(54, 215, 138, 0.95); box-shadow: 0 0 0 4px rgba(54,215,138,0.18); }
.apiDot.warn{ background: rgba(255, 193, 7, 0.95); box-shadow: 0 0 0 4px rgba(255,193,7,0.18); }
.apiDot.error{ background: rgba(255, 77, 77, 0.95); box-shadow: 0 0 0 4px rgba(255,77,77,0.18); }

.apiCard__meta{
  margin-top: 10px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px 10px;
  font-size: .92rem;
}
.apiKV .k{ color: rgba(255,255,255,0.62); font-size:.82rem; }
.admin2.theme-light .apiKV .k{ color: rgba(0,0,0,0.55); }
.apiKV .v{ font-weight:600; }
.apiCard__foot{
  margin-top: 10px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.apiCard__hint{
  color: rgba(255,255,255,0.62);
  font-size: .86rem;
  overflow:hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.admin2.theme-light .apiCard__hint{ color: rgba(0,0,0,0.55); }

.apiMeta{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 10px 12px;
  margin-top: 12px;
}
.apiMeta__item{
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(0,0,0,0.14);
  border-radius: 14px;
  padding: 10px;
}
.admin2.theme-light .apiMeta__item{
  background: rgba(255,255,255,0.80);
  border-color: rgba(0,0,0,0.10);
}
.apiCharts{
  margin-top: 14px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
@media (max-width: 980px){
  .apiCharts{ grid-template-columns: 1fr; }
}
.chartCard{
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(0,0,0,0.12);
  border-radius: 16px;
  padding: 10px;
}
.admin2.theme-light .chartCard{
  background: rgba(255,255,255,0.80);
  border-color: rgba(0,0,0,0.10);
}
.chartCard__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom: 8px;
}
.chartCard__title{ font-weight:700; }
.mono{ font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; font-size:.9rem; }

.btn.tiny{ padding: 6px 10px; border-radius: 999px; font-size: .86rem; }

/* Dots (status) */
.dot{ width:10px; height:10px; border-radius:99px; display:inline-block; background:rgba(255,255,255,0.25); }
.dot--ok{ background: rgba(54, 215, 138, 0.95); box-shadow: 0 0 0 4px rgba(54,215,138,0.16); }
.dot--warn{ background: rgba(255, 193, 7, 0.95); box-shadow: 0 0 0 4px rgba(255,193,7,0.16); }
.dot--bad{ background: rgba(255, 77, 77, 0.95); box-shadow: 0 0 0 4px rgba(255,77,77,0.16); }
.dot--unknown{ background: rgba(255,255,255,0.28); box-shadow: 0 0 0 4px rgba(255,255,255,0.08); }



/* Pulsating API dots + clickable button */
.apiDotBtn{
  border:0;
  background:transparent;
  padding:0;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
}
.apiDot{
  position:relative;
}
.apiDot.ok::after,
.apiDot.error::after,
.apiDot.warn::after{
  content:"";
  position:absolute;
  inset:-6px;
  border-radius:999px;
  opacity:.0;
  animation:pulse 1.6s ease-out infinite;
}
.apiDot.ok::after{ box-shadow: 0 0 0 0 rgba(54,215,138,.45); }
.apiDot.warn::after{ box-shadow: 0 0 0 0 rgba(255,193,7,.45); }
.apiDot.error::after{ box-shadow: 0 0 0 0 rgba(255,99,132,.45); }

@keyframes pulse{
  0%{ opacity:.0; transform:scale(.85); }
  15%{ opacity:.55; }
  70%{ opacity:0; transform:scale(1.65); }
  100%{ opacity:0; transform:scale(1.65); }
}

/* Mini API grid on overview */
.apiMiniGrid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:12px;
}
.apiMini{
  display:flex;
  justify-content:space-between;
  gap:10px;
  padding:12px;
  border:1px solid var(--stroke);
  border-radius:14px;
  background: rgba(255,255,255,0.03);
}
.apiMini__left{ display:flex; align-items:center; gap:10px; min-width:0; }
.apiMini__title{ font-weight:700; }
.apiMini__right{ text-align:right; }

@media (max-width: 980px){
  .apiMiniGrid{ grid-template-columns: 1fr; }
}

/* Status modal */
.statusModal{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  z-index:9999;
  padding:18px;
  background: rgba(0,0,0,.55);
}
.statusModal.is-open{ display:flex; }
.statusModal__box{
  width:min(720px, 96vw);
  border-radius:18px;
  border:1px solid var(--stroke);
  background: rgba(15, 26, 47, .96);
  box-shadow: 0 24px 70px rgba(0,0,0,.55);
  padding:16px;
}
.statusModal__head{ display:flex; justify-content:space-between; align-items:flex-start; gap:12px; }
.statusModal__title{ font-weight:800; font-size:1.05rem; margin:0; }
.statusModal__close{ border:1px solid var(--stroke); background: rgba(255,255,255,.06); border-radius:12px; padding:6px 10px; cursor:pointer; }
.statusModal__body{ margin-top:10px; display:grid; gap:10px; }
.statusModal__pill{
  display:inline-flex; align-items:center; gap:8px;
  border:1px solid var(--stroke); border-radius:999px; padding:6px 10px;
  background: rgba(255,255,255,.05);
  width:fit-content;
}
.statusModal__msg{ white-space:pre-wrap; line-height:1.35; }


/* Tools / KPIs / Charts */
.admin-page .kpis{
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap:12px;
  margin-top:12px;
}
@media (max-width: 980px){
  .admin-page .kpis{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
.admin-page .kpi{
  background: rgba(0,0,0,.16);
  border: 1px solid var(--stroke);
  border-radius: var(--r);
  padding: 12px 14px;
}
.admin-page .kpi__label{ font-size: 12px; color: rgba(255,255,255,.70); }
.admin-page .kpi__value{ font-size: 22px; font-weight: 800; margin-top: 4px; }

.admin-page .chartGrid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:12px;
  margin-top:12px;
}
@media (max-width: 980px){
  .admin-page .chartGrid{ grid-template-columns: 1fr; }
}
.admin-page .chartBox{
  background: rgba(0,0,0,.10);
  border: 1px solid var(--stroke);
  border-radius: var(--r);
  padding: 12px;
}
.admin-page .chartHead{ display:flex; align-items:center; justify-content:space-between; margin-bottom:8px; }
.admin-page .chartCanvas{ width:100%; height:260px; display:block; }
.admin-page .card__title.small{ font-size: 14px; }

.admin-page .chartEmpty{
  display:grid;
  place-items:center;
  min-height:120px;
  border:1px dashed rgba(255,255,255,.18);
  border-radius:14px;
  background: rgba(0,0,0,.08);
  color: rgba(255,255,255,.78);
  font-weight: 800;
  letter-spacing: .2px;
}
.admin-page.theme-light .chartEmpty{border-color: rgba(15,23,42,.18); color: rgba(2,6,23,.72); background: rgba(2,6,23,.03)}
.admin-page .chartEmpty.is-hidden{display:none}


/* Admin reply for opinions (PRO) */
.op-admin-reply{
  margin-top: 10px;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(255, 215, 0, .08);
  border: 1px solid rgba(255, 215, 0, .20);
}
.op-admin-reply__label{
  font-size: 12px;
  opacity: .8;
  margin-bottom: 6px;
}
.op-admin-reply__text{
  font-size: 14px;
  line-height: 1.35;
}

.op-admin-replyform{
  display: flex;
  gap: 8px;
  align-items: center;
  margin-top: 10px;
}
.op-admin-replyform__input{
  flex: 1;
  min-width: 160px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.20);
  color: inherit;
}
.op-admin-replyform__input::placeholder{ opacity:.65; }
.op-admin-replyform__btn{
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.08);
  color: inherit;
  cursor: pointer;
}
.op-admin-replyform__btn:hover{ background: rgba(255,255,255,.12); }
.muted{ opacity:.7; font-size: 12px; }
.sr-only{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }

/* Failsafe: mirror preferences on <body> (in case root classes are overridden) */
body.admin-density-wide .admin-page{max-width:1600px}
body.admin-density-compact .admin-page{max-width:1280px}
body.admin-theme-light .admin-page{ }


/* ----------------------------
   VPS / System stats (PRO)
---------------------------- */
.admin-page .vpsGrid{
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap:12px;
}
@media (max-width: 1100px){
  .admin-page .vpsGrid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 640px){
  .admin-page .vpsGrid{ grid-template-columns: 1fr; }
}

.admin-page .vpsCard{
  background: var(--card);
  border:1px solid var(--stroke);
  border-radius: var(--r);
  padding:14px;
  box-shadow: var(--shadow);
}
.admin-page .vpsHead{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px}
.admin-page .vpsTitle{font-weight:900}
.admin-page .vpsBadge{
  font-size:.85rem;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--stroke);
  background: rgba(255,255,255,.06);
  white-space:nowrap;
}
.admin-page .vpsBadge.ok{border-color:rgba(45,212,191,.40);background:rgba(45,212,191,.10)}
.admin-page .vpsBadge.warn{border-color:rgba(251,191,36,.45);background:rgba(251,191,36,.10)}
.admin-page .vpsBadge.bad{border-color:rgba(251,113,133,.45);background:rgba(251,113,133,.10)}

.admin-page .vpsRow{display:flex;justify-content:space-between;align-items:center;gap:10px}
.admin-page .vpsVal{font-weight:800}
.admin-page .vpsList{display:flex;flex-direction:column;gap:10px}
.admin-page .vpsItem{padding:10px;border-radius:14px;border:1px solid var(--stroke);background:rgba(255,255,255,.04)}
.admin-page .progress{height:10px;border-radius:999px;background:rgba(255,255,255,.07);overflow:hidden;border:1px solid var(--stroke);margin-top:8px}
.admin-page .progress > span{display:block;height:100%;width:0%;background:linear-gradient(90deg, rgba(125,211,252,.9), rgba(45,212,191,.9))}
.admin-page .vpsTableWrap{overflow:auto}
.admin-page .vpsTable{width:100%;border-collapse:separate;border-spacing:0}
.admin-page .vpsTable th,.admin-page .vpsTable td{padding:10px 10px;border-bottom:1px solid var(--stroke);text-align:left;font-size:.95rem}
.admin-page .vpsTable th{font-weight:900;color:var(--muted)}
.admin-page .vpsServices{display:flex;flex-direction:column;gap:8px}
.admin-page .vpsServices .svc{
  display:flex;justify-content:space-between;align-items:center;gap:10px;
  padding:10px;border-radius:14px;border:1px solid var(--stroke);background:rgba(255,255,255,.04)
}
.admin-page .vpsServices .svc.ok{border-color:rgba(45,212,191,.35)}
.admin-page .vpsServices .svc.warn{border-color:rgba(251,191,36,.40)}
.admin-page .vpsServices .svc.bad{border-color:rgba(251,113,133,.40)}



/* ============================
   SaaS Dashboard (Ultra PRO) — Mobile-first refinements
   (adds only; does not remove existing styles)
============================ */
.admin-page{
  --space-1:8px;
  --space-2:12px;
  --space-3:16px;
  --space-4:22px;
  --space-5:28px;
  --ring: 0 0 0 3px rgba(125,211,252,.18);
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Liberation Sans", sans-serif;
  letter-spacing: .1px;
}

/* More SaaS-like topbar */
.admin-page .admin-topbar{
  border:1px solid var(--stroke);
  border-radius: calc(var(--r) + 6px);
  padding: var(--space-3);
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,0));
  box-shadow: var(--shadow);
}
.admin-page .admin-topbar h1{
  font-size: 1.35rem;
  line-height: 1.15;
  letter-spacing: .2px;
}
.admin-page .admin-actions{ gap:8px; }

/* Button polish */
.admin-page .btn{
  border-radius: 14px;
  padding: 10px 12px;
  box-shadow: 0 10px 25px rgba(0,0,0,.18);
}
.admin-page .btn:focus{ outline:none; box-shadow: var(--shadow), var(--ring); }

/* Card polish */
.admin-page .card{
  border-radius: calc(var(--r) + 6px);
  background: radial-gradient(1200px 420px at 0% 0%, rgba(125,211,252,.08), rgba(0,0,0,0)) , var(--card);
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 18px 55px rgba(0,0,0,.32);
}
.admin-page .card:hover{ border-color: rgba(125,211,252,.28); }
.admin-page .card-head{ gap:12px; }

/* Softer KPI typography */
.admin-page .kpi-num{
  font-size: clamp(1.65rem, 4.4vw, 2.2rem);
  line-height: 1.05;
  letter-spacing: .3px;
}

/* Grids: prefer auto-fit on wide screens */
@media (min-width: 1100px){
  .admin-page .grid-4{ grid-template-columns: repeat(4, minmax(0, 1fr)); }
}

/* Mobile: make actions compact (icon-first) */
@media (max-width: 640px){
  .admin-page{ padding: 0 10px 18px; }
  .admin-page .admin-topbar{
    padding: 12px;
    margin: 10px 0 10px;
  }
  .admin-page .admin-topbar h1{ font-size: 1.1rem; }
  .admin-page .admin-actions .btn{
    min-width: auto !important;
    padding: 10px 10px;
    border-radius: 14px;
  }
  /* Hide long toggle labels if any */
  .admin-page .admin-toggle{ min-width: auto; }
}

/* Sidebar: clearer active state */
.admin-page .nav-item.active{
  background: rgba(125,211,252,.12);
  border-color: rgba(125,211,252,.35);
  box-shadow: inset 0 0 0 1px rgba(125,211,252,.15);
}

/* Tables / lists: prevent horizontal overflow on mobile */
.admin-page .table-wrap,
.admin-page table{
  width:100%;
}
.admin-page .table-wrap{ overflow-x:auto; -webkit-overflow-scrolling: touch; }

/* Reduce overly-long numbers in technical fields */
.admin-page .mono, .admin-page code{ font-variant-numeric: tabular-nums; }

/* --- PRO KPIs + inputs --- */
.kpiRow{ display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:12px; }
@media (max-width: 900px){ .kpiRow{ grid-template-columns: 1fr; } }
.kpi{ background: rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); border-radius: 14px; padding:12px 14px; }
.kpi__label{ color: rgba(255,255,255,.70); font-size:.9rem; }
.kpi__value{ font-weight: 900; letter-spacing:.2px; font-size: 1.05rem; margin-top:4px; }
.input{ background: rgba(0,0,0,.35); border:1px solid rgba(255,255,255,.12); color: #fff; border-radius: 12px; padding: 10px 12px; outline:none; }
.input:focus{ border-color: rgba(120,180,255,.55); box-shadow: 0 0 0 4px rgba(120,180,255,.12); }

/* --- Switch (maintenance toggles) --- */
.switch{ position:relative; display:inline-block; width:44px; height:24px; }
.switch input{ opacity:0; width:0; height:0; }
.slider{ position:absolute; cursor:pointer; top:0; left:0; right:0; bottom:0; background: rgba(255,255,255,.12); border-radius: 999px; transition:.2s; border:1px solid rgba(255,255,255,.14); }
.slider:before{ position:absolute; content:""; height:18px; width:18px; left:3px; top:2px; background:#fff; border-radius:999px; transition:.2s; }
.switch input:checked + .slider{ background: rgba(0,180,120,.45); border-color: rgba(0,180,120,.55); }
.switch input:checked + .slider:before{ transform: translateX(20px); }
