    :root{
      --blue-dark:#00427e;
      --blue-medium:#0072a9;
      --neutral-gray:#808285;
      --white-cold:#F2F5F7;
      --text-dark:#4A4D4F;
      --blue-light:#9BCFE0;

      --bg:var(--white-cold);
      --card-bg: rgba(255,255,255,0.75);
      --glass: rgba(242,245,247,0.55);

      --radius:12px;
      --shadow: 0 6px 18px rgba(10,20,30,0.06);

      --header-height:92px; /* desktop */
      --header-min:56px; /* after scroll */

      --primary: var(--blue-dark); /* botão ativo das abas */
    }

    /* Reset minimal */
    *{box-sizing:border-box}
    html,body{height:100%}
    body{
      margin:0;
      font-family:Inter, system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial;
      background:linear-gradient(180deg,var(--bg),#eef4f8 120%);
      color:var(--text-dark);
      -webkit-font-smoothing:antialiased;
      -moz-osx-font-smoothing:grayscale;
      -webkit-tap-highlight-color:transparent;
    }

    /* =====================
       Header (shrink-on-scroll)
       ===================== */
    .site-header {
      position: sticky;
      top: 0;
      z-index: 60;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 16px;
      padding: 16px 20px;

      height: var(--header-height);
      background: linear-gradient(90deg, rgba(0,66,126,0.06), rgba(0,114,169,0.02));
      backdrop-filter: blur(6px) saturate(120%);
      border-bottom: 1px solid rgba(0,0,0,0.04);
      box-shadow: var(--shadow);

      /* ✨ Suavização sem tremor */
      will-change: transform, opacity;
      transition: transform 0.32s ease, box-shadow 0.32s ease, opacity 0.32s ease;
    }
    
    .site-header.shrink {
      transform: translateY(-8px) scale(0.98);
      opacity: 0.97;
      box-shadow: 0 8px 24px rgba(10,20,30,0.08);
      backdrop-filter: blur(10px) saturate(140%);
    }

    /* Compensa o recuo visual para não gerar jump no conteúdo */
    body.has-shrink-header {
      padding-top: var(--header-min);
    }

    /* Logo */
    .brand{
      display:flex;align-items:center;gap:12px;min-width:160px;
    }
    .brand .logo{
      width:48px;height:48px;border-radius:10px;background:linear-gradient(135deg,var(--blue-dark),var(--blue-medium));
      display:grid;place-items:center;color:var(--white-cold);font-weight:700;font-size:18px;box-shadow:0 4px 12px rgba(0,66,126,0.25);
    }
    .brand .title{line-height:1;}
    .brand .title .app{font-weight:700;color:var(--blue-dark)}
    .brand .title .sub{font-size:12px;color:var(--neutral-gray)}

    /* Header actions */
    .header-actions{display:flex;align-items:center;gap:12px}
    .icon-btn{
      background:transparent;border:0;padding:8px;border-radius:10px;cursor:pointer;display:inline-grid;place-items:center;min-width:44px;min-height:44px
    }
    .icon-btn:hover{background:rgba(0,0,0,0.03)}

    .badge-notif{
      position:relative;display:inline-block
    }
    .badge-notif .counter{
      position:absolute;top:6px;right:6px;background:var(--blue-medium);color:var(--white-cold);font-size:11px;padding:2px 6px;border-radius:999px;box-shadow:0 2px 6px rgba(0,0,0,0.12)
    }

    /* Dropdowns */
    .dropdown{position:relative}
    .dropdown-panel{
      position:absolute;right:0;top:calc(100% + 12px);min-width:260px;background:var(--card-bg);backdrop-filter: blur(6px);border-radius:12px;padding:12px;box-shadow:var(--shadow);border:1px solid rgba(74,77,79,0.06);display:none;
    }
    .dropdown.open .dropdown-panel{display:block}

    /* Layout grid */
    .container{max-width:1200px;margin:18px auto;padding:0 18px}
    .layout{display:grid;grid-template-columns: 280px 1fr;gap:20px;align-items:start}

    /* Responsive collapse for mobile */
    @media (max-width:900px){
      .layout{grid-template-columns:1fr}
      .sidebar{order:2}
      .mobile-bottom-nav{display:flex}
    }

    /* Sidebar */
    .sidebar{padding:14px;background:linear-gradient(180deg,var(--glass), rgba(255,255,255,0.6));border-radius:12px;border:1px solid rgba(0,0,0,0.04)}
    .nav-item{display:flex;align-items:center;gap:12px;padding:10px;border-radius:8px;color:var(--text-dark);cursor:pointer}
    .nav-item:hover{background:rgba(0,0,0,0.03)}
    .nav-item a{display:flex;align-items:center;gap:12px;padding:10px;border-radius:8px;color:var(--text-dark);cursor:pointer}

    /* Cards */
    .card{background:var(--card-bg);border-radius:12px;padding:14px;border:1px solid rgba(0,0,0,0.04);box-shadow:var(--shadow)}

    /* Fieldset elegant (transparent) */
    fieldset.elegant{
      border-radius:12px;border:1px solid rgba(128,130,133,0.12);padding:14px;background:linear-gradient(180deg, rgba(255,255,255,0.56), rgba(255,255,255,0.42));backdrop-filter: blur(4px);
    }
    fieldset.elegant legend{padding:0 8px;color:var(--blue-dark);font-weight:600}

    /* Badge harmonic */
    .status-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;font-weight:600;font-size:13px}
    .status-badge--novo{background:linear-gradient(90deg,var(--blue-light),var(--blue-medium));color:var(--text-dark)}
    .status-badge--ativo{background:linear-gradient(90deg,#e6f9f0,#81C784);color:#255b38}
    .status-badge--inativo{background:rgba(0,0,0,0.04);color:var(--neutral-gray)}

    /* Tiny helpers */
    .muted{color:var(--neutral-gray);font-size:13px}
    .row{display:flex;gap:12px;align-items:center}
    .spacer{flex:1}

    /* Dashboard placeholders */
    .donut{
      width:140px;
      height:140px;
      border-radius:50%;
      background:conic-gradient(var(--blue-medium) 0 45%, #e6eef5 0 100%);
      display:grid;
      place-items:center;
      font-weight:700;
      color:var(--blue-dark)
    }

    /* Mobile bottom nav */
    .mobile-bottom-nav{display:none;position:fixed;bottom:16px;left:50%;transform:translateX(-50%);gap:8px;background:var(--card-bg);padding:6px;border-radius:999px;border:1px solid rgba(0,0,0,0.04);box-shadow:var(--shadow)}

    /* Forms and upload */
    .form-row{display:flex;gap:12px;align-items:center}
    .input{padding:10px;border-radius:8px;border:1px solid rgba(0,0,0,0.06);background:transparent}

    .texto-recorte {
      font-size: 1dvw*1dvh;
      color: #4A4D4F;
      mix-blend-mode: exclusion; /* ou exclusion, multiply, overlay */
      padding:1dvh;
      text-align:center;
      margin-right: 5dvh;
    }

    /* Garantia de overlay/modal global (adicionar ao final de base.css) */
.blocker {
  position: fixed !important;
  top: 0; left: 0;
  width: 100dvw;
  height: 100dvh;
  background: rgba(0,0,0,0.45);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
}

.alert {
  padding: 10px 14px;
  border-radius: 8px;
  font-weight: 500;
  backdrop-filter: blur(6px);
}
.alert-success {
  background: rgba(0, 180, 90, 0.2);
  color: #0a5c2e;
  border: 1px solid rgba(0, 180, 90, 0.3);
}
.alert-danger {
  background: rgba(220, 0, 0, 0.2);
  color: #6b0d0d;
  border: 1px solid rgba(220, 0, 0, 0.3);
}

/* Botões padrão */
.btn {
  padding: 8px 16px;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  border: none;
  outline: none;
  backdrop-filter: blur(8px);
  background: rgba(255, 255, 255, 0.15);
  color: #fff;
  box-shadow: 0 4px 10px rgba(0,0,0,0.2);
  transition: all 0.2s ease;
}

.btn-clean {
  padding: 8px 16px;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  border: none;
  outline: none;
  backdrop-filter: blur(8px);
  background: rgba(255, 255, 255, 0.15);
  color: #A0A0A0 !important;
  box-shadow: 0 4px 10px rgba(0,0,0,0.2);
  transition: all 0.2s ease;
}

.btn:hover {
  background: rgba(255, 255, 255, 0.25);
  transform: translateY(-2px);
  box-shadow: 0 6px 14px rgba(0,0,0,0.25);
}

.btn:active {
  transform: translateY(0);
  box-shadow: 0 2px 6px rgba(0,0,0,0.2);
}

/* Botão primário */
.btn-primary {
  background: rgba(0, 66, 126, 0.8);
}

.btn-primary:hover {
  background: rgba(0, 66, 126, 1);
}

/* Botão de perigo */
.btn-danger {
  background: rgba(220, 53, 69, 0.8);
}

.btn-danger:hover {
  background: rgba(220, 53, 69, 1);
}

/* Botão de ação secundária */
.btn-secondary {
  background: rgba(108, 117, 125, 0.6);
}

.btn-secondary:hover {
  background: rgba(108, 117, 125, 0.9);
}


/* Botão de navegação (Voltar) */
.btn-back {
  padding: 8px 16px;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 500;
  border: 1px solid rgba(0, 66, 126, 0.6);
  background: transparent;
  color: #00427e;
  cursor: pointer;
  transition: all 0.2s ease;
}

.btn-back:hover {
  background: rgba(0, 66, 126, 0.08);
}

.btn-back:active {
  background: rgba(0, 66, 126, 0.15);
}

a {
  text-decoration: none;
}

.tab-btn.disabled {
  opacity: 0.4;
  cursor: not-allowed;
  pointer-events: none;
}

.imagem-tipo {
  height: 5dvh;
}

.imagem-cabeçalho {
  height: 5dvh;
  max-height: 40px;
  min-width: 40px;
}

.modal{
  max-width: 80dvw;
  max-height: 90dvh;
  overflow-y: auto;
}

#modal-title{
  max-width: 56dvw;
  max-height: 90dvh;
  overflow-y: auto;
}

#modal-date{
  max-width: 56dvw;
  max-height: 90dvh;
  overflow-y: auto;
}


/* ===============================
   TEXTOS RICOS E DESCRITIVOS
   =============================== */
.text-rich {
  max-width: 59dvw; /* Ideal: 60–75 caracteres por linha */
  /* margin: 0 auto; */
  line-height: 1.65;
  font-size: clamp(0.95rem, 1vw, 1.05rem);
  color: var(--text-dark);
  text-align: justify; /* ou left, conforme contexto */
  hyphens: auto; /* quebras suaves de palavras */
  word-wrap: break-word;
  overflow-wrap: break-word;
}

/* Títulos e subtítulos dentro de texto */
.text-rich h2, 
.text-rich h3 {
  color: var(--blue-dark);
  font-weight: 700;
  margin-top: 1.2em;
  margin-bottom: 0.6em;
}

/* Parágrafos espaçados de forma equilibrada */
.text-rich p {
  margin-bottom: 1em;
}

/* Listas */
.text-rich ul, 
.text-rich ol {
  padding-left: 1.4em;
  margin-bottom: 1em;
}
.text-rich li {
  margin-bottom: 0.3em;
}

/* Blocos de citação */
.text-rich blockquote {
  border-left: 4px solid var(--blue-light);
  padding-left: 1em;
  color: var(--neutral-gray);
  font-style: italic;
  margin: 1em 0;
}

/* Código / exemplos */
.text-rich code {
  background: rgba(0,0,0,0.05);
  padding: 2px 6px;
  border-radius: 4px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.9em;
}

/* Responsive collapse for mobile */
@media (min-width:800px){
  .text-rich {
    margin: 0 auto !important;
  }
}

/* css do modal de notificações */

 .banners.modal .modal-content {
  width: 90dvw;
  max-width: 100%;
  max-height: 85dvh;
  overflow-y: auto;
  background: rgba(255,255,255,0.12);
  backdrop-filter: blur(12px) saturate(180%);
  -webkit-backdrop-filter: blur(12px) saturate(180%);
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,0.20);
  box-shadow: 0 10px 30px rgba(0,0,0,0.30);
  color: #fff;
  padding: 18px;
  box-sizing: border-box;
}

/* Mobile tweaks */
@media (max-width: 600px) {
  .modal .modal-content, .banners.modal .modal-content {
    /* width: 95dvw;
    max-width: 95dvw; */
    max-height: 92dvh;
    padding: 14px;
    border-radius: 12px;
  }
}

.close-modal {
  appearance: none;
  -webkit-appearance: none;
  border: 0;
  background: transparent;
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
  padding: 6px 10px;
  border-radius: 8px;
  position: absolute;
  right: 1dvw;
  top: -1dvh;
}

.close-modal:hover { 
  outline: 3px solid rgba(0,114,169,0.18); 
}

.banners.modal .modal-content {
  animation: fadeInUp 0.4s ease-out;
}

@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Override modal base to use glassmorphism and viewport units */
.modal {
  /* position: fixed;
  top: 0;
  left: 0; */
  /* width: 100dvw;
  height: 100dvh; */
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.8); /* fallback if plugin uses modal container */
  z-index: 1000;
  padding: 20px;
}

.blur-text {
    color: transparent;
    text-shadow: 0 0 7px #555, 0 0 10px #000;
}

/* ======================================================
   BLOCO DE TIPOS — REVISÃO DE LAYOUT E GRÁFICO
   ====================================================== */

/* Container geral dos tipos */
.score-types {
  margin-top: 24px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
  gap: 24px;
}

/* Cada tipo de pontuação */
.score-type.glass-card {
  display: flex;
  flex-direction: column;
  background: rgba(255,255,255,0.75);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 16px;
  box-shadow: 0 6px 18px rgba(0,0,0,0.06);
  overflow: hidden;
  transition: transform .25s ease, box-shadow .25s ease;
}
.score-type.glass-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(0,0,0,0.1);
}

/* Cabeçalho do tipo */
.score-type-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  gap: 16px;
  background: linear-gradient(135deg, rgba(255,255,255,0.65), rgba(245,245,245,0.4));
  backdrop-filter: blur(10px) saturate(140%);
  border-bottom: 1px solid rgba(255,255,255,0.25);
}

/* Info textual */
.score-type-info h4 {
  color: var(--blue-dark);
  font-size: 1.2rem;
  font-weight: 700;
  margin: 0;
}
.score-type-sub {
  color: var(--neutral-gray);
  font-size: 0.9rem;
}

/* Gráfico lateral */
.score-type-chart {
  flex-shrink: 0;
  width: 120px;
  height: 120px;
  position: relative;
}
.score-type-chart canvas {
  width: 100% !important;
  height: 100% !important;
  display: block;
  object-fit: contain;
}

/* Lista de itens */
.score-type-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 16px 20px;
  background: linear-gradient(180deg, rgba(255,255,255,0.5), rgba(250,250,250,0.35));
  max-height: 280px;
  overflow-y: auto;
}

/* Itens */
.score-type-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: rgba(255,255,255,0.8);
  border-radius: 10px;
  padding: 10px 14px;
  box-shadow: 0 2px 6px rgba(0,0,0,0.05);
  transition: all 0.2s ease;
}
.score-type-item:hover {
  background: rgba(255,255,255,0.95);
  transform: translateY(-2px);
}

.item-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.item-title {
  font-weight: 600;
  color: #003f74;
}
.item-sub {
  font-size: 0.85rem;
  color: rgba(0,0,0,0.6);
}
.item-value {
  font-weight: 700;
  color: var(--blue-medium);
}

/* Responsivo */
@media (max-width: 768px) {
  .score-type-header {
    flex-direction: column;
    align-items: flex-start;
  }
  .score-type-chart {
    align-self: center;
    width: 140px;
    height: 140px;
    margin-top: 12px;
  }
}

.notif-item {
  transition: opacity 0.25s ease, transform 0.2s ease;
}
.notif-item.read {
  opacity: 0.55 !important;
  transform: scale(0.99);
}

.fade-retangular {
  --fade-size: 32px;

  -webkit-mask-image: 
    linear-gradient(to right, transparent 0, black var(--fade-size), black calc(100% - var(--fade-size)), transparent 100%),
    linear-gradient(to bottom, transparent 0, black var(--fade-size), black calc(100% - var(--fade-size)), transparent 100%);
  -webkit-mask-composite: multiply;
          mask-composite: intersect;
}


/* Parte de abas no adição de novo filtro modelo */

.modal-overlay {
  display: none; /* estado padrão */
  align-items: center;
  justify-content: center;
  position: fixed !important;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.45);
  backdrop-filter: blur(4px);
  z-index: 9999;
}

.modal-card {
  background: var(--card-bg);
  border-radius: 14px;
  padding: 22px;
  width: 90%;
  max-width: 900px;
  max-height: 85vh;
  overflow-y: auto;
  border: 1px solid rgba(0,0,0,0.05);
  box-shadow: 0 8px 24px rgba(0,0,0,0.15);
  animation: fadeInUp .25s ease;
  backdrop-filter: blur(12px) saturate(180%);
}

@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

.preview-panel {
  display: none;
  animation: fadeIn .22s ease;
}

.preview-panel.active {
  display: block;
}

/* ============================
   PREVIEW TABS (Big Tech)
   ============================ */

.preview-tab {
  padding: 6px 14px;
  background: rgba(255,255,255,0.35);
  border-radius: 8px;
  border: 1px solid rgba(0,0,0,0.06);
  cursor: pointer;
  font-weight: 500;
  color: var(--text-dark);
  transition: all .25s ease;
  backdrop-filter: blur(8px) saturate(140%);
}

.preview-tab:hover {
  background: rgba(255,255,255,0.55);
  transform: translateY(-1px);
}

.preview-tab.active {
  background: var(--blue-light);
  border-color: var(--blue-dark);
  color: var(--blue-dark);
  font-weight: 600;
  box-shadow: 0 3px 8px rgba(0,0,0,0.12);
}


/* Base botões delete */

.btn-icon {
  border: none;
  background: transparent;
  cursor: pointer;
  padding: 6px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 6px;
  transition: background 0.2s ease;
}

.btn-icon:hover {
  background: rgba(0, 0, 0, 0.05);
}

.btn-icon.danger i {
  color: #c0392b;
  font-size: 18px;
}

.btn-icon.danger:hover i {
  color: #e74c3c;
}
