/* =========================================================
   Fabuloop - Header responsive V4
   ASCII only.
   Target file:
   /themes/custom/fabuloop/css/fabuloop-mobile-header.css

   Key fixes compared with V3:
   - Do not hide header overflow, otherwise the language dropdown is clipped.
   - Force the logo link and logo image to be visible on reduced desktop browsers.
   - Keep the nav scrollable on one line.
   ========================================================= */

html,
body {
  max-width: 100%;
  overflow-x: hidden;
}

.dialog-off-canvas-main-canvas,
.site-wrapper,
.site-main,
.site-container,
#block-fabuloop-content,
.fl-page {
  max-width: 100%;
  box-sizing: border-box;
}

/* Invitation page full width inside theme container */
.site-main > .site-container:has(.fl-page) {
  width: 100% !important;
  max-width: none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

#block-fabuloop-content:has(.fl-page) {
  width: 100% !important;
}

/* General header safety */
.site-header,
.site-header-inner,
.site-header-brand,
.site-header-menu,
.site-header-lang,
.site-nav,
.site-nav > div,
.site-nav nav {
  min-width: 0 !important;
  box-sizing: border-box !important;
}

.site-nav ul {
  min-width: 0 !important;
  box-sizing: border-box !important;
}

.site-nav a {
  white-space: nowrap !important;
}

/* =========================================================
   Tablet / narrow desktop / mobile header
   ========================================================= */

@media (max-width: 1100px) {
  .site-header {
    border-bottom: 1px solid #eeeeee !important;
    overflow: visible !important;
    position: relative !important;
    z-index: 100 !important;
    background: #ffffff !important;
  }

  .site-header .site-container,
  .site-header-inner {
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 12px 18px 10px !important;
    overflow: visible !important;
  }

  .site-header-inner {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    grid-template-areas:
      "brand lang"
      "menu menu" !important;
    align-items: center !important;
    column-gap: 12px !important;
    row-gap: 10px !important;
  }

  .site-header-brand {
    grid-area: brand !important;
    justify-self: start !important;
    width: auto !important;
    max-width: 260px !important;
    min-width: 0 !important;
    height: auto !important;
    min-height: 58px !important;
    overflow: visible !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
  }

  .site-logo {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    width: 245px !important;
    max-width: 245px !important;
    height: auto !important;
    overflow: visible !important;
    line-height: 0 !important;
    text-decoration: none !important;
  }

  .site-logo img {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    width: 245px !important;
    max-width: 245px !important;
    height: auto !important;
    max-height: none !important;
    object-fit: contain !important;
  }

  .site-logo-baseline {
    display: block !important;
    visibility: visible !important;
    text-align: center !important;
    font-size: 15px !important;
    font-weight: 400 !important;
    line-height: 1.05 !important;
    margin-top: 2px !important;
    color: #111111 !important;
  }

  .site-header-lang {
    grid-area: lang !important;
    justify-self: end !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    position: relative !important;
    overflow: visible !important;
    z-index: 300 !important;
  }

  .site-lang-switcher {
    position: relative !important;
    overflow: visible !important;
  }

  .site-lang-toggle {
    min-height: 38px !important;
    padding: 0 14px !important;
    font-size: 15px !important;
    white-space: nowrap !important;
    position: relative !important;
    z-index: 301 !important;
  }

  .site-lang-dropdown {
    position: absolute !important;
    top: calc(100% + 8px) !important;
    right: 0 !important;
    left: auto !important;
    width: 190px !important;
    min-width: 190px !important;
    max-width: calc(100vw - 24px) !important;
    overflow: visible !important;
    z-index: 9999 !important;
  }

  .site-lang-dropdown ul,
  .site-lang-dropdown li {
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
  }

  .site-lang-dropdown a {
    display: block !important;
    width: 100% !important;
    box-sizing: border-box !important;
    white-space: nowrap !important;
  }

  .site-header-menu {
    grid-area: menu !important;
    width: 100% !important;
    overflow: hidden !important;
    z-index: 1 !important;
  }

  .site-nav,
  .site-nav > div,
  .site-nav nav {
    width: 100% !important;
  }

  .site-nav ul {
    display: flex !important;
    flex-wrap: nowrap !important;
    justify-content: flex-start !important;
    align-items: center !important;
    gap: 8px !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 0 4px !important;
    list-style: none !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: none !important;
  }

  .site-nav ul::-webkit-scrollbar {
    display: none !important;
  }

  .site-nav li {
    flex: 0 0 auto !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .site-nav a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 34px !important;
    padding: 0 11px !important;
    border-radius: 999px !important;
    background: #f5f5f5 !important;
    color: #555555 !important;
    text-decoration: none !important;
    font-size: 14px !important;
    line-height: 1 !important;
    font-weight: 500 !important;
    white-space: nowrap !important;
  }

  .fl-page {
    width: 100% !important;
    max-width: none !important;
    padding: 28px 18px 40px !important;
  }

  .fl-title {
    max-width: 760px !important;
    margin: 0 auto 18px !important;
    font-size: clamp(36px, 7vw, 58px) !important;
    line-height: 1 !important;
    letter-spacing: -0.045em !important;
    font-weight: 900 !important;
  }

  .fl-description {
    max-width: 680px !important;
    margin: 0 auto 20px !important;
    padding: 0 8px !important;
    font-size: clamp(20px, 3.5vw, 28px) !important;
    line-height: 1.13 !important;
  }

  .fl-visual-stack,
  .fl-main-visual {
    width: 100% !important;
    max-width: 760px !important;
  }

  .fl-media-box-article .fl-inline-image {
    aspect-ratio: 16 / 9 !important;
    object-fit: cover !important;
  }
}

/* =========================================================
   Phones
   ========================================================= */

@media (max-width: 600px) {
  .site-header .site-container,
  .site-header-inner {
    padding: 9px 10px 8px !important;
  }

  .site-header-brand {
    max-width: 190px !important;
    min-height: 50px !important;
  }

  .site-logo,
  .site-logo img {
    width: 190px !important;
    max-width: 190px !important;
  }

  .site-logo-baseline {
    font-size: 13px !important;
    margin-top: 1px !important;
  }

  .site-lang-toggle {
    min-height: 34px !important;
    padding: 0 12px !important;
    font-size: 14px !important;
  }

  .site-lang-dropdown {
    width: 170px !important;
    min-width: 170px !important;
    right: 0 !important;
  }

  .site-nav ul {
    gap: 6px !important;
    padding-bottom: 3px !important;
  }

  .site-nav a {
    min-height: 31px !important;
    padding: 0 9px !important;
    font-size: 13px !important;
  }

  .fl-page {
    padding: 22px 10px 34px !important;
  }

  .fl-title {
    font-size: clamp(32px, 10.3vw, 44px) !important;
    line-height: 1.02 !important;
    letter-spacing: -0.05em !important;
    margin-bottom: 16px !important;
  }

  .fl-description {
    font-size: clamp(19px, 5vw, 23px) !important;
    line-height: 1.13 !important;
    margin-bottom: 16px !important;
  }

  .fl-article-site-badge {
    left: 10px !important;
    top: 10px !important;
    min-height: 30px !important;
    padding: 0 12px !important;
    font-size: 13px !important;
  }

  .fl-score-preview-trigger {
    width: 190px !important;
    height: 190px !important;
    margin-top: 14px !important;
  }

  .fl-score-preview-wrap,
  .main-loop-notation.main-loop-notation-preview {
    width: 182px !important;
    height: 182px !important;
  }

  .fl-score-preview-value {
    font-size: 42px !important;
  }

  .fl-score-preview-value .fl-ring-pourcent {
    font-size: 22px !important;
    transform: translateY(6px) !important;
  }

  .fl-score-preview-label {
    font-size: 14px !important;
  }

  .fl-arrow-up {
    font-size: 34px !important;
    margin-top: 6px !important;
  }

  .fl-reassurance {
    padding-left: 10px !important;
    padding-right: 10px !important;
  }

  .fl-reassurance-title {
    font-size: 26px !important;
    line-height: 1.05 !important;
  }

  .fl-reassurance-text,
  .fl-small {
    font-size: 18px !important;
    line-height: 1.24 !important;
  }
}

/* Very small phones */
@media (max-width: 380px) {
  .site-header-brand {
    max-width: 160px !important;
    min-height: 46px !important;
  }

  .site-logo,
  .site-logo img {
    width: 160px !important;
    max-width: 160px !important;
  }

  .site-nav a {
    font-size: 12px !important;
    padding: 0 8px !important;
  }

  .fl-title {
    font-size: 31px !important;
  }

  .fl-description {
    font-size: 18px !important;
  }
}

/* =========================================================
   Invitation CTA - Give feedback button
   ========================================================= */

.fl-feedback-cta-wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 6px auto 12px;
  padding: 0 12px;
  text-align: center;
}

.fl-feedback-cta {
  min-width: 260px !important;
  width: auto !important;
  padding: 16px 30px !important;
  font-size: 22px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  cursor: pointer !important;
}

@media (max-width: 600px) {
  .fl-feedback-cta-wrap {
    margin: 4px auto 10px;
    padding: 0 10px;
  }

  .fl-feedback-cta {
    min-width: 0 !important;
    width: min(100%, 320px) !important;
    padding: 16px 22px !important;
    font-size: 22px !important;
  }
}
