/* styles/custom.css */

/* HERO */
.hero{
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 1.2rem;
  padding: 1.25rem 1.25rem;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 1.6rem;
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  box-shadow: 0 18px 55px rgba(0,0,0,.35);
  margin: 1rem 0 1.5rem 0;
}
.hero-mascot{
  width: 100%;
  max-width: 380px;
  display: block;
  margin-left: auto;
  filter: drop-shadow(0 18px 28px rgba(0,0,0,.45));
}

/* GRID de cards */
/* Grid mais responsivo e confortável */
.grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 1.25rem;
  margin: 1.25rem 0;
}

.card{
  padding: 1.25rem 1.25rem;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 1.6rem;
  background: rgba(255,255,255,.04);
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.card:hover{
  transform: translateY(-3px);
  background: rgba(255,255,255,.06);
  box-shadow: 0 18px 55px rgba(0,0,0,.35);
}

/* Navbar: logo (mascote) bem integrado */
.navbar-brand img{
  height: 34px;
  width: auto;
}

/* Responsividade */
@media (max-width: 900px){
  .hero{ grid-template-columns: 1fr; }
  .grid{ grid-template-columns: 1fr; }
}

/* Páginas de listagem (ex.: Disciplinas) */
body.disciplinas .page-columns .content,
body[data-quarto-title="Disciplinas"] .page-columns .content {
  max-width: 1200px;
}

.card .btn{
  margin: .25rem .35rem .25rem 0;
}

/* Resource cards (Materiais de apoio) */
.resource{
  position: relative;
}

.resource-head{
  display: flex;
  align-items: center;
  gap: .85rem;
  margin-bottom: .75rem;
}

.resource-icon{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  font-size: 22px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 14px 35px rgba(0,0,0,.25);
}

.resource-meta{
  line-height: 1.1;
}

/* Cards de recursos */
.resource-kicker{
  display: inline-block;
  font-size: .72rem;
  letter-spacing: .10em;
  text-transform: uppercase;
  opacity: .78;
  margin: .35rem 0 .65rem 0;
  padding: .25rem .55rem;
  border-radius: .8rem;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.05);
}

.resource .btn{
  margin: .25rem .35rem .25rem 0;
}

.resource-title{
  font-size: 1.1rem;
  margin: 0;
}

.btn-row .btn,
.resource .btn{
  margin: .25rem .35rem .25rem 0;
}

/* Cards de aulas (slides) */
.lecture-card{
  display: flex;
  flex-direction: column;
  gap: .55rem;
}

.lecture-badge{
  display: inline-block;
  width: fit-content;
  font-size: .72rem;
  letter-spacing: .10em;
  text-transform: uppercase;
  opacity: .85;
  padding: .25rem .55rem;
  border-radius: .9rem;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.05);
}

.lecture-sub{
  display: block;
  opacity: .85;
  font-size: .95rem;
  line-height: 1.35;
  margin-top: -.25rem;
}

/* Botão alinhado ao “rodapé” do card */
.lecture-card .btn{
  margin-top: auto;
  width: fit-content;
}


