/* ============================================================
   APK CONSOLE — Midnight Indigo design system
   ============================================================ */
*,*::before,*::after{ box-sizing:border-box }
html,body{ margin:0; padding:0 }

:root{
  --bg:#0a0a1a;
  --bg-2:#0d0d22;
  --surface:#141432;
  --surface-2:#1a1a40;
  --surface-3:#22224d;
  --line:rgba(255,255,255,.06);
  --line-2:rgba(255,255,255,.10);
  --indigo:#4f46e5;
  --indigo-2:#6366f1;
  --indigo-glow:rgba(79,70,229,.45);
  --indigo-soft:rgba(79,70,229,.12);
  --text:#e8ecff;
  --text-dim:#b6bce0;
  --muted:#8a8fb5;
  --success:#22c55e;
  --warning:#f59e0b;
  --danger:#ef4444;
  --radius:14px;
  --radius-sm:10px;
  --shadow-lg:0 30px 60px -20px rgba(2,4,40,.6), 0 0 0 1px var(--line);
  --shadow-glow:0 0 30px var(--indigo-glow);
  --font:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,Menlo,Consolas,monospace;
}

html,body{
  background: radial-gradient(1200px 800px at 80% -10%, rgba(79,70,229,.18), transparent 60%),
              radial-gradient(900px 700px at -10% 110%, rgba(99,102,241,.12), transparent 60%),
              var(--bg);
  color:var(--text);
  font-family:var(--font);
  font-size:14px;
  line-height:1.5;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{ color:inherit; text-decoration:none }
button{ font-family:inherit }

/* ===================== LOGIN ===================== */
.login-body{
  min-height:100vh; display:grid; place-items:center;
  background:
    radial-gradient(800px 600px at 50% -10%, rgba(79,70,229,.35), transparent 60%),
    radial-gradient(600px 500px at 80% 100%, rgba(99,102,241,.18), transparent 60%),
    var(--bg);
  position:relative; overflow:hidden;
}
.login-bg-grid{
  position:absolute; inset:0; pointer-events:none; opacity:.35;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 44px 44px;
  mask-image: radial-gradient(circle at 50% 40%, #000 0, transparent 70%);
}
.login-card{
  position:relative; z-index:2;
  width:min(420px,92vw);
  background:linear-gradient(180deg, rgba(20,20,50,.85), rgba(10,10,26,.85));
  backdrop-filter:blur(20px);
  border:1px solid var(--line-2);
  border-radius:20px;
  padding:36px 32px;
  box-shadow:var(--shadow-lg), 0 0 80px rgba(79,70,229,.15);
}
.login-logo{ display:flex; align-items:center; gap:12px; margin-bottom:22px }
.login-logo-mark{
  width:42px; height:42px; border-radius:12px;
  background:linear-gradient(135deg,var(--indigo),var(--indigo-2));
  display:grid; place-items:center; font-size:22px; color:#fff;
  box-shadow:0 0 24px var(--indigo-glow);
}
.login-logo-text{ font-weight:800; letter-spacing:.5px; font-size:18px }
.login-logo-text span{ color:var(--indigo-2) }
.login-card h1{ margin:0 0 18px; font-size:22px; font-weight:700 }
.login-card label{ display:block; font-size:12px; color:var(--muted); margin-bottom:14px; font-weight:600; text-transform:uppercase; letter-spacing:.5px }
.login-card input{
  display:block; width:100%; margin-top:6px;
  background:var(--surface); border:1px solid var(--line-2); color:var(--text);
  padding:13px 14px; border-radius:10px; font-size:14px; font-family:inherit;
  transition:border-color .15s, box-shadow .15s;
}
.login-card input:focus{ outline:none; border-color:var(--indigo); box-shadow:0 0 0 3px var(--indigo-soft) }
.login-card .hint{ color:var(--muted); font-size:12px; margin:14px 0 0; text-align:center }

/* ===================== SHELL ===================== */
.app-shell{ min-height:100vh }
.shell{ display:flex; min-height:100vh }

/* SIDEBAR */
.sb{
  width:240px; flex-shrink:0;
  background:linear-gradient(180deg, rgba(20,20,50,.6), rgba(10,10,26,.6));
  backdrop-filter:blur(20px);
  border-right:1px solid var(--line);
  display:flex; flex-direction:column;
  position:sticky; top:0; height:100vh;
  transition:width .25s ease;
  z-index:20;
}
.sb-brand{ padding:22px 20px 18px; display:flex; align-items:center; gap:10px; border-bottom:1px solid var(--line) }
.sb-mark{
  width:34px; height:34px; flex-shrink:0; border-radius:10px;
  background:linear-gradient(135deg,var(--indigo),var(--indigo-2));
  display:grid; place-items:center; color:#fff; font-size:18px;
  box-shadow:0 0 20px var(--indigo-glow);
}
.sb-name{ font-weight:800; letter-spacing:.5px; white-space:nowrap; overflow:hidden }
.sb-name span{ color:var(--indigo-2) }

.sb-toggle{
  position:absolute; top:30px; right:-12px; z-index:30;
  width:24px; height:24px; border-radius:50%;
  background:var(--surface-2); border:1px solid var(--line-2); color:var(--text);
  cursor:pointer; font-size:14px; line-height:1;
  display:none;
}
@media (min-width:900px){ .sb-toggle{ display:grid; place-items:center } }
.sb.is-collapsed .sb-toggle{ transform:rotate(180deg) }

.sb-nav{ flex:1; overflow-y:auto; padding:18px 12px }
.sb-section{
  font-size:10px; font-weight:700; letter-spacing:1.2px;
  color:var(--muted); text-transform:uppercase;
  padding:14px 10px 8px;
}
.sb-link{
  display:flex; align-items:center; gap:12px;
  padding:10px 12px; border-radius:10px;
  color:var(--text-dim); font-weight:500; font-size:14px;
  transition:background .15s, color .15s, box-shadow .15s;
  position:relative; white-space:nowrap;
}
.sb-link:hover{ background:var(--surface-2); color:var(--text) }
.sb-link.is-active{
  background:linear-gradient(90deg, var(--indigo-soft), transparent);
  color:#fff;
  box-shadow:inset 3px 0 0 var(--indigo), 0 0 20px -8px var(--indigo-glow);
}
.sb-ic{ width:18px; height:18px; flex-shrink:0; opacity:.85 }
.sb-link.is-active .sb-ic{ opacity:1; color:var(--indigo-2) }

.sb-foot{ padding:14px; border-top:1px solid var(--line) }
.sb-user{ display:flex; align-items:center; gap:10px; padding:6px; border-radius:10px; background:var(--surface) }
.sb-ava{
  width:36px; height:36px; border-radius:50%; flex-shrink:0;
  background:linear-gradient(135deg,var(--indigo),var(--indigo-2));
  display:grid; place-items:center; color:#fff; font-weight:700; font-size:14px;
  box-shadow:0 0 12px var(--indigo-glow);
}
.sb-uinfo{ flex:1; min-width:0; overflow:hidden }
.sb-uname{ font-size:13px; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis }
.sb-urole{ font-size:11px; color:var(--muted); text-transform:uppercase; letter-spacing:.5px }
.sb-out{
  width:32px; height:32px; flex-shrink:0; border-radius:8px;
  background:var(--surface-2); display:grid; place-items:center; font-size:14px; color:var(--text-dim);
  transition:background .15s, color .15s;
}
.sb-out:hover{ background:var(--danger); color:#fff }

/* Sidebar colapsada */
.sb.is-collapsed{ width:72px }
.sb.is-collapsed .sb-name,
.sb.is-collapsed .sb-lbl,
.sb.is-collapsed .sb-section,
.sb.is-collapsed .sb-uinfo,
.sb.is-collapsed .sb-out{ display:none }
.sb.is-collapsed .sb-brand{ justify-content:center; padding:22px 0 18px }
.sb.is-collapsed .sb-link{ justify-content:center; padding:10px }
.sb.is-collapsed .sb-user{ justify-content:center }

/* Mobile drawer */
@media (max-width:899px){
  .sb{ position:fixed; transform:translateX(-100%); box-shadow:var(--shadow-lg) }
  .sb.is-open{ transform:none }
}

/* MAIN */
.main{ flex:1; min-width:0; display:flex; flex-direction:column }

/* TOPBAR */
.tb{
  position:sticky; top:0; z-index:10;
  display:flex; align-items:center; gap:18px;
  padding:14px 26px;
  background:linear-gradient(180deg, rgba(10,10,26,.85), rgba(10,10,26,.55));
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.tb-burger{
  display:none; background:var(--surface); border:1px solid var(--line-2);
  color:var(--text); width:38px; height:38px; border-radius:10px; cursor:pointer; font-size:18px;
}
@media (max-width:899px){ .tb-burger{ display:block } }
.tb-title{ font-size:18px; font-weight:700; flex:1; min-width:0 }
.tb-actions{ display:flex; gap:10px; align-items:center }
.tb-pill{
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 14px; border-radius:999px;
  background:var(--surface); border:1px solid var(--line-2);
  font-size:13px; color:var(--text-dim); transition:background .15s, color .15s;
}
.tb-pill:hover{ background:var(--surface-2); color:#fff }

/* COUNTDOWN */
.tb-countdown{
  display:flex; align-items:center; gap:14px;
  padding:8px 16px; border-radius:12px;
  background:linear-gradient(135deg, var(--indigo-soft), transparent);
  border:1px solid var(--line-2);
  transition:background .3s, border-color .3s, box-shadow .3s;
}
.tb-cd-label{ font-size:11px; color:var(--muted); text-transform:uppercase; letter-spacing:.6px; font-weight:600 }
.tb-cd-value{ font-family:var(--mono); font-size:16px; font-weight:700; color:#fff; letter-spacing:.5px }
.tb-cd-value b{ font-variant-numeric:tabular-nums; min-width:2ch; display:inline-block; text-align:center }
.tb-cd-value i{ color:var(--muted); font-style:normal; font-weight:500; margin:0 4px 0 1px; font-size:11px }
.tb-countdown.is-warn{ background:linear-gradient(135deg, rgba(245,158,11,.18), transparent); border-color:rgba(245,158,11,.35) }
.tb-countdown.is-warn .tb-cd-value{ color:var(--warning) }
.tb-countdown.is-crit{ background:linear-gradient(135deg, rgba(239,68,68,.22), transparent); border-color:rgba(239,68,68,.45); box-shadow:0 0 20px rgba(239,68,68,.25); animation:pulse-crit 1.4s ease-in-out infinite }
.tb-countdown.is-crit .tb-cd-value{ color:var(--danger) }
@keyframes pulse-crit{ 50%{ box-shadow:0 0 28px rgba(239,68,68,.5) } }

/* CONTEÚDO */
.content{ padding:28px 26px 48px; max-width:1400px; width:100%; margin:0 auto }

/* ===================== COMPONENTS ===================== */
.btn-primary{
  display:inline-flex; align-items:center; gap:8px;
  background:linear-gradient(135deg,var(--indigo),var(--indigo-2));
  color:#fff; border:none; cursor:pointer;
  padding:11px 20px; border-radius:10px;
  font-weight:600; font-size:14px;
  box-shadow:0 6px 20px -6px var(--indigo-glow);
  transition:transform .12s, box-shadow .15s;
}
.btn-primary:hover{ transform:translateY(-1px); box-shadow:0 10px 28px -6px var(--indigo-glow) }
.btn-primary.disabled{ opacity:.5; cursor:not-allowed; pointer-events:none }
.btn-secondary{
  display:inline-flex; align-items:center; gap:8px;
  background:var(--surface-2); border:1px solid var(--line-2); color:var(--text);
  padding:10px 18px; border-radius:10px; font-weight:500; font-size:14px;
  cursor:pointer; transition:background .15s;
}
.btn-secondary:hover{ background:var(--surface-3) }
.btn-danger{
  background:var(--danger); color:#fff; border:none;
  padding:8px 14px; border-radius:8px; cursor:pointer; font-size:13px; font-weight:600;
}
.btn-warn{
  background:var(--warning); color:#0a0a1a; border:none;
  padding:8px 14px; border-radius:8px; cursor:pointer; font-size:13px; font-weight:700;
}

.alert{ padding:12px 16px; border-radius:10px; margin-bottom:14px; font-size:14px; border:1px solid var(--line-2) }
.alert.ok{ background:rgba(34,197,94,.1); border-color:rgba(34,197,94,.3); color:#86efac }
.alert.error{ background:rgba(239,68,68,.1); border-color:rgba(239,68,68,.35); color:#fca5a5 }

code{ background:var(--surface); padding:2px 6px; border-radius:4px; font-family:var(--mono); font-size:.9em }

/* ===================== DASHBOARD ===================== */
.dash-hero{
  display:flex; align-items:center; justify-content:space-between; gap:20px;
  margin-bottom:24px;
}
.dash-hero h1{ margin:0 0 4px; font-size:24px; font-weight:700 }
.dash-hero p{ margin:0; color:var(--muted); font-size:14px }
.counter{
  display:inline-block; margin-left:8px;
  background:rgba(255,255,255,.08); padding:2px 8px; border-radius:999px;
  font-size:11px; font-family:var(--mono); font-weight:600;
}

/* STAT CARDS */
.stat-grid{
  display:grid; grid-template-columns:repeat(4, 1fr); gap:16px; margin-bottom:24px;
}
@media (max-width:1100px){ .stat-grid{ grid-template-columns:repeat(2, 1fr) } }
@media (max-width:560px){ .stat-grid{ grid-template-columns:1fr } }
.stat{
  position:relative;
  background:linear-gradient(180deg, var(--surface), var(--surface-2));
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:20px 18px;
  overflow:hidden;
  transition:transform .15s, box-shadow .15s, border-color .15s;
}
.stat::before{
  content:''; position:absolute; inset:0;
  background:radial-gradient(220px 120px at 100% 0%, var(--indigo-soft), transparent 70%);
  pointer-events:none; opacity:0; transition:opacity .25s;
}
.stat:hover{ transform:translateY(-2px); border-color:var(--line-2); box-shadow:var(--shadow-glow) }
.stat:hover::before{ opacity:1 }
.stat-ic{
  width:38px; height:38px; border-radius:10px;
  background:linear-gradient(135deg, var(--indigo-soft), transparent);
  border:1px solid var(--line-2);
  display:grid; place-items:center; color:var(--indigo-2);
  margin-bottom:14px;
}
.stat-ic svg{ width:18px; height:18px }
.stat-lbl{ font-size:11px; text-transform:uppercase; letter-spacing:.7px; color:var(--muted); font-weight:600 }
.stat-val{ font-family:var(--mono); font-size:30px; font-weight:700; color:#fff; margin-top:6px; line-height:1 }
.stat-sub{ margin-top:8px; font-size:12px; color:var(--text-dim) }
.stat-sub b{ color:var(--success); font-weight:600 }
.stat-sub.warn b{ color:var(--warning) }
.stat-sub.crit b{ color:var(--danger) }

/* PANEL */
.panel{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
}
.panel-head{
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 20px;
  border-bottom:1px solid var(--line);
}
.panel-head h2{ margin:0; font-size:15px; font-weight:600; display:flex; align-items:center; gap:8px }
.panel-head .badge{ background:var(--indigo-soft); color:var(--indigo-2); padding:2px 8px; border-radius:999px; font-size:11px; font-family:var(--mono); font-weight:600 }
.panel-body{ padding:6px }
.panel-body.tight{ padding:0 }

/* GRID 2 cols */
.grid-2{ display:grid; grid-template-columns:2fr 1fr; gap:16px; margin-bottom:16px }
@media (max-width:980px){ .grid-2{ grid-template-columns:1fr } }

/* APPS TABLE (glass rows) */
.apps-table{ display:flex; flex-direction:column }
.apps-table .row{
  display:grid;
  grid-template-columns: 44px 1fr 100px 80px 220px;
  align-items:center; gap:14px;
  padding:12px 14px; border-radius:10px;
  transition:background .15s;
}
.apps-table .row:hover{ background:var(--surface-2) }
.apps-table .row + .row{ margin-top:2px }
.apps-table .ic{ width:44px; height:44px; border-radius:10px; object-fit:cover; background:var(--surface-3); border:1px solid var(--line-2) }
.apps-table .meta .nome{ font-weight:600; color:#fff; font-size:14px }
.apps-table .meta .empresa{ font-size:12px; color:var(--muted); margin-top:2px }
.apps-table .stars{ font-size:11px; color:var(--warning); white-space:nowrap; font-family:var(--mono) }
.apps-table .dl{ font-family:var(--mono); font-size:13px; color:var(--text-dim); font-weight:600 }
.apps-table .actions{ display:flex; gap:4px; justify-content:flex-end }
.apps-table .act{
  width:32px; height:32px; border-radius:8px;
  background:transparent; border:1px solid transparent; color:var(--text-dim);
  display:grid; place-items:center; cursor:pointer; font-size:14px;
  transition:background .12s, color .12s, border-color .12s;
}
.apps-table .act:hover{ background:var(--surface-3); color:#fff; border-color:var(--line-2) }
.apps-table .act.del:hover{ background:var(--danger); color:#fff; border-color:var(--danger) }
.apps-table form{ display:inline-flex; margin:0 }
@media (max-width:780px){
  .apps-table .row{ grid-template-columns: 44px 1fr 140px }
  .apps-table .stars, .apps-table .dl{ display:none }
}

.empty{ padding:40px 20px; text-align:center; color:var(--muted); font-size:14px }

/* TOP LIST (right panel) */
.top-list{ display:flex; flex-direction:column; padding:6px }
.top-list .item{
  display:grid; grid-template-columns:32px 36px 1fr auto; gap:12px; align-items:center;
  padding:10px 14px; border-radius:10px; transition:background .15s;
}
.top-list .item:hover{ background:var(--surface-2) }
.top-list .rank{ font-family:var(--mono); font-weight:700; color:var(--indigo-2); font-size:14px }
.top-list .ic{ width:36px; height:36px; border-radius:8px; object-fit:cover; background:var(--surface-3) }
.top-list .nm{ font-size:13px; font-weight:500; color:#fff; overflow:hidden; text-overflow:ellipsis; white-space:nowrap }
.top-list .dl{ font-family:var(--mono); font-size:12px; color:var(--text-dim) }

/* SPARKLINE / BARS */
.bars{ padding:18px 20px 24px }
.bars-svg{ display:block; width:100%; height:200px }

/* SEARCH (in topbar of list pages) */
.list-head{
  display:flex; align-items:center; justify-content:space-between;
  gap:14px; margin-bottom:14px;
}
.list-head .title{ font-size:15px; font-weight:600; color:var(--text-dim) }
.list-head .search input{
  background:var(--surface); border:1px solid var(--line-2); color:var(--text);
  padding:10px 14px; border-radius:10px; font-size:13px; font-family:inherit; width:280px;
}
.list-head .search input:focus{ outline:none; border-color:var(--indigo); box-shadow:0 0 0 3px var(--indigo-soft) }

/* ===================== FORMS / MODAL-STYLE ===================== */
.modal-style{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:28px 28px 22px;
  max-width:920px; margin:0 auto;
  position:relative;
}
.modal-style h1{ margin:0 0 18px; font-size:20px; font-weight:700 }
.modal-style .close{
  position:absolute; top:16px; right:18px;
  width:32px; height:32px; border-radius:8px;
  background:var(--surface-2); display:grid; place-items:center;
  color:var(--text-dim); font-size:18px; line-height:1;
}
.modal-style .close:hover{ background:var(--danger); color:#fff }

.grid2{ display:grid; grid-template-columns:1fr 1fr; gap:16px }
@media (max-width:640px){ .grid2{ grid-template-columns:1fr } }

.field{ display:flex; flex-direction:column; gap:6px }
.field .lbl, .upload-box .lbl{
  font-size:10px; font-weight:700; letter-spacing:1px; color:var(--muted); text-transform:uppercase;
}
.field input, .field select, .field textarea{
  background:var(--bg-2); border:1px solid var(--line-2); color:var(--text);
  padding:11px 13px; border-radius:10px; font-size:14px; font-family:inherit;
  transition:border-color .15s, box-shadow .15s;
}
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none; border-color:var(--indigo); box-shadow:0 0 0 3px var(--indigo-soft);
}

.upload-box{
  display:flex; flex-direction:column; gap:8px;
  background:var(--bg-2); border:1px dashed var(--line-2); border-radius:12px;
  padding:14px; cursor:pointer; position:relative;
  transition:border-color .15s, background .15s;
}
.upload-box:hover{ border-color:var(--indigo); background:var(--surface) }
.upload-box input[type=file]{ position:absolute; inset:0; opacity:0; cursor:pointer }
.upload-box .ph{ display:flex; align-items:center; gap:12px }
.upload-box .thumb{
  width:54px; height:54px; flex-shrink:0; border-radius:10px;
  background:var(--surface-3); display:grid; place-items:center; font-size:22px;
  object-fit:cover;
}
.upload-box .thumb.apk{ background:linear-gradient(135deg,var(--indigo),var(--indigo-2)); color:#fff; font-weight:700; font-size:13px }
.upload-box .info-txt b{ display:block; font-size:13px; color:#fff }
.upload-box .info-txt p{ margin:2px 0 0; font-size:11px; color:var(--muted) }
.upload-box .badge-ready{
  margin-left:auto; background:var(--success); color:#fff; padding:2px 8px;
  border-radius:999px; font-size:10px; font-weight:700;
}
.upload-box .btn-clear{
  margin-left:auto; width:24px; height:24px; border-radius:50%;
  background:var(--danger); border:none; color:#fff; cursor:pointer; font-size:14px; line-height:1;
}

.foot{
  grid-column:1 / -1; margin-top:6px; padding-top:16px; border-top:1px solid var(--line);
  display:flex; align-items:center; gap:10px; flex-wrap:wrap;
}
.foot .info{ flex:1; color:var(--muted); font-size:12px }

/* OG fieldset (override claro p/ dark) */
.og-fieldset{
  grid-column: 1 / -1; margin-top:8px; padding:16px 18px;
  border:1px dashed var(--line-2); border-radius:12px; background:var(--bg-2);
}
.og-fieldset > legend{ padding:0 8px; font-size:11px; font-weight:700; color:var(--indigo-2); text-transform:uppercase; letter-spacing:1px }
.og-fieldset .og-hint{ margin:0 0 12px; font-size:12px; color:var(--muted) }
.og-fieldset .og-hint a{ color:var(--indigo-2); text-decoration:underline }

/* ===================== USUÁRIOS ===================== */
.users-table{
  width:100%; border-collapse:separate; border-spacing:0 6px;
}
.users-table thead th{
  text-align:left; padding:8px 14px; font-size:11px; color:var(--muted);
  text-transform:uppercase; letter-spacing:.7px; font-weight:600;
}
.users-table tbody tr{ background:var(--surface-2); transition:background .12s }
.users-table tbody tr:hover{ background:var(--surface-3) }
.users-table tbody td{ padding:14px; font-size:14px; vertical-align:middle }
.users-table tbody tr td:first-child{ border-top-left-radius:10px; border-bottom-left-radius:10px }
.users-table tbody tr td:last-child{ border-top-right-radius:10px; border-bottom-right-radius:10px }
.users-table .u-name{ font-weight:600; color:#fff }
.users-table .u-meta{ font-size:12px; color:var(--muted) }
.users-table .u-plan{ font-family:var(--mono); font-weight:700; color:var(--indigo-2) }
.users-table .u-expires{ font-family:var(--mono); font-size:13px }
.users-table .u-expires.warn{ color:var(--warning) }
.users-table .u-expires.crit{ color:var(--danger) }
.users-table .u-expires.ok{ color:var(--success) }
.users-table .u-actions{ display:flex; gap:6px; justify-content:flex-end; flex-wrap:wrap }

.badge-status{
  display:inline-block; padding:3px 10px; border-radius:999px;
  font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.5px;
}
.badge-status.ok{ background:rgba(34,197,94,.15); color:#86efac }
.badge-status.off{ background:rgba(239,68,68,.15); color:#fca5a5 }
.badge-status.master{ background:linear-gradient(135deg,var(--indigo),var(--indigo-2)); color:#fff }

/* Radio plano */
.plan-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:10px; grid-column:1/-1 }
.plan-grid label{
  display:block; padding:14px; border-radius:12px; cursor:pointer;
  background:var(--bg-2); border:1px solid var(--line-2);
  transition:border-color .15s, background .15s, transform .12s;
}
.plan-grid label:hover{ border-color:var(--indigo); transform:translateY(-1px) }
.plan-grid input{ display:none }
.plan-grid input:checked + .plan-content{
  color:#fff;
}
.plan-grid label:has(input:checked){
  background:linear-gradient(135deg, var(--indigo-soft), transparent);
  border-color:var(--indigo);
  box-shadow:0 0 20px var(--indigo-glow);
}
.plan-grid .plan-content{ text-align:center }
.plan-grid .plan-days{ font-family:var(--mono); font-size:28px; font-weight:700; color:#fff }
.plan-grid .plan-lbl{ font-size:12px; color:var(--muted); margin-top:2px; text-transform:uppercase; letter-spacing:.6px }

/* === Screenshots & reviews editor === */
.screens-fieldset, .reviews-fieldset {
  grid-column: 1 / -1;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  padding: 18px 18px 16px;
  background: rgba(20,20,50,.45);
  margin-top: 6px;
}
.screens-fieldset legend, .reviews-fieldset legend {
  font-size: 13px; font-weight: 700; letter-spacing: .04em;
  padding: 0 8px; color: #e8ecff;
}
.shots-list {
  display: grid; gap: 10px;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  margin: 10px 0 12px;
}
.shot-card {
  position: relative; border-radius: 10px; overflow: hidden;
  border: 1px solid rgba(255,255,255,.08); background: #0a0a1a; aspect-ratio: 9/16;
}
.shot-card img { width: 100%; height: 100%; object-fit: cover; display: block; }
.shot-card .shot-actions {
  position: absolute; left: 0; right: 0; bottom: 0;
  display: flex; justify-content: space-between;
  background: linear-gradient(to top, rgba(0,0,0,.85), transparent);
  padding: 6px;
}
.shot-card .shot-actions button {
  background: rgba(0,0,0,.6); color: #fff; border: 1px solid rgba(255,255,255,.2);
  width: 28px; height: 28px; border-radius: 6px; cursor: pointer; font-size: 14px; line-height: 1;
}
.shot-card .shot-actions button:hover { background: #4f46e5; }
.shot-card .badge-new {
  position: absolute; top: 6px; left: 6px;
  background: #4f46e5; color: #fff; font-size: 10px; font-weight: 700;
  padding: 2px 6px; border-radius: 4px; letter-spacing: .05em;
}
.shots-controls { display: flex; align-items: center; gap: 12px; }
.shots-count, .reviews-count {
  color: #8a8fb5; font-size: 12px; font-family: 'JetBrains Mono', monospace;
}
.reviews-list { display: flex; flex-direction: column; gap: 10px; margin: 10px 0 12px; }
.review-card {
  border: 1px solid rgba(255,255,255,.08); border-radius: 10px;
  background: rgba(10,10,26,.55); padding: 12px; display: flex; flex-direction: column; gap: 10px;
}
.review-card .rv-grid {
  display: grid; gap: 10px;
  grid-template-columns: 2fr 1fr 1fr;
}
.review-card .rv-del { align-self: flex-end; padding: 6px 12px; font-size: 12px; }
@media (max-width: 640px) { .review-card .rv-grid { grid-template-columns: 1fr; } }
