/* DMS Energia - CSS completo restaurado com ajustes da administração */
:root{
    --fundo:#020817;
    --fundo-sec:#061224;
    --painel:#071427;
    --painel-2:#0a1930;
    --borda:rgba(148,163,184,.16);
    --texto:#e5eefc;
    --texto-sec:#94a3b8;
    --azul-1:#38bdf8;
    --azul-2:#2563eb;
    --azul-3:#1d4ed8;
    --verde:#22c55e;
    --amarelo:#f59e0b;
    --vermelho:#ef4444;
    --sombra:0 18px 60px rgba(0,0,0,.34);
    --raio:22px;
    --raio-sm:16px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
    min-height:100vh;
    background:
        radial-gradient(circle at 15% 20%, rgba(59,130,246,.20), transparent 28%),
        radial-gradient(circle at 78% 18%, rgba(59,130,246,.10), transparent 25%),
        radial-gradient(circle at 52% 82%, rgba(37,99,235,.12), transparent 24%),
        linear-gradient(135deg,#020617 0%, #020b1a 38%, #01050f 100%);
    color:var(--texto);
    font-family:Inter, "Segoe UI", Arial, sans-serif;
    line-height:1.45;
}
a{color:#cfe5ff;text-decoration:none}
a:hover{color:#fff}
img{max-width:100%;display:block}
.text-muted{color:var(--texto-sec)}
.text-right{text-align:right}
.text-center{text-align:center}

/* Login */
.auth-shell{height:100vh;min-height:100vh;overflow:hidden;display:grid;grid-template-columns:1.1fr .9fr}
.auth-hero{
    padding:20px 22px 12px;
    border-right:1px solid rgba(59,130,246,.20);
    display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden
}
.auth-hero::before{
    content:"";position:absolute;inset:0;
    background:linear-gradient(90deg, rgba(37,99,235,.12), transparent 45%),
               radial-gradient(circle at 30% 25%, rgba(56,189,248,.12), transparent 26%);
    pointer-events:none;
}
.marca-badge{
    display:inline-flex;align-items:center;gap:12px;padding:10px 14px;border:1px solid rgba(148,163,184,.14);
    background:rgba(9,20,40,.72);border-radius:18px;box-shadow:var(--sombra);width:max-content;backdrop-filter:blur(12px);position:relative;z-index:1
}
.marca-badge img{width:28px;height:28px;object-fit:cover;border-radius:8px}
.marca-texto{font-size:14px;color:#d8e6fa;font-weight:700}
.auth-conteudo{position:relative;z-index:1;max-width:700px;padding:10px 0}
.auth-kicker{color:#d7e6ff;text-transform:uppercase;letter-spacing:.16em;font-size:11px;font-weight:800;margin-bottom:10px}
.auth-titulo{font-size:clamp(28px,3.4vw,52px);line-height:1.02;letter-spacing:-.04em;margin:0 0 12px;max-width:720px}
.auth-subtitulo{max-width:720px;color:var(--texto-sec);font-size:14px;margin:0 0 14px}
.auth-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;max-width:700px}
.feature-card{
    background:linear-gradient(180deg, rgba(9,19,38,.9), rgba(6,14,28,.88));
    border:1px solid var(--borda);border-radius:18px;padding:9px 11px;min-height:66px;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.03)
}
.feature-card h3{margin:0 0 4px;font-size:13px;color:#f0f6ff}
.feature-card p{margin:0;color:var(--texto-sec);font-size:12px;line-height:1.3}
.auth-footer{position:relative;z-index:1;color:#8fa6c6;font-size:12px;padding-top:8px}
.auth-pane{display:flex;align-items:center;justify-content:center;padding:14px}
.auth-card{
    width:min(100%, 380px);background:linear-gradient(180deg, rgba(7,18,37,.95), rgba(4,10,22,.96));
    border:1px solid rgba(148,163,184,.18);border-radius:28px;box-shadow:var(--sombra);padding:16px 16px 10px;position:relative
}
.auth-card::before{
    content:"";position:absolute;inset:0;border-radius:28px;padding:1px;
    background:linear-gradient(180deg, rgba(56,189,248,.28), rgba(37,99,235,.06));
    -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
    -webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none
}
.auth-chip{
    display:inline-flex;align-items:center;justify-content:center;margin:0 auto 10px;padding:6px 12px;border-radius:999px;
    background:rgba(8,39,78,.7);border:1px solid rgba(56,189,248,.18);color:#87d8ff;font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase
}
.auth-logo{width:150px;margin:0 auto 6px;border-radius:10px}
.auth-card h1{margin:0 0 10px;text-align:center;font-size:30px}
.auth-card p{margin:0 0 10px;color:var(--texto-sec);text-align:center;font-size:13px}

/* App */
.layout{min-height:100vh;display:grid;grid-template-columns:260px 1fr}
.sidebar{
    padding:22px 18px;border-right:1px solid rgba(59,130,246,.18);
    background:linear-gradient(180deg, rgba(3,11,24,.94), rgba(4,10,20,.94));
    position:sticky;top:0;height:100vh
}
.brand{
    padding:14px 16px;border:1px solid var(--borda);border-radius:18px;background:rgba(9,20,40,.78);
    font-weight:800;font-size:18px;margin-bottom:18px
}
.brand.brand-logo{
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    gap:8px;
}
.brand-logo-image{
    display:block;
    width:100%;
    max-width:180px;
    height:auto;
    object-fit:contain;
}
.brand small{display:block;font-size:12px;color:var(--texto-sec);font-weight:600;margin-top:0}
.sidebar-section{margin-top:18px}
.sidebar-label{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#8ba1bf;margin:0 0 8px 10px}
.sidebar nav{display:flex;flex-direction:column;gap:8px}
.sidebar nav a{
    display:flex;align-items:center;justify-content:space-between;
    padding:13px 14px;border-radius:14px;color:#c7d7ef;border:1px solid transparent
}
.sidebar nav a:hover,.sidebar nav a.ativo{
    background:rgba(37,99,235,.15);color:#fff;border-color:rgba(56,189,248,.18)
}
.logout-form{margin-top:18px}

.content{padding:24px}
.topbar{
    display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;padding:18px 20px;
    border:1px solid var(--borda);border-radius:22px;
    background:linear-gradient(180deg, rgba(6,15,30,.84), rgba(4,10,20,.84));box-shadow:var(--sombra)
}
.topbar h1{margin:0;font-size:28px}
.topbar-tools{display:flex;align-items:center;gap:12px}
.search-box{
    min-width:280px;background:rgba(8,17,34,.72);border:1px solid var(--borda);
    border-radius:14px;padding:10px 12px;color:#e5eefc
}
.user-badge{
    display:inline-flex;align-items:center;gap:10px;padding:10px 12px;
    background:rgba(8,17,34,.72);border:1px solid var(--borda);border-radius:14px
}
.user-dot{width:12px;height:12px;border-radius:999px;background:linear-gradient(90deg,var(--azul-1),var(--azul-2))}

.page-header{margin-bottom:18px}
.page-header h1{margin:0 0 8px;font-size:34px}
.page-header p{margin:0;color:var(--texto-sec)}

.cards{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:18px}
.card,.panel,.table-wrap,.form-card{
    border:1px solid var(--borda);border-radius:22px;
    background:linear-gradient(180deg, rgba(8,18,35,.92), rgba(5,11,22,.92));box-shadow:var(--sombra)
}
.card{padding:20px}
.card strong{display:block;color:#dceafe;margin-bottom:10px;font-size:14px;font-weight:700}
.card span{font-size:34px;font-weight:800;letter-spacing:-.03em}
.card small{display:block;color:var(--texto-sec);margin-top:8px}


.dashboard-grid{
    display:grid;
    grid-template-columns:repeat(4,minmax(0,1fr));
    grid-template-areas:
        "usinas medidores online offline"
        "tensaoA tensaoB tensaoC gerado"
        "correnteA correnteB correnteC consumido"
        "fp fpbaixo alertas leituras";
    gap:14px;
    margin-bottom:18px;
}
.dashboard-card{min-height:146px}
.dashboard-card.usinas{grid-area:usinas}
.dashboard-card.medidores{grid-area:medidores}
.dashboard-card.online{grid-area:online}
.dashboard-card.offline{grid-area:offline}
.dashboard-card.tensaoA{grid-area:tensaoA}
.dashboard-card.tensaoB{grid-area:tensaoB}
.dashboard-card.tensaoC{grid-area:tensaoC}
.dashboard-card.gerado{grid-area:gerado}
.dashboard-card.correnteA{grid-area:correnteA}
.dashboard-card.correnteB{grid-area:correnteB}
.dashboard-card.correnteC{grid-area:correnteC}
.dashboard-card.consumido{grid-area:consumido}
.dashboard-card.fp{grid-area:fp}
.dashboard-card.fpbaixo{grid-area:fpbaixo}
.dashboard-card.alertas{grid-area:alertas}
.dashboard-card.leituras{grid-area:leituras}

.grid-2{display:grid;grid-template-columns:1.45fr 1fr;gap:16px}
.panel{padding:20px}
.panel h2{margin:0 0 10px;font-size:20px}
.panel p{color:var(--texto-sec)}

.lista{display:grid;gap:10px;margin-top:12px}
.lista-item{
    display:flex;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:16px;
    background:rgba(9,20,40,.65);border:1px solid rgba(148,163,184,.10)
}

.kpis{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.kpi{
    padding:16px;border-radius:18px;background:rgba(9,20,40,.72);border:1px solid rgba(148,163,184,.10)
}
.kpi-label{font-size:12px;color:var(--texto-sec);text-transform:uppercase;letter-spacing:.08em}
.kpi-value{margin-top:8px;font-size:28px;font-weight:800}

.toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;flex-wrap:wrap}
.toolbar-group{display:flex;gap:10px;flex-wrap:wrap}
.filter-chip{
    display:inline-flex;align-items:center;justify-content:center;padding:9px 12px;border-radius:999px;
    background:rgba(9,20,40,.72);border:1px solid var(--borda);color:#d7e6ff;font-size:13px
}

.table-wrap{overflow:auto}
table{width:100%;border-collapse:collapse}
th,td{padding:15px 16px;text-align:left;white-space:nowrap}
th{
    color:#dceafe;font-size:13px;text-transform:uppercase;letter-spacing:.08em;
    border-bottom:1px solid rgba(148,163,184,.12)
}
td{color:#cfdbef;border-bottom:1px solid rgba(148,163,184,.08)}
tr:last-child td{border-bottom:none}

.empty-state{
    padding:34px 20px;text-align:center;border:1px dashed rgba(148,163,184,.20);
    border-radius:22px;background:rgba(8,17,34,.44)
}
.empty-state h3{margin:0 0 8px;font-size:22px}
.empty-state p{margin:0;color:var(--texto-sec)}

/* Forms and alerts */
.form-card{padding:18px}
.form-card-compacto{padding:16px}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.form-group{margin-bottom:0}
label{display:block;margin:0 0 6px;color:#dbe7fb;font-size:13px;font-weight:600}
input,select,textarea{
    width:100%;border:none;outline:none;background:#d8e1ee;color:#0f172a;border-radius:14px;padding:10px 12px;font-size:14px
}
textarea{min-height:96px;resize:vertical}
input:focus,select:focus,textarea:focus{box-shadow:0 0 0 3px rgba(56,189,248,.26)}
button,.btn{
    display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;cursor:pointer;
    border-radius:14px;padding:11px 14px;font-size:14px;font-weight:800;color:#eff6ff;
    background:linear-gradient(90deg,var(--azul-1),var(--azul-2));box-shadow:0 10px 30px rgba(37,99,235,.28)
}
button:hover,.btn:hover{filter:brightness(1.05)}
.btn-full{width:100%}
.btn-secundario{background:rgba(15,23,42,.65);border:1px solid var(--borda);box-shadow:none}
.btn-perigo{background:linear-gradient(90deg,#ef4444,#dc2626)}
.btn-mini{padding:8px 10px;font-size:12px;border-radius:12px}
.form-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}

.alert{
    margin:0 0 16px;padding:12px 14px;border-radius:14px;
    background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.22);color:#ffd5d5;font-size:14px
}
.alert-sucesso{
    background:rgba(34,197,94,.12);border-color:rgba(34,197,94,.22);color:#bbf7d0
}

.badge{
    display:inline-flex;align-items:center;justify-content:center;padding:6px 10px;border-radius:999px;
    font-size:12px;font-weight:800;letter-spacing:.04em
}
.badge-ok{background:rgba(34,197,94,.14);color:#b7f7c8}
.badge-off{background:rgba(239,68,68,.12);color:#fecaca}
.badge-warn{background:rgba(245,158,11,.14);color:#fde68a}

.acoes-linha{display:flex;justify-content:flex-end;gap:8px}
.admin-grid{align-items:start}

/* Ajuste visual da tela de administração */
.admin-layout-usuarios{
    display:grid;
    grid-template-columns:2.2fr 1fr;
    gap:16px;
    align-items:stretch;
}
.admin-bloco{min-height:100%}
.admin-formulario-wrap{display:flex;height:100%}
.admin-formulario{
    width:100%;
    min-height:100%;
    display:flex;
    flex-direction:column;
    justify-content:flex-start;
    border:1px solid var(--borda);
    border-radius:22px;
    background:linear-gradient(180deg, rgba(8,18,35,.92), rgba(5,11,22,.92));
    box-shadow:var(--sombra);
}
.admin-formulario-nota{margin-top:8px}

@media (max-width:1200px){
    .cards{grid-template-columns:repeat(2,minmax(0,1fr))}
    .dashboard-grid{grid-template-columns:repeat(2,minmax(0,1fr));grid-template-areas:
        "usinas medidores"
        "online offline"
        "tensaoA tensaoB"
        "tensaoC gerado"
        "correnteA correnteB"
        "correnteC consumido"
        "fp fpbaixo"
        "alertas leituras";}
    .grid-2,.admin-grid,.admin-layout-usuarios{grid-template-columns:1fr}
    .kpis{grid-template-columns:1fr}
}
@media (max-width:900px){
    .layout{grid-template-columns:1fr}
    .sidebar{position:relative;height:auto;border-right:none;border-bottom:1px solid rgba(59,130,246,.18)}
    .topbar{flex-direction:column;align-items:flex-start}
    .search-box{min-width:0;width:100%}
    .form-grid{grid-template-columns:1fr}
}
@media (max-width:800px){
    .auth-shell{height:auto;min-height:100vh;overflow:auto;grid-template-columns:1fr}
    .auth-hero{border-right:none;border-bottom:1px solid rgba(59,130,246,.18);padding:18px 16px 10px}
    .auth-pane{padding:16px}
    .auth-grid{grid-template-columns:1fr}
    .auth-titulo{font-size:clamp(28px,7vw,42px)}
    .cards{grid-template-columns:1fr}
    .dashboard-grid{grid-template-columns:1fr;grid-template-areas:
        "usinas"
        "medidores"
        "online"
        "offline"
        "tensaoA"
        "tensaoB"
        "tensaoC"
        "gerado"
        "correnteA"
        "correnteB"
        "correnteC"
        "consumido"
        "fp"
        "fpbaixo"
        "alertas"
        "leituras";}
}
@media (max-height:760px){
    .feature-card:last-child{display:none}
    .auth-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}


/* Relatórios: reduzir barras laterais */
.painel-relatorios-filtros{overflow:hidden}
.toolbar-relatorios{display:grid;grid-template-columns:minmax(0,1fr);gap:12px;align-items:end}
.filtros-principais-relatorios,.filtros-personalizados-relatorios,.acoes-relatorios{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;width:100%}
.acoes-relatorios{grid-template-columns:repeat(auto-fit,minmax(220px,max-content));justify-content:flex-start}
.acoes-relatorios-secundarias{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.table-wrap-relatorio{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch}
.tabela-relatorio{min-width:100%;table-layout:fixed}
.tabela-relatorio th,.tabela-relatorio td{white-space:normal;vertical-align:top;word-break:break-word;padding:12px 14px}
.tabela-relatorio-integralizado th:nth-child(1),.tabela-relatorio-integralizado td:nth-child(1){width:12%}
.tabela-relatorio-integralizado th:nth-child(2),.tabela-relatorio-integralizado td:nth-child(2){width:12%}
.tabela-relatorio-integralizado th:nth-child(3),.tabela-relatorio-integralizado td:nth-child(3){width:11%}
.tabela-relatorio-integralizado th:nth-child(4),.tabela-relatorio-integralizado td:nth-child(4){width:8%}
.tabela-relatorio-integralizado th:nth-child(5),.tabela-relatorio-integralizado td:nth-child(5),.tabela-relatorio-integralizado th:nth-child(6),.tabela-relatorio-integralizado td:nth-child(6){width:16%}
.tabela-relatorio-integralizado th:nth-child(7),.tabela-relatorio-integralizado td:nth-child(7),.tabela-relatorio-integralizado th:nth-child(8),.tabela-relatorio-integralizado td:nth-child(8){width:12%}
.tabela-relatorio-integralizado th:nth-child(9),.tabela-relatorio-integralizado td:nth-child(9){width:7%}
.celula-metrica-grupo{display:grid;gap:4px;font-size:13px;line-height:1.35}
.celula-metrica-grupo strong{color:#dceafe}
.tabela-relatorio-desempenho{table-layout:auto}
.tabela-relatorio-lacunas{table-layout:auto}
@media (max-width:1100px){
  .tabela-relatorio-integralizado{min-width:980px}
  .tabela-relatorio-desempenho,.tabela-relatorio-lacunas{min-width:760px}
}
@media (max-width:720px){
  .filtros-principais-relatorios,.filtros-personalizados-relatorios,.acoes-relatorios{grid-template-columns:1fr}
}
