/* Safe area insets for Capacitor (notched devices) */
.tp-portal {
  padding-top: env(safe-area-inset-top);
  padding-bottom: env(safe-area-inset-bottom);
}

/* Receipt lightbox */
.tp-receipt-lightbox {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 999999;
  padding: 18px;
  padding-top: max(18px, env(safe-area-inset-top));
  padding-bottom: max(18px, env(safe-area-inset-bottom));
}
.tp-receipt-lightbox.is-open {
  display: flex;
}
.tp-receipt-lightbox-inner {
  background: #fff;
  border-radius: 14px;
  max-width: min(780px, 92vw);
  max-height: 88vh;
  overflow: hidden;
  position: relative;
  box-shadow: 0 18px 60px rgba(0, 0, 0, 0.35);
}
.tp-receipt-lightbox-close {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 38px;
  height: 38px;
  border-radius: 10px;
  border: 1px solid rgba(0, 0, 0, 0.12);
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
}
.tp-receipt-lightbox-close:hover {
  background: #f5f5f5;
}
.tp-receipt-lightbox-img {
  display: block;
  max-width: 100%;
  max-height: 88vh;
  height: auto;
  width: auto;
}
.tp-receipt-trigger {
  cursor: zoom-in;
}

/* Card Layout */
.tp-portal .tp-card {
  background: #fff;
  border: 1px solid #e5e5e5;
  border-radius: 8px;
  margin-bottom: 12px;
  overflow: hidden;
  text-align: left;
}

.tp-portal .tp-card-header {
  padding: 14px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  user-select: none;
  background: #f9f9f9;
  border-bottom: 1px solid #e5e5e5;
}

.tp-portal .tp-card-header:hover {
  background: #f5f5f5;
}

.tp-portal .tp-card-header-info {
  flex: 1;
  display: flex;
  gap: 16px;
  align-items: center;
  flex-wrap: wrap;
  row-gap: 8px;
}

.tp-portal .tp-card-header-value {
  font-weight: 600;
  color: #1f2f46;
}

.tp-portal .tp-card-header-label {
  font-size: 12px;
  color: #666;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.tp-portal .tp-card-header-item {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}

.tp-portal .tp-card-header-toggle {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #999;
  font-size: 16px;
  flex-shrink: 0;
}

.tp-portal .tp-card-expanded .tp-card-header-toggle {
  transform: rotate(180deg);
}

.tp-portal .tp-card-body {
  display: none;
  border-top: 1px solid #e5e5e5;
}

.tp-portal .tp-card-expanded .tp-card-body {
  display: block;
}

.tp-portal .tp-card-row {
  display: flex;
  justify-content: space-between;
  padding: 12px 14px;
  border-bottom: 1px solid #f1f1f1;
  font-size: 14px;
  gap: 12px;
}

.tp-portal .tp-card-row:last-child {
  border-bottom: none;
}

.tp-portal .tp-card-row-label {
  color: #666;
  font-weight: 500;
}

.tp-portal .tp-card-row-value {
  font-weight: 600;
  text-align: right;
  max-width: 70%;
  word-break: break-word;
}

.tp-portal .tp-card-actions {
  display: flex;
  gap: 8px;
  padding: 12px 14px;
  border-top: 1px solid #f1f1f1;
}

.tp-portal .tp-card-actions form,
.tp-portal .tp-card-actions a {
  flex: 1;
}

.tp-portal .tp-card-actions button {
  width: 100%;
  padding: 8px 12px;
  font-size: 12px;
}

/* Datepicker navigation fixes */
.ui-datepicker-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.ui-datepicker-prev,
.ui-datepicker-next {
  min-width: 90px;
  padding: 8px 10px;
  font-size: 14px;
  text-align: center;
  box-sizing: border-box;
  min-height: 40px;
}

.ui-datepicker-title {
  flex: 1;
  text-align: center;
}

.ui-datepicker select.ui-datepicker-month,
.ui-datepicker select.ui-datepicker-year {
  margin: 0 4px;
  font-size: 14px;
}

/* Global input and button minimum touch targets */
.tp-portal input[type="text"],
.tp-portal input[type="email"],
.tp-portal input[type="password"],
.tp-portal input[type="number"],
.tp-portal input[type="date"],
.tp-portal select,
.tp-portal textarea {
  font-size: 16px !important;
  min-height: 44px !important;
  padding: 10px 12px !important;
  box-sizing: border-box !important;
}

.tp-portal input[type="checkbox"],
.tp-portal input[type="radio"] {
  min-width: 20px !important;
  min-height: 20px !important;
  cursor: pointer !important;
  accent-color: #0b57d0 !important;
}

/* Desktop form label/readability safeguards */
.tp-portal label,
.tp-portal .tp-form label,
.tp-portal .tp-takings-form label,
.tp-portal .tp-expenses-form label,
.tp-portal .tp-date-filter-form label {
  color: #1f2f46 !important;
}

/* Admin drivers actions row layout */
.tp-admin-table td.tp-actions,
.tp-admin-table td.actions,
.tp-admin-table .tp-actions {
  white-space: nowrap;
}
.tp-admin-table .tp-actions {
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: nowrap;
}
.tp-admin-table .tp-actions .tp-btn-export {
  margin-left: auto;
}

/* Admin panel: keep driver action buttons in one row and push Export CSV to the far right */
.tp-driver-actions {
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: nowrap;
  white-space: nowrap;
}
.tp-driver-actions .tp-quick-link,
.tp-driver-actions .tp-modal-btn {
  display: inline-flex !important;
  align-items: center !important;
  width: 95px !important;
  height: 32px !important;
  padding: 6px 8px !important;
  font-size: 11px !important;
  justify-content: center !important;
  white-space: nowrap !important;
  flex-shrink: 0 !important;
}
.tp-driver-actions .tp-export-btn {
  margin-left: auto;
}
.tp-admin-table td.actions {
  white-space: nowrap;
}

@media (max-width: 768px) {
  .tp-portal .tp-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    width: 100%;
  }

  .tp-portal .tp-admin-drivers-table {
    display: table !important;
    width: auto !important;
    min-width: 520px;
  }

  .tp-portal .tp-admin-drivers-table th,
  .tp-portal .tp-admin-drivers-table td {
    padding: 8px 6px !important;
    font-size: 12px;
  }

  .tp-portal .tp-driver-actions {
    flex-wrap: wrap !important;
    gap: 6px !important;
    white-space: normal !important;
  }

  .tp-portal .tp-driver-actions .tp-quick-link,
  .tp-portal .tp-driver-actions .tp-modal-btn {
    width: auto !important;
    min-width: 72px !important;
    height: auto !important;
    padding: 6px 8px !important;
    font-size: 11px !important;
  }
}

/* === TaxiPortal Global Hover Effects (TPA_HOVER_V1) === */
.tp-btn,
a.tp-btn,
button,
input[type="submit"],
input[type="button"],
input[type="reset"],
a.button,
.button,
.wp-element-button,
.wp-block-button__link,
.ast-button,
.ast-custom-button,
.ast-button-wrap a,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button {
  transition:
    transform 0.15s ease,
    filter 0.15s ease,
    box-shadow 0.15s ease,
    opacity 0.15s ease !important;
}

.tp-btn:hover,
a.tp-btn:hover,
button:hover,
input[type="submit"]:hover,
input[type="button"]:hover,
input[type="reset"]:hover,
a.button:hover,
.button:hover,
.wp-element-button:hover,
.wp-block-button__link:hover,
.ast-button:hover,
.ast-custom-button:hover,
.ast-button-wrap a:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover {
  transform: translateY(-1px) !important;
  filter: brightness(1.06) !important;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.18) !important;
}

/* TaxiPortal: stronger hover effect (incl. Admin Panel buttons) */
.tp-admin-panel a,
.tp-admin-panel button,
.tp-admin-panel .tp-btn,
.tp-admin-panel .tp-tab,
.tp-admin-panel .tp-tab-link,
.tp-admin-panel .tp-admin-tabs button,
.tp-admin-panel .tp-admin-tabs a,
.tp-admin-panel .tp-admin-table a,
.tp-admin-panel .tp-admin-table button,
.tp-btn,
a.tp-btn,
button,
input[type="submit"],
input[type="button"],
a.button,
.wp-block-button__link {
  transition:
    transform 0.12s ease,
    filter 0.12s ease,
    box-shadow 0.12s ease,
    outline-color 0.12s ease;
}

.tp-admin-panel a:hover,
.tp-admin-panel button:hover,
.tp-admin-panel .tp-btn:hover,
.tp-admin-panel .tp-tab:hover,
.tp-admin-panel .tp-tab-link:hover,
.tp-admin-panel .tp-admin-tabs button:hover,
.tp-admin-panel .tp-admin-tabs a:hover,
.tp-admin-panel .tp-admin-table a:hover,
.tp-admin-panel .tp-admin-table button:hover,
.tp-btn:hover,
a.tp-btn:hover,
button:hover,
input[type="submit"]:hover,
input[type="button"]:hover,
a.button:hover,
.wp-block-button__link:hover {
  transform: translateY(-1px) !important;
  filter: brightness(1.18) contrast(1.04) !important;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.22) !important;
  outline: 2px solid rgba(0, 0, 0, 0.35) !important;
  outline-offset: 2px !important;
}

/* Match primary action buttons to header colour */
.tp-btn-primary,
.tp-btn.active,
button.tp-primary,
button.is-active,
.dashboard .quick-ranges button.active,
.dashboard button.apply,
button.apply,
a.apply,
input.apply {
  background-color: #1f2f46 !important;
  border-color: #1f2f46 !important;
  color: #ffffff !important;
}

.tp-btn-primary:hover,
.tp-btn.active:hover,
button.tp-primary:hover,
button.is-active:hover,
.dashboard .quick-ranges button.active:hover,
.dashboard button.apply:hover {
  background-color: #253a57 !important;
  border-color: #253a57 !important;
}

/* Global portal field shadows */
.tp-portal .tp-form > div {
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12) !important;
  border-radius: 8px;
  padding: 8px;
}
.tp-portal .tp-form input,
.tp-portal .tp-form select,
.tp-portal .tp-form textarea {
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.16) !important;
  background-clip: padding-box;
}

/* Portal forms - Base styling */
.tp-form.tp-takings-form {
  padding: 14px 16px;
  border: 1px solid #e6e6e6;
  border-radius: 10px;
  background: #fbfbfb;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.05);
}
.tp-form.tp-takings-form label {
  font-weight: 600;
  font-size: 12.5px;
  color: #24324a;
}
.tp-form.tp-takings-form input,
.tp-form.tp-takings-form select,
.tp-form.tp-takings-form textarea {
  border-radius: 6px;
  border: 1px solid #d9d9d9;
  padding: 7px 9px;
}
.tp-form.tp-takings-form textarea {
  resize: vertical;
}
.tp-form.tp-takings-form button[type="submit"] {
  border-radius: 7px;
}
@media (max-width: 980px) {
  .tp-form.tp-takings-form {
    grid-template-columns: 1fr 1fr !important;
  }
}

@media (max-width: 640px) {
  .tp-form.tp-takings-form {
    grid-template-columns: 1fr !important;
  }
}

/* Mobile layout fixes: header + button stacks */
@media (max-width: 768px) {
  /* Astra header tweaks to avoid cramped mobile layout */
  .ast-header-break-point #masthead .main-header-bar {
    padding-left: 12px;
    padding-right: 12px;
  }
  .ast-header-break-point #masthead .site-branding,
  .ast-header-break-point #masthead .main-header-bar .site-title,
  .ast-header-break-point #masthead .main-header-bar .site-description {
    text-align: center;
    width: 100%;
    justify-content: center;
  }
  .ast-header-break-point #masthead .main-header-menu {
    text-align: center;
  }

  /* Stabilize mobile nav panel and toggle button */
  .ast-header-break-point .main-header-bar-navigation,
  .ast-header-break-point #ast-hf-mobile-menu,
  .ast-header-break-point .main-header-menu {
    width: 100%;
    max-width: 100%;
  }

  .ast-header-break-point #ast-hf-mobile-menu,
  .ast-header-break-point .main-header-menu {
    background: #ffffff;
  }

  .ast-header-break-point .main-header-menu .menu-item {
    border-bottom: 1px solid #f0f0f0;
  }

  .ast-header-break-point .main-header-menu .menu-link,
  .ast-header-break-point .main-header-menu a {
    display: block;
    padding: 12px 16px;
    text-align: left;
  }

  .ast-header-break-point .ast-mobile-menu-buttons,
  .ast-header-break-point .ast-button-wrap,
  .ast-header-break-point .menu-toggle {
    position: relative;
    z-index: 1000;
  }

  .ast-header-break-point .menu-toggle {
    min-height: 44px;
    padding: 10px 14px;
    border-radius: 10px;
    line-height: 1;
    background: transparent;
    border: 1px solid #ccc;
    cursor: pointer;
  }

  .ast-header-break-point .menu-toggle,
  .ast-header-break-point .menu-toggle:hover,
  .ast-header-break-point .menu-toggle:focus,
  .ast-header-break-point .menu-toggle:focus-visible,
  .ast-header-break-point .menu-toggle:active {
    outline: none !important;
    box-shadow: none !important;
    transform: none !important;
    filter: none !important;
  }

  /* Keep header layout stable on mobile (logo left, toggle right) */
  .ast-header-break-point #masthead .main-header-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 16px !important;
  }

  .ast-header-break-point #masthead .site-branding,
  .ast-header-break-point #masthead .ast-site-identity {
    flex: 1 1 auto;
    min-width: 0;
  }

  .ast-header-break-point #masthead .site-branding a,
  .ast-header-break-point #masthead .site-title,
  .ast-header-break-point #masthead .site-title a {
    font-size: 18px !important;
    white-space: nowrap;
  }

  .ast-header-break-point #masthead .ast-mobile-menu-buttons,
  .ast-header-break-point #masthead .ast-button-wrap {
    flex: 0 0 auto;
    display: flex;
    gap: 8px;
    align-items: center;
  }

  .ast-header-break-point #masthead .ast-mobile-menu-trigger,
  .ast-header-break-point #masthead .menu-toggle {
    position: relative;
    top: 0;
    right: 0;
    transform: none;
  }

  /* Ensure the mobile panel does not overlap the header bar */
  .ast-header-break-point .main-header-bar-navigation {
    margin-top: 6px;
  }

  /* Dashboard: force mobile dropdown to appear under header, full width */
  body .ast-header-break-point #masthead .main-header-bar {
    position: relative;
  }

  body .ast-header-break-point #masthead .main-header-bar-navigation {
    position: relative;
    width: 100%;
    max-width: 100%;
  }

  body .ast-header-break-point #masthead .main-header-menu {
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
    width: 100%;
    max-width: 100%;
    margin: 0;
    padding: 0;
    background: #ffffff;
    z-index: 999999;
  }

  body .ast-header-break-point #masthead .main-header-menu .menu-item,
  body .ast-header-break-point #masthead .main-header-menu li {
    width: 100%;
  }

  /* Button groups and navs should wrap cleanly */
  .tp-portal .tp-admin-nav,
  .tp-portal .tp-quick,
  .tp-portal .tp-actions,
  .tp-portal .tp-driver-actions {
    gap: 8px;
    flex-wrap: wrap;
    justify-content: center;
  }

  .tp-portal .tp-actions .tp-btn,
  .tp-portal .tp-driver-actions .tp-btn,
  .tp-portal .tp-driver-actions .tp-quick-link,
  .tp-portal .tp-driver-actions .tp-modal-btn,
  .tp-portal .tp-actions form,
  .tp-portal .tp-actions a {
    flex: 1 1 100%;
  }

  .tp-portal .tp-actions .tp-btn,
  .tp-portal .tp-driver-actions .tp-btn,
  .tp-portal .tp-btn,
  .tp-portal button,
  .tp-portal input[type="submit"],
  .tp-portal input[type="button"],
  .tp-portal input[type="reset"] {
    width: 100%;
    justify-content: center;
  }

  /* Stack filter forms on mobile */
  .tp-portal form[method="get"],
  .tp-portal form[method="post"] {
    flex-direction: column;
    align-items: stretch;
  }
  .tp-portal form[method="get"] > div,
  .tp-portal form[method="post"] > div {
    width: 100%;
  }

  /* Responsive tables - stack on mobile without horizontal scroll */
  .tp-portal table {
    width: 100%;
  }

  /* Hide non-essential columns on mobile */
  .tp-portal table th:nth-child(n + 5),
  .tp-portal table td:nth-child(n + 5) {
    display: none;
  }

  /* Hide VAT and Notes columns on very small screens */
  .tp-portal table th:nth-child(5),
  .tp-portal table td:nth-child(5),
  .tp-portal table th:nth-child(8),
  .tp-portal table td:nth-child(8) {
    display: none;
  }

  /* Keep essential columns visible: Date, Name, Category, Net/Total */
  .tp-portal table thead tr {
    display: grid;
    grid-template-columns: 1fr 1.5fr 1fr 0.8fr;
    gap: 8px;
    background: #f8f8f8;
    padding: 8px;
  }

  .tp-portal table tbody tr {
    display: grid;
    grid-template-columns: 1fr 1.5fr 1fr 0.8fr;
    gap: 8px;
    padding: 12px 8px;
    border-bottom: 1px solid #f1f1f1;
    align-items: center;
  }

  .tp-portal table td {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .tp-portal table th {
    font-size: 12px;
    font-weight: 600;
    padding: 0;
    border: none;
  }

  .tp-portal table td {
    font-size: 13px;
    padding: 0;
  }

  .tp-portal table tbody tr:last-child {
    border-bottom: none;
  }

  /* Actions column - adjust for mobile */
  .tp-portal table thead tr th:last-child,
  .tp-portal table tbody tr td:last-child {
    display: flex !important;
    justify-content: flex-end;
    gap: 4px;
  }

  .tp-portal table tbody tr td:last-child {
    flex-wrap: wrap;
    align-items: center;
  }
}

@media (max-width: 520px) {
  /* Keep dashboard title on one line */
  .tp-portal h2 {
    white-space: nowrap;
    word-break: normal;
    hyphens: none;
    font-size: clamp(20px, 5.5vw, 26px);
    line-height: 1.2;
  }

  /* Keep quick range buttons on a single row */
  .tp-portal .tp-quick {
    flex-wrap: nowrap !important;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    justify-content: flex-start !important;
    gap: 4px;
  }
  .tp-portal .tp-quick > div {
    flex: 0 0 auto;
  }
  .tp-portal .tp-quick-link {
    padding: 4px 6px !important;
    margin: 0 !important;
    font-size: 12px !important;
    border-radius: 5px !important;
  }
  .tp-portal .tp-quick > span {
    font-size: 12px;
  }

  /* Improve table layout on very small screens */
  .tp-portal table thead tr {
    grid-template-columns: 0.8fr 1.2fr 0.6fr !important;
  }

  .tp-portal table tbody tr {
    grid-template-columns: 0.8fr 1.2fr 0.6fr !important;
  }

  .tp-portal table th,
  .tp-portal table td {
    font-size: 12px !important;
    padding: 0 !important;
  }

  .tp-portal table thead tr {
    padding: 6px 4px !important;
  }

  .tp-portal table tbody tr {
    padding: 10px 4px !important;
  }
}

@media (max-width: 640px) {
  .tp-portal .tp-expenses-form {
    width: 100% !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    column-gap: 10px !important;
    row-gap: 12px !important;
    justify-items: stretch;
  }
  .tp-portal .tp-expenses-form > div {
    min-width: 0;
  }
  .tp-portal .tp-expenses-form input,
  .tp-portal .tp-expenses-form select,
  .tp-portal .tp-expenses-form textarea {
    width: 100% !important;
  }
}

@media (max-width: 768px) {
  .tp-portal .tp-recent-grid {
    justify-items: stretch;
  }
  .tp-portal .tp-recent-grid > div {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    width: 100%;
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
  }
  .tp-portal .tp-recent-grid .tp-table-wrap,
  .tp-portal .tp-recent-grid table {
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  .tp-portal .tp-recent-grid table {
    display: table !important;
    width: 100% !important;
    max-width: 100% !important;
  }
  .tp-portal .tp-recent-grid .tp-table-wrap {
    text-align: left;
  }

  .tp-portal .tp-recent-table-wrap {
    display: block !important;
  }
  .tp-portal .tp-recent-table {
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    float: none !important;
    display: table !important;
  }

  .tp-portal .tp-recent-table th,
  .tp-portal .tp-recent-table td {
    text-align: left !important;
  }

  .tp-portal form {
    max-width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .tp-portal form input[type="text"],
  .tp-portal form input[type="email"],
  .tp-portal form input[type="password"],
  .tp-portal form input[type="number"],
  .tp-portal form select,
  .tp-portal form textarea {
    width: 100% !important;
    display: block !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .tp-portal form button,
  .tp-portal form input[type="submit"] {
    width: 100% !important;
    display: block !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
}

/* Extra mobile optimizations for 360px screens */
@media (max-width: 360px) {
  .tp-portal {
    padding: 12px 0 20px !important;
  }

  .tp-portal h1,
  .tp-portal h2 {
    font-size: 20px !important;
    margin: 12px 0 8px 0 !important;
  }

  .tp-portal h3 {
    font-size: 16px !important;
  }

  /* Admin navigation */
  .tp-admin-nav {
    flex-direction: column !important;
    gap: 6px !important;
  }

  .tp-admin-nav .tp-btn {
    width: 100% !important;
    padding: 8px 10px !important;
    font-size: 13px !important;
  }

  /* Forms */
  .tp-portal form {
    padding: 8px !important;
  }

  .tp-form > div,
  .tp-takings-form > div,
  .tp-expenses-form > div,
  .tp-rent-form > div {
    padding: 8px 10px !important;
    gap: 6px !important;
  }

  .tp-portal input,
  .tp-portal select,
  .tp-portal textarea,
  .tp-portal button,
  .tp-portal input[type="submit"] {
    font-size: 16px !important;
    padding: 10px 12px !important;
    min-height: 44px !important;
  }

  /* Filter forms */
  .tp-portal form[method="get"] {
    flex-direction: column;
    gap: 8px !important;
  }

  .tp-portal form[method="get"] > div {
    width: 100% !important;
  }

  .tp-portal form[method="get"] input,
  .tp-portal form[method="get"] button {
    width: 100% !important;
  }

  /* Buttons in filter forms */
  .tp-portal form[method="get"] .tp-btn,
  .tp-portal form[method="get"] button {
    padding: 8px 10px !important;
    min-height: 40px !important;
  }

  /* Dashboard summary cards */
  .tp-portal
    div[style*="display:flex"][style*="gap:12px"][style*="justify-content:center"] {
    flex-direction: column !important;
    gap: 8px !important;
  }

  .tp-portal
    div[style*="display:flex"][style*="gap:12px"][style*="justify-content:center"]
    > div {
    width: 100% !important;
    min-width: 100% !important;
    margin: 0 !important;
  }

  /* Quick range buttons */
  .tp-portal .tp-quick {
    gap: 2px !important;
    flex-wrap: wrap !important;
  }

  .tp-portal .tp-quick-link {
    padding: 3px 4px !important;
    font-size: 11px !important;
    margin: 0 2px 2px 0 !important;
  }

  /* Tables */
  .tp-portal table {
    font-size: 12px !important;
  }

  .tp-portal table th,
  .tp-portal table td {
    padding: 6px 4px !important;
  }

  .tp-portal .tp-actions {
    flex-direction: column !important;
    gap: 4px !important;
  }

  .tp-portal .tp-actions .tp-btn {
    width: 100% !important;
    padding: 6px 8px !important;
    font-size: 12px !important;
    min-height: 36px !important;
  }

  .tp-portal .tp-table-wrap {
    padding: 0 4px !important;
  }

  /* Settings form grid */
  .tp-portal form[style*="grid-template-columns"] {
    grid-template-columns: 1fr !important;
  }

  .tp-portal form[style*="grid-template-columns"] > div {
    grid-column: auto !important;
  }

  .tp-portal
    form[style*="grid-template-columns"]
    > div[style*="grid-column:1/-1"] {
    grid-column: 1 / -1 !important;
  }

  /* Dashboard range filter stacking */
  .tp-quick {
    flex-direction: column !important;
  }

  .tp-quick > span {
    font-size: 12px !important;
  }

  /* File upload inputs */
  .tp-file-box {
    width: 100% !important;
  }

  .tp-file-input {
    width: 100% !important;
  }

  /* Modals and lightboxes */
  .tp-portal .tp-modal-inner {
    max-width: 95vw !important;
    max-height: 90vh !important;
  }

  .tp-portal .tp-modal-stage {
    width: 95vw !important;
    height: 60vh !important;
  }

  .tp-portal .tp-receipt-lightbox-inner {
    max-width: 95vw !important;
    max-height: 85vh !important;
  }

  .tp-portal .tp-receipt-lightbox-img {
    max-height: 85vh !important;
  }

  /* Login form */
  .tp-portal div[style*="max-width:400px"] {
    max-width: 100% !important;
    padding: 0 12px !important;
  }

  .tp-portal button {
    width: 100% !important;
  }

  /* Datepicker */
  .ui-datepicker {
    width: 95vw !important;
    max-width: 320px !important;
    font-size: 14px !important;
    padding: 12px 8px !important;
  }

  .ui-datepicker-header {
    font-size: 14px !important;
    padding: 8px 4px !important;
  }

  .ui-datepicker-prev,
  .ui-datepicker-next {
    min-width: 80px !important;
    padding: 8px 8px !important;
    font-size: 12px !important;
  }

  .ui-datepicker-calendar td a,
  .ui-datepicker-calendar td span {
    padding: 8px 6px !important;
    font-size: 14px !important;
    min-height: 40px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }

  /* Additional mobile form improvements */
  .tp-portal form input[type="text"],
  .tp-portal form input[type="email"],
  .tp-portal form input[type="password"],
  .tp-portal form input[type="number"],
  .tp-portal form input[type="checkbox"],
  .tp-portal form select,
  .tp-portal form textarea {
    box-sizing: border-box !important;
  }

  /* Prevent text zoom on input focus */
  .tp-portal input,
  .tp-portal select,
  .tp-portal textarea {
    font-size: 16px !important;
  }

  /* Ensure form labels are readable */
  .tp-portal label {
    font-size: 14px !important;
    display: block !important;
    margin-bottom: 6px !important;
    font-weight: 500 !important;
  }

  /* HR separator */
  .tp-portal hr {
    margin: 12px 0 !important;
    border: none !important;
    border-top: 1px solid #ddd !important;
  }

  /* Link styling */
  .tp-portal p,
  .tp-portal div {
    word-wrap: break-word !important;
    overflow-wrap: break-word !important;
  }

  /* Enhanced form field spacing */
  .tp-portal form > div {
    margin-bottom: 12px !important;
  }

  /* Grid form adjustments for mobile */
  .tp-portal form[style*="grid-template-columns"] {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }

  /* Ensure all inputs are touchable */
  .tp-portal input[type="checkbox"],
  .tp-portal input[type="radio"] {
    min-width: 20px !important;
    min-height: 20px !important;
    cursor: pointer !important;
  }

  /* Improve button spacing */
  .tp-portal button,
  .tp-portal input[type="submit"],
  .tp-portal .tp-btn {
    min-height: 44px !important;
    padding: 10px 16px !important;
    font-size: 16px !important;
  }

  /* Link buttons should match button styling */
  .tp-portal a.tp-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 44px !important;
  }
}

/* Enhanced mobile-first responsive improvements */
@media (max-width: 480px) {
  body .tp-portal,
  .tp-portal {
    padding: 16px 8px 24px !important;
  }

  .tp-portal h1 {
    font-size: 24px !important;
  }

  .tp-portal h2 {
    font-size: 20px !important;
  }

  .tp-portal h3 {
    font-size: 18px !important;
  }

  /* Stack all form fields */
  .tp-portal form[style*="grid-template-columns"] {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  .tp-portal form[style*="grid-template-columns"] > div {
    grid-column: 1 / -1 !important;
  }

  /* Forms and inputs */
  .tp-portal form {
    padding: 12px 8px !important;
  }

  .tp-portal input,
  .tp-portal select,
  .tp-portal textarea {
    font-size: 16px !important;
    padding: 10px 12px !important;
    min-height: 44px !important;
    width: 100% !important;
  }

  .tp-portal textarea {
    min-height: 100px !important;
  }

  /* Buttons */
  .tp-portal button,
  .tp-portal input[type="submit"],
  .tp-portal input[type="button"],
  .tp-portal .tp-btn {
    width: 100% !important;
    min-height: 44px !important;
    font-size: 16px !important;
  }

  /* Cards and containers */
  .tp-portal div[style*="border:1px"][style*="border-radius"] {
    padding: 12px !important;
    margin: 8px 0 !important;
  }

  /* Table improvements */
  .tp-portal table {
    font-size: 14px !important;
  }

  .tp-portal table td,
  .tp-portal table th {
    padding: 10px 8px !important;
  }

  /* Action buttons in tables */
  .tp-portal table .tp-actions {
    flex-direction: column !important;
  }

  .tp-portal table .tp-actions .tp-btn {
    width: 100% !important;
    min-height: 40px !important;
    font-size: 14px !important;
  }
}

/* Ultra-small screens (320px and below) */
@media (max-width: 320px) {
  body .tp-portal,
  .tp-portal {
    padding: 12px 4px 20px !important;
  }

  .tp-portal h1 {
    font-size: 20px !important;
  }

  .tp-portal h2 {
    font-size: 18px !important;
  }

  .tp-portal input,
  .tp-portal select,
  .tp-portal textarea,
  .tp-portal button {
    font-size: 16px !important;
    padding: 8px 10px !important;
  }

  .tp-portal table {
    font-size: 12px !important;
  }

  .tp-portal table td,
  .tp-portal table th {
    padding: 6px 4px !important;
  }
}

/* Admin: mobile-friendly tables and forms */
@media (max-width: 768px) {
  .tp-portal .tp-admin-nav {
    justify-content: flex-start !important;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 4px;
  }
  .tp-portal .tp-admin-nav .tp-quick-link {
    flex: 0 0 auto;
  }

  .tp-portal .tp-admin-data-table,
  .tp-portal .tp-admin-drivers-table {
    display: block;
    width: 100%;
    border: 0;
    background: transparent;
  }

  .tp-portal .tp-admin-data-table thead,
  .tp-portal .tp-admin-drivers-table thead {
    display: none;
  }

  .tp-portal .tp-admin-data-table tbody,
  .tp-portal .tp-admin-drivers-table tbody {
    display: block;
  }

  .tp-portal .tp-admin-data-table tr,
  .tp-portal .tp-admin-drivers-table tr {
    display: block;
    background: #fff;
    border: 1px solid #e5e5e5;
    border-radius: 10px;
    padding: 8px 12px;
    margin: 0 0 12px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
  }

  .tp-portal .tp-admin-data-table td,
  .tp-portal .tp-admin-drivers-table td {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
    padding: 8px 0;
    border: none;
    font-size: 14px;
  }

  .tp-portal .tp-admin-data-table td:before,
  .tp-portal .tp-admin-drivers-table td:before {
    content: "";
    min-width: 0;
    font-weight: 600;
    color: #666;
    text-transform: uppercase;
    font-size: 11px;
    letter-spacing: 0.4px;
    flex: 0 0 auto;
  }

  .tp-portal .tp-admin-data-table td,
  .tp-portal .tp-admin-drivers-table td {
    text-align: left;
  }

  .tp-portal .tp-admin-data-table td:nth-child(1):before {
    content: "Date";
  }
  .tp-portal .tp-admin-data-table td:nth-child(2):before {
    content: "Type";
  }
  .tp-portal .tp-admin-data-table td:nth-child(3):before {
    content: "Driver";
  }
  .tp-portal .tp-admin-data-table td:nth-child(4):before {
    content: "Details";
  }
  .tp-portal .tp-admin-data-table td:nth-child(5):before {
    content: "Total";
  }

  .tp-portal .tp-admin-drivers-table td:nth-child(1):before {
    content: "Driver";
  }
  .tp-portal .tp-admin-drivers-table td:nth-child(2):before {
    content: "Email";
  }
  .tp-portal .tp-admin-drivers-table td:nth-child(3):before {
    content: "Status";
  }
  .tp-portal .tp-admin-drivers-table td:nth-child(4):before {
    content: "Actions";
  }

  .tp-portal .tp-admin-data-table td,
  .tp-portal .tp-admin-drivers-table td {
    word-break: break-word;
  }

  .tp-portal .tp-admin-drivers-table .tp-driver-actions {
    flex-direction: column !important;
    align-items: stretch !important;
    flex-wrap: nowrap !important;
    gap: 6px !important;
  }

  .tp-portal .tp-admin-drivers-table .tp-driver-actions .tp-quick-link,
  .tp-portal .tp-admin-drivers-table .tp-driver-actions .tp-modal-btn,
  .tp-portal .tp-admin-drivers-table .tp-driver-actions .tp-export-btn {
    width: 100% !important;
    min-width: 0 !important;
  }

  .tp-portal .tp-admin-export-fields {
    flex-direction: column !important;
    align-items: stretch !important;
  }

  .tp-portal .tp-admin-export-fields > div {
    width: 100% !important;
  }

  .tp-portal .tp-admin-export-form select[multiple] {
    width: 100% !important;
    min-width: 0 !important;
  }

  .tp-portal .tp-admin-export-form button {
    width: 100% !important;
  }
}
/* Show cards on mobile, tables on desktop */
.tp-portal .tp-cards-mobile {
  display: none;
}

@media (max-width: 768px) {
  .tp-portal .tp-cards-mobile {
    display: block;
  }
  .tp-portal .tp-cards-mobile + .tp-table-wrap {
    display: none !important;
  }
}

@media (min-width: 769px) {
  .tp-portal .tp-cards-mobile {
    display: none;
  }
  .tp-portal .tp-cards-mobile + .tp-table-wrap {
    display: block !important;
  }
}

/* ===================================== */
/* CAPACITOR MOBILE APP OPTIMIZATIONS   */
/* ===================================== */

/* Admin export form mobile layout */
@media (max-width: 768px) {
  .tp-admin-export-form .tp-admin-export-fields {
    flex-direction: column !important;
    gap: 16px !important;
    align-items: stretch !important;
  }
  .tp-admin-export-form .tp-admin-export-fields > div {
    width: 100% !important;
  }
  .tp-admin-export-form select,
  .tp-admin-export-form input,
  .tp-admin-export-form button {
    width: 100% !important;
    min-height: 48px !important;
    padding: 12px !important;
    font-size: 16px !important;
  }
  .tp-admin-export-form select[multiple] {
    min-height: 200px !important;
  }
}

/* Admin settings form-table mobile layout (WordPress admin pages) */
@media (max-width: 768px) {
  .wrap .form-table,
  form .form-table {
    border: none !important;
  }
  .form-table tr,
  .form-table th,
  .form-table td {
    display: block !important;
    width: 100% !important;
    padding: 8px 0 !important;
  }
  .form-table th {
    padding-bottom: 4px !important;
    font-weight: 600 !important;
  }
  .form-table td {
    padding-top: 0 !important;
    padding-bottom: 16px !important;
  }
  .form-table input[type="text"],
  .form-table input[type="email"],
  .form-table input[type="password"],
  .form-table select,
  .form-table textarea {
    width: 100% !important;
    max-width: 100% !important;
    min-height: 48px !important;
    font-size: 16px !important;
    padding: 12px !important;
  }
}

/* Quick links tap target sizing (44×44px minimum) */
.tp-quick-link,
a.tp-quick-link {
  min-height: 44px !important;
  min-width: 44px !important;
  padding: 10px 14px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Enhanced button tap targets for mobile */
@media (max-width: 768px) {
  .tp-portal button,
  .tp-portal .tp-btn,
  .tp-portal a.tp-btn,
  .tp-portal input[type="submit"],
  .tp-portal input[type="button"] {
    min-height: 48px !important;
    min-width: 48px !important;
    padding: 12px 16px !important;
    font-size: 16px !important;
  }

  .tp-portal .tp-card-actions .tp-btn,
  .tp-portal .tp-card-actions button,
  .tp-portal .tp-card-actions a.tp-btn {
    min-height: 48px !important;
    padding: 12px 16px !important;
    font-size: 15px !important;
  }
}

/* Admin export form mobile layout */
@media (max-width: 768px) {
  .tp-admin-export-form .tp-admin-export-fields {
    flex-direction: column !important;
    gap: 16px !important;
    align-items: stretch !important;
  }
  .tp-admin-export-form .tp-admin-export-fields > div {
    width: 100% !important;
  }
  .tp-admin-export-form select,
  .tp-admin-export-form input,
  .tp-admin-export-form button {
    width: 100% !important;
    min-height: 44px !important;
    padding: 12px !important;
    font-size: 16px !important;
  }
  .tp-admin-export-form select[multiple] {
    min-height: 180px !important;
  }
}

/* Admin settings form-table mobile layout */
@media (max-width: 768px) {
  .wrap .form-table,
  form .form-table {
    border: none !important;
  }
  .form-table tr,
  .form-table th,
  .form-table td {
    display: block !important;
    width: 100% !important;
    padding: 8px 0 !important;
  }
  .form-table th {
    padding-bottom: 4px !important;
    font-weight: 600 !important;
  }
  .form-table td {
    padding-top: 0 !important;
    padding-bottom: 16px !important;
  }
  .form-table input[type="text"],
  .form-table input[type="email"],
  .form-table input[type="password"],
  .form-table select,
  .form-table textarea {
    width: 100% !important;
    max-width: 100% !important;
    min-height: 44px !important;
    font-size: 16px !important;
  }
}

/* Quick links tap target sizing */
.tp-quick-link,
a.tp-quick-link {
  min-height: 44px !important;
  min-width: 44px !important;
  padding: 10px 14px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Card action buttons mobile sizing */
@media (max-width: 768px) {
  .tp-portal .tp-card-actions .tp-btn,
  .tp-portal .tp-card-actions button,
  .tp-portal .tp-card-actions a.tp-btn {
    min-height: 48px !important;
    padding: 12px 16px !important;
    font-size: 15px !important;
  }
}

/* Form inputs minimum tap target */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="date"],
input[type="number"],
select,
textarea {
  min-height: 44px !important;
}

@media (max-width: 768px) {
  input[type="text"],
  input[type="email"],
  input[type="password"],
  input[type="date"],
  input[type="number"],
  select,
  textarea {
    font-size: 16px !important;
  }
}
