/* Cashbook Finance v2.7.5 — mobile-only spacing and overlap refinement */

@media (max-width: 760px){
  html,body{max-width:100%;overflow-x:hidden}
  body{min-width:0}
  .wrap{width:calc(100% - 32px)!important;max-width:none!important;margin-inline:auto!important}
  :is(.grid2,.grid3,.ticker,.sectors,.team-grid,.blog-grid,.glossary,.wrow,.values-grid,.related,.profile,.explain,.bio-block)>*{min-width:0}
  :is(.card,.icard,.sector,.sector-group,.tcard,.contact-card,.form-card,.quote-form-card,.checker,.flowcard,.apply-card,.portal-card,.profile-card-info,.bcard,.spec,.qa){max-width:100%;box-sizing:border-box}
  :is(input,select,textarea,button,.btn){max-width:100%;box-sizing:border-box}
  :is(input,select,textarea){min-width:0;width:100%}
  .btn{white-space:normal;text-align:center;line-height:1.25}
  .hero-cta,.cta-row,.faq-cta-row{width:100%}
  .hero-cta .btn,.cta-row .btn{min-width:0}

  /* Header and mobile menu: consistent touch targets and safe gutters. */
  header.nav{padding:8px!important}
  header.nav .nav-in{width:100%!important;min-height:60px!important;padding:8px 9px 8px 12px!important;gap:8px!important;border-radius:16px!important}
  header.nav .brand{min-width:0!important;max-width:calc(100% - 100px)}
  header.nav .brand img{max-width:145px;width:auto!important;height:27px!important}
  header.nav .nav-cta{gap:8px!important}
  header.nav .portal-nav-link,header.nav .burger{width:42px!important;min-width:42px!important;height:42px!important;min-height:42px!important;border-radius:12px!important}
  .mobile-menu{padding:82px 16px calc(24px + env(safe-area-inset-bottom))!important;gap:7px!important;overscroll-behavior:contain}
  .mobile-menu a:not(.btn):not(.m-call):not(.portal-mobile-link){width:100%;min-height:48px!important;padding:11px 12px!important;line-height:1.3!important}
  .mobile-menu .mobile-site-search{margin-bottom:5px!important}
  .mobile-menu .m-contact{width:100%;margin-top:10px!important}
  .mobile-menu .m-call,.mobile-menu .mobile-apply{width:100%!important;min-height:52px!important;border-radius:13px!important}
  .mobile-menu .portal-mobile-link{width:100%!important;min-height:74px!important;padding:13px!important;border-radius:15px!important}
  .mobile-menu .portal-mobile-copy{min-width:0}
  .mobile-menu .portal-mobile-copy small{white-space:normal}

  /* Prevent two-option controls and tab bars from pushing outside small screens. */
  .tabs{display:grid!important;grid-template-columns:minmax(0,1fr) minmax(0,1fr)!important;width:100%!important;gap:5px!important;overflow:visible!important;padding:5px!important}
  .tabs .tab{min-width:0!important;width:100%!important;min-height:48px!important;padding:8px 7px!important;font-size:13px!important;line-height:1.2!important;white-space:normal!important;text-align:center!important}
  .quote-form-card .seg{display:grid!important;grid-template-columns:minmax(0,1fr) minmax(0,1fr)!important;gap:6px!important;width:100%!important;padding:5px!important}
  .quote-form-card .seg label{min-width:0!important;width:100%!important}
  .quote-form-card .seg .opt{display:flex!important;align-items:center!important;justify-content:center!important;width:100%!important;min-height:52px!important;padding:8px 6px!important;font-size:12px!important;line-height:1.2!important;text-align:center!important}
  .seg input[type="radio"]{position:absolute!important;width:1px!important;height:1px!important;margin:0!important;opacity:0!important;pointer-events:none!important;overflow:hidden!important}

  /* Forms and wizard controls: no clipped buttons or uneven inner spacing. */
  .fld-2{grid-template-columns:minmax(0,1fr)!important;gap:0!important}
  .form-card,.quote-form-card{padding:22px 20px!important}
  .wnav{display:grid!important;grid-template-columns:minmax(0,1fr) minmax(0,1fr)!important;gap:10px!important;padding:16px!important}
  .wnav .btn{width:100%!important;min-width:0!important;min-height:50px!important;padding:10px 12px!important}
  .wbody{padding-inline:18px!important}
  .qpick{gap:8px!important}
  .qpick button{min-width:0!important}
  .send-panel .btn{width:100%!important}

  /* Portal progress: replace the clipped horizontal strip with a compact 2×2 grid. */
  body[data-page="portal"] .portal-steps{display:grid!important;grid-template-columns:minmax(0,1fr) minmax(0,1fr)!important;gap:7px!important;width:100%!important;overflow:visible!important;padding:8px!important;border-radius:16px!important}
  body[data-page="portal"] .portal-step{min-width:0!important;width:100%!important;min-height:50px!important;padding:8px!important;gap:7px!important;white-space:normal!important;line-height:1.2!important;font-size:11.5px!important;transform:none!important}
  body[data-page="portal"] .portal-step span{width:25px!important;height:25px!important;flex:0 0 25px!important}
  body[data-page="portal"] .portal-step.done::after{margin-left:auto!important}
  body[data-page="portal"] .finance-wrap{width:100%!important;max-width:100%!important;overflow-x:auto!important;-webkit-overflow-scrolling:touch;overscroll-behavior-inline:contain}
  body[data-page="portal"] .portal-grid>*{min-width:0}
  body[data-page="portal"] .upload-box{padding:20px 16px!important}

  /* Profile pages: remove the last few pixels of overflow and wrap long contact data. */
  .profile{width:100%!important;max-width:100%!important}
  .profile>*{min-width:0!important;max-width:100%!important}
  .profile-photo{width:min(100%,260px)!important;margin-inline:auto!important}
  .profile-card-info,.profile-bio,.profile-tags{width:100%!important;max-width:100%!important;box-sizing:border-box!important}
  .profile-card-info a{min-width:0!important;overflow-wrap:anywhere!important;word-break:break-word!important}
  .profile-tags span{max-width:100%;white-space:normal}
  .profile .btn{width:100%!important}

  /* FAQs and legal/article content: balanced spacing and resilient wrapping. */
  .qa>button{display:grid!important;grid-template-columns:minmax(0,1fr) auto!important;align-items:center!important;width:100%!important;gap:12px!important;text-align:left!important}
  .qa .plus{flex:0 0 auto}
  .qa-panel .inner{padding:18px!important}
  .prose,.article,.article-head{max-width:100%!important}
  .prose :is(pre,table){max-width:100%;overflow-x:auto}
  .spec .row{min-width:0}
  .spec .row>*{min-width:0;overflow-wrap:anywhere}

  /* Footer and long contact values. */
  footer :is(a,p,li,span){overflow-wrap:anywhere}
  .ft-top{gap:28px!important}
  .ft-col a{min-height:38px;display:flex;align-items:center}
}

@media (max-width: 360px){
  .wrap{width:calc(100% - 28px)!important}
  .section{padding-block:56px!important}
  .h1{font-size:clamp(38px,12vw,52px)!important}
  .h2{font-size:clamp(31px,10vw,42px)!important}
  .form-card,.quote-form-card{padding:20px 16px!important;border-radius:18px!important}
  .quote-form-card .seg .opt{font-size:11.5px!important;padding-inline:4px!important}
  .tabs .tab{font-size:12.5px!important;padding-inline:5px!important}
  .wnav{padding:14px!important;gap:8px!important}
  .wnav .btn{font-size:13px!important;padding-inline:8px!important}
  body[data-page="portal"] .portal-card{padding:20px 15px!important}
  body[data-page="portal"] .portal-step{font-size:11px!important;padding:7px 6px!important}
  .mobile-menu{padding-inline:14px!important}
}

@media (max-width: 1320px){
  .mobile-menu .mobile-site-search{max-width:none!important;min-width:0!important;flex:0 0 auto!important}
  .mobile-menu .mobile-site-search .site-search-form{width:100%!important;max-width:none!important}
  body:has(.mobile-menu.show) .theme-toggle{opacity:0!important;pointer-events:none!important;transform:translateY(12px)!important}
}

@media (max-width: 480px){
  .dir-row{display:grid!important;grid-template-columns:1fr!important;gap:4px!important}
  .dir-row b{min-width:0!important}
  .oneliner{max-width:100%!important;white-space:normal!important}
}
