/* PMO Client Portal – modern responsive UI */
.pmo-portal{position:relative;isolation:isolate;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.45}
.pmo-portal__bg{position:absolute;inset:0;z-index:-1;background:
 radial-gradient(900px 500px at 10% 10%, rgba(99,102,241,.18), transparent 60%),
 radial-gradient(900px 500px at 90% 20%, rgba(16,185,129,.14), transparent 55%),
 radial-gradient(900px 500px at 50% 100%, rgba(59,130,246,.12), transparent 55%),
 linear-gradient(180deg, rgba(15,23,42,.02), rgba(15,23,42,0));
}
.pmo-portal__container{max-width:1180px;margin:0 auto;padding:20px 16px 40px;min-width:0}
.pmo-portal__header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 14px;border-radius:20px;background:rgba(255,255,255,.72);backdrop-filter:blur(10px);border:1px solid rgba(15,23,42,.08);box-shadow:0 10px 30px rgba(2,6,23,.06)}
.pmo-portal__brand{display:flex;align-items:center;gap:12px;min-width:0}
.pmo-portal__logo{width:42px;height:42px;border-radius:14px;background:
 linear-gradient(135deg, rgba(99,102,241,1), rgba(59,130,246,1));
 box-shadow:0 10px 20px rgba(59,130,246,.25);
}
.pmo-portal__title{font-weight:750;font-size:18px;color:#0f172a}
.pmo-portal__subtitle{font-size:12px;color:rgba(15,23,42,.65);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:46vw}
.pmo-portal__user{display:flex;align-items:center;gap:12px}
.pmo-portal__user-meta{display:flex;flex-direction:column;align-items:flex-end}
.pmo-portal__user-name{font-weight:650;color:#0f172a;font-size:13px}
.pmo-portal__user-email{font-size:12px;color:rgba(15,23,42,.6);max-width:32vw;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Header: prevent overlap on small screens */
@media (max-width: 600px){
  .pmo-portal__header{flex-direction:column;align-items:stretch}
  .pmo-portal__subtitle{max-width:100%;white-space:normal}
  .pmo-portal__user{justify-content:space-between;flex-wrap:wrap;gap:10px}
  .pmo-portal__user-meta{align-items:flex-start;min-width:0}
  .pmo-portal__user-email{max-width:100%;white-space:normal;overflow:visible;text-overflow:clip;word-break:break-word}
}

.pmo-alert{margin:14px 0;padding:12px 14px;border-radius:14px;border:1px solid rgba(15,23,42,.10);background:rgba(255,255,255,.78);backdrop-filter:blur(10px)}
.pmo-alert--success{border-color:rgba(16,185,129,.35);box-shadow:0 8px 18px rgba(16,185,129,.10)}
.pmo-alert--error{border-color:rgba(239,68,68,.35);box-shadow:0 8px 18px rgba(239,68,68,.10)}

.pmo-tabs{display:flex;gap:8px;flex-wrap:wrap;margin:14px 0 10px}
.pmo-tabs__item{display:inline-flex;align-items:center;gap:8px;padding:10px 12px;border-radius:14px;text-decoration:none;
background:rgba(255,255,255,.64);border:1px solid rgba(15,23,42,.08);color:#0f172a;font-weight:650;font-size:13px}
.pmo-tabs__item:hover{transform:translateY(-1px);box-shadow:0 10px 18px rgba(2,6,23,.06)}
.pmo-tabs__item.is-active{background:linear-gradient(135deg, rgba(99,102,241,.18), rgba(59,130,246,.14));
border-color:rgba(99,102,241,.28)}

.pmo-portal__main{min-width:0}

.pmo-card{background:rgba(255,255,255,.78);backdrop-filter:blur(10px);border:1px solid rgba(15,23,42,.08);
border-radius:22px;box-shadow:0 16px 40px rgba(2,6,23,.06);padding:16px;min-width:0}
.pmo-card--wide{grid-column:1 / -1}
.pmo-card--center{max-width:520px;margin:18px auto}
.pmo-card--compact{padding:14px}
.pmo-card--sub{background:rgba(255,255,255,.86)}
.pmo-card__head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px}
.pmo-card__title{margin:0;font-size:18px;font-weight:800;color:#0f172a}
.pmo-card__desc{margin:8px 0 0;color:rgba(15,23,42,.65)}
.pmo-card__actions{display:flex;gap:10px;align-items:center}
.pmo-card__foot{margin-top:12px;display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}

.pmo-grid{display:grid;grid-template-columns:1.6fr .8fr;gap:14px;min-width:0}
@media (max-width: 980px){.pmo-grid{grid-template-columns:1fr}}
.pmo-list{margin:10px 0 0;padding-left:18px;color:rgba(15,23,42,.72)}
.pmo-muted{color:rgba(15,23,42,.65)}
.pmo-kicker{font-size:12px;font-weight:700;color:rgba(15,23,42,.55)}
.pmo-h3{font-size:16px;font-weight:800;color:#0f172a;margin-top:2px}
.pmo-right{text-align:right}

.pmo-badge{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:750;
background:rgba(15,23,42,.05);border:1px solid rgba(15,23,42,.08);color:#0f172a}
.pmo-badge--cancelled{background:rgba(239,68,68,.10);border-color:rgba(239,68,68,.25)}
.pmo-badge--confirmed{background:rgba(16,185,129,.12);border-color:rgba(16,185,129,.25)}
.pmo-badge--assigned,.pmo-badge--en_route,.pmo-badge--arrived,.pmo-badge--on_trip{background:rgba(59,130,246,.12);border-color:rgba(59,130,246,.25)}
.pmo-badge--pending{background:rgba(245,158,11,.12);border-color:rgba(245,158,11,.22)}

.pmo-btn{appearance:none;border:none;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;
gap:8px;padding:10px 14px;border-radius:14px;font-weight:800;font-size:13px;color:white;
background:linear-gradient(135deg, rgba(99,102,241,1), rgba(59,130,246,1));
box-shadow:0 14px 26px rgba(59,130,246,.18)}
.pmo-btn:hover{transform:translateY(-1px);box-shadow:0 18px 32px rgba(59,130,246,.22)}
.pmo-btn--ghost{background:rgba(255,255,255,.65);color:#0f172a;border:1px solid rgba(15,23,42,.10);box-shadow:none}
.pmo-btn--ghost:hover{background:rgba(255,255,255,.82);box-shadow:0 14px 24px rgba(2,6,23,.06)}
.pmo-btn--danger{background:linear-gradient(135deg, rgba(239,68,68,1), rgba(244,63,94,1))}
.pmo-btn--sm{padding:8px 10px;border-radius:12px;font-size:12px}
.pmo-btn--block{width:100%}

.pmo-link{color:rgba(59,130,246,1);text-decoration:none;font-weight:700}
.pmo-link:hover{text-decoration:underline}

.pmo-tablewrap{overflow:auto;border-radius:16px;border:1px solid rgba(15,23,42,.08);background:rgba(255,255,255,.7)}
.pmo-table{width:100%;border-collapse:collapse;min-width:720px}
.pmo-table th,.pmo-table td{padding:12px 12px;border-bottom:1px solid rgba(15,23,42,.07);text-align:left;font-size:13px;color:#0f172a}
.pmo-table th{font-size:12px;letter-spacing:.02em;color:rgba(15,23,42,.65);text-transform:uppercase}
.pmo-table tr:hover td{background:rgba(2,6,23,.02)}

.pmo-cards{display:none;gap:12px;margin-top:12px}
/* Dashboard uses cards at all sizes (bookings tab switches table/cards via media queries). */
.pmo-cards--always{display:grid}
@media (max-width: 900px){
  .pmo-tablewrap{display:none}
  .pmo-cards{display:grid}
  .pmo-portal__subtitle{max-width:62vw}

  /* Mobile: tabs & filter pills should never overflow the screen */
  .pmo-tabs{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:6px}
  .pmo-tabs::-webkit-scrollbar{display:none}
  .pmo-tabs__item{flex:0 0 auto;white-space:nowrap}
  .pmo-pillbar{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:6px}
  .pmo-pillbar::-webkit-scrollbar{display:none}
  .pmo-pill{flex:0 0 auto;white-space:nowrap}
}

/* Invoice cards (mobile) */
.pmo-invoicecards{display:none;gap:12px;margin-top:12px}
@media (max-width: 900px){
  .pmo-invoicecards{display:grid}
}
.pmo-invoicecard{border:1px solid rgba(15,23,42,.08);background:rgba(255,255,255,.78);border-radius:18px;padding:14px;box-shadow:0 10px 24px rgba(2,6,23,.05)}
.pmo-invoicecard__top{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.pmo-invoicecard__id{font-weight:850;color:#0f172a}
.pmo-invoicecard__pickup{margin-top:8px;color:rgba(15,23,42,.75);font-weight:650}
.pmo-invoicecard__meta{margin-top:10px;display:flex;justify-content:space-between;gap:12px;align-items:center}

.pmo-split{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.pmo-divider{height:1px;background:rgba(15,23,42,.08);margin:14px 0}

.pmo-detailgrid{display:grid;grid-template-columns:repeat(2, minmax(0,1fr));gap:12px;margin-top:10px}
@media (max-width: 700px){.pmo-detailgrid{grid-template-columns:1fr}}
.pmo-kv{border:1px solid rgba(15,23,42,.08);background:rgba(255,255,255,.75);border-radius:16px;padding:12px;min-width:0}
.pmo-kv__k{font-size:12px;font-weight:800;color:rgba(15,23,42,.55);text-transform:uppercase;letter-spacing:.02em}
.pmo-kv__v{margin-top:6px;font-size:13px;color:#0f172a;white-space:pre-wrap;word-break:break-word}
pre.pmo-kv__v{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;background:rgba(2,6,23,.03);padding:10px;border-radius:12px;overflow:auto}

.pmo-actions{display:grid;grid-template-columns:repeat(2, minmax(0,1fr));gap:12px}
@media (max-width: 900px){.pmo-actions{grid-template-columns:1fr}}

.pmo-codes{display:grid;gap:10px;margin-top:10px}
.pmo-code{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;padding:12px 14px;border-radius:16px;border:1px solid rgba(15,23,42,.08);background:rgba(255,255,255,.75)}

.pmo-form{display:grid;gap:10px;margin-top:10px}
.pmo-field{display:grid;gap:6px}
.pmo-field__label{font-size:12px;font-weight:800;color:rgba(15,23,42,.55);text-transform:uppercase;letter-spacing:.02em}
.pmo-field__input{width:100%;border-radius:14px;border:1px solid rgba(15,23,42,.10);padding:10px 12px;background:rgba(255,255,255,.9);font-size:13px;outline:none}
.pmo-field__input:focus{border-color:rgba(99,102,241,.45);box-shadow:0 0 0 4px rgba(99,102,241,.15)}
.pmo-hint{margin-top:8px;font-size:12px;color:rgba(15,23,42,.6)}

/* Support form + generic form controls inside portal */
.pmo-grid2{display:grid;grid-template-columns:repeat(2, minmax(0,1fr));gap:12px}
@media (max-width: 700px){.pmo-grid2{grid-template-columns:1fr}}
.pmo-form input[type="text"],
.pmo-form input[type="email"],
.pmo-form input[type="tel"],
.pmo-form select,
.pmo-form textarea{
  width:100%;
  max-width:100%;
  box-sizing:border-box;
  border-radius:14px;
  border:1px solid rgba(15,23,42,.10);
  padding:10px 12px;
  background:rgba(255,255,255,.9);
  font-size:13px;
  outline:none;
}
.pmo-form textarea{resize:vertical}
.pmo-form select{appearance:auto}
@media (max-width: 700px){
  .pmo-form .pmo-btn{width:100%}
}

.pmo-empty{display:flex;gap:12px;align-items:center;padding:14px;border-radius:18px;border:1px dashed rgba(15,23,42,.18);background:rgba(2,6,23,.02);margin-top:12px}
.pmo-empty__icon{width:36px;height:36px;border-radius:14px;background:linear-gradient(135deg, rgba(16,185,129,1), rgba(59,130,246,1));opacity:.9}

.pmo-trackcard{margin-top:12px;padding:14px;border-radius:18px;border:1px solid rgba(15,23,42,.08);background:rgba(255,255,255,.75)}
.pmo-trackmeta{margin-top:10px;font-size:13px;color:#0f172a}
.pmo-label{display:inline-flex;min-width:72px;font-size:12px;font-weight:800;color:rgba(15,23,42,.55);text-transform:uppercase;letter-spacing:.02em}
.pmo-trackactions{margin-top:12px;display:flex;gap:10px;flex-wrap:wrap}

/* WP login form polish inside portal */
#pmo-portal-loginform p{margin:10px 0}
#pmo-portal-loginform label{font-weight:700;color:rgba(15,23,42,.75)}
#pmo-portal-loginform input[type="text"],
#pmo-portal-loginform input[type="password"]{width:100%;max-width:360px;border-radius:14px;border:1px solid rgba(15,23,42,.10);padding:10px 12px}
#pmo-portal-loginform input[type="submit"]{margin-top:10px}



/* --- Portal login form alignment (wp_login_form output) --- */
#pmo-portal-loginform p { margin: 0 0 14px 0; }
#pmo-portal-loginform label { display:block; font-weight:600; margin: 0 0 6px 0; }
#pmo-portal-loginform input[type="text"],
#pmo-portal-loginform input[type="password"]{
  width:100%;
  box-sizing:border-box;
  display:block;
}
#pmo-portal-loginform p.login-remember label{ display:flex; align-items:center; gap:8px; font-weight:600; margin:0; }
#pmo-portal-loginform p.login-remember input{ width:auto; }
#pmo-portal-loginform p.login-submit { margin-top: 16px; }
#pmo-portal-loginform input[type="submit"]{ width:auto; }

/* Notice board */
.pmo-noticeboard{padding:14px 16px;border-radius:18px;border:1px solid rgba(15,23,42,.08);background:rgba(255,255,255,.72);color:#0f172a;font-size:14px;line-height:1.5}
.pmo-noticeboard p{margin:0 0 10px 0}
.pmo-noticeboard p:last-child{margin-bottom:0}


/* Booking list filter pills */
.pmo-pill{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:999px;border:1px solid rgba(15,23,42,.12);background:rgba(255,255,255,.7);color:#0f172a;text-decoration:none;font-weight:600;font-size:13px;line-height:1;}
.pmo-pill:hover{background:#fff;}
.pmo-pill.is-active{background:#0f172a;color:#fff;border-color:#0f172a;}

/* Loyalty redeem spacing */
.pmo-actions--redeem{display:flex;flex-direction:column;gap:10px;margin-top:10px;}
.pmo-inlineform{margin:0;}


/* Portal logout button as form submit */
.pmo-logoutform{margin:0}
.pmo-logoutform .pmo-btn{margin:0}

/* Prevent portal component styles from distorting booking strip / fixed-route modal */
.pmo-prefill--calculator .acb,
.pmo-prefill--calculator .acb *{box-sizing:border-box}
.pmo-prefill--calculator .acbFrModal,
.pmo-prefill--calculator .acb-modal-overlay{font-family:inherit}
.pmo-prefill--calculator .acbFrDialog,
.pmo-prefill--calculator .acb-modal{max-width:min(960px,92vw)}
.pmo-prefill--calculator .acbFrList label{display:flex;align-items:center;gap:12px;width:100%}
.pmo-prefill--calculator .acbFrList input[type="radio"]{width:auto;min-width:16px;flex:0 0 auto;margin:0}
.pmo-prefill--calculator .acbFrItem{align-items:flex-start}
.pmo-prefill--calculator .acbFrActions{display:flex;justify-content:flex-end;gap:12px;flex-wrap:wrap}


.pmo-portal__user-account{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.pmo-portal__user-company{font-weight:650;color:#0f172a;word-break:break-word}
@media (max-width: 900px){
  .pmo-portal__header{flex-direction:column;align-items:stretch}
  .pmo-portal__brand{width:100%}
  .pmo-portal__user{width:100%;justify-content:space-between;align-items:flex-start;flex-wrap:wrap}
  .pmo-portal__user-meta{display:flex;align-items:flex-start;min-width:0;flex:1 1 220px}
  .pmo-portal__user-name{font-size:14px}
  .pmo-portal__user-email{display:block;max-width:100%;white-space:normal;overflow:visible;text-overflow:clip;word-break:break-word}
  .pmo-portal__user-account{justify-content:flex-start}
  .pmo-logoutform{align-self:flex-start}
}
@media (max-width: 520px){
  .pmo-portal__container{padding-left:12px;padding-right:12px}
  .pmo-portal__title{font-size:17px}
}

.pmo-portal__header-actions{display:flex;flex-direction:column;gap:8px;align-items:flex-end}
.pmo-install-app__hint{font-size:12px;color:rgba(15,23,42,.65);max-width:220px;text-align:right}
.pmo-portal__splash{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#f5f6fb,#eaf4f2);z-index:99999;transition:opacity .35s ease,visibility .35s ease}
.pmo-portal__splash.is-hidden{opacity:0;visibility:hidden}
.pmo-portal__splash-card{display:flex;flex-direction:column;align-items:center;gap:14px;padding:28px 34px;border-radius:24px;background:rgba(255,255,255,.88);box-shadow:0 16px 40px rgba(2,6,23,.08);border:1px solid rgba(15,23,42,.08)}
.pmo-portal__splash-title{font-weight:750;color:#0f172a;font-size:18px}
body.acb-portal-app-mode .pmo-portal__container{max-width:none;padding:0 0 24px}
body.acb-portal-app-mode .pmo-portal__header{border-radius:0;padding:16px 18px}
body.acb-portal-app-mode .pmo-tabs{padding:0 16px}
body.acb-portal-app-mode .pmo-alert,body.acb-portal-app-mode .pmo-portal__main{margin-left:16px;margin-right:16px}
@media (max-width: 700px){
  .pmo-portal__header-actions{align-items:stretch}
  .pmo-install-app__hint{max-width:none;text-align:left}
}


.pmo-portal__header-actions{display:flex;flex-direction:column;align-items:flex-end;gap:8px}
.pmo-install-app__hint{font-size:12px;line-height:1.4;color:rgba(15,23,42,.68);max-width:260px;text-align:right}
@media (max-width: 600px){
  .pmo-portal__header-actions{align-items:stretch}
  .pmo-install-app__hint{max-width:none;text-align:left}
}

/* PWA app-mode overrides */
@media all and (display-mode: standalone) {
  html, body { width: 100%; overflow-x: hidden; }
  body {
    background: #f5f6fb !important;
  }
  .site, .site-content, .content-area, article, .entry-content {
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
    max-width: none !important;
  }
  .pmo-portal__container {
    max-width: 640px !important;
    margin: 0 auto !important;
    padding: 12px 12px 24px !important;
  }
  .pmo-portal__header {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 10px !important;
    border-radius: 18px !important;
    padding: 12px !important;
  }
  .pmo-portal__brand {
    width: 100%;
  }
  .pmo-portal__subtitle {
    max-width: 100% !important;
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: clip !important;
  }
  .pmo-portal__header-actions {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }
  .pmo-install-app,
  .pmo-install-app__hint {
    width: 100%;
  }
  .pmo-portal__user {
    width: 100%;
    justify-content: space-between !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
  }
  .pmo-portal__user-meta {
    align-items: flex-start !important;
    min-width: 0;
    flex: 1 1 auto;
  }
  .pmo-portal__user-email {
    max-width: 100% !important;
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: clip !important;
    word-break: break-word !important;
  }
  .pmo-tabs {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px !important;
    width: 100%;
  }
  .pmo-tabs__item {
    justify-content: center !important;
    width: 100%;
    min-height: 42px;
  }
  .pmo-card, .pmo-panel, .pmo-tablewrap, .pmo-alert {
    border-radius: 16px !important;
  }
  .pmo-tablewrap {
    overflow-x: auto !important;
  }
  .pmo-portal__splash-card {
    width: min(92vw, 360px);
    padding: 22px 18px;
    border-radius: 22px;
  }
  .pmo-portal__splash-title {
    font-size: 22px;
    line-height: 1.2;
  }
}


/* PWA should follow the normal mobile web layout closely */
body.acb-portal-app-mode .pmo-portal__container{
  max-width:1180px!important;
}
body.acb-portal-app-mode .pmo-tabs{
  display:flex!important;
  flex-wrap:nowrap!important;
  overflow-x:auto!important;
  -webkit-overflow-scrolling:touch;
  gap:8px!important;
  padding-bottom:4px;
}
body.acb-portal-app-mode .pmo-tabs__item{
  flex:0 0 auto!important;
  white-space:nowrap!important;
}
body.acb-portal-app-mode .pmo-portal__header{
  display:flex!important;
}
body.acb-portal-app-mode .pmo-portal__user,
body.acb-portal-app-mode .pmo-portal__user-meta,
body.acb-portal-app-mode .pmo-portal__header-actions{
  display:flex!important;
}
body.acb-portal-app-mode .pmo-install-app{
  display:inline-flex!important;
}
@media (max-width: 600px){
  body.acb-portal-app-mode .pmo-portal__container{
    padding:20px 16px 40px!important;
  }
  body.acb-portal-app-mode .pmo-portal__header{
    flex-direction:column!important;
    align-items:stretch!important;
  }
  body.acb-portal-app-mode .pmo-portal__subtitle{
    max-width:100%!important;
    white-space:normal!important;
    overflow:visible!important;
    text-overflow:clip!important;
  }
  body.acb-portal-app-mode .pmo-portal__user{
    justify-content:space-between!important;
    flex-wrap:wrap!important;
    gap:10px!important;
  }
  body.acb-portal-app-mode .pmo-portal__user-meta{
    align-items:flex-start!important;
    min-width:0;
  }
  body.acb-portal-app-mode .pmo-portal__user-email{
    max-width:100%!important;
    white-space:normal!important;
    overflow:visible!important;
    text-overflow:clip!important;
    word-break:break-word!important;
  }
}


/* === v26 PWA app shell: follow the existing mobile web view exactly === */
@media all and (display-mode: standalone) {
  html, body { width:100%; overflow-x:hidden; }
  body.acb-portal-page,
  body.acb-portal-app-mode { background:#f5f6fb !important; }

  /* hide only theme/site chrome, keep the portal chrome */
  #wpadminbar,
  header.site-header,
  footer.site-footer,
  #masthead,
  #colophon,
  .site-header,
  .site-footer,
  .main-header-bar,
  .ast-primary-header-bar,
  .ast-above-header-wrap,
  .ast-below-header-wrap,
  .entry-header,
  .page-header,
  .main-navigation,
  #ast-mobile-header,
  .ast-desktop-header-content,
  .ast-mobile-header-wrap {
    display:none !important;
  }

  .site, .site-content, .content-area, article, .entry-content {
    margin:0 !important;
    padding:0 !important;
    width:100% !important;
    max-width:none !important;
  }

  /* keep the same portal layout as the mobile website */
  body.acb-portal-app-mode .pmo-portal__container,
  .acb-portal-standalone .pmo-portal__container,
  .pmo-portal__container {
    max-width:1180px !important;
    margin:0 auto !important;
    padding:20px 16px 40px !important;
  }

  body.acb-portal-app-mode .pmo-portal__header,
  .acb-portal-standalone .pmo-portal__header {
    display:flex !important;
    flex-direction:column !important;
    align-items:stretch !important;
    gap:10px !important;
    border-radius:20px !important;
    padding:14px !important;
  }

  body.acb-portal-app-mode .pmo-portal__brand,
  body.acb-portal-app-mode .pmo-portal__user,
  body.acb-portal-app-mode .pmo-portal__user-meta,
  body.acb-portal-app-mode .pmo-portal__header-actions {
    display:flex !important;
  }

  body.acb-portal-app-mode .pmo-portal__user {
    justify-content:space-between !important;
    flex-wrap:wrap !important;
    gap:10px !important;
    width:100% !important;
  }

  body.acb-portal-app-mode .pmo-portal__user-meta {
    align-items:flex-start !important;
    min-width:0 !important;
    flex:1 1 auto !important;
  }

  body.acb-portal-app-mode .pmo-portal__user-email,
  .acb-portal-standalone .pmo-portal__user-email {
    max-width:100% !important;
    white-space:normal !important;
    overflow:visible !important;
    text-overflow:clip !important;
    word-break:break-word !important;
  }

  body.acb-portal-app-mode .pmo-portal__subtitle,
  .acb-portal-standalone .pmo-portal__subtitle {
    max-width:100% !important;
    white-space:normal !important;
    overflow:visible !important;
    text-overflow:clip !important;
  }

  /* exact mobile-style sliding tabs */
  body.acb-portal-app-mode .pmo-tabs,
  .acb-portal-standalone .pmo-tabs {
    display:flex !important;
    flex-wrap:nowrap !important;
    overflow-x:auto !important;
    -webkit-overflow-scrolling:touch !important;
    scrollbar-width:none !important;
    gap:8px !important;
    margin:14px 0 10px !important;
    padding:0 0 6px !important;
    width:auto !important;
  }
  body.acb-portal-app-mode .pmo-tabs::-webkit-scrollbar,
  .acb-portal-standalone .pmo-tabs::-webkit-scrollbar {
    display:none !important;
  }

  body.acb-portal-app-mode .pmo-tabs__item,
  .acb-portal-standalone .pmo-tabs__item {
    flex:0 0 auto !important;
    width:auto !important;
    min-width:max-content !important;
    max-width:none !important;
    justify-content:center !important;
    white-space:nowrap !important;
  }

  /* allow cards/buttons to breathe on small screens */
  body.acb-portal-app-mode .pmo-grid,
  .acb-portal-standalone .pmo-grid,
  body.acb-portal-app-mode .pmo-actions,
  .acb-portal-standalone .pmo-actions {
    grid-template-columns:1fr !important;
  }

  body.acb-portal-app-mode .pmo-card,
  body.acb-portal-app-mode .pmo-alert,
  body.acb-portal-app-mode .pmo-tablewrap,
  .acb-portal-standalone .pmo-card,
  .acb-portal-standalone .pmo-alert,
  .acb-portal-standalone .pmo-tablewrap {
    border-radius:18px !important;
    padding:14px !important;
  }

  body.acb-portal-app-mode .pmo-card__head,
  body.acb-portal-app-mode .pmo-card__actions,
  body.acb-portal-app-mode .pmo-card__foot,
  .acb-portal-standalone .pmo-card__head,
  .acb-portal-standalone .pmo-card__actions,
  .acb-portal-standalone .pmo-card__foot {
    flex-wrap:wrap !important;
  }

  body.acb-portal-app-mode .pmo-btn,
  .acb-portal-standalone .pmo-btn {
    max-width:100% !important;
  }

  body.acb-portal-app-mode .pmo-install-app {
    display:inline-flex !important;
  }

  /* mobile invoice cards/table switching */
  body.acb-portal-app-mode .pmo-tablewrap,
  .acb-portal-standalone .pmo-tablewrap {
    display:none !important;
  }
  body.acb-portal-app-mode .pmo-cards,
  body.acb-portal-app-mode .pmo-invoicecards,
  .acb-portal-standalone .pmo-cards,
  .acb-portal-standalone .pmo-invoicecards {
    display:grid !important;
  }

  /* professional splash */
  #acb-pwa-splash,
  .pmo-portal__splash {
    inset:0 !important;
    position:fixed !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    padding:24px !important;
    background:linear-gradient(180deg,#f8f9ff 0%,#eef2ff 100%) !important;
  }
  .pmo-portal__splash-card {
    width:min(92vw, 360px) !important;
    padding:22px 20px !important;
    border-radius:24px !important;
    text-align:center !important;
  }
  .pmo-portal__splash-title {
    font-size:20px !important;
    line-height:1.25 !important;
    word-break:break-word !important;
  }
}


/* Better splash layout for PWA */
.pmo-portal__splash{
  padding:24px;
}
.pmo-portal__splash-card{
  width:min(92vw, 420px);
  max-width:92vw;
  text-align:center;
  padding:28px 24px;
  border-radius:22px;
  box-sizing:border-box;
}
.pmo-portal__splash-title{
  font-size:clamp(20px, 5vw, 28px);
  line-height:1.2;
  max-width:100%;
  word-break:break-word;
  overflow-wrap:anywhere;
}
.pmo-portal__splash-subtitle{
  font-size:14px;
  color:rgba(15,23,42,.70);
  line-height:1.4;
}
body.acb-portal-app-mode .pmo-portal__splash-card{
  width:min(88vw, 420px);
}


.pmo-portal__header-actions{display:flex;flex-direction:column;gap:8px;align-items:flex-end}
.pmo-notification-status{font-size:13px;color:#0f172a;font-weight:600}
@media (max-width:700px){.pmo-portal__header-actions{align-items:flex-start}}

body.acb-portal-app-mode .pmo-install-app{display:none !important;}
body.acb-portal-app-mode .pmo-enable-notifications{display:inline-flex;}


.pmo-form input[type="password"],
.pmo-form input.input[type="password"],
.pmo-form input.input[type="email"],
.pmo-form input[type="text"],
.pmo-form input.input{
  width:100%;
  max-width:100%;
  box-sizing:border-box;
  border-radius:14px;
  border:1px solid rgba(15,23,42,.10);
  padding:10px 12px;
  background:rgba(255,255,255,.9);
  font-size:13px;
  outline:none;
}
.pmo-form .button.button-primary,
.pmo-form button[type="submit"]{
  appearance:none;
  border:none;
  cursor:pointer;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:10px 14px;
  border-radius:14px;
  font-weight:800;
  font-size:13px;
  color:white;
  background:linear-gradient(135deg, rgba(99,102,241,1), rgba(59,130,246,1));
  box-shadow:0 14px 26px rgba(59,130,246,.18);
}
