/* =====================================================================
   MagoCharge — Painel + Login
   Reaproveita a identidade do site (emerald + mono nos números).
   --brand é injetado por operador (white-label) no <style> inline.
   ===================================================================== */
:root{
  --brand:#12534A; --e900:#08221F; --e800:#0C322D; --green:#16A34A; --bright:#2BD46E; --lime:#C7F25A;
  --ink:#0E1A18; --muted:#5C6B67; --line:#E6EDE9; --paper:#F4F7F5; --card:#FFFFFF;
  --r:14px; --shadow:0 16px 40px -24px rgba(8,34,31,.4);
}
*{box-sizing:border-box}
body{margin:0; font-family:"Inter",system-ui,sans-serif; color:var(--ink); background:var(--paper); -webkit-font-smoothing:antialiased}
h1,h2,h3{font-family:"Space Grotesk","Inter",sans-serif; letter-spacing:-.02em; margin:0}
a{text-decoration:none; color:inherit}
.mono{font-family:"Space Mono",monospace; font-variant-numeric:tabular-nums}
.bolt{display:grid; place-items:center; width:30px; height:30px; border-radius:9px; background:linear-gradient(150deg,var(--brand),var(--e900)); color:var(--lime)}
.bolt svg{width:17px;height:17px}

/* ---------- LOGIN ---------- */
.auth{min-height:100vh; display:grid; grid-template-columns:1fr 1fr; margin:0}
.auth-side{position:relative; overflow:hidden; padding:48px; color:#EAF3EF; display:flex; flex-direction:column; justify-content:space-between;
  background:radial-gradient(120% 90% at 90% -10%, color-mix(in srgb, var(--brand) 70%, #1b6) 0%, transparent 55%), linear-gradient(160deg,var(--brand),var(--e900))}
.auth-side::before{content:""; position:absolute; inset:0; background-image:radial-gradient(rgba(255,255,255,.06) 1px,transparent 1px); background-size:26px 26px; opacity:.5}
.auth-brand{position:relative; display:flex; align-items:center; gap:.6rem; font-family:"Space Grotesk"; font-weight:600; font-size:20px; color:#fff}
.auth-pitch{position:relative; max-width:30ch}
.auth-pitch h2{font-size:2rem; color:#fff; line-height:1.1}
.auth-pitch p{color:#A7C2B9; margin:.8rem 0 1.4rem}
.auth-pitch ul{list-style:none; padding:0; margin:0; display:grid; gap:.7rem}
.auth-pitch li{position:relative; padding-left:1.6rem; color:#C7DBD3; font-size:.96rem}
.auth-pitch li::before{content:""; position:absolute; left:0; top:.45em; width:9px; height:9px; border-radius:50%; background:var(--bright)}
.auth-main{display:grid; place-items:center; padding:32px}
.auth-card{width:100%; max-width:380px}
.auth-card h1{font-size:1.7rem; margin-bottom:.3rem}
.auth-op{color:var(--muted); font-size:.92rem; margin:.2rem 0 1.4rem}
.auth-op strong{color:var(--brand)}
.auth-warn{color:#B45309}
.auth-card label{display:block; font-size:13px; font-weight:600; color:var(--ink); margin:14px 0 6px}
.auth-card input{width:100%; padding:.82rem .9rem; border:1px solid var(--line); border-radius:11px; font:inherit; font-size:15px; background:#fff}
.auth-card input:focus{outline:none; border-color:var(--brand); box-shadow:0 0 0 3px color-mix(in srgb,var(--brand) 18%, transparent)}
.btn-brand{width:100%; margin-top:20px; padding:.85rem; border:0; border-radius:999px; cursor:pointer;
  font:600 15px "Inter"; color:#fff; background:linear-gradient(180deg, color-mix(in srgb,var(--brand) 86%, #fff 0%), var(--brand)); transition:transform .15s, box-shadow .2s}
.btn-brand:hover{transform:translateY(-2px); box-shadow:0 14px 26px -12px color-mix(in srgb,var(--brand) 70%, transparent)}
.auth-back{display:inline-block; margin-top:18px; color:var(--muted); font-size:14px}
.auth-back:hover{color:var(--brand)}

/* alerts */
.alert{padding:.7rem .9rem; border-radius:10px; font-size:14px; margin-bottom:14px; border:1px solid transparent}
.alert-erro{background:#FEF2F2; color:#B91C1C; border-color:#FECACA}
.alert-ok{background:#ECFDF5; color:#047857; border-color:#A7F3D0}
.alert-info{background:#EFF6FF; color:#1D4ED8; border-color:#BFDBFE}

/* ---------- PAINEL ---------- */
.shell{display:grid; grid-template-columns:248px 1fr; min-height:100vh}
.side{background:var(--e900); color:#CFE0DA; display:flex; flex-direction:column; padding:18px 14px; position:sticky; top:0; height:100vh}
.side-brand{display:flex; align-items:center; gap:.6rem; padding:.4rem .5rem 1.2rem; font-family:"Space Grotesk"; font-weight:600; font-size:18px; color:#fff}
.side-nav{display:flex; flex-direction:column; gap:3px; flex:1}
.side-nav a{display:flex; align-items:center; gap:.7rem; padding:.7rem .8rem; border-radius:10px; color:#9FB7AE; font-size:14.5px; font-weight:500; transition:.15s}
.side-nav a svg{width:19px; height:19px; flex:none}
.side-nav a:hover{background:rgba(255,255,255,.05); color:#fff}
.side-nav a.on{background:color-mix(in srgb,var(--brand) 55%, #0000); color:#fff; box-shadow:inset 0 0 0 1px rgba(199,242,94,.18)}
.side-nav a.on svg{color:var(--lime)}
.side-foot{border-top:1px solid rgba(255,255,255,.08); padding-top:12px}
.logout{display:flex; align-items:center; gap:.6rem; padding:.7rem .8rem; border-radius:10px; color:#9FB7AE; font-size:14.5px}
.logout svg{width:18px;height:18px}
.logout:hover{background:rgba(255,255,255,.05); color:#fff}

.main{display:flex; flex-direction:column; min-width:0}
.topbar{display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:22px 30px; background:#fff; border-bottom:1px solid var(--line)}
.top-op{font:600 12px "Space Mono",monospace; letter-spacing:.12em; text-transform:uppercase; color:var(--green)}
.topbar h1{font-size:1.45rem; margin-top:2px}
.top-user{display:flex; align-items:center; gap:.7rem}
.top-user strong{display:block; font-size:14px; line-height:1.1}
.top-user small{color:var(--muted); font-size:12px}
.avatar{width:40px; height:40px; border-radius:50%; display:grid; place-items:center; color:#fff; font-weight:700;
  background:linear-gradient(150deg,var(--brand),var(--e900)); font-family:"Space Grotesk"}
.content{padding:30px; max-width:1180px; width:100%}

/* KPIs */
.kpis{display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-bottom:24px}
.kpi{background:var(--card); border:1px solid var(--line); border-radius:var(--r); padding:20px; display:flex; flex-direction:column; gap:6px}
.kpi-l{font-size:13px; color:var(--muted); font-weight:500}
.kpi-v{font:700 30px/1 "Space Mono",monospace; letter-spacing:-.02em}
.kpi-v small{font-size:15px; color:var(--muted)}
.kpi-s{font-size:12.5px; color:var(--green); font-weight:600}
.kpi-hi{background:linear-gradient(160deg,var(--brand),var(--e900)); border:0; color:#fff}
.kpi-hi .kpi-l{color:#A7C2B9}
.kpi-hi .kpi-s{color:var(--lime)}

/* Card + tabela */
.card{background:var(--card); border:1px solid var(--line); border-radius:var(--r); overflow:hidden}
.card-head{display:flex; align-items:center; justify-content:space-between; padding:18px 22px; border-bottom:1px solid var(--line)}
.card-head h2{font-size:1.15rem}
.link{color:var(--green); font-weight:600; font-size:14px}
.table{width:100%; border-collapse:collapse}
.table th{text-align:left; font:600 11.5px "Space Mono",monospace; letter-spacing:.06em; text-transform:uppercase; color:var(--muted); padding:12px 22px; background:#FAFCFB; border-bottom:1px solid var(--line)}
.table td{padding:13px 22px; border-bottom:1px solid var(--line); font-size:14px}
.table tr:last-child td{border-bottom:0}
.table tbody tr:hover{background:#FAFCFB}
.st{display:inline-block; padding:.25rem .6rem; border-radius:999px; font:600 11.5px "Space Mono",monospace}
.st-ok{background:#ECFDF5; color:#047857}
.st-go{background:#EFF8E8; color:#3f7a12}
.st-mut{background:#F1F5F4; color:#64746F}
.st-err{background:#FEF2F2; color:#B91C1C}
.empty{padding:48px 22px; text-align:center}
.empty p{font-family:"Space Grotesk"; font-weight:600; font-size:1.1rem; margin:0 0 .3rem}
.empty span{color:var(--muted); font-size:.95rem}

/* mobile */
.side-toggle{display:none}
@media (max-width:880px){
  .shell{grid-template-columns:1fr}
  .side{position:fixed; left:0; top:0; z-index:60; width:248px; transform:translateX(-100%); transition:.25s}
  body.side-open .side{transform:none}
  .kpis{grid-template-columns:repeat(2,1fr)}
  .content{padding:20px}
  .table{display:block; overflow-x:auto; white-space:nowrap}
}
@media (max-width:640px){
  .auth{grid-template-columns:1fr}
  .auth-side{display:none}
  .kpis{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){*{transition:none!important}}

/* ---------- Toolbar / botões / formulários ---------- */
.toolbar{display:flex; align-items:center; justify-content:space-between; gap:1rem; margin-bottom:22px; flex-wrap:wrap}
.toolbar .sub{color:var(--muted); font-size:14px}
.btn{display:inline-flex; align-items:center; gap:.5rem; font:600 14px "Inter"; padding:.6rem 1.1rem; border-radius:999px; border:1px solid transparent; cursor:pointer; transition:transform .15s, box-shadow .2s, background .2s}
.btn svg{width:17px;height:17px}
.btn:active{transform:translateY(1px)}
.btn-pri{background:var(--brand); color:#fff}
.btn-pri:hover{transform:translateY(-2px); box-shadow:0 12px 24px -12px color-mix(in srgb,var(--brand) 70%, transparent)}
.btn-soft{background:#fff; border-color:var(--line); color:var(--ink)}
.btn-soft:hover{border-color:var(--brand); color:var(--brand)}
.btn-danger{background:#fff; border-color:#FECACA; color:#B91C1C}
.btn-danger:hover{background:#FEF2F2}
.btn-sm{padding:.4rem .7rem; font-size:13px}

.actions{display:flex; gap:.4rem; justify-content:flex-end}
.iconbtn{display:grid; place-items:center; width:32px; height:32px; border-radius:9px; border:1px solid var(--line); background:#fff; color:var(--muted); cursor:pointer}
.iconbtn svg{width:16px;height:16px}
.iconbtn:hover{border-color:var(--brand); color:var(--brand)}
.iconbtn.danger:hover{border-color:#FECACA; color:#B91C1C; background:#FEF2F2}

.form{background:var(--card); border:1px solid var(--line); border-radius:var(--r); padding:26px; max-width:760px}
.form-grid{display:grid; grid-template-columns:1fr 1fr; gap:16px 20px}
.field{display:flex; flex-direction:column}
.field.full{grid-column:1 / -1}
.field label{font-size:13px; font-weight:600; margin-bottom:6px}
.field .hint{font-size:12px; color:var(--muted); margin-top:5px}
.field input,.field select{padding:.72rem .85rem; border:1px solid var(--line); border-radius:10px; font:inherit; font-size:15px; background:#fff}
.field input:focus,.field select:focus{outline:none; border-color:var(--brand); box-shadow:0 0 0 3px color-mix(in srgb,var(--brand) 16%, transparent)}
.field input[readonly]{background:#F4F7F5; color:var(--muted)}
.form-foot{display:flex; gap:.6rem; align-items:center; margin-top:24px; padding-top:20px; border-top:1px solid var(--line)}

/* status dos carregadores */
.st-disponivel{background:#ECFDF5; color:#047857}
.st-carregando{background:#EFF8E8; color:#3f7a12}
.st-ocupado{background:#FFF7ED; color:#C2410C}
.st-falha{background:#FEF2F2; color:#B91C1C}
.st-offline{background:#F1F5F4; color:#64746F}
.st-indisponivel{background:#F1F5F4; color:#64746F}
.dot-st{display:inline-block; width:8px; height:8px; border-radius:50%; margin-right:.45rem; vertical-align:middle}

/* chips de detalhe */
.detail{display:grid; grid-template-columns:repeat(2,1fr); gap:14px; background:var(--card); border:1px solid var(--line); border-radius:var(--r); padding:24px}
.detail .it{display:flex; flex-direction:column; gap:3px}
.detail .it .k{font:600 11.5px "Space Mono",monospace; letter-spacing:.06em; text-transform:uppercase; color:var(--muted)}
.detail .it .v{font-size:15px}
.qr-token{font-family:"Space Mono",monospace; font-size:13px; background:#F4F7F5; padding:.3rem .6rem; border-radius:7px; display:inline-block}
@media (max-width:640px){.form-grid{grid-template-columns:1fr}.detail{grid-template-columns:1fr}}

/* ---------- Cadastro (form largo) + checkbox ---------- */
.auth-card-wide{max-width:560px}
.auth-grid{display:grid; grid-template-columns:1fr 1fr; gap:14px 16px}
.auth-grid .full{grid-column:1 / -1}
.auth-grid label{display:block; font-size:13px; font-weight:600; margin:0 0 6px}
.auth-grid input,.auth-grid select{width:100%; padding:.72rem .85rem; border:1px solid var(--line); border-radius:10px; font:inherit; font-size:15px; background:#fff}
.auth-grid input:focus,.auth-grid select:focus{outline:none; border-color:var(--brand); box-shadow:0 0 0 3px color-mix(in srgb,var(--brand) 16%, transparent)}
.check{display:flex; align-items:flex-start; gap:.6rem; margin:18px 0 4px; font-size:14px; color:var(--muted)}
.check input{width:18px; height:18px; margin-top:1px; accent-color:var(--brand)}
@media (max-width:560px){.auth-grid{grid-template-columns:1fr}}

/* ---------- Banner de período de teste ---------- */
.trialbar{display:flex; align-items:center; justify-content:space-between; gap:1rem; flex-wrap:wrap;
  background:linear-gradient(180deg,#FFF8E6,#FFF1CC); border:1px solid #F5DE9C; color:#7A5A12;
  padding:.7rem 1rem; border-radius:12px; font-size:14px; margin-bottom:20px}
.trialbar a{font-weight:700; color:#7A5A12; white-space:nowrap}
.trialbar a:hover{text-decoration:underline}
.trialbar.trial-end{background:#FEF2F2; border-color:#FECACA; color:#B91C1C}
.trialbar.trial-end a{color:#B91C1C}

/* ---------- Configurações ---------- */
.color-row{display:flex; align-items:center; gap:.8rem}
input[type=color]{width:54px; height:40px; padding:3px; border:1px solid var(--line); border-radius:10px; background:#fff; cursor:pointer}
.logo-row{display:flex; align-items:center; gap:14px; flex-wrap:wrap}
.logo-prev{height:44px; max-width:160px; object-fit:contain; border:1px solid var(--line); border-radius:8px; padding:4px; background:#fff}
input[type=file]{font-size:14px}
input[type=file]::file-selector-button{margin-right:10px; padding:.5rem .8rem; border:1px solid var(--line); border-radius:999px; background:#fff; cursor:pointer; font:inherit; font-size:13px; color:var(--ink)}
input[type=file]::file-selector-button:hover{border-color:var(--brand); color:var(--brand)}
.badge-cfg{font:600 11.5px "Space Mono",monospace; padding:.3rem .65rem; border-radius:999px}
.badge-cfg.on{background:#ECFDF5; color:#047857}
.badge-cfg.off{background:#F1F5F4; color:#64746F}
