/* MA Taxi Portal (Driver + Customer) — v0.4.77 */
.ma-portal{font-family:Arial,sans-serif;color:#111827;max-width:980px;margin:0 auto;padding:0 16px;font-size:16px;line-height:1.4}
.ma-portal *{box-sizing:border-box}
.ma-portal-header{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin:10px 0 14px}
.ma-portal-title{margin:0;font-size:28px;line-height:1.1}
.ma-portal-sub{margin-top:6px;color:#6b7280;font-size:14px}
.ma-portal-grid{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:980px){.ma-portal-grid{grid-template-columns:420px 1fr}}
.ma-card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;overflow:hidden;box-shadow:0 1px 2px rgba(0,0,0,.04)}
.ma-card-header{padding:12px 14px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #f1f5f9;background:#fafafa}
.ma-card-title{font-weight:700}
.ma-card-meta{display:flex;gap:8px;align-items:center}
.ma-card-body{padding:14px}
.ma-muted{color:#6b7280}
.ma-small{font-size:12px}
.ma-btn{background:#f59e0b;border:1px solid #f59e0b;color:#111827;padding:10px 14px;border-radius:10px;cursor:pointer;font-weight:700;display:inline-flex;align-items:center;gap:8px;text-decoration:none !important}
.ma-btn:focus,.ma-btn:active,.ma-btn:visited{color:inherit !important;text-decoration:none !important}
.ma-portal a.ma-btn{color:inherit !important;text-decoration:none !important}
.ma-btn:hover{opacity:.95}
.ma-btn:disabled{opacity:.5;cursor:not-allowed}
.ma-btn-outline{background:#fff;border:1px solid #d1d5db}
.ma-btn-danger{background:#ef4444;border-color:#ef4444;color:#fff !important;text-decoration:none !important}
.ma-btn-danger:visited,.ma-btn-danger:focus,.ma-btn-danger:active{color:#fff !important;text-decoration:none !important}

/* Defensive: some themes force underline/blue links */
.ma-portal a,.ma-portal a:visited,.ma-portal a:hover{color:inherit !important;text-decoration:none !important}
.ma-pill{display:inline-flex;align-items:center;gap:6px;border:1px solid #e5e7eb;background:#fff;border-radius:999px;padding:5px 10px;font-size:12px;color:#374151}
.ma-pill.ma-pill-muted{background:#f9fafb;color:#6b7280;border-color:#e5e7eb}
.ma-chip{border:1px solid #e5e7eb;background:#fff;border-radius:999px;padding:7px 10px;font-size:12px;cursor:pointer}
.ma-chip.is-active{background:#111827;color:#fff;border-color:#111827}
.ma-jobs-filters{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 12px}

/* Next job / active job banner */
.ma-next-banner{border:1px solid #e5e7eb;border-radius:14px;padding:12px;margin:0 0 12px;background:#fff}
.ma-next-inner{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.ma-next-title{font-weight:700}
.ma-next-meta{font-size:13px;color:#374151;margin-top:4px;line-height:1.35}
.ma-next-actions{flex:0 0 auto}

.ma-list{display:flex;flex-direction:column;gap:10px}
.ma-job-item{border:1px solid #e5e7eb;border-radius:12px;padding:12px 12px;background:#fff}
.ma-job-item:hover{background:#fcfcfc}
.ma-job-item.is-active{border-color:#111827}
.ma-job-top{display:flex;justify-content:space-between;gap:10px}
.ma-job-ref{font-weight:800}
.ma-job-meta{color:#6b7280;font-size:12px;margin-top:4px;line-height:1.35}
.ma-job-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.ma-job-actions .ma-btn{padding:9px 12px}
.ma-btn-sm{padding:8px 12px;border-radius:10px;font-size:13px}

/* Detail mode:
   Mobile: collapse the jobs list when a job is opened.
   Desktop: keep split view (list + detail) for faster dispatching. */
@media(max-width:979px){
  .ma-driver-portal.is-detail [data-ma-panel="list"]{display:none}
  .ma-driver-portal.is-detail .ma-portal-grid{grid-template-columns:1fr !important}
}
.ma-primary-action{margin-top:12px}
.ma-primary-action .ma-btn{width:100%;justify-content:center}


.ma-maps-bar{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.ma-maps-bar .ma-btn{flex:1 1 auto}

.ma-stepper{display:flex;gap:10px;align-items:flex-start;justify-content:space-between;margin:0 0 12px;padding:10px 12px;border:1px solid #e5e7eb;border-radius:12px;background:#fff}
.ma-step{display:flex;flex-direction:column;gap:6px;align-items:center;flex:1 1 0;min-width:0}
.ma-step-dot{width:10px;height:10px;border-radius:999px;background:#e5e7eb}
.ma-step.is-active .ma-step-dot{background:#f59e0b}
.ma-step.is-done .ma-step-dot{background:#111827}
.ma-step-label{font-size:11px;color:#374151;text-align:center;line-height:1.2}
.ma-step-time{font-size:10px;color:#6b7280;margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}

/* Better spacing on small screens */
@media(max-width:520px){
  .ma-step-time{display:none}

  .ma-portal{padding:0 8px}
  .ma-card-body{padding:12px}
  .ma-card-header{padding:12px}
}
.ma-job-badges{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.ma-badge{display:inline-flex;align-items:center;border-radius:999px;padding:4px 9px;font-size:12px;background:#f3f4f6;color:#111827}
.ma-badge.status{background:#111827;color:#fff}
.ma-badge.ma-badge-price{background:#fff;border:1px solid #e5e7eb}

.ma-job-route{display:flex;align-items:center;gap:10px;margin-top:10px;flex-wrap:wrap}
.ma-route-line{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:#111827;min-width:0}
.ma-route-line span:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}
.ma-route-arrow{color:#6b7280;font-weight:800}
.ma-dot{width:8px;height:8px;border-radius:999px;background:#f59e0b;flex:0 0 auto}

.ma-job-item.is-next{border-color:#f59e0b;box-shadow:0 0 0 2px rgba(245,158,11,.15)}
.ma-job-item.is-completed{opacity:.85}
.ma-detail-grid{display:grid;grid-template-columns:1fr;gap:12px}
@media(min-width:980px){.ma-detail-grid{grid-template-columns:1fr 320px}}
.ma-kv{display:flex;justify-content:space-between;gap:10px;padding:8px 0;border-bottom:1px dashed #e5e7eb}
.ma-kv:last-child{border-bottom:0}
.ma-k{color:#6b7280;font-size:12px}
.ma-v{font-weight:700}
.ma-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:12px}
@media(min-width:980px){.ma-actions{grid-template-columns:repeat(4,minmax(0,1fr))}}
.ma-actions [data-ma-do="complete"]{grid-column:1/-1}
.ma-chat{display:flex;flex-direction:column;gap:10px}
.ma-chat-log{border:1px solid #e5e7eb;border-radius:12px;padding:10px;height:280px;overflow:auto;background:#fafafa}
.ma-msg{max-width:85%;padding:9px 11px;border-radius:12px;margin:6px 0;line-height:1.35;font-size:13px}
.ma-msg.driver{background:#111827;color:#fff;margin-left:auto}
.ma-msg.customer{background:#fff;border:1px solid #e5e7eb}
.ma-msg-meta{font-size:11px;opacity:.8;margin-top:4px}
.ma-chat-compose{display:flex;gap:8px}
.ma-chat-compose input{flex:1;border:1px solid #d1d5db;border-radius:10px;padding:10px 12px}
.ma-modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.45);display:none;align-items:center;justify-content:center;z-index:999999}
.ma-modal{background:#fff;border-radius:14px;border:1px solid #e5e7eb;max-width:480px;width:92%;padding:14px}
.ma-modal h3{margin:0 0 10px}
.ma-modal .ma-kv{border-bottom:1px solid #f1f5f9}
.ma-modal-actions{display:flex;gap:8px;margin-top:12px}

/* v0.4.94: Customer portal top actions layout */
.ma-portal-actions{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
  margin:10px 0 18px;
}

@media (max-width: 480px){
  .ma-portal-actions{
    flex-direction:column;
    align-items:stretch;
  }
  .ma-portal-actions .ma-btn{
    width:100%;
    justify-content:center;
  }
}


/* Tabs + alerts (Customer account UX polish) */
.ma-tabs{display:flex !important;gap:8px !important;flex-wrap:wrap !important;align-items:center !important}
.ma-tab{display:inline-flex !important;align-items:center !important;justify-content:center !important;padding:10px 12px !important;border-radius:999px !important;border:1px solid #e5e7eb !important;background:#fff !important;color:#111827 !important;text-decoration:none !important;font-weight:800 !important;font-size:13px !important;line-height:1.1 !important;width:auto !important}
.ma-tab.is-active{background:#111827 !important;border-color:#111827 !important;color:#fff !important}

/* booking card actions (Track/Cancel/Support) */
.ma-job-actions{margin-top:12px;display:flex;gap:10px;flex-wrap:wrap}
.ma-job-actions .ma-btn{
  flex:1 1 220px;
  min-width:160px;
  width:100%;
  text-align:center;
  text-decoration:none !important;
}
.ma-job-actions .ma-support-btn{flex:1 1 220px}

@media (max-width: 480px){
  .ma-job-actions{flex-direction:column}
  .ma-job-actions .ma-btn{flex:0 0 auto; min-width:0}
}
.ma-alert{margin:12px 0;padding:12px 14px;border-radius:14px;border:1px solid #e5e7eb;background:#fff;font-weight:700}
.ma-alert-success{border-color:#bbf7d0;background:#f0fdf4}
.ma-alert-warn{border-color:#fde68a;background:#fffbeb}

/* -----------------------------
   Customer portal tidy-up
   (layout only; no logic changes)
----------------------------- */

/* Auth (magic link request) */
.ma-auth-form{display:flex;flex-direction:column;gap:12px}
.ma-auth-form input[type="email"],
.ma-auth-form input[type="text"],
.ma-auth-form input[type="password"]{
  width:100%;
  height:52px;
  padding:0 14px;
  border-radius:14px;
}

.ma-auth-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.ma-auth-actions .ma-btn{flex:1 1 220px;min-width:180px;justify-content:center}

@media(max-width:520px){
  .ma-auth-actions{flex-direction:column;align-items:stretch}
  .ma-auth-actions .ma-btn{width:100%;min-width:0}
}

/* Upcoming / Previous */
.ma-bookings-tabs{display:flex;gap:10px;padding:0 18px 12px}
.ma-bookings-tabs .ma-pill{flex:1;justify-content:center}
.ma-bookings-tabs .ma-pill.is-active{background:#111827;color:#fff;border-color:#111827}

/* Booking card spacing */
.ma-job-item-customer{border-radius:16px}
.ma-job-item-customer .ma-card-body{padding:14px}
.ma-job-route-block{margin-top:12px;display:flex;flex-direction:column;gap:6px}
.ma-job-route-block > div{line-height:1.35}

@media(max-width:520px){
  .ma-auth-actions .ma-btn{min-width:0;flex:1 1 100%}
}

/* --- Strong overrides for theme link styles (fix blue/underline on buttons) --- */
.ma-portal a,
.ma-portal a:visited,
.ma-portal a:hover,
.ma-portal a:focus {
  color: inherit !important;
  text-decoration: none !important;
}

.ma-portal a.ma-btn,
.ma-portal a.ma-btn:visited,
.ma-portal a.ma-btn:hover,
.ma-portal a.ma-btn:focus,
.ma-portal a.ma-btn * {
  text-decoration: none !important;
}

.ma-portal a.ma-btn-primary,
.ma-portal a.ma-btn-primary:visited,
.ma-portal a.ma-btn-primary:hover,
.ma-portal a.ma-btn-primary:focus {
  color: #111827 !important;
}

.ma-portal a.ma-btn-danger,
.ma-portal a.ma-btn-danger:visited,
.ma-portal a.ma-btn-danger:hover,
.ma-portal a.ma-btn-danger:focus {
  color: #fff !important;
}

/* Add-ons badges (Driver portal) */
.ma-addons-badges{margin-top:10px;display:flex;flex-wrap:wrap;gap:6px}
.ma-badge.ma-badge-addon{background:#fff;border:1px solid #e5e7eb}
