/* Taxi Booking Form v2.0 */
.tbk-wrap{font-family:'Poppins',Arial,sans-serif;max-width:820px;margin:0 auto}
#tbk-booking-form{background:#fff;padding:28px;border-radius:14px;box-shadow:0 10px 30px rgba(0,0,0,.08)}
.tbk-title{font-size:22px;color:#1a1a2e;margin:0 0 22px;font-weight:700}
.tbk-field{margin-bottom:16px}
.tbk-field label,#tbk-booking-form label{font-weight:600;font-size:13.5px;color:#333;display:block;margin-bottom:5px}
#tbk-booking-form input,#tbk-booking-form select,#tbk-booking-form textarea{width:100%;padding:11px 14px;border-radius:8px;border:1.5px solid #e0e0e0;font-family:inherit;font-size:13.5px;color:#333;outline:none;transition:border .2s;box-sizing:border-box}
#tbk-booking-form input:focus,#tbk-booking-form select:focus,#tbk-booking-form textarea:focus{border-color:#ff7a18}
.tbk-divider{border:none;border-top:1.5px solid #f0f0f0;margin:22px 0}
.tbk-row{display:flex;gap:16px}
.tbk-col{flex:1;min-width:0}
.tbk-icon-wrap{position:relative;display:flex;align-items:center}
.tbk-icon-wrap input{padding-left:38px !important;width:100%}
.tbk-iicon{position:absolute;left:11px;font-size:16px;color:#aaa;pointer-events:none;z-index:1}
.tbk-btn-orange{padding:11px 20px;border:none;border-radius:8px;background:#ff7a18;color:#fff;cursor:pointer;font-weight:600;font-family:inherit;font-size:13.5px;transition:background .2s;white-space:nowrap}
.tbk-btn-orange:hover{background:#e06010}
.tbk-btn-grey{padding:7px 14px;border:none;border-radius:7px;background:#f0f0f0;color:#444;cursor:pointer;font-weight:500;font-family:inherit;font-size:13px;margin:6px 0 4px;transition:background .2s}
.tbk-btn-grey:hover{background:#e0e0e0}
.tbk-btn-red{padding:7px 12px;border:none;border-radius:6px;background:#ff4444;color:#fff;cursor:pointer;font-family:inherit;font-size:12px;flex-shrink:0}
.tbk-type-btns{display:flex;border-radius:9px;overflow:hidden;border:1.5px solid #ff7a18;margin-bottom:6px}
.tbk-type-btns button{flex:1;padding:10px;border:none;background:#fff;color:#ff7a18;font-weight:600;cursor:pointer;font-family:inherit;font-size:13.5px;transition:all .2s}
.tbk-type-btns button.active{background:#ff7a18;color:#fff}
.tbk-toggle-wrap{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.tbk-toggle-wrap span{font-size:13px;color:#666}
.tbk-toggle{width:48px;height:26px;background:#ccc;border-radius:20px;position:relative;cursor:pointer;transition:background .3s;flex-shrink:0}
.tbk-toggle::after{content:"";position:absolute;width:20px;height:20px;background:#fff;border-radius:50%;top:3px;left:3px;transition:left .3s}
.tbk-toggle.active{background:#ff7a18}
.tbk-toggle.active::after{left:25px}
.tbk-phone-row{display:flex;gap:10px;align-items:center}
.tbk-phone-row .tbk-icon-wrap{flex:1}
.tbk-otp-row{display:flex;gap:10px;align-items:center}
.tbk-otp-row input{flex:1}
.tbk-verified{display:inline-block;background:#e8f5e9;color:#27ae60;padding:6px 12px;border-radius:20px;font-size:13px;font-weight:600;margin-top:8px}
.tbk-fp-bar{display:flex;align-items:center;justify-content:space-between;background:#fff8f3;border:1.5px solid #ffe0c8;border-radius:10px;padding:12px 16px;margin-bottom:12px}
.tbk-fp-left{display:flex;align-items:center;gap:10px}
.tbk-fp-icon{font-size:20px}
.tbk-fp-title{font-weight:700;font-size:15px;color:#ff7a18}
.tbk-fp-sub{font-size:12px;color:#888}
.tbk-vehicle-wrap{border:1.5px solid #e8e8e8;border-radius:10px;overflow:hidden}
.tbk-vehicle-card{display:flex;align-items:center;padding:13px 15px;background:#fff;cursor:pointer;border-bottom:1px solid #f0f0f0;transition:background .15s}
.tbk-vehicle-card:last-child{border-bottom:none}
.tbk-vehicle-card:hover{background:#fff8f3}
.tbk-vehicle-card.selected{background:#fff3ea;border-left:4px solid #ff7a18}
.tbk-vehicle-card.selected .tbk-vc-name{color:#ff7a18}
.tbk-vc-icon{width:52px;height:44px;margin-right:13px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.tbk-vc-icon svg{width:40px;height:40px;fill:#ff7a18;overflow:visible;display:block}
.tbk-vc-info{flex:1}
.tbk-vc-name{font-weight:700;font-size:14px;color:#222}
.tbk-vc-pax{font-size:12px;color:#888;margin-top:2px}
.tbk-vc-right{text-align:right;flex-shrink:0}
.tbk-vc-price{font-size:12px;color:#555;font-weight:600}
.tbk-vc-dest{font-size:11px;color:#ff7a18;font-weight:600}
.tbk-collapse-btn{display:flex;align-items:center;justify-content:space-between;padding:11px 15px;background:#f9f9f9;border-top:1px solid #e8e8e8;cursor:pointer;user-select:none}
.tbk-collapse-btn span:first-child{font-weight:600;font-size:14px;color:#333}
.tbk-collapse-btn span:last-child{font-size:20px;color:#555}
.tbk-extra-field{display:flex;gap:10px;margin-bottom:8px;align-items:center}
.tbk-extra-field input{margin:0 !important;flex:1}
.tbk-payment-box{border:1.5px solid #f0f0f0;padding:16px;border-radius:10px;margin-top:10px;background:#fafafa}
#tbk-card-element{padding:12px;background:#fff;border:1.5px solid #e0e0e0;border-radius:8px}
/* Route info */
.tbk-route-summary{display:flex;gap:20px;padding:10px 14px;background:#fff8f3;border:1.5px solid #ffe0c8;border-radius:8px;flex-wrap:wrap}
.tbk-route-item{font-size:13.5px;color:#333}
/* Fare box */
.tbk-fare-fixed,.tbk-fare-estimate{padding:14px 18px;border-radius:10px;background:linear-gradient(135deg,#ff7a18,#ff4500);color:#fff}
.tbk-fare-label{display:block;font-size:12px;opacity:.85;margin-bottom:4px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.tbk-fare-amount{display:block;font-size:28px;font-weight:700;line-height:1}
.tbk-fare-note{display:block;font-size:11px;opacity:.8;margin-top:5px}
/* Messages */
.tbk-msg{padding:12px 16px;border-radius:8px;margin-top:12px;font-size:13.5px;font-weight:500}
.tbk-msg.success{background:#e8f5e9;color:#2e7d32;border:1px solid #c8e6c9}
.tbk-msg.error{background:#fdecea;color:#c62828;border:1px solid #ffcdd2}
.tbk-error{color:#e74c3c;font-size:13px;margin-top:6px}
.tbk-info{font-size:12px;color:#888;margin:8px 0 0}
/* Confirm button */
.tbk-confirm-btn{width:100%;padding:14px;border:none;border-radius:10px;background:linear-gradient(135deg,#ff7a18,#ff4500);color:#fff;cursor:pointer;font-weight:700;font-family:inherit;font-size:16px;letter-spacing:.5px;transition:opacity .2s;margin-top:8px}
.tbk-confirm-btn:hover{opacity:.9}
.tbk-confirm-btn:disabled{opacity:.6;cursor:not-allowed}
/* Mobile */
@media(max-width:600px){
  #tbk-booking-form{padding:16px;border-radius:0;box-shadow:none}
  .tbk-row{flex-direction:column;gap:10px}
  .tbk-phone-row{flex-direction:column;gap:8px}
  .tbk-phone-row .tbk-icon-wrap,.tbk-phone-row .tbk-btn-orange{width:100%}
  .tbk-otp-row{flex-direction:column}
  .tbk-otp-row input,.tbk-otp-row button{width:100%}
  .tbk-vc-icon svg{width:32px;height:32px}
  .tbk-confirm-btn{position:sticky;bottom:12px;box-shadow:0 4px 20px rgba(255,122,24,.4)}
  .tbk-fare-amount{font-size:22px}
}
