:root{--ink:#12213c;--muted:#71809a;--primary:#1267f4;--primary2:#10b981;--bg:#f4f7fc;--card:#fff;--line:#e7edf7;--danger:#ef4444;--warning:#ff9f1a;--shadow:0 14px 35px rgba(25,61,117,.09)}*{box-sizing:border-box}body{margin:0;font-family:"Be Vietnam Pro",Arial,sans-serif;background:var(--bg);color:var(--ink);font-size:14px}.topbar{height:68px;background:#fff;display:flex;align-items:center;gap:30px;padding:0 max(20px,calc((100vw - 1540px)/2));border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}.brand{display:flex;align-items:center;gap:8px;text-decoration:none;font-size:23px;font-weight:800;color:#1184e8;letter-spacing:-.8px}.brand-mark{display:grid;place-items:center;background:linear-gradient(135deg,#1387f4,#18c789);border-radius:50%;color:#fff;width:34px;height:34px;font-size:22px}.main-nav{display:flex;align-items:center;gap:10px;flex:1;justify-content:center}.main-nav a,.nav-actions>a{color:#2b3953;text-decoration:none;padding:11px 13px;font-weight:600;font-size:13px}.main-nav a:hover{color:var(--primary)}.nav-actions{display:flex;align-items:center;gap:4px}.btn{border:0;border-radius:9px;padding:10px 16px;text-decoration:none;font-weight:700;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-family:inherit}.btn-primary{background:var(--primary);color:#fff!important;box-shadow:0 6px 15px rgba(18,103,244,.22)}.btn-success{background:#16a34a;color:#fff}.btn-danger{background:#fff0f0;color:var(--danger);border:1px solid #ffc9c9}.btn-light{background:#f1f5fb;color:#1e365b!important}.btn-sm{padding:7px 10px;font-size:12px}.user-chip{background:#eff5ff;border-radius:8px}.page-shell{max-width:1540px;margin:0 auto;padding:24px 24px 32px}.alert{padding:13px 16px;border-radius:10px;margin-bottom:18px;font-weight:600}.alert.success{background:#eafcf2;color:#15723b;border:1px solid #bcefd1}.alert.error{background:#fff0f0;color:#b42318;border:1px solid #ffc9c9}.hero-grid{display:grid;grid-template-columns:1.3fr .85fr;gap:20px}.card{background:var(--card);border:1px solid var(--line);border-radius:15px;box-shadow:var(--shadow)}.hero-copy{padding:30px 32px;min-height:370px;position:relative;overflow:hidden;background:linear-gradient(145deg,#fff 0%,#f8fbff 60%,#eef7ff)}.eyebrow{display:inline-flex;padding:7px 11px;border-radius:99px;background:#e7f5ff;color:#1475d0;font-weight:700;font-size:12px}.eyebrow-link{text-decoration:none;cursor:pointer;transition:all .18s ease}.eyebrow-link:hover{background:#d9efff;color:#0a67e8;transform:translateY(-1px)}.hero-copy h1{font-size:42px;line-height:1.18;letter-spacing:-1.7px;max-width:550px;margin:16px 0 13px}.hero-copy p{color:var(--muted);font-size:15px;line-height:1.7;max-width:540px}.floating-road{position:absolute;right:-40px;bottom:-80px;width:360px;height:260px;border-radius:48% 45% 20% 20%;border:24px solid rgba(37,149,255,.12);transform:rotate(-20deg)}.booking-widget{margin-top:25px;position:relative;z-index:2;display:grid;grid-template-columns:1.1fr 1.1fr .9fr auto;gap:10px;padding:12px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);border-radius:13px}.field{display:flex;flex-direction:column;gap:5px}.field label{font-size:11px;color:#64738a;font-weight:700}.input,.select{border:1px solid #e3ebf7;background:#fff;border-radius:8px;padding:10px 11px;color:#243654;font:inherit;width:100%}.map-panel{min-height:370px;overflow:hidden;position:relative;background:linear-gradient(135deg,#dff0e7,#f5f3e7)}.map-grid{position:absolute;inset:0;background-image:linear-gradient(#c9e1dc 1px,transparent 1px),linear-gradient(90deg,#c9e1dc 1px,transparent 1px);background-size:30px 30px;opacity:.75}.route{position:absolute;width:86%;height:58%;left:7%;top:19%;border-left:6px solid #1570ef;border-bottom:6px solid #1570ef;border-radius:0 0 35% 22%;transform:rotate(-10deg)}.pin{position:absolute;width:26px;height:26px;background:#f44545;border:4px solid #fff;border-radius:50% 50% 50% 0;transform:rotate(-45deg);box-shadow:0 3px 12px #8b302e}.pin.start{background:#16b86c;left:16%;top:66%}.pin.end{right:15%;top:15%}.map-info{position:absolute;left:17px;top:17px;background:#fff;border-radius:10px;padding:12px;box-shadow:var(--shadow);width:190px}.map-info b{display:block;color:#1e9e61;font-size:12px;margin-bottom:7px}.map-controls{position:absolute;right:15px;bottom:15px;display:flex;flex-direction:column;gap:8px}.map-controls span{width:38px;height:38px;display:grid;place-items:center;background:#fff;border-radius:8px;box-shadow:var(--shadow);font-size:20px}.section{margin-top:20px}.section-header{display:flex;justify-content:space-between;align-items:center;margin:0 2px 10px}.section-header h2{margin:0;font-size:17px}.section-header a{color:var(--primary);font-weight:700;text-decoration:none;font-size:12px}.service-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:10px}.service{padding:14px;border:1px solid var(--line);border-radius:12px;background:#fff;text-decoration:none;color:var(--ink);display:flex;gap:11px;align-items:center}.service-icon{font-size:28px;background:#eff7ff;border-radius:10px;padding:8px}.service b{font-size:13px;display:block}.service small{color:var(--muted);line-height:1.4;display:block;margin-top:3px}.split{display:grid;grid-template-columns:.75fr 1.25fr;gap:20px}.pad{padding:22px}.form-title{margin:0 0 5px;font-size:20px}.muted{color:var(--muted)}.stack{display:grid;gap:12px}.perks{list-style:none;margin:20px 0;padding:0;display:grid;gap:12px}.perks li{color:#3a506f}.perks li:before{content:'✓';color:#1eaf69;margin-right:8px;font-weight:bold}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.stat{padding:16px;border:1px solid var(--line);border-radius:12px;background:#fff}.stat .value{font-size:25px;font-weight:800;margin-top:7px}.stat .label{font-weight:600;color:#61708a;font-size:12px}.dashboard-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:15px}.chart{height:225px;display:flex;align-items:end;gap:12px;border-bottom:1px solid #d9e5f5;padding:10px 10px 0}.chart i{display:block;flex:1;background:linear-gradient(#3881ff,#8bb8ff);border-radius:9px 9px 0 0;min-height:20px}.review{padding:12px 0;border-bottom:1px solid var(--line)}.review:last-child{border:0}.stars{color:#ff9f1a;letter-spacing:1px}.feature-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.feature{padding:14px;background:#fff;border-radius:12px;border:1px solid var(--line);display:flex;gap:11px}.feature .emoji{font-size:28px}.feature b{font-size:13px;display:block}.feature p{font-size:12px;margin:4px 0;color:var(--muted);line-height:1.45}.site-footer{background:#10284b;color:#d9e5f8;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:20px;padding:26px max(24px,calc((100vw - 1540px)/2));font-size:12px}.site-footer strong{font-size:14px;color:#fff}.site-footer p{line-height:1.6;margin:6px 0}.page-title{display:flex;align-items:start;justify-content:space-between;margin-bottom:17px}.page-title h1{margin:0;font-size:25px}.page-title p{margin:6px 0 0}.form-card{max-width:760px;margin:0 auto}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.full{grid-column:1/-1}.radio-row{display:flex;gap:10px;flex-wrap:wrap}.radio-card{flex:1;min-width:130px;padding:12px;border:1px solid var(--line);border-radius:10px;cursor:pointer}.radio-card input{margin-right:6px}.table-wrap{overflow:auto}.data-table{width:100%;border-collapse:collapse;background:#fff}.data-table th,.data-table td{padding:12px;border-bottom:1px solid var(--line);text-align:left;white-space:nowrap;font-size:12px}.data-table th{color:#5b6b84;background:#f8fbff}.badge{display:inline-flex;border-radius:99px;padding:5px 9px;font-size:11px;font-weight:700}.badge.pending{background:#fff4df;color:#b56a00}.badge.approved,.badge.completed{background:#e7fbef;color:#147b43}.badge.rejected,.badge.cancelled{background:#fff0f0;color:#bf3131}.badge.assigned,.badge.accepted{background:#e6f0ff;color:#1769dd}.admin-layout{display:grid;grid-template-columns:230px 1fr;gap:18px}.sidebar{background:#112946;border-radius:14px;padding:16px;color:#fff;min-height:600px}.sidebar .side-brand{font-size:18px;font-weight:800;padding:7px 8px 18px}.sidebar a{display:block;text-decoration:none;color:#d8e6f5;padding:11px 10px;border-radius:8px;font-size:13px}.sidebar a:hover,.sidebar a.active{background:#1f4673;color:#fff}.admin-main{min-width:0}.quick-actions{display:flex;gap:8px;flex-wrap:wrap}.location-box{padding:14px;border:1px dashed #aec9f6;background:#f9fbff;border-radius:10px;color:#50617d;font-size:12px}.helper{font-size:11px;color:var(--muted)}.empty{padding:32px;text-align:center;color:var(--muted)}@media(max-width:1050px){.hero-grid,.split,.dashboard-grid{grid-template-columns:1fr}.service-grid{grid-template-columns:repeat(3,1fr)}.feature-strip{grid-template-columns:repeat(2,1fr)}.admin-layout{grid-template-columns:1fr}.sidebar{min-height:0}.sidebar nav{display:flex;overflow:auto}.sidebar a{white-space:nowrap}.topbar{gap:10px}.main-nav{display:none}.hero-copy h1{font-size:34px}}@media(max-width:640px){.page-shell{padding:14px}.topbar{height:58px;padding:0 14px}.brand{font-size:19px}.brand-mark{width:29px;height:29px}.nav-actions>a:not(.btn){display:none}.booking-widget,.form-grid{grid-template-columns:1fr}.service-grid{grid-template-columns:1fr 1fr}.stats{grid-template-columns:1fr 1fr}.feature-strip{grid-template-columns:1fr}.site-footer{grid-template-columns:1fr;padding:22px}.hero-copy{padding:22px}.hero-copy h1{font-size:30px}.form-card{margin:0}.map-panel{min-height:290px}}

/* Bản đồ chọn điểm trực tiếp */
.live-map-card{min-height:370px;overflow:hidden;position:relative;background:#e9f0eb}.map-topline{position:absolute;z-index:3;top:14px;left:14px;right:14px;display:flex;justify-content:space-between;gap:10px;align-items:center;pointer-events:none}.live-pill{padding:8px 10px;background:#fff;border-radius:10px;box-shadow:var(--shadow);font-size:11px;font-weight:800;color:#1267f4}.map-hint{padding:8px 10px;background:rgba(17,41,70,.9);border-radius:10px;color:#fff;font-size:11px;font-weight:600}.map-canvas{width:100%;height:100%;min-height:370px;background:#e9f0eb;z-index:1}.map-side-help{position:absolute;z-index:3;bottom:14px;left:14px;max-width:260px;background:#fff;padding:13px;border-radius:11px;box-shadow:var(--shadow);pointer-events:none}.map-side-help b{display:block;font-size:12px;margin-bottom:5px}.map-side-help small{display:block;color:var(--muted);line-height:1.45;font-size:11px}.map-legend{display:flex;gap:10px;margin-top:9px;font-size:10px;color:#53627a}.map-legend span{display:flex;align-items:center;gap:4px}.legend-dot{display:inline-block;width:8px;height:8px;border-radius:50%}.legend-dot.green{background:#13a760}.legend-dot.red{background:#e44343}.booking-widget-map{grid-template-columns:1.1fr 1.1fr .9fr auto}.map-action-row{grid-column:1/-1;display:flex;gap:8px;align-items:center;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:10px}.map-trigger{border:0;background:#f2f7ff;color:#1267f4;font:inherit;font-size:11px;font-weight:700;padding:7px 9px;border-radius:8px;cursor:pointer}.map-trigger:hover{background:#e3efff}.place-field{position:relative}.input-with-icon{position:relative}.input-with-icon .input{padding-left:28px}.point-dot{position:absolute;left:11px;top:50%;z-index:2;width:10px;height:10px;margin-top:-5px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 1px rgba(0,0,0,.08)}.pickup-dot{background:#14ad68}.dropoff-dot{background:#ed4141}.place-suggestions{display:none;position:absolute;z-index:35;top:calc(100% + 3px);left:0;right:0;background:#fff;border:1px solid #d8e5f5;border-radius:10px;box-shadow:0 12px 26px rgba(22,51,96,.17);overflow:hidden;max-height:250px;overflow-y:auto}.place-suggestions.visible{display:block}.suggestion-item{display:flex;gap:9px;width:100%;text-align:left;border:0;border-bottom:1px solid #edf2f9;background:#fff;padding:10px 12px;color:#263852;font:inherit;font-size:12px;line-height:1.4;cursor:pointer}.suggestion-item:hover{background:#f2f7ff}.suggestion-item:last-child{border-bottom:0}.suggestion-loading,.suggestion-empty{padding:12px;color:#667791;font-size:12px}.hs-map-marker-wrap{background:transparent!important;border:0!important}.hs-map-marker{display:grid;place-items:center;width:38px;height:38px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);font-size:17px;color:#fff;border:3px solid #fff;box-shadow:0 4px 12px rgba(0,0,0,.24)}.hs-map-marker>*{transform:rotate(45deg)}.hs-map-marker.pickup{background:#11ab67}.hs-map-marker.dropoff{background:#ed4141}.booking-layout{display:grid;grid-template-columns:minmax(0,.88fr) minmax(420px,1.12fr);gap:20px;align-items:stretch}.booking-form-panel{position:relative;z-index:5}.booking-map-panel{overflow:hidden;min-height:680px;display:flex;flex-direction:column}.booking-map-head{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:18px 18px 13px}.booking-map-head .eyebrow{font-size:10px;padding:5px 8px}.booking-map-head h2{font-size:18px;margin:6px 0 0}.booking-map{min-height:0;flex:1}.map-choice-toggle{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}.choice-btn{border:1px solid #dce8f8;background:#fff;color:#52637d;padding:8px 10px;border-radius:8px;font:inherit;font-weight:700;font-size:11px;cursor:pointer}.choice-btn.active{background:#1267f4;color:#fff;border-color:#1267f4}.map-route-summary{display:flex;justify-content:space-between;gap:12px;padding:13px 16px;background:#f8fbff;color:#5a6b84;font-size:11px;line-height:1.4;border-top:1px solid var(--line)}.map-route-summary strong{color:#1267f4;text-align:right}.location-box{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.location-box strong{color:#1267f4;font-size:11px}.leaflet-container{font-family:"Be Vietnam Pro",Arial,sans-serif}.leaflet-control-attribution{font-size:9px!important}.leaflet-popup-content{font-size:12px}
@media(max-width:1050px){.booking-layout{grid-template-columns:1fr}.booking-map-panel{min-height:500px}.booking-map{min-height:420px}.booking-widget-map{grid-template-columns:1fr 1fr}.live-map-card{min-height:420px}.map-canvas{min-height:420px}}
@media(max-width:640px){.booking-widget-map{grid-template-columns:1fr}.map-topline{align-items:flex-start;flex-direction:column;right:auto}.map-hint{max-width:235px}.map-side-help{right:12px;max-width:none}.live-map-card,.map-canvas{min-height:400px}.booking-map-panel{min-height:450px}.booking-map-head{align-items:flex-start;flex-direction:column}.map-choice-toggle{justify-content:flex-start}.booking-map{min-height:330px}.map-route-summary{flex-direction:column}.map-route-summary strong{text-align:left}.location-box{align-items:flex-start;flex-direction:column}}

/* V4: điều phối tài xế gần nhất + GPS trực tiếp */
.notification-chip{position:relative;display:inline-grid;place-items:center;width:36px;height:36px;border-radius:10px;background:#f2f7ff;color:#0c67ef;text-decoration:none;font-size:16px}.notification-chip b{position:absolute;right:-5px;top:-6px;min-width:17px;height:17px;padding:1px 4px;border-radius:99px;background:#e74848;color:#fff;font-size:9px;line-height:15px;text-align:center}.small-line{font-size:12px;margin:5px 0 0}.inline-form{display:inline}.live-driver-hint{margin-top:16px;padding:11px 13px;border-radius:10px;background:#f2f8ff;color:#245caa;border:1px solid #dceafe;font-size:12px;font-weight:600}.offer-count{display:inline-grid;place-items:center;min-width:21px;height:21px;margin-left:6px;padding:0 6px;border-radius:99px;background:#1267f4;color:#fff;font-size:11px}.offer-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.offer-card{border:1px solid #dce7f5;border-radius:14px;padding:15px;background:linear-gradient(135deg,#fff,#f7fbff);box-shadow:0 8px 18px rgba(44,84,135,.06)}.offer-card.expired{opacity:.5;pointer-events:none}.offer-card h3{font-size:15px;margin:13px 0 8px}.offer-card p{font-size:12px;line-height:1.5;color:#42536d;margin:6px 0}.offer-card form{margin-top:13px}.offer-card form .btn{width:100%}.offer-top,.offer-meta{display:flex;align-items:center;gap:8px;justify-content:space-between}.offer-top b{font-size:13px}.offer-meta{border-top:1px solid #e7eef8;margin-top:12px;padding-top:10px;color:#5b6d87;font-size:11px}.distance-chip{background:#e9f8ef;color:#14834a;border-radius:99px;padding:5px 7px;font-size:10px;font-weight:800}.notification-list{display:grid;gap:9px}.notification-item{display:flex;gap:11px;padding:12px;border:1px solid #e4edf8;border-radius:11px;text-decoration:none;color:inherit;background:#fff}.notification-item:hover{border-color:#a9cbfb;background:#f8fbff}.notification-item.unread{border-left:4px solid #1267f4;background:#f6faff}.notification-item>span{font-size:20px;line-height:1.2}.notification-item b{font-size:13px}.notification-item p{margin:4px 0;color:#5d6f89;font-size:12px;line-height:1.45}.notification-item small{color:#8190a6;font-size:10px}.full-list .notification-item{padding:15px}.trip-layout{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(320px,.65fr);gap:20px;align-items:start}.trip-map-panel{overflow:hidden;min-height:600px;display:flex;flex-direction:column}.trip-map-top{display:flex;justify-content:space-between;align-items:flex-start;gap:15px;padding:18px 18px 13px}.trip-map-top h2{margin:6px 0 0;font-size:18px}.trip-map-canvas{height:500px;min-height:500px;flex:1}.trip-live-footer{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:12px 16px;border-top:1px solid var(--line);font-size:11px;color:#58708f;background:#f8fbff}.trip-live-footer span:last-child{color:#118754;font-weight:800}.trip-info-stack{display:grid;gap:14px}.route-step{display:flex;gap:10px;align-items:flex-start}.route-step>span{display:grid;place-items:center;width:31px;height:31px;border-radius:50%;background:#eef6ff;font-size:16px;flex:none}.route-step small{display:block;color:#7d8ba0;font-size:10px;text-transform:uppercase;font-weight:800;letter-spacing:.03em;margin-bottom:3px}.route-step b{display:block;font-size:12px;line-height:1.5;color:#243750}.route-line{height:25px;border-left:2px dashed #b9cce8;margin:0 0 0 15px}.fare-line{display:flex;justify-content:space-between;align-items:center;margin-top:18px;padding-top:13px;border-top:1px solid var(--line);font-size:12px;color:#697a91}.fare-line strong{color:#0c67ef;font-size:16px}.driver-card{display:flex;align-items:center;gap:11px}.driver-avatar{display:grid;place-items:center;width:45px;height:45px;border-radius:50%;background:#eef6ff;font-size:22px;flex:none}.driver-card b{font-size:14px}.driver-card p{margin:3px 0 8px;color:#60728d;font-size:11px}.live-dot{padding:5px 8px;border-radius:99px;background:#e9fbf0;color:#0b8f4b;font-size:10px;font-weight:800}.route-open{display:block;width:100%;margin-top:16px;text-align:center}.badge.in_progress{background:#e6f0ff;color:#1769dd}.badge.accepted{background:#e6f0ff;color:#1769dd}.badge.pending{background:#fff4df;color:#b56a00}.hidden{display:none!important}
@media(max-width:850px){.trip-layout{grid-template-columns:1fr}.trip-map-panel{min-height:470px}.trip-map-canvas{min-height:390px;height:390px}.offer-grid{grid-template-columns:1fr}}@media(max-width:640px){.notification-chip{width:32px;height:32px}.trip-map-top{padding:15px}.trip-live-footer{align-items:flex-start;flex-direction:column}.trip-map-canvas{min-height:340px;height:340px}.offer-top{flex-wrap:wrap}.offer-meta{align-items:flex-start;flex-direction:column}.quick-actions{align-items:stretch}.quick-actions .inline-form{display:flex;gap:6px;flex-wrap:wrap}.quick-actions .inline-form .btn{flex:1}.notification-item{padding:11px}.trip-info-stack{gap:12px}}

/* V5: giá/km theo tuyến map, điều phối realtime và bản đồ vận hành tài xế */
.hs-map-marker.driver{background:#6b59f6}.hs-map-marker.self{background:#0c67ef}.hs-map-marker i{font-style:normal}.fare-preview{display:flex;justify-content:space-between;gap:16px;padding:14px 16px;border:1px solid #cfe1fb;border-radius:13px;background:linear-gradient(135deg,#f5faff,#edf6ff)}.fare-preview>div{display:grid;gap:3px}.fare-preview small{font-size:10px;color:#71849f;font-weight:800;text-transform:uppercase;letter-spacing:.03em}.fare-preview b{font-size:14px;color:#174a8b}.fare-preview strong{font-size:22px;color:#0b67ed}.fare-preview span{font-size:10px;color:#61728c}.hero-fare-mini{margin-right:auto;font-size:11px;color:#536987}.hero-fare-mini b{color:#0b67ed}.offer-actions{display:flex;gap:8px;align-items:center;margin-top:13px}.offer-actions .btn{flex:1;justify-content:center}.driver-peer-map-canvas{height:400px;border:1px solid #d9e7f8;border-radius:13px;overflow:hidden}.peer-map-footer{padding:11px 12px;background:#f7fbff;border-radius:0 0 11px 11px;color:#58708f;font-size:11px;font-weight:600}.offer-modal-backdrop{position:fixed;inset:0;z-index:9999;display:grid;place-items:center;padding:16px;background:rgba(8,28,58,.55);backdrop-filter:blur(3px)}.offer-modal{position:relative;width:min(520px,100%);padding:22px;border-radius:18px;background:#fff;box-shadow:0 22px 70px rgba(0,0,0,.28);animation:hsOfferPop .22s ease-out}.offer-modal-close{position:absolute;right:12px;top:12px;width:34px;height:34px;border:0;border-radius:50%;background:#eef4fd;color:#32577e;font-size:23px;line-height:1;cursor:pointer}.offer-modal-head{display:flex;align-items:center;gap:12px;padding-right:30px}.offer-modal-head>span{display:grid;place-items:center;width:48px;height:48px;border-radius:14px;background:#e8f4ff;font-size:24px}.offer-modal-head small{font-size:10px;font-weight:800;letter-spacing:.07em;color:#0b67ed}.offer-modal-head h2{margin:3px 0 0;font-size:22px;color:#102d56}.offer-modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:18px 0}.offer-modal-grid>div{padding:11px;border:1px solid #e1ebf7;border-radius:11px;background:#fbfdff}.offer-modal-grid small{display:block;color:#6f819b;font-size:10px;margin-bottom:4px}.offer-modal-grid b{font-size:13px;color:#203b60}.offer-modal-grid b.price{color:#0b9a5b;font-size:18px}.offer-route{padding:12px;border-radius:12px;background:#f5f9fe}.offer-route p{display:flex;gap:7px;margin:6px 0;color:#334c70;font-size:12px;line-height:1.45}.offer-route strong{white-space:nowrap}.offer-modal-footer{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:18px}.live-toast-host{position:fixed;z-index:10000;top:76px;right:18px;display:grid;gap:9px;width:min(350px,calc(100vw - 32px))}.live-toast{position:relative;padding:13px 40px 13px 14px;border:1px solid #cfe1fb;border-left:4px solid #0b67ed;border-radius:12px;background:#fff;box-shadow:0 16px 36px rgba(20,61,115,.2);animation:hsOfferPop .24s ease-out}.live-toast b{display:block;color:#133561;font-size:13px}.live-toast p{margin:4px 0 0;color:#61728c;font-size:11px;line-height:1.4}.live-toast button{position:absolute;right:8px;top:8px;border:0;background:transparent;color:#6f819b;font-size:18px;cursor:pointer}@keyframes hsOfferPop{from{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:none}}@media(max-width:640px){.fare-preview{flex-direction:column;gap:10px}.offer-modal{padding:18px}.offer-modal-grid{grid-template-columns:1fr 1fr}.offer-modal-footer{align-items:stretch;flex-direction:column}.offer-modal-footer .btn{width:100%}.driver-peer-map-canvas{height:340px}.live-toast-host{top:66px;right:12px}.hero-fare-mini{width:100%;order:5}.offer-actions{flex-direction:column}.offer-actions .inline-form{width:100%;display:block}.offer-actions .btn{width:100%}}
/* V6: trang tải ứng dụng Android / iOS */
.app-download-hero{position:relative;overflow:hidden;padding:42px;max-width:950px;margin:0 auto;background:linear-gradient(135deg,#f5fbff,#fff)}.app-download-hero:after{content:"";position:absolute;width:260px;height:260px;border-radius:50%;right:-110px;top:-120px;background:#d8efff}.app-download-hero>*{position:relative;z-index:1}.app-download-hero h1{max-width:720px;margin:10px 0;font-size:34px;letter-spacing:-.03em}.app-download-hero p{max-width:760px;line-height:1.7}.app-requirements{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px}.app-requirements span{padding:9px 12px;border-radius:99px;background:#fff;border:1px solid #d7e7fa;font-size:11px;font-weight:700;color:#31577f}.app-download-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}.app-platform-card{padding:25px;display:grid;grid-template-columns:58px 1fr;gap:14px;align-items:start}.app-platform-card h2{margin:8px 0;font-size:20px}.app-platform-card p{grid-column:2;margin:0;color:#61748e;font-size:13px;line-height:1.6}.app-platform-icon{grid-row:span 2;display:grid;place-items:center;width:58px;height:58px;border-radius:17px;font-size:28px;font-weight:800}.app-platform-icon.android{background:#e6f8ed}.app-platform-icon.ios{background:#edf1f6;color:#19253b}.app-download-btn{grid-column:1/-1;margin-top:12px;justify-content:center}.app-steps{grid-column:1/-1;margin:4px 0 0;padding-left:20px;color:#4e617d;font-size:12px;line-height:1.8}.app-note{grid-column:1/-1!important;margin:0!important;padding:10px 12px;background:#fff8e9;border:1px solid #f6e7bd;border-radius:10px;color:#89620d!important;font-size:11px!important}.app-url-guide{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:15px 0}.app-url-guide>div{padding:14px;border:1px solid #dbe8f6;border-radius:11px;background:#fbfdff}.app-url-guide b{display:block;font-size:12px;color:#1e416b;margin-bottom:7px}.app-url-guide code{font-size:12px;color:#066ee8;word-break:break-all}@media(max-width:720px){.app-download-hero{padding:25px 20px}.app-download-hero h1{font-size:26px}.app-download-grid{grid-template-columns:1fr}.app-url-guide{grid-template-columns:1fr}.app-platform-card{padding:20px}}

/* V7: chat hỗ trợ HSMobile, cộng đồng tài xế và phát hành HSMGO Đặt Xe */
.hsmgo-community{align-items:stretch}.support-home-card,.driver-community-card{position:relative;overflow:hidden}.support-home-card:before,.driver-community-card:before{content:"";position:absolute;right:-38px;top:-54px;width:150px;height:150px;border-radius:50%;background:#eaf3ff}.driver-community-card:before{background:#e7fbef}.support-home-card>*,.driver-community-card>*{position:relative;z-index:1}.support-home-card h2,.driver-community-card h2{margin:9px 0;font-size:22px}.support-home-card p,.driver-community-card p{line-height:1.65;min-height:62px}.support-chat-widget{position:fixed;right:18px;bottom:18px;z-index:10050}.support-fab{display:flex;align-items:center;gap:8px;border:0;border-radius:999px;background:#0969ef;color:#fff;padding:12px 16px;box-shadow:0 14px 32px rgba(12,87,198,.32);font:700 13px/1 var(--font,inherit);cursor:pointer}.support-fab span{font-size:19px}.support-panel{display:none;position:absolute;right:0;bottom:62px;width:min(375px,calc(100vw - 28px));overflow:hidden;border:1px solid #d7e5f6;border-radius:18px;background:#fff;box-shadow:0 25px 65px rgba(14,48,94,.28)}.support-chat-widget.is-open .support-panel{display:flex;flex-direction:column;animation:hsOfferPop .2s ease-out}.support-panel header{position:relative;padding:16px 42px 14px 16px;background:linear-gradient(135deg,#0b68f0,#27a1f2);color:#fff}.support-panel header span{font-size:10px;font-weight:800;letter-spacing:.06em}.support-panel h3{margin:4px 0;font-size:17px}.support-panel header p{margin:5px 0 0;font-size:11px;line-height:1.45;opacity:.92}.support-panel header button{position:absolute;right:10px;top:12px;border:0;background:rgba(255,255,255,.18);color:#fff;border-radius:50%;width:30px;height:30px;font-size:20px;cursor:pointer}.support-messages{min-height:235px;max-height:345px;overflow:auto;padding:13px;background:#f6faff;display:flex;flex-direction:column;gap:9px}.chat-empty{padding:24px 12px;text-align:center;color:#6b7d96;font-size:12px;line-height:1.5}.support-bubble{max-width:86%;padding:9px 11px;border-radius:12px;background:#fff;border:1px solid #e2ebf6;box-shadow:0 3px 8px rgba(35,83,145,.04)}.support-bubble.from-user{align-self:flex-end;background:#e7f2ff;border-color:#cce2ff}.support-bubble small{display:block;font-size:9px;color:#6d7e95;margin-bottom:4px}.support-bubble p{margin:0;color:#223f64;font-size:12px;line-height:1.5;white-space:pre-wrap;word-break:break-word}.support-visitor-fields{display:grid;grid-template-columns:1fr 1fr;gap:7px;padding:9px 10px 0;background:#fff}.support-visitor-fields .input{min-width:0;padding:9px 10px;font-size:11px}.support-form{display:flex;gap:8px;padding:10px;border-top:1px solid #e4edf8;background:#fff}.support-form textarea,.driver-chat-form textarea,.support-admin-form textarea{resize:none;min-height:42px;border:1px solid #cbdced;border-radius:10px;padding:10px;font:12px/1.4 inherit;color:#183758;outline:none}.support-form textarea{flex:1}.support-form textarea:focus,.driver-chat-form textarea:focus,.support-admin-form textarea:focus{border-color:#4f9cff;box-shadow:0 0 0 3px #e4f0ff}.support-form .btn{padding:0 13px;align-self:stretch}.driver-chat-layout{display:grid;grid-template-columns:minmax(0,1fr) 280px;gap:20px;align-items:start}.driver-chat-room{overflow:hidden}.driver-chat-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;padding:25px 25px 17px;border-bottom:1px solid #e5edf7}.driver-chat-head h1{margin:8px 0;font-size:25px}.driver-chat-head p{max-width:610px;margin:0;line-height:1.6}.driver-chat-messages{height:470px;overflow:auto;padding:18px;background:linear-gradient(180deg,#f8fbff,#eff6ff);display:flex;flex-direction:column;gap:10px}.driver-chat-bubble{max-width:84%;padding:10px 12px;border:1px solid #dfeaf7;border-radius:13px;background:#fff;box-shadow:0 4px 12px rgba(43,85,142,.04)}.driver-chat-bubble.mine{align-self:flex-end;background:#e8f4ff;border-color:#c8e1ff}.driver-chat-meta{display:flex;gap:7px;align-items:baseline;flex-wrap:wrap}.driver-chat-meta b{font-size:12px;color:#174a8b}.driver-chat-meta span{font-size:10px;color:#70819a}.driver-chat-bubble p{margin:5px 0 0;white-space:pre-wrap;word-break:break-word;color:#243c5d;font-size:13px;line-height:1.5}.driver-chat-form{display:flex;gap:10px;padding:14px;border-top:1px solid #dfebf8}.driver-chat-form textarea{flex:1;min-height:48px}.driver-chat-form .btn{min-width:90px}.chat-rules{margin:0;padding:10px 20px 15px;color:#7888a0;font-size:10px;line-height:1.5}.driver-chat-side h2{margin:8px 0 12px;font-size:20px}.driver-online-number{display:flex;align-items:baseline;gap:8px;padding:14px 0;border-bottom:1px solid #e6eef7}.driver-online-number b{font-size:38px;color:#0b67ed}.driver-online-number span{font-size:11px;color:#667890;line-height:1.4}.driver-chat-person{display:flex;gap:10px;align-items:center;padding:16px 0}.driver-chat-person>span{display:grid;place-items:center;width:40px;height:40px;border-radius:50%;background:#e7f4ff;font-size:20px}.driver-chat-person b{display:block;font-size:13px}.driver-chat-person small{display:block;margin-top:3px;color:#6d7f98;font-size:10px}.driver-chat-side .btn{width:100%;justify-content:center}.driver-chat-gate{max-width:740px;margin:35px auto}.driver-chat-gate h1{margin:9px 0;font-size:28px}.driver-chat-gate p{max-width:620px;line-height:1.7;margin-bottom:20px}.support-admin-layout{display:grid;grid-template-columns:330px minmax(0,1fr);gap:18px;align-items:stretch;min-height:640px}.support-thread-list{overflow:hidden}.support-thread-list header{padding:17px;border-bottom:1px solid #e5edf8}.support-thread-list h2{font-size:17px;margin:0 0 5px}.support-thread-list p{margin:0;font-size:11px;line-height:1.5}.support-thread-scroll{overflow:auto;max-height:720px}.support-thread{position:relative;display:flex;gap:10px;padding:12px 14px;color:inherit;text-decoration:none;border-bottom:1px solid #eef3f9}.support-thread:hover,.support-thread.active{background:#f1f7ff}.support-thread-avatar{display:grid;place-items:center;flex:0 0 32px;height:32px;border-radius:50%;background:#dceeff;color:#0a67e8;font-size:13px;font-weight:800}.support-thread>span:nth-child(2){min-width:0;display:block;flex:1}.support-thread b,.support-thread small,.support-thread em{display:block}.support-thread b{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.support-thread small{font-size:9px;color:#708199;margin-top:3px}.support-thread em{font-size:10px;color:#71839d;margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-style:normal}.support-thread>i{position:absolute;right:10px;top:10px;display:grid;place-items:center;min-width:18px;height:18px;padding:0 5px;border-radius:20px;background:#0a69f0;color:#fff;font-style:normal;font-size:9px;font-weight:800}.support-admin-room{display:flex;flex-direction:column;overflow:hidden}.support-admin-room>header{padding:17px 20px;border-bottom:1px solid #e3edf8}.support-admin-room h2{font-size:18px;margin:5px 0 0}.support-admin-messages{flex:1;min-height:460px;max-height:600px;overflow:auto;padding:18px;background:#f8fbff;display:flex;flex-direction:column;gap:10px}.admin-chat-bubble{max-width:78%;padding:10px 12px;border-radius:12px;border:1px solid #dfeaf6;background:#fff}.admin-chat-bubble.from-admin{align-self:flex-end;background:#e7f3ff;border-color:#c9e1ff}.admin-chat-bubble small{font-size:9px;color:#72839a}.admin-chat-bubble p{margin:4px 0 0;color:#243e61;font-size:12px;line-height:1.5}.support-admin-form{display:flex;gap:10px;padding:14px;border-top:1px solid #e0ebf7}.support-admin-form textarea{flex:1;min-height:50px}.support-admin-form .btn{min-width:120px}@media(max-width:900px){.driver-chat-layout{grid-template-columns:1fr}.driver-chat-side{order:-1}.support-admin-layout{grid-template-columns:1fr}.support-thread-scroll{max-height:260px}.support-admin-messages{max-height:500px}}@media(max-width:640px){.support-chat-widget{right:10px;bottom:10px}.support-fab{padding:11px 13px}.support-fab b{font-size:11px}.support-panel{bottom:55px;width:calc(100vw - 20px)}.support-visitor-fields{grid-template-columns:1fr}.driver-chat-head{padding:18px;flex-direction:column}.driver-chat-head h1{font-size:22px}.driver-chat-messages{height:390px;padding:12px}.driver-chat-form{padding:10px;flex-direction:column}.driver-chat-form .btn{width:100%}.driver-chat-bubble{max-width:93%}.support-admin-form{flex-direction:column}.support-admin-form .btn{width:100%}}
/* V8.3 Google Maps + GPS khách/tài xế */
.driver-live-status{margin:6px 0 9px!important;color:#1769dd!important;font-size:12px!important;font-weight:600}.trip-live-footer{flex-wrap:wrap}.trip-live-footer [data-customer-gps]{color:#b36b00}.map-canvas .gm-style{font-family:"Be Vietnam Pro",Arial,sans-serif}.map-canvas .gm-style-iw{font-family:"Be Vietnam Pro",Arial,sans-serif}.helper{display:block;margin-top:5px;line-height:1.5}.form-card .divider{height:1px;background:#e8eef7;margin:8px 0 4px}.trip-map-canvas{min-height:500px}@media(max-width:640px){.trip-map-canvas{min-height:380px}.trip-live-footer{gap:7px}.trip-live-footer span{font-size:10px}}
