/* ==========================================================================
   Grupo MS Tecnologia — ms-theme.css
   Tema "Tech / Cyber" baseado na paleta (dark navy + cyan neon) e logo MS.
   (ARQUIVO COMPLETO • corrigido • NAV mobile organizado • hambúrguer OK)
   ========================================================================== */

/* ---------- Reset básico ---------- */
* { box-sizing: border-box; }
html, body { height: 100%; min-height: 100%; }

body {
  margin: 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  color: var(--text);
  background: var(--bg);
  line-height: 1.45;
  overflow-x: hidden; /* evita overflow horizontal acidental */
}

/* mídia e imagens responsivas */
img, svg, video, canvas { max-width: 100%; height: auto; display: block; }

/* ---------- Paleta / Tokens ---------- */
:root{
  --bg: #050c16;
  --bg-2: #071a2c;
  --panel: #081f35;
  --panel-2: #0b2742;

  --border: rgba(55, 204, 235, 0.18);
  --border-strong: rgba(55, 204, 235, 0.35);
  --shadow: 0 10px 30px rgba(0,0,0,.45);

  --text: rgba(255,255,255,.92);
  --muted: rgba(255,255,255,.68);

  --primary: #37cceb;
  --primary-2: #1370a0;
  --glow: 0 0 0.75rem rgba(55, 204, 235, .35);

  --success: #22c55e;
  --warning: #fbbf24;
  --danger:  #ef4444;

  --r-xs: 8px;
  --r-sm: 10px;
  --r-md: 14px;
  --r-lg: 18px;

  --pad-1: 10px;
  --pad-2: 14px;
  --pad-3: 18px;
  --pad-4: 24px;

  --maxw: 1180px;
}

/* ---------- Fundo com grid suave (tech) ---------- */
body::before{
  content:"";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(800px 500px at 15% 10%, rgba(55,204,235,.10), transparent 60%),
    radial-gradient(700px 520px at 85% 20%, rgba(19,112,160,.14), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.04), transparent 60%),
    repeating-linear-gradient(90deg, rgba(55,204,235,.06) 0, rgba(55,204,235,.06) 1px, transparent 1px, transparent 90px),
    repeating-linear-gradient(0deg,  rgba(55,204,235,.04) 0, rgba(55,204,235,.04) 1px, transparent 1px, transparent 90px);
  opacity: .55;
  z-index: -1;
}

/* ---------- Links ---------- */
a{ color: var(--primary); text-decoration: none; }
a:hover{ text-decoration: underline; }

/* ---------- Layout helpers ---------- */
.container{
  width: 100%;
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 0 var(--pad-4);
}
@media (max-width: 720px){
  .container{ padding: 0 16px; }
}

/* ---------- Header ---------- */
.header{
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(7,26,44,.75);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border);
}

.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  padding: 14px 0;
}

/* marca */
.brand{
  display:flex;
  align-items:center;
  gap: 12px;
  min-width: 220px;
  color: inherit; /* brand é <a> */
}

.brand-logo{
  width: 42px;
  height: 42px;
  border-radius: 12px;
  background: linear-gradient(135deg, rgba(55,204,235,.22), rgba(19,112,160,.18));
  border: 1px solid var(--border);
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow: var(--shadow);
  overflow: hidden;
  flex: 0 0 auto;
}

.brand-logo img{
  width: 80%;
  height: 80%;
  object-fit: contain;
  filter: drop-shadow(0 10px 15px rgba(0,0,0,.25));
}

.brand-title strong{
  display:block;
  font-size: 14px;
  letter-spacing: .4px;
}

/* se existir span em outras páginas, escondemos */
.brand-title span{ display:none; }

/* ---------- Cards / Painéis ---------- */
.card{
  background: linear-gradient(180deg, rgba(11,39,66,.95), rgba(8,31,53,.95));
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow);
  padding: var(--pad-4);
}
@media (max-width: 480px){
  .card{ padding: 18px; border-radius: 16px; }
}

.card-header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 12px;
  margin-bottom: 14px;
}
@media (max-width: 520px){
  .card-header{ flex-direction: column; align-items: flex-start; }
}

.card-title{ margin: 0; font-size: 18px; letter-spacing: .2px; }
.card-subtitle{ margin: 6px 0 0 0; color: var(--muted); font-size: 13px; }

/* ---------- Botões ---------- */
.btn{
  appearance: none;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.03);
  color: var(--text);
  padding: 10px 14px;
  border-radius: 12px;
  cursor: pointer;
  font-weight: 600;
  letter-spacing: .2px;
  transition: transform .08s ease, box-shadow .2s ease, border-color .2s ease, background .2s ease;
  display:inline-flex;
  align-items:center;
  justify-content: center;
  gap: 8px;
  user-select:none;
  text-align: center;
}
.btn:hover{ border-color: var(--border-strong); box-shadow: var(--glow); }
.btn:active{ transform: translateY(1px); }

.btn-primary{
  border-color: rgba(55,204,235,.55);
  background: linear-gradient(135deg, rgba(55,204,235,.20), rgba(19,112,160,.18));
}
.btn-primary:hover{
  background: linear-gradient(135deg, rgba(55,204,235,.28), rgba(19,112,160,.22));
}

.btn-outline{
  background: transparent;
  border-color: rgba(55,204,235,.40);
  color: var(--primary);
}
.btn-outline:hover{ background: rgba(55,204,235,.10); }

.btn-danger{
  border-color: rgba(239,68,68,.45);
  color: rgba(255,255,255,.92);
  background: rgba(239,68,68,.12);
}
.btn-danger:hover{
  border-color: rgba(239,68,68,.65);
  box-shadow: 0 0 0.75rem rgba(239,68,68,.25);
}

@media (max-width: 520px){
  .btn{ width: 100%; }
}

/* ---------- Inputs ---------- */
.input, .select, .textarea{
  width: 100%;
  background: rgba(5,12,22,.55);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 11px 12px;
  outline: none;
  transition: box-shadow .2s ease, border-color .2s ease, background .2s ease;
}
.textarea{ min-height: 110px; resize: vertical; }
.input::placeholder, .textarea::placeholder{ color: rgba(255,255,255,.45); }

.input:focus, .select:focus, .textarea:focus{
  border-color: rgba(55,204,235,.65);
  box-shadow: var(--glow);
  background: rgba(5,12,22,.72);
}

.label{ display:block; font-size: 12px; color: var(--muted); margin: 0 0 6px 2px; }

/* ---------- Grid de formulário ---------- */
.form-grid{ display:grid; grid-template-columns: repeat(12, 1fr); gap: 12px; }
.col-12{ grid-column: span 12; }
.col-6{ grid-column: span 6; }
.col-4{ grid-column: span 4; }
.col-3{ grid-column: span 3; }

@media (max-width: 860px){
  .col-6,.col-4,.col-3{ grid-column: span 12; }
}

/* ---------- Tabelas ---------- */
.table-wrap{
  overflow:auto;
  -webkit-overflow-scrolling: touch;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: rgba(8,31,53,.70);
}
table{ width: 100%; border-collapse: collapse; min-width: 640px; }
@media (max-width: 520px){ table{ min-width: 520px; } }

thead th{
  position: sticky;
  top: 0;
  background: rgba(7,26,44,.95);
  border-bottom: 1px solid var(--border);
  color: rgba(255,255,255,.86);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .6px;
  padding: 12px 12px;
  text-align: left;
  white-space: nowrap;
}
tbody td{
  padding: 12px 12px;
  border-bottom: 1px solid rgba(55,204,235,.10);
  color: rgba(255,255,255,.88);
  font-size: 14px;
  white-space: nowrap;
}
tbody tr:hover{ background: rgba(55,204,235,.06); }
.td-right{ text-align: right; }
.td-center{ text-align: center; }

/* ---------- Badges ---------- */
.badge{
  display:inline-flex;
  align-items:center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid var(--border);
  font-size: 12px;
  color: rgba(255,255,255,.86);
  background: rgba(255,255,255,.03);
  white-space: nowrap;
}
.badge-primary{
  border-color: rgba(55,204,235,.45);
  background: rgba(55,204,235,.10);
  color: rgba(255,255,255,.92);
}
.badge-success{ border-color: rgba(34,197,94,.45); background: rgba(34,197,94,.10); }
.badge-warning{ border-color: rgba(251,191,36,.45); background: rgba(251,191,36,.10); }
.badge-danger{ border-color: rgba(239,68,68,.45); background: rgba(239,68,68,.10); }

/* ---------- Alertas ---------- */
.alert{
  border-radius: var(--r-lg);
  border: 1px solid var(--border);
  background: rgba(255,255,255,.03);
  padding: 12px 14px;
  color: rgba(255,255,255,.88);
}
@media (max-width: 480px){ .alert{ padding: 10px 12px; } }
.alert-info{ border-color: rgba(55,204,235,.45); background: rgba(55,204,235,.08); }
.alert-success{ border-color: rgba(34,197,94,.45); background: rgba(34,197,94,.08); }
.alert-danger{ border-color: rgba(239,68,68,.45); background: rgba(239,68,68,.08); }

/* ---------- Footer ---------- */
.footer{
  border-top: 1px solid var(--border);
  margin-top: 34px;
  padding: 18px 0;
  color: var(--muted);
  font-size: 12px;
}

/* ---------- Utilitários ---------- */
.row{ display:flex; gap: 12px; flex-wrap: wrap; }
.space-between{ display:flex; justify-content:space-between; gap: 12px; align-items:center; }
.mt-1{ margin-top: 10px; }
.mt-2{ margin-top: 16px; }
.mt-3{ margin-top: 22px; }
.mb-1{ margin-bottom: 10px; }
.mb-2{ margin-bottom: 16px; }
.mb-3{ margin-bottom: 22px; }

@media (max-width: 520px){
  .space-between{ flex-direction: column; align-items: stretch; }
}

.hr{
  height: 1px;
  background: rgba(55,204,235,.12);
  border: 0;
  margin: 18px 0;
}

/* =========================
   LOGIN - FUNDO + CONTAINER (RESPONSIVO / COMPACTO)
========================= */

.login-bg{
  position: relative;
  min-height: 100vh;
  min-height: 100dvh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px 12px;
  background: linear-gradient(180deg, #071d33, #031220);
  overflow: hidden;
}
.login-bg::before{
  content:"";
  position:absolute;
  inset:0;
  background: rgba(3,18,32,0.55);
  z-index:1;
}
.login-container{
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 520px;
  padding: 28px 28px;
  border-radius: 18px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.10);
  backdrop-filter: blur(10px);
  box-shadow: 0 20px 60px rgba(0,0,0,.45);
  margin: 0 auto;
}
.login-logo{
  display:flex;
  justify-content:center;
  align-items:center;
  margin-bottom: 14px;
}
.login-logo img{
  width: 100%;
  max-width: 240px;
  height: auto;
  filter: drop-shadow(0 10px 25px rgba(0,0,0,0.45));
}
@media (max-height: 740px){
  .login-bg{ padding: 12px 10px; }
  .login-container{ padding: 22px 18px; }
  .login-logo img{ max-width: 220px; }
  .hr{ margin: 14px 0; }
}
@media (max-width: 480px){
  .login-container{ padding: 22px 16px; border-radius: 16px; }
  .login-logo img{ max-width: 210px; }
}

/* =========================
   TOPNAV (estilo MikroTik-like)
========================= */

.topnav{
  display:flex;
  align-items:center;
  gap: 12px;
  width: 100%;
  margin-left: auto;
  justify-content: flex-end;
}

/* lista de links */
.topnav-list{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  align-items:center;
  gap: 18px;
  flex: 1 1 auto;        /* empurra ações p/ direita */
  justify-content: flex-end;
}

/* links */
.topnav-link{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 10px 10px;
  border-radius: 10px;
  color: rgba(255,255,255,.88);
  border: 1px solid transparent;
  text-decoration:none;
  font-weight: 700;
  letter-spacing:.2px;
}
.topnav-link:hover{
  border-color: rgba(55,204,235,.35);
  background: rgba(255,255,255,.03);
  box-shadow: var(--glow);
  text-decoration:none;
}

/* ações direita */
.topnav-actions{
  display:flex;
  align-items:center;
  gap: 10px;
  flex: 0 0 auto;
  margin-left: 10px;
}

/* botões ícone (usuário) */
.icon-btn{
  width: 44px;
  height: 44px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius: 12px;
  border: 1px solid rgba(55,204,235,.40);
  background: rgba(255,255,255,.03);
  color: var(--text);
  cursor: pointer;
  text-decoration:none;
}
.icon-btn:hover{
  border-color: var(--border-strong);
  box-shadow: var(--glow);
}

/* =========================
   HAMBURGUER (some no desktop, aparece no mobile)
========================= */
.nav-toggle{
  display:none; /* desktop: não aparece */
  width: 44px;
  height: 44px;
  border-radius: 12px;
  border: 1px solid rgba(55,204,235,.40);
  background: rgba(255,255,255,.03);
  color: var(--text);
  align-items:center;
  justify-content:center;
  cursor:pointer;
}
.nav-toggle:hover{
  border-color: var(--border-strong);
  box-shadow: var(--glow);
}

/* garante o desenho do ícone (3 barras) */
.nav-toggle .bars{
  width: 20px;
  height: 14px;
  display:block;
  position: relative;
}
.nav-toggle .bars::before,
.nav-toggle .bars::after,
.nav-toggle .bars span{
  content:"";
  position:absolute;
  left:0; right:0;
  height:2px;
  background: var(--primary);
  border-radius: 2px;
}
.nav-toggle .bars::before{ top:0; }
.nav-toggle .bars span{ top:6px; }
.nav-toggle .bars::after{ bottom:0; }

/* quando abre: vira X */
html.nav-open .nav-toggle .bars::before{ transform: translateY(6px) rotate(45deg); }
html.nav-open .nav-toggle .bars span{ opacity: 0; }
html.nav-open .nav-toggle .bars::after{ transform: translateY(-6px) rotate(-45deg); }
.nav-toggle .bars::before,
.nav-toggle .bars::after,
.nav-toggle .bars span{ transition: transform .2s ease, opacity .2s ease; }

/* =========================
   DROPDOWN (desktop)
========================= */
.topnav-item{ position: relative; }
.has-submenu{ position: relative; }

.submenu{
  position: absolute;
  top: calc(100% + 10px);
  left: 0;
  width: 340px;
  padding: 10px;
  border-radius: 14px;
  border: 1px solid rgba(55,204,235,.22);
  background: rgba(8,31,53,.96);
  box-shadow: 0 20px 60px rgba(0,0,0,.55);
  display: none;
  z-index: 999;
}

.submenu-item{
  display:flex;
  gap: 10px;
  align-items:center;
  padding: 10px 10px;
  border-radius: 12px;
  border: 1px solid transparent;
  color: rgba(255,255,255,.88);
  text-decoration:none;
}
.submenu-item:hover{
  border-color: rgba(55,204,235,.25);
  background: rgba(55,204,235,.06);
  text-decoration:none;
}

.submenu-ico{
  width: 34px;
  height: 34px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius: 12px;
  background: rgba(55,204,235,.08);
  border: 1px solid rgba(55,204,235,.18);
  flex: 0 0 auto;
}
.submenu-txt strong{ display:block; font-size: 13px; }
.submenu-txt small{ display:block; font-size: 12px; color: var(--muted); margin-top: 2px; }

/* desktop: abre no hover */
@media (min-width: 861px){
  .has-submenu:hover > .submenu{ display:block; }
}

/* =========================
   MOBILE: Drawer organizado (estilo Mikrotik)
========================= */
@media (max-width: 860px){

  /* mostra o hambúrguer só no mobile */
  .nav-toggle{
    display:inline-flex;
  }

  /* header precisa conseguir “quebrar” */
  .header-inner{
    flex-wrap: wrap;
  }

  /* trava scroll quando menu aberto */
  html.nav-open, html.nav-open body{
    overflow: hidden;
  }

  /* overlay */
  html.nav-open body::after{
    content:"";
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.55);
    backdrop-filter: blur(2px);
    z-index: 900;
  }

  /* a lista vira um painel fixo à direita */
  .topnav-list{
    display:none; /* fechado */
  }
  html.nav-open .topnav-list{
    display:flex;
    position: fixed;
    top: 76px;                 /* abaixo do header */
    right: 16px;
    width: min(420px, calc(100vw - 32px));
    max-height: calc(100vh - 96px);
    overflow: auto;
    -webkit-overflow-scrolling: touch;

    flex-direction: column;
    gap: 8px;
    padding: 12px;

    border-radius: 16px;
    border: 1px solid rgba(55,204,235,.22);
    background: rgba(8,31,53,.96);
    box-shadow: 0 24px 70px rgba(0,0,0,.60);

    z-index: 1000;
    animation: navDrop .14s ease-out;
  }

  @keyframes navDrop{
    from{ transform: translateY(-6px); opacity: 0; }
    to  { transform: translateY(0);    opacity: 1; }
  }

  /* cada item ocupa a largura e fica “em lista” */
  .topnav-item{ width: 100%; }

  .topnav-link{
    width: 100%;
    justify-content: flex-start;
    text-align: left;

    padding: 14px 14px;
    border-radius: 14px;

    background: rgba(255,255,255,.02);
    border: 1px solid rgba(55,204,235,.14);
  }

  /* submenu no mobile: não flutua */
  .submenu{
    position: static;
    width: 100%;
    margin-top: 6px;
    padding: 10px;
    border-radius: 14px;
    border: 1px solid rgba(55,204,235,.12);
    background: rgba(5,12,22,.35);
    box-shadow: none;
    display: none; /* abre via JS com data-open="1" */
  }
  .has-submenu[data-open="1"] > .submenu{
    display: block;
  }

  .submenu-item{
    width: 100%;
    padding: 12px 12px;
    border-radius: 12px;
    border: 1px solid rgba(55,204,235,.10);
    background: rgba(255,255,255,.02);
  }
  .submenu-item + .submenu-item{
    margin-top: 8px;
  }
}
/* =========================
   FIX DEFINITIVO — MENU MOBILE CLICÁVEL (z-index/stacking context)
   Cole NO FINAL do ms-theme.css
========================= */
@media (max-width: 860px){

  /* quando abrir o menu, o header precisa ficar acima do overlay */
  html.nav-open .header{
    z-index: 4000 !important;
  }

  /* overlay fica abaixo do header/menu */
  html.nav-open body::after{
    z-index: 3000 !important;
  }

  /* drawer (lista) acima de tudo dentro do header */
  html.nav-open .topnav-list{
    z-index: 4100 !important;
    pointer-events: auto !important;
  }

  /* garante clique nos links */
  html.nav-open .topnav-list a,
  html.nav-open .submenu,
  html.nav-open .submenu-item{
    pointer-events: auto !important;
  }
}
/* === FIX: alinhar logo + menu no mobile === */
@media (max-width: 860px) {

  .header-inner{
    align-items: center;       /* alinha tudo na mesma linha */
  }

  .brand{
    min-width: auto;           /* remove a força de quebra */
  }

  .topnav{
    width: auto;
    margin-left: auto;         /* empurra menu para a direita */
  }

  .topnav-actions{
    align-items: center;
  }
}
