/* IPTV Charleroi v1.3.60 — Mobile hamburger overlay final stabilization
   Scope: smartphone/tablet menu overlay, mobile overflow prevention, and hero/pricing mobile polish.
   Reason: v1.3.59 drawer was too transparent, inherited the page behind it, and displayed duplicate close controls visually. */

:root {
  --ipch-mobile-sheet-radius: 28px;
}

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

body {
  overflow-x: hidden;
}

@media (max-width: 980px) {
  html.ipch-mobile-menu-lock,
  html.ipch-mobile-menu-lock body,
  body.ipch-menu-open {
    overflow: hidden !important;
    touch-action: none;
  }

  .ipch-mobile-panel {
    z-index: 99999 !important;
    inset: 0 !important;
    min-height: 100dvh;
    background:
      radial-gradient(circle at 88% 6%, rgba(237, 13, 18, .34), transparent 26%),
      radial-gradient(circle at 10% 92%, rgba(237, 13, 18, .13), transparent 32%),
      linear-gradient(180deg, #060609 0%, #0b0b10 48%, #050507 100%) !important;
    -webkit-backdrop-filter: none !important;
    backdrop-filter: none !important;
  }

  .ipch-mobile-panel::before {
    opacity: .72;
    background:
      linear-gradient(90deg, rgba(255,255,255,.035) 0 1px, transparent 1px 24px),
      linear-gradient(180deg, rgba(255,255,255,.025) 0 1px, transparent 1px 24px);
  }

  body.ipch-menu-open .topbar.ipch-command-header {
    pointer-events: none;
  }

  body.ipch-menu-open .topbar.ipch-command-header .mobile-toggle.ipch-mobile-toggle {
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }

  .ipch-mobile-panel__inner {
    width: min(100% - 22px, 500px) !important;
    height: auto;
    max-height: calc(100dvh - 22px - env(safe-area-inset-bottom, 0px)) !important;
    margin: max(10px, env(safe-area-inset-top, 0px)) auto calc(10px + env(safe-area-inset-bottom, 0px)) !important;
    padding: 16px 12px 14px !important;
    gap: 10px !important;
    border-radius: var(--ipch-mobile-sheet-radius) !important;
    background:
      radial-gradient(circle at 100% 0%, rgba(237,13,18,.16), transparent 32%),
      linear-gradient(180deg, rgba(18, 18, 23, .98) 0%, rgba(7, 7, 10, .985) 100%) !important;
    border: 1px solid rgba(255,255,255,.11) !important;
    box-shadow: 0 28px 90px rgba(0,0,0,.72), inset 0 1px 0 rgba(255,255,255,.075) !important;
  }

  .ipch-mobile-panel__head {
    min-height: 48px;
    padding: 2px 2px 4px !important;
    border-bottom: 1px solid rgba(255,255,255,.08);
  }

  .ipch-mobile-panel__head span {
    display: inline-flex;
    align-items: center;
    min-height: 22px;
    padding: 5px 9px;
    border-radius: 999px;
    background: rgba(237,13,18,.15);
    color: rgba(255,255,255,.72);
    font-size: 10px !important;
    line-height: 1;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
  }

  .ipch-mobile-panel__head strong {
    display: block;
    margin-top: 6px;
    color: #fff;
    font-size: clamp(22px, 7vw, 30px) !important;
    line-height: 1 !important;
    letter-spacing: -.04em;
    font-weight: 950;
  }

  .ipch-mobile-close {
    width: 42px !important;
    height: 42px !important;
    flex-basis: 42px !important;
    border-radius: 15px !important;
    background: rgba(255,255,255,.075) !important;
    border-color: rgba(255,255,255,.13) !important;
    font-size: 24px !important;
  }

  .ipch-mobile-hero-cta {
    min-height: 58px !important;
    padding: 14px 16px !important;
    border-radius: 18px !important;
    background: linear-gradient(135deg, #ff1b24, #d70711) !important;
    box-shadow: 0 18px 42px rgba(237,13,18,.32) !important;
    font-size: 15px !important;
    font-weight: 950 !important;
  }

  .ipch-mobile-offers {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }

  .ipch-mobile-offers a {
    min-height: 64px !important;
    padding: 10px 8px !important;
    border-radius: 16px !important;
    background: linear-gradient(180deg, rgba(255,255,255,.085), rgba(255,255,255,.055)) !important;
    border-color: rgba(255,255,255,.12) !important;
  }

  .ipch-mobile-offers strong {
    font-size: 12px !important;
    letter-spacing: -.015em;
  }

  .ipch-mobile-offers small {
    font-size: 10px !important;
    color: rgba(255,255,255,.68) !important;
  }

  .ipch-mobile-links {
    gap: 7px !important;
  }

  .ipch-mobile-links a {
    min-height: 51px !important;
    padding: 12px 16px !important;
    border-radius: 16px !important;
    background: linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,.045)) !important;
    border-color: rgba(255,255,255,.105) !important;
    color: #fff !important;
    font-size: 14px !important;
    line-height: 1.1;
    font-weight: 900 !important;
    letter-spacing: -.01em;
  }

  .ipch-mobile-links a::after {
    opacity: .85;
  }

  .ipch-mobile-trust {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 0 !important;
    margin-top: 2px !important;
    padding: 8px 12px !important;
    border-radius: 18px !important;
    background: rgba(255,255,255,.055) !important;
    border: 1px solid rgba(255,255,255,.095) !important;
  }

  .ipch-mobile-trust span {
    min-height: 34px !important;
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 6px 0 !important;
    color: rgba(255,255,255,.86) !important;
    font-size: 12px !important;
    line-height: 1.2 !important;
    font-weight: 850 !important;
  }

  .ipch-mobile-trust span + span {
    border-top: 1px solid rgba(255,255,255,.075);
  }

  .ipch-mobile-trust i {
    width: 28px !important;
    height: 28px !important;
    display: inline-grid !important;
    place-items: center !important;
    border-radius: 9px !important;
    background: rgba(237,13,18,.20) !important;
    color: #fff !important;
  }

  .ipch-mobile-panel a,
  .ipch-mobile-close {
    will-change: transform;
  }

  .ipch-mobile-panel a:active,
  .ipch-mobile-close:active {
    transform: scale(.985);
  }
}

@media (max-width: 680px) {
  .hero,
  .hero.hero-v2-local-assets {
    min-height: auto !important;
    padding-top: calc(var(--ipch-live-header-h, 68px) + 18px) !important;
    padding-bottom: 32px !important;
  }

  .hero-title,
  .hero h1 {
    font-size: clamp(42px, 13vw, 64px) !important;
    line-height: .92 !important;
    letter-spacing: -.055em !important;
  }

  .hero-subtitle,
  .hero-copy p {
    font-size: 14px !important;
    line-height: 1.5 !important;
  }

  .pricing-grid-v1341 .price-card {
    min-height: auto !important;
  }

  .ipch-mobile-panel__inner {
    width: min(100% - 16px, 500px) !important;
    max-height: calc(100dvh - 14px - env(safe-area-inset-bottom, 0px)) !important;
    margin-top: max(7px, env(safe-area-inset-top, 0px)) !important;
    padding: 14px 10px 12px !important;
    border-radius: 24px !important;
  }
}

@media (max-width: 390px) {
  .ipch-mobile-panel__head strong {
    font-size: 24px !important;
  }

  .ipch-mobile-hero-cta {
    min-height: 54px !important;
  }

  .ipch-mobile-offers {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }

  .ipch-mobile-offers a {
    min-height: 58px !important;
    padding: 8px 5px !important;
  }

  .ipch-mobile-links a {
    min-height: 47px !important;
    font-size: 13px !important;
  }

  .ipch-mobile-trust span {
    min-height: 31px !important;
    font-size: 11px !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  .ipch-mobile-panel,
  .ipch-mobile-panel__inner,
  .ipch-mobile-panel a,
  .ipch-mobile-close {
    transition: none !important;
    animation: none !important;
  }
}
