/* Family Drivers v73 - UI MOBILE INTERNA ONLY.
   Le pagine pubbliche e il desktop restano invariati. */
@media (max-width: 768px) {
  #app.app--internal {
    --fd-navy: #062743;
    --fd-navy-2: #0a3f67;
    --fd-blue: #096fb1;
    --fd-blue-2: #0d8ad3;
    --fd-red: #e21d2f;
    --fd-yellow: #f4b22a;
    --fd-green: #0ea85c;
    --fd-bg: #eef6fb;
    --fd-card: rgba(255,255,255,.96);
    --fd-muted: #5c6d7e;
    --fd-line: rgba(6,39,67,.12);
    --fd-shadow: 0 16px 34px rgba(6,39,67,.14);
    --fd-shadow-strong: 0 22px 54px rgba(6,39,67,.24);
    min-height: 100vh;
    background:
      linear-gradient(180deg, rgba(10,63,103,.06), rgba(238,246,251,.96)),
      #eef6fb;
    color: #102033;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  }

  #app.app--internal .app-main,
  #app.app--internal .app-content,
  #app.app--internal .route-view {
    width: 100%;
    min-height: 100vh;
    background: transparent !important;
  }

  #app.app--internal .app-main { padding-top: 0 !important; }
  #app.app--internal .app-content { padding: 0 0 calc(74px + env(safe-area-inset-bottom)) !important; }
  #app.app--internal .route-view { padding: 0 12px 18px !important; }

  /* Top bar tipo app nativa: solo sulle pagine interne non mappa. */
  #app.app--internal .route-view::before {
    content: "";
    position: sticky;
    top: 0;
    display: block;
    height: 82px;
    margin: 0 -12px 12px;
    background:
      linear-gradient(180deg, rgba(6,39,67,.98), rgba(7,51,86,.98));
    border-radius: 0 0 22px 22px;
    box-shadow: 0 12px 26px rgba(6,39,67,.22);
    z-index: 0;
  }

  #app.app--internal .route-view::after {
    content: "Family Drivers";
    position: fixed;
    top: calc(16px + env(safe-area-inset-top));
    left: 22px;
    color: #fff;
    font-size: 15px;
    font-weight: 900;
    letter-spacing: .2px;
    z-index: 20;
    pointer-events: none;
  }

  #app.app--internal .profile-shell,
  #app.app--internal .wallet-shell,
  #app.app--internal .driver-shell,
  #app.app--internal .documents-shell,
  #app.app--internal .notifications-shell,
  #app.app--internal .referrals-shell,
  #app.app--internal .admin-shell {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    width: 100%;
    max-width: none;
    margin: -70px auto 0 !important;
    position: relative;
    z-index: 2;
  }

  #app.app--internal .profile-header-card,
  #app.app--internal .wallet-hero,
  #app.app--internal .driver-hero-card,
  #app.app--internal .documents-hero-card,
  #app.app--internal .notifications-hero-card,
  #app.app--internal .referrals-hero-card,
  #app.app--internal .admin-hero-card {
    min-height: 132px;
    padding: 54px 18px 18px !important;
    border: 0 !important;
    border-radius: 0 0 28px 28px !important;
    background:
      linear-gradient(180deg, var(--fd-navy) 0%, var(--fd-navy-2) 100%) !important;
    color: #fff !important;
    box-shadow: var(--fd-shadow-strong) !important;
    position: relative;
    overflow: hidden;
  }

  #app.app--internal .profile-header-card::after,
  #app.app--internal .wallet-hero::after,
  #app.app--internal .driver-hero-card::after,
  #app.app--internal .documents-hero-card::after,
  #app.app--internal .notifications-hero-card::after,
  #app.app--internal .referrals-hero-card::after,
  #app.app--internal .admin-hero-card::after {
    content: "SOS";
    position: absolute;
    right: 16px;
    top: 18px;
    padding: 5px 8px;
    border-radius: 10px;
    background: var(--fd-red);
    color: #fff;
    font-size: 11px;
    font-weight: 900;
    box-shadow: 0 8px 16px rgba(226,29,47,.24);
  }

  #app.app--internal .page-title,
  #app.app--internal .wallet-hero .page-title,
  #app.app--internal .profile-header-card .page-title,
  #app.app--internal .driver-hero-card .page-title,
  #app.app--internal .admin-hero-card .page-title,
  #app.app--internal .documents-hero-card .page-title,
  #app.app--internal .notifications-hero-card .page-title,
  #app.app--internal .referrals-hero-card .page-title {
    color: #fff !important;
    font-size: 24px !important;
    line-height: 1.05;
    letter-spacing: -.5px;
    margin: 0 0 6px !important;
    font-weight: 900;
  }

  #app.app--internal .page-subtitle,
  #app.app--internal .profile-header-card p,
  #app.app--internal .wallet-hero p,
  #app.app--internal .driver-hero-card p,
  #app.app--internal .documents-hero-card p,
  #app.app--internal .notifications-hero-card p,
  #app.app--internal .referrals-hero-card p,
  #app.app--internal .admin-hero-card p {
    color: rgba(255,255,255,.82) !important;
    font-size: 14px !important;
    line-height: 1.32;
    margin: 0;
  }

  #app.app--internal .profile-completion-badge,
  #app.app--internal .documents-completion-badge,
  #app.app--internal .driver-status-badge,
  #app.app--internal .status-pill {
    border-radius: 999px !important;
    padding: 7px 10px !important;
    background: rgba(255,255,255,.14) !important;
    color: #fff !important;
    border: 1px solid rgba(255,255,255,.18) !important;
    font-size: 12px;
    font-weight: 800;
  }

  #app.app--internal .profile-section,
  #app.app--internal .wallet-panel,
  #app.app--internal .driver-panel,
  #app.app--internal .documents-panel,
  #app.app--internal .notifications-panel,
  #app.app--internal .referrals-panel,
  #app.app--internal .admin-panel,
  #app.app--internal .admin-stat-card,
  #app.app--internal .document-upload-card,
  #app.app--internal .documents-summary-card,
  #app.app--internal .notification-card,
  #app.app--internal .referral-card,
  #app.app--internal .referral-code-card,
  #app.app--internal .referral-stat-card,
  #app.app--internal .transaction-card,
  #app.app--internal .wallet-transaction-card,
  #app.app--internal .trip-card,
  #app.app--internal .driver-request-card {
    border: 1px solid var(--fd-line) !important;
    border-radius: 22px !important;
    background: var(--fd-card) !important;
    box-shadow: var(--fd-shadow) !important;
    padding: 16px !important;
    overflow: hidden;
  }

  #app.app--internal .section-title-row h2,
  #app.app--internal .wallet-panel__header h2,
  #app.app--internal .driver-panel__header h2,
  #app.app--internal .documents-panel__header h2,
  #app.app--internal .admin-panel__header h2,
  #app.app--internal .notifications-panel__header h2,
  #app.app--internal .referrals-panel__header h2 {
    color: var(--fd-navy) !important;
    font-size: 19px !important;
    font-weight: 900;
    margin: 0 0 6px !important;
  }

  #app.app--internal .wallet-summary-cards,
  #app.app--internal .wallet-grid,
  #app.app--internal .admin-summary-grid,
  #app.app--internal .form-grid,
  #app.app--internal .driver-status-grid,
  #app.app--internal .documents-grid,
  #app.app--internal .referrals-grid,
  #app.app--internal .profile-form,
  #app.app--internal .option-list {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    grid-template-columns: none !important;
  }

  #app.app--internal .wallet-balance-card {
    border: 0 !important;
    border-radius: 22px !important;
    min-height: 118px;
    padding: 18px !important;
    color: #fff !important;
    background: linear-gradient(180deg, var(--fd-navy), #082039) !important;
    box-shadow: 0 16px 34px rgba(6,39,67,.22) !important;
  }

  #app.app--internal .wallet-balance-card--bonus {
    background: linear-gradient(180deg, #0d8ad3, #075985) !important;
  }

  #app.app--internal .wallet-balance-card__label,
  #app.app--internal .wallet-balance-card__hint { color: rgba(255,255,255,.82) !important; }
  #app.app--internal .wallet-balance-card__amount { color: #fff !important; font-size: 34px !important; font-weight: 900 !important; letter-spacing: -1px; }

  #app.app--internal .label {
    color: #1b2d43;
    font-size: 14px;
    font-weight: 850;
    margin: 0 0 7px;
  }

  #app.app--internal .input,
  #app.app--internal input.input,
  #app.app--internal select.input,
  #app.app--internal textarea.input,
  #app.app--internal .admin-form input,
  #app.app--internal .admin-form select,
  #app.app--internal .admin-form textarea {
    width: 100%;
    min-height: 52px;
    border-radius: 14px !important;
    border: 1px solid #d9e3ed !important;
    background: #fff !important;
    color: #142033 !important;
    font-size: 16px !important;
    padding: 0 14px !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.7) !important;
  }

  #app.app--internal textarea.input,
  #app.app--internal .admin-form textarea { min-height: 100px; padding-top: 12px !important; }

  #app.app--internal .input:focus,
  #app.app--internal input:focus,
  #app.app--internal select:focus,
  #app.app--internal textarea:focus {
    border-color: var(--fd-blue-2) !important;
    box-shadow: 0 0 0 3px rgba(13,138,211,.14) !important;
    outline: none !important;
  }

  #app.app--internal .btn,
  #app.app--internal button.btn,
  #app.app--internal label.btn {
    min-height: 48px;
    border-radius: 14px !important;
    font-weight: 900 !important;
    letter-spacing: .1px;
    padding: 12px 16px !important;
  }

  #app.app--internal .btn-primary {
    background: linear-gradient(180deg, #0d8ad3, #076aa8) !important;
    border-color: transparent !important;
    color: #fff !important;
    box-shadow: 0 10px 22px rgba(9,111,177,.24) !important;
  }

  #app.app--internal .btn--ghost {
    background: #edf7ff !important;
    border: 1px solid #cfeaff !important;
    color: var(--fd-blue) !important;
  }

  #app.app--internal .option-card,
  #app.app--internal .vehicle-option,
  #app.app--internal .ride-vehicle-option {
    min-height: 76px;
    border-radius: 18px !important;
    border: 1px solid #dbe5ef !important;
    background: #fff !important;
    box-shadow: 0 8px 18px rgba(6,39,67,.06) !important;
  }

  #app.app--internal .option-card.is-active,
  #app.app--internal .vehicle-option.is-active,
  #app.app--internal .ride-vehicle-option.is-active,
  #app.app--internal .option-card[aria-checked="true"] {
    border-color: #0d8ad3 !important;
    background: #eff8ff !important;
    box-shadow: 0 10px 24px rgba(13,138,211,.15) !important;
  }

  #app.app--internal .profile-avatar-preview,
  #app.app--internal .avatar,
  #app.app--internal .partner-profile-avatar,
  #app.app--internal .sidebar-user__avatar {
    border-radius: 999px !important;
    background: linear-gradient(180deg, #fff, #dff2ff) !important;
    border: 3px solid #fff !important;
    box-shadow: 0 10px 22px rgba(6,39,67,.20) !important;
  }

  #app.app--internal .mobile-bottom-nav {
    left: 8px !important;
    right: 8px !important;
    bottom: 8px !important;
    min-height: 58px !important;
    padding: 5px 6px calc(5px + env(safe-area-inset-bottom)) !important;
    border: 1px solid rgba(6,39,67,.10) !important;
    border-radius: 22px !important;
    background: rgba(255,255,255,.96) !important;
    box-shadow: 0 -8px 26px rgba(6,39,67,.13) !important;
    backdrop-filter: blur(14px) saturate(150%);
  }

  #app.app--internal .mobile-bottom-nav__item {
    min-height: 48px !important;
    border-radius: 15px !important;
    color: #526376 !important;
  }

  #app.app--internal .mobile-bottom-nav__item.is-active {
    background: var(--fd-navy) !important;
    color: #fff !important;
    box-shadow: 0 8px 16px rgba(6,39,67,.18) !important;
  }

  #app.app--internal .mobile-bottom-nav__icon svg { width: 21px !important; height: 21px !important; stroke-width: 2.4; }
  #app.app--internal .mobile-bottom-nav__label { font-size: 10px !important; font-weight: 800 !important; }

  /* MAPPA PASSEGGERO: stile phone screen del mockup, senza modificare desktop. */
  body.ride-map-open #app.app--internal .route-view,
  #app.app--internal .passenger-map-page .route-view { padding: 0 !important; }
  body.ride-map-open #app.app--internal .route-view::before,
  body.ride-map-open #app.app--internal .route-view::after { display: none !important; }

  #app.app--internal .passenger-map-page,
  #app.app--internal .ride-map-page,
  #app.app--internal .passenger-map-shell {
    min-height: 100vh;
    background: #c8effb !important;
  }

  #app.app--internal .ride-details-card,
  #app.app--internal .ride-request-card,
  #app.app--internal .ride-panel,
  #app.app--internal .map-floating-card,
  #app.app--internal .ride-map-summary,
  #app.app--internal .ride-bottom-sheet {
    border-radius: 20px !important;
    background: rgba(255,255,255,.96) !important;
    border: 1px solid rgba(6,39,67,.10) !important;
    box-shadow: 0 14px 34px rgba(6,39,67,.17) !important;
    backdrop-filter: blur(12px) saturate(140%);
  }

  #app.app--internal .ride-price,
  #app.app--internal .ride-estimated-price,
  #app.app--internal .ride-fare-amount,
  #app.app--internal .ride-request-price,
  #app.app--internal [data-ride-price] {
    color: #111827 !important;
    font-size: clamp(30px, 9vw, 42px) !important;
    font-weight: 950 !important;
    letter-spacing: -1px;
    line-height: .98 !important;
  }

  #app.app--internal .ride-surcharge-banner {
    grid-column: 1 / -1;
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 10px;
    padding: 12px 14px;
    border-radius: 18px;
    border: 1px solid rgba(56, 189, 248, 0.32);
    background: linear-gradient(135deg, rgba(240, 249, 255, 0.96), rgba(255, 255, 255, 0.92));
    box-shadow: 0 16px 36px rgba(56, 189, 248, 0.18);
    color: #075985;
  }

  #app.app--internal .ride-surcharge-banner strong,
  #app.app--internal .ride-surcharge-banner b { color: #0f172a; }

  #app.app--internal .modal,
  #app.app--internal .modal__dialog,
  #app.app--internal .modal-card,
  #app.app--internal .bottom-sheet {
    border-radius: 22px !important;
    border: 1px solid rgba(6,39,67,.10) !important;
    background: rgba(255,255,255,.98) !important;
    box-shadow: 0 24px 60px rgba(6,39,67,.28) !important;
  }

  #app.app--internal .admin-layout,
  #app.app--internal .admin-form,
  #app.app--internal .admin-actions-row,
  #app.app--internal .admin-live-map-filters {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    grid-template-columns: none !important;
  }

  #app.app--internal .admin-panel { overflow-x: auto; }
  #app.app--internal .admin-panel table,
  #app.app--internal .admin-form table { min-width: 760px; }
}

/* v74 - Mobile internal app skin closer to provided Family Drivers mockup.
   Scope is intentionally limited to authenticated views on <=768px. */
@media (max-width: 768px) {
  body:has(#app.app--internal) {
    background: #dcecf6 !important;
    overflow-x: hidden;
  }

  #app.app--internal {
    --fd-navy: #063055;
    --fd-navy-2: #0a456f;
    --fd-navy-3: #0b5b90;
    --fd-blue: #0876bd;
    --fd-sky: #e8f7ff;
    --fd-red: #ec1d34;
    --fd-yellow: #f7b733;
    --fd-green: #12a45c;
    --fd-ink: #18324b;
    --fd-muted: #6a7d91;
    --fd-line: rgba(10, 48, 85, .13);
    --fd-card: rgba(255, 255, 255, .98);
    min-height: 100svh;
    background:
      radial-gradient(circle at 15% -8%, rgba(13,138,211,.18), transparent 32%),
      linear-gradient(180deg, #e7f5ff 0%, #f6fbff 42%, #edf6fb 100%) !important;
  }

  #app.app--internal .app-content {
    min-height: 100svh !important;
    padding: calc(64px + env(safe-area-inset-top)) 0 calc(86px + env(safe-area-inset-bottom)) !important;
  }

  #app.app--internal .route-view {
    width: 100% !important;
    max-width: 430px !important;
    min-height: calc(100svh - 74px) !important;
    margin: 0 auto !important;
    padding: 12px 13px 20px !important;
    background: transparent !important;
    overflow: visible !important;
  }

  /* Native-app top bar: hamburger + logo/title + SOS, injected visually without touching public pages. */
  #app.app--internal::before {
    content: "☰   Family\A Drivers";
    white-space: pre;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: calc(58px + env(safe-area-inset-top));
    padding: calc(9px + env(safe-area-inset-top)) 68px 8px 18px;
    z-index: 9998;
    box-sizing: border-box;
    color: #fff;
    font-size: 11px;
    line-height: 1.05;
    font-weight: 900;
    letter-spacing: .1px;
    text-shadow: 0 1px 0 rgba(0,0,0,.18);
    background: linear-gradient(180deg, #052b4d 0%, #083d68 100%);
    box-shadow: 0 10px 24px rgba(6,39,67,.24);
    border-radius: 0 0 18px 18px;
  }

  #app.app--internal::after {
    content: "SOS";
    position: fixed;
    top: calc(13px + env(safe-area-inset-top));
    right: 15px;
    z-index: 9999;
    min-width: 37px;
    height: 27px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 11px;
    background: linear-gradient(180deg, #ff4156, var(--fd-red));
    color: #fff;
    font-size: 11px;
    font-weight: 950;
    box-shadow: 0 8px 16px rgba(236,29,52,.30);
  }

  #app.app--internal .route-view::before,
  #app.app--internal .route-view::after {
    display: none !important;
    content: none !important;
  }

  #app.app--internal .profile-shell,
  #app.app--internal .wallet-shell,
  #app.app--internal .driver-shell,
  #app.app--internal .documents-shell,
  #app.app--internal .notifications-shell,
  #app.app--internal .referrals-shell,
  #app.app--internal .admin-shell,
  #app.app--internal .ride-shell,
  #app.app--internal .notifications-page {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 13px !important;
  }

  #app.app--internal .profile-header-card,
  #app.app--internal .wallet-hero,
  #app.app--internal .driver-hero-card,
  #app.app--internal .documents-hero-card,
  #app.app--internal .notifications-hero-card,
  #app.app--internal .referrals-hero-card,
  #app.app--internal .admin-hero-card,
  #app.app--internal .ride-hero-card {
    min-height: 132px !important;
    padding: 20px 16px 16px !important;
    border: 0 !important;
    border-radius: 24px !important;
    color: #fff !important;
    background:
      linear-gradient(135deg, rgba(255,255,255,.10), rgba(255,255,255,0) 38%),
      linear-gradient(180deg, var(--fd-navy) 0%, var(--fd-navy-2) 100%) !important;
    box-shadow: 0 18px 42px rgba(6,39,67,.22) !important;
    position: relative !important;
    overflow: hidden !important;
  }

  #app.app--internal .profile-header-card::before,
  #app.app--internal .wallet-hero::before,
  #app.app--internal .driver-hero-card::before,
  #app.app--internal .documents-hero-card::before,
  #app.app--internal .admin-hero-card::before,
  #app.app--internal .ride-hero-card::before {
    content: "";
    position: absolute;
    width: 142px;
    height: 142px;
    right: -54px;
    bottom: -72px;
    border-radius: 999px;
    background: rgba(255,255,255,.10);
  }

  #app.app--internal .profile-header-card::after,
  #app.app--internal .wallet-hero::after,
  #app.app--internal .driver-hero-card::after,
  #app.app--internal .documents-hero-card::after,
  #app.app--internal .notifications-hero-card::after,
  #app.app--internal .referrals-hero-card::after,
  #app.app--internal .admin-hero-card::after,
  #app.app--internal .ride-hero-card::after {
    display: none !important;
  }

  #app.app--internal .page-title {
    font-size: clamp(22px, 7vw, 29px) !important;
    line-height: 1.02 !important;
    letter-spacing: -.7px !important;
    font-weight: 950 !important;
    color: #fff !important;
    margin: 0 0 7px !important;
  }

  #app.app--internal .page-subtitle,
  #app.app--internal .profile-header-card p,
  #app.app--internal .wallet-hero p,
  #app.app--internal .driver-hero-card p,
  #app.app--internal .documents-hero-card p,
  #app.app--internal .ride-hero-card p,
  #app.app--internal .admin-hero-card p {
    max-width: 92%;
    color: rgba(255,255,255,.84) !important;
    font-size: 13px !important;
    line-height: 1.33 !important;
  }

  #app.app--internal .ride-hero-badge,
  #app.app--internal .admin-hero-badge,
  #app.app--internal .profile-completion-badge,
  #app.app--internal .documents-completion-badge,
  #app.app--internal .driver-online-badge,
  #app.app--internal .driver-status-badge,
  #app.app--internal .status-pill {
    align-self: flex-start !important;
    border: 1px solid rgba(255,255,255,.23) !important;
    background: rgba(255,255,255,.15) !important;
    color: #fff !important;
    border-radius: 999px !important;
    padding: 7px 10px !important;
    font-size: 11px !important;
    font-weight: 900 !important;
    box-shadow: none !important;
  }

  #app.app--internal .profile-section,
  #app.app--internal .wallet-panel,
  #app.app--internal .driver-panel,
  #app.app--internal .documents-panel,
  #app.app--internal .notifications-panel,
  #app.app--internal .referrals-panel,
  #app.app--internal .admin-panel,
  #app.app--internal .admin-stat-card,
  #app.app--internal .document-upload-card,
  #app.app--internal .documents-summary-card,
  #app.app--internal .notification-card,
  #app.app--internal .referral-card,
  #app.app--internal .referral-code-card,
  #app.app--internal .referral-stat-card,
  #app.app--internal .transaction-card,
  #app.app--internal .wallet-transaction-card,
  #app.app--internal .wallet-transaction-item,
  #app.app--internal .trip-card,
  #app.app--internal .driver-request-card,
  #app.app--internal .driver-request-item,
  #app.app--internal .driver-status-card,
  #app.app--internal .ride-request-panel,
  #app.app--internal .ride-history-panel,
  #app.app--internal .ride-navigation-card,
  #app.app--internal .ride-estimate-card,
  #app.app--internal .ride-open-item,
  #app.app--internal .ride-history-item,
  #app.app--internal .recent-request-item {
    border: 1px solid var(--fd-line) !important;
    border-radius: 22px !important;
    background: var(--fd-card) !important;
    box-shadow: 0 14px 34px rgba(6,39,67,.13) !important;
    padding: 15px !important;
  }

  #app.app--internal .wallet-summary-cards {
    margin-top: 14px !important;
  }

  #app.app--internal .wallet-balance-card,
  #app.app--internal .admin-stat-card,
  #app.app--internal .driver-stat-card {
    border-radius: 21px !important;
    background: linear-gradient(180deg, #ffffff, #f4fbff) !important;
    color: var(--fd-ink) !important;
    border: 1px solid rgba(10,48,85,.12) !important;
    box-shadow: 0 12px 28px rgba(6,39,67,.12) !important;
  }

  #app.app--internal .wallet-balance-card__label,
  #app.app--internal .wallet-balance-card__hint { color: var(--fd-muted) !important; }
  #app.app--internal .wallet-balance-card__amount,
  #app.app--internal .admin-stat-card strong,
  #app.app--internal .driver-stat-card strong {
    color: var(--fd-navy) !important;
    font-weight: 950 !important;
  }

  #app.app--internal .section-title-row h2,
  #app.app--internal .wallet-panel__header h2,
  #app.app--internal .driver-panel__header h2,
  #app.app--internal .documents-panel__header h2,
  #app.app--internal .admin-panel__header h2,
  #app.app--internal .notifications-panel__header h2,
  #app.app--internal .referrals-panel__header h2,
  #app.app--internal .ride-request-panel__header h2,
  #app.app--internal .ride-history-panel__header h2 {
    font-size: 18px !important;
    line-height: 1.12 !important;
    color: var(--fd-navy) !important;
    font-weight: 950 !important;
  }

  #app.app--internal .wallet-panel__header p,
  #app.app--internal .driver-panel__header p,
  #app.app--internal .documents-panel__header p,
  #app.app--internal .admin-panel__header p,
  #app.app--internal .ride-request-panel__header p,
  #app.app--internal .ride-history-panel__header p,
  #app.app--internal .form-hint,
  #app.app--internal .input-help {
    color: var(--fd-muted) !important;
    font-size: 12px !important;
    line-height: 1.35 !important;
  }

  #app.app--internal .form-grid,
  #app.app--internal .wallet-grid,
  #app.app--internal .driver-grid,
  #app.app--internal .driver-stats-grid,
  #app.app--internal .admin-summary-grid,
  #app.app--internal .documents-grid,
  #app.app--internal .referrals-grid,
  #app.app--internal .option-list,
  #app.app--internal .admin-layout,
  #app.app--internal .ride-layout {
    display: flex !important;
    flex-direction: column !important;
    grid-template-columns: none !important;
    gap: 12px !important;
  }

  #app.app--internal .input,
  #app.app--internal input.input,
  #app.app--internal select.input,
  #app.app--internal textarea.input,
  #app.app--internal .admin-form input,
  #app.app--internal .admin-form select,
  #app.app--internal .admin-form textarea {
    min-height: 50px !important;
    border-radius: 16px !important;
    border: 1px solid #d6e5ef !important;
    background: #fff !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.85), 0 5px 14px rgba(6,39,67,.04) !important;
    color: #172b41 !important;
    font-size: 16px !important;
  }

  #app.app--internal .btn,
  #app.app--internal button.btn,
  #app.app--internal label.btn {
    min-height: 47px !important;
    border-radius: 14px !important;
    font-weight: 950 !important;
    text-transform: uppercase;
    font-size: 12px !important;
  }

  #app.app--internal .btn-primary {
    background: linear-gradient(180deg, #168bd0 0%, #086ba8 100%) !important;
    border: 0 !important;
    color: #fff !important;
    box-shadow: 0 10px 22px rgba(8,118,189,.24) !important;
  }

  #app.app--internal .btn--ghost {
    color: var(--fd-navy) !important;
    background: #f2f9ff !important;
    border: 1px solid #cfe6f5 !important;
  }

  #app.app--internal .btn--danger,
  #app.app--internal .ride-map-action-icon--danger {
    background: linear-gradient(180deg, #ff4055, var(--fd-red)) !important;
    color: #fff !important;
    border: 0 !important;
  }

  #app.app--internal .option-card,
  #app.app--internal .vehicle-option,
  #app.app--internal .ride-vehicle-option,
  #app.app--internal .ride-map-vehicle-option {
    border-radius: 19px !important;
    min-height: 74px !important;
    border: 1px solid #d6e5ef !important;
    background: #fff !important;
    box-shadow: 0 9px 22px rgba(6,39,67,.08) !important;
  }

  #app.app--internal .option-card.is-active,
  #app.app--internal .option-card.is-selected,
  #app.app--internal .option-card[aria-checked="true"],
  #app.app--internal .vehicle-option.is-active,
  #app.app--internal .ride-vehicle-option.is-active {
    background: #eaf7ff !important;
    border-color: #70c4f0 !important;
    box-shadow: 0 12px 26px rgba(8,118,189,.16) !important;
  }

  #app.app--internal .profile-avatar-preview,
  #app.app--internal .avatar,
  #app.app--internal .partner-profile-avatar,
  #app.app--internal .sidebar-user__avatar {
    width: 86px !important;
    height: 86px !important;
    border: 4px solid #fff !important;
    border-radius: 999px !important;
    background: linear-gradient(180deg, #fff, #d7effd) !important;
    box-shadow: 0 14px 28px rgba(6,39,67,.22) !important;
  }

  /* Bottom navigation: compact white pill, like the mockup phones. */
  #app.app--internal .mobile-bottom-nav {
    left: 10px !important;
    right: 10px !important;
    bottom: 9px !important;
    max-width: 410px;
    margin: 0 auto;
    min-height: 61px !important;
    padding: 6px 7px calc(6px + env(safe-area-inset-bottom)) !important;
    border-radius: 22px !important;
    background: rgba(255,255,255,.97) !important;
    border: 1px solid rgba(10,48,85,.13) !important;
    box-shadow: 0 -10px 28px rgba(6,39,67,.15) !important;
    backdrop-filter: blur(16px) saturate(160%) !important;
  }

  #app.app--internal .mobile-bottom-nav__item {
    min-height: 48px !important;
    padding: 5px 3px !important;
    border-radius: 16px !important;
    color: #66798b !important;
    font-weight: 800 !important;
  }

  #app.app--internal .mobile-bottom-nav__item.is-active {
    color: #fff !important;
    background: linear-gradient(180deg, #0a456f, #063055) !important;
    box-shadow: 0 9px 18px rgba(6,39,67,.20) !important;
  }

  #app.app--internal .mobile-bottom-nav__icon svg {
    width: 20px !important;
    height: 20px !important;
    stroke-width: 2.6 !important;
  }

  #app.app--internal .mobile-bottom-nav__label {
    font-size: 9.5px !important;
    line-height: 1.05 !important;
    font-weight: 900 !important;
  }

  /* Passenger/driver maps: bigger visual map, overlay cards, and no desktop spillover. */
  #app.app--internal .ride-map-fullscreen-shell,
  #app.app--internal .driver-map-shell {
    border-radius: 24px !important;
    overflow: hidden !important;
    border: 1px solid rgba(10,48,85,.14) !important;
    box-shadow: 0 18px 42px rgba(6,39,67,.18) !important;
    background: #d8f2fb !important;
  }

  #app.app--internal .ride-map-canvas,
  #app.app--internal .driver-map-canvas,
  #app.app--internal .admin-live-map {
    min-height: 330px !important;
    border-radius: 22px !important;
  }

  #app.app--internal .ride-map-controls,
  #app.app--internal .ride-map-controls__panel,
  #app.app--internal .map-floating-card,
  #app.app--internal .ride-bottom-sheet,
  #app.app--internal .ride-map-controls__toggle {
    border-radius: 22px !important;
    background: rgba(255,255,255,.97) !important;
    border: 1px solid rgba(10,48,85,.12) !important;
    box-shadow: 0 14px 36px rgba(6,39,67,.15) !important;
  }

  #app.app--internal .ride-map-floating-action,
  #app.app--internal .ride-map-action-icon {
    width: 44px !important;
    height: 44px !important;
    border-radius: 16px !important;
    box-shadow: 0 10px 20px rgba(6,39,67,.16) !important;
  }

  #app.app--internal .ride-price,
  #app.app--internal .ride-estimated-price,
  #app.app--internal .ride-fare-amount,
  #app.app--internal .ride-request-price,
  #app.app--internal [data-ride-price],
  #app.app--internal #rideEstimateValueResults {
    font-size: clamp(30px, 9vw, 40px) !important;
    line-height: .96 !important;
    font-weight: 950 !important;
    color: #102033 !important;
    letter-spacing: -1px !important;
  }

  #app.app--internal .admin-panel,
  #app.app--internal .documents-panel,
  #app.app--internal .wallet-panel {
    overflow-x: auto !important;
  }
}

/* v75 - rifinitura forte mobile interno: logo reale, meno padding, look più fedele ai mockup. */
@media (max-width: 768px) {
  html:has(#app.app--internal),
  body:has(#app.app--internal) {
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
    min-height: 100svh !important;
    overflow-x: hidden !important;
    background: #eaf5fb !important;
  }

  #app.app--internal {
    --fd-navy: #062f52;
    --fd-navy-dark: #052642;
    --fd-blue: #0877b8;
    --fd-blue-soft: #e9f7ff;
    --fd-red: #e52637;
    --fd-green: #13a565;
    --fd-yellow: #ffc33d;
    --fd-ink: #17314a;
    --fd-muted: #637587;
    --fd-line: rgba(6, 47, 82, .13);
    --fd-radius: 14px;
    --fd-radius-lg: 18px;
    --fd-shadow: 0 8px 20px rgba(6, 47, 82, .11);
    --fd-shadow-soft: 0 4px 12px rgba(6, 47, 82, .075);
    background:
      radial-gradient(circle at 30% -18%, rgba(31,151,212,.22), transparent 35%),
      linear-gradient(180deg, #dff2fb 0%, #f4f9fc 44%, #edf6fa 100%) !important;
    color: var(--fd-ink) !important;
  }

  /* Barra superiore vera: non testo finto, ma logo immagine reale. */
  #app.app--internal::before {
    content: "" !important;
    position: fixed !important;
    inset: 0 0 auto 0 !important;
    height: calc(52px + env(safe-area-inset-top)) !important;
    z-index: 9990 !important;
    border-radius: 0 0 14px 14px !important;
    background: linear-gradient(180deg, #062b4b 0%, #083b63 100%) !important;
    box-shadow: 0 7px 17px rgba(6, 47, 82, .22) !important;
  }

  #app.app--internal .app-main::before {
    content: "" !important;
    position: fixed !important;
    top: calc(7px + env(safe-area-inset-top)) !important;
    left: 47px !important;
    width: 108px !important;
    height: 36px !important;
    z-index: 9992 !important;
    pointer-events: none !important;
    background-image: url('/frontend/public/assets/img/logo-bianco-rettangolare.png') !important;
    background-repeat: no-repeat !important;
    background-position: left center !important;
    background-size: contain !important;
    filter: drop-shadow(0 1px 1px rgba(0,0,0,.20));
  }

  #app.app--internal .app-main::after {
    content: "☰" !important;
    position: fixed !important;
    top: calc(13px + env(safe-area-inset-top)) !important;
    left: 15px !important;
    z-index: 9993 !important;
    color: #fff !important;
    font-size: 22px !important;
    line-height: 1 !important;
    font-weight: 800 !important;
    pointer-events: none !important;
  }

  #app.app--internal::after {
    content: "SOS" !important;
    position: fixed !important;
    top: calc(11px + env(safe-area-inset-top)) !important;
    right: 12px !important;
    z-index: 9994 !important;
    width: 38px !important;
    min-width: 38px !important;
    height: 28px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 10px !important;
    background: linear-gradient(180deg, #ff4354 0%, #d9182c 100%) !important;
    color: #fff !important;
    font-size: 10px !important;
    font-weight: 950 !important;
    letter-spacing: -.1px !important;
    box-shadow: 0 5px 12px rgba(229, 38, 55, .30) !important;
  }

  #app.app--internal .app-header,
  #app.app--internal .app-sidebar,
  #app.app--internal .sidebar-brand-logo,
  #app.app--internal .sidebar-user,
  #app.app--internal .side-nav {
    display: none !important;
  }

  #app.app--internal .app-main,
  #app.app--internal .app-content {
    width: 100% !important;
    max-width: 100% !important;
    min-height: 100svh !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    display: block !important;
  }

  #app.app--internal .app-content {
    padding-top: calc(54px + env(safe-area-inset-top)) !important;
    padding-bottom: calc(67px + env(safe-area-inset-bottom)) !important;
  }

  #app.app--internal .route-view {
    box-sizing: border-box !important;
    width: 100% !important;
    max-width: 430px !important;
    min-height: calc(100svh - 121px) !important;
    margin: 0 auto !important;
    padding: 7px 8px 10px !important;
    overflow: visible !important;
  }

  #app.app--internal .route-view::before,
  #app.app--internal .route-view::after {
    display: none !important;
    content: none !important;
  }

  #app.app--internal .profile-shell,
  #app.app--internal .wallet-shell,
  #app.app--internal .driver-shell,
  #app.app--internal .documents-shell,
  #app.app--internal .notifications-shell,
  #app.app--internal .referrals-shell,
  #app.app--internal .admin-shell,
  #app.app--internal .ride-shell,
  #app.app--internal .notifications-page {
    gap: 8px !important;
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
  }

  /* Hero compatte tipo schermate mockup, senza spazio eccessivo. */
  #app.app--internal .profile-header-card,
  #app.app--internal .wallet-hero,
  #app.app--internal .driver-hero-card,
  #app.app--internal .documents-hero-card,
  #app.app--internal .notifications-hero-card,
  #app.app--internal .referrals-hero-card,
  #app.app--internal .admin-hero-card,
  #app.app--internal .ride-hero-card {
    min-height: 0 !important;
    padding: 12px 12px 11px !important;
    border-radius: var(--fd-radius-lg) !important;
    background:
      linear-gradient(135deg, rgba(255,255,255,.10), rgba(255,255,255,0) 48%),
      linear-gradient(180deg, #083d68 0%, #062f52 100%) !important;
    box-shadow: var(--fd-shadow) !important;
    border: 0 !important;
  }

  #app.app--internal .profile-header-card::before,
  #app.app--internal .wallet-hero::before,
  #app.app--internal .driver-hero-card::before,
  #app.app--internal .documents-hero-card::before,
  #app.app--internal .notifications-hero-card::before,
  #app.app--internal .referrals-hero-card::before,
  #app.app--internal .admin-hero-card::before,
  #app.app--internal .ride-hero-card::before,
  #app.app--internal .profile-header-card::after,
  #app.app--internal .wallet-hero::after,
  #app.app--internal .driver-hero-card::after,
  #app.app--internal .documents-hero-card::after,
  #app.app--internal .notifications-hero-card::after,
  #app.app--internal .referrals-hero-card::after,
  #app.app--internal .admin-hero-card::after,
  #app.app--internal .ride-hero-card::after {
    display: none !important;
    content: none !important;
  }

  #app.app--internal .page-title,
  #app.app--internal h1.page-title {
    margin: 0 0 4px !important;
    color: #fff !important;
    text-transform: uppercase !important;
    font-size: 18px !important;
    line-height: 1.05 !important;
    letter-spacing: -.25px !important;
    font-weight: 950 !important;
  }

  #app.app--internal .page-subtitle,
  #app.app--internal .profile-header-card p,
  #app.app--internal .wallet-hero p,
  #app.app--internal .driver-hero-card p,
  #app.app--internal .documents-hero-card p,
  #app.app--internal .notifications-hero-card p,
  #app.app--internal .referrals-hero-card p,
  #app.app--internal .admin-hero-card p,
  #app.app--internal .ride-hero-card p {
    max-width: 100% !important;
    margin: 0 !important;
    color: rgba(255,255,255,.83) !important;
    font-size: 11.5px !important;
    line-height: 1.25 !important;
  }

  #app.app--internal .profile-section,
  #app.app--internal .wallet-panel,
  #app.app--internal .driver-panel,
  #app.app--internal .documents-panel,
  #app.app--internal .notifications-panel,
  #app.app--internal .referrals-panel,
  #app.app--internal .admin-panel,
  #app.app--internal .admin-stat-card,
  #app.app--internal .document-upload-card,
  #app.app--internal .documents-summary-card,
  #app.app--internal .notification-card,
  #app.app--internal .referral-card,
  #app.app--internal .referral-code-card,
  #app.app--internal .referral-stat-card,
  #app.app--internal .transaction-card,
  #app.app--internal .wallet-transaction-card,
  #app.app--internal .wallet-transaction-item,
  #app.app--internal .trip-card,
  #app.app--internal .driver-request-card,
  #app.app--internal .driver-request-item,
  #app.app--internal .driver-status-card,
  #app.app--internal .ride-request-panel,
  #app.app--internal .ride-history-panel,
  #app.app--internal .ride-navigation-card,
  #app.app--internal .ride-estimate-card,
  #app.app--internal .ride-open-item,
  #app.app--internal .ride-history-item,
  #app.app--internal .recent-request-item {
    padding: 10px !important;
    border-radius: var(--fd-radius) !important;
    border: 1px solid var(--fd-line) !important;
    background: rgba(255,255,255,.98) !important;
    box-shadow: var(--fd-shadow-soft) !important;
  }

  #app.app--internal .wallet-summary-cards,
  #app.app--internal .wallet-grid,
  #app.app--internal .driver-grid,
  #app.app--internal .driver-stats-grid,
  #app.app--internal .admin-summary-grid,
  #app.app--internal .documents-grid,
  #app.app--internal .referrals-grid,
  #app.app--internal .form-grid,
  #app.app--internal .profile-form,
  #app.app--internal .option-list,
  #app.app--internal .admin-layout,
  #app.app--internal .ride-layout {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    grid-template-columns: none !important;
    margin: 0 !important;
  }

  #app.app--internal .wallet-summary-cards {
    margin-top: 8px !important;
  }

  #app.app--internal .wallet-balance-card,
  #app.app--internal .driver-stat-card,
  #app.app--internal .admin-stat-card {
    min-height: 0 !important;
    padding: 12px !important;
    border-radius: 16px !important;
    background: #fff !important;
    color: var(--fd-ink) !important;
    box-shadow: var(--fd-shadow-soft) !important;
  }

  #app.app--internal .wallet-balance-card__label,
  #app.app--internal .wallet-balance-card__hint {
    color: var(--fd-muted) !important;
    text-transform: uppercase !important;
    font-size: 10px !important;
    line-height: 1.1 !important;
    font-weight: 900 !important;
  }

  #app.app--internal .wallet-balance-card__amount,
  #app.app--internal #walletBalanceValue,
  #app.app--internal #walletBonusValue {
    color: var(--fd-navy) !important;
    font-size: 28px !important;
    line-height: 1 !important;
    font-weight: 950 !important;
    letter-spacing: -.8px !important;
  }

  #app.app--internal .section-title-row,
  #app.app--internal .wallet-panel__header,
  #app.app--internal .driver-panel__header,
  #app.app--internal .documents-panel__header,
  #app.app--internal .admin-panel__header,
  #app.app--internal .notifications-panel__header,
  #app.app--internal .referrals-panel__header,
  #app.app--internal .ride-request-panel__header,
  #app.app--internal .ride-history-panel__header {
    margin: 0 0 7px !important;
    gap: 4px !important;
  }

  #app.app--internal .section-title-row h2,
  #app.app--internal .wallet-panel__header h2,
  #app.app--internal .driver-panel__header h2,
  #app.app--internal .documents-panel__header h2,
  #app.app--internal .admin-panel__header h2,
  #app.app--internal .notifications-panel__header h2,
  #app.app--internal .referrals-panel__header h2,
  #app.app--internal .ride-request-panel__header h2,
  #app.app--internal .ride-history-panel__header h2,
  #app.app--internal h2 {
    margin: 0 !important;
    color: var(--fd-navy) !important;
    text-transform: uppercase !important;
    font-size: 14px !important;
    line-height: 1.08 !important;
    font-weight: 950 !important;
    letter-spacing: -.1px !important;
  }

  #app.app--internal .wallet-panel__header p,
  #app.app--internal .driver-panel__header p,
  #app.app--internal .documents-panel__header p,
  #app.app--internal .admin-panel__header p,
  #app.app--internal .ride-request-panel__header p,
  #app.app--internal .ride-history-panel__header p,
  #app.app--internal .form-hint,
  #app.app--internal .input-help,
  #app.app--internal p {
    font-size: 11.5px !important;
    line-height: 1.28 !important;
  }

  #app.app--internal .label,
  #app.app--internal label {
    margin-bottom: 4px !important;
    color: var(--fd-ink) !important;
    font-size: 11.5px !important;
    font-weight: 900 !important;
  }

  #app.app--internal .input,
  #app.app--internal input.input,
  #app.app--internal select.input,
  #app.app--internal textarea.input,
  #app.app--internal .admin-form input,
  #app.app--internal .admin-form select,
  #app.app--internal .admin-form textarea {
    min-height: 41px !important;
    border-radius: 10px !important;
    padding: 0 10px !important;
    font-size: 14px !important;
    border: 1px solid #d7e4ed !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.8) !important;
  }

  #app.app--internal textarea.input,
  #app.app--internal .admin-form textarea {
    min-height: 72px !important;
    padding-top: 9px !important;
  }

  #app.app--internal .btn,
  #app.app--internal button.btn,
  #app.app--internal label.btn {
    min-height: 39px !important;
    border-radius: 10px !important;
    padding: 9px 11px !important;
    font-size: 10.5px !important;
    line-height: 1.1 !important;
    font-weight: 950 !important;
    text-transform: uppercase !important;
    letter-spacing: -.05px !important;
  }

  #app.app--internal .btn-primary {
    background: linear-gradient(180deg, #1185cb 0%, #076aa8 100%) !important;
    color: #fff !important;
    border: 0 !important;
    box-shadow: 0 6px 14px rgba(8, 118, 184, .22) !important;
  }

  #app.app--internal .btn--ghost,
  #app.app--internal .btn-secondary {
    background: #f1f8fd !important;
    color: var(--fd-navy) !important;
    border: 1px solid #cddfea !important;
  }

  #app.app--internal .profile-avatar-preview,
  #app.app--internal .avatar,
  #app.app--internal .partner-profile-avatar,
  #app.app--internal .sidebar-user__avatar {
    width: 66px !important;
    height: 66px !important;
    border: 3px solid #fff !important;
    border-radius: 999px !important;
    box-shadow: 0 6px 14px rgba(6,47,82,.16) !important;
  }

  #app.app--internal .profile-avatar-preview img,
  #app.app--internal .avatar img,
  #app.app--internal .partner-profile-avatar img,
  #app.app--internal .sidebar-user__avatar img,
  #app.app--internal .sidebar-user__avatar-image {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    border-radius: inherit !important;
  }

  #app.app--internal .option-card,
  #app.app--internal .vehicle-option,
  #app.app--internal .ride-vehicle-option,
  #app.app--internal .ride-map-vehicle-option {
    min-height: 56px !important;
    padding: 9px 10px !important;
    border-radius: 12px !important;
    background: #fff !important;
    border: 1px solid #d7e4ed !important;
    box-shadow: 0 4px 12px rgba(6,47,82,.07) !important;
  }

  #app.app--internal .status-pill,
  #app.app--internal .profile-completion-badge,
  #app.app--internal .documents-completion-badge,
  #app.app--internal .driver-status-badge,
  #app.app--internal .driver-online-badge,
  #app.app--internal .ride-hero-badge,
  #app.app--internal .admin-hero-badge {
    padding: 5px 8px !important;
    border-radius: 999px !important;
    font-size: 10px !important;
    font-weight: 950 !important;
    line-height: 1 !important;
  }

  #app.app--internal .wallet-transaction-item,
  #app.app--internal .driver-request-item,
  #app.app--internal .notification-card,
  #app.app--internal .ride-history-item,
  #app.app--internal .ride-open-item {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
  }

  #app.app--internal .wallet-transaction-item__title,
  #app.app--internal .driver-request-item__title,
  #app.app--internal .ride-history-item__title {
    font-size: 12px !important;
    line-height: 1.15 !important;
    font-weight: 900 !important;
    color: var(--fd-ink) !important;
  }

  #app.app--internal .wallet-transaction-item__meta,
  #app.app--internal .driver-request-item__meta,
  #app.app--internal .ride-history-item__meta {
    font-size: 10.5px !important;
    line-height: 1.2 !important;
    color: var(--fd-muted) !important;
  }

  #app.app--internal .mobile-bottom-nav {
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    max-width: 430px !important;
    margin: 0 auto !important;
    min-height: calc(56px + env(safe-area-inset-bottom)) !important;
    padding: 4px 6px calc(4px + env(safe-area-inset-bottom)) !important;
    border-radius: 14px 14px 0 0 !important;
    background: rgba(255,255,255,.985) !important;
    border: 1px solid rgba(6,47,82,.12) !important;
    border-bottom: 0 !important;
    box-shadow: 0 -6px 18px rgba(6,47,82,.13) !important;
  }

  #app.app--internal .mobile-bottom-nav__item {
    min-height: 46px !important;
    padding: 4px 2px !important;
    border-radius: 10px !important;
    color: #50657a !important;
  }

  #app.app--internal .mobile-bottom-nav__item.is-active {
    background: #062f52 !important;
    color: #fff !important;
    box-shadow: 0 4px 10px rgba(6,47,82,.17) !important;
  }

  #app.app--internal .mobile-bottom-nav__icon svg {
    width: 18px !important;
    height: 18px !important;
    stroke-width: 2.5 !important;
  }

  #app.app--internal .mobile-bottom-nav__label {
    font-size: 8.8px !important;
    line-height: 1.05 !important;
    font-weight: 900 !important;
  }

  /* Mappa interna: massimo spazio visivo e pannelli sovrapposti più compatti. */
  body.ride-map-open #app.app--internal .app-content,
  #app.app--internal.app--ride-map-open .app-content {
    padding-top: calc(52px + env(safe-area-inset-top)) !important;
  }

  #app.app--internal .ride-map-fullscreen-shell,
  #app.app--internal .driver-map-shell,
  #app.app--internal .passenger-map-shell {
    border-radius: 14px !important;
    overflow: hidden !important;
    border: 1px solid rgba(6,47,82,.12) !important;
    box-shadow: var(--fd-shadow) !important;
  }

  #app.app--internal .ride-map-canvas,
  #app.app--internal .driver-map-canvas,
  #app.app--internal .admin-live-map,
  #app.app--internal .map-canvas {
    min-height: 405px !important;
    border-radius: 12px !important;
  }

  #app.app--internal .ride-map-controls,
  #app.app--internal .ride-map-controls__panel,
  #app.app--internal .map-floating-card,
  #app.app--internal .ride-bottom-sheet,
  #app.app--internal .ride-map-controls__toggle {
    border-radius: 14px !important;
    padding: 9px !important;
    background: rgba(255,255,255,.98) !important;
    border: 1px solid rgba(6,47,82,.12) !important;
    box-shadow: 0 8px 20px rgba(6,47,82,.13) !important;
  }

  #app.app--internal .ride-price,
  #app.app--internal .ride-estimated-price,
  #app.app--internal .ride-fare-amount,
  #app.app--internal .ride-request-price,
  #app.app--internal [data-ride-price],
  #app.app--internal #rideEstimateValueResults {
    font-size: 31px !important;
    line-height: .95 !important;
    letter-spacing: -.8px !important;
    font-weight: 950 !important;
  }

  #app.app--internal table {
    font-size: 11px !important;
  }

  #app.app--internal th,
  #app.app--internal td {
    padding: 7px 8px !important;
  }
}

/* v76 - allineamento padding: usa la stessa compattezza della pagina Mensajes y notificaciones su tutte le pagine interne mobile. */
@media (max-width: 768px) {
  #app.app--internal .route-view {
    padding: 7px 8px 10px !important;
  }

  #app.app--internal .profile-page,
  #app.app--internal .wallet-page,
  #app.app--internal .driver-page,
  #app.app--internal .documents-page,
  #app.app--internal .admin-page,
  #app.app--internal .ride-page,
  #app.app--internal .notifications-page {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    box-sizing: border-box !important;
  }

  #app.app--internal .profile-shell,
  #app.app--internal .wallet-shell,
  #app.app--internal .driver-shell,
  #app.app--internal .documents-shell,
  #app.app--internal .admin-shell,
  #app.app--internal .ride-shell,
  #app.app--internal .notifications-page {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    gap: 8px !important;
    box-sizing: border-box !important;
  }

  #app.app--internal .profile-header-card,
  #app.app--internal .wallet-hero,
  #app.app--internal .driver-hero-card,
  #app.app--internal .documents-hero-card,
  #app.app--internal .notifications-hero-card,
  #app.app--internal .referrals-hero-card,
  #app.app--internal .admin-hero-card,
  #app.app--internal .ride-hero-card {
    margin: 0 !important;
    padding: 12px 12px 11px !important;
    box-sizing: border-box !important;
  }

  #app.app--internal .profile-section,
  #app.app--internal .wallet-panel,
  #app.app--internal .driver-panel,
  #app.app--internal .documents-panel,
  #app.app--internal .notifications-panel,
  #app.app--internal .referrals-panel,
  #app.app--internal .admin-panel,
  #app.app--internal .ride-request-panel,
  #app.app--internal .ride-history-panel {
    margin: 0 !important;
    box-sizing: border-box !important;
  }

  /* Titoli e testi nei contenitori blu superiori sempre bianchi. */
  #app.app--internal .profile-header-card :is(h1,h2,h3,.page-title,.page-subtitle,p,span,strong,b),
  #app.app--internal .wallet-hero > :not(.wallet-summary-cards) :is(h1,h2,h3,.page-title,.page-subtitle,p,span,strong,b),
  #app.app--internal .driver-hero-card :is(h1,h2,h3,.page-title,.page-subtitle,p,span,strong,b),
  #app.app--internal .documents-hero-card :is(h1,h2,h3,.page-title,.page-subtitle,p,span,strong,b),
  #app.app--internal .notifications-hero-card :is(h1,h2,h3,.page-title,.page-subtitle,p,span,strong,b),
  #app.app--internal .referrals-hero-card :is(h1,h2,h3,.page-title,.page-subtitle,p,span,strong,b),
  #app.app--internal .admin-hero-card :is(h1,h2,h3,.page-title,.page-subtitle,p,span,strong,b),
  #app.app--internal .ride-hero-card :is(h1,h2,h3,.page-title,.page-subtitle,p,span,strong,b) {
    color: #fff !important;
  }

  #app.app--internal .page-title,
  #app.app--internal h1.page-title {
    color: #fff !important;
  }
}

/* v77 - correzione titoli hero + respiro fondo Billetera/Invita.
   Solo mobile autenticato: desktop e pagine pubbliche non vengono toccati. */
@media (max-width: 768px) {
  /* I titoli dentro le hero blu devono essere identici a Mensajes y notificaciones. */
  #app.app--internal :is(
    .profile-header-card,
    .wallet-hero,
    .driver-hero-card,
    .documents-hero-card,
    .notifications-hero-card,
    .referrals-hero-card,
    .admin-hero-card,
    .ride-hero-card
  ) :is(h1, h2, h3, .page-title) {
    color: #fff !important;
    font-size: 18px !important;
    line-height: 1.05 !important;
    letter-spacing: -.25px !important;
    font-weight: 950 !important;
    text-transform: uppercase !important;
    margin: 0 0 4px !important;
  }

  #app.app--internal :is(
    .profile-header-card,
    .wallet-hero,
    .driver-hero-card,
    .documents-hero-card,
    .notifications-hero-card,
    .referrals-hero-card,
    .admin-hero-card,
    .ride-hero-card
  ) :is(.page-subtitle, p, span, strong, b) {
    color: rgba(255,255,255,.86) !important;
  }

  /* Non fare ereditare il bianco alle card statistiche/saldo dentro la hero della billetera. */
  #app.app--internal .wallet-hero .wallet-summary-cards,
  #app.app--internal .wallet-hero .wallet-summary-cards :is(span, strong, b, div, p) {
    color: var(--fd-ink) !important;
  }

  #app.app--internal .wallet-hero .wallet-summary-cards .wallet-balance-card__label,
  #app.app--internal .wallet-hero .wallet-summary-cards .wallet-balance-card__hint {
    color: var(--fd-muted) !important;
  }

  #app.app--internal .wallet-hero .wallet-summary-cards .wallet-balance-card__amount {
    color: var(--fd-navy) !important;
  }

  /* Più padding sotto nelle pagine Billetera e Invita, mantenendo il padding compatto laterale. */
  #app.app--internal .wallet-page,
  #app.app--internal .wallet-page .wallet-shell,
  #app.app--internal .profile-page:has(#referralCodeValue),
  #app.app--internal .profile-page:has(#referralCodeValue) .profile-shell {
    padding-bottom: 24px !important;
  }

  #app.app--internal .wallet-page .wallet-grid,
  #app.app--internal .profile-page:has(#referralCodeValue) .profile-shell > section:last-child {
    margin-bottom: 12px !important;
  }
}

/* v78 - micro-fix: fondo più equilibrato + titoli hero realmente bianchi.
   Scope: solo mobile autenticato. */
@media (max-width: 768px) {
  /* Forza il bianco anche se altri CSS globali applicano color/text-fill ai titoli. */
  #app.app--internal :is(
    .profile-header-card,
    .wallet-hero,
    .driver-hero-card,
    .documents-hero-card,
    .notifications-hero-card,
    .referrals-hero-card,
    .admin-hero-card,
    .ride-hero-card
  ) :is(h1, h2, h3, .page-title, .page-title *, .ride-hero-badge, .admin-hero-badge) {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    text-shadow: 0 1px 1px rgba(0,0,0,.12) !important;
  }

  #app.app--internal :is(
    .profile-header-card,
    .wallet-hero,
    .driver-hero-card,
    .documents-hero-card,
    .notifications-hero-card,
    .referrals-hero-card,
    .admin-hero-card,
    .ride-hero-card
  ) :is(h1.page-title, .page-title) {
    font-size: 18px !important;
    line-height: 1.05 !important;
    letter-spacing: -.25px !important;
    font-weight: 950 !important;
    text-transform: uppercase !important;
    margin: 0 0 4px !important;
  }

  #app.app--internal :is(
    .profile-header-card,
    .wallet-hero,
    .driver-hero-card,
    .documents-hero-card,
    .notifications-hero-card,
    .referrals-hero-card,
    .admin-hero-card,
    .ride-hero-card
  ) :is(.page-subtitle, p) {
    color: rgba(255,255,255,.86) !important;
    -webkit-text-fill-color: rgba(255,255,255,.86) !important;
  }

  /* Le card saldo dentro la hero Billetera devono restare scure, non bianche. */
  #app.app--internal .wallet-hero .wallet-summary-cards,
  #app.app--internal .wallet-hero .wallet-summary-cards * {
    text-shadow: none !important;
    -webkit-text-fill-color: currentColor !important;
  }
  #app.app--internal .wallet-hero .wallet-summary-cards :is(span, strong, b, div, p) {
    color: var(--fd-ink) !important;
  }
  #app.app--internal .wallet-hero .wallet-summary-cards .wallet-balance-card__label,
  #app.app--internal .wallet-hero .wallet-summary-cards .wallet-balance-card__hint {
    color: var(--fd-muted) !important;
  }
  #app.app--internal .wallet-hero .wallet-summary-cards .wallet-balance-card__amount {
    color: var(--fd-navy) !important;
  }

  /* Riduce il padding sotto eccessivo aggiunto in v77. */
  #app.app--internal .wallet-page,
  #app.app--internal .wallet-page .wallet-shell,
  #app.app--internal .profile-page:has(#referralCodeValue),
  #app.app--internal .profile-page:has(#referralCodeValue) .profile-shell {
    padding-bottom: 10px !important;
  }

  #app.app--internal .wallet-page .wallet-grid,
  #app.app--internal .profile-page:has(#referralCodeValue) .profile-shell > section:last-child {
    margin-bottom: 4px !important;
  }

  /* Aggiunge solo un piccolo respiro in Mensajes e Solicitar viaje. */
  #app.app--internal .notifications-page,
  #app.app--internal .ride-page,
  #app.app--internal .ride-page .ride-shell {
    padding-bottom: 8px !important;
  }

  #app.app--internal .notifications-page > section:last-child,
  #app.app--internal .ride-page .ride-shell > section:last-child {
    margin-bottom: 4px !important;
  }
}

/* v79 - fix profilo mobile: upload button vertical alignment + avatar perfettamente tondo */
@media (max-width: 768px) {
  #app.app--internal .avatar-upload__actions {
    align-items: stretch !important;
    gap: 10px !important;
  }

  #app.app--internal .avatar-upload__actions .btn,
  #app.app--internal .avatar-upload__actions button.btn,
  #app.app--internal .avatar-upload__actions label.btn,
  #app.app--internal label[for="avatarFile"].btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 39px !important;
    height: 39px !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    line-height: 1 !important;
    text-align: center !important;
    vertical-align: middle !important;
    box-sizing: border-box !important;
  }

  #app.app--internal #profileAvatarPreview.profile-avatar-preview {
    border-radius: 50% !important;
    overflow: hidden !important;
    clip-path: circle(50% at 50% 50%) !important;
    aspect-ratio: 1 / 1 !important;
    flex: 0 0 66px !important;
  }

  #app.app--internal #profileAvatarImage.profile-avatar-image,
  #app.app--internal #profileAvatarPreview.profile-avatar-preview img,
  #app.app--internal .profile-avatar-image {
    display: block;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    border-radius: 50% !important;
    clip-path: circle(50% at 50% 50%) !important;
    background: #f8fafc !important;
  }
}
