/* =========================================================
   responsive.css — global + dashboard + index mobile portrait
========================================================= */

/* ---------- Global Safe Defaults ---------- */
html, body{
  max-width: 100%;
  overflow-x: hidden;
}

img, video, audio{
  max-width: 100%;
  height: auto;
}

/* =========================================================
   DASHBOARD RESPONSIVE (dashboard.html)
========================================================= */
@media (max-width: 1024px){
  .dashboard-container{ flex-direction: column; }

  .dashboard-sidebar{
    width: 100%;
    flex-direction: row;
    overflow-x: auto;
    order: 0;
  }

  .dashboard-sidebar .sidebar-header{
    flex-direction: row;
    justify-content: space-between;
    padding: 10px;
  }

  .sidebar-nav{
    display: flex;
    width: 100%;
    justify-content: space-around;
    padding: 5px 0;
  }

  .nav-item{
    flex: 1;
    text-align: center;
    font-size: 14px;
    padding: 8px 0;
  }

  .dashboard-main{
    width: 100%;
    padding: 10px;
    order: 1;
  }

  .content-header h2{ font-size: 18px; }
  .content-section{ padding: 5px 0; }

  .form-field, .form-row{
    width: 100%;
    display: block;
    margin-bottom: 10px;
  }

  .form-row > .form-field{
    width: 100%;
    margin-right: 0;
  }

  .file-input-wrapper{ width: 100%; }

  .submit-btn{
    width: 100%;
    padding: 12px;
    font-size: 16px;
  }

  .catalog-list, .calendar-list{
    max-height: 400px;
    overflow-y: auto;
  }
}

@media (max-width: 768px){
  .dashboard-sidebar{
    flex-direction: column;
    align-items: stretch;
  }

  .sidebar-nav{ flex-direction: column; }

  .nav-item{
    width: 100%;
    padding: 12px 0;
    font-size: 16px;
  }

  .content-header h2{ font-size: 16px; }

  .form-field input,
  .form-field select,
  .form-field textarea{
    font-size: 16px;
    padding: 10px;
  }

  .cover-preview img{
    max-width: 100%;
    height: auto;
    display: block;
    margin: 10px 0;
  }

  .upload-progress{ width: 100%; }
}

@media (max-width: 480px){
  .dashboard-sidebar{ font-size: 14px; }

  .submit-btn{
    font-size: 14px;
    padding: 10px;
  }

  .content-header h2{ font-size: 14px; }

  .catalog-list, .calendar-list{ max-height: 300px; }
}

/* =========================================================
   INDEX MOBILE — ÚNICO BLOCO (portrait + landscape)
========================================================= */

/* MOBILE (geral): compacta playlist */
@media (max-width: 900px){
  .playlist-container{
    width: 100% !important;
    right: 0 !important;
    border-left: none !important;
  }

  .playlist-item-header{
    padding: 12px 14px !important;
    gap: 12px !important;
  }

  .playlist-item-cover{
    width: 46px !important;
    height: 46px !important;
  }

  .playlist-item-title{
    font-size: 13px !important;
    margin-bottom: 4px !important;
  }

  .playlist-item-artists{
    font-size: 11.5px !important;
  }

  .playlist-item-toggle{
    width: 30px !important;
    height: 30px !important;
  }

  .playlist-item-details{ padding: 0 14px !important; }
  .playlist-item.expanded .playlist-item-details{
    padding: 0 14px 14px !important;
    max-height: 45dvh !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }
}

/* PORTRAIT: player fixo embaixo, playlist rola acima */
@media (max-width: 900px) and (orientation: portrait){
  :root{
    --topHeaderH: 92px;
    --bottomNavH: 70px;
    --playerH: 160px;
  }

  html, body{
    height: 100%;
    overflow: hidden !important;
  }

  .bottom-nav{
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    transform: none !important;
    z-index: 100 !important;
  }

  .main-content{
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    bottom: var(--bottomNavH) !important;
    height: var(--playerH) !important;
    width: 100% !important;
    padding: 8px 10px !important;
    z-index: 90 !important;
  }

  .playlist-container{
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    top: var(--topHeaderH) !important;
    bottom: calc(var(--bottomNavH) + var(--playerH)) !important;
    height: auto !important;
    padding: 10px 12px !important;
    overflow: hidden !important;
    z-index: 50 !important;
  }

  .playlist{
    height: 100% !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
    padding-bottom: 16px !important;
  }
}

/* LANDSCAPE: evita fim escondido pela bottom-nav */
@media (max-width: 1024px) and (orientation: landscape){
  .playlist{
    padding-bottom: 140px !important; /* garante fim visível */
  }
}

/* =========================================================
   PORTRAIT: player volta a ser "card pequeno" com fundo
========================================================= */
@media (max-width: 900px) and (orientation: portrait){

  /* faixa do player (wrapper) */
  .main-content{
    background: rgba(0,0,0,.55) !important;
    backdrop-filter: blur(10px) !important;
    border-top: 1px solid rgba(255,255,255,.12) !important;
  }

  /* o CARD do player (igual seu visual anterior) */
  .player-container{
    width: 100% !important;
    max-width: 420px !important;      /* deixa “pequeno” no centro */
    margin: 0 auto !important;

    background: rgba(0,0,0,.35) !important;
    border: 1px solid rgba(255,255,255,.12) !important;
    border-radius: 14px !important;
    backdrop-filter: blur(12px) !important;

    padding: 10px 10px !important;
    overflow: visible !important;
  }

  /* deixa o player mais compacto dentro do card */
  .player{
    padding: 8px 8px !important;
    gap: 10px !important;
  }

  .player-logo-container{
    width: 56px !important;
    height: 56px !important;
  }

  .player-waveform{
    height: 42px !important;
    min-height: 42px !important;
  }
}

/* =========================================================
   PORTRAIT: bottom-nav alinhada e com botões iguais
========================================================= */
@media (max-width: 900px) and (orientation: portrait){

  .bottom-nav{
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    transform: none !important;

    width: 100% !important;
    padding: 10px 12px !important;
    box-sizing: border-box !important;

    display: flex !important;
    gap: 10px !important;
    justify-content: space-between !important;
    align-items: center !important;

    background: rgba(0,0,0,.75) !important;
    border-top: 1px solid rgba(255,255,255,.12) !important;
    backdrop-filter: blur(10px) !important;
  }

  .bottom-nav .nav-bottom-btn{
    flex: 1 1 0 !important;
    min-width: 0 !important;
    height: 46px !important;
    border-radius: 12px !important;
    text-align: center !important;
    padding: 12px 0 !important;
  }
}

/* =================================
   Hide signature on mobile portrait
================================= */

@media (max-width: 768px) and (orientation: portrait){
  .site-signature{
    display: none !important;
  }
}

/* =========================================
   MOBILE PORTRAIT — logo maior + sem “anel branco”
========================================= */
@media (max-width: 900px) and (orientation: portrait){

  /* deixa a área da logo maior */
  .player-logo-container{
    width: 72px !important;
    height: 72px !important;
  }

  /* aumenta a imagem e garante leitura */
  #playerLogo{
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
    padding: 6px !important;         /* respiro sem cortar */
    filter: none !important;         /* mata qualquer filtro que “lava” */
    background: transparent !important;
    border-radius: 0 !important;
  }

  /* remove “anel/círculo branco” do botão */
  #playPauseBtn{
    background: rgba(0,0,0,.35) !important;  /* discreto */
    border-color: rgba(255,255,255,.18) !important;
    box-shadow: none !important;
    outline: none !important;
  }

  /* se o círculo branco for do SVG/ícone */
  #playPauseBtn svg{
    filter: none !important;
  }
}

/* =========================================
   INDEX CALENDAR — mobile landscape: caber tudo + scroll interno
========================================= */
@media (max-width: 900px) and (orientation: landscape){

  /* o overlay inteiro não pode estourar a tela */
  #calendarOverlay,
  .calendar-overlay{
    padding: 10px !important;
  }

  /* o card/modal do calendário */
  #calendarOverlay .calendar-content,
  .calendar-overlay .calendar-content,
  #calendarOverlay .calendar-modal,
  .calendar-overlay .calendar-modal{
    max-height: 92dvh !important;
    height: auto !important;
    overflow: hidden !important;

    display: flex !important;
    flex-direction: column !important;
  }

  /* área do grid do calendário: pode encolher */
  #calendarOverlay .calendar-grid-wrap,
  .calendar-grid-wrap,
  #calendarOverlay .calendar-grid,
  .calendar-grid{
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow: auto !important; /* scroll se precisar */
    -webkit-overflow-scrolling: touch;
  }

  /* células um pouco menores no landscape */
  .calendar-day,
  .calendar-cell{
    min-height: 44px !important;
  }

  /* painel de baixo (onde aparecem os uploads do dia) */
  #calendarOverlay .calendar-day-panel,
  .calendar-day-panel,
  #calendarOverlay .calendar-results,
  .calendar-results{
    flex: 0 0 120px !important;   /* altura visível */
    max-height: 120px !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
    min-height: 0 !important;
  }
}

/* =========================================
   CALENDAR overlay — quando a ALTURA é baixa (ex: landscape celular)
   O alvo é: 499px de altura ou menos
========================================= */
@media (max-height: 500px) {

  /* o card do calendário precisa virar flex-col e caber na tela */
  #calendarOverlay .catalog-content{
    max-height: 92vh !important;
    height: 92vh !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
    padding: 16px !important; /* menos padding */
  }

  /* header do modal menor */
  #calendarOverlay .catalog-header{
    padding: 10px 12px !important;
    margin-bottom: 10px !important;
  }

  /* área do calendário (grid) precisa poder encolher */
  #calendarOverlay #calendarContent{
    flex: 1 1 auto !important;
    min-height: 0 !important;     /* CRÍTICO p/ flex scroll funcionar */
    overflow: hidden !important;  /* quem rola são os filhos */
  }

  /* grid rola se precisar */
  #calendarOverlay .calendar-grid,
  #calendarOverlay .calendar-grid-wrap{
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow: auto !important;
    -webkit-overflow-scrolling: touch;
  }

  /* células menores */
  #calendarOverlay .calendar-day,
  #calendarOverlay .calendar-cell{
    min-height: 42px !important;
    padding: 6px !important;
  }

  /* PAINEL “tracks do dia” SEMPRE visível: fixa altura e scroll */
  #calendarOverlay .calendar-results,
  #calendarOverlay .calendar-day-panel,
  #calendarOverlay .calendar-list,
  #calendarOverlay .day-tracks{
    flex: 0 0 110px !important;
    max-height: 110px !important;
    min-height: 110px !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
  }
}

/* =========================================================
   CALENDAR OVERLAY — FIX LANDSCAPE LOW HEIGHT (<=500px)
   resolve 499px sumindo lista/painel
========================================================= */
@media (max-height: 500px) {
  /* o overlay precisa permitir scroll interno */
  #calendarOverlay .catalog-content{
    max-height: 92dvh !important;
    overflow: auto !important;
    -webkit-overflow-scrolling: touch;
  }

  /* compacta o shell */
  #calendarOverlay .cal-shell{
    padding: 10px 12px !important;
    gap: 10px !important;
  }

  /* header menor */
  #calendarOverlay .cal-head{
    gap: 8px !important;
  }

  #calendarOverlay .cal-h1{
    font-size: 18px !important;
    margin: 0 !important;
  }
  #calendarOverlay .cal-h2{
    font-size: 12px !important;
    opacity: .75 !important;
  }

  #calendarOverlay .cal-nav{
    gap: 10px !important;
  }
  #calendarOverlay .cal-month{
    font-size: 12px !important;
    letter-spacing: .08em !important;
  }
  #calendarOverlay .cal-nav-btn{
    width: 34px !important;
    height: 34px !important;
    border-radius: 10px !important;
  }

  /* grid mais baixo + scroll se precisar */
  #calendarOverlay .cal-grid-wrap{
    max-height: 46dvh !important;      /* chave */
    overflow: auto !important;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 6px !important;
  }

  /* células menores */
  #calendarOverlay .cal-grid{
    gap: 6px !important;
  }
  #calendarOverlay .cal-day{
    min-height: 42px !important;       /* antes tava alto demais */
    border-radius: 10px !important;
    padding: 8px 8px !important;
  }
  #calendarOverlay .cal-day-num{
    font-size: 12px !important;
  }

  /* painel (lista de tracks) sempre visível e rolável */
  #calendarOverlay .cal-panel{
    max-height: 30dvh !important;      /* chave */
    overflow: auto !important;
    -webkit-overflow-scrolling: touch;
    padding: 10px 12px !important;
  }

  #calendarOverlay .cal-item{
    padding: 8px 10px !important;
  }
  #calendarOverlay .cal-item-title{
    font-size: 13px !important;
  }
  #calendarOverlay .cal-item-artist{
    font-size: 12px !important;
    opacity: .7 !important;
  }

  /* evita que algum overflow hidden mate o conteúdo */
  #calendarOverlay,
  #calendarOverlay *{
    min-height: 0;
  }
}

@media (orientation: portrait){
  .player-logo img{
    width: 180px;   /* aumenta aqui */
    height: auto;
  }
}


@media (max-width: 900px) and (orientation: landscape){
  body::before{
    content: "Rotate your device to portrait.";
    position: fixed;
    inset: 0;
    z-index: 999999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    background: #000;
    color: rgba(255,255,255,.9);
    font-family: 'Space Grotesk','Inter',sans-serif;
    font-size: 14px;
    letter-spacing: .06em;
    text-transform: uppercase;
    text-align: center;
  }

  .top-header,
  .background-container,
  .main-content,
  .bottom-nav,
  .playlist-container,
  .catalog-overlay,
  .artist-overlay,
  .site-signature{
    display: none !important;
  }
}

@media (max-width: 900px) and (orientation: portrait){
  :root{
    --topHeaderH: 160px;   /* era 92px */
    --bottomNavH: 70px;
    --playerH: 170px;
  }

  .top-header{
    top: 12px !important;
    left: 12px !important;
    gap: 8px !important;
    z-index: 120 !important;
  }

  .brand-ticker,
  #nowPlayingHeader{
    width: min(240px, calc(100vw - 24px)) !important;
    max-width: min(240px, calc(100vw - 24px)) !important;
  }

  .playlist-container{
    top: var(--topHeaderH) !important;
  }
}

@media (max-width: 900px) and (orientation: portrait){
  .now-playing-genre{
    display: block !important;
    opacity: .7;
    font-size: 12px;
    margin-top: 4px;
  }

  #nowPlayingHeader{
    padding: 10px 12px !important;
  }

  #nowPlayingTitle{
    font-size: 16px !important;
    line-height: 1.15 !important;
  }
}