/* Fontes carregadas de forma assíncrona no <head> (head_tags) — sem @import bloqueante. */

/* Tudo escopado em #bora-app e em tela cheia, para o tema do WordPress não interferir */
#bora-app, #bora-app * { box-sizing: border-box; margin: 0; padding: 0; }
#bora-app {
  --ink: #F5F7FB; --ink2: #FFFFFF; --card: #FFFFFF; --line: #E6ECF6;
  --green: #1B57F0; --green-d: #0E3DCB; --txt: #0A1B3D; --mut: #6A7689; --mut2: #9AA7B8;
  --danger: #EF4444; --star: #FBBF24;
  position: fixed; inset: 0; z-index: 99999;
  background: var(--ink); color: var(--txt);
  font-family: 'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
  -webkit-font-smoothing: antialiased; overflow: hidden;
  display: flex; flex-direction: column;
  padding-top: env(safe-area-inset-top); padding-bottom: env(safe-area-inset-bottom);
}
#bora-app h1, #bora-app h2, #bora-app h3, #bora-app .brand { font-family: 'Sora', sans-serif; letter-spacing: -.02em; }
#bora-app button { font-family: inherit; cursor: pointer; border: 0; }
#bora-app input { font-family: inherit; }
#bora-app .hide { display: none !important; }

/* Mapa de fundo */
#bora-app .map { position: absolute; inset: 0; z-index: 0; background: #E3E9F2; }
#bora-app .map-ph { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; text-align: center; padding: 40px; color: var(--mut); }
#bora-app .map-ph svg { opacity: .5; }
#bora-app .map-ph code { background: #EAF0FF; color: #1B57F0; padding: 2px 7px; border-radius: 6px; font-size: 12px; }

/* Top bar */
#bora-app .top { position: relative; z-index: 5; display: flex; align-items: center; gap: 12px; padding: 14px 16px; }
#bora-app .top .brand { font-weight: 800; font-size: 20px; }
#bora-app .top .brand span { color: var(--green); }
#bora-app .chip { margin-left: auto; display: flex; align-items: center; gap: 8px; background: rgba(255,255,255,.92); backdrop-filter: blur(8px); border: 1px solid var(--line); padding: 7px 12px; border-radius: 999px; font-size: 13px; font-weight: 600; }
#bora-app .chip .av { width: 24px; height: 24px; border-radius: 50%; background: var(--green); color: #fff; display: grid; place-items: center; font-weight: 800; font-size: 12px; }
#bora-app .iconbtn { width: 40px; height: 40px; border-radius: 12px; background: rgba(255,255,255,.92); backdrop-filter: blur(8px); border: 1px solid var(--line); color: var(--txt); display: grid; place-items: center; }

/* Bottom sheet */
#bora-app #bora-host:not(.sheet) { position: relative; z-index: 5; flex: 1; min-height: 0; display: flex; flex-direction: column; }
#bora-app .sheet { position: relative; z-index: 5; margin-top: auto; background: var(--ink2); border-top-left-radius: 26px; border-top-right-radius: 26px; border-top: 1px solid var(--line); box-shadow: 0 -12px 40px rgba(0,0,0,.5); padding: 8px 18px 22px; max-height: 70%; overflow-y: auto; -webkit-overflow-scrolling: touch; animation: sheetUp .32s cubic-bezier(.2,.8,.2,1); }
@keyframes sheetUp { from { transform: translateY(40px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
#bora-app .grip { width: 40px; height: 4px; border-radius: 999px; background: var(--line); margin: 6px auto 14px; }
#bora-app .sheet h2 { font-size: 19px; font-weight: 700; margin-bottom: 4px; }
#bora-app .sheet .sub { color: var(--mut); font-size: 14px; margin-bottom: 14px; }

/* Inputs */
#bora-app .field { display: flex; align-items: center; gap: 10px; background: var(--card); border: 1px solid var(--line); border-radius: 14px; padding: 13px 14px; margin-bottom: 10px; }
#bora-app .field .dot { width: 9px; height: 9px; border-radius: 50%; flex: none; }
#bora-app .field .dot.o { background: var(--green); }
#bora-app .field .dot.d { background: var(--danger); border-radius: 2px; }
#bora-app .field input { flex: 1; background: transparent; border: 0; outline: none; color: var(--txt); font-size: 15px; }
#bora-app .field input::placeholder { color: var(--mut2); }
#bora-app label.lbl { display: block; font-size: 13px; color: var(--mut); margin: 12px 0 6px; font-weight: 600; }

/* Suggestions */
#bora-app .sugg { list-style: none; }
#bora-app .sugg li { display: flex; gap: 12px; align-items: center; padding: 13px 6px; border-bottom: 1px solid var(--line); cursor: pointer; }
#bora-app .sugg li:active { background: var(--card); }
#bora-app .sugg .pin { width: 34px; height: 34px; border-radius: 10px; background: var(--card); display: grid; place-items: center; flex: none; color: var(--green); }
#bora-app .sugg .m { font-weight: 600; font-size: 15px; }
#bora-app .sugg .s { color: var(--mut); font-size: 12.5px; }

/* Buttons */
#bora-app .btn { width: 100%; background: var(--green); color: #fff; font-weight: 700; font-size: 16px; padding: 15px; border-radius: 16px; display: flex; align-items: center; justify-content: center; gap: 8px; transition: transform .08s, background .15s; }
#bora-app .btn:active { transform: scale(.985); background: var(--green-d); }
#bora-app .btn[disabled] { opacity: .5; pointer-events: none; }
#bora-app .btn.ghost { background: transparent; color: var(--txt); border: 1px solid var(--line); }
#bora-app .btn.sm { padding: 12px; font-size: 14px; border-radius: 13px; }
#bora-app .row { display: flex; gap: 10px; }

/* Categorias (estilo +Mobi) */
#bora-app .cats { display: flex; flex-direction: column; gap: 6px; margin: 4px 0 8px; }
#bora-app .cat { display: flex; align-items: center; gap: 13px; padding: 12px; border-radius: 16px; border: 2px solid transparent; background: transparent; cursor: pointer; transition: border-color .15s, background .15s, transform .08s; }
#bora-app .cat:active { transform: scale(.99); }
#bora-app .cat.sel { border-color: var(--green); background: #EAF0FF; }
#bora-app .cat .ic { width: 52px; height: 46px; border-radius: 13px; background: var(--ink); color: var(--txt); display: grid; place-items: center; flex: none; font-size: 24px; }
#bora-app .cat.sel .ic { background: #fff; color: var(--green); }
#bora-app .cat .info { flex: 1; min-width: 0; }
#bora-app .cat .nm { font-weight: 800; font-size: 15.5px; display: flex; align-items: center; gap: 7px; }
#bora-app .cat .tag { font-size: 10.5px; font-weight: 800; color: #fff; background: var(--green); padding: 2px 7px; border-radius: 20px; letter-spacing: .3px; flex: none; }
#bora-app .cat .ds { color: var(--mut); font-size: 12.5px; margin-top: 1px; }
#bora-app .cat .pr-wrap { text-align: right; flex: none; }
#bora-app .cat .pr { font-family: 'Sora'; font-weight: 800; font-size: 16px; }
#bora-app .cat .et { color: var(--mut); font-size: 11.5px; margin-top: 1px; }

/* Pagamento pills */
#bora-app .pays { display: flex; gap: 8px; margin: 2px 0 12px; }
#bora-app .pay { flex: 1; text-align: center; padding: 12px; border-radius: 13px; border: 2px solid transparent; background: var(--ink); font-weight: 700; font-size: 13.5px; color: var(--txt); cursor: pointer; transition: border-color .15s, background .15s; }
#bora-app .pay.sel { border-color: var(--green); color: var(--green); background: #EAF0FF; }

/* Status / procurando */
#bora-app .pulse { width: 84px; height: 84px; border-radius: 50%; background: rgba(27,87,240,.15); display: grid; place-items: center; margin: 6px auto 14px; animation: pls 1.6s ease-out infinite; }
#bora-app .pulse .core { width: 46px; height: 46px; border-radius: 50%; background: var(--green); display: grid; place-items: center; color: #fff; }
@keyframes pls { 0% { box-shadow: 0 0 0 0 rgba(27,87,240,.4); } 100% { box-shadow: 0 0 0 26px rgba(27,87,240,0); } }
#bora-app .center { text-align: center; }

/* Card motorista */
#bora-app .driver { display: flex; align-items: center; gap: 13px; padding: 14px 0; }
#bora-app .driver .av { width: 54px; height: 54px; border-radius: 50%; background: linear-gradient(135deg,#1B57F0,#3A74FF); display: grid; place-items: center; font-weight: 800; font-size: 20px; color: #fff; flex: none; }
#bora-app .driver .nm { font-weight: 700; font-size: 16px; }
#bora-app .driver .meta { color: var(--mut); font-size: 13px; }
#bora-app .driver .plate { margin-left: auto; text-align: right; }
#bora-app .driver .plate b { display: inline-block; background: #fff; color: #111; border: 1px solid var(--line); font-family: 'Sora'; font-weight: 700; letter-spacing: .04em; padding: 4px 9px; border-radius: 7px; font-size: 14px; }
#bora-app .actions { display: flex; gap: 10px; margin-top: 12px; }
#bora-app .actions .iconbtn { width: 48px; height: 48px; border-radius: 14px; background: var(--card); border: 1px solid var(--line); }
#bora-app .info-line { display: flex; gap: 10px; align-items: center; padding: 11px 0; border-top: 1px solid var(--line); font-size: 14px; }
#bora-app .info-line .k { color: var(--mut); }
#bora-app .info-line .v { margin-left: auto; font-weight: 600; }

/* Estrelas */
#bora-app .stars { display: flex; gap: 8px; justify-content: center; margin: 10px 0 16px; }
#bora-app .stars button { font-size: 38px; line-height: 1; color: var(--line); background: none; transition: transform .1s; }
#bora-app .stars button.on { color: var(--star); }
#bora-app .stars button:active { transform: scale(1.2); }
#bora-app .tips { display: flex; gap: 8px; margin: 4px 0 14px; }
#bora-app .tips .tip { flex: 1; padding: 11px; text-align: center; border-radius: 12px; border: 1.5px solid var(--line); background: var(--card); font-weight: 600; font-size: 14px; }
#bora-app .tips .tip.sel { border-color: var(--green); color: var(--green); }

/* Auth */
#bora-app .auth { position: relative; z-index: 5; margin: auto; width: 100%; max-width: 420px; padding: 28px 22px; }
#bora-app .auth .logo { font-family: 'Sora'; font-weight: 800; font-size: 40px; text-align: center; margin-bottom: 6px; }
#bora-app .auth .logo span { color: var(--green); }
#bora-app .auth .tag { text-align: center; color: var(--mut); margin-bottom: 26px; font-size: 15px; }
#bora-app .auth .tabs { display: flex; background: var(--card); border-radius: 13px; padding: 4px; margin-bottom: 18px; }
#bora-app .auth .tabs button { flex: 1; padding: 10px; border-radius: 10px; background: transparent; color: var(--mut); font-weight: 700; font-size: 14px; }
#bora-app .auth .tabs button.on { background: var(--green); color: #fff; }
#bora-app .auth .switchrole { text-align: center; margin-top: 14px; font-size: 13.5px; color: var(--mut); }

/* Histórico */
#bora-app .hist { padding: 4px 0; }
#bora-app .hist .it { display: flex; gap: 12px; padding: 13px 0; border-bottom: 1px solid var(--line); }
#bora-app .hist .it .ic { width: 38px; height: 38px; border-radius: 11px; background: var(--card); display: grid; place-items: center; flex: none; }
#bora-app .hist .it .v { margin-left: auto; font-family: 'Sora'; font-weight: 700; }
#bora-app .hist .st { font-size: 11.5px; color: var(--mut); }

/* Toast */
#bora-app .toast { position: fixed; left: 50%; bottom: calc(26px + env(safe-area-inset-bottom)); transform: translateX(-50%); background: #0A1B3D; color: #fff; padding: 12px 18px; border-radius: 12px; font-weight: 600; font-size: 14px; z-index: 100000; box-shadow: 0 8px 30px rgba(0,0,0,.4); max-width: 90%; text-align: center; animation: sheetUp .25s; }
#bora-app .toast.err { background: var(--danger); color: #fff; }

/* Spinner */
#bora-app .spin { width: 18px; height: 18px; border: 2.5px solid rgba(10,27,61,.15); border-top-color: var(--green); border-radius: 50%; animation: sp .7s linear infinite; }
#bora-app .btn .spin { border-color: rgba(255,255,255,.4); border-top-color: #fff; }
@keyframes sp { to { transform: rotate(360deg); } }
#bora-app .loadfull { margin: auto; display: flex; flex-direction: column; align-items: center; gap: 14px; color: var(--mut); z-index: 5; }
#bora-app .loadfull .spin { width: 30px; height: 30px; border-color: rgba(10,27,61,.12); border-top-color: var(--green); }

/* ===================== App do Motorista ===================== */
#bora-app .muted { color: var(--mut); }
#bora-app .sm { font-size: 12.5px; }
#bora-app .muted.sm svg { vertical-align: -2px; margin-right: 3px; }

/* Botões extra */
#bora-app .btn.primary { background: var(--green); color: #fff; }
#bora-app .btn.block { width: 100%; }
#bora-app .btn.danger { background: var(--danger); color: #fff; }
#bora-app .btn.link { width: auto; background: transparent; color: var(--mut); border: 0; padding: 12px; font-weight: 600; }
#bora-app .btn.link.danger { color: var(--danger); }

/* Campos rotulados (cadastro) */
#bora-app .fld { display: block; margin-bottom: 11px; }
#bora-app .fld > span { display: block; font-size: 12.5px; color: var(--mut); margin-bottom: 5px; font-weight: 600; }
#bora-app .fld input, #bora-app .sel { width: 100%; background: var(--card); border: 1px solid var(--line); border-radius: 13px; padding: 13px 14px; color: var(--txt); font-size: 15px; outline: none; }
#bora-app .fld input::placeholder { color: var(--mut2); }
#bora-app .sel { -webkit-appearance: none; appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%2394A3B8' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; }
#bora-app .row2 { display: flex; gap: 10px; }
#bora-app .row2 .fld { flex: 1; }

/* Top bar do motorista (dentro de .top) */
#bora-app .topbar { width: 100%; display: flex; align-items: center; gap: 12px; background: rgba(255,255,255,.92); backdrop-filter: blur(10px); border: 1px solid var(--line); border-radius: 16px; padding: 11px 14px; }
#bora-app .tb-info { min-width: 0; }
#bora-app .tb-title { font-family: 'Sora'; font-weight: 700; font-size: 16px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
#bora-app .tb-sub { color: var(--mut); font-size: 12.5px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
#bora-app .tb-av { margin-left: auto; width: 38px; height: 38px; border-radius: 50%; background: linear-gradient(135deg,#1B57F0,#3A74FF); color: #fff; display: grid; place-items: center; font-weight: 800; font-size: 14px; flex: none; }

/* Botão de ícone */
#bora-app .icon-btn { width: 42px; height: 42px; border-radius: 12px; background: var(--card); border: 1px solid var(--line); color: var(--txt); display: grid; place-items: center; flex: none; }
#bora-app .icon-btn.call { background: var(--green); color: #fff; border: 0; }

/* Avatar genérico */
#bora-app .av { width: 50px; height: 50px; border-radius: 50%; background: linear-gradient(135deg,#1B57F0,#3A74FF); color: #fff; display: grid; place-items: center; font-weight: 800; font-size: 18px; flex: none; }
#bora-app .av.sm { width: 38px; height: 38px; font-size: 14px; }

/* Cabeçalho de sub-tela */
#bora-app .sheet-h { display: flex; align-items: center; gap: 10px; padding: 6px 0 14px; }
#bora-app .sheet-t { font-family: 'Sora'; font-weight: 700; font-size: 19px; }
#bora-app .sheet-h .icon-btn { margin-left: auto; }

/* Home do motorista */
#bora-app .d-home { display: flex; flex-direction: column; gap: 12px; padding-top: 6px; }
#bora-app .d-status { display: flex; align-items: center; gap: 12px; padding: 16px; border-radius: 18px; border: 1px solid var(--line); background: var(--card); }
#bora-app .d-status.on { border-color: var(--green); background: rgba(27,87,240,.10); }
#bora-app .d-status-t { font-family: 'Sora'; font-weight: 700; font-size: 16px; }
#bora-app .pwr { margin-left: auto; width: 58px; height: 58px; border-radius: 50%; background: var(--ink2); border: 1.5px solid var(--line); color: var(--mut); display: grid; place-items: center; flex: none; transition: transform .1s; }
#bora-app .pwr:active { transform: scale(.94); }
#bora-app .pwr.on { background: var(--green); border-color: var(--green); color: #fff; box-shadow: 0 0 0 6px rgba(27,87,240,.18); }
#bora-app .d-earn { display: flex; align-items: center; padding: 14px 16px; border-radius: 16px; background: var(--card); border: 1px solid var(--line); }
#bora-app .d-earn-v { font-family: 'Sora'; font-weight: 800; font-size: 22px; }
#bora-app .d-earn-rate { margin-left: auto; display: flex; align-items: center; gap: 5px; font-weight: 700; color: var(--star); }
#bora-app .d-actions { display: flex; gap: 9px; }
#bora-app .d-actions .btn { flex: 1; width: auto; flex-direction: column; gap: 5px; padding: 13px 6px; font-size: 12.5px; border-radius: 14px; }
#bora-app .d-veh { padding-top: 4px; }

/* Oferta de corrida */
#bora-app .offer { display: flex; flex-direction: column; gap: 13px; padding-top: 4px; animation: sheetUp .25s; }
#bora-app .offer-top { display: flex; align-items: center; }
#bora-app .offer-fare { font-family: 'Sora'; font-weight: 800; font-size: 30px; }
#bora-app .offer-timer { margin-left: auto; width: 46px; height: 46px; border-radius: 50%; border: 3px solid var(--green); display: grid; place-items: center; font-weight: 800; font-size: 14px; color: var(--green); }
#bora-app .offer-meta { display: flex; gap: 8px; flex-wrap: wrap; }
#bora-app .offer-meta span { display: inline-flex; align-items: center; gap: 5px; background: var(--card); border: 1px solid var(--line); padding: 6px 11px; border-radius: 999px; font-size: 13px; font-weight: 600; }
#bora-app .offer-meta .pay { flex: none; color: var(--green); }
#bora-app .trip-line { padding: 2px 0; }
#bora-app .tl-row { display: flex; align-items: center; gap: 11px; }
#bora-app .tl-dot { width: 11px; height: 11px; border-radius: 50%; flex: none; }
#bora-app .tl-dot.o { background: var(--green); }
#bora-app .tl-dot.d { background: var(--danger); border-radius: 3px; }
#bora-app .tl-bar { width: 2px; height: 16px; background: var(--line); margin-left: 4.5px; }
#bora-app .tl-addr { font-size: 14px; font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
#bora-app .offer-pax { display: flex; align-items: center; gap: 11px; padding: 11px 0; border-top: 1px solid var(--line); }
#bora-app .offer-btns { display: flex; gap: 10px; }
#bora-app .offer-btns .btn { flex: 1; width: auto; }

/* Tela da corrida ativa */
#bora-app .ride-sheet { display: flex; flex-direction: column; gap: 14px; padding-top: 6px; }
#bora-app .addr-line { display: flex; gap: 11px; align-items: flex-start; }
#bora-app .addr-line .tl-dot { margin-top: 5px; }
#bora-app .addr-main { font-weight: 600; font-size: 15.5px; }
#bora-app .pax-card { display: flex; align-items: center; gap: 12px; padding: 13px; border-radius: 16px; background: var(--card); border: 1px solid var(--line); }
#bora-app .pax-info { min-width: 0; flex: 1; }
#bora-app .pax-info b { font-size: 15.5px; }
#bora-app .ride-actions { display: flex; gap: 10px; }
#bora-app .ride-actions .btn { flex: 1; width: auto; }

/* Resumo */
#bora-app .d-summary { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 8px; padding: 10px 0 4px; }
#bora-app .sum-badge { width: 72px; height: 72px; border-radius: 50%; background: rgba(27,87,240,.15); color: var(--green); display: grid; place-items: center; margin-bottom: 4px; }
#bora-app .sum-v { font-family: 'Sora'; font-weight: 800; font-size: 34px; }
#bora-app .d-summary .btn { margin-top: 14px; }

/* Ganhos */
#bora-app .earn-cards { display: flex; gap: 9px; margin-bottom: 14px; }
#bora-app .earn-c { flex: 1; padding: 14px 8px; border-radius: 15px; background: var(--card); border: 1px solid var(--line); text-align: center; }
#bora-app .earn-c-v { font-family: 'Sora'; font-weight: 800; font-size: 18px; }
#bora-app .tx-list { display: flex; flex-direction: column; }
#bora-app .tx { display: flex; align-items: center; gap: 12px; padding: 13px 0; border-bottom: 1px solid var(--line); }
#bora-app .tx-d { font-weight: 600; font-size: 14.5px; }
#bora-app .tx-v { margin-left: auto; font-family: 'Sora'; font-weight: 700; color: var(--green); }

/* Login do motorista (abas) */
#bora-app .auth-wrap { min-height: 100%; display: flex; align-items: center; justify-content: center; padding: 24px 18px; }
#bora-app .auth-card { width: 100%; max-width: 420px; background: var(--card); border: 1px solid var(--line); border-radius: 22px; padding: 22px; }
#bora-app .auth-card .brand { display: flex; align-items: center; gap: 9px; font-family: 'Sora'; font-weight: 800; font-size: 22px; margin-bottom: 16px; }
#bora-app .auth-card .brand b { font-weight: 800; }
#bora-app .brand-dot { width: 12px; height: 12px; border-radius: 50%; background: var(--green); box-shadow: 0 0 0 4px rgba(27,87,240,.18); flex: none; }
#bora-app .auth-tabs { display: flex; gap: 6px; background: var(--ink2); border: 1px solid var(--line); border-radius: 13px; padding: 4px; margin-bottom: 16px; }
#bora-app .auth-tab { flex: 1; width: auto; border: 0; background: transparent; color: var(--mut); font-weight: 700; font-size: 14px; padding: 10px; border-radius: 9px; }
#bora-app .auth-tab.on { background: var(--green); color: #fff; }

/* Saque (carteira do motorista) */
#bora-app .payout { padding: 2px 0 6px; }
#bora-app .pix-row { display: flex; align-items: center; gap: 10px; padding: 12px; border-radius: 14px; background: var(--card); border: 1px solid var(--line); margin-bottom: 10px; }
#bora-app .pix-row > div:first-child { flex: 1; min-width: 0; }

/* Pagamento com cartão (Mercado Pago Bricks) */
#bora-app .card-brick { margin-top: 12px; background: #fff; border-radius: 14px; padding: 10px; min-height: 60px; }

/* Documentos (verificação do motorista) */
#bora-app .doc-banner { padding: 12px 14px; border-radius: 12px; font-size: 14px; font-weight: 600; margin-bottom: 14px; }
#bora-app .doc-banner.ok { background: rgba(27,87,240,.12); color: #1B57F0; }
#bora-app .doc-banner.wait { background: rgba(245,158,11,.14); color: #B45309; }
#bora-app .doc-card { background: var(--card); border: 1px solid var(--line); border-radius: 14px; padding: 14px; margin-bottom: 12px; }
#bora-app .doc-top { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
#bora-app .doc-name { font-weight: 600; }
#bora-app .doc-dot { width: 12px; height: 12px; border-radius: 50%; flex: none; }

/* Agendamento de corridas */
#bora-app .sched-banner { display: flex; align-items: center; justify-content: space-between; gap: 10px; background: rgba(11,18,32,.04); border: 1px solid var(--line); border-radius: 14px; padding: 12px 14px; margin-bottom: 12px; cursor: pointer; }
#bora-app .sched-input { width: 100%; padding: 12px 14px; border: 1px solid var(--line); border-radius: 12px; font-size: 15px; font-family: inherit; background: var(--card, #fff); color: var(--ink, #0B1220); }
#bora-app .sched-tag { display: inline-block; margin: 8px 0 4px; padding: 6px 10px; border-radius: 10px; background: #EAF0FF; color: #1B57F0; font-weight: 700; font-size: 13px; }

/* Recibo (histórico) */
#bora-app .rcpt-head { text-align: center; margin: 8px 0 12px; }
#bora-app .rcpt-total { display: flex; align-items: center; justify-content: space-between; padding: 14px 16px; border-radius: 14px; background: var(--card, #f1f5f9); margin-bottom: 12px; }
#bora-app .rcpt-total b { font-family: 'Sora'; font-size: 22px; }
#bora-app .rcpt { border: 1px solid var(--line); border-radius: 14px; overflow: hidden; }
#bora-app .rcpt-row { display: flex; justify-content: space-between; gap: 12px; padding: 11px 14px; border-bottom: 1px solid var(--line); font-size: 14px; }
#bora-app .rcpt-row:last-child { border-bottom: 0; }
#bora-app .rcpt-row .k { color: var(--mut, #64748b); }
#bora-app .rcpt-row .v { font-weight: 600; text-align: right; }
/* ---- Detalhes da viagem (motorista) ---- */
#bora-app .rcpt-sub { color: var(--mut); font-size: 13px; margin: 0 0 12px; }
#bora-app .rcpt-map { height: 190px; border-radius: 16px; overflow: hidden; border: 1px solid var(--line); margin: 4px 0 14px; background: #E3E9F2; }
#bora-app .rcpt-stats { display: flex; gap: 9px; }
#bora-app .rcpt-stat { flex: 1; padding: 13px 8px; border-radius: 14px; background: var(--card); border: 1px solid var(--line); text-align: center; }
#bora-app .rcpt-stat .v { font-family: 'Sora'; font-weight: 800; font-size: 17px; }
#bora-app .rcpt-sec { font-family: 'Sora'; font-weight: 700; font-size: 14px; color: var(--txt); margin: 18px 0 9px; }
#bora-app .rcpt-trip { margin: 14px 0 2px; }
#bora-app .rcpt-trip .tl-row { align-items: flex-start; }
#bora-app .rcpt-trip .tl-addr { white-space: normal; line-height: 1.35; }
#bora-app .rcpt-trip .tl-dot { margin-top: 4px; }
#bora-app .rcpt-trip .tl-bar { height: 22px; }
#bora-app .rcpt-tl { padding: 2px 0; }
#bora-app .rcpt-tl-row { display: flex; gap: 12px; position: relative; padding-bottom: 16px; }
#bora-app .rcpt-tl-row.last { padding-bottom: 0; }
#bora-app .rcpt-tl-row:not(.last)::before { content: ''; position: absolute; left: 5px; top: 14px; bottom: 0; width: 2px; background: var(--line); }
#bora-app .rcpt-tl-mark { width: 12px; height: 12px; border-radius: 50%; background: #fff; border: 3px solid var(--green); box-sizing: border-box; flex: none; margin-top: 2px; position: relative; z-index: 2; }
#bora-app .rcpt-tl-row.last .rcpt-tl-mark { background: var(--green); }
#bora-app .rcpt-tl-txt { font-size: 14px; font-weight: 500; }
#bora-app .rcpt-row.strong { font-weight: 800; background: var(--card); }
#bora-app .rcpt-row.strong .v { font-weight: 800; }
#bora-app .rcpt-row .v.neg { color: var(--danger); }
#bora-app .rcpt-row .v.pos { color: #16A34A; }
#bora-app .rcpt-note { margin-top: 9px; font-size: 12.5px; color: var(--txt); background: #EFF4FF; border-radius: 10px; padding: 9px 12px; line-height: 1.4; }
#bora-app .rcpt-pax { display: flex; align-items: center; gap: 12px; }
#bora-app .rcpt-rate { margin-top: 10px; }
#bora-app .rcpt-stars { color: var(--star); font-size: 18px; letter-spacing: 2px; }

/* Marca +Mobi — o "+" em quadradinho azul */
#bora-app .top .brand, #bora-app .auth .logo { display: inline-flex; align-items: center; gap: 4px; }
#bora-app .top .brand span, #bora-app .auth .logo span, #bora-app .auth-card .brand span {
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--green); color: #fff; border-radius: .28em;
  width: 1.06em; height: 1.06em; line-height: 1; font-weight: 800;
  box-shadow: 0 3px 9px rgba(27,87,240,.32);
}

/* ===================== Home estilo +Mobi (etapa 1b) ===================== */
#bora-app .home-uber { position: relative; z-index: 5; flex: 1; min-height: 0; overflow-y: auto; -webkit-overflow-scrolling: touch; background: var(--ink); padding: 6px 16px 20px; }
#bora-app .page-h { font-family: 'Sora'; font-weight: 800; font-size: 26px; margin: 8px 2px 14px; }

/* Cartão de busca "Para onde?" */
#bora-app .search-card { display: flex; align-items: center; gap: 12px; background: var(--card); border: 1.5px solid var(--line); border-radius: 16px; padding: 15px 15px; box-shadow: 0 10px 24px rgba(10,27,61,.07); margin: 8px 0 4px; cursor: pointer; color: var(--green); }
#bora-app .search-card .q { flex: 1; font-size: 17px; font-weight: 700; color: var(--txt); }
#bora-app .search-card .later { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; font-weight: 700; color: var(--green); background: #EAF0FF; padding: 8px 11px; border-radius: 11px; }

/* Rótulo de seção */
#bora-app .eyebrow { font-size: 12px; font-weight: 800; letter-spacing: 1.1px; text-transform: uppercase; color: var(--mut); margin: 20px 2px 11px; }

/* Atalhos de serviço */
#bora-app .svc-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
#bora-app .svc { background: var(--card); border: 1.5px solid var(--line); border-radius: 18px; padding: 14px 4px 11px; display: flex; flex-direction: column; align-items: center; gap: 9px; cursor: pointer; transition: transform .1s; }
#bora-app .svc:active { transform: scale(.95); }
#bora-app .svc .ic { width: 46px; height: 46px; border-radius: 14px; background: #EAF0FF; color: var(--green); display: grid; place-items: center; }
#bora-app .svc .lb { font-size: 12.5px; font-weight: 700; color: var(--txt); }

/* Destinos recentes */
#bora-app .recent { background: var(--card); border: 1.5px solid var(--line); border-radius: 18px; overflow: hidden; }
#bora-app .recrow { display: flex; align-items: center; gap: 13px; padding: 14px 15px; cursor: pointer; }
#bora-app .recrow + .recrow { border-top: 1px solid var(--line); }
#bora-app .recrow .ic { width: 38px; height: 38px; border-radius: 11px; background: #EAF0FF; color: var(--mut); display: grid; place-items: center; flex: none; }
#bora-app .recrow .tt { flex: 1; min-width: 0; }
#bora-app .recrow .t1 { font-size: 14.5px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
#bora-app .recrow > svg { color: #C2CCDC; flex: none; }

/* Banner de parcerias */
#bora-app .promo { margin-top: 20px; border-radius: 20px; padding: 18px; background: linear-gradient(125deg, var(--green), #0E3DCB); color: #fff; cursor: pointer; box-shadow: 0 12px 28px rgba(27,87,240,.28); }
#bora-app .promo .pp { font-size: 12px; font-weight: 800; letter-spacing: 1.1px; text-transform: uppercase; opacity: .82; }
#bora-app .promo .ph { font-size: 18px; font-weight: 800; margin-top: 5px; line-height: 1.25; max-width: 84%; }
#bora-app .promo .pb { margin-top: 14px; display: inline-flex; align-items: center; gap: 6px; background: #fff; color: var(--green); font-size: 13px; font-weight: 800; padding: 9px 14px; border-radius: 11px; }

/* Barra inferior */
#bora-app .tabbar { position: relative; z-index: 6; flex: none; display: flex; background: var(--card); border-top: 1px solid var(--line); padding: 9px 8px calc(11px + env(safe-area-inset-bottom)); box-shadow: 0 -6px 20px rgba(10,27,61,.05); }
#bora-app .tab { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 4px; background: none; color: var(--mut); padding: 4px; transition: color .12s; }
#bora-app .tab.on { color: var(--green); }
#bora-app .tab .lb { font-size: 11px; font-weight: 700; }

/* Conta */
#bora-app .profile { display: flex; align-items: center; gap: 14px; background: var(--card); border: 1.5px solid var(--line); border-radius: 20px; padding: 16px; margin-bottom: 16px; }
#bora-app .profile .pn { font-size: 18px; font-weight: 800; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
#bora-app .profile .ps { font-size: 13px; color: var(--mut); margin-top: 3px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
#bora-app .menu { background: var(--card); border: 1.5px solid var(--line); border-radius: 18px; overflow: hidden; }
#bora-app .mrow { display: flex; align-items: center; gap: 13px; padding: 15px; cursor: pointer; }
#bora-app .mrow + .mrow { border-top: 1px solid var(--line); }
#bora-app .mrow .ic { color: var(--green); display: grid; place-items: center; flex: none; }
#bora-app .mrow .ml { flex: 1; font-size: 15px; font-weight: 700; }
#bora-app .mrow > svg:last-child { color: #C2CCDC; flex: none; }

/* Avatar pequeno (topo) */
#bora-app .top .av.sm { width: 40px; height: 40px; font-size: 14px; }

/* Home cheia cobre o mapa; nas telas de corrida o mapa reaparece */
#bora-app.home-mode #bora-map { display: none; }
#bora-app.home-mode #bora-top { background: var(--ink); }

/* Marca no login do motorista: "+Mobi Motorista" mais coeso */
#bora-app .auth-card .brand { gap: 5px; }

/* ===== Pacote Segurança (compartilhar viagem, SOS, código de embarque) ===== */
#bora-app .boarding { display: flex; align-items: center; justify-content: space-between; gap: 12px; background: linear-gradient(135deg,#EEF4FF,#E0EBFF); border: 1px solid #C7DBFF; border-radius: 14px; padding: 12px 14px; margin: 10px 0; }
#bora-app .boarding .bk { font-weight: 800; color: #0A1B3D; font-size: 14px; }
#bora-app .boarding .bsub { color: #5B6B86; font-size: 12px; margin-top: 2px; }
#bora-app .boarding .bcode { font-weight: 800; font-size: 26px; letter-spacing: 4px; color: #1B57F0; background: #fff; border-radius: 10px; padding: 6px 12px; box-shadow: 0 1px 4px rgba(27,87,240,.18); white-space: nowrap; }
#bora-app .safety-row { display: flex; gap: 10px; margin: 10px 0 2px; }
#bora-app .safety-btn { flex: 1; display: flex; align-items: center; justify-content: center; gap: 6px; background: #F1F5F9; color: #0A1B3D; border: none; border-radius: 12px; padding: 11px 10px; font-size: 13px; font-weight: 700; cursor: pointer; }
#bora-app .safety-btn:active { transform: scale(.98); }
#bora-app .safety-btn.sos { background: #FEE2E2; color: #B91C1C; }

/* ===== Preferência: motorista mulher ===== */
#bora-app .fem-row { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 12px 0; cursor: pointer; border-top: 1px solid #EEF2F7; }
#bora-app .fem-row .tgl { width: 46px; height: 28px; border-radius: 999px; background: #CBD5E1; position: relative; flex: 0 0 auto; transition: background .15s; }
#bora-app .fem-row .tgl span { position: absolute; top: 3px; left: 3px; width: 22px; height: 22px; border-radius: 50%; background: #fff; transition: left .15s; box-shadow: 0 1px 3px rgba(0,0,0,.2); }
#bora-app .fem-row .tgl.on { background: #1B57F0; }
#bora-app .fem-row .tgl.on span { left: 21px; }

/* ===== Indique e ganhe ===== */
#bora-app .ref-card { background: linear-gradient(135deg,#1B57F0,#0A1B3D); color: #fff; border-radius: 16px; padding: 20px; text-align: center; }
#bora-app .ref-card .rc-lbl { font-size: 12px; opacity: .8; letter-spacing: 1px; text-transform: uppercase; }
#bora-app .ref-card .rc-code { font-size: 30px; font-weight: 800; letter-spacing: 5px; margin: 6px 0 8px; cursor: pointer; word-break: break-all; }
#bora-app .ref-card .rc-sub { font-size: 13px; opacity: .92; line-height: 1.45; }

/* ===== Comodidades (chips) ===== */
#bora-app .extras-wrap { padding: 8px 0 2px; border-top: 1px solid #EEF2F7; margin-top: 6px; }
#bora-app .extras-row { display: flex; flex-wrap: wrap; gap: 8px; }
#bora-app .chip { border: 1px solid #E2E8F0; background: #fff; color: #0A1B3D; border-radius: 999px; padding: 8px 13px; font-size: 13px; font-weight: 600; cursor: pointer; }
#bora-app .chip.on { background: #1B57F0; border-color: #1B57F0; color: #fff; }

/* ===== Missões do motorista ===== */
#bora-app .mission { border: 1px solid #E2E8F0; border-radius: 14px; padding: 14px; margin-bottom: 12px; background: #fff; }
#bora-app .mission.done { border-color: #22C55E; background: #F0FDF4; }
#bora-app .mbar { height: 8px; border-radius: 999px; background: #EEF2F7; overflow: hidden; }
#bora-app .mbar .mfill { height: 100%; background: #1B57F0; border-radius: 999px; transition: width .3s; }
#bora-app .mission.done .mfill { background: #22C55E; }
