/* SIPAE – Estilos globais */
:root{
  --bg:#0f0f1a;--bg2:#16162a;--bg3:#1e1e35;--bg4:#252540;
  --accent:#7c6fff;--accent2:#a78bfa;--accent3:#34d399;
  --accent4:#f59e0b;--accent5:#f87171;
  --text:#e8e8f0;--text2:#9898b8;--text3:#5a5a7a;
  --border:rgba(124,111,255,.15);--border2:rgba(124,111,255,.3);
  --r:14px;--rs:8px;
  --sidebar-w:220px;
  --fh:'Syne',sans-serif;--fb:'DM Sans',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;background:var(--bg);color:var(--text);font-family:var(--fb);font-size:15px;line-height:1.6}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:4px}
a{color:var(--accent2);text-decoration:none}

/* ── Layout ── */
body{display:flex;flex-direction:row}
.sidebar{
  width:var(--sidebar-w);min-height:100vh;background:var(--bg2);
  border-right:1px solid var(--border);display:flex;flex-direction:column;
  padding:.875rem 0;position:fixed;left:0;top:0;bottom:0;z-index:100;
  transition:transform .25s;overflow-y:auto
}
.sidebar-logo{padding:.5rem 1rem 1.25rem;border-bottom:1px solid var(--border)}
.nav-link{
  display:flex;align-items:center;gap:10px;padding:.625rem 1.25rem;
  color:var(--text2);font-size:13px;font-weight:500;transition:all .2s;border-radius:0
}
.nav-link:hover{background:var(--bg3);color:var(--text)}
.nav-link.active{background:rgba(124,111,255,.18);color:var(--accent2);font-weight:600;border-left:3px solid var(--accent)}
.nav-ico{font-size:16px;width:22px;text-align:center;flex-shrink:0}
.nav-lbl{white-space:nowrap}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:99}

.main-content{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh}

/* ── Topbar ── */
.topbar{
  height:52px;background:var(--bg2);border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 1.5rem;position:sticky;top:0;z-index:50;flex-shrink:0
}
.topbar-left{display:flex;align-items:center;gap:.75rem}
.hamburger{background:none;border:none;color:var(--text2);font-size:20px;cursor:pointer;display:none;padding:4px}
.topbar-right{display:flex;align-items:center;gap:.75rem}
.plan-chip{padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700}
.plan-trial{background:rgba(245,158,11,.15);color:var(--accent4);border:1px solid rgba(245,158,11,.3)}
.plan-ativo{background:rgba(52,211,153,.15);color:var(--accent3);border:1px solid rgba(52,211,153,.3)}
.plan-expirado{background:rgba(248,113,113,.15);color:var(--accent5);border:1px solid rgba(248,113,113,.3)}
.avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}

/* ── Page body ── */
.page-body{padding:1.5rem;flex:1}
.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.25rem;flex-wrap:wrap;gap:.75rem}
.page-header h1{font-family:var(--fh);font-size:24px;font-weight:800}
.page-header p{font-size:13px;color:var(--text2)}
.section-title{font-family:var(--fh);font-size:15px;font-weight:700;margin-bottom:.875rem;color:var(--text)}

/* ── Alerts ── */
.alert{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:var(--rs);font-size:13px;margin-bottom:1rem}
.alert-success{background:rgba(52,211,153,.1);border:1px solid rgba(52,211,153,.25);color:var(--accent3)}
.alert-warn{background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.25);color:var(--accent4)}
.alert-danger{background:rgba(248,113,113,.1);border:1px solid rgba(248,113,113,.25);color:var(--accent5)}
.alert-info{background:rgba(124,111,255,.1);border:1px solid rgba(124,111,255,.25);color:var(--accent2)}
.ml-auto{margin-left:auto}

/* ── Metrics ── */
.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-bottom:1.5rem}
.metric-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:1rem 1.1rem;display:flex;flex-direction:column;gap:6px}
.metric-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.metric-val{font-family:var(--fh);font-size:28px;font-weight:800}
.metric-lbl{font-size:11px;color:var(--text2);text-transform:uppercase;letter-spacing:.4px}

/* ── Quick access ── */
.quick-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;margin-bottom:1.5rem}
.quick-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:1rem;transition:all .2s;color:var(--text)}
.quick-card:hover{border-color:var(--border2);background:var(--bg3);transform:translateY(-1px)}
.qc-icon{font-size:24px;margin-bottom:.5rem}
.qc-title{font-family:var(--fh);font-size:14px;font-weight:700;margin-bottom:3px}
.qc-sub{font-size:12px;color:var(--text2)}

/* ── Cards ── */
.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:1.25rem 1.5rem;margin-bottom:1rem}
.card-title{font-family:var(--fh);font-size:16px;font-weight:700;margin-bottom:1rem}
.card-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-wrap:wrap;gap:.75rem}

/* ── Form ── */
.fg{margin-bottom:.875rem}
.fl{display:block;font-size:11px;font-weight:600;color:var(--text2);margin-bottom:5px;text-transform:uppercase;letter-spacing:.5px}
input[type=text],input[type=email],input[type=password],input[type=tel],input[type=date],input[type=number],select,textarea{
  width:100%;padding:9px 12px;background:var(--bg3);border:1px solid var(--border);
  border-radius:var(--rs);color:var(--text);font-family:var(--fb);font-size:14px;outline:none;transition:border-color .2s
}
input:focus,select:focus,textarea:focus{border-color:var(--accent)}
select option{background:var(--bg3)}
textarea{resize:vertical;min-height:80px;line-height:1.6}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:5px;padding:8px 16px;border-radius:var(--rs);border:1px solid var(--border);background:var(--bg3);color:var(--text);font-family:var(--fb);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap;text-decoration:none}
.btn:hover{background:var(--bg4);border-color:var(--border2)}
.btn:disabled{opacity:.4;cursor:not-allowed}
.btn-p{background:var(--accent);border-color:var(--accent);color:#fff}
.btn-p:hover{background:#6a5ef0;border-color:#6a5ef0}
.btn-g{background:rgba(52,211,153,.15);border-color:rgba(52,211,153,.3);color:var(--accent3)}
.btn-g:hover{background:rgba(52,211,153,.25)}
.btn-r{background:rgba(248,113,113,.12);border-color:rgba(248,113,113,.25);color:var(--accent5)}
.btn-r:hover{background:rgba(248,113,113,.22)}
.btn-sm{padding:5px 10px;font-size:12px}
.bgroup{display:flex;gap:7px;flex-wrap:wrap}

/* ── Tags ── */
.tag{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600}
.t-bncc{background:rgba(124,111,255,.18);color:var(--accent2);border:1px solid rgba(124,111,255,.3)}
.t-easy{background:rgba(52,211,153,.12);color:var(--accent3);border:1px solid rgba(52,211,153,.25)}
.t-med{background:rgba(245,158,11,.12);color:var(--accent4);border:1px solid rgba(245,158,11,.25)}
.t-hard{background:rgba(248,113,113,.12);color:var(--accent5);border:1px solid rgba(248,113,113,.25)}
.t-disc{background:rgba(96,165,250,.12);color:#60a5fa;border:1px solid rgba(96,165,250,.25)}
.t-m{background:rgba(52,211,153,.12);color:var(--accent3);border:1px solid rgba(52,211,153,.25)}
.t-f{background:rgba(248,113,113,.12);color:var(--accent5);border:1px solid rgba(248,113,113,.25)}
.t-ativo{background:rgba(52,211,153,.12);color:var(--accent3);border:1px solid rgba(52,211,153,.25)}
.t-inativo{background:rgba(90,90,122,.15);color:var(--text3);border:1px solid var(--border)}
.t-transferido{background:rgba(96,165,250,.12);color:#60a5fa;border:1px solid rgba(96,165,250,.25)}

/* ── Table ── */
.data-table{width:100%;border-collapse:collapse;font-size:13px}
.data-table th{text-align:left;padding:9px 12px;font-size:11px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.4px;border-bottom:1px solid var(--border);white-space:nowrap}
.data-table td{padding:10px 12px;border-bottom:1px solid rgba(124,111,255,.06);vertical-align:middle}
.data-table tr:last-child td{border-bottom:none}
.data-table tr:hover td{background:rgba(124,111,255,.04)}
.table-wrap{overflow-x:auto}

/* ── Modal ── */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:200;display:flex;align-items:center;justify-content:center;padding:1rem;backdrop-filter:blur(4px)}
.modal{background:var(--bg2);border:1px solid var(--border2);border-radius:18px;padding:1.75rem;width:min(540px,96vw);max-height:90vh;overflow-y:auto;position:relative}
.modal-title{font-family:var(--fh);font-size:18px;font-weight:700;margin-bottom:1.25rem}
.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;color:var(--text2);font-size:22px;cursor:pointer;line-height:1;padding:0}

/* ── AI Box ── */
.ai-box{background:var(--bg3);border:1px solid var(--border2);border-radius:var(--r);padding:1.1rem;position:relative;margin-top:.625rem}
.ai-box::before{content:'✦ Gerado por IA';position:absolute;top:-10px;left:12px;background:var(--accent);color:#fff;font-size:10px;font-weight:700;padding:2px 9px;border-radius:10px;letter-spacing:.3px}
.ai-content{font-size:13px;line-height:1.75;white-space:pre-wrap;color:var(--text)}

/* ── Divider ── */
.div{height:1px;background:var(--border);margin:.875rem 0}

/* ── Spinner ── */
.spin{width:16px;height:16px;border:2px solid var(--border2);border-top-color:var(--accent);border-radius:50%;animation:sp .7s linear infinite;flex-shrink:0;display:inline-block}
@keyframes sp{to{transform:rotate(360deg)}}

/* ── Toast ── */
#toast{position:fixed;bottom:1.5rem;right:1.5rem;z-index:500;display:none;background:var(--bg3);border:1px solid var(--border2);border-radius:10px;padding:.75rem 1.1rem;font-size:13px;max-width:300px;box-shadow:0 4px 20px rgba(0,0,0,.4)}

/* ── Chips ── */
.chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:.875rem}
.chip{padding:5px 12px;border-radius:20px;border:1px solid var(--border);background:var(--bg3);color:var(--text2);font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}
.chip:hover{border-color:var(--border2);color:var(--text)}
.chip.sel{background:rgba(124,111,255,.2);border-color:var(--accent);color:var(--accent2);font-weight:600}

/* ── Progress ── */
.prog{height:5px;background:var(--bg4);border-radius:3px;overflow:hidden}
.prog-f{height:100%;border-radius:3px;transition:width .5s}

/* ── Responsive ── */
@media(max-width:768px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0)}
  .sidebar-overlay.show{display:block}
  .main-content{margin-left:0}
  .hamburger{display:block}
  .g2,.g3{grid-template-columns:1fr}
  .metrics-grid{grid-template-columns:repeat(2,1fr)}
}
@media print{
  .sidebar,.topbar,.bgroup,.btn,.modal-bg{display:none!important}
  .main-content{margin:0}
  .page-body{padding:.5rem}
  .card,.data-table td,.data-table th{background:#fff!important;color:#000!important;border-color:#ccc!important}
}
