/*
 * Correções responsivas mobile — Bendito Cacao Resort
 * Aplica-se a viewports <= 767px. Não afeta o desktop.
 * Acompanha js/mobile-menu.js (menu de navegação próprio).
 */

/* === GLOBAL (todos os viewports): contém vazamento horizontal === */
.dmFooterContainer { overflow-x: hidden !important; }
.slick-list { overflow: hidden !important; }

@media (max-width: 767px) {
  /* === BASE === */
  html, body {
    overflow-x: hidden !important;
    width: 100% !important;
    max-width: 100vw !important;
    margin: 0 !important;
  }
  body {
    padding-top: 98px !important;   /* casa com a altura do header compacto (~93px) + folga */
    padding-bottom: 40px !important;
    box-sizing: border-box !important;
  }

  /* Esconde elementos marcados como desktop-only */
  .showOnLarge, .hideOnMedium, .hideOnSmall, .hideOnMediumLarge,
  .hide-for-small, .hide-for-medium, .show-for-large, .show-for-medium-only {
    display: none !important;
  }

  /* === HEADER MOBILE === */
  .hamburger-header-container, #hamburger-header-container {
    background-color: #291103 !important;
    border-bottom: 2px solid #c8a96e !important;
    box-shadow: 0 4px 12px rgba(0,0,0,0.2) !important;
    position: fixed !important;
    top: 0 !important; left: 0 !important; right: 0 !important;
    width: 100% !important;
    z-index: 9000 !important;
  }
  body .hamburger-header, body #hamburger-header,
  #dm #hamburger-header, #dm .p_hfcontainer div#hamburger-header {
    background-color: transparent !important;
    padding: 10px 0 !important;
    height: auto !important;
    text-align: center !important;
  }
  /* Logo centralizado e compacto no header */
  body .hamburger-header img {
    max-width: 110px !important;
    height: auto !important;
    display: inline-block !important;
    margin: 0 auto !important;
  }

  /* Esconde o hamburguer/drawer nativo da Duda (quebrado offline).
     body+id eleva a especificidade acima de regras inline #id legadas. */
  body #layout-drawer-hamburger, body .layout-drawer-hamburger,
  body #hamburger-drawer, body .hamburger-drawer,
  body #layout-drawer-overlay, body .layout-drawer-overlay {
    display: none !important;
  }

  /* === MENU PRÓPRIO (js/mobile-menu.js) === */
  #bc-mobile-toggle {
    position: fixed !important;
    top: 22px !important;
    right: 16px !important;
    width: 44px !important;
    height: 44px !important;
    z-index: 10001 !important;
    background: transparent !important;
    border: 0 !important;
    padding: 9px 8px !important;
    cursor: pointer !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: space-between !important;
    box-sizing: border-box !important;
  }
  #bc-mobile-toggle span {
    display: block !important;
    height: 3px !important;
    width: 100% !important;
    background-color: #c8a96e !important;
    border-radius: 2px !important;
    transition: transform .25s ease, opacity .25s ease !important;
  }
  #bc-mobile-toggle.bc-open span:nth-child(1) {
    transform: translateY(10px) rotate(45deg) !important;
  }
  #bc-mobile-toggle.bc-open span:nth-child(2) { opacity: 0 !important; }
  #bc-mobile-toggle.bc-open span:nth-child(3) {
    transform: translateY(-10px) rotate(-45deg) !important;
  }

  #bc-mobile-overlay {
    position: fixed !important;
    inset: 0 !important;
    background: rgba(0,0,0,0.55) !important;
    z-index: 9998 !important;
    opacity: 0 !important;
    visibility: hidden !important;
    transition: opacity .25s ease !important;
  }
  #bc-mobile-overlay.bc-open { opacity: 1 !important; visibility: visible !important; }

  #bc-mobile-panel {
    position: fixed !important;
    top: 0 !important;
    right: 0 !important;
    height: 100% !important;
    width: 78% !important;
    max-width: 320px !important;
    background-color: #291103 !important;
    border-left: 2px solid #c8a96e !important;
    box-shadow: -8px 0 24px rgba(0,0,0,0.4) !important;
    z-index: 9999 !important;
    padding: 80px 0 24px !important;
    box-sizing: border-box !important;
    overflow-y: auto !important;
    transform: translateX(100%) !important;
    transition: transform .28s ease !important;
  }
  #bc-mobile-panel.bc-open { transform: translateX(0) !important; }
  #bc-mobile-panel ul {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
  }
  #bc-mobile-panel li {
    border-bottom: 1px solid rgba(200,169,110,0.15) !important;
  }
  #bc-mobile-panel a {
    display: block !important;
    color: #c8a96e !important;
    font-size: 17px !important;
    font-weight: 500 !important;
    text-decoration: none !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    padding: 16px 28px !important;
  }
  #bc-mobile-panel a:hover,
  #bc-mobile-panel a.bc-active { color: #ffffff !important; }

  /* === LAYOUT: força colunas a empilhar === */
  .dmInner, .dmOuter, .allWrapper, .dmContent, .dmRespRowsWrapper,
  .site_content, .dmLayoutWrapper, .dmwr, .dmRespCol, .dmRespColsWrapper,
  .dmRespRow, .row, [class*="small-"], [class*="medium-"], [class*="large-"] {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }
  .dmRespColsWrapper { display: flex !important; flex-direction: column !important; }
  .dmRespCol {
    width: 100% !important;
    flex: 0 0 100% !important;
    max-width: 100% !important;
    margin-bottom: 20px !important;
    float: none !important;
  }

  /* === IMAGENS === */
  img { max-width: 100% !important; height: auto !important; }
  .imageWidget {
    margin: 0 auto !important;
    width: 100% !important;
    max-width: 100% !important;
    text-align: center !important;
    display: block !important;
  }

  /* === BOTÕES DA DUDA (dmButtonLink) ===
     No desktop usam ícone com position:absolute e altura/largura fixas,
     o que no mobile joga o texto pro lado e estica a caixa. Normaliza. */
  .dmButtonLink, a.dmButtonLink, .dmButton {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: auto !important;
    max-width: 100% !important;
    min-width: 0 !important;
    height: auto !important;
    min-height: 44px !important;
    padding: 12px 24px !important;
    box-sizing: border-box !important;
    text-align: center !important;
    line-height: 1.3 !important;
    white-space: normal !important;
  }
  /* Neutraliza o ícone absoluto que desalinha o texto */
  .dmButtonLink .iconBg, .dmButtonLink .icon, .dmButtonLink .hasFontIcon {
    position: static !important;
    left: auto !important; top: auto !important;
    margin: 0 6px 0 0 !important;
  }
  /* Span de texto centralizado, sem deslocamento */
  .dmButtonLink .text {
    position: static !important;
    left: auto !important; top: auto !important;
    width: auto !important;
    padding: 0 !important;
    display: inline !important;
    text-align: center !important;
  }
  /* Wrapper do botão centralizado na coluna */
  .dmButtonLinkWrapper, .align-center.dmButtonLink {
    text-align: center !important;
    margin: 0 auto !important;
  }

  .dmNewParagraph, .dmNewParagraph p, .dmNewParagraph span {
    max-width: 100% !important;
    word-wrap: break-word !important;
  }
  h1 { font-size: clamp(24px, 7vw, 42px) !important; line-height: 1.15 !important; }
  h2 { font-size: clamp(20px, 5.5vw, 32px) !important; line-height: 1.2 !important; }
  h3 { font-size: clamp(16px, 4.5vw, 26px) !important; line-height: 1.3 !important; }

  /* === BARRA DE RESERVA === */
  #FormReservav6 {
    display: flex !important;
    flex-direction: column !important;
    padding: 15px 10px !important;
    height: auto !important;
  }
  #FormReservav6 .checkblock { display: flex !important; flex-wrap: wrap !important; height: auto !important; }
  #FormReservav6 .check {
    width: 48% !important; flex: 0 0 48% !important; max-width: 48% !important; margin-bottom: 10px !important;
  }
  #FormReservav6 .check:nth-child(1) { margin-right: 4% !important; }
  #FormReservav6 .hospedes, #FormReservav6 .cupom {
    width: 100% !important; flex: 0 0 100% !important; max-width: 100% !important; margin-bottom: 10px !important;
  }
  #FormReservav6 .columns.text-center { width: 100% !important; flex: 0 0 100% !important; position: relative !important; }
  #FormReservav6 #reservar {
    width: 100% !important; display: block !important; height: 50px !important; line-height: 50px !important;
  }

  /* === DRINKS / CALENDÁRIO === */
  .drink-container { height: auto !important; width: 100% !important; margin-bottom: 25px !important; }
  .lightpick {
    position: fixed !important;
    top: 50% !important; left: 50% !important;
    transform: translate(-50%, -50%) !important;
    z-index: 99999 !important;
    max-width: 95vw !important;
  }
}
