/* MotoRide PRO V2 - app-like UI inspired by Bolt */
:root{
  --mbrh-green:#2FB36A;
  --mbrh-green-2:#1f9153;
  --mbrh-bg:#F4F6F5;
  --mbrh-card:#FFFFFF;
  --mbrh-text:#0E1A12;
  --mbrh-muted:#6B7280;
  --mbrh-line:#E6EAE7;
  --mbrh-shadow:0 10px 24px rgba(17,24,39,.10);
  --mbrh-radius:18px;
  --mbrh-radius-lg:24px;
  --mbrh-font: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
}

.mbrh-page{font-family:var(--mbrh-font); background:var(--mbrh-bg); padding:24px; min-height:60vh;}
.mbrh-card{background:var(--mbrh-card); border-radius:var(--mbrh-radius); box-shadow:var(--mbrh-shadow); padding:18px;}

.mbrh-btn{border:1px solid var(--mbrh-line); background:#fff; color:var(--mbrh-text); border-radius:999px; padding:12px 16px; font-weight:700; cursor:pointer; width:100%;}
.mbrh-btn:hover{filter:brightness(.98)}
.mbrh-btn-primary{background:var(--mbrh-green); border-color:var(--mbrh-green); color:#fff;}
.mbrh-btn-primary:hover{background:var(--mbrh-green-2)}
.mbrh-btn-danger{background:#E11D48; border-color:#E11D48; color:#fff;}
.mbrh-btn-lg{padding:14px 18px; font-size:16px;}
.mbrh-alert{border-radius:14px; padding:12px 14px; margin:12px 0; font-weight:600;}
.mbrh-alert-error{background:#FEF2F2; color:#991B1B; border:1px solid #FECACA}

/* AUTH */
.mbrh-auth{font-family:var(--mbrh-font); display:grid; grid-template-columns: 1fr; background:var(--mbrh-bg); min-height: calc(100vh - 32px); padding:16px; gap:16px;}
@media(min-width: 980px){ .mbrh-auth{grid-template-columns: 1.2fr .8fr; align-items:stretch; padding:24px;} }

.mbrh-auth-hero{background:linear-gradient(160deg, var(--mbrh-green), #0f6a3a); border-radius:var(--mbrh-radius-lg); color:#fff; padding:22px; position:relative; overflow:hidden; box-shadow:var(--mbrh-shadow);}
.mbrh-brand{display:flex; align-items:center; gap:12px;}
.mbrh-logo{width:44px; height:44px; border-radius:14px; background:rgba(255,255,255,.18); display:flex; align-items:center; justify-content:center; font-weight:900; font-size:20px;}
.mbrh-brand-name{font-weight:900; font-size:18px; letter-spacing:.2px}
.mbrh-brand-tag{opacity:.92; font-weight:600; font-size:13px}
.mbrh-hero-illustration{position:absolute; right:-40px; top:-30px; width:300px; height:300px; opacity:.95;}
.mbrh-blob{position:absolute; inset:0; background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.35), rgba(255,255,255,0) 62%);}
.mbrh-bike{position:absolute; right:70px; top:90px; width:160px; height:160px; border-radius:40px; background:rgba(255,255,255,.20); transform:rotate(10deg); filter: blur(0px);}
.mbrh-hero-copy{position:absolute; left:22px; bottom:22px; max-width:420px;}
.mbrh-hero-copy h1{margin:0 0 6px; font-size:28px; line-height:1.15; font-weight:900;}
.mbrh-hero-copy p{margin:0; opacity:.95; font-weight:600; line-height:1.4}

.mbrh-auth-card{background:var(--mbrh-card); border-radius:var(--mbrh-radius-lg); box-shadow:var(--mbrh-shadow); padding:18px;}
.mbrh-tabs{display:flex; gap:8px; background:var(--mbrh-bg); border:1px solid var(--mbrh-line); border-radius:999px; padding:6px;}
.mbrh-tab{flex:1; border:0; background:transparent; padding:10px 12px; border-radius:999px; font-weight:800; color:var(--mbrh-muted); cursor:pointer;}
.mbrh-tab.is-active{background:#fff; color:var(--mbrh-text); box-shadow:0 6px 16px rgba(17,24,39,.08);}
.mbrh-form{margin-top:14px; display:flex; flex-direction:column; gap:12px;}
.mbrh-field label{display:block; font-weight:800; font-size:13px; margin-bottom:6px; color:var(--mbrh-text);}
.mbrh-field input{width:100%; border:1px solid var(--mbrh-line); border-radius:14px; padding:12px 12px; font-size:15px; outline:none; background:#fff;}
.mbrh-field input:focus{border-color: rgba(47,179,106,.55); box-shadow:0 0 0 4px rgba(47,179,106,.14);}
.mbrh-hint{font-size:12px; color:var(--mbrh-muted); margin-top:6px; font-weight:600;}
.mbrh-phone{display:flex; align-items:center; gap:10px; border:1px solid var(--mbrh-line); border-radius:14px; padding:10px 12px; background:#fff;}
.mbrh-phone input{border:0; padding:0; border-radius:0; box-shadow:none;}
.mbrh-phone input:focus{box-shadow:none}
.mbrh-flag{font-size:18px}
.mbrh-code{font-weight:900; color:var(--mbrh-text)}
.mbrh-password{display:flex; align-items:center; gap:10px;}
.mbrh-password input{flex:1}
.mbrh-icon-btn{border:1px solid var(--mbrh-line); background:#fff; border-radius:12px; padding:10px 12px; cursor:pointer}
.mbrh-seg-row{display:flex; gap:10px;}
.mbrh-pill{flex:1; border:1px solid var(--mbrh-line); background:#fff; border-radius:14px; padding:10px 12px; cursor:pointer; display:flex; align-items:center; justify-content:center; font-weight:800;}
.mbrh-pill input{display:none}
.mbrh-pill span{color:var(--mbrh-muted)}
.mbrh-pill:has(input:checked){border-color: rgba(47,179,106,.55); box-shadow:0 0 0 4px rgba(47,179,106,.14);}
.mbrh-pill:has(input:checked) span{color:var(--mbrh-text)}
.mbrh-divider{display:flex; align-items:center; gap:12px; color:var(--mbrh-muted); font-weight:700; margin:2px 0;}
.mbrh-divider:before,.mbrh-divider:after{content:''; flex:1; height:1px; background:var(--mbrh-line);}
.mbrh-divider span{font-size:12px;}
.mbrh-btn-ghost{background:#fff;}
.mbrh-social{display:inline-flex; width:22px; height:22px; border-radius:8px; align-items:center; justify-content:center; background:var(--mbrh-bg); margin-right:8px; font-weight:900;}
.mbrh-legal{font-size:12px; color:var(--mbrh-muted); font-weight:600; margin-top:2px;}
.mbrh-legal a{color:var(--mbrh-green); text-decoration:none}

/* APP SHELL */
.mbrh-app{font-family:var(--mbrh-font); background:var(--mbrh-bg); min-height:100vh; position:relative;}
.mbrh-topbar{position:fixed; left:0; right:0; top:0; height:60px; display:flex; align-items:center; justify-content:center; z-index:50; pointer-events:none;}
.mbrh-topbar-title{pointer-events:auto; font-weight:900; color:#fff; background:rgba(14,26,18,.35); backdrop-filter: blur(10px); padding:10px 16px; border-radius:999px;}
.mbrh-fab{pointer-events:auto; width:50px; height:50px; border-radius:999px; border:0; background:#fff; box-shadow:var(--mbrh-shadow); font-size:18px; cursor:pointer;}
.mbrh-fab-left{position:absolute; left:14px;}
.mbrh-fab-right{position:absolute; right:14px;}
.mbrh-main{padding-top:0}
.mbrh-map{position:fixed; inset:0; z-index:1;}
/* Leaflet full height fix */
.mbrh-map .leaflet-container{width:100%; height:100%;}

.mbrh-sheet{position:fixed; left:0; right:0; bottom:64px; z-index:20; background:rgba(244,246,245,.92); backdrop-filter: blur(10px); border-top-left-radius:26px; border-top-right-radius:26px; box-shadow:0 -16px 32px rgba(17,24,39,.10); padding:10px 14px 14px; max-height:56vh; overflow:auto;}
.mbrh-sheet-handle{width:56px; height:6px; border-radius:999px; background:#D6DBD7; margin:0 auto 10px;}

.mbrh-promo{background:var(--mbrh-card); border:1px solid var(--mbrh-line); border-radius:18px; padding:12px 12px; box-shadow:0 10px 22px rgba(17,24,39,.06);}
.mbrh-promo-badge{display:inline-flex; background:rgba(47,179,106,.15); color:var(--mbrh-green-2); font-weight:900; padding:4px 10px; border-radius:999px; font-size:12px;}
.mbrh-promo-title{margin-top:8px; font-weight:900; font-size:14px;}
.mbrh-promo-sub{color:var(--mbrh-muted); font-weight:600; font-size:12px; margin-top:2px;}

.mbrh-search-row{display:flex; gap:10px; margin-top:12px;}
.mbrh-search{flex:1; display:flex; align-items:center; gap:10px; background:var(--mbrh-card); border:1px solid var(--mbrh-line); border-radius:18px; padding:12px 12px;}
.mbrh-search-icon{opacity:.65}
.mbrh-search input{border:0; outline:none; width:100%; font-size:15px; font-weight:800; background:transparent;}
.mbrh-later{border:1px solid var(--mbrh-line); background:var(--mbrh-card); border-radius:18px; padding:12px 14px; font-weight:900; cursor:pointer;}
.mbrh-quick{display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-top:12px;}
.mbrh-card-btn{display:flex; gap:12px; align-items:center; border:1px solid var(--mbrh-line); background:var(--mbrh-card); border-radius:18px; padding:12px 12px; cursor:pointer; box-shadow:0 10px 22px rgba(17,24,39,.06); text-align:left;}
.mbrh-card-ico{width:44px; height:44px; border-radius:16px; display:flex; align-items:center; justify-content:center; background:var(--mbrh-bg); font-size:20px;}
.mbrh-card-title{font-weight:900}
.mbrh-card-sub{color:var(--mbrh-muted); font-weight:700; font-size:12px; margin-top:2px;}

.mbrh-actions{display:flex; gap:10px; margin-top:12px;}
.mbrh-actions .mbrh-btn{flex:1}

.mbrh-tripcard{margin-top:12px; background:var(--mbrh-card); border:1px solid var(--mbrh-line); border-radius:18px; padding:12px; box-shadow:0 10px 22px rgba(17,24,39,.06);}
.mbrh-tripcard h3{margin:0 0 6px; font-size:14px;}
.mbrh-triprow{display:flex; justify-content:space-between; gap:10px; font-weight:800;}
.mbrh-triprow small{color:var(--mbrh-muted); font-weight:700}

.mbrh-bottomnav{position:fixed; left:0; right:0; bottom:0; height:64px; background:rgba(255,255,255,.92); backdrop-filter: blur(10px); border-top:1px solid var(--mbrh-line); z-index:30; display:flex; padding:8px 10px; gap:10px;}
.mbrh-navitem{flex:1; border:0; border-radius:18px; background:transparent; font-weight:900; color:var(--mbrh-muted); cursor:pointer;}
.mbrh-navitem.is-active{background:rgba(47,179,106,.12); color:var(--mbrh-green-2);}

.mbrh-screen-title{font-weight:900; font-size:16px; margin:6px 2px 10px;}
.mbrh-list{display:flex; flex-direction:column; gap:10px;}
.mbrh-list .mbrh-item{background:var(--mbrh-card); border:1px solid var(--mbrh-line); border-radius:18px; padding:12px; box-shadow:0 10px 22px rgba(17,24,39,.06);}
.mbrh-item-title{font-weight:900}
.mbrh-item-sub{color:var(--mbrh-muted); font-weight:700; font-size:12px; margin-top:4px}

.mbrh-account{display:flex; flex-direction:column; gap:10px;}
.mbrh-account .mbrh-profile{display:flex; gap:12px; align-items:center; background:var(--mbrh-card); border:1px solid var(--mbrh-line); border-radius:18px; padding:12px; box-shadow:0 10px 22px rgba(17,24,39,.06);}
.mbrh-avatar{width:44px; height:44px; border-radius:16px; background:var(--mbrh-bg); display:flex; align-items:center; justify-content:center; font-size:18px;}
.mbrh-profile-name{font-weight:900}
.mbrh-profile-meta{color:var(--mbrh-muted); font-weight:700; font-size:12px; margin-top:2px;}
.mbrh-account .mbrh-section{background:var(--mbrh-card); border:1px solid var(--mbrh-line); border-radius:18px; padding:10px; box-shadow:0 10px 22px rgba(17,24,39,.06);}
.mbrh-section h4{margin:6px 8px 10px; font-weight:900; font-size:13px; color:var(--mbrh-muted); text-transform:uppercase; letter-spacing:.8px}
.mbrh-row{display:flex; align-items:center; justify-content:space-between; padding:12px 10px; border-top:1px solid var(--mbrh-line); font-weight:900; cursor:pointer;}
.mbrh-row:first-of-type{border-top:0}
.mbrh-row span{color:var(--mbrh-muted); font-weight:800}

/* Drawer & modal */
.mbrh-drawer{position:fixed; inset:0; z-index:80; display:none;}
.mbrh-drawer[aria-hidden="false"]{display:block;}
.mbrh-drawer-card{position:absolute; left:12px; top:72px; width:min(360px, calc(100vw - 24px)); background:rgba(255,255,255,.96); backdrop-filter: blur(10px); border:1px solid var(--mbrh-line); border-radius:22px; box-shadow:var(--mbrh-shadow); padding:12px;}
.mbrh-drawer-header{display:flex; gap:12px; align-items:center; padding:8px;}
.mbrh-drawer-name{font-weight:900}
.mbrh-drawer-rating{color:var(--mbrh-muted); font-weight:800; font-size:12px; margin-top:2px;}
.mbrh-drawer-list{display:flex; flex-direction:column; gap:6px; padding:8px;}
.mbrh-drawer-item{border:1px solid var(--mbrh-line); background:#fff; border-radius:16px; padding:12px; font-weight:900; text-align:left; cursor:pointer;}
.mbrh-drawer-backdrop{position:absolute; inset:0; background:rgba(0,0,0,.20);}

.mbrh-modal{position:fixed; inset:0; z-index:90; display:none;}
.mbrh-modal[aria-hidden="false"]{display:block;}
.mbrh-modal-card{position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); width:min(360px, calc(100vw - 24px)); background:#fff; border-radius:22px; box-shadow:var(--mbrh-shadow); padding:16px; text-align:center;}
.mbrh-modal-title{font-weight:900; font-size:16px; margin-bottom:14px;}
.mbrh-modal-actions{display:flex; flex-direction:column; gap:10px;}
.mbrh-modal-backdrop{position:absolute; inset:0; background:rgba(0,0,0,.25);}
