/* ============================================================
   RUPTEN — Painel administrativo
   Identidade: preto + carmim, alinhada com o site público.
   ============================================================ */
:root{
  --ink:#050505; --ink-2:#0c0c0c; --ink-3:#141414; --panel:#0e0e0e;
  --red:#e0102b; --red-deep:#a50d20; --red-glow:rgba(224,16,43,.4);
  --text:#efece6; --muted:#8d8a85; --muted-2:#5f5d59;
  --line:rgba(244,241,234,.12); --line-strong:rgba(244,241,234,.24);
  --ok:#2ea043; --err:#e0102b;
  --display:'Anton','Arial Narrow',sans-serif;
  --body:'Archivo',system-ui,sans-serif;
  --mono:'Space Mono',ui-monospace,monospace;
  --bg:var(--ink-2);
}
*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:var(--body);background:var(--ink);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.6;}
a{color:inherit;text-decoration:none;}
::selection{background:var(--red);color:#fff;}

/* ---------- Auth ---------- */
.auth-body{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px;
  background:radial-gradient(ellipse at 30% 20%, rgba(224,16,43,.10), transparent 55%), var(--ink);}
.auth-wrap{width:100%;max-width:420px;}
.auth-card{background:var(--panel);border:1px solid var(--line);padding:46px 40px;border-radius:4px;
  box-shadow:0 40px 90px -40px rgba(0,0,0,.9);}
.auth-brand{font-family:var(--display);font-size:2.4rem;letter-spacing:.08em;text-transform:uppercase;}
.auth-sub{font-family:var(--mono);color:var(--muted);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;margin:6px 0 30px;}
.auth-card label{display:block;font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin:18px 0 7px;}
.auth-card input{width:100%;padding:13px 15px;background:var(--ink);border:1px solid var(--line);color:var(--text);font-family:var(--body);font-size:.95rem;border-radius:3px;}
.auth-card input:focus{outline:none;border-color:var(--red);}
.auth-foot{text-align:center;font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2);margin-top:26px;}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;justify-content:center;font-family:var(--mono);font-weight:700;
  font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;padding:13px 24px;border:2px solid var(--red);
  background:var(--red);color:#fff;cursor:pointer;border-radius:3px;transition:all .25s ease;width:100%;}
.btn:hover{background:transparent;color:var(--text);}
.btn-sm{padding:8px 15px;font-size:.7rem;width:auto;border-width:1px;}
.btn-ghost{background:transparent;color:var(--text);border-color:var(--line-strong);}
.btn-ghost:hover{border-color:var(--red);color:#fff;background:transparent;}
.btn-danger{background:transparent;border:1px solid rgba(224,16,43,.5);color:#ff8e98;}
.btn-danger:hover{background:var(--red);color:#fff;border-color:var(--red);}

/* ---------- Layout ---------- */
.admin{display:flex;min-height:100vh;}
.sidebar{width:260px;background:#020202;border-right:1px solid var(--line);display:flex;flex-direction:column;
  padding:30px 20px;position:fixed;top:0;bottom:0;left:0;z-index:50;}
.sidebar .brand{font-family:var(--display);font-size:1.9rem;letter-spacing:.08em;text-transform:uppercase;padding:0 8px 26px;
  border-bottom:1px solid var(--line);margin-bottom:22px;}
.sidebar .brand::after{content:"";display:inline-block;width:8px;height:8px;background:var(--red);margin-left:6px;border-radius:50%;vertical-align:middle;}
.sidebar nav{display:flex;flex-direction:column;gap:2px;flex:1;}
.sidebar nav a{font-family:var(--mono);font-size:.8rem;letter-spacing:.04em;color:var(--muted);padding:11px 14px;border-radius:3px;
  transition:.2s;position:relative;}
.sidebar nav a:hover{color:var(--text);background:rgba(255,255,255,.03);}
.sidebar nav a.active{color:#fff;background:rgba(224,16,43,.12);}
.sidebar nav a.active::before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:3px;background:var(--red);border-radius:3px;}
.sidebar .foot{border-top:1px solid var(--line);padding-top:18px;margin-top:14px;}
.sidebar .foot .who{font-weight:700;font-size:.92rem;}
.sidebar .foot .role{font-family:var(--mono);font-size:.7rem;color:var(--red);text-transform:uppercase;letter-spacing:.08em;margin-top:2px;}

.main{flex:1;margin-left:260px;display:flex;flex-direction:column;}
.topbar{display:flex;align-items:center;gap:18px;padding:20px 34px;border-bottom:1px solid var(--line);
  position:sticky;top:0;background:rgba(5,5,5,.85);backdrop-filter:blur(10px);z-index:40;}
.topbar h1{font-family:var(--display);font-size:1.5rem;letter-spacing:.03em;text-transform:uppercase;flex:1;font-weight:400;}
.menu-btn{display:none;background:none;border:0;color:var(--text);font-size:1.5rem;cursor:pointer;}
.content{padding:34px;max-width:1100px;width:100%;}

/* ---------- Panels ---------- */
.panel{background:var(--panel);border:1px solid var(--line);border-radius:4px;margin-bottom:26px;overflow:hidden;}
.panel-head{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--line);}
.panel-head h2{font-family:var(--display);font-size:1.15rem;letter-spacing:.04em;text-transform:uppercase;font-weight:400;}
.panel-body{padding:24px;}

/* ---------- Stat cards ---------- */
.stat-grid,.stat-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:18px;margin-bottom:26px;}
.stat-card{background:var(--panel);border:1px solid var(--line);padding:24px;border-radius:4px;position:relative;overflow:hidden;}
.stat-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--red);}
.stat-card .n,.stat-card .v{font-family:var(--display);font-size:2.6rem;line-height:1;}
.stat-card .l{font-family:var(--mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-top:8px;}

/* ---------- Forms ---------- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:22px;}
.fld{display:flex;flex-direction:column;}
.fld.full{grid-column:1/-1;}
.fld label{font-family:var(--mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:7px;}
.fld input,.fld textarea,.fld select{padding:12px 14px;background:var(--ink);border:1px solid var(--line);color:var(--text);
  font-family:var(--body);font-size:.92rem;border-radius:3px;transition:border-color .25s;}
.fld input:focus,.fld textarea:focus,.fld select:focus{outline:none;border-color:var(--red);}
.fld textarea{min-height:110px;resize:vertical;}
.check{flex-direction:row!important;align-items:center;gap:9px;font-family:var(--body);font-size:.9rem;color:var(--text);text-transform:none;letter-spacing:0;}
.check input{width:auto;}
.hint{display:block;margin-top:6px;font-size:.74rem;color:var(--muted-2);font-family:var(--mono);}
.thumb{width:54px;height:54px;object-fit:cover;border-radius:3px;border:1px solid var(--line);}

/* ---------- Tables ---------- */
table{width:100%;border-collapse:collapse;}
thead th{font-family:var(--mono);text-align:left;font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);
  padding:14px 16px;border-bottom:1px solid var(--line);}
tbody td{padding:14px 16px;border-bottom:1px solid var(--line);font-size:.9rem;vertical-align:middle;}
tbody tr:last-child td{border-bottom:0;}
tbody tr:hover{background:rgba(255,255,255,.02);}
td.actions{display:flex;gap:8px;justify-content:flex-end;}

/* ---------- Badges ---------- */
.badge{display:inline-block;font-family:var(--mono);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;
  padding:4px 10px;border-radius:3px;background:rgba(255,255,255,.08);color:var(--text);}
.badge.on{background:rgba(46,160,67,.16);color:#7ee2a0;}
.badge.off{background:rgba(224,16,43,.16);color:#ff9aa3;}
.badge.st-novo,.badge.novo{background:rgba(224,16,43,.18);color:#ff9aa3;}
.badge.st-em_analise,.badge.em_analise{background:rgba(255,176,32,.16);color:#ffcf7a;}
.badge.st-respondido,.badge.respondido{background:rgba(46,160,67,.16);color:#7ee2a0;}
.badge.st-fechado,.badge.fechado{background:rgba(255,255,255,.08);color:var(--muted);}

/* ---------- Contact detail ---------- */
.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:20px;}
.detail-grid .dk{display:block;font-family:var(--mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--red);margin-bottom:5px;}
.detail-grid .dv{font-weight:600;}
.msg-box{background:var(--ink);border:1px solid var(--line);border-radius:4px;padding:20px;line-height:1.7;margin-bottom:20px;}
.inline-form{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.inline-form label{font-family:var(--mono);font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);}
.inline-form select{padding:10px 12px;background:var(--ink);border:1px solid var(--line);color:var(--text);border-radius:3px;min-width:170px;}
.notes-list{margin-top:20px;display:flex;flex-direction:column;gap:12px;}
.note-item{background:var(--ink);border-left:3px solid var(--red);border-radius:3px;padding:13px 15px;}
.note-item p{margin:0 0 6px;line-height:1.55;}
.note-meta{font-family:var(--mono);font-size:.72rem;color:var(--muted-2);}

/* ---------- Gallery (admin) ---------- */
.gal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px;}
.gal-card{border:1px solid var(--line);border-radius:4px;overflow:hidden;background:var(--ink);}
.gal-card img{width:100%;aspect-ratio:1;object-fit:cover;filter:grayscale(.4);}
.gal-meta{padding:12px;display:flex;flex-direction:column;gap:9px;align-items:flex-start;}
.gal-meta .gal-title{font-size:.82rem;color:var(--muted);}

/* ---------- Bars (chart) ---------- */
.bars{display:flex;flex-direction:column;gap:14px;}
.bar-row{display:flex;align-items:center;gap:14px;}
.bar-row .lbl{width:130px;font-family:var(--mono);font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;}
.bar-track{flex:1;height:24px;background:var(--ink);border:1px solid var(--line);border-radius:3px;overflow:hidden;}
.bar-fill{height:100%;background:var(--red);transition:width .8s var(--ease,ease);}
.bar-row .val{width:34px;text-align:right;font-family:var(--mono);font-weight:700;}

/* ---------- Alerts ---------- */
.alert{padding:13px 16px;margin-bottom:18px;border-left:3px solid;font-size:.9rem;border-radius:3px;}
.alert-success{border-color:var(--ok);background:rgba(46,160,67,.1);color:#8fe9ab;}
.alert-error{border-color:var(--err);background:rgba(224,16,43,.12);color:#ff9aa3;}

code{background:var(--ink);padding:2px 7px;border-radius:3px;font-family:var(--mono);font-size:.82em;color:#ff9aa3;}

/* ---------- Responsive ---------- */
.overlay{display:none;}
@media(max-width:900px){
  .sidebar{transform:translateX(-100%);transition:transform .3s ease;}
  .sidebar.open{transform:none;}
  .main{margin-left:0;}
  .topbar .menu-btn{display:block;}
  .form-grid{grid-template-columns:1fr;}
  .content{padding:22px;}
  .overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:45;}
  .overlay.show{display:block;}
}
