
/* === CEO MOBILE HOTFIX v2026-05-15 ===
   Fixes: header button collision, pill overlap, bottom CTA overlap, mobile hero readability.
*/
@media(max-width:980px){
  html,body{
    width:100%!important;
    max-width:100%!important;
    overflow-x:hidden!important;
  }

  body{
    padding-bottom:104px!important;
  }

  .top{
    min-height:88px!important;
    padding:14px 16px!important;
    display:flex!important;
    align-items:center!important;
    justify-content:space-between!important;
    gap:10px!important;
    flex-wrap:nowrap!important;
  }

  .brand{
    min-width:0!important;
    max-width:calc(100% - 60px)!important;
    flex:1 1 auto!important;
    display:flex!important;
    align-items:center!important;
  }

  .brand img{
    width:48px!important;
    height:48px!important;
    min-width:48px!important;
    object-fit:contain!important;
  }

  .brand h1{
    font-family:Inter,Arial,sans-serif!important;
    font-size:25px!important;
    line-height:1!important;
    max-width:210px!important;
    white-space:nowrap!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
  }

  .brand p{
    font-size:9.5px!important;
    line-height:1.2!important;
    letter-spacing:1.6px!important;
    white-space:nowrap!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
    max-width:230px!important;
  }

  /* Hide desktop CTA from mobile header. It causes the exact overlap shown in screenshot. */
  .topActions{
    display:none!important;
  }

  .scoreDrawer{
    top:92px!important;
    left:12px!important;
    right:12px!important;
    max-height:calc(100svh - 120px)!important;
    overflow:auto!important;
  }

  .page{
    padding:12px!important;
  }

  .hero{
    display:block!important;
    min-height:auto!important;
    padding:20px!important;
    border-radius:28px!important;
    margin-top:10px!important;
    overflow:hidden!important;
  }

  .heroLeft,.heroRight{
    width:100%!important;
    min-width:0!important;
  }

  .pills{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:10px!important;
    width:100%!important;
    margin:0 0 22px!important;
  }

  .pills span{
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    width:100%!important;
    min-width:0!important;
    max-width:100%!important;
    white-space:normal!important;
    overflow:hidden!important;
    text-align:center!important;
    line-height:1.15!important;
    font-size:13px!important;
    min-height:46px!important;
    padding:10px 12px!important;
    border-radius:18px!important;
  }

  h2.big,.big{
    font-family:Inter,Arial,sans-serif!important;
    font-size:36px!important;
    line-height:1.08!important;
    letter-spacing:-1.2px!important;
    margin:0 0 14px!important;
    max-width:100%!important;
    overflow-wrap:break-word!important;
  }

  .big:after{
    display:block!important;
    font-size:28px!important;
    line-height:1.05!important;
    margin-top:14px!important;
    overflow-wrap:break-word!important;
  }

  .lead{
    font-size:15.5px!important;
    line-height:1.62!important;
    max-width:100%!important;
    margin:0!important;
  }

  .heroActions{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:12px!important;
    margin-top:22px!important;
  }

  .goldBtn,.darkBtn,.ghost{
    width:100%!important;
    min-height:56px!important;
    border-radius:18px!important;
    font-size:15.5px!important;
    padding:14px 16px!important;
    text-align:center!important;
  }

  .logoBox{
    min-height:150px!important;
    border-radius:24px!important;
    padding:14px!important;
    margin-top:18px!important;
  }

  .logoBox img{
    max-width:132px!important;
    width:132px!important;
  }

  .miniCards{
    display:grid!important;
    grid-template-columns:1fr 1fr!important;
    gap:10px!important;
  }

  .miniCards div{
    min-width:0!important;
    padding:14px!important;
    border-radius:18px!important;
  }

  .miniCards b{
    font-size:17px!important;
    white-space:normal!important;
  }

  .miniCards span{
    font-size:12px!important;
  }

  .grid4,.grid3,.grid2,.formRow,.simGrid,.moduleGrid,.riskCards,.leadForm{
    grid-template-columns:1fr!important;
    gap:12px!important;
  }

  .card,.feature,.metric,.riskPulse,.contactBlock,.qCard,.reportHero,.resultConversionBand,.simCard,.riskCard,.module,.threatCard{
    padding:18px!important;
    border-radius:22px!important;
  }

  .sectionTitle h2{
    font-size:26px!important;
    line-height:1.22!important;
    letter-spacing:-.6px!important;
  }

  input,select{
    min-height:56px!important;
    border-radius:17px!important;
    font-size:15px!important;
  }

  /* Fix bottom CTA overlap: keep one clean CTA, inside viewport, not too tall. */
  .mobileStickyCTA{
    display:block!important;
    position:fixed!important;
    left:12px!important;
    right:12px!important;
    bottom:12px!important;
    z-index:9999!important;
    min-height:58px!important;
    padding:16px 14px!important;
    border-radius:18px!important;
    text-align:center!important;
    font-weight:950!important;
    background:linear-gradient(135deg,#00B884,#5AF0CE)!important;
    color:#05110D!important;
    box-shadow:0 14px 38px rgba(7,17,15,.22)!important;
  }

  /* Hide duplicate Book Pilot sticky on landing mobile to prevent the yellow/green collision in screenshot. */
  body:not(.result-page) .scoreStickyCTA{
    display:none!important;
  }

  .resultConversionBand .scoreStickyCTA{
    display:none!important;
  }
}

@media(max-width:390px){
  .brand h1{font-size:21px!important;max-width:176px!important}
  .brand p{font-size:8px!important;max-width:190px!important}
  h2.big,.big{font-size:31px!important}
  .big:after{font-size:25px!important}
  .pills span{font-size:12px!important}
}
