/*
Theme Name:  Minor 7th
Theme URI:   https://mixolidio.com.br
Description: Tema oficial Mixolidio Música — Block Theme FSE
Version:     1.0.0
Author:      Mixolidio
Text Domain: minor-7th
*/

/* ============================================================
   TOKENS GLOBAIS
   Edite aqui — os valores propagam por todo o tema via var()
   Nota: CSS custom properties não aceitam !important diretamente.
   O !important é aplicado nas propriedades que usam o token.
   ============================================================ */
:root {
  --mxl-bg:                  #030312;
  --mxl-fg:                  #ffffff;
  --mxl-muted:               #888888;
  --mxl-accent:              #FAE372;
  --mxl-header-border:       rgba(255, 255, 255, 0.5);
  --mxl-header-border-width: 1px;
  --mxl-max-width:           1024px;   /* ← token de largura máxima global */
  --mxl-grid-gap:            24px;
  --mxl-font:                'IBM Plex Mono', monospace;
  --mxl-font-size:           0.9rem;
  --mxl-letter-spacing-nav:  0.08em;
  --mxl-header-height:       56px;
  --mxl-padding-x:           48px;     /* ← padding horizontal mínimo global */
}

/* ============================================================
   RESET
   ============================================================ */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html, body {
  background-color: var(--mxl-bg);
  color: var(--mxl-fg);
  font-family: var(--mxl-font);
  font-size: var(--mxl-font-size);
  -webkit-font-smoothing: antialiased;
}

img {
  display: block;
  max-width: 100%;
}

a {
  color: inherit;
  text-decoration: none;
}

/* ============================================================
   HEADER
   max-width + margin auto centra o conteúdo em telas largas
   mantendo o fundo e a borda no limite do content area
   ============================================================ */
header.mxl-header.wp-block-group {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  flex-wrap: nowrap !important;
  width: 100% !important;
  max-width: var(--mxl-max-width) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  height: var(--mxl-header-height);
  padding: 0 var(--mxl-padding-x) !important;
  gap: 32px;
  background-color: var(--mxl-bg);
  border-bottom: var(--mxl-header-border-width) solid var(--mxl-header-border);
}

/* ============================================================
   LOGO
   ============================================================ */
header.mxl-header .mxl-logo {
  flex-shrink: 0;
  margin: 0 !important;
}

header.mxl-header .wp-block-site-logo.mxl-logo img {
  height: 28px;
  width: auto;
}

/* ============================================================
   NAVEGAÇÃO — desktop (>768px)
   ============================================================ */
header.mxl-header .mxl-nav {
  flex: 1;
}

@media (min-width: 769px) {

  /* mostra o nav inline */
  header.mxl-header .mxl-nav .wp-block-navigation__container {
    display: flex !important;
    align-items: center;
    gap: 32px;
    list-style: none;
    margin: 0;
    padding: 0;
    flex-wrap: nowrap;
  }

  /* esconde o hamburguer */
  header.mxl-header .mxl-nav button.wp-block-navigation__responsive-container-open {
    display: none !important;
  }
}

header.mxl-header .mxl-nav .wp-block-navigation-item__content {
  font-family: var(--mxl-font);
  font-size: 0.8rem;
  font-weight: 400;
  letter-spacing: var(--mxl-letter-spacing-nav);
  color: var(--mxl-muted);
  text-transform: lowercase;
  padding: 0;
  text-decoration: none;
  position: relative;
  transition: color 0.2s ease;
}

/* item ativo — cor */
header.mxl-header .mxl-nav .wp-block-navigation-item.current-menu-item .wp-block-navigation-item__content,
header.mxl-header .mxl-nav .wp-block-navigation-item__content[data-active="true"] {
  color: var(--mxl-fg);
}

/* item ativo — underline */
header.mxl-header .mxl-nav .wp-block-navigation-item.current-menu-item .wp-block-navigation-item__content::after,
header.mxl-header .mxl-nav .wp-block-navigation-item__content[data-active="true"]::after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: 0;
  right: 0;
  height: 1px;
  background-color: var(--mxl-fg);
}

header.mxl-header .mxl-nav .wp-block-navigation-item__content:hover {
  color: var(--mxl-fg);
}

/* ============================================================
   NAVEGAÇÃO — hamburguer (≤768px)
   Lógica: esconde o container do nav, exibe o botão hamburguer.
   Quando o overlay abre (.is-menu-open), o container
   volta a aparecer dentro do overlay em modo coluna.
   ============================================================ */
@media (max-width: 768px) {

  /* esconde nav inline */
  header.mxl-header .mxl-nav .wp-block-navigation__container {
    display: none !important;
  }

  /* exibe hamburguer */
  header.mxl-header .mxl-nav button.wp-block-navigation__responsive-container-open {
    display: flex !important;
    align-items: center;
    justify-content: center;
    background: none;
    border: none;
    cursor: pointer;
    padding: 4px;
    color: var(--mxl-fg);
  }

  header.mxl-header .mxl-nav button.wp-block-navigation__responsive-container-open svg {
    fill: var(--mxl-fg);
    width: 22px;
    height: 22px;
  }

  /* overlay aberto */
  header.mxl-header .mxl-nav .wp-block-navigation__responsive-container.is-menu-open {
    background-color: var(--mxl-bg) !important;
    padding: 80px 24px 24px;
  }

  /* nav items visíveis dentro do overlay */
  header.mxl-header .mxl-nav .wp-block-navigation__responsive-container.is-menu-open
  .wp-block-navigation__container {
    display: flex !important;
    flex-direction: column;
    gap: 0;
    list-style: none;
    padding: 0;
    margin: 0;
  }

  header.mxl-header .mxl-nav .wp-block-navigation__responsive-container.is-menu-open
  .wp-block-navigation-item__content {
    font-size: 1.1rem !important;
    letter-spacing: 0.1em;
    padding: 14px 0 !important;
    color: var(--mxl-fg) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    display: block;
    width: 100%;
  }

  /* botão fechar */
  header.mxl-header .mxl-nav button.wp-block-navigation__responsive-container-close {
    position: absolute;
    top: 16px !important;
    right: 16px !important;
    background: none;
    border: none;
    cursor: pointer;
  }

  header.mxl-header .mxl-nav button.wp-block-navigation__responsive-container-close svg {
    fill: var(--mxl-fg);
    width: 22px;
    height: 22px;
  }
}

/* ============================================================
   BOTÃO CATÁLOGO
   seletor longo garante precedência sobre estilos nativos do WP
   ============================================================ */
header.mxl-header .mxl-catalog-wrap.wp-block-buttons {
  flex-shrink: 0;
  margin: 0 !important;
}

header.mxl-header .mxl-catalog-wrap.wp-block-buttons
.mxl-btn-catalog.wp-block-button .wp-block-button__link {
  font-family: var(--mxl-font);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: var(--mxl-letter-spacing-nav);
  text-transform: lowercase;
  color: #000000 !important;
  background-color: #FAE372 !important;
  border-color: #FAE372 !important;
  border-radius: 2px;
  padding: 6px 16px;
  transition: opacity 0.2s ease;
}

header.mxl-header .mxl-catalog-wrap.wp-block-buttons
.mxl-btn-catalog.wp-block-button .wp-block-button__link:hover {
  color: #000000 !important;
  background-color: #FAE372 !important;
  opacity: 0.85;
}

/* ============================================================
   MAIN — compensa header fixo e aplica max-width global
   ============================================================ */
main.mxl-main.wp-block-group {
  max-width: var(--mxl-max-width) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  margin-top: var(--mxl-header-height) !important;
  min-height: calc(100vh - var(--mxl-header-height));
  padding: 48px var(--mxl-padding-x) !important;
}

/* ============================================================
   SISTEMA DE TABS
   ============================================================ */
.mxl-tab {
  display: none;
  width: 100%;
}

.mxl-tab.mxl-tab--active {
  display: block;
}

/* ============================================================
   GRID DE CAPAS
   seletores múltiplos cobrem todos os contextos
   em que o WP pode renderizar o shortcode
   ============================================================ */
ul.mxl-grid,
.wp-block-shortcode ul.mxl-grid,
.entry-content ul.mxl-grid,
main.mxl-main ul.mxl-grid {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--mxl-grid-gap);
  list-style: none !important;
  padding-left: 0 !important;
  margin: 0 !important;
}

ul.mxl-grid li.mxl-grid__item {
  list-style: none !important;
  padding-left: 0 !important;
  margin: 0 !important;
}

ul.mxl-grid li.mxl-grid__item::marker {
  content: none !important;
}

ul.mxl-grid li.mxl-grid__item a {
  display: block;
  overflow: hidden;
  line-height: 0;
}

/* quadrado — lançamentos */
ul.mxl-grid li.mxl-grid__item img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  display: block;
  transition: transform 0.3s ease, opacity 0.3s ease;
}

/* 16:9 — vídeos */
ul.mxl-grid li.mxl-grid__item--video img {
  aspect-ratio: 16 / 9;
}

/* hover */
ul.mxl-grid li.mxl-grid__item a:hover img {
  transform: scale(1.03);
  opacity: 0.85;
}

/* estado vazio */
.mxl-empty {
  color: var(--mxl-muted);
  font-size: 0.8rem;
  letter-spacing: 0.05em;
  padding: 48px 0;
}

/* ============================================================
   SEÇÃO CONTATO
   ============================================================ */
.mxl-contact {
  max-width: 560px;
  padding: 48px 0;
}

.mxl-contact p {
  color: var(--mxl-muted);
  font-size: 0.875rem;
  line-height: 1.8;
  letter-spacing: 0.04em;
}

/* ============================================================
   FOOTER
   ============================================================ */
footer.mxl-footer.wp-block-group {
  max-width: var(--mxl-max-width) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  margin-top: 48px !important;
  padding: 24px var(--mxl-padding-x) !important;
  border-top: var(--mxl-header-border-width) solid var(--mxl-header-border);
}

footer.mxl-footer .mxl-footer__copy {
  font-size: 0.7rem !important;
  letter-spacing: 0.1em;
  color: var(--mxl-muted) !important;
  text-transform: lowercase;
  margin: 0 !important;
}

/* ============================================================
   RESPONSIVO — TABLET (≤1024px)
   max-width reduz para 800px
   grid passa para 3 colunas
   gap mantém 24px
   ============================================================ */
@media (max-width: 1024px) {
  :root {
    --mxl-max-width: 800px;
    --mxl-padding-x: 48px;
  }

  ul.mxl-grid,
  .wp-block-shortcode ul.mxl-grid,
  main.mxl-main ul.mxl-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* ============================================================
   RESPONSIVO — MOBILE (≤768px)
   max-width reduz para 640px
   grid passa para 2 colunas
   gap reduz para 16px
   padding reduz para manter usabilidade em telas pequenas
   ============================================================ */
@media (max-width: 768px) {
  :root {
    --mxl-max-width:      640px;
    --mxl-header-height:  52px;
    --mxl-grid-gap:       16px;
    --mxl-padding-x:      20px;
  }

  header.mxl-header.wp-block-group {
    gap: 16px;
  }

  ul.mxl-grid,
  .wp-block-shortcode ul.mxl-grid,
  main.mxl-main ul.mxl-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  header.mxl-header .mxl-catalog-wrap.wp-block-buttons
  .mxl-btn-catalog.wp-block-button .wp-block-button__link {
    font-size: 0.65rem;
    padding: 4px 8px;
  }
}