/* =============================================
   MFBT — Marcus Ferreira Beach Tennis
   Estilo Principal — Tema Claro Moderno
   ============================================= */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');

:root {
  --laranja: #ff6900;
  --laranja-escuro: #e05c00;
  --laranja-claro: #ff8533;
  --laranja-suave: rgba(255, 105, 0, 0.08);
  --laranja-borda: rgba(255, 105, 0, 0.25);

  --preto: #0f0f0f;
  --preto-suave: #1a1a1a;
  --texto-principal: #111111;
  --texto-secundario: #555555;
  --texto-terciario: #888888;

  --fundo: #ffffff;
  --fundo-pagina: #f7f7f7;
  --fundo-card: #ffffff;
  --fundo-input: #f9f9f9;
  --fundo-input-foco: #ffffff;

  --borda: #e8e8e8;
  --borda-foco: var(--laranja);

  --cinza-900: #1a1a1a;
  --cinza-800: #2a2a2a;
  --cinza-700: #3a3a3a;
  --cinza-600: #555555;
  --cinza-400: #888888;
  --cinza-200: #e0e0e0;
  --cinza-100: #f5f5f5;
  --branco: #ffffff;

  --verde: #16a34a;
  --verde-suave: rgba(22, 163, 74, 0.08);
  --vermelho: #dc2626;
  --vermelho-suave: rgba(220, 38, 38, 0.08);
  --amarelo: #d97706;
  --amarelo-suave: rgba(217, 119, 6, 0.08);

  --sombra-sm: 0 1px 3px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
  --sombra-md: 0 4px 16px rgba(0,0,0,0.07), 0 2px 4px rgba(0,0,0,0.04);
  --sombra-lg: 0 16px 40px rgba(0,0,0,0.10), 0 4px 12px rgba(0,0,0,0.05);
  --sombra-laranja: 0 4px 20px rgba(255,105,0,0.25);

  --raio: 12px;
  --raio-sm: 8px;
  --raio-lg: 16px;
  --raio-xl: 20px;
  --raio-pill: 999px;
  --barra-largura: 248px;
  --fonte: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --transicao: 0.18s ease;
}

/* ============ RESET ============ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; overflow-x: hidden; }
body {
  font-family: var(--fonte);
  background: var(--fundo-pagina);
  color: var(--texto-principal);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}
a { color: var(--laranja); text-decoration: none; transition: color var(--transicao); }
a:hover { color: var(--laranja-escuro); }
img { max-width: 100%; display: block; }
button { cursor: pointer; font-family: var(--fonte); }

/* =============================================
   AUTENTICAÇÃO — Split Screen Moderno
   ============================================= */

.layout-auth {
  min-height: 100vh;
  display: flex;
  align-items: stretch;
  padding: 0;
  background: #09090f;
}

/* ——— Contêiner split ——— */
.split-login {
  display: flex;
  width: 100%;
  min-height: 100vh;
}

/* ——— Painel esquerdo: foto ——— */
.split-foto {
  flex: 0 0 56%;
  position: relative;
  overflow: hidden;
  background-image: url('/assets/img/fundo.jpeg');
  background-size: cover;
  background-position: center 18%;
}

.split-foto-overlay {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 20% 85%, rgba(255,105,0,0.22) 0%, transparent 55%),
    linear-gradient(160deg, rgba(4,4,10,0.55) 0%, rgba(4,4,10,0.40) 50%, rgba(4,4,10,0.70) 100%);
}

.split-foto-conteudo {
  position: relative;
  z-index: 2;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 2.75rem 3rem;
}

.split-logo {
  width: 190px;
  height: auto;
  flex-shrink: 0;
}

.split-foto-rodape {
  display: flex;
  flex-direction: column;
}

.split-foto-titulo {
  font-size: 2.125rem;
  font-weight: 800;
  color: #ffffff;
  line-height: 1.2;
  letter-spacing: -0.03em;
  text-shadow: 0 2px 20px rgba(0,0,0,0.5);
}

.split-foto-sub {
  font-size: 1rem;
  color: rgba(255,255,255,0.68);
  margin-top: 0.75rem;
  line-height: 1.65;
}

.split-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: rgba(255,105,0,0.15);
  border: 1px solid rgba(255,105,0,0.35);
  color: #ff9040;
  border-radius: 999px;
  padding: 0.5rem 1rem;
  font-size: 0.8125rem;
  font-weight: 500;
  margin-top: 1.5rem;
  width: fit-content;
  backdrop-filter: blur(8px);
}

/* ——— Painel direito: formulário ——— */
.split-form {
  flex: 1;
  background: #09090f;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2.5rem 2rem;
  position: relative;
}

/* Linha laranja sutil no topo */
.split-form::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, rgba(255,105,0,0.45) 50%, transparent 100%);
}

/* Borda esquerda sutil */
.split-form::after {
  content: '';
  position: absolute;
  top: 0; left: 0; bottom: 0;
  width: 1px;
  background: linear-gradient(180deg, transparent, rgba(255,255,255,0.07) 30%, rgba(255,255,255,0.07) 70%, transparent);
}

.split-form-inner {
  width: 100%;
  max-width: 368px;
}

.split-mobile-logo {
  display: none;
  width: 120px;
  height: auto;
  margin: 0 auto 2.25rem;
}

.split-form-header {
  margin-bottom: 2rem;
}

.split-form-titulo {
  font-size: 1.875rem;
  font-weight: 700;
  color: #ffffff;
  letter-spacing: -0.03em;
  line-height: 1.2;
}

.split-form-sub {
  font-size: 0.9375rem;
  color: rgba(255,255,255,0.42);
  margin-top: 0.5rem;
}

/* ——— Campos no painel escuro ——— */
.split-form .campo-label {
  color: rgba(255,255,255,0.88);
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.01em;
}

.split-form .campo-input {
  background: rgba(255,255,255,0.10);
  border: 1.5px solid rgba(255,255,255,0.22);
  color: #ffffff;
  border-radius: 10px;
  font-size: 0.9375rem;
}

.split-form .campo-input::placeholder {
  color: rgba(255,255,255,0.42);
}

.split-form .campo-input:focus {
  background: rgba(255,255,255,0.14);
  border-color: var(--laranja);
  box-shadow: 0 0 0 3px rgba(255,105,0,0.22);
}

.split-form .btn-ver-senha {
  color: rgba(255,255,255,0.55);
}

.split-form .btn-ver-senha:hover {
  color: var(--laranja);
}

.split-form .auth-link {
  color: rgba(255,255,255,0.50);
}

.split-form .auth-link a {
  color: var(--laranja-claro);
}

.split-form .alerta {
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.18);
  color: rgba(255,255,255,0.90);
  margin-bottom: 1.5rem;
}

/* Rodapé na tela de auth */
.layout-auth .rodape-app {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 0.75rem 1.5rem;
  background: transparent;
  border-top: 1px solid rgba(255,255,255,0.06);
  text-align: center;
  color: rgba(255,255,255,0.28);
  font-size: 0.8rem;
  z-index: 10;
}

/* Seta oculta por padrão no desktop — só ativa no mobile via media query */
.split-scroll-seta { display: none; }

/* ——— Mobile: painel foto vira header compacto ——— */
@media (max-width: 768px) {
  .split-login {
    flex-direction: column;
    min-height: 100dvh;
  }

  /* Painel da foto: tela cheia no mobile */
  .split-foto {
    display: flex;
    flex-direction: column;
    flex: none;
    height: 100vh;
    height: 100dvh;
    min-height: 0;
    max-height: none;
    width: 100%;
  }

  .split-logo {
    width: 145px;
  }

  .split-foto-titulo {
    font-size: 1.625rem;
    letter-spacing: -0.02em;
  }

  .split-foto-sub {
    font-size: 0.875rem;
    margin-top: 0.4rem;
  }

  .split-badge {
    margin-top: 0.875rem;
    font-size: 0.75rem;
    padding: 0.35rem 0.75rem;
  }

  .split-foto-conteudo {
    justify-content: space-between;
    align-items: stretch;
    padding: 1.75rem 1.5rem calc(5.5rem - 25px);
  }

  /* Logo fica no canto esquerdo */
  .split-logo {
    align-self: flex-start;
  }

  /* Bloco de texto centralizado como bloco simples */
  .split-foto-rodape {
    display: block;
    text-align: center;
  }

  .split-foto-titulo {
    text-align: center;
    display: block;
  }

  .split-foto-sub {
    text-align: center;
    display: block;
  }

  .split-badge {
    margin-left: auto;
    margin-right: auto;
  }

  /* Títulos do formulário centralizados no mobile */
  .split-form-titulo,
  .split-form-sub {
    text-align: center;
  }

  /* Formulário ocupa o restante */
  .split-form {
    flex: 1;
    min-height: auto;
    padding: calc(2rem + 50px) 1.5rem 4rem;
    align-items: flex-start;
  }

  .split-form-inner {
    max-width: 100%;
  }

  /* Esconde a mini-logo duplicada — agora aparece no header */
  .split-mobile-logo {
    display: none;
  }

  /* Seta de scroll visível no mobile */
  .split-scroll-seta {
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    bottom: calc(2rem - 25px);
    left: 50%;
    transform: translateX(-50%);
    width: 46px;
    height: 46px;
    border-radius: 50%;
    background: rgba(255,255,255,0.18);
    border: 1.5px solid rgba(255,255,255,0.38);
    color: #ffffff;
    cursor: pointer;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    animation: setaBounce 1.8s ease-in-out infinite;
    transition: background 0.2s, border-color 0.2s;
    z-index: 10;
    box-shadow: 0 2px 12px rgba(0,0,0,0.30);
  }

  .split-scroll-seta svg {
    width: 22px;
    height: 22px;
  }

  .split-scroll-seta:hover,
  .split-scroll-seta:active {
    background: rgba(255,105,0,0.32);
    border-color: rgba(255,105,0,0.60);
  }

  /* Oculta o rodapé fixo no mobile — não deve sobrepor a capa */
  .layout-auth .rodape-app {
    display: none;
  }
}

@keyframes setaBounce {
  0%, 100% { transform: translateX(-50%) translateY(0);   opacity: 0.80; }
  50%       { transform: translateX(-50%) translateY(6px); opacity: 1;    }
}

/* ——— Legado: tela-auth/card-auth usados em cadastro.php ——— */
.tela-auth {
  width: 100%;
  max-width: 440px;
  margin: auto;
  padding: 3rem 1.5rem 5rem;
  align-self: center;
}

.card-auth {
  background: rgba(255,255,255,0.06);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border: 1px solid rgba(255,255,255,0.11);
  border-radius: var(--raio-xl);
  padding: 2.5rem 2.25rem;
  box-shadow: 0 24px 60px rgba(0,0,0,0.45);
}

.auth-marca { text-align: center; margin-bottom: 2rem; }
.auth-logo-wrap { display: block; margin-bottom: 1.25rem; }
.auth-logo-img { width: 130px; height: auto; display: block; margin: 0 auto; }
.auth-titulo {
  font-size: 1.375rem; font-weight: 700; color: #fff;
  margin-bottom: 0.25rem; letter-spacing: -0.02em;
}
.auth-subtitulo { font-size: 0.875rem; color: rgba(255,255,255,0.45); }
.auth-link { color: rgba(255,255,255,0.45); }
.auth-link a { color: var(--laranja-claro); }

/* Campos dentro de card-auth (cadastro) */
.card-auth .campo-label { color: rgba(255,255,255,0.65); }
.card-auth .campo-input {
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.12);
  color: #fff;
}
.card-auth .campo-input::placeholder { color: rgba(255,255,255,0.28); }
.card-auth .campo-input:focus {
  background: rgba(255,255,255,0.1);
  border-color: var(--laranja);
  box-shadow: 0 0 0 3px rgba(255,105,0,0.18);
}
.card-auth .btn-ver-senha { color: rgba(255,255,255,0.4); }
.card-auth .btn-ver-senha:hover { color: var(--laranja); }

/* ——— Formulários ——— */
.formulario-auth {
  display: flex;
  flex-direction: column;
  gap: 1.125rem;
}

.campo-grupo {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
}

.campo-label {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--texto-principal);
  letter-spacing: 0.01em;
}

.campo-input {
  background: var(--fundo-input);
  border: 1.5px solid var(--borda);
  border-radius: var(--raio-sm);
  padding: 0.75rem 1rem;
  font-size: 0.9375rem;
  font-family: var(--fonte);
  color: var(--texto-principal);
  transition: border-color var(--transicao), box-shadow var(--transicao), background var(--transicao);
  outline: none;
  width: 100%;
}

.campo-input::placeholder { color: var(--texto-terciario); }

.campo-input:focus {
  border-color: var(--laranja);
  box-shadow: 0 0 0 3px var(--laranja-suave);
  background: var(--fundo-input-foco);
}

.campo-senha-wrapper { position: relative; }
.campo-senha-wrapper .campo-input { padding-right: 3rem; }

.btn-ver-senha {
  position: absolute;
  right: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  color: var(--texto-terciario);
  padding: 0.25rem;
  display: flex;
  align-items: center;
  transition: color var(--transicao);
}

.btn-ver-senha svg { width: 18px; height: 18px; }
.btn-ver-senha:hover { color: var(--laranja); }

/* ——— Botões ——— */
.btn-primario {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  background: var(--laranja);
  color: var(--branco);
  border: none;
  border-radius: var(--raio-sm);
  padding: 0.8125rem 1.5rem;
  font-size: 0.9375rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  transition: background var(--transicao), transform 0.1s, box-shadow var(--transicao);
  cursor: pointer;
}

.btn-primario:hover {
  background: var(--laranja-escuro);
  color: var(--branco);
  box-shadow: var(--sombra-laranja);
  transform: translateY(-1px);
}

.btn-primario:active { transform: translateY(0); box-shadow: none; }
.btn-bloco { width: 100%; margin-top: 0.375rem; }

.btn-secundario {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  background: transparent;
  color: var(--texto-principal);
  border: 1.5px solid var(--borda);
  border-radius: var(--raio-sm);
  padding: 0.75rem 1.5rem;
  font-size: 0.9375rem;
  font-weight: 500;
  transition: border-color var(--transicao), color var(--transicao), background var(--transicao);
  cursor: pointer;
}

.btn-secundario:hover {
  border-color: var(--laranja);
  color: var(--laranja);
  background: var(--laranja-suave);
}

.auth-link {
  margin-top: 1.375rem;
  text-align: center;
  font-size: 0.875rem;
  color: var(--texto-secundario);
}

.auth-link a { color: var(--laranja); font-weight: 600; }
.auth-link a:hover { text-decoration: underline; }

/* ——— Alertas ——— */
.alerta {
  padding: 0.875rem 1rem;
  border-radius: var(--raio-sm);
  font-size: 0.875rem;
  font-weight: 500;
  margin-bottom: 1.25rem;
  border-left: 3px solid;
  line-height: 1.4;
}

.alerta-erro {
  background: var(--vermelho-suave);
  color: #b91c1c;
  border-left-color: var(--vermelho);
}

.alerta-sucesso {
  background: var(--verde-suave);
  color: var(--verde);
  border-left-color: var(--verde);
}

.alerta-aviso {
  background: var(--amarelo-suave);
  color: var(--amarelo);
  border-left-color: var(--amarelo);
}

.alerta-info {
  background: var(--laranja-suave);
  color: var(--laranja-escuro);
  border-left-color: var(--laranja);
}

/* =============================================
   LAYOUT PRINCIPAL — ÁREA DE MEMBROS
   ============================================= */

.layout-app {
  background: var(--fundo-pagina);
}

.layout-principal {
  display: flex;
  min-height: 100vh;
}

/* ——— Barra Lateral ——— */
.barra-lateral {
  width: var(--barra-largura);
  min-height: 100vh;
  background:
    linear-gradient(180deg, rgba(8,8,12,0.92) 0%, rgba(12,12,18,0.97) 100%),
    url('/assets/img/fundo.jpeg') center 20% / cover;
  border-right: 1px solid rgba(255,255,255,0.06);
  display: flex;
  flex-direction: column;
  position: fixed;
  left: 0; top: 0; bottom: 0;
  z-index: 100;
  transition: transform 0.3s ease;
}

.logo-lateral {
  padding: 1.25rem 1rem 1rem;
  border-bottom: 1px solid rgba(255,255,255,0.07);
  text-align: center;
}

.logo-lateral-link {
  display: block;
}

.sidebar-logo-img {
  width: 100%;
  max-width: 200px;
  height: auto;
  display: block;
  margin: 0 auto;
}

/* legado — mantido para evitar erros se referenciado em outro lugar */
.logo-icon { display: none; }
.logo-info { display: none; }
.logo-sub {
  font-size: 0.6875rem;
  color: rgba(255,255,255,0.4);
  font-weight: 400;
}

.nav-lateral { flex: 1; padding: 0.875rem 0; overflow-y: auto; }
.nav-lista { list-style: none; display: flex; flex-direction: column; gap: 1px; padding: 0 0.75rem; }

.nav-separador {
  padding: 1rem 0.625rem 0.375rem;
  list-style: none;
}
.nav-separador span {
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: rgba(255,255,255,0.3);
}

.nav-link {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.625rem 0.875rem;
  border-radius: var(--raio-sm);
  font-size: 0.875rem;
  font-weight: 500;
  color: rgba(255,255,255,0.55);
  transition: background var(--transicao), color var(--transicao);
}

.nav-link svg { width: 17px; height: 17px; flex-shrink: 0; }

.nav-link:hover {
  background: rgba(255,255,255,0.07);
  color: var(--branco);
}

.nav-link.ativo {
  background: rgba(255,105,0,0.15);
  color: var(--laranja-claro);
}

/* Perfil na lateral */
.perfil-lateral {
  padding: 1rem 1.25rem;
  border-top: 1px solid rgba(255,255,255,0.07);
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.perfil-info {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  flex: 1;
  min-width: 0;
}

.perfil-avatar {
  width: 34px;
  height: 34px;
  background: var(--laranja);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 0.8125rem;
  color: var(--branco);
  flex-shrink: 0;
}

.perfil-detalhes { display: flex; flex-direction: column; min-width: 0; }
.perfil-nome {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--branco);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.perfil-cargo { font-size: 0.6875rem; color: rgba(255,255,255,0.4); }

.btn-sair {
  color: rgba(255,255,255,0.3);
  padding: 0.375rem;
  border-radius: var(--raio-sm);
  display: flex;
  align-items: center;
  transition: color var(--transicao), background var(--transicao);
  flex-shrink: 0;
}
.btn-sair svg { width: 16px; height: 16px; }
.btn-sair:hover { color: #ff6b6b; background: rgba(220,38,38,0.1); }

/* ——— Conteúdo Principal ——— */
.conteudo-principal {
  flex: 1;
  min-width: 0;
  max-width: 100%;
  margin-left: var(--barra-largura);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  background: var(--fundo-pagina);
}

.cabecalho-pagina {
  background: var(--fundo-card);
  border-bottom: 1px solid var(--borda);
  padding: 1.25rem 2rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  position: sticky;
  top: 0;
  z-index: 50;
}

.pagina-titulo {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--texto-principal);
  letter-spacing: -0.02em;
}

.pagina-subtitulo {
  font-size: 0.8125rem;
  color: var(--texto-terciario);
  margin-top: 0.125rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

/* ——— Banner Marcus Ferreira ——— */
.banner-marcus {
  display: flex;
  align-items: stretch;
  background: #111318;
  border-radius: 16px;
  overflow: hidden;
  margin: 0 2rem 1.5rem;
  min-height: 190px;
  box-shadow: 0 4px 24px rgba(0,0,0,0.22);
}

.banner-marcus-texto {
  flex: 1;
  padding: 2rem 2rem 2rem 2.25rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.55rem;
}

.banner-marcus-tag {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--cor-primaria, #FF6900);
}

.banner-marcus-titulo {
  font-size: 1.5rem;
  font-weight: 800;
  color: #ffffff;
  line-height: 1.15;
  margin: 0;
  letter-spacing: -0.02em;
}

.banner-marcus-sub {
  font-size: 0.875rem;
  color: rgba(255,255,255,0.55);
  margin: 0;
  line-height: 1.55;
  max-width: 36ch;
}

.banner-marcus-foto {
  width: 38%;
  flex-shrink: 0;
  position: relative;
  overflow: hidden;
}

.banner-marcus-foto::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, #111318 0%, transparent 45%);
  z-index: 1;
  pointer-events: none;
}

.banner-marcus-foto img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 15%;
  display: block;
}

/* Atalhos rápidos */
.atalhos-rapidos {
  padding: 2rem;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1rem;
  align-content: start;
}

.atalho-card {
  background: var(--fundo-card);
  border: 1.5px solid var(--borda);
  border-radius: var(--raio);
  padding: 1.375rem;
  display: flex;
  align-items: center;
  gap: 1rem;
  transition: border-color var(--transicao), box-shadow var(--transicao), transform 0.15s;
  color: var(--texto-principal);
  cursor: pointer;
}

.atalho-card:hover {
  border-color: var(--laranja);
  box-shadow: var(--sombra-md);
  transform: translateY(-2px);
  color: var(--texto-principal);
}

.atalho-icone {
  width: 46px;
  height: 46px;
  border-radius: var(--raio-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.atalho-laranja { background: var(--laranja); color: var(--branco); }
.atalho-escuro  { background: var(--preto-suave); color: var(--branco); }

.atalho-icone svg { width: 21px; height: 21px; }

.atalho-info {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
}

.atalho-titulo {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--texto-principal);
}

.atalho-desc {
  font-size: 0.8125rem;
  color: var(--texto-terciario);
}

.atalho-seta { width: 17px; height: 17px; color: var(--cinza-200); flex-shrink: 0; }

/* Badges de perfil */
.badge {
  display: inline-flex;
  align-items: center;
  padding: 0.2em 0.625em;
  border-radius: var(--raio-pill);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.01em;
}

.badge-admin    { background: var(--laranja-suave); color: var(--laranja-escuro); }
.badge-professor{ background: var(--verde-suave); color: var(--verde); }
.badge-aluno    { background: rgba(99,102,241,0.08); color: #6366f1; }

/* Rodapé */
.rodape-app {
  padding: 1.25rem 2rem;
  border-top: 1px solid var(--borda);
  margin-top: auto;
  background: var(--fundo-card);
}

/* Nas páginas com sidebar fixa, empurra o footer para não ficar sob ela */
.layout-principal ~ .rodape-app {
  margin-left: var(--barra-largura);
}

.rodape-conteudo p {
  font-size: 0.8125rem;
  color: var(--texto-terciario);
  white-space: nowrap;
}

/* Botão hambúrguer (mobile) */
.btn-menu-mobile {
  display: none;
  background: none;
  border: none;
  color: var(--texto-principal);
  padding: 0.375rem;
  border-radius: var(--raio-sm);
}
.btn-menu-mobile svg { width: 22px; height: 22px; }

/* =============================================
   RESPONSIVO
   ============================================= */

/* Overlay escuro quando sidebar está aberta no mobile */
.sidebar-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.45);
  z-index: 99;
  cursor: pointer;
}
.sidebar-overlay.visivel { display: block; }

/* Hamburguer e sidebar: oculta em tablet/mobile */
@media (max-width: 1024px) {
  .barra-lateral { transform: translateX(-100%); }
  .barra-lateral.aberta { transform: translateX(0); }
  .conteudo-principal { margin-left: 0; }
  .layout-principal ~ .rodape-app { margin-left: 0; }
  .btn-menu-mobile { display: flex; }
}

@media (max-width: 768px) {
  .atalhos-rapidos { padding: 1rem; grid-template-columns: 1fr; }
  .cabecalho-pagina { padding: 1rem 1.25rem; }
  .card-auth { padding: 2rem 1.5rem; }

  .banner-marcus {
    margin: 0 1rem 1.25rem;
    min-height: 160px;
  }
  .banner-marcus-foto { width: 44%; }
  .banner-marcus-texto { padding: 1.5rem 1rem 1.5rem 1.25rem; }
  .banner-marcus-titulo { font-size: 1.2rem; }
  .banner-marcus-sub { font-size: 0.8rem; }
}

@media (max-width: 480px) {
  .auth-titulo { font-size: 1.25rem; }
  .card-auth { border-radius: var(--raio); }
}


/* =============================================
   SELETOR DE PERFIL — Cadastro
   ============================================= */

.campo-perfil-opcoes {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.625rem;
}

.opcao-perfil { display: flex; cursor: pointer; }
.opcao-perfil input[type="radio"] { display: none; }

.opcao-perfil-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.375rem;
  padding: 0.875rem 0.625rem;
  border: 1.5px solid var(--borda);
  border-radius: var(--raio-sm);
  background: var(--fundo-input);
  text-align: center;
  width: 100%;
  transition: border-color var(--transicao), background var(--transicao), box-shadow var(--transicao);
}

.opcao-perfil-card svg {
  width: 22px;
  height: 22px;
  color: var(--texto-terciario);
  transition: color var(--transicao);
}

.opcao-perfil-card strong {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--texto-principal);
}

.opcao-perfil-card small {
  font-size: 0.6875rem;
  color: var(--texto-terciario);
  line-height: 1.3;
}

.opcao-perfil input[type="radio"]:checked + .opcao-perfil-card {
  border-color: var(--laranja);
  background: var(--laranja-suave);
  box-shadow: 0 0 0 3px var(--laranja-suave);
}

.opcao-perfil input[type="radio"]:checked + .opcao-perfil-card svg {
  color: var(--laranja);
}

.opcao-perfil:hover .opcao-perfil-card {
  border-color: var(--laranja);
}

/* =============================================
   MINHA CONTA — Perfil do Usuário
   ============================================= */

.conteudo-pagina {
  padding: 1.75rem 2rem;
  max-width: 960px;
  width: 100%;
  box-sizing: border-box;
}

.grade-perfil {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
  align-items: start;
}

@media (max-width: 820px) {
  .grade-perfil { grid-template-columns: 1fr; }
  .conteudo-pagina { padding: 1.25rem; }
}

.card-perfil-info,
.card-alterar-senha {
  background: var(--fundo-card);
  border: 1.5px solid var(--borda);
  border-radius: var(--raio-lg);
  padding: 1.75rem;
}

.perfil-header {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1.5rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--borda);
}

.perfil-avatar-grande {
  width: 64px;
  height: 64px;
  background: var(--laranja);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--branco);
  flex-shrink: 0;
  box-shadow: var(--sombra-laranja);
}

.perfil-nome-grande {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--texto-principal);
  margin-bottom: 0.125rem;
}

.perfil-email-grande {
  font-size: 0.875rem;
  color: var(--texto-terciario);
  margin-bottom: 0.5rem;
}

.perfil-dados-lista {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.perfil-dado-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.75rem 0;
  border-bottom: 1px solid var(--cinza-100);
  gap: 1rem;
}

.perfil-dado-item:last-child { border-bottom: none; }

.dado-rotulo {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.8125rem;
  color: var(--texto-terciario);
  font-weight: 500;
}

.dado-rotulo svg { width: 15px; height: 15px; flex-shrink: 0; }

.dado-valor {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--texto-principal);
  text-align: right;
}

.status-ativo {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  color: var(--verde);
}

.status-ponto {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--verde);
  flex-shrink: 0;
}

/* Card alterar senha */
.card-titulo-secao {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 1rem;
  font-weight: 700;
  color: var(--texto-principal);
  margin-bottom: 0.375rem;
}

.card-titulo-secao svg { width: 18px; height: 18px; color: var(--laranja); }

.card-descricao {
  font-size: 0.8125rem;
  color: var(--texto-terciario);
  margin-bottom: 1.25rem;
}

.formulario-interno {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

/* Área logada — conteúdo principal padding */
.conteudo-principal .alerta {
  margin: 1.25rem 2rem 0;
}

/* Botão salvar senha — tamanho adequado */
.btn-senha-salvar {
  align-self: flex-start;
  padding: 0.6875rem 1.375rem;
  font-size: 0.875rem;
}

/* =============================================
   DASHBOARD ADMIN — Stats e Tabelas
   ============================================= */

.dashboard-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  padding: 1.75rem 2rem 1rem;
}

@media (max-width: 768px) {
  .dashboard-stats { grid-template-columns: 1fr; padding: 1.25rem; }
}

.stat-card {
  background: var(--fundo-card);
  border: 1.5px solid var(--borda);
  border-radius: var(--raio);
  padding: 1.375rem 1.5rem;
  display: flex;
  align-items: center;
  gap: 1rem;
  box-shadow: var(--sombra-sm);
}

.stat-icone {
  width: 48px;
  height: 48px;
  border-radius: var(--raio-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.stat-icone svg { width: 22px; height: 22px; }

.stat-laranja { background: var(--laranja);    color: var(--branco); }
.stat-verde   { background: var(--verde);      color: var(--branco); }
.stat-escuro  { background: var(--preto-suave); color: var(--branco); }

.stat-info { display: flex; flex-direction: column; }

.stat-valor {
  font-size: 2rem;
  font-weight: 800;
  color: var(--texto-principal);
  line-height: 1;
  letter-spacing: -0.03em;
}

.stat-rotulo {
  font-size: 0.8125rem;
  color: var(--texto-terciario);
  font-weight: 500;
  margin-top: 0.25rem;
}

/* Seção admin com título */
.secao-admin { }

.secao-titulo {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 1rem;
  font-weight: 700;
  color: var(--texto-principal);
  margin-bottom: 1rem;
}

.secao-titulo svg { width: 18px; height: 18px; color: var(--laranja); }

/* Tabela simples */
.tabela-wrapper {
  overflow-x: auto;
  border-radius: var(--raio);
  border: 1.5px solid var(--borda);
}

.tabela-simples {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.875rem;
}

.tabela-simples thead {
  background: var(--cinza-100);
}

.tabela-simples th {
  padding: 0.75rem 1rem;
  text-align: left;
  font-weight: 600;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--texto-terciario);
  border-bottom: 1px solid var(--borda);
}

.tabela-simples td {
  padding: 0.75rem 1rem;
  color: var(--texto-principal);
  border-bottom: 1px solid var(--cinza-100);
  vertical-align: middle;
}

.tabela-simples tbody tr:last-child td { border-bottom: none; }

.tabela-simples tbody tr:hover { background: var(--cinza-100); }

.tabela-simples code {
  font-size: 0.8125rem;
  background: var(--cinza-100);
  padding: 0.125rem 0.375rem;
  border-radius: 4px;
  color: var(--laranja-escuro);
}

/* Em construção */
.em-construcao {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 4rem 2rem;
  max-width: 480px;
  margin: 0 auto;
}

.em-construcao-icone {
  width: 80px;
  height: 80px;
  background: var(--laranja-suave);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.5rem;
}

.em-construcao-icone svg {
  width: 36px;
  height: 36px;
  color: var(--laranja);
}

.em-construcao-titulo {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--texto-principal);
  margin-bottom: 0.75rem;
  letter-spacing: -0.02em;
}

.em-construcao-desc {
  font-size: 0.9375rem;
  color: var(--texto-terciario);
  line-height: 1.6;
  margin-bottom: 1.75rem;
}

.em-construcao .btn-primario {
  display: inline-flex;
  gap: 0.375rem;
  align-items: center;
}

.em-construcao .btn-primario svg { width: 16px; height: 16px; }

/* =============================================
   ETAPA 4 — Categorias, Conteúdos, Formulários
   ============================================= */

/* Cabeçalho com botão de ação */
.cabecalho-acoes {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-left: auto;
}

/* Breadcrumb */
.breadcrumb {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.8125rem;
  color: var(--texto-terciario);
  margin-bottom: 0.25rem;
}
.breadcrumb a { color: var(--laranja); text-decoration: none; }
.breadcrumb a:hover { text-decoration: underline; }
.breadcrumb span:last-child { color: var(--texto-secundario); }

/* Alerta flash */
.alerta {
  display: flex;
  align-items: flex-start;
  gap: 0.625rem;
  padding: 0.75rem 1rem;
  border-radius: var(--raio);
  font-size: 0.9rem;
  font-weight: 500;
  margin-bottom: 1.25rem;
  border: 1.5px solid transparent;
  line-height: 1.45;
}
.alerta svg {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  margin-top: 1px;
}
.alerta-sucesso { background:#f0fdf4; border-color:#86efac; color:#15803d; }
.alerta-erro    { background:#fef2f2; border-color:#fca5a5; color:#b91c1c; }

/* Badges */
.badge {
  display: inline-block;
  padding: 0.1875rem 0.625rem;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 600;
  white-space: nowrap;
}
.badge-ativo          { background:#dcfce7; color:#166534; }
.badge-inativo        { background:#f1f5f9; color:#64748b; }
.badge-aluno          { background:#eff6ff; color:#1d4ed8; }
.badge-professor      { background:#f5f3ff; color:#6d28d9; }
.badge-ambos          { background:#fff7ed; color:#c2410c; }
.badge-admin          { background:#fef2f2; color:#b91c1c; }
.badge-tipo-video     { background:#ffe4e6; color:#be123c; }
.badge-tipo-documento { background:#e0f2fe; color:#0369a1; }

/* Botões de ação na linha da tabela */
.acoes-linha {
  display: flex;
  align-items: center;
  gap: 0.375rem;
}
.btn-acao {
  width: 30px;
  height: 30px;
  border: 1.5px solid var(--borda);
  background: var(--fundo-card);
  border-radius: var(--raio-sm);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
  text-decoration: none;
  color: var(--texto-secundario);
  padding: 0;
}
.btn-acao svg { width: 14px; height: 14px; }
.btn-editar:hover  { background:#eff6ff; border-color:#bfdbfe; color:#1d4ed8; }
.btn-ativar:hover  { background:#f0fdf4; border-color:#86efac; color:#15803d; }
.btn-inativar:hover{ background:#fff7ed; border-color:#fed7aa; color:#c2410c; }
.btn-excluir:hover { background:#fef2f2; border-color:#fca5a5; color:#b91c1c; }

.form-inline { display: inline; margin: 0; padding: 0; }

/* Textos auxiliares */
.txt-terciario { color: var(--texto-terciario); }
.txt-pequeno   { font-size: 0.8125rem; }
.txt-alerta    { color: #c2410c; }

/* Thumbnail na tabela */
.thumb-tabela {
  width: 48px;
  height: 32px;
  object-fit: cover;
  border-radius: 4px;
  display: block;
}
.thumb-vazio {
  width: 48px;
  height: 32px;
  background: var(--cinza-100);
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--texto-terciario);
}
.thumb-vazio svg { width: 16px; height: 16px; }

/* ——— Tabela de conteúdos (layout fixo para controlar largura do título) ——— */
.tabela-conteudos {
  table-layout: fixed;
}

/* Célula do título — deixa o conteúdo filho fazer o corte */
.td-titulo-conteudo {
  overflow: hidden;
}

/* Link/título do conteúdo — uma linha, corta com "…" */
.link-titulo-conteudo {
  display: block;
  font-weight: 600;
  font-size: 0.875rem;
  color: var(--texto-principal);
  text-decoration: none;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.link-titulo-conteudo:hover { color: var(--laranja); }

/* Descrição curta abaixo do título */
.desc-titulo-conteudo {
  font-size: 0.8125rem;
  color: var(--texto-terciario);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-top: 2px;
  line-height: 1.4;
}

/* Indicador de fonte YouTube na coluna "Fonte" */
.badge-youtube-fonte {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.75rem;
  color: var(--texto-terciario);
}

/* ——— Cards de formulário ——— */
.card-form {
  background: var(--fundo-card);
  border: 1.5px solid var(--borda);
  border-radius: var(--raio);
  padding: 1.75rem;
  box-shadow: var(--sombra-sm);
  margin-bottom: 1.25rem;
}
.card-form-titulo {
  font-size: 0.9375rem;
  font-weight: 700;
  color: var(--texto-principal);
  margin-bottom: 1.25rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--borda);
  letter-spacing: -0.015em;
}

/* Campos de formulário */
.campo-grupo  { display: flex; flex-direction: column; gap: 0.375rem; margin-bottom: 1.125rem; }
.campo-grupo:last-child { margin-bottom: 0; }
.campo-label  { font-size: 0.875rem; font-weight: 600; color: var(--texto-secundario); }
.obrigatorio  { color: var(--laranja); }
.campo-hint   { font-size: 0.8125rem; color: var(--texto-terciario); }
.campo-input  {
  width: 100%;
  padding: 0.6875rem 0.875rem;
  border: 1.5px solid var(--borda);
  border-radius: var(--raio-sm);
  font-size: 0.9375rem;
  font-family: inherit;
  color: var(--texto-principal);
  background: var(--branco);
  transition: border-color 0.15s, box-shadow 0.15s;
  box-sizing: border-box;
}
.campo-input:focus {
  outline: none;
  border-color: var(--laranja);
  box-shadow: 0 0 0 3px rgba(255,105,0,0.12);
}
.campo-textarea { resize: vertical; min-height: 80px; }
.campo-select { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 0.875rem center; padding-right: 2.5rem; cursor: pointer; }

/* Upload */
.campo-arquivo {
  font-size: 0.875rem;
  color: var(--texto-secundario);
  cursor: pointer;
  width: 100%;
}
.campo-arquivo::file-selector-button {
  padding: 0.4375rem 0.875rem;
  border: 1.5px solid var(--borda);
  border-radius: var(--raio-sm);
  background: var(--cinza-100);
  font-size: 0.8125rem;
  font-weight: 600;
  cursor: pointer;
  margin-right: 0.625rem;
  color: var(--texto-secundario);
  transition: background 0.15s;
}
.campo-arquivo::file-selector-button:hover { background: var(--laranja-suave); color: var(--laranja); }

.arquivo-atual {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.8125rem;
  color: var(--texto-terciario);
  background: var(--cinza-100);
  padding: 0.5rem 0.75rem;
  border-radius: var(--raio-sm);
  margin-bottom: 0.625rem;
}
.arquivo-atual svg { width: 14px; height: 14px; flex-shrink: 0; }
.arquivo-atual code { font-size: 0.8125rem; color: var(--laranja-escuro); }

/* Toggle publicado */
.campo-toggle {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  cursor: pointer;
  user-select: none;
}
.campo-toggle input[type=checkbox] { display: none; }
.toggle-slider {
  position: relative;
  width: 42px;
  height: 24px;
  background: var(--cinza-200, #e2e8f0);
  border-radius: 999px;
  transition: background 0.2s;
  flex-shrink: 0;
}
.campo-toggle input:checked ~ .toggle-slider { background: var(--laranja); }
.toggle-slider::after {
  content: '';
  position: absolute;
  width: 18px;
  height: 18px;
  background: white;
  border-radius: 50%;
  top: 3px;
  left: 3px;
  transition: transform 0.2s;
  box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}
.campo-toggle input:checked ~ .toggle-slider::after { transform: translateX(18px); }
.toggle-label { font-size: 0.875rem; color: var(--texto-secundario); font-weight: 500; }

/* Preview da thumbnail */
.preview-thumb img,
.preview-thumb-img {
  width: 100%;
  max-height: 140px;
  object-fit: cover;
  border-radius: var(--raio-sm);
  border: 1.5px solid var(--borda);
  display: block;
  margin-bottom: 0.75rem;
}

/* Grid de formulário 2 colunas */
.form-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
.campo-col-2 { grid-column: 1 / -1; }

@media (max-width: 640px) {
  .form-grid-2 { grid-template-columns: 1fr; }
  .campo-col-2 { grid-column: auto; }
}

/* Layout form duplo (principal + lateral) */
.layout-form-duplo {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 1.25rem;
  align-items: start;
}
@media (max-width: 900px) {
  .layout-form-duplo { grid-template-columns: 1fr; }
  .col-form-lateral  { order: -1; }
}

/* Ações do formulário */
.form-acoes {
  display: flex;
  justify-content: flex-end;
  gap: 0.75rem;
  margin-top: 1.5rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--borda);
}

/* Botão secundário */
.btn-secundario {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.625rem 1.25rem;
  border: 1.5px solid var(--borda);
  border-radius: var(--raio-sm);
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--texto-secundario);
  background: var(--fundo-card);
  text-decoration: none;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}
.btn-secundario:hover { background: var(--cinza-100); border-color: var(--texto-terciario); }

/* Btn primário com ícone (complemento ao existente) */
.btn-primario svg { width: 16px; height: 16px; }

/* =============================================
   ETAPA 5 — Biblioteca de Conteúdos (Catálogo)
   ============================================= */

/* Filtro de categorias */
.filtro-categorias {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 1.75rem;
}

.filtro-btn {
  display: inline-flex;
  align-items: center;
  padding: 0.375rem 1rem;
  border: 1.5px solid var(--borda);
  border-radius: 999px;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--texto-secundario);
  background: var(--fundo-card);
  text-decoration: none;
  transition: all 0.15s;
  white-space: nowrap;
}

.filtro-btn:hover {
  border-color: var(--laranja);
  color: var(--laranja);
  background: var(--laranja-suave);
}

.filtro-btn.ativo {
  background: var(--laranja);
  border-color: var(--laranja);
  color: var(--branco);
  font-weight: 600;
}

/* Seção com título de categoria */
.catalogo-secao { margin-bottom: 2.5rem; }

.catalogo-secao-titulo {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 1.0625rem;
  font-weight: 700;
  color: var(--texto-principal);
  margin-bottom: 1rem;
  padding-bottom: 0.625rem;
  border-bottom: 2px solid var(--borda);
  letter-spacing: -0.02em;
}

.catalogo-secao-titulo svg { width: 16px; height: 16px; color: var(--laranja); flex-shrink: 0; }

.catalogo-secao-count {
  margin-left: auto;
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--texto-terciario);
  background: var(--cinza-100);
  padding: 0.125rem 0.5rem;
  border-radius: 999px;
}

/* Grid de cards */
.catalogo-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 1.125rem;
}

@media (max-width: 600px) {
  .catalogo-grid { grid-template-columns: repeat(2, 1fr); gap: 0.75rem; }
}

@media (max-width: 380px) {
  .catalogo-grid { grid-template-columns: 1fr; }
}

/* Card de conteúdo */
.card-conteudo {
  display: flex;
  flex-direction: column;
  background: var(--fundo-card);
  border: 1.5px solid var(--borda);
  border-radius: var(--raio);
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s;
  box-shadow: var(--sombra-sm);
}

.card-conteudo:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.10);
  border-color: var(--laranja);
}

/* Thumbnail */
.card-thumb {
  position: relative;
  aspect-ratio: 16/9;
  background: var(--preto-suave);
  background-size: cover;
  background-position: center;
  overflow: hidden;
}

.card-thumb-placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,0.3);
}
.card-thumb-placeholder svg { width: 40px; height: 40px; }

.card-thumb-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,0);
  color: var(--branco);
  opacity: 0;
  transition: all 0.2s;
}
.card-thumb-overlay svg { width: 40px; height: 40px; filter: drop-shadow(0 2px 8px rgba(0,0,0,0.5)); }
.card-conteudo:hover .card-thumb-overlay { background: rgba(0,0,0,0.35); opacity: 1; }

.card-tipo-badge {
  position: absolute;
  bottom: 0.5rem;
  left: 0.5rem;
  background: rgba(0,0,0,0.75);
  color: var(--branco);
  font-size: 0.6875rem;
  font-weight: 700;
  padding: 0.125rem 0.5rem;
  border-radius: 4px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

/* Info do card */
.card-info {
  padding: 0.875rem;
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
  flex: 1;
}

.card-titulo {
  font-size: 0.9375rem;
  font-weight: 700;
  color: var(--texto-principal);
  line-height: 1.35;
  letter-spacing: -0.01em;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.card-meta {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.card-cat {
  font-size: 0.75rem;
  color: var(--laranja);
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 120px;
}

.card-data {
  font-size: 0.75rem;
  color: var(--texto-terciario);
  white-space: nowrap;
}

.card-acessos {
  font-size: 0.75rem;
  color: var(--texto-terciario);
  margin-top: auto;
  padding-top: 0.25rem;
}

/* ——— Página de Detalhe ——— */

.detalhe-layout {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 1.5rem;
  align-items: start;
}

@media (max-width: 900px) {
  .detalhe-layout { grid-template-columns: 1fr; }
  .detalhe-sidebar { order: -1; }
}

/* Player de vídeo */
.player-wrapper {
  background: #000;
  border-radius: var(--raio);
  overflow: hidden;
  margin-bottom: 1.25rem;
  aspect-ratio: 16/9;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Container do player YouTube (mantém proporção 16:9) */
.youtube-player-container {
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;
  background: #000;
  border-radius: var(--raio);
  overflow: hidden;
}

.youtube-player-iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: none;
  display: block;
}

/* Bloqueia os links "Assistir no YouTube" que aparecem ao passar o mouse */
.yt-overlay-logo {
  position: absolute;
  z-index: 10;
  cursor: default;
  background: transparent;
  pointer-events: all; /* captura o clique, não repassa ao iframe */
}
/* Faixa do topo: título e botões de info do YouTube */
.yt-overlay-logo-topo {
  top: 0;
  left: 0;
  right: 0;
  height: 52px;
}
/* Parte direita da linha de botões: "Mais vídeos" + logo YouTube
   Altura cobre apenas os botões (~46px), deixando o scrubber livre acima */
.yt-overlay-logo-rodape {
  bottom: 0;
  right: 0;
  width: 65%;
  height: 46px;
}

/* ——— Capa (thumbnail facade) sobre o player do YouTube ——— */
.yt-capa {
  position: absolute;
  inset: 0;
  z-index: 6;
  cursor: pointer;
  overflow: hidden;
  border-radius: var(--raio);
}
.yt-capa-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.yt-capa-play {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,0.25);
  transition: background 0.2s;
}
.yt-capa:hover .yt-capa-play {
  background: rgba(0,0,0,0.1);
}
.yt-capa:focus-visible {
  outline: 2px solid var(--laranja);
  outline-offset: 2px;
}
.yt-capa-play svg {
  width: 72px;
  height: 72px;
  filter: drop-shadow(0 2px 12px rgba(0,0,0,0.6));
  transition: transform 0.15s;
}
.yt-capa:hover .yt-capa-play svg {
  transform: scale(1.08);
}

.player-erro,
.player-sem-arquivo {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  color: rgba(255,255,255,0.7);
  text-align: center;
  padding: 2rem;
  width: 100%;
}

.player-erro svg,
.player-sem-arquivo svg {
  width: 40px;
  height: 40px;
  color: rgba(255,255,255,0.4);
}

.player-erro p { font-size: 0.9375rem; }

.link-laranja { color: var(--laranja); text-decoration: underline; }

/* Documento */
.doc-wrapper { margin-bottom: 1.25rem; }

.doc-acoes {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
  margin-bottom: 1.25rem;
  align-items: center;
}

.badge-tamanho {
  background: rgba(255,255,255,0.2);
  border-radius: 4px;
  padding: 0.125rem 0.375rem;
  font-size: 0.75rem;
  margin-left: 0.25rem;
}

.doc-embed-wrapper {
  border-radius: var(--raio);
  overflow: hidden;
  border: 1.5px solid var(--borda);
}

.doc-embed {
  width: 100%;
  height: 70vh;
  min-height: 500px;
  border: none;
  display: block;
}

/* Mobile: iframe PDF não funciona — mostra botões de ação */
.doc-mobile-abrir {
  display: none;
}

@media (max-width: 768px) {
  .doc-embed-wrapper {
    display: none;
  }
  .doc-mobile-abrir {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    padding: 2.5rem 1.5rem;
    text-align: center;
    color: var(--texto-secundario);
    background: var(--cinza-100);
    border-radius: var(--raio);
    border: 1.5px solid var(--borda);
  }
  .doc-mobile-abrir p {
    font-size: 0.9375rem;
    margin: 0;
  }
  .doc-mobile-abrir .btn-primario,
  .doc-mobile-abrir .btn-secundario {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.875rem 1.25rem;
    font-size: 1rem;
  }
}

.doc-fallback,
.doc-nao-visualizavel,
.doc-sem-arquivo {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
  padding: 3rem 2rem;
  text-align: center;
  color: var(--texto-terciario);
  background: var(--cinza-100);
  border-radius: var(--raio);
  border: 1.5px solid var(--borda);
}
.doc-nao-visualizavel svg,
.doc-sem-arquivo svg { width: 36px; height: 36px; opacity: 0.5; }

/* Descrição */
.detalhe-descricao {
  background: var(--fundo-card);
  border: 1.5px solid var(--borda);
  border-radius: var(--raio);
  padding: 1.25rem 1.5rem;
}

.detalhe-descricao h3 {
  font-size: 0.9375rem;
  font-weight: 700;
  margin-bottom: 0.75rem;
  color: var(--texto-principal);
}

.detalhe-descricao p {
  font-size: 0.9375rem;
  color: var(--texto-secundario);
  line-height: 1.7;
}

/* Sidebar de informações */
.detalhe-thumb {
  border-radius: var(--raio);
  overflow: hidden;
  border: 1.5px solid var(--borda);
  margin-bottom: 1rem;
}

.detalhe-thumb img { width: 100%; display: block; }

.detalhe-info-card {
  background: var(--fundo-card);
  border: 1.5px solid var(--borda);
  border-radius: var(--raio);
  padding: 1.25rem;
  margin-bottom: 0.875rem;
}

.detalhe-info-titulo {
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--texto-principal);
  margin-bottom: 1rem;
  padding-bottom: 0.625rem;
  border-bottom: 1px solid var(--borda);
}

.detalhe-meta-lista { display: flex; flex-direction: column; gap: 0.75rem; }

.detalhe-meta-item {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
}

.meta-rotulo {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--texto-terciario);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.meta-valor {
  font-size: 0.9375rem;
  color: var(--texto-principal);
  font-weight: 500;
}

.btn-voltar-lib {
  width: 100%;
  justify-content: center;
}

/* =============================================
   ETAPA 6 — Módulo de Reuniões Semanais
   ============================================= */

/* Badge de semana */
.badge-semana {
  display: inline-flex;
  align-items: center;
  background: var(--laranja-suave);
  color: var(--laranja);
  font-size: 0.75rem;
  font-weight: 700;
  padding: 0.2rem 0.625rem;
  border-radius: 999px;
  border: 1px solid rgba(255,105,0,0.2);
  white-space: nowrap;
}

/* Barra de progresso */
.barra-progresso {
  height: 5px;
  background: var(--cinza-100);
  border-radius: 999px;
  overflow: hidden;
  min-width: 60px;
  width: 100%;
}
.barra-progresso-fill { height: 100%; border-radius: 999px; transition: width 0.4s; }
.barra-sucesso { background: #22c55e; }
.barra-aviso   { background: #f59e0b; }
.barra-erro    { background: #ef4444; }

/* Resumo confirmações na tabela */
.confirmacao-resumo { display: flex; flex-direction: column; gap: 0.375rem; }

/* Mini avatar */
.mini-avatar {
  width: 30px; height: 30px; border-radius: 50%;
  background: var(--laranja); color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 0.75rem; font-weight: 700; flex-shrink: 0;
}

/* Link título na tabela */
.celula-titulo-duplo { display: flex; flex-direction: column; gap: 0.25rem; }
.link-titulo { color: var(--texto-principal); font-weight: 600; text-decoration: none; }
.link-titulo:hover { color: var(--laranja); }

/* Seção card (bloco reutilizável) */
.secao-card {
  background: var(--fundo-card);
  border: 1.5px solid var(--borda);
  border-radius: var(--raio);
  padding: 1.5rem;
  margin-bottom: 1.25rem;
}
.secao-card-titulo {
  font-size: 1rem;
  font-weight: 700;
  color: var(--texto-principal);
  margin-bottom: 1.25rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--borda);
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.texto-vazio { color: var(--texto-terciario); font-size: 0.9375rem; }

/* Lista de conteúdos simples (admin detalhe) */
.lista-conteudos-simples { display: flex; flex-direction: column; gap: 0.5rem; }
.conteudo-item-simples {
  display: flex; align-items: center; gap: 0.875rem;
  padding: 0.75rem; border-radius: 8px;
  background: var(--cinza-100); border: 1px solid var(--borda);
}
.conteudo-item-icone {
  width: 36px; height: 36px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.icone-video { background: rgba(255,105,0,0.12); color: var(--laranja); }
.icone-video svg { width: 16px; height: 16px; }
.icone-doc   { background: rgba(59,130,246,0.12); color: #3b82f6; }
.icone-doc svg { width: 16px; height: 16px; }
.conteudo-item-info { flex: 1; min-width: 0; }
.conteudo-item-titulo { font-size: 0.9375rem; font-weight: 600; color: var(--texto-principal); text-decoration: none; }
.conteudo-item-titulo:hover { color: var(--laranja); }
.conteudo-item-meta { font-size: 0.8125rem; color: var(--texto-terciario); }

/* Seleção de conteúdos no formulário */
.lista-conteudos-selecao {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 0.625rem;
}
.conteudo-check-item {
  display: flex; align-items: center; gap: 0.75rem;
  padding: 0.75rem 1rem;
  border: 1.5px solid var(--borda);
  border-radius: 8px;
  background: var(--fundo-card);
  cursor: pointer;
  transition: all 0.15s;
}
.conteudo-check-item:hover { border-color: var(--laranja); background: var(--laranja-suave); }
.conteudo-check-item.selecionado {
  border-color: var(--laranja);
  background: var(--laranja-suave);
}
.conteudo-check-item input[type=checkbox] { width: 18px; height: 18px; accent-color: var(--laranja); flex-shrink: 0; }
.conteudo-check-icone { width: 28px; height: 28px; color: var(--laranja); flex-shrink: 0; }
.conteudo-check-icone svg { width: 20px; height: 20px; }
.conteudo-check-info { flex: 1; min-width: 0; }
.conteudo-check-titulo { display: block; font-size: 0.875rem; font-weight: 600; color: var(--texto-principal); }
.conteudo-check-meta { display: flex; align-items: center; gap: 0.375rem; margin-top: 0.125rem; font-size: 0.75rem; color: var(--texto-terciario); }
.form-secao-badge {
  margin-left: auto;
  font-size: 0.8125rem; font-weight: 500;
  color: var(--laranja);
  background: var(--laranja-suave);
  padding: 0.125rem 0.5rem;
  border-radius: 999px;
}
.filtro-conteudo-form { display: flex; flex-wrap: wrap; gap: 0.375rem; }

/* ——— Lista de reuniões (professor) ——— */
.reunioes-lista { display: flex; flex-direction: column; gap: 1rem; }

.reuniao-card {
  background: var(--fundo-card);
  border: 1.5px solid var(--borda);
  border-radius: var(--raio);
  padding: 1.375rem 1.5rem;
  position: relative;
  transition: box-shadow 0.15s, border-color 0.15s;
}
.reuniao-card:hover { box-shadow: var(--sombra-md); }

.reuniao-card-destaque {
  border-color: var(--laranja);
  box-shadow: 0 0 0 3px rgba(255,105,0,0.08);
}

.reuniao-confirmada { opacity: 0.8; }
.reuniao-confirmada .reuniao-card-destaque { border-color: #22c55e; box-shadow: 0 0 0 3px rgba(34,197,94,0.08); }

.reuniao-badge-atual {
  position: absolute;
  top: -12px; left: 1.25rem;
  background: var(--laranja);
  color: #fff;
  font-size: 0.6875rem; font-weight: 700;
  padding: 0.2rem 0.625rem;
  border-radius: 999px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.reuniao-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: 0.875rem;
}

.reuniao-card-meta { display: flex; align-items: center; gap: 0.5rem; flex-wrap: wrap; }

.reuniao-data { font-size: 0.8125rem; color: var(--texto-terciario); }

.status-confirmado {
  display: inline-flex; align-items: center; gap: 0.375rem;
  color: #16a34a; font-size: 0.875rem; font-weight: 600;
}
.status-confirmado svg { width: 16px; height: 16px; }
.status-pendente {
  display: inline-flex; align-items: center; gap: 0.375rem;
  color: #f59e0b; font-size: 0.875rem; font-weight: 600;
}
.status-pendente svg { width: 16px; height: 16px; }

.reuniao-card-body { margin-bottom: 1rem; }

.reuniao-titulo {
  font-size: 1.125rem; font-weight: 700;
  color: var(--texto-principal);
  letter-spacing: -0.02em; margin-bottom: 0.5rem;
}
.reuniao-titulo a { color: inherit; text-decoration: none; }
.reuniao-titulo a:hover { color: var(--laranja); }

.reuniao-descricao { font-size: 0.9375rem; color: var(--texto-secundario); line-height: 1.6; }

.reuniao-card-footer {
  display: flex; align-items: center; justify-content: space-between;
  gap: 0.75rem; flex-wrap: wrap;
  padding-top: 0.875rem;
  border-top: 1px solid var(--borda);
}

.reuniao-conteudos {
  display: flex; align-items: center; gap: 0.375rem;
  font-size: 0.875rem; color: var(--texto-terciario);
}
.reuniao-conteudos svg { width: 15px; height: 15px; }

/* ——— Detalhe da reunião (professor) ——— */
.reuniao-descricao-bloco {
  background: var(--cinza-100);
  border: 1.5px solid var(--borda);
  border-radius: var(--raio);
  padding: 1.125rem 1.375rem;
  margin-bottom: 1.25rem;
  font-size: 0.9375rem;
  color: var(--texto-secundario);
  line-height: 1.7;
}

/* Bloco de confirmação */
.bloco-confirmacao {
  margin-bottom: 1.25rem;
  border-radius: var(--raio);
  overflow: hidden;
}

.confirmacao-ok {
  display: flex; align-items: center; gap: 1rem;
  padding: 1.125rem 1.375rem;
  background: #f0fdf4; border: 1.5px solid #86efac;
  border-radius: var(--raio);
  color: #16a34a;
}
.confirmacao-ok svg { width: 32px; height: 32px; flex-shrink: 0; }
.confirmacao-ok strong { display: block; font-size: 1rem; font-weight: 700; }
.confirmacao-ok p { font-size: 0.875rem; margin-top: 0.125rem; opacity: 0.8; }

.confirmacao-pendente {
  background: var(--fundo-card);
  border: 1.5px solid var(--borda);
  border-radius: var(--raio);
  padding: 1.25rem 1.375rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.25rem;
  flex-wrap: wrap;
}

.confirmacao-pendente-texto {
  display: flex; align-items: center; gap: 1rem;
  color: var(--texto-secundario);
}
.confirmacao-pendente-texto svg { width: 28px; height: 28px; flex-shrink: 0; color: #f59e0b; }
.confirmacao-pendente-texto strong { display: block; font-size: 0.9375rem; font-weight: 700; color: var(--texto-principal); }
.confirmacao-pendente-texto p { font-size: 0.875rem; margin-top: 0.125rem; }

.btn-confirmar {
  display: inline-flex;
  align-items: center;
  gap: 0.625rem;
  padding: 0.875rem 1.75rem;
  background: var(--laranja);
  color: var(--branco);
  border: none;
  border-radius: var(--raio);
  font-size: 1rem;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.15s, transform 0.1s;
  white-space: nowrap;
}
.btn-confirmar svg { width: 20px; height: 20px; }
.btn-confirmar:hover:not(:disabled) { background: var(--laranja-escuro); transform: translateY(-1px); }
.btn-confirmar:disabled { opacity: 0.65; cursor: not-allowed; }

/* Conteúdos dentro da reunião */
.reuniao-conteudos-lista { display: flex; flex-direction: column; gap: 1.5rem; }

.reuniao-conteudo-item {
  border: 1.5px solid var(--borda);
  border-radius: var(--raio);
  overflow: hidden;
  background: var(--fundo-card);
}

.rci-header {
  display: flex; align-items: flex-start; gap: 1rem;
  padding: 1.125rem 1.375rem;
  flex-wrap: wrap;
}

.rci-info { flex: 1; min-width: 0; }
.rci-titulo {
  font-size: 1rem; font-weight: 700; color: var(--texto-principal);
  margin: 0.375rem 0 0.375rem;
}
.rci-desc { font-size: 0.875rem; color: var(--texto-secundario); line-height: 1.5; }
.rci-link { flex-shrink: 0; }

.rci-player {
  background: #000;
  border-top: 1px solid var(--borda);
  padding: 0;
}

.rci-player .youtube-player-container {
  border-radius: 0;
}

.rci-player .youtube-player-iframe {
  border-radius: 0;
}

.rci-doc { border-top: 1px solid var(--borda); }
.rci-doc-acoes {
  display: flex; gap: 0.625rem; padding: 0.875rem 1.375rem;
  background: var(--cinza-100); flex-wrap: wrap;
}
.rci-pdf-embed {
  width: 100%; height: 500px; border: none; display: block;
  border-top: 1px solid var(--borda);
}
.rci-media-erro {
  padding: 1rem 1.375rem;
  color: var(--texto-terciario); font-size: 0.875rem;
}

/* ---- Card compacto de arquivo (reunião e conteúdo individual) ---- */
.rci-arquivo-card {
  display: flex;
  align-items: center;
  gap: 0.875rem;
  padding: 0.875rem 1rem;
  border-top: 1px solid var(--borda);
  background: #fafafa;
}

/* Quando usado na página de detalhe de conteúdo (fora do .rci-doc) */
.doc-arquivo-card {
  border-top: none;
  border: 1.5px solid var(--borda);
  border-radius: var(--raio);
  background: var(--fundo-card);
  margin-bottom: 1rem;
}

/* Quadrado de ícone colorido */
.rci-arquivo-icone {
  width: 42px;
  height: 42px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.icone-pdf     { background: rgba(220,38,38,.1);   color: #dc2626; }
.icone-doc     { background: rgba(37,99,235,.1);   color: #2563eb; }
.icone-xls     { background: rgba(22,163,74,.1);   color: #16a34a; }
.icone-arquivo { background: rgba(107,114,128,.1); color: #6b7280; }

/* Informação do arquivo */
.rci-arquivo-info { flex: 1; min-width: 0; }

.rci-arquivo-nome {
  display: block;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--texto-principal);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.rci-arquivo-ext {
  display: block;
  font-size: 0.75rem;
  color: var(--texto-terciario);
  letter-spacing: .04em;
  margin-top: 0.125rem;
}

/* Botões de ação ícone-only */
.rci-arquivo-acoes { display: flex; gap: 0.375rem; flex-shrink: 0; }

.rci-acao-btn {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--branco);
  border: 1.5px solid var(--borda);
  color: var(--texto-secundario);
  transition: background 0.15s, border-color 0.15s, color 0.15s;
  text-decoration: none;
  cursor: pointer;
  flex-shrink: 0;
}
.rci-acao-btn:hover {
  background: var(--cinza-100);
  border-color: var(--texto-terciario);
  color: var(--texto-principal);
}

.rci-acao-btn-primary {
  background: var(--laranja);
  border-color: var(--laranja);
  color: var(--branco);
}
.rci-acao-btn-primary:hover {
  background: var(--laranja-escuro);
  border-color: var(--laranja-escuro);
  color: var(--branco);
}

/* Badges de tipo de conteúdo */
.badge-tipo-video { background: rgba(255,105,0,0.12); color: var(--laranja); }
.badge-tipo-documento { background: rgba(59,130,246,0.12); color: #3b82f6; }

/* ==========================================================
   ETAPA 7 — Usuários + Relatórios + Dashboard upgrade
   ========================================================== */

/* ---- Tabela genérica ---- */
.tabela { width: 100%; border-collapse: collapse; font-size: 0.875rem; }
.tabela thead tr { border-bottom: 2px solid var(--borda); }
.tabela th { padding: 0.75rem 1rem; text-align: left; font-weight: 700; font-size: 0.8125rem; text-transform: uppercase; letter-spacing: .06em; color: var(--texto-terciario); white-space: nowrap; }
.tabela td { padding: 0.875rem 1rem; border-bottom: 1px solid var(--borda); vertical-align: middle; }
.tabela tbody tr:hover { background: var(--cinza-100); }
.tabela-wrapper { overflow-x: auto; }

/* ---- Cards de stat (relatórios) ---- */
.stats-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(175px, 1fr)); gap: 1rem; padding: 0 2rem; }
.stat-icone-laranja { background: rgba(255,105,0,.12); color: var(--laranja); }
.stat-icone-azul    { background: rgba(59,130,246,.12); color: #3b82f6; }
.stat-icone-verde   { background: rgba(34,197,94,.12); color: #22c55e; }
.stat-icone-cinza   { background: rgba(107,114,128,.1); color: #6b7280; }
.stat-numero { font-size: 2rem; font-weight: 800; line-height: 1; display: block; }
.stat-label  { font-size: 0.8125rem; color: var(--texto-secundario); display: block; margin-top: 0.25rem; }

/* ---- Seção card (widget) ---- */
.secao-card { background: var(--fundo-card); border: 1.5px solid var(--borda); border-radius: var(--raio); padding: 1.375rem; }
.secao-card-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1rem; gap: 1rem; flex-wrap: wrap; }
.secao-card-titulo { display: flex; align-items: center; gap: 0.5rem; font-size: 0.9375rem; font-weight: 700; color: var(--texto-principal); }
.secao-card-titulo svg { width: 18px; height: 18px; color: var(--laranja); }
.secao-card-link { font-size: 0.8125rem; color: var(--laranja); font-weight: 600; text-decoration: none; white-space: nowrap; }
.secao-card-link:hover { text-decoration: underline; }
.texto-vazio { font-size: 0.875rem; color: var(--texto-terciario); text-align: center; padding: 1.5rem 0; }

/* ---- Dashboard widgets ---- */
.dashboard-widgets { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1.25rem; }

/* ---- Gráfico de barras ---- */
.grafico-barras-wrapper { display: flex; align-items: flex-end; gap: 6px; height: 120px; padding-top: 0.5rem; }
.grafico-compacto { height: 90px; }
.grafico-barra-item { display: flex; flex-direction: column; align-items: center; flex: 1; min-width: 0; gap: 0.25rem; height: 100%; }
.grafico-barra-total { flex: 1; width: 100%; display: flex; align-items: flex-end; min-height: 0; }
.grafico-barra-fill { width: 100%; border-radius: 4px 4px 0 0; transition: height 0.4s; min-height: 2px; }
.barra-laranja { background: var(--laranja); }
.barra-vazia   { background: var(--borda); min-height: 0 !important; }
.grafico-barra-label { display: flex; flex-direction: column; align-items: center; gap: 0; }
.grafico-barra-label span { font-size: 0.6875rem; color: var(--texto-terciario); line-height: 1.3; text-align: center; }

/* ---- Grid de relatórios ---- */
.relatorios-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 1.25rem; }

/* ---- Ranking lista ---- */
.ranking-lista { display: flex; flex-direction: column; gap: 0.75rem; }
.ranking-compacto { gap: 0.5rem; }
.ranking-item { display: flex; align-items: center; gap: 0.75rem; }
.ranking-pos { width: 24px; height: 24px; border-radius: 50%; background: var(--laranja); color: #fff; font-size: 0.75rem; font-weight: 700; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.ranking-info { flex: 1; min-width: 0; }
.ranking-titulo { font-size: 0.875rem; font-weight: 600; color: var(--texto-principal); text-decoration: none; display: block; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
a.ranking-titulo:hover { color: var(--laranja); }
.ranking-meta { display: flex; align-items: center; gap: 0.375rem; font-size: 0.75rem; color: var(--texto-terciario); margin-top: 0.125rem; flex-wrap: wrap; }
.ranking-valor { font-size: 0.875rem; font-weight: 700; color: var(--texto-secundario); white-space: nowrap; flex-shrink: 0; }

/* ---- Barra de progresso (cores variadas) ---- */
.barra-laranja-fill { background: var(--laranja); }
.barra-sucesso { background: #22c55e; }
.barra-aviso   { background: #f59e0b; }
.barra-erro    { background: #ef4444; }

/* ---- Seletor de período ---- */
.periodo-seletor { display: flex; gap: 0.375rem; flex-wrap: wrap; }

/* ---- Filtros de busca (usuários) ---- */
.filtros-form { margin-bottom: 1.5rem; }
.filtros-linha { display: flex; align-items: center; gap: 0.75rem; flex-wrap: wrap; }
.filtro-busca { position: relative; flex: 1; min-width: 200px; }
.filtro-busca svg { position: absolute; left: 0.875rem; top: 50%; transform: translateY(-50%); width: 16px; height: 16px; color: var(--texto-terciario); pointer-events: none; }
.filtro-busca .filtro-input { padding-left: 2.5rem !important; width: 100%; }
.filtros-chips { display: flex; gap: 0.375rem; flex-wrap: wrap; }

/* ---- Usuário célula na tabela ---- */
.usuario-celula { display: flex; align-items: center; gap: 0.75rem; }
.usuario-nome  { font-weight: 600; font-size: 0.875rem; color: var(--texto-principal); }
.usuario-email { font-size: 0.8125rem; color: var(--texto-terciario); }
.mini-avatar-admin { background: var(--texto-principal) !important; }
.mini-avatar-prof  { background: #3b82f6 !important; }

/* ---- Botões de ação na tabela ---- */
.acoes-tabela { display: flex; gap: 0.375rem; align-items: center; }
.btn-acao { display: inline-flex; align-items: center; justify-content: center; width: 32px; height: 32px; border-radius: 6px; background: var(--cinza-100); border: 1px solid var(--borda); cursor: pointer; color: var(--texto-secundario); transition: background 0.15s, color 0.15s; }
.btn-acao svg { width: 15px; height: 15px; }
.btn-acao:hover { background: var(--laranja); color: #fff; border-color: var(--laranja); }
.btn-acao[data-url*="excluir"]:hover, .btn-excluir-item:hover { background: #ef4444; border-color: #ef4444; color: #fff; }

/* ---- Toggle status badge ---- */
button.toggle-status { cursor: pointer; border: none; transition: opacity .2s; }
button.toggle-status:disabled { opacity: .5; cursor: not-allowed; }
.badge-ativo   { background: rgba(34,197,94,.12); color: #16a34a; }
.badge-inativo { background: rgba(239,68,68,.1);  color: #dc2626; }

/* ---- Badges extras relatórios ---- */
.badge-semana  { background: rgba(99,102,241,.1); color: #6366f1; }
.badge-sucesso { background: rgba(34,197,94,.12); color: #16a34a; }
.badge-aviso   { background: rgba(245,158,11,.12); color: #b45309; }
.badge-erro    { background: rgba(239,68,68,.1);  color: #dc2626; }

/* ———————————————————————————————————————
   RASTREAMENTO DE PROGRESSO YOUTUBE
——————————————————————————————————————— */
.yt-progresso-wrapper {
  background: var(--branco);
  border: 1px solid var(--borda);
  border-radius: var(--raio);
  padding: 0.875rem 1rem;
  margin-bottom: 1.25rem;
}

.yt-progresso-rci {
  margin: 0;
  border-top: none;
  border-radius: 0 0 var(--raio) var(--raio);
  padding: 0.75rem 1rem;
  background: #fafafa;
}

.yt-progresso-topo {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.5rem;
}

.yt-progresso-titulo {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--texto-secundario);
  text-transform: uppercase;
  letter-spacing: .04em;
}

.yt-badge-concluido {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  font-size: 0.75rem;
  font-weight: 600;
  background: rgba(34,197,94,.12);
  color: #15803d;
  padding: 0.2rem 0.625rem;
  border-radius: 99px;
}

.yt-progresso-barra {
  height: 8px;
  background: var(--cinza-200, #e5e7eb);
  border-radius: 99px;
  overflow: hidden;
  margin-bottom: 0.375rem;
}

.yt-progresso-fill {
  height: 100%;
  background: var(--laranja);
  border-radius: 99px;
  transition: width .4s ease, background .4s;
  min-width: 4px;
}

.yt-progresso-fill--ok {
  background: #22c55e;
}

.yt-progresso-rodape {
  display: flex;
  justify-content: space-between;
  font-size: 0.75rem;
  color: var(--texto-terciario);
}

.yt-progresso-req { font-style: italic; }

/* Aviso sobre mínimo de visualização */
.yt-aviso-confirmar {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.8125rem;
  color: #92400e;
  background: rgba(245,158,11,.1);
  border: 1px solid rgba(245,158,11,.3);
  border-radius: 6px;
  padding: 0.625rem 0.875rem;
  margin-bottom: 0.75rem;
}

/* Botão confirmar bloqueado */
.btn-confirmar-bloqueado,
.btn-confirmar:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  filter: grayscale(0.3);
}

.btn-confirmar-bloqueado:hover,
.btn-confirmar:disabled:hover {
  transform: none;
  box-shadow: none;
}

/* ==========================================================
   MOBILE — Reunião Detalhe (/reuniao?id=X)
   ========================================================== */

/* Garante que o texto do cabeçalho encolha antes do botão hamburguer */
.cabecalho-texto { min-width: 0; flex: 1; }

/* Breadcrumb não transborda */
.breadcrumb {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  flex-wrap: nowrap;
  overflow: hidden;
  max-width: 100%;
}
.breadcrumb span:last-child {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

@media (max-width: 640px) {
  /* Confirmação pendente: empilha verticalmente */
  .confirmacao-pendente {
    flex-direction: column;
    align-items: stretch;
    gap: 0.875rem;
  }
  /* Botão confirmar: largura total */
  .btn-confirmar {
    width: 100%;
    justify-content: center;
    white-space: normal;
    text-align: center;
  }
  /* Header de cada conteúdo: padding reduzido, botão vai abaixo */
  .rci-header {
    padding: 0.875rem 1rem;
    flex-direction: column;
    gap: 0.75rem;
  }
  /* Botão "Abrir completo" — largura total abaixo do título */
  .rci-link {
    width: 100%;
    justify-content: center;
  }
  /* Ações de documento: empilha os botões */
  .rci-doc-acoes {
    flex-direction: column;
    gap: 0.5rem;
    padding: 0.75rem 1rem;
  }
  .rci-doc-acoes .btn-sm {
    width: 100%;
    justify-content: center;
  }
  /* PDF: altura reduzida no celular */
  .rci-pdf-embed { height: 320px; }
  /* Barra de progresso: padding menor */
  .yt-progresso-rci { padding: 0.625rem 0.875rem; }
}

@media (max-width: 480px) {
  /* Cabeçalho da página: padding mínimo */
  .cabecalho-pagina { padding: 0.875rem 1rem; }
  /* Título da página: levemente menor */
  .pagina-titulo { font-size: 1.125rem; }
  /* Breadcrumb: limita o título da reunião */
  .breadcrumb span:last-child { max-width: 55vw; }
  /* Header do item: padding mínimo */
  .rci-header { padding: 0.75rem 0.875rem; }
  /* PDF: ainda mais compacto */
  .rci-pdf-embed { height: 260px; }
  /* Rodapé da barra de progresso: fonte menor */
  .yt-progresso-rodape { font-size: 0.6875rem; }
  /* Ícone do texto de confirmação: menor */
  .confirmacao-pendente-texto svg { width: 22px; height: 22px; }
  .confirmacao-pendente-texto { gap: 0.75rem; }
  /* Conteúdo da página: padding menor */
  .conteudo-pagina { padding: 1rem 0.875rem; }
}
