/* Imara Flow UI/UX Pro Max patch 2026-06-07
   Mobile-first SaaS UX, WCAG AA touch targets, overflow fixes, separated wallet/petty cash. */
:root{
  --imara-primary:#020F2A;
  --imara-accent:#D7A642;
  --imara-blue:#0B6BFF;
  --imara-bg:#FFFFFF;
  --imara-canvas:#F4F7FB;
  --imara-border:#DCE6F3;
  --imara-muted:#52617A;
  --imara-danger:#991B1B;
  --imara-success:#147A3A;
  --safe-bottom:env(safe-area-inset-bottom,0px);
}
*{box-sizing:border-box;}
html,body{max-width:100%;overflow-x:hidden;-webkit-text-size-adjust:100%;}
body{background:var(--imara-canvas);color:var(--imara-primary);}
a,button,input,select,textarea{font:inherit;}
a,button,.primaryBtn,.darkBtn,.lightBtn,.ghostBtn,.authGoogleBtn{min-height:44px;touch-action:manipulation;}
button,input,select,textarea{font-size:16px;}
img,svg{max-width:100%;}

/* Auth and form overflow fixes */
.loginCardPremium,.registerCardPremium,.loginFormPanel,.authCard,.glassCard,.setupCard,.modulePanel,.metricCard,.heroCard,.appHero,.moduleHero{max-width:100%;overflow:hidden;}
.loginFormPanel,.registerCardPremium,.loginCardPremium{width:100%;}
.premiumField,.inputWrap,.fieldWrap,.formField{width:100%;max-width:100%;min-width:0;}
.premiumField>div,.inputWrap,.fieldWrap{position:relative;display:flex;align-items:center;gap:10px;min-height:60px;border-radius:18px;min-width:0;}
.premiumField input,.premiumField select,.premiumField textarea,.inputWrap input,.inputWrap select,.inputWrap textarea,.fieldWrap input,.fieldWrap select,.fieldWrap textarea{width:100%;min-width:0;max-width:100%;border:0;background:transparent;outline:0;font-size:16px;line-height:1.35;color:var(--imara-primary);overflow:hidden;text-overflow:ellipsis;}
.premiumField .material-symbols-outlined,.inputWrap .material-symbols-outlined,.fieldWrap .material-symbols-outlined,.inputIcon{flex:0 0 24px;color:#70809A;z-index:1;pointer-events:none;}
.premiumField button[type="button"],.passwordToggle,.fieldToggle{flex:0 0 44px;width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;border:0;background:transparent;color:#70809A;}
.rememberPremium,.rememberRow{display:flex;align-items:flex-start;gap:12px;min-width:0;max-width:100%;}
.rememberPremium span,.rememberRow span,.rememberPremium label,.rememberRow label{white-space:normal;line-height:1.3;min-width:0;overflow-wrap:break-word;}
.rememberPremium input,.rememberRow input{flex:0 0 28px;width:28px;height:28px;margin-top:2px;}
.orDivider,.authDivider{display:flex;align-items:center;gap:14px;white-space:nowrap;color:#8C98AA;font-weight:900;letter-spacing:.14em;text-transform:uppercase;}
.orDivider:before,.orDivider:after,.authDivider:before,.authDivider:after{content:"";height:1px;flex:1;background:var(--imara-border);}
.authGoogleBtn{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;border:1px solid var(--imara-border);border-radius:18px;background:#fff;color:var(--imara-primary);font-weight:900;text-decoration:none;padding:13px 16px;box-shadow:0 10px 28px rgba(2,15,42,.04);}
.authGoogleBtn:before{content:"G";font-weight:900;color:#4285F4;}

/* Better hierarchy and premium fintech surfaces */
.dashMain{min-width:0;}
.appHero,.moduleHero{background:linear-gradient(145deg,#fff 0%,#fff 58%,#F4F8FF 100%);border:1px solid var(--imara-border);box-shadow:0 18px 45px rgba(2,15,42,.06);}
.appHero h2,.moduleHero h2{font-size:clamp(32px,8vw,64px);line-height:.98;letter-spacing:-.06em;max-width:11ch;}
.moduleHero p,.appHero p{font-size:clamp(17px,4.2vw,24px);line-height:1.55;color:#3C4A62;}
.eyebrow{color:#0B6BFF;letter-spacing:.18em;text-transform:uppercase;font-weight:900;}
.appHeroMini,.heroCard{background:linear-gradient(135deg,var(--imara-primary),#06468C);color:#fff;border:0;}
.appHeroMini span,.appHeroMini small,.heroCard span,.heroCard small{color:rgba(255,255,255,.76)!important;}
.appHeroMini strong,.heroCard strong{color:#fff!important;}
.modulePanel,.metricCard,.settingsItem,.dataCard{background:#fff;border:1px solid var(--imara-border);border-radius:28px;box-shadow:0 12px 35px rgba(2,15,42,.045);}
.metricGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;}
.metricCard{padding:24px;}
.metricCard span{display:block;color:#5B6880;font-weight:800;line-height:1.25;}
.metricCard strong{display:block;font-size:clamp(32px,7vw,52px);line-height:1;color:var(--imara-primary);letter-spacing:-.05em;margin:6px 0 10px;}
.metricCard small{color:#5B6880;font-size:16px;line-height:1.4;}
.panelHeader{gap:14px;align-items:flex-start;}
.panelHeader h3{letter-spacing:-.04em;}
.primaryBtn,.darkBtn{background:#0B63FF;color:#fff;border:0;border-radius:18px;display:inline-flex;align-items:center;justify-content:center;gap:10px;font-weight:900;text-decoration:none;padding:13px 18px;}
.darkBtn{background:var(--imara-primary);}
.lightBtn,.ghostBtn{background:#fff;border:1px solid var(--imara-border);color:var(--imara-primary);border-radius:18px;display:inline-flex;align-items:center;justify-content:center;gap:10px;font-weight:900;text-decoration:none;padding:12px 18px;}
.successNote,.softNote,.walletLockBanner,.dangerNote{border-radius:22px;line-height:1.5;}
.errorNote,.dangerNote,.alertError{background:#FFF1F1!important;border:1px solid #FFC9C9!important;color:var(--imara-danger)!important;}
.successNote,.alertSuccess{background:#ECFDF3!important;border:1px solid #B7F0CB!important;color:var(--imara-success)!important;}
.emptyState{border:1px dashed #BFD0E8;background:#F7FAFE;border-radius:24px;}

/* Auto-save module toggles */
.moduleAutosaveStatus{display:inline-flex;align-items:center;gap:8px;min-height:36px;border-radius:999px;padding:8px 12px;background:#F1F6FF;color:#39506F;font-weight:800;font-size:13px;}
.moduleAutosaveStatus.is-saving{background:#FFF7E3;color:#735600;}
.moduleAutosaveStatus.is-saved{background:#EAFBF0;color:#147A3A;}
.moduleAutosaveStatus.is-error{background:#FFF1F1;color:#991B1B;}
.moduleToggleCard{cursor:pointer;min-height:150px;}
.moduleToggleCard.lockedModule{opacity:.58;cursor:not-allowed;}
.toggleSwitch{min-width:70px;display:inline-flex;justify-content:flex-end;}
.toggleSwitch input{position:absolute;opacity:0;pointer-events:none;}
.toggleSwitch i{display:block;width:64px;height:40px;border-radius:999px;background:#D9E3F2;position:relative;transition:.2s ease;box-shadow:inset 0 0 0 1px rgba(2,15,42,.08);}
.toggleSwitch i:after{content:"";position:absolute;width:32px;height:32px;border-radius:50%;background:#fff;left:4px;top:4px;box-shadow:0 4px 12px rgba(2,15,42,.18);transition:.2s ease;}
.toggleSwitch input:checked+i{background:#0B63FF;}
.toggleSwitch input:checked+i:after{transform:translateX(24px);}

/* Wallet and petty cash separation */
.cashLedgerGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;}
.cashActionCard{background:#fff;border:1px solid var(--imara-border);border-radius:28px;padding:22px;box-shadow:0 12px 35px rgba(2,15,42,.045);}
.cashActionCard form{display:grid;gap:12px;}
.cashActionCard label{font-weight:900;color:var(--imara-primary);}
.cashActionCard input,.cashActionCard textarea,.cashActionCard select{width:100%;border:1px solid var(--imara-border);border-radius:16px;padding:14px 16px;background:#fff;color:var(--imara-primary);}
.cashTypePill{display:inline-flex;align-items:center;min-height:34px;border-radius:999px;padding:6px 12px;font-weight:900;font-size:13px;}
.cashTypePill.in{background:#ECFDF3;color:#147A3A;}
.cashTypePill.out{background:#FFF1F1;color:#991B1B;}

/* Mobile app shell fixes */
.mobileBottomNav{padding-bottom:calc(10px + var(--safe-bottom));}
.imaraFab{bottom:calc(96px + var(--safe-bottom));right:max(22px,env(safe-area-inset-right,0px) + 22px);}
.imaraFabBtn{width:72px;height:72px;border-radius:50%;}
.imaraFabBtn span:not(.imaraSvgIcon){position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);}
.imaraFabPanel{max-width:calc(100vw - 32px);}

/* Assurance dashboard/auth fixes */
.assuranceHeader,.assuranceMobileNav{max-width:100%;overflow:hidden;}
.assuranceLogout{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:10px 14px;border-radius:999px;border:1px solid var(--imara-border);text-decoration:none;color:var(--imara-primary);font-weight:900;background:#fff;}
.assuranceBottomNav{padding-bottom:calc(12px + var(--safe-bottom));}

@media (max-width:760px){
  body{background:#F4F7FB;}
  .dashMain{padding-left:clamp(14px,4vw,24px)!important;padding-right:clamp(14px,4vw,24px)!important;padding-bottom:calc(132px + var(--safe-bottom))!important;}
  .dashTopbar{padding:14px 0!important;gap:10px;}
  .dashTopbar h1{font-size:clamp(28px,7vw,42px);line-height:1.05;letter-spacing:-.05em;}
  .topActions{display:none!important;}
  .appHero,.moduleHero{border-radius:30px;padding:28px 22px;margin-bottom:18px;}
  .appHero,.moduleHero,.moduleLayout{display:grid!important;grid-template-columns:1fr!important;gap:18px!important;}
  .appHero h2,.moduleHero h2{max-width:100%;font-size:clamp(38px,10vw,58px);}
  .appHero p,.moduleHero p{font-size:clamp(18px,4.8vw,23px);}
  .moduleActions,.heroActions{display:grid!important;grid-template-columns:1fr!important;width:100%;gap:12px;}
  .primaryBtn,.darkBtn,.lightBtn,.ghostBtn,.authGoogleBtn{width:100%;min-height:56px;border-radius:18px;font-size:17px;}
  .modulePanel{border-radius:28px;padding:22px!important;}
  .panelHeader{display:grid!important;grid-template-columns:1fr!important;}
  .metricGrid{grid-template-columns:1fr!important;gap:14px;}
  .metricCard{border-radius:24px;padding:22px;}
  .metricCard strong{font-size:44px;}
  .moduleToggleGrid{grid-template-columns:1fr!important;gap:14px;}
  .moduleToggleCard{display:grid!important;grid-template-columns:1fr auto!important;align-items:center;padding:20px!important;border-radius:24px;gap:12px;}
  .moduleToggleCard h3{font-size:28px;line-height:1.05;margin:8px 0;}
  .moduleToggleCard p{font-size:16px;line-height:1.35;}
  .dataTable{min-width:0!important;}
  .tableWrap{overflow-x:auto;-webkit-overflow-scrolling:touch;}
  .settingsItem{display:grid!important;grid-template-columns:1fr!important;gap:12px;padding:18px!important;border-radius:22px;}
  .settingsItem .statusPill,.settingsItem a,.settingsItem button{justify-self:start;}
  .loginCardPremium,.registerCardPremium,.loginFormPanel{border-radius:30px!important;padding:24px!important;width:100%!important;max-width:100%!important;}
  .loginCardPremium h1,.registerCardPremium h1{font-size:clamp(42px,11vw,62px)!important;line-height:.98!important;letter-spacing:-.07em!important;}
  .premiumField>div,.inputWrap,.fieldWrap{min-height:58px!important;border-radius:18px!important;padding-left:16px!important;padding-right:10px!important;}
  .premiumField input,.inputWrap input,.fieldWrap input{font-size:16px!important;}
  .mobileBottomNav a{min-width:56px;min-height:64px;}
}

@media (max-width:380px){
  .dashMain{padding-left:12px!important;padding-right:12px!important;}
  .appHero h2,.moduleHero h2{font-size:36px;}
  .loginCardPremium h1,.registerCardPremium h1{font-size:40px!important;}
  .imaraFabBtn{width:64px;height:64px;}
  .imaraFab{right:16px;}
}

/* 2026-06-07 V6 dashboard sidebar stabilization
   Fixes: cramped desktop sidebar, wrapped helper cards, optional module list pushing cards, and icon/label clipping. */
@media (min-width: 861px){
  .dashShell{
    display:block!important;
    min-height:100vh!important;
    width:100%!important;
  }
  .dashSidebar{
    width:280px!important;
    min-width:280px!important;
    max-width:280px!important;
    height:100vh!important;
    height:100dvh!important;
    padding:24px 18px 18px!important;
    display:flex!important;
    flex-direction:column!important;
    gap:0!important;
    overflow:hidden!important;
  }
  .dashMain{
    margin-left:280px!important;
    width:calc(100% - 280px)!important;
    max-width:calc(100% - 280px)!important;
  }
  .sideBrand{
    flex:0 0 auto!important;
    margin-bottom:24px!important;
  }
  .sideLogoMark{
    width:100%!important;
    min-width:0!important;
    overflow:hidden!important;
  }
  .sideLogoMark img{
    height:30px!important;
    max-width:172px!important;
    width:auto!important;
    object-fit:contain!important;
  }
  .sideNav{
    flex:0 0 auto!important;
    width:100%!important;
    min-width:0!important;
  }
  .sideNav a{
    width:100%!important;
    min-width:0!important;
    min-height:46px!important;
    padding:0 14px!important;
    gap:12px!important;
    border-radius:11px!important;
    justify-content:flex-start!important;
    overflow:hidden!important;
  }
  .sideNav a .navLabel{
    display:block!important;
    min-width:0!important;
    max-width:100%!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
    white-space:nowrap!important;
    line-height:1.2!important;
  }
  .sideNav a .imaraSvgIcon,
  .sideNav a .material-symbols-outlined{
    flex:0 0 22px!important;
    width:22px!important;
    min-width:22px!important;
    height:22px!important;
  }
  .sideSectionTitle{
    flex:0 0 auto!important;
    margin:18px 10px 8px!important;
    white-space:nowrap!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
  }
  .sideNavMore{
    flex:1 1 auto!important;
    min-height:84px!important;
    max-height:none!important;
    margin-top:0!important;
    padding-top:10px!important;
    padding-right:4px!important;
    padding-bottom:6px!important;
    overflow-y:auto!important;
    overflow-x:hidden!important;
    border-top:1px solid rgba(148,163,184,.22)!important;
    scrollbar-width:thin;
  }
  .sideNavMore a{
    min-height:42px!important;
    font-size:13px!important;
  }
  .sideTrial,
  .sideHelp{
    flex:0 0 auto!important;
    width:100%!important;
    max-width:100%!important;
    margin-top:12px!important;
    padding:14px!important;
    overflow:hidden!important;
    border-radius:15px!important;
  }
  .sideTrial p,
  .sideHelp p{
    width:100%!important;
    max-width:100%!important;
    margin:0 0 7px!important;
    line-height:1.25!important;
    word-break:normal!important;
    overflow-wrap:normal!important;
    hyphens:none!important;
  }
  .sideTrial p{
    white-space:nowrap!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
  }
  .sideHelp p,
  .sideHelp p b,
  .sideTrial strong,
  .sideTrial span,
  .sideHelp span,
  .sideTrial a,
  .sideHelp a{
    word-break:normal!important;
    overflow-wrap:normal!important;
    hyphens:none!important;
  }
  .sideHelp p b,
  .sideTrial strong,
  .sideTrial a,
  .sideHelp a{
    white-space:nowrap!important;
  }
  .sideTrial span,
  .sideHelp span{
    display:block!important;
    line-height:1.45!important;
  }
}
@media (max-width: 860px){
  .dashSidebar{
    width:min(86vw,320px)!important;
    max-width:min(86vw,320px)!important;
    height:100vh!important;
    height:100dvh!important;
    overflow-y:auto!important;
  }
  .dashMain{
    margin-left:0!important;
    width:100%!important;
    max-width:100%!important;
  }
}
