/* ==========================================================================
   Portal de Coletas — CSS Global
   Estilo corporativo, fundo contínuo, topbar fixa e tipografia Inter
   Inclui tema claro (padrão) e tema escuro (data-theme="dark")
   ========================================================================== */

/* ===== Reset & base ===== */
* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }

/* ==========================================================================
   Tema Claro (padrão)
   ========================================================================== */
:root{
  /* Cores base */
  --bg: #f6f8fb;           /* fundo geral sutil */
  --surface: #ffffff;       /* cartões/painéis */
  --text: #111827;          /* cinza grafite */
  --muted: #6b7280;         /* cinza suave */
  --line: #e5e7eb;          /* bordas */
  --brand: #0f62fe;         /* azul profissional */
  --brand-600: #1158d6;     /* hover */

  /* Sidebar (branding) */
  --sidebar-bg: #ffcc00;
  --sidebar-fg: #1f2937;
  --sidebar-active: rgba(0,0,0,.12);
  --sidebar-hover: rgba(0,0,0,.07);
  --sidebar-divider: rgba(0,0,0,.08);

  /* Badges e estados */
  --badge-bg: #e7f1ff;
  --badge-fg: #0b5bd3;
  --ok: #2e7d32;
  --warn: #b45309;
  --danger: #d32f2f;

  /* Raios/sombras */
  --radius-sm: 8px;
  --radius: 12px;
  --radius-lg: 18px;
  --shadow-sm: 0 2px 10px rgba(16,24,40,.06);
  --shadow: 0 10px 30px rgba(16,24,40,.08);
  --shadow-lg: 0 18px 50px rgba(16,24,40,.10);

  /* Tipografia */
  --h1: clamp(1.6rem, 1.2rem + 1.4vw, 2.2rem);
  --h2: clamp(1.35rem, 1.05rem + 0.9vw, 1.75rem);
  --h3: 1.125rem;
}

/* ==========================================================================
   Tema Escuro
   ========================================================================== */
:root[data-theme="dark"]{
  --bg: #111827;           
  --surface: #1f2937;      
  --text: #f3f4f6;         
  --muted: #9ca3af;        
  --line: #374151;         
  --brand: #60a5fa;        
  --brand-600: #3b82f6;    

  /* Sidebar em dark: mantém identidade, mas reduz brilho do amarelo */
  --sidebar-bg: #e5b800;
  --sidebar-fg: #111827;
  --sidebar-active: rgba(255,255,255,.15);
  --sidebar-hover: rgba(255,255,255,.10);
  --sidebar-divider: rgba(0,0,0,.12);

  --badge-bg: rgba(96,165,250,0.15);
  --badge-fg: #93c5fd;

  --ok: #6ee7b7;
  --warn: #fcd34d;
  --danger: #f87171;

  --shadow-sm: 0 2px 10px rgba(0,0,0,.4);
  --shadow: 0 10px 30px rgba(0,0,0,.5);
  --shadow-lg: 0 18px 50px rgba(0,0,0,.6);
}

/* ==========================================================================
   Base tipográfica e fundo
   ========================================================================== */
html {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  font-feature-settings: "kern","liga","clig","calt","cv01","cv02","cv03","cv04";
  background: var(--bg);
}
body{
  color: var(--text);
  font-family: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  font-weight: 400;
  letter-spacing: 0.2px;
  line-height: 1.55;
  background: var(--bg);
}

/* Utilitários */
.emoji{ font-size: 1.05em; }
.time, .kpi, .mono { font-variant-numeric: tabular-nums; }

/* ==========================================================================
   Layout principal: Sidebar fixa + conteúdo com topbar fixa
   ========================================================================== */

/* Sidebar fixa */
.sidebar{
  position: fixed; top: 0; left: 0; bottom: 0;
  width: 260px;
  background: var(--sidebar-bg);
  color: var(--sidebar-fg);
  padding: 1rem .9rem;
  overflow-y: auto;
  box-shadow: 2px 0 10px rgba(0,0,0,.06);
}
.sidebar h2{
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: .2px;
  margin: .25rem .25rem 0.6rem;
  color: var(--sidebar-fg);
}
.sidebar ul{ list-style: none; }
.sidebar hr{
  border: none; height: 1px; background: var(--sidebar-divider);
  margin: .7rem 0 .9rem;
}
.sidebar .group-title{
  margin: 0 .25rem .35rem;
  font-size: .92rem;
  opacity:.95;
  color: var(--sidebar-fg);
}
.sidebar a{
  display: flex; align-items: center; gap: .6rem;
  padding: .56rem .7rem;
  margin: .12rem .1rem;
  border-radius: var(--radius-sm);
  text-decoration: none;
  color: var(--sidebar-fg);
  font-weight: 500;
  transition: background .15s ease, transform .04s ease;
}
.sidebar a:hover{ background: var(--sidebar-hover); }
.sidebar a.is-active{
  background: var(--sidebar-active);
  outline: 2px solid rgba(0,0,0,.14);
  font-weight: 600;
}

/* Conteúdo principal (fundo contínuo) */
.content{
  position: relative;
  margin-left: 260px;             /* largura da sidebar */
  min-height: 100vh;
  padding-top: 64px;              /* altura da topbar */
  background: var(--bg);
  overflow: hidden;
}

/* Topbar fixa da workspace */
.workspace-topbar{
  position: fixed;
  top: 0; left: 260px; right: 0;
  height: 64px;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 16px;
  background: rgba(255,255,255,0.82);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--line);
  box-shadow: var(--shadow-sm);
  z-index: 1000;
}
:root[data-theme="dark"] .workspace-topbar{
  background: rgba(31,41,55,0.82);
}
.ws-left{
  display: flex; align-items: center; gap: .55rem;
  color: var(--text);
  font-size: .96rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ws-left strong{ font-weight: 600; }
.ws-date{ color: var(--muted); }
.ws-dot{ color: var(--muted); margin: 0 .15rem; }
.ws-time{ font-weight: 600; }

.ws-role{
  margin-left: .6rem;
  display: inline-flex; align-items: center; gap: .35rem;
  padding: 2px 10px;
  border-radius: 999px;
  background: var(--badge-bg);
  color: var(--badge-fg);
  border: 1px solid rgba(11,91,211,.15);
  font-weight: 600;
  line-height: 1.2;
}

/* Ações à direita da topbar */
.ws-right{ display: flex; align-items: center; gap: .4rem; }
.topbar-btn{
  width: 36px; height: 36px;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--text);
  border-radius: 10px;
  box-shadow: var(--shadow-sm);
  cursor: pointer;
  font-size: 16px;
  transition: transform .06s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease, color .2s ease;
}
.topbar-btn:hover{
  transform: translateY(-1px);
  box-shadow: var(--shadow);
  background: #f9fafb;
}
:root[data-theme="dark"] .topbar-btn:hover{
  background: #111827;
}

/* Área de trabalho */
.workspace{
  padding: 20px 24px 28px;
}

/* Painéis padrão */
.panel{
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 18px 18px 16px;
}
.panel + .panel{ margin-top: 16px; }

.panel-title{
  font-size: var(--h2);
  font-weight: 700;
  letter-spacing: .2px;
  margin-bottom: .3rem;
}
.panel-subtitle{
  color: var(--muted);
  font-weight: 500;
}

/* ==========================================================================
   Login
   ========================================================================== */

#login-screen{
  position: fixed; inset: 0;
  display: grid; place-items: center;
  background: linear-gradient(180deg, #fff 0%, var(--bg) 100%);
  z-index: 2000;
}
:root[data-theme="dark"] #login-screen{
  background: linear-gradient(180deg, #1f2937 0%, var(--bg) 100%);
}
.login-box{
  width: 100%;
  max-width: 420px;
  background: var(--surface);
  padding: 24px 22px 18px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-lg);
}
.login-title-row{
  display: flex; align-items: center; gap: .6rem;
  font-size: 1.05rem; font-weight: 700;
  margin-bottom: .8rem;
  color: var(--text);
}
.login-label{ display:block; font-size:.9rem; margin:.55rem 0 .25rem; color: var(--muted); }
.login-input{
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: .65rem .7rem;
  outline: none;
  background: #fff;
  color: #111;
  transition: border-color .2s ease, box-shadow .2s ease;
}
:root[data-theme="dark"] .login-input{
  background: #111827; color: #f3f4f6; border-color: #374151;
}
.login-input:focus{
  border-color: var(--brand);
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--brand) 20%, transparent);
}
.login-btn{
  width: 100%;
  margin-top: .9rem;
  padding: .75rem .9rem;
  border: 1px solid var(--brand);
  background: var(--brand);
  color: #fff;
  border-radius: 12px;
  font-weight: 700;
  cursor: pointer;
  transition: background .15s ease, border-color .15s ease, transform .06s ease, box-shadow .2s ease;
}
.login-btn:hover{
  background: var(--brand-600); border-color: var(--brand-600);
  transform: translateY(-1px); box-shadow: var(--shadow);
}
.login-links{
  display:flex; justify-content: space-between; gap: .6rem;
  margin-top: .7rem; font-size: .9rem;
}
.login-links a{ color: var(--brand); text-decoration: none; }
.login-links a:hover{ text-decoration: underline; }

.login-title-row, .login-subtitle{
  user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  cursor: default;
}



/* Background SucaMob (imagem) — v4 */
.bg-cacamba{
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background: #0b1220 url("/sucamob-login-bg-v4-1920x1080.png")
              no-repeat right bottom / cover;
}
.bg-cacamba::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:
    radial-gradient(90% 90% at 20% 40%, rgba(11,18,32,.75) 0%, rgba(11,18,32,0) 60%),
    linear-gradient(90deg, rgba(11,18,32,.90) 0%, rgba(11,18,32,0) 40%);
}
:root[data-theme="dark"] .bg-cacamba { filter: brightness(0.95); }

/* Mobile (retrato) */
@media (orientation: portrait){
  .bg-cacamba{
    background-image: url("/sucamob-login-bg-v4-1080x1920.png");
    background-position: center bottom;
  }
}

/* ==========================================================================
   Form padrão, botões e inputs (aproveitado por módulos)
   ========================================================================== */

label{ display:block; }

input[type="text"], input[type="email"], input[type="password"], input[type="number"],
input[type="date"], select, textarea{
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: .6rem .7rem;
  background: #fff;
  color: var(--text);
  outline: none;
  transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}
:root[data-theme="dark"] input[type="text"],
:root[data-theme="dark"] input[type="email"],
:root[data-theme="dark"] input[type="password"],
:root[data-theme="dark"] input[type="number"],
:root[data-theme="dark"] input[type="date"],
:root[data-theme="dark"] select,
:root[data-theme="dark"] textarea{
  background: #111827; color: #f3f4f6; border-color: #374151;
}
textarea{ min-height: 120px; }
input:focus, select:focus, textarea:focus{
  border-color: var(--brand);
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--brand) 20%, transparent);
}

button{
  display: inline-flex; align-items: center; justify-content: center;
  gap: .45rem;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--text);
  border-radius: 12px;
  padding: .6rem .9rem;
  font-weight: 600;
  cursor: pointer;
  transition: transform .06s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease, color .2s ease;
}
button:hover{
  transform: translateY(-1px);
  box-shadow: var(--shadow);
  background: #f9fafb;
}
:root[data-theme="dark"] button:hover{
  background: #111827;
}
button.primary{
  background: var(--brand);
  color: #fff;
  border-color: var(--brand);
}
button.primary:hover{ background: var(--brand-600); border-color: var(--brand-600); }

/* Grids auxiliares */
.grid-2{ display:grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.grid-3{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.grid-4{ display:grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }

/* ==========================================================================
   Responsividade
   ========================================================================== */
@media (max-width: 1200px){
  .grid-4{ grid-template-columns: repeat(3,1fr); }
}
@media (max-width: 1024px){
  .content{ margin-left: 240px; }
  .workspace-topbar{ left: 240px; }
}
@media (max-width: 900px){
  .sidebar{ width: 220px; }
  .content{ margin-left: 220px; }
  .workspace-topbar{ left: 220px; }
}
@media (max-width: 720px){
  .sidebar{ position: fixed; width: 100%; height: auto; bottom: auto; z-index: 1200; }
  .content{ margin-left: 0; padding-top: 108px; }
  .workspace-topbar{ left: 0; top: 52px; }
  .ws-left{ gap: .45rem; font-size: .92rem; }
  .grid-3{ grid-template-columns: 1fr 1fr; }
  .grid-4{ grid-template-columns: 1fr 1fr; }
}
@media (max-width: 520px){
  .ws-left{ font-size: .9rem; }
  .ws-role{ display:none; } /* esconde badge em telas muito pequenas */
  .grid-2, .grid-3, .grid-4{ grid-template-columns: 1fr; }
}
/* ==== COMPONENTES PADRÃO — PCU Design System v1 ========================= */

/* Badges genéricos (além do ws-role) */
.badge{
  display:inline-flex; align-items:center; gap:.35rem;
  padding: 2px 10px; border-radius: 999px;
  background: color-mix(in oklab, var(--muted) 12%, transparent);
  color: var(--text); border: 1px solid color-mix(in oklab, var(--muted) 18%, transparent);
  font-weight: 600; font-size: .92rem; line-height: 1.2;
}
.badge.info{ background: color-mix(in oklab, var(--brand) 16%, transparent); color: var(--brand-600); }
.badge.success{ background: color-mix(in oklab, var(--ok) 16%, transparent); color: var(--ok); }
.badge.warning{ background: color-mix(in oklab, var(--warn) 16%, transparent); color: var(--warn); }
.badge.danger{ background: color-mix(in oklab, var(--danger) 16%, transparent); color: var(--danger); }

/* Botões — variações e tamanhos */
.btn{ /* já herdado do button global; garantindo classe para links <a> */
  display:inline-flex; align-items:center; justify-content:center; gap:.45rem;
  padding:.6rem .9rem; border-radius:12px; font-weight:600; text-decoration:none;
  border:1px solid var(--line); background: var(--surface); color: var(--text);
  transition: transform .06s, box-shadow .2s, background .2s, border-color .2s, color .2s;
}
.btn:hover{ transform: translateY(-1px); box-shadow: var(--shadow); background:#f9fafb; }
:root[data-theme="dark"] .btn:hover{ background:#111827; }
.btn.primary{ background: var(--brand); color:#fff; border-color: var(--brand); }
.btn.primary:hover{ background: var(--brand-600); border-color: var(--brand-600); }
.btn.ghost{ background: transparent; }
.btn.danger{ border-color: color-mix(in oklab, var(--danger) 30%, var(--line)); color: var(--danger); }
.btn.sm{ padding:.42rem .62rem; border-radius:10px; font-size:.92rem; }
.btn.lg{ padding:.8rem 1.1rem; border-radius:12px; font-size:1.02rem; }

/* Abas */
.tabs{ display:flex; gap:.25rem; border-bottom:1px solid var(--line); }
.tab{
  appearance:none; border:none; background:transparent; cursor:pointer;
  padding:.55rem .9rem; border-radius:8px 8px 0 0; color:var(--muted); font-weight:600;
}
.tab.is-active{ color:var(--text); background: var(--surface); border:1px solid var(--line); border-bottom-color: var(--surface); }

/* Tabela */
.table{ width:100%; border-collapse:separate; border-spacing:0; background: var(--surface); border:1px solid var(--line); border-radius:12px; overflow:hidden; }
.table thead th{
  text-align:left; font-weight:600; padding:.7rem .8rem; background: color-mix(in oklab, var(--surface) 85%, var(--bg));
  position: sticky; top: 0; z-index: 1; border-bottom:1px solid var(--line);
}
.table tbody td{ padding:.68rem .8rem; border-bottom:1px solid var(--line); }
.table tbody tr:hover{ background: color-mix(in oklab, var(--brand) 6%, transparent); }

/* Estados padrão */
.state{ display:flex; flex-direction:column; align-items:center; justify-content:center; gap:.6rem; padding:28px 8px; border:1px dashed var(--line); border-radius:12px; color:var(--muted); }
.state .empty{ font-size:2rem; }
.state-loading .loader{ width:26px; height:26px; border-radius:50%; border:3px solid var(--line); border-top-color: var(--brand); animation:spin 1s linear infinite; }
@keyframes spin { to{ transform: rotate(360deg); } }

/* Autocomplete (dropdown simples) */
.autocomplete-list{
  position:absolute; z-index: 999; background: var(--surface); border:1px solid var(--line); border-radius:10px; margin-top:4px; min-width: 240px; max-height: 240px; overflow:auto; box-shadow: var(--shadow);
}
.ac-item{ padding:.5rem .7rem; cursor:pointer; }
.ac-item:hover{ background: color-mix(in oklab, var(--brand) 8%, transparent); }
.ac-item.muted{ color: var(--muted); cursor: default; }

/* Overlay / Modal */
.overlay-bg{
  position: fixed; inset: 0; display:flex; align-items:center; justify-content:center;
  background: rgba(0,0,0,.17); z-index: 1050;
}
.overlay-modal{
  background: var(--surface); border-radius: 18px; max-width: 960px; width: 98vw; max-height: 96vh;
  box-shadow: 0 8px 32px rgba(0,0,0,0.17); padding: 1.6rem 1.8rem; overflow-y:auto; position:relative; display:flex; flex-direction:column; border:1px solid var(--line);
}

/* Toasts */
.toast-container{
  position: fixed; right: 16px; top: 76px; display: flex; flex-direction: column; gap: 10px; z-index: 1200;
}
.toast{
  min-width: 240px; max-width: 420px; padding: .7rem .9rem; border-radius: 12px; border:1px solid var(--line); background: var(--surface);
  box-shadow: var(--shadow); color: var(--text); transform: translateY(-8px); opacity: 0; transition: transform .18s ease, opacity .18s ease;
}
.toast.show{ transform: translateY(0); opacity: 1; }
.toast.info{ border-color: color-mix(in oklab, var(--brand) 30%, var(--line)); }
.toast.success{ border-color: color-mix(in oklab, var(--ok) 30%, var(--line)); }
.toast.warning{ border-color: color-mix(in oklab, var(--warn) 30%, var(--line)); }
.toast.danger{ border-color: color-mix(in oklab, var(--danger) 30%, var(--line)); }

/* Form helpers */
.form-row{ display:grid; gap: 12px; }
.form-field{ position: relative; }
.form-field .help-text{ color: var(--muted); font-size:.9rem; margin-top:.25rem; }
.form-field.is-error input, .form-field.is-error select, .form-field.is-error textarea{ border-color: color-mix(in oklab, var(--danger) 40%, var(--line)); box-shadow: 0 0 0 4px color-mix(in oklab, var(--danger) 16%, transparent); }
.form-field .error-text{ color: var(--danger); font-size:.9rem; margin-top:.25rem; }
/* ===== Fix hover dos botões no app ===== */
:root{
  --btn-primary:#2563EB;
  --btn-primary-hover:#1D4ED8;
  --btn-secondary:#F3F4F6;
  --btn-secondary-hover:#E5E7EB;
  --text-on-primary:#fff;
  --text-on-secondary:#111;
}

/* Escopo para evitar conflito com regras globais antigas */
#main-container .btn,
#pw-change-root .btn{
  transition: background-color .15s ease, color .15s ease, box-shadow .15s ease;
}

/* Primary */
#main-container .btn-primary,
#pw-change-root .btn-primary{
  background: var(--btn-primary) !important;
  color: var(--text-on-primary) !important;
}
#main-container .btn-primary:hover,
#main-container .btn-primary:focus,
#pw-change-root .btn-primary:hover,
#pw-change-root .btn-primary:focus{
  background: var(--btn-primary-hover) !important;
  color: var(--text-on-primary) !important;
  box-shadow: 0 2px 10px rgba(37,99,235,.25);
}

/* Secondary */
#main-container .btn-secondary,
#pw-change-root .btn-secondary{
  background: var(--btn-secondary) !important;
  color: var(--text-on-secondary) !important;
}
#main-container .btn-secondary:hover,
#main-container .btn-secondary:focus,
#pw-change-root .btn-secondary:hover,
#pw-change-root .btn-secondary:focus{
  background: var(--btn-secondary-hover) !important;
  color: var(--text-on-secondary) !important;
}

/* Disabled não deve “acender” no hover */
#main-container .btn[disabled],
#pw-change-root .btn[disabled]{
  opacity:.6; pointer-events:none; filter:saturate(.6);
}
#main-container .btn[disabled]:hover,
#pw-change-root .btn[disabled]:hover{
  background: inherit !important;
  color: inherit !important;
  box-shadow: none !important;
}
/* === Centralizar tela de login e zerar offset da sidebar === */
body.is-auth-screen .sidebar { display: none !important; }
body.is-auth-screen #main-container,
body.is-auth-screen .app-shell,
body.is-auth-screen .app-content {
  margin-left: 0 !important;
  padding-left: 0 !important;
}

/* Se seu login tem um wrapper, mantenha centralizado */
body.is-auth-screen .login-wrapper {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

body.is-auth-screen #login-screen { display: grid !important; place-items: center; }
.overlay-bg { position:fixed; inset:0; background:rgba(0,0,0,.17); display:flex; align-items:center; justify-content:center; z-index:1050; }
.overlay-modal { background:#fff; border-radius:18px; width:min(640px, 92vw); padding:24px; box-shadow:0 8px 32px rgba(0,0,0,.17); }
.btn-primary { border:0; padding:.65rem 1rem; border-radius:10px; font-weight:600; cursor:pointer; }

/* Barra de busca grande + botões à direita */
.search-row{
  display:flex;
  align-items:center;
  gap:10px;             /* espaço entre input e botões */
  flex-wrap:nowrap;     /* não quebra de linha no desktop */
}
.search-row .form-field{
  flex:1 1 auto;        /* input ocupa todo o restante */
  min-width:240px;      /* ainda permite encolher no desktop */
}
.search-actions{
  display:flex;
  gap:10px;
  flex:0 0 auto;        /* não estica, fica só do tamanho dos botões */
  white-space:nowrap;
}
/* altura consistente (se seu kit não padroniza) */
.search-row input.form-field{ height:44px; }
.search-actions > button{ height:44px; }

/* Responsivo: em telas menores, pode quebrar; botões descem alinhados à direita */
@media (max-width: 720px){
  .search-row{ flex-wrap:wrap; }
  .search-actions{ width:100%; justify-content:flex-end; }
}

/* === ULTRA GLASS — Login compacto e translúcido ======================= */
:root{
  /* tamanho do card */
  --login-max-w: 400px;

  /* transparência do card */
  --glass-1: 0.70;   /* topo (claro)   */
  --glass-2: 0.52;   /* base (escuro)  */

  /* inputs */
  --field-alpha: .20;
  --field-alpha-hover: .26;
  --field-alpha-focus: .30;
}

:root[data-theme="dark"]{
  --glass-1: 0.56;
  --glass-2: 0.40;
  --field-alpha: .18;
  --field-alpha-hover: .24;
  --field-alpha-focus: .28;
}

#login-screen{ padding: clamp(14px, 4vh, 32px); }

.login-box{
  max-width: var(--login-max-w);
  padding: 18px 18px 16px;

  /* vidro em camadas */
  background:
    linear-gradient( to bottom right,
      rgba(255,255,255,var(--glass-1)),
      rgba(255,255,255,var(--glass-2))
    );
  border: 1px solid rgba(255,255,255,.22);
  border-radius: 20px;

  backdrop-filter: blur(16px) saturate(1.15);
  -webkit-backdrop-filter: blur(16px) saturate(1.15);

  box-shadow:
    0 18px 50px rgba(0,0,0,.35),
    inset 0 1px 0 rgba(255,255,255,.25);
  position: relative;
}

/* brilho superior suave no card */
.login-box::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  border-radius: inherit;
  background:
    linear-gradient(180deg, rgba(255,255,255,.35), transparent 42%);
  mix-blend-mode: soft-light;
}

/* título mais compacto */
.login-title-row{ margin-bottom: .45rem; }
.login-subtitle{ margin-bottom: .75rem; opacity:.9; }

/* ===== Inputs de vidro ===== */
.login-input{
  height: 44px;
  border-radius: 12px;
  color: var(--text);

  background: rgba(255,255,255,var(--field-alpha));
  border: 1px solid rgba(255,255,255,.28);
  backdrop-filter: blur(10px) saturate(1.1);
  -webkit-backdrop-filter: blur(10px) saturate(1.1);

  box-shadow: inset 0 1px 0 rgba(255,255,255,.25);
  transition: background .15s ease, border-color .15s ease, box-shadow .15s ease;
}
.login-input::placeholder{
  color: rgba(255,255,255,.75);
  mix-blend-mode: overlay;
}
.login-input:hover{
  background: rgba(255,255,255,var(--field-alpha-hover));
}
.login-input:focus{
  background: rgba(255,255,255,var(--field-alpha-focus));
  border-color: color-mix(in oklab, var(--brand) 60%, white);
  box-shadow:
    0 0 0 6px color-mix(in oklab, var(--brand) 22%, transparent),
    inset 0 1px 0 rgba(255,255,255,.35);
}

/* botão mantém a cor de marca, com um toque vidro */
.login-btn{
  height: 46px; border-radius: 12px; font-weight: 800;
  box-shadow:
    0 10px 28px rgba(37,99,235,.35),
    inset 0 1px 0 rgba(255,255,255,.25);
}

/* links discretos */
.login-links{ opacity:.95; }

/* responsivo */
@media (max-width: 480px){
  .login-box{ max-width: 92vw; padding: 16px 14px; }
}
/* ===== Sidebar Brand — grande, destacado e NÃO clicável ===== */
.sidebar .sb-brand{
  display: grid;
  grid-template-columns: 40px 1fr;
  grid-template-areas:
    "logo title"
    "logo subtitle";
  align-items: center;
  gap: 2px .65rem;

  margin: .4rem .5rem .7rem;
  padding: 12px 12px 14px;
  border-radius: 14px;
  background: color-mix(in oklab, var(--sidebar-fg) 8%, var(--sidebar-bg));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.18), 0 2px 10px rgba(0,0,0,.08);
  border: 1px solid var(--sidebar-divider);

  cursor: default;
  user-select: none;
}
.sidebar .sb-brand:hover{ background: color-mix(in oklab, var(--sidebar-fg) 10%, var(--sidebar-bg)); }
.sb-brand-logo{ grid-area: logo; width: 36px; height: 36px; display:block; }

.sb-brand-text{ min-width: 0; }
.sb-brand-title{
  grid-area: title;
  font-weight: 900;
  font-size: 1.28rem;         /* maior */
  line-height: 1.1;
  letter-spacing: .2px;
  color: var(--sidebar-fg);
}
.sb-brand-subtitle{
  grid-area: subtitle;
  font-size: .98rem;          /* maior também */
  line-height: 1.15;
  margin-top: 2px;
  color: color-mix(in oklab, var(--sidebar-fg) 74%, black);
  opacity: .95;
  text-wrap: balance;
}

.sidebar .sb-divider{ margin: .6rem .5rem .9rem; opacity: .5; }

/* Dark theme: ligeiro ajuste de contraste */
:root[data-theme="dark"] .sb-brand{
  background: color-mix(in oklab, var(--sidebar-fg) 12%, var(--sidebar-bg));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.12), 0 2px 10px rgba(0,0,0,.18);
}

/* Responsivo: se a sidebar for 220px, reduz um pouco */
@media (max-width: 900px){
  .sb-brand-logo{ width: 32px; height: 32px; }
  .sb-brand-title{ font-size: 1.18rem; }
  .sb-brand-subtitle{ font-size: .94rem; }
}
.unit-picker, .city-picker { position: relative; }
.city-suggest, .unit-suggest { z-index: 20; }

