/*
Theme Name: Korean Black Car Draft
Theme URI: http://bigbang.local/
Description: Local draft child theme for Korean airport taxi / black car booking site, based on Kingcabs.
Author: Hommy for JP
Template: kingcabs
Version: 0.1.0
Text Domain: korean-blackcar
*/

:root {
  --kb-bg: #07090d;
  --kb-panel: #111722;
  --kb-panel-2: #18202d;
  --kb-gold: #d6a94f;
  --kb-gold-2: #f0cf7a;
  --kb-text: #f7f4ec;
  --kb-muted: #b7bdc8;
  --kb-line: rgba(255,255,255,.12);
  --kb-green: #23c55e;
}

body {
  background: var(--kb-bg);
  color: var(--kb-text);
  font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.main-header,
.top-header,
.logo-nav-wrapper,
.header-lower {
  background: #06080c !important;
  border-color: rgba(255,255,255,.08) !important;
}

.site-title a,
.site-description,
.main-navigation a,
.topheader-list a { color: #fff !important; }
.site-title a { letter-spacing: -.03em; font-weight: 800; }
.site-description { opacity: .72; }

.kb-landing a { color: inherit; }
.kb-landing {
  background:
    radial-gradient(circle at 15% 10%, rgba(214,169,79,.18), transparent 35%),
    linear-gradient(180deg, #080b11 0%, #0a0d13 48%, #07090d 100%);
  color: var(--kb-text);
}
.kb-container { width: min(1180px, calc(100% - 32px)); margin: 0 auto; }
.kb-eyebrow { color: var(--kb-gold-2); text-transform: uppercase; letter-spacing: .14em; font-weight: 800; font-size: 13px; }
.kb-hero { padding: 76px 0 54px; position: relative; overflow: hidden; }
.kb-hero-grid { display: grid; grid-template-columns: minmax(0,1.05fr) minmax(340px,.78fr); gap: 42px; align-items: center; }
.kb-hero h1 { font-size: clamp(42px, 6vw, 76px); line-height: .98; color: #fff; margin: 14px 0 20px; letter-spacing: -.055em; }
.kb-hero p { color: var(--kb-muted); font-size: 20px; line-height: 1.65; max-width: 680px; }
.kb-hero strong { color: #fff; }
.kb-hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 30px; }
.kb-btn { display: inline-flex; align-items: center; justify-content: center; gap: 9px; min-height: 52px; padding: 0 22px; border-radius: 999px; font-weight: 800; text-decoration: none !important; border: 1px solid transparent; transition: .18s ease; }
.kb-btn-primary { background: linear-gradient(135deg, var(--kb-gold), var(--kb-gold-2)); color: #111 !important; box-shadow: 0 18px 40px rgba(214,169,79,.22); }
.kb-btn-secondary { border-color: var(--kb-line); color: #fff !important; background: rgba(255,255,255,.06); }
.kb-btn:hover { transform: translateY(-1px); filter: brightness(1.05); }
.kb-trust-row { display: flex; flex-wrap: wrap; gap: 18px; margin-top: 28px; color: #dbe0ea; font-size: 14px; }
.kb-trust-row span { display: inline-flex; gap: 7px; align-items: center; }
.kb-trust-row span:before { content: "✓"; color: var(--kb-green); font-weight: 900; }

.kb-card { background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.035)); border: 1px solid var(--kb-line); border-radius: 28px; box-shadow: 0 22px 80px rgba(0,0,0,.35); }
.kb-quote-card { padding: 26px; }
.kb-quote-card h2 { color: #fff; font-size: 27px; margin: 0 0 6px; }
.kb-quote-card p { font-size: 15px; line-height: 1.5; margin: 0 0 20px; }
.kb-form { display: grid; gap: 12px; }
.kb-field label { display: block; color: #d7dce5; font-size: 13px; font-weight: 800; margin: 0 0 6px; }
.kb-field input, .kb-field select, .kb-field textarea { width: 100%; border-radius: 14px; border: 1px solid rgba(255,255,255,.13); background: rgba(0,0,0,.25); color: #fff; padding: 13px 14px; min-height: 48px; }
.kb-field input::placeholder, .kb-field textarea::placeholder { color: rgba(255,255,255,.45); }
.kb-note { font-size: 12px !important; color: #9ea7b6 !important; margin-top: 12px !important; }

.kb-section { padding: 66px 0; }
.kb-section-head { display: flex; align-items: end; justify-content: space-between; gap: 28px; margin-bottom: 26px; }
.kb-section h2 { color: #fff; font-size: clamp(30px, 4vw, 46px); line-height: 1.1; margin: 8px 0 0; letter-spacing: -.035em; }
.kb-section-head p { color: var(--kb-muted); max-width: 540px; font-size: 17px; line-height: 1.6; margin: 0; }
.kb-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.kb-feature { padding: 24px; }
.kb-feature b { display: block; color: #fff; font-size: 20px; margin: 12px 0 8px; }
.kb-feature p { color: var(--kb-muted); line-height: 1.55; margin: 0; }
.kb-icon { width: 44px; height: 44px; border-radius: 14px; background: rgba(214,169,79,.14); color: var(--kb-gold-2); display: grid; place-items: center; font-size: 22px; }

.kb-routes { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.kb-route { padding: 24px; display:flex; justify-content:space-between; gap:20px; align-items:center; }
.kb-route h3 { color:#fff; margin:0 0 6px; font-size:22px; }
.kb-route p { color:var(--kb-muted); margin:0; }
.kb-pill { white-space:nowrap; border:1px solid rgba(214,169,79,.35); color:var(--kb-gold-2); border-radius:999px; padding:8px 12px; font-weight:800; font-size:13px; }

.kb-cta { padding: 34px; display:grid; grid-template-columns: 1fr auto; gap:24px; align-items:center; background: linear-gradient(135deg, rgba(214,169,79,.20), rgba(255,255,255,.05)); }
.kb-cta h2 { margin:0 0 8px; }
.kb-cta p { color:var(--kb-muted); margin:0; font-size:17px; }

@media (max-width: 900px) {
  .kb-hero-grid, .kb-grid-3, .kb-routes, .kb-cta { grid-template-columns: 1fr; }
  .kb-section-head { display:block; }
  .kb-hero { padding-top: 42px; }
  .kb-quote-card { padding: 20px; }
}

/* Korean header/logo cleanup */
.logo-section { padding: 14px 0 !important; }
.logo-left, .logo.site-branding { max-width: 360px; }
.logo.site-branding { display: flex; flex-direction: column; justify-content: center; }
.logo.site-branding .site-title {
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1.15 !important;
  font-family: -apple-system, BlinkMacSystemFont, "Apple SD Gothic Neo", "Noto Sans KR", "Malgun Gothic", "Segoe UI", sans-serif !important;
  font-size: 24px !important;
  font-weight: 850 !important;
  letter-spacing: -0.05em !important;
  white-space: nowrap;
}
.logo.site-branding .site-title a {
  color: #fff !important;
  text-decoration: none !important;
}
.logo.site-branding .site-description {
  margin: 4px 0 0 !important;
  padding: 0 !important;
  line-height: 1.25 !important;
  font-family: -apple-system, BlinkMacSystemFont, "Apple SD Gothic Neo", "Noto Sans KR", "Malgun Gothic", "Segoe UI", sans-serif !important;
  font-size: 12px !important;
  letter-spacing: -0.03em !important;
  color: rgba(255,255,255,.68) !important;
  white-space: nowrap;
}
@media (max-width: 700px) {
  .logo-left, .logo.site-branding { max-width: 240px; }
  .logo.site-branding .site-title { font-size: 19px !important; }
  .logo.site-branding .site-description { display: none; }
}

/* Pricing calculator draft */
.kb-pricing-card { padding: 26px; }
.kb-pricing-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.kb-pricing-card .kb-field small { display:block; margin-top:6px; color:#8f99aa; line-height:1.35; }
.kb-price-result { margin-top: 18px; padding: 20px; border-radius: 20px; background: rgba(214,169,79,.12); border: 1px solid rgba(214,169,79,.28); }
.kb-price-result strong { display:block; color:#fff; font-size: 34px; line-height:1; margin-bottom:8px; }
.kb-price-result span { color: var(--kb-muted); font-size: 14px; line-height:1.5; }
.kb-rate-list { display:grid; grid-template-columns: repeat(3,1fr); gap: 12px; margin-top:18px; }
.kb-rate-item { padding:16px; border-radius:18px; background:rgba(255,255,255,.05); border:1px solid var(--kb-line); }
.kb-rate-item b { display:block; color:#fff; font-size:16px; margin-bottom:5px; }
.kb-rate-item span { color:var(--kb-gold-2); font-weight:900; }
@media (max-width: 900px) { .kb-pricing-grid, .kb-rate-list { grid-template-columns: 1fr; } }

/* BigBang Ride full landing polish */
.kb-form-row { display:grid; grid-template-columns: 1fr 1fr; gap:12px; }
.kb-grid-5 { display:grid; grid-template-columns: repeat(5, 1fr); gap:16px; }
.kb-service { padding:22px; min-height: 250px; display:flex; flex-direction:column; }
.kb-service h3 { color:#fff; font-size:21px; line-height:1.2; margin:14px 0 9px; letter-spacing:-.03em; }
.kb-service p { color:var(--kb-muted); line-height:1.55; margin:0 0 18px; font-size:15px; }
.kb-service span { margin-top:auto; color:var(--kb-gold-2); font-weight:900; border-top:1px solid var(--kb-line); padding-top:14px; }
.kb-card-title { color:#fff; margin:0 0 18px; font-size:24px; letter-spacing:-.03em; }
.kb-rate-list-top { margin-bottom:18px; }
.kb-step { width:44px; height:44px; border-radius:999px; display:grid; place-items:center; background:linear-gradient(135deg,var(--kb-gold),var(--kb-gold-2)); color:#111; font-weight:950; font-size:20px; }
.logo-right-info.k-button a, .btn.btn-primary { background:linear-gradient(135deg,var(--kb-gold),var(--kb-gold-2)) !important; color:#111 !important; border-color:transparent !important; }
.kb-landing h1, .kb-landing h2, .kb-landing h3, .kb-landing b, .kb-landing p, .kb-landing label, .kb-landing input, .kb-landing select, .kb-landing small, .kb-landing span {
  font-family: -apple-system, BlinkMacSystemFont, "Apple SD Gothic Neo", "Noto Sans KR", "Malgun Gothic", "Segoe UI", sans-serif;
}
@media (max-width: 1180px) { .kb-grid-5 { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 760px) { .kb-grid-5, .kb-form-row { grid-template-columns: 1fr; } .kb-service { min-height:auto; } }
.kb-service-link { color: var(--kb-gold-2) !important; font-weight: 900; margin: 0 0 14px; display:inline-flex; text-decoration:none !important; }
.kb-service-link:after { content:'→'; margin-left:6px; }
.page .entry-content h2, .page .entry-content h3 { color:#101828; letter-spacing:-.03em; }
.page .entry-content p, .page .entry-content li { font-size:17px; line-height:1.75; }
.page .entry-content ul { margin-left: 1.2em; }
.kb-jfk-rate-list { max-height: 560px; overflow:auto; padding-right:6px; }
.kb-jfk-rate-list .kb-rate-item { min-height: 86px; }
.kb-jfk-rate b { font-size:14px; line-height:1.35; }
.kb-jfk-rate span { font-size:18px; }
.kb-pay-rate { margin-top:12px; width:100%; border:0; border-radius:999px; min-height:38px; padding:0 12px; background:rgba(214,169,79,.16); color:var(--kb-gold-2); font-weight:900; cursor:pointer; }
.kb-pay-rate:hover { background:linear-gradient(135deg,var(--kb-gold),var(--kb-gold-2)); color:#111; }
.kb-checkout-panel { margin-top:18px; display:grid; grid-template-columns:1fr auto; gap:22px; align-items:center; padding:24px; border-radius:24px; background:rgba(255,255,255,.06); border:1px solid var(--kb-line); }
.kb-checkout-panel h3 { margin:6px 0; color:#fff; font-size:26px; letter-spacing:-.04em; }
.kb-checkout-panel p { margin:0; color:var(--kb-muted); }
.kb-checkout-small { font-size:13px !important; margin-top:6px !important; }
.kb-checkout-total { text-align:right; min-width:220px; }
.kb-checkout-total span { display:block; color:var(--kb-muted); font-size:13px; font-weight:800; }
.kb-checkout-total strong { display:block; color:#fff; font-size:38px; line-height:1; margin:8px 0 14px; }
.kb-checkout-total small { display:block; color:#8f99aa; margin-top:8px; }
@media (max-width:760px){ .kb-checkout-panel { grid-template-columns:1fr; } .kb-checkout-total { text-align:left; } }

/* Region filter buttons for flat fare table */
.kb-region-filter {
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:16px;
  margin: 0 0 22px;
}
.kb-region-filter button {
  min-height:76px;
  border:0;
  border-radius:8px;
  background:#eba400;
  color:#fff;
  font-weight:900;
  cursor:pointer;
  box-shadow:0 14px 30px rgba(0,0,0,.18);
  transition:.16s ease;
  padding:12px 14px;
}
.kb-region-filter button span,
.kb-region-filter button small { display:block; color:#fff; line-height:1.25; }
.kb-region-filter button span { font-size:16px; letter-spacing:-.03em; }
.kb-region-filter button small { font-size:15px; opacity:.92; margin-top:4px; }
.kb-region-filter button:hover,
.kb-region-filter button.active { transform:translateY(-2px); background:linear-gradient(135deg,#f2b000,#d89200); box-shadow:0 18px 42px rgba(235,164,0,.28); }
@media (max-width:900px){ .kb-region-filter { grid-template-columns: repeat(2, 1fr); } }
@media (max-width:520px){ .kb-region-filter { grid-template-columns: 1fr; } }

/* Override region buttons: BigBang premium style, not yellow competitor style */
.kb-region-filter button {
  min-height:78px !important;
  border:1px solid rgba(214,169,79,.32) !important;
  border-radius:18px !important;
  background:linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,.035)) !important;
  color:#fff !important;
  box-shadow:0 18px 48px rgba(0,0,0,.22) !important;
}
.kb-region-filter button span,
.kb-region-filter button small { color:#fff !important; }
.kb-region-filter button small { color:var(--kb-muted) !important; opacity:1 !important; }
.kb-region-filter button:hover,
.kb-region-filter button.active {
  transform:translateY(-2px);
  background:linear-gradient(135deg, rgba(214,169,79,.24), rgba(255,255,255,.07)) !important;
  border-color:rgba(240,207,122,.78) !important;
  box-shadow:0 22px 54px rgba(214,169,79,.14) !important;
}
.kb-region-filter button.active span { color:var(--kb-gold-2) !important; }
.kb-schedule-total { padding:16px; border-radius:18px; background:rgba(214,169,79,.12); border:1px solid rgba(214,169,79,.28); }
.kb-schedule-total span { display:block; color:var(--kb-muted); font-size:13px; font-weight:800; }
.kb-schedule-total strong { display:block; color:#fff; font-size:32px; line-height:1; margin:7px 0; }
.kb-schedule-total small { display:block; color:#aeb6c5; line-height:1.4; }
.kb-schedule-pay { width:100%; border:0; cursor:pointer; }
.kb-addons, .kb-payment-choice { display:grid; gap:8px; padding:14px; border-radius:16px; background:rgba(255,255,255,.045); border:1px solid var(--kb-line); }
.kb-addons { grid-template-columns:1fr 1fr; }
.kb-addons label, .kb-payment-choice label { color:#d7dce5; font-size:13px; line-height:1.35; display:flex; gap:8px; align-items:flex-start; }
.kb-addons input, .kb-payment-choice input { width:auto; min-height:auto; margin-top:2px; }
#kb-payment-detail { display:block; margin-top:7px; color:var(--kb-gold-2); font-weight:800; }
@media (max-width:760px){ .kb-addons { grid-template-columns:1fr; } }
.kb-deposit-explain { margin:0 0 18px; padding:15px; border-radius:18px; background:rgba(35,197,94,.10); border:1px solid rgba(35,197,94,.28); }
.kb-deposit-explain b { display:block; color:#fff; font-size:15px; margin-bottom:5px; }
.kb-deposit-explain span { display:block; color:#c7d2df; font-size:13px; line-height:1.45; }
.kb-flat-options { margin-top:14px; display:grid; grid-template-columns:1fr 1fr; gap:9px; }
.kb-flat-options label { color:#d7dce5; font-size:13px; display:flex; gap:8px; align-items:flex-start; line-height:1.35; padding:10px; border-radius:12px; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); }
.kb-flat-options label span { font-weight:900; color:#fff; }
.kb-flat-options label small { display:block; color:#9ba6b6; margin-top:3px; }
.kb-flat-options input[type="number"] { width:74px; min-height:34px; border-radius:9px; margin-left:auto; background:rgba(0,0,0,.25); color:#fff; border:1px solid var(--kb-line); padding:4px 8px; }
.kb-flat-options input[type="checkbox"] { width:auto; min-height:auto; margin-top:2px; }
.kb-deposit-number { color:var(--kb-gold-2) !important; font-size:30px !important; }
@media (max-width:760px){ .kb-flat-options { grid-template-columns:1fr; } }

/* Full-width dark service pages */
body.page { background:#07090d !important; }
body.page .breadcrumb-wrapper,
body.page .breadcrumbs,
body.page .kingcabs-breadcrumb,
body.page .page-title-section,
body.page .breadcrumb { display:none !important; }
body.page .site-content,
body.page #content,
body.page .content-area { background:#07090d !important; }
.kb-page-shell { min-height:70vh; }
.kb-page-hero { padding:58px 0 34px; background:linear-gradient(180deg,#080b11 0%,#0a0d13 100%); border-top:1px solid rgba(255,255,255,.06); border-bottom:1px solid rgba(214,169,79,.18); }
.kb-page-hero h1 { color:#fff; font-size:clamp(34px,5vw,58px); line-height:1.08; margin:10px 0 12px; letter-spacing:-.055em; font-family:-apple-system,BlinkMacSystemFont,"Apple SD Gothic Neo","Noto Sans KR","Malgun Gothic","Segoe UI",sans-serif; }
.kb-page-hero p { color:var(--kb-muted); font-size:18px; line-height:1.65; max-width:820px; margin:0; }
.kb-page-content-section { padding:36px 0 76px; }
.kb-page-content { padding:38px; max-width:980px; margin:0 auto; }
.kb-page-content h2,
.kb-page-content h3 { color:#fff !important; font-family:-apple-system,BlinkMacSystemFont,"Apple SD Gothic Neo","Noto Sans KR","Malgun Gothic","Segoe UI",sans-serif; letter-spacing:-.04em; }
.kb-page-content h2 { font-size:32px; margin:0 0 20px; }
.kb-page-content h3 { font-size:23px; margin:30px 0 12px; }
.kb-page-content p,
.kb-page-content li { color:#d5dbe6 !important; font-size:17px; line-height:1.8; }
.kb-page-content strong { color:#fff; }
.kb-page-content ul { margin:0 0 18px 1.25em; }
.kb-page-content .kb-btn { margin-top:18px; margin-right:10px; }
/* Kill parent theme white breadcrumb/title strip */
.bread-cumb,
#breadcrumb,
.breadcrumb-trail,
.trail-items { display:none !important; height:0 !important; min-height:0 !important; padding:0 !important; margin:0 !important; overflow:hidden !important; background:transparent !important; border:0 !important; }

/* Remove duplicate lower calculator UI; keep flat fare checkout only */
.kb-pricing-card > .kb-pricing-grid,
.kb-pricing-card > .kb-price-result {
  display:none !important;
}
.kb-pricing-card .kb-card-title::after {
  content:'지역별 플랫 요금 카드를 선택하면 아래 결제 준비 영역에 반영됩니다.';
  display:block;
  margin-top:8px;
  color:var(--kb-muted);
  font-size:14px;
  font-weight:500;
  letter-spacing:0;
}

/* BigBang Ride logo concept 3 */
.logo.site-branding .site-title a {
  display:block !important;
  width:260px !important;
  height:64px !important;
  background:url('assets/bigbang-ride-logo-concept3.svg') left center / contain no-repeat !important;
  text-indent:-9999px !important;
  overflow:hidden !important;
  white-space:nowrap !important;
}
.logo.site-branding .site-title { line-height:0 !important; }
.logo.site-branding .site-description { display:none !important; }
.logo-left, .logo.site-branding { max-width:300px !important; }
@media (max-width:700px){
  .logo.site-branding .site-title a { width:210px !important; height:54px !important; }
  .logo-left, .logo.site-branding { max-width:230px !important; }
}

/* Logo refinement: closer to reference image */
.logo.site-branding .site-title a {
  width:230px !important;
  height:58px !important;
  background-size:contain !important;
}
@media (max-width:700px){
  .logo.site-branding .site-title a { width:190px !important; height:50px !important; }
}

/* Restore originally selected logo concept 3 */
.logo.site-branding .site-title a {
  width:260px !important;
  height:64px !important;
  background:url('assets/bigbang-ride-logo-concept3.svg') left center / contain no-repeat !important;
}
@media (max-width:700px){
  .logo.site-branding .site-title a { width:210px !important; height:54px !important; }
}

/* Apply actual generated concept 3 crop */
.logo.site-branding .site-title a {
  width:260px !important;
  height:82px !important;
  background:url('assets/bigbang-ride-logo-concept3-original.png') left center / contain no-repeat !important;
}
@media (max-width:700px){
  .logo.site-branding .site-title a { width:210px !important; height:66px !important; }
}

/* Apply actual generated concept 3 crop */
.logo.site-branding .site-title a {
  width:260px !important;
  height:82px !important;
  background:url('assets/bigbang-ride-logo-concept3-original.png') left center / contain no-repeat !important;
}
@media (max-width:700px){
  .logo.site-branding .site-title a { width:210px !important; height:66px !important; }
}

/* Correct concept 3 crop: bottom-left quadrant */
.logo.site-branding .site-title a {
  width:250px !important;
  height:76px !important;
  background:url('assets/bigbang-ride-logo-concept3-original.png') center center / contain no-repeat !important;
}
.logo.site-branding { overflow:visible !important; }
.logo-left { overflow:visible !important; }
@media (max-width:700px){
  .logo.site-branding .site-title a { width:205px !important; height:62px !important; }
}

/* Correct actual concept 3 crop: car silhouette + BigBang Ride only */
.logo.site-branding .site-title a {
  width:250px !important;
  height:92px !important;
  background:url('assets/bigbang-ride-logo-concept3-original.png') left center / contain no-repeat !important;
}
.logo-section { padding:8px 0 !important; }
.logo-left, .logo.site-branding { max-width:280px !important; overflow:visible !important; }
@media (max-width:700px){
  .logo.site-branding .site-title a { width:205px !important; height:76px !important; }
}

/* Tight concept 3 crop fix */
.logo.site-branding .site-title a {
  width:250px !important;
  height:110px !important;
  background:url('assets/bigbang-ride-logo-concept3-original.png') center center / contain no-repeat !important;
}
.logo-section { padding:4px 0 !important; }
.logo-left, .logo.site-branding, .site-branding, .site-title { overflow:visible !important; }
.logo-left, .logo.site-branding { max-width:280px !important; }
@media (max-width:700px){
  .logo.site-branding .site-title a { width:205px !important; height:92px !important; }
}

/* New clean BigBang Ride logo, concept 3 direction */
.logo.site-branding .site-title a {
  width:260px !important;
  height:95px !important;
  background:url('assets/bigbang-ride-logo-final.svg') center center / contain no-repeat !important;
  text-indent:-9999px !important;
  overflow:hidden !important;
}
.logo.site-branding .site-title { line-height:0 !important; margin:0 !important; }
.logo.site-branding .site-description { display:none !important; }
.logo-section { padding:6px 0 !important; }
.logo-left, .logo.site-branding { max-width:290px !important; overflow:visible !important; }
@media (max-width:700px){
  .logo.site-branding .site-title a { width:215px !important; height:80px !important; }
}

/* Approved generated BigBang Ride logo */
.logo.site-branding .site-title a {
  width:270px !important;
  height:92px !important;
  background:url('assets/bigbang-ride-logo-approved.png') center center / contain no-repeat !important;
  text-indent:-9999px !important;
  overflow:hidden !important;
}
.logo.site-branding .site-title { line-height:0 !important; margin:0 !important; }
.logo.site-branding .site-description { display:none !important; }
.logo-section { padding:4px 0 !important; }
.logo-left, .logo.site-branding { max-width:300px !important; overflow:visible !important; }
@media (max-width:700px){
  .logo.site-branding .site-title a { width:220px !important; height:76px !important; }
}

/* Match header background to approved logo black background */
.main-header,
.top-header,
.logo-nav-wrapper,
.logo-section,
.header-lower,
.logo-section .container,
.logo-left,
.logo.site-branding {
  background:#020304 !important;
}
.logo.site-branding .site-title a {
  background-color:#020304 !important;
  border-radius:0 !important;
}

/* Transparent logo version so logo box background does not show */
.logo.site-branding .site-title a {
  background-image:url('assets/bigbang-ride-logo-approved-transparent.png') !important;
  background-color:transparent !important;
}
.main-header,
.top-header,
.logo-nav-wrapper,
.logo-section,
.header-lower {
  background:#07090d !important;
}

/* Final logo cleanup: no long logo background rectangle */
.logo-section,
.logo-section .container,
.logo-left,
.logo.site-branding,
.logo.site-branding .site-title,
.logo.site-branding .site-title a {
  background:transparent !important;
  box-shadow:none !important;
  border:0 !important;
}
.logo.site-branding .site-title a {
  width:185px !important;
  height:70px !important;
  background-image:url('assets/bigbang-ride-logo-approved-cropped.png') !important;
  background-position:left center !important;
  background-size:contain !important;
  background-repeat:no-repeat !important;
}
.logo-left,
.logo.site-branding { max-width:200px !important; }
.logo-section .container { display:flex; align-items:center; }
@media (max-width:700px){
  .logo.site-branding .site-title a { width:160px !important; height:58px !important; }
  .logo-left, .logo.site-branding { max-width:170px !important; }
}

/* Wide logo crop fix: preserve full BigBang Ride text */
.logo.site-branding .site-title a {
  width:245px !important;
  height:82px !important;
  background-image:url('assets/bigbang-ride-logo-approved-cropped.png') !important;
  background-position:left center !important;
  background-size:contain !important;
  background-repeat:no-repeat !important;
}
.logo-left,
.logo.site-branding { max-width:260px !important; overflow:visible !important; }
.logo-section .container { align-items:center !important; }
@media (max-width:700px){
  .logo.site-branding .site-title a { width:200px !important; height:68px !important; }
  .logo-left, .logo.site-branding { max-width:215px !important; }
}

/* Safe logo fix: no crop, no text cut */
.logo.site-branding .site-title a {
  width:310px !important;
  height:95px !important;
  background-image:url('assets/bigbang-ride-logo-approved-safe.png') !important;
  background-position:left center !important;
  background-size:contain !important;
  background-repeat:no-repeat !important;
  background-color:transparent !important;
}
.logo-left,
.logo.site-branding {
  max-width:330px !important;
  width:330px !important;
  overflow:visible !important;
  background:transparent !important;
}
.logo-section .container,
.logo-nav-wrapper,
.logo-section {
  overflow:visible !important;
}
@media (max-width:700px){
  .logo.site-branding .site-title a { width:250px !important; height:78px !important; }
  .logo-left, .logo.site-branding { max-width:265px !important; width:265px !important; }
}

/* Move main hero content upward */
.kb-hero {
  padding-top: 28px !important;
  padding-bottom: 48px !important;
}
.kb-hero-grid {
  align-items: start !important;
}
.kb-hero h1 {
  margin-top: 10px !important;
}
@media (max-width: 900px) {
  .kb-hero { padding-top: 22px !important; }
}

/* Overnight polish pass: step 1 customer-facing cleanup */
.kb-pay-rate { font-size:13px; }
.kb-pricing-card { margin-top: 8px; }
.kb-checkout-panel { scroll-margin-top: 120px; }
.kb-rate-list-top { border-radius: 24px; }
.kb-hero p { max-width: 760px; }
.kb-trust-row { margin-bottom: 8px; }


/* Final header cleanup requested by JP: remove duplicate header text/nav. */
.top-header {
  display: none !important;
}
.logo.site-branding .site-title,
.logo.site-branding .site-title a {
  font-size: 0 !important;
  color: transparent !important;
  text-shadow: none !important;
  letter-spacing: 0 !important;
  overflow: hidden !important;
}
.logo.site-branding .site-description {
  display: none !important;
  visibility: hidden !important;
}

/* Calculator form readability: make typed text visible on dark fields. */
.kb-landing .kb-form input,
.kb-landing .kb-form select,
.kb-landing .kb-pricing-card input,
.kb-landing .kb-pricing-card select,
.kb-landing .kb-checkout-panel input,
.kb-landing .kb-checkout-panel select {
  color: #ffffff !important;
  caret-color: #f5d28a !important;
}
.kb-landing .kb-form input::placeholder,
.kb-landing .kb-pricing-card input::placeholder,
.kb-landing .kb-checkout-panel input::placeholder {
  color: rgba(255,255,255,.62) !important;
  opacity: 1 !important;
}
.kb-landing .kb-form select option,
.kb-landing .kb-pricing-card select option,
.kb-landing .kb-checkout-panel select option {
  color: #111827 !important;
  background: #ffffff !important;
}

/* Force focused/active calculator text to stay visible while typing. */
.kb-landing input,
.kb-landing textarea,
.kb-landing select,
.kb-landing input:focus,
.kb-landing textarea:focus,
.kb-landing select:focus,
.kb-landing input:active,
.kb-landing textarea:active,
.kb-landing select:active {
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
  caret-color: #f5d28a !important;
  background-color: rgba(255,255,255,.08) !important;
  border-color: rgba(245,210,138,.55) !important;
  outline-color: rgba(245,210,138,.55) !important;
}
.kb-landing input:focus::placeholder,
.kb-landing textarea:focus::placeholder {
  color: rgba(255,255,255,.55) !important;
  -webkit-text-fill-color: rgba(255,255,255,.55) !important;
}
.kb-landing input:-webkit-autofill,
.kb-landing input:-webkit-autofill:hover,
.kb-landing input:-webkit-autofill:focus,
.kb-landing textarea:-webkit-autofill,
.kb-landing textarea:-webkit-autofill:hover,
.kb-landing textarea:-webkit-autofill:focus {
  -webkit-text-fill-color: #ffffff !important;
  caret-color: #f5d28a !important;
  transition: background-color 9999s ease-in-out 0s !important;
  box-shadow: 0 0 0 1000px rgba(255,255,255,.08) inset !important;
}

/* Flat fare checkout options: quantity inputs like the app. */
.kb-quantity-options label {
  display: grid !important;
  grid-template-columns: 1fr 86px !important;
  gap: 4px 10px !important;
  align-items: center !important;
}
.kb-quantity-options label input {
  grid-column: 2 !important;
  grid-row: 1 / span 2 !important;
  text-align: center !important;
  min-height: 40px !important;
}
.kb-quantity-options label small {
  grid-column: 1 !important;
}
.kb-quantity-options .kb-sign-option {
  grid-template-columns: 1fr 40px !important;
}
.kb-quantity-options .kb-sign-option input[type="checkbox"] {
  width: 24px !important;
  min-height: 24px !important;
  justify-self: center !important;
  accent-color: #d6a94f !important;
}

/* Keep local calculator hidden until the Local Calculator button is clicked. */
.kb-local-calc-hidden {
  display: none !important;
}
.kb-calc-title-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
}
.kb-calc-title-row h2 {
  margin: 0 0 6px !important;
}
.kb-local-calc-close {
  border: 1px solid rgba(214,169,79,.45) !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.08) !important;
  color: #f5d28a !important;
  padding: 7px 12px !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  cursor: pointer !important;
}

/* Customer login/signup/guest access block. */
.kb-customer-access {
  margin: 16px 0;
  padding: 14px;
  border: 1px solid rgba(214,169,79,.28);
  border-radius: 18px;
  background: rgba(255,255,255,.06);
}
.kb-access-tabs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-bottom: 12px;
}
.kb-access-tabs button {
  border: 1px solid rgba(214,169,79,.34);
  border-radius: 999px;
  background: rgba(0,0,0,.18);
  color: #f5d28a;
  padding: 9px 10px;
  font-weight: 900;
  cursor: pointer;
}
.kb-access-tabs button.active {
  background: linear-gradient(135deg,#f5d28a,#d6a94f);
  color: #101827;
}
.kb-access-panel { display: none; }
.kb-access-panel.active { display: block; }
.kb-access-panel b { color: #f5d28a; }
.kb-access-panel p { color: #dce6f6; font-size: 14px; line-height: 1.5; }
@media(max-width:700px){ .kb-access-tabs { grid-template-columns: 1fr; } }

/* Visible customer access tabs on main hero, not hidden inside local calculator. */
.kb-main-customer-access {
  max-width: 760px;
  margin-top: 18px !important;
  background: rgba(8,12,20,.72) !important;
  backdrop-filter: blur(10px);
}
.kb-main-customer-access .kb-form-row {
  grid-template-columns: 1fr 1fr;
}
@media(max-width:800px){ .kb-main-customer-access .kb-form-row { grid-template-columns: 1fr; } }

/* BigBang header auth links */
.bb-header{background:#05070b;border-bottom:1px solid rgba(214,169,79,.16);position:relative;z-index:20}.bb-header-inner{max-width:1120px;margin:0 auto;padding:12px 20px;display:flex;align-items:center;gap:24px}.bb-logo{width:150px;height:58px;background:url('assets/bigbang-ride-logo-approved-safe.png') left center/contain no-repeat;display:block;flex:0 0 auto}.bb-nav{flex:1}.bb-menu{display:flex;gap:26px;align-items:center;list-style:none;margin:0;padding:0}.bb-menu a{color:#f4eee0;text-decoration:none;font-weight:850}.bb-auth-links{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.bb-auth-links a{border:1px solid rgba(214,169,79,.35);border-radius:999px;color:#f5d28a;text-decoration:none;font-weight:900;font-size:13px;padding:8px 12px}.bb-auth-links a:last-child{background:linear-gradient(135deg,#f5d28a,#d6a94f);color:#101827}.bb-auth-modal{display:none;position:fixed;inset:0;z-index:99999}.bb-auth-modal.active{display:block}.bb-auth-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.72);backdrop-filter:blur(4px)}.bb-auth-dialog{position:relative;max-width:720px;margin:8vh auto;background:#0b111c;border:1px solid rgba(214,169,79,.36);border-radius:24px;padding:18px;box-shadow:0 30px 90px rgba(0,0,0,.55)}.bb-auth-close{float:right;border:1px solid rgba(214,169,79,.35);border-radius:999px;background:rgba(255,255,255,.08);color:#f5d28a;font-weight:900;padding:7px 12px;cursor:pointer}.bb-auth-content{clear:both;margin-top:12px}.bb-auth-content .kb-form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}@media(max-width:900px){.bb-header-inner{display:grid}.bb-nav{order:3}.bb-menu{gap:12px;flex-wrap:wrap}.bb-auth-content .kb-form-row{grid-template-columns:1fr}}@media(max-width:600px){.bb-auth-links a{font-size:12px;padding:7px 10px}.bb-auth-dialog{margin:4vh 12px}.bb-logo{width:130px}}

/* Header auth buttons: keep signup subtle, no yellow filled background. */
.bb-auth-links a,
.bb-auth-links a:last-child {
  background: rgba(255,255,255,.06) !important;
  color: #f5d28a !important;
  border: 1px solid rgba(214,169,79,.35) !important;
}
.bb-auth-links a:hover {
  background: rgba(214,169,79,.14) !important;
}

/* Header text should stay white; gold only as accent/border. */
.bb-menu a,
.bb-auth-links a,
.bb-auth-links a:last-child {
  color: #ffffff !important;
}
.bb-auth-links a:hover,
.bb-menu a:hover {
  color: #ffffff !important;
}

/* Auth modal: keep submit buttons below the input grid, never overlapping fields. */
.bb-auth-content .kb-access-panel > .kb-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: auto !important;
  max-width: 100% !important;
  margin-top: 18px !important;
  clear: both !important;
  position: relative !important;
  z-index: 1 !important;
}
.bb-auth-content .kb-form-row {
  margin-bottom: 4px !important;
  row-gap: 18px !important;
}
.bb-auth-content .kb-field {
  min-width: 0 !important;
}
@media(max-width:700px){
  .bb-auth-content .kb-access-panel > .kb-btn {
    width: 100% !important;
  }
}
.kb-driver-recruit{background:linear-gradient(180deg,rgba(8,16,28,.92),rgba(6,10,18,.98))}.kb-driver-apply-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:22px;align-items:start}.kb-driver-info ul{margin:16px 0 0;padding-left:20px;color:#e8eef7}.kb-driver-info li{margin:8px 0}.kb-pill{display:inline-flex;align-items:center;border:1px solid rgba(227,190,111,.5);background:rgba(227,190,111,.12);color:#f5d891;border-radius:999px;padding:7px 12px;font-weight:800;font-size:12px;letter-spacing:.04em}.kb-muted-small{color:rgba(237,242,250,.68);font-size:13px}.kb-driver-form h3,.kb-driver-info h3{color:#fff;margin-top:14px}.kb-driver-form small{display:block;margin-top:10px;color:rgba(237,242,250,.62)}.kb-checkline{display:flex;gap:9px;align-items:flex-start;margin:14px 0;color:#f4f7fb;font-weight:700}.kb-checkline input{width:auto;min-height:auto;margin-top:3px;accent-color:#e3be6f}@media(max-width:900px){.kb-driver-apply-grid{grid-template-columns:1fr}}
.bb-header{position:sticky;top:0;z-index:9999;background:rgba(5,10,18,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 10px 30px rgba(0,0,0,.24)}.admin-bar .bb-header{top:32px}@media(max-width:782px){.admin-bar .bb-header{top:46px}}
.bb-logo{transform:translateY(4px)}
/* Keep extra calculators hidden until the customer asks for them. */
.kb-local-calc-hidden{display:none!important}#local-calculator.kb-pricing-card{display:none}#local-calculator.kb-pricing-card.kb-show-flat-checkout{display:block}#local-calculator .kb-pricing-grid,#local-calculator .kb-price-result{display:none!important}
/* Hero flat fare button: remove yellow fill, keep luxury dark outline style. */
.kb-hero-actions .kb-flat-rate-open{
  background:rgba(255,255,255,.06)!important;
  color:#f4eee0!important;
  border:1px solid rgba(255,255,255,.16)!important;
  box-shadow:none!important;
}
.kb-hero-actions .kb-flat-rate-open:hover,
.kb-hero-actions .kb-flat-rate-open:focus{
  background:rgba(214,169,79,.12)!important;
  border-color:rgba(214,169,79,.42)!important;
  color:#f5d28a!important;
}
/* Premium black SUV silhouette blended into hero background. */
.kb-hero{position:relative;overflow:hidden}.kb-hero:before{content:"";position:absolute;inset:0;background:url('assets/luxury-suv-front-silhouette.svg') right 6% center/58% auto no-repeat;opacity:.32;filter:saturate(.85) contrast(1.04);pointer-events:none;z-index:0}.kb-hero:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 72% 48%,rgba(214,169,79,.10),transparent 34%),linear-gradient(90deg,rgba(5,7,11,.94) 0%,rgba(5,7,11,.72) 45%,rgba(5,7,11,.88) 100%);pointer-events:none;z-index:0}.kb-hero .kb-container{position:relative;z-index:1}@media(max-width:900px){.kb-hero:before{background-position:center bottom 8%;background-size:96% auto;opacity:.18}.kb-hero:after{background:linear-gradient(180deg,rgba(5,7,11,.92),rgba(5,7,11,.82))}}
/* Revert SUV hero background experiment. */
.kb-hero:before,.kb-hero:after{content:none!important;display:none!important;background:none!important}.kb-hero .kb-container{position:relative;z-index:auto}

/* BigBang minimal footer: text only, centered, no background bar/card. */
body > footer,
footer,
.footerup,
.footer-bottom,
.footer-bottom .container,
.footer-bottom .row,
.footer-bottom .col-md-6,
.footer-bottom .text,
.footer-bottom .text-left {
  background: transparent !important;
  background-color: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}
.footerup { display: none !important; }
.footer-bottom {
  padding: 18px 0 28px !important;
  margin: 0 !important;
}
.footer-bottom .container {
  width: 100% !important;
  max-width: none !important;
  padding: 0 16px !important;
}
.footer-bottom .row,
.footer-bottom .col-md-6 {
  float: none !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}
.footer-bottom .text,
.footer-bottom .text-left {
  text-align: center !important;
  color: rgba(247,244,236,.72) !important;
  font-size: 13px !important;
  line-height: 1.6 !important;
}
.footer-bottom .social-links,
.footer-bottom .text-right {
  display: none !important;
}

/* Driver recruiting should not appear in normal homepage scroll.
   It opens as its own view only when the nav link /#drivers is used. */
.kb-driver-recruit {
  display: none !important;
}
body.kb-driver-only .kb-landing > section:not(#drivers) {
  display: none !important;
}
body.kb-driver-only .kb-driver-recruit {
  display: block !important;
  min-height: calc(100vh - 120px);
  padding-top: 72px !important;
}
body.kb-driver-only .kb-landing {
  background: linear-gradient(180deg, #080b11 0%, #07090d 100%);
}

/* Remove obsolete HOW IT WORKS booking-flow section completely. */
#how {
  display: none !important;
}

/* Remove parent theme back-to-top floating button. */
a.scroll-top,
.scroll-top,
.scroll-top-visible,
.scroll-top-fade-out {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* Remove parent theme back-to-top floating button completely. */
html body a.scroll-top,
html body .scroll-top,
html body .scroll-top-visible,
html body .scroll-top-fade-out,
html body a[href="javascript:void(0)"].fa-angle-up {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  width: 0 !important;
  height: 0 !important;
  overflow: hidden !important;
  pointer-events: none !important;
}

/* TEMP: BigBang construction red badge safety CSS. Remove with functions.php TEMP badge block when ready. */
#bb-under-construction-badge {
  position: fixed !important;
  right: 14px !important;
  bottom: 14px !important;
  left: auto !important;
  top: auto !important;
  z-index: 2147483647 !important;
  display: block !important;
  padding: 12px 16px !important;
  border: 2px solid #fff !important;
  border-radius: 999px !important;
  background: #d90000 !important;
  color: #fff !important;
  font-size: 12px !important;
  line-height: 1 !important;
  font-weight: 950 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  box-shadow: 0 12px 32px rgba(0,0,0,.45) !important;
  pointer-events: none !important;
  user-select: none !important;
  transform: none !important;
  width: auto !important;
  height: auto !important;
}
a.scroll-top,
.scroll-top,
.scroll-top-visible,
.scroll-top-fade-out,
.fa-angle-up,
[class*="angle-up"],
a[href="javascript:void(0)"].fa {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  width: 0 !important;
  height: 0 !important;
  overflow: hidden !important;
  pointer-events: none !important;
}
.kb-construction-watermark,
.kb-construction-watermark-footer {
  display: none !important;
}
@media (max-width: 760px) {
  #bb-under-construction-badge {
    right: 10px !important;
    bottom: 10px !important;
    font-size: 10px !important;
    padding: 10px 12px !important;
  }
}

/* BigBang local ride stop add/remove controls. */
.kb-stop-list {
  display: grid;
  gap: 8px;
  margin: 8px 0;
}
.kb-stop-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  align-items: center;
}
.kb-stop-remove {
  border: 1px solid rgba(245,210,138,.45);
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  color: #f5d28a;
  padding: 10px 13px;
  font-weight: 900;
  cursor: pointer;
}
.kb-stop-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin: 8px 0;
}
.kb-stop-actions .kb-btn {
  padding: 9px 13px;
  font-size: 13px;
}

/* Make individual stop delete control small red text, no button background. */
.kb-stop-remove {
  border: 0 !important;
  background: transparent !important;
  color: #ff5a5a !important;
  padding: 4px 2px !important;
  font-size: 12px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  box-shadow: none !important;
  text-decoration: underline !important;
  text-underline-offset: 2px !important;
}
.kb-stop-row {
  grid-template-columns: 1fr 34px !important;
  gap: 6px !important;
}

/* Final force: stop delete must be tiny red text only. */
.kb-stop-row {
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: center !important;
}
.kb-stop-row > .kb-stop-remove,
html body .kb-stop-row > button.kb-stop-remove {
  all: unset !important;
  color: #ff4d4d !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  cursor: pointer !important;
  text-decoration: underline !important;
  text-underline-offset: 2px !important;
  padding: 2px !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

/* OpenClaw mobile-only homepage layout reset — 2026-05-10 safe CSS only */
@media (max-width: 760px) {
  .bb-header {
    position: sticky;
    top: 0;
    z-index: 9999;
    background: rgba(5, 10, 18, .96);
  }

  .bb-header-inner {
    display: grid !important;
    grid-template-columns: 1fr 122px 1fr !important;
    grid-template-rows: auto auto !important;
    align-items: center !important;
    gap: 8px 4px !important;
    padding: 10px 10px 12px !important;
  }

  .bb-logo {
    grid-column: 2 !important;
    grid-row: 1 !important;
    justify-self: center !important;
    width: 122px !important;
    height: 58px !important;
    margin: 0 !important;
    transform: none !important;
    background-size: contain !important;
    background-position: center !important;
  }

  .bb-auth-links {
    grid-column: 3 !important;
    grid-row: 1 !important;
    justify-self: end !important;
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 5px !important;
    margin: 0 !important;
    white-space: nowrap !important;
  }

  .bb-auth-links a {
    font-size: 11px !important;
    line-height: 1 !important;
    padding: 8px 8px !important;
    border-radius: 999px !important;
  }

  .bb-nav {
    grid-column: 1 / -1 !important;
    grid-row: 2 !important;
    width: 100% !important;
    overflow: hidden !important;
  }

  .bb-menu {
    display: flex !important;
    flex-wrap: nowrap !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 0 !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .bb-menu li {
    flex: 0 1 auto !important;
    margin: 0 !important;
  }

  .bb-menu a {
    display: block !important;
    padding: 6px 2px !important;
    font-size: 11px !important;
    line-height: 1.15 !important;
    letter-spacing: -.06em !important;
    white-space: nowrap !important;
  }

  body.home .kb-hero {
    min-height: calc(100svh - 132px) !important;
    padding: 22px 0 26px !important;
  }

  body.home .kb-hero-grid {
    display: block !important;
  }

  body.home .kb-hero .kb-eyebrow {
    margin-bottom: 12px !important;
    font-size: 12px !important;
  }

  body.home .kb-hero h1 {
    margin: 0 0 14px !important;
    font-size: 34px !important;
    line-height: 1.12 !important;
    letter-spacing: -.06em !important;
  }

  body.home .kb-hero p {
    margin: 0 0 20px !important;
    font-size: 16px !important;
    line-height: 1.65 !important;
  }

  body.home .kb-hero-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    margin-top: 18px !important;
  }

  body.home .kb-hero-actions .kb-driver-access,
  body.home .kb-trust-row,
  body.home #schedule {
    display: none !important;
  }

  body.home .kb-hero-actions .kb-btn {
    width: 100% !important;
    justify-content: center !important;
    text-align: center !important;
    border-radius: 999px !important;
    padding: 16px 18px !important;
    font-size: 17px !important;
  }

  body.home .kb-landing > .kb-section {
    display: none !important;
  }
}


/* OpenClaw global mobile header consistency — applies to every page */
@media (max-width: 760px) {
  .bb-header-inner {
    display: grid !important;
    grid-template-columns: 1fr 122px 1fr !important;
    grid-template-rows: auto auto !important;
    align-items: center !important;
    gap: 8px 4px !important;
    padding: 10px 10px 12px !important;
  }
  .bb-logo {
    grid-column: 2 !important;
    grid-row: 1 !important;
    justify-self: center !important;
    width: 122px !important;
    height: 58px !important;
    margin: 0 !important;
    transform: none !important;
    background-size: contain !important;
    background-position: center !important;
  }
  .bb-auth-links {
    grid-column: 3 !important;
    grid-row: 1 !important;
    justify-self: end !important;
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 5px !important;
    margin: 0 !important;
    white-space: nowrap !important;
  }
  .bb-auth-links a {
    font-size: 11px !important;
    line-height: 1 !important;
    padding: 8px 8px !important;
    border-radius: 999px !important;
  }
  .bb-nav {
    grid-column: 1 / -1 !important;
    grid-row: 2 !important;
    width: 100% !important;
    overflow: hidden !important;
  }
  .bb-menu {
    display: flex !important;
    flex-wrap: nowrap !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 0 !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }
  .bb-menu li { flex: 0 1 auto !important; margin: 0 !important; }
  .bb-menu a {
    display: block !important;
    padding: 6px 2px !important;
    font-size: 11px !important;
    line-height: 1.15 !important;
    letter-spacing: -.06em !important;
    white-space: nowrap !important;
  }
}


/* OpenClaw hard lock: identical mobile header on every BigBang page */
@media (max-width: 760px) {
  .bb-header { min-height: 113px !important; }
  .admin-bar .bb-header { top: 46px !important; }
  .bb-header-inner {
    height: 113px !important;
    box-sizing: border-box !important;
    display: grid !important;
    grid-template-columns: minmax(0,1fr) 122px minmax(108px,1fr) !important;
    grid-template-rows: 62px 31px !important;
    align-items: center !important;
  }
  .bb-logo { grid-column: 2 !important; grid-row: 1 !important; align-self: center !important; }
  .bb-auth-links { grid-column: 3 !important; grid-row: 1 !important; align-self: center !important; }
  .bb-nav { grid-column: 1 / -1 !important; grid-row: 2 !important; align-self: center !important; }
  .bb-menu { height: 25px !important; }
  .bb-menu a { font-size: 10.5px !important; }
  body:not(.home) .site-main,
  body:not(.home) #primary,
  body:not(.home) .kb-landing { margin-top: 0 !important; }
}


/* OpenClaw mobile nav tightening + driver anchor fix */
@media (max-width: 760px) {
  .bb-header-inner {
    grid-template-columns: minmax(0,1fr) 108px minmax(92px,1fr) !important;
    grid-template-rows: 54px 28px !important;
    height: 100px !important;
    min-height: 100px !important;
    padding: 8px 8px 10px !important;
  }
  .bb-header { min-height: 100px !important; }
  .bb-logo { width: 108px !important; height: 52px !important; }
  .bb-auth-links { gap: 3px !important; }
  .bb-auth-links a { font-size: 10px !important; padding: 7px 6px !important; }
  .bb-nav { height: 28px !important; overflow: visible !important; }
  .bb-menu { height: 28px !important; justify-content: space-evenly !important; }
  .bb-menu a {
    font-size: 9.4px !important;
    letter-spacing: -.08em !important;
    padding: 6px 1px !important;
    max-width: none !important;
  }
  .kb-driver-only .kb-landing > .kb-section { display: none !important; }
  .kb-driver-only .kb-landing > .kb-section#drivers,
  .kb-driver-only #drivers { display: block !important; }
  .kb-driver-only .kb-hero { display: none !important; }
  .kb-driver-only #drivers { padding-top: 22px !important; }
}

/* OpenClaw mobile hero subtle car image under ride buttons */
@media (max-width: 760px) {
  body.home .kb-hero {
    position: relative !important;
    overflow: hidden !important;
    min-height: calc(100svh - 100px) !important;
  }
  body.home .kb-hero::before {
    content: "" !important;
    display: block !important;
    position: absolute !important;
    left: 55.5% !important;
    top: 438px !important;
    width: min(118vw, 520px) !important;
    height: 300px !important;
    transform: translateX(-50%) !important;
    background:
      linear-gradient(180deg, rgba(5,7,11,0) 0%, rgba(5,7,11,.10) 42%, rgba(5,7,11,.28) 100%),
      url('assets/bigbang-mobile-black-car.jpg') center top / contain no-repeat !important;
    opacity: .28 !important;
    filter: saturate(.82) contrast(1.05) brightness(.78) !important;
    pointer-events: none !important;
    z-index: 0 !important;
    -webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 13%, #000 96%, transparent 100%) !important;
    mask-image: linear-gradient(180deg, transparent 0%, #000 13%, #000 96%, transparent 100%) !important;
  }
  body.home .kb-hero::after {
    content: "" !important;
    display: block !important;
    position: absolute !important;
    left: 0 !important;
    right: 0 !important;
    top: 382px !important;
    bottom: 0 !important;
    background: radial-gradient(circle at 50% 18%, rgba(214,169,79,.10), transparent 34%) !important;
    pointer-events: none !important;
    z-index: 0 !important;
  }
  body.home .kb-hero .kb-container {
    position: relative !important;
    z-index: 1 !important;
  }
}

/* OpenClaw mobile car position adjustment: image shifted right and lower */

/* OpenClaw mobile car bottom mask fix: front bumper no longer covered */

/* OpenClaw mobile car full-front visibility fix */
@media (max-width: 760px) {
  body.home .kb-hero::before {
    left: 55.5% !important;
    top: 438px !important;
    width: min(120vw, 540px) !important;
    height: 390px !important;
    background: url('assets/bigbang-mobile-black-car.jpg') center top / contain no-repeat !important;
    opacity: .31 !important;
    filter: saturate(.82) contrast(1.08) brightness(.82) !important;
    -webkit-mask-image: none !important;
    mask-image: none !important;
  }
  body.home .kb-hero::after {
    display: none !important;
    content: none !important;
    background: none !important;
  }
}

/* OpenClaw mobile car clipping fix: give the hero enough room so bumper is not cut */
@media (max-width: 760px) {
  body.home .kb-hero {
    min-height: 760px !important;
    padding-bottom: 170px !important;
    overflow: hidden !important;
  }
  body.home .kb-hero::before {
    left: 55% !important;
    top: 430px !important;
    width: min(118vw, 520px) !important;
    height: 360px !important;
    background: url('assets/bigbang-mobile-black-car.jpg') center top / contain no-repeat !important;
    opacity: .31 !important;
    -webkit-mask-image: none !important;
    mask-image: none !important;
  }
}

/* OpenClaw mobile car top blend fix: fade only the top edge into the dark theme */
@media (max-width: 760px) {
  body.home .kb-hero::before {
    background:
      linear-gradient(180deg, rgba(5,7,11,1) 0%, rgba(5,7,11,.84) 10%, rgba(5,7,11,.35) 22%, rgba(5,7,11,0) 38%),
      url('assets/bigbang-mobile-black-car.jpg') center top / contain no-repeat !important;
    -webkit-mask-image: linear-gradient(180deg, transparent 0%, rgba(0,0,0,.22) 7%, #000 22%, #000 100%) !important;
    mask-image: linear-gradient(180deg, transparent 0%, rgba(0,0,0,.22) 7%, #000 22%, #000 100%) !important;
  }
}

/* OpenClaw mobile flat fare step flow */
@media (max-width: 760px) {
  body.home.bb-mobile-flat-step .kb-hero { display: none !important; }
  body.home.bb-mobile-flat-step .kb-landing > .kb-section#rates {
    display: block !important;
    min-height: calc(100svh - 100px) !important;
    padding: 20px 0 34px !important;
    background: linear-gradient(180deg,#07101d,#05070b) !important;
  }
  body.home.bb-mobile-flat-step #rates .kb-container { padding: 0 14px !important; }
  body.home.bb-mobile-flat-step #rates .kb-section-head,
  body.home.bb-mobile-flat-step #rates .kb-pricing-card { display: none !important; }
  body.home.bb-mobile-flat-step #rates .kb-region-filter {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 11px !important;
    margin: 0 !important;
    padding: 0 !important;
  }
  body.home.bb-mobile-flat-step #rates .kb-region-filter button[data-region="all"] { display: none !important; }
  body.home.bb-mobile-flat-step #rates .kb-region-filter button {
    min-height: 82px !important;
    border-radius: 22px !important;
    padding: 13px 8px !important;
    text-align: center !important;
    background: rgba(255,255,255,.075) !important;
    border: 1px solid rgba(245,210,138,.28) !important;
    color: #f5d28a !important;
    box-shadow: 0 14px 30px rgba(0,0,0,.22) !important;
  }
  body.home.bb-mobile-flat-step #rates .kb-region-filter button span {
    display: block !important;
    font-size: 14px !important;
    line-height: 1.25 !important;
    font-weight: 950 !important;
  }
  body.home.bb-mobile-flat-step #rates .kb-region-filter button small {
    display: block !important;
    margin-top: 5px !important;
    font-size: 10px !important;
    line-height: 1.2 !important;
    color: rgba(255,255,255,.68) !important;
  }
  body.home.bb-mobile-flat-step:not(.bb-mobile-route-step) #rates .kb-rate-list { display: none !important; }
  body.home.bb-mobile-flat-step.bb-mobile-route-step #rates .kb-region-filter { display: none !important; }
  body.home.bb-mobile-flat-step.bb-mobile-route-step #rates .kb-rate-list {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    margin-top: 0 !important;
  }
  body.home.bb-mobile-flat-step.bb-mobile-route-step #rates .kb-rate-item {
    border-radius: 18px !important;
    padding: 14px !important;
    background: rgba(255,255,255,.075) !important;
    border: 1px solid rgba(245,210,138,.24) !important;
  }
  body.home.bb-mobile-flat-step.bb-mobile-route-step #rates .kb-rate-item b { color: #fff7e3 !important; }
  body.home.bb-mobile-flat-step.bb-mobile-route-step #rates .kb-rate-item span { color: #f5d28a !important; font-weight: 950 !important; }
}

/* OpenClaw mobile flat-region page subtle car image */
@media (max-width: 760px) {
  body.home.bb-mobile-flat-step:not(.bb-mobile-route-step) #rates {
    position: relative !important;
    overflow: hidden !important;
    min-height: calc(100svh - 100px) !important;
  }
  body.home.bb-mobile-flat-step:not(.bb-mobile-route-step) #rates::before {
    content: "" !important;
    position: absolute !important;
    left: 55% !important;
    top: 420px !important;
    width: min(116vw, 520px) !important;
    height: 350px !important;
    transform: translateX(-50%) !important;
    background:
      linear-gradient(180deg, rgba(5,7,11,1) 0%, rgba(5,7,11,.75) 12%, rgba(5,7,11,.18) 30%, rgba(5,7,11,0) 54%),
      url('assets/bigbang-mobile-black-car.jpg') center top / contain no-repeat !important;
    opacity: .24 !important;
    filter: saturate(.82) contrast(1.05) brightness(.75) !important;
    pointer-events: none !important;
    z-index: 0 !important;
    -webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 18%, #000 100%) !important;
    mask-image: linear-gradient(180deg, transparent 0%, #000 18%, #000 100%) !important;
  }
  body.home.bb-mobile-flat-step:not(.bb-mobile-route-step) #rates .kb-container {
    position: relative !important;
    z-index: 1 !important;
  }
}


/* OpenClaw mobile selected-price booking info step */
.kb-mobile-booking-info { display: none; }
@media (max-width: 760px) {
  body.home.bb-mobile-booking-info .kb-hero { display: none !important; }
  body.home.bb-mobile-booking-info .kb-landing > .kb-section#rates {
    display: block !important;
    min-height: calc(100svh - 100px) !important;
    padding: 20px 0 36px !important;
    background: linear-gradient(180deg,#07101d,#05070b) !important;
  }
  body.home.bb-mobile-booking-info #rates .kb-section-head,
  body.home.bb-mobile-booking-info #rates .kb-region-filter,
  body.home.bb-mobile-booking-info #rates .kb-rate-list,
  body.home.bb-mobile-booking-info #rates .kb-pricing-card { display: none !important; }
  body.home.bb-mobile-booking-info #kb-mobile-booking-info {
    display: grid !important;
    gap: 14px !important;
    color: #fff !important;
  }
  #kb-mobile-booking-info h2 { margin: 4px 0 4px !important; color: #f5d28a !important; font-size: 28px !important; }
  #kb-mobile-booking-info h3 { margin: 0 0 8px !important; color: #f5d28a !important; }
  .kb-mobile-selected-route { color: #dfe7f4 !important; line-height: 1.45 !important; }
  .kb-mobile-selected-route b { color: #f5d28a !important; }
  .kb-mobile-member-card,
  .kb-mobile-guest-card {
    border: 1px solid rgba(245,210,138,.24) !important;
    border-radius: 22px !important;
    background: rgba(255,255,255,.075) !important;
    padding: 16px !important;
    box-shadow: 0 16px 36px rgba(0,0,0,.26) !important;
  }
  .kb-mobile-guest-card label { display: block !important; margin: 11px 0 !important; color: #fff7e3 !important; font-weight: 850 !important; }
  .kb-mobile-guest-card input {
    width: 100% !important;
    margin-top: 6px !important;
    border: 1px solid rgba(245,210,138,.22) !important;
    border-radius: 14px !important;
    padding: 13px !important;
    background: rgba(255,255,255,.08) !important;
    color: #fff !important;
    font: inherit !important;
  }
  .kb-mobile-back-rates { border:0 !important; background:transparent !important; color:#f5d28a !important; text-align:left !important; font-weight:900 !important; padding:0 !important; }
  body.home.bb-mobile-checkout-step #rates .kb-region-filter,
  body.home.bb-mobile-checkout-step #rates .kb-rate-list,
  body.home.bb-mobile-checkout-step #kb-mobile-booking-info { display: none !important; }
  body.home.bb-mobile-checkout-step #rates .kb-pricing-card { display: block !important; }
}

/* OpenClaw mobile local ride booking flow */
@media (max-width: 760px) {
  body.home.bb-mobile-local-info .kb-hero,
  body.home.bb-mobile-local-checkout .kb-hero {
    display: block !important;
    min-height: calc(100svh - 100px) !important;
    padding: 20px 0 36px !important;
    background: linear-gradient(180deg,#07101d,#05070b) !important;
  }
  body.home.bb-mobile-local-info .kb-hero .kb-hero-grid,
  body.home.bb-mobile-local-checkout .kb-hero .kb-hero-grid { display: block !important; }
  body.home.bb-mobile-local-info .kb-hero .kb-hero-grid > div:first-child,
  body.home.bb-mobile-local-checkout .kb-hero .kb-hero-grid > div:first-child,
  body.home.bb-mobile-local-info .kb-trust-row,
  body.home.bb-mobile-local-checkout .kb-trust-row { display: none !important; }
  body.home.bb-mobile-local-info #rates,
  body.home.bb-mobile-local-info .kb-landing > .kb-section,
  body.home.bb-mobile-local-checkout #rates,
  body.home.bb-mobile-local-checkout .kb-landing > .kb-section { display: none !important; }
  body.home.bb-mobile-local-info #kb-mobile-booking-info {
    display: grid !important;
    gap: 14px !important;
    color: #fff !important;
  }
  body.home.bb-mobile-local-info #schedule { display: none !important; }
  body.home.bb-mobile-local-checkout #schedule {
    display: block !important;
    margin-top: 0 !important;
  }
  body.home.bb-mobile-local-checkout #schedule .kb-calc-title-row h2::after {
    content: ' 예약 정보';
  }
  body.home.bb-mobile-local-checkout.bb-mobile-member-mode #schedule .kb-customer-fields,
  body.home.bb-mobile-local-checkout.bb-mobile-member-mode #schedule .kb-customer-email-field,
  body.home.bb-mobile-local-checkout.bb-mobile-guest-mode #schedule .kb-customer-fields,
  body.home.bb-mobile-local-checkout.bb-mobile-guest-mode #schedule .kb-customer-email-field {
    display: none !important;
  }
}

/* OpenClaw fix: local ride info step must show the info panel, not blank hero/car */
@media (max-width: 760px) {
  body.home.bb-mobile-local-info .kb-hero {
    display: none !important;
  }
  body.home.bb-mobile-local-info .kb-landing > .kb-section#rates {
    display: block !important;
    min-height: calc(100svh - 100px) !important;
    padding: 20px 0 36px !important;
    background: linear-gradient(180deg,#07101d,#05070b) !important;
  }
  body.home.bb-mobile-local-info #rates .kb-container {
    display: block !important;
    padding: 0 14px !important;
  }
  body.home.bb-mobile-local-info #rates .kb-section-head,
  body.home.bb-mobile-local-info #rates .kb-region-filter,
  body.home.bb-mobile-local-info #rates .kb-rate-list,
  body.home.bb-mobile-local-info #rates .kb-pricing-card {
    display: none !important;
  }
  body.home.bb-mobile-local-info #kb-mobile-booking-info {
    display: grid !important;
    gap: 14px !important;
  }
}

/* OpenClaw mobile schedule step: basic info first, options after confirm */
@media (max-width: 760px) {
  body.home.bb-mobile-local-checkout #schedule .kb-schedule-total,
  body.home.bb-mobile-local-checkout #schedule .kb-note,
  body.home.bb-mobile-checkout-step #schedule .kb-schedule-total,
  body.home.bb-mobile-checkout-step #schedule .kb-note {
    display: none !important;
  }
  body.home.bb-mobile-local-checkout:not(.bb-mobile-schedule-options) #schedule .kb-stop-field,
  body.home.bb-mobile-local-checkout:not(.bb-mobile-schedule-options) #schedule .kb-addons,
  body.home.bb-mobile-checkout-step:not(.bb-mobile-schedule-options) #schedule .kb-stop-field,
  body.home.bb-mobile-checkout-step:not(.bb-mobile-schedule-options) #schedule .kb-addons {
    display: none !important;
  }
  body.home.bb-mobile-local-checkout.bb-mobile-schedule-options #schedule .kb-stop-field,
  body.home.bb-mobile-local-checkout.bb-mobile-schedule-options #schedule .kb-addons,
  body.home.bb-mobile-checkout-step.bb-mobile-schedule-options #schedule .kb-stop-field,
  body.home.bb-mobile-checkout-step.bb-mobile-schedule-options #schedule .kb-addons {
    display: grid !important;
    gap: 12px !important;
  }
  body.home.bb-mobile-local-checkout #schedule .kb-schedule-pay,
  body.home.bb-mobile-checkout-step #schedule .kb-schedule-pay {
    margin-top: 16px !important;
  }
}


/* OpenClaw fix: local ride basic/option step must not show duplicated flat pricing below confirm */
@media (max-width: 760px) {
  body.home.bb-mobile-local-checkout .kb-landing > .kb-section#rates,
  body.home.bb-mobile-local-checkout #rates {
    display: none !important;
  }
  body.home.bb-mobile-local-checkout #schedule {
    margin-bottom: 0 !important;
  }
}

/* OpenClaw fix: keep route/stop add button on local basic step */
@media (max-width: 760px) {
  body.home.bb-mobile-local-checkout:not(.bb-mobile-schedule-options) #schedule .kb-stop-field,
  body.home.bb-mobile-checkout-step:not(.bb-mobile-schedule-options) #schedule .kb-stop-field {
    display: block !important;
  }
  body.home.bb-mobile-local-checkout:not(.bb-mobile-schedule-options) #schedule .kb-stop-field > label,
  body.home.bb-mobile-local-checkout:not(.bb-mobile-schedule-options) #schedule .kb-stop-field > small,
  body.home.bb-mobile-checkout-step:not(.bb-mobile-schedule-options) #schedule .kb-stop-field > label,
  body.home.bb-mobile-checkout-step:not(.bb-mobile-schedule-options) #schedule .kb-stop-field > small {
    display: none !important;
  }
  body.home.bb-mobile-local-checkout:not(.bb-mobile-schedule-options) #schedule .kb-stop-list,
  body.home.bb-mobile-checkout-step:not(.bb-mobile-schedule-options) #schedule .kb-stop-list {
    margin: 0 0 10px !important;
  }
  body.home.bb-mobile-local-checkout:not(.bb-mobile-schedule-options) #schedule .kb-stop-actions,
  body.home.bb-mobile-checkout-step:not(.bb-mobile-schedule-options) #schedule .kb-stop-actions {
    display: block !important;
  }
  body.home.bb-mobile-local-checkout:not(.bb-mobile-schedule-options) #schedule .kb-add-stop,
  body.home.bb-mobile-checkout-step:not(.bb-mobile-schedule-options) #schedule .kb-add-stop {
    width: 100% !important;
    border-radius: 18px !important;
    padding: 14px !important;
    margin: 2px 0 8px !important;
  }
}

/* OpenClaw final mobile options step: options + total + 20% deposit only */
@media (max-width: 760px) {
  body.home.bb-mobile-local-checkout.bb-mobile-schedule-options #schedule .kb-calc-title-row,
  body.home.bb-mobile-local-checkout.bb-mobile-schedule-options #schedule > p,
  body.home.bb-mobile-local-checkout.bb-mobile-schedule-options #schedule .kb-deposit-explain,
  body.home.bb-mobile-local-checkout.bb-mobile-schedule-options #schedule .kb-customer-fields,
  body.home.bb-mobile-local-checkout.bb-mobile-schedule-options #schedule .kb-customer-email-field,
  body.home.bb-mobile-local-checkout.bb-mobile-schedule-options #schedule .kb-form > .kb-field:not(.kb-stop-field),
  body.home.bb-mobile-local-checkout.bb-mobile-schedule-options #schedule .kb-stop-field,
  body.home.bb-mobile-local-checkout.bb-mobile-schedule-options #schedule .kb-form-row {
    display: none !important;
  }
  body.home.bb-mobile-local-checkout.bb-mobile-schedule-options #schedule .kb-addons {
    display: grid !important;
    gap: 12px !important;
  }
  body.home.bb-mobile-local-checkout.bb-mobile-schedule-options #schedule .kb-schedule-total {
    display: block !important;
    margin-top: 16px !important;
  }
  body.home.bb-mobile-local-checkout.bb-mobile-schedule-options #schedule .kb-schedule-total span,
  body.home.bb-mobile-local-checkout.bb-mobile-schedule-options #schedule .kb-schedule-total strong,
  body.home.bb-mobile-local-checkout.bb-mobile-schedule-options #schedule .kb-schedule-total small {
    display: block !important;
  }
  body.home.bb-mobile-local-checkout.bb-mobile-schedule-options #schedule .kb-note {
    display: none !important;
  }
}

/* OpenClaw mobile booking flow: no close button inside booking steps */
@media (max-width: 760px) {
  body.home.bb-mobile-local-checkout #schedule .kb-local-calc-close,
  body.home.bb-mobile-checkout-step #schedule .kb-local-calc-close,
  body.home.bb-mobile-schedule-options #schedule .kb-local-calc-close {
    display: none !important;
  }
}


/* OpenClaw Driver Portal */
.kb-driver-portal-card .login-username,
.kb-driver-portal-card .login-password,
.kb-driver-portal-card .login-remember { margin: 0 0 12px !important; }
.kb-driver-portal-card .login-username label,
.kb-driver-portal-card .login-password label { display:block !important; margin-bottom:6px !important; font-weight:850 !important; color:#fff7e3 !important; }
.kb-driver-portal-card .input,
.kb-driver-portal-card input[type="text"],
.kb-driver-portal-card input[type="email"],
.kb-driver-portal-card input[type="password"],
.kb-driver-portal-card input[type="tel"],
.kb-driver-portal-card select { width:100% !important; border-radius:14px !important; border:1px solid rgba(245,210,138,.24) !important; background:rgba(255,255,255,.08) !important; color:#fff !important; padding:12px !important; }
.kb-driver-portal-card .button-primary,
.kb-driver-portal-card .login-submit input { width:100% !important; border:0 !important; border-radius:999px !important; padding:13px 18px !important; background:#f5d28a !important; color:#111 !important; font-weight:950 !important; }
.kb-driver-divider { border:0 !important; border-top:1px solid rgba(255,255,255,.14) !important; margin:22px 0 !important; }
.kb-driver-notice { border-radius:14px !important; padding:12px !important; margin:0 0 14px !important; font-weight:850 !important; }
.kb-driver-notice-success { background:rgba(42,180,120,.18) !important; color:#bff7dc !important; border:1px solid rgba(42,180,120,.35) !important; }
.kb-driver-notice-error { background:rgba(255,80,80,.15) !important; color:#ffd0d0 !important; border:1px solid rgba(255,80,80,.35) !important; }
.kb-driver-task-grid { display:grid !important; grid-template-columns:1fr 1fr !important; gap:12px !important; margin:16px 0 !important; }
.kb-driver-task-grid > div { border:1px solid rgba(245,210,138,.2) !important; border-radius:16px !important; padding:14px !important; background:rgba(255,255,255,.06) !important; }
@media (max-width:760px){ .kb-driver-task-grid{grid-template-columns:1fr!important;} }


/* OpenClaw Driver Portal placement and account setup emphasis */
.kb-driver-portal-card {
  order: -1 !important;
}
.kb-driver-apply-grid {
  align-items: start !important;
}
.kb-driver-account-note {
  grid-column: 1 / -1 !important;
  border: 1px solid rgba(245,210,138,.28) !important;
  border-radius: 16px !important;
  padding: 12px 14px !important;
  margin: 4px 0 !important;
  background: rgba(245,210,138,.09) !important;
  color: #fff7e3 !important;
}
.kb-driver-account-note b,
.kb-driver-account-note span {
  display: block !important;
}
.kb-driver-account-note b {
  color: #f5d28a !important;
  font-weight: 950 !important;
  margin-bottom: 3px !important;
}
.kb-driver-account-note span {
  color: rgba(255,255,255,.78) !important;
  font-size: 13px !important;
}
.kb-driver-username-field,
.kb-driver-password-field {
  border: 1px solid rgba(245,210,138,.18) !important;
  border-radius: 16px !important;
  padding: 10px !important;
  background: rgba(255,255,255,.04) !important;
}
@media (max-width: 760px) {
  .kb-driver-portal-card { order: -10 !important; }
}

/* OpenClaw desktop hero car image in hidden calculator/right-side space */
@media (min-width: 761px) {
  body.home .kb-hero {
    position: relative !important;
    overflow: hidden !important;
  }
  body.home .kb-hero::after {
    content: "" !important;
    position: absolute !important;
    right: clamp(-90px, -5vw, -28px) !important;
    bottom: clamp(18px, 5vw, 70px) !important;
    width: min(54vw, 760px) !important;
    height: min(42vw, 520px) !important;
    background:
      linear-gradient(90deg, rgba(5,7,11,1) 0%, rgba(5,7,11,.48) 22%, rgba(5,7,11,0) 52%),
      linear-gradient(180deg, rgba(5,7,11,.88) 0%, rgba(5,7,11,.08) 36%, rgba(5,7,11,.64) 100%),
      url('assets/bigbang-mobile-black-car.jpg') center center / contain no-repeat !important;
    opacity: .34 !important;
    filter: saturate(.82) contrast(1.08) brightness(.82) !important;
    pointer-events: none !important;
    z-index: 0 !important;
  }
  body.home .kb-hero .kb-container,
  body.home .kb-hero .kb-hero-grid {
    position: relative !important;
    z-index: 1 !important;
  }
  body.home .kb-hero .kb-quote-card.kb-local-calc-hidden {
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }
}


/* OpenClaw desktop explicit hero car layer */
.kb-desktop-hero-car { display: none; }
@media (min-width: 761px) {
  body.home .kb-hero-grid {
    position: relative !important;
  }
  body.home .kb-desktop-hero-car {
    display: block !important;
    position: absolute !important;
    right: -76px !important;
    top: 58px !important;
    width: min(55vw, 760px) !important;
    height: 500px !important;
    background:
      linear-gradient(90deg, rgba(5,7,11,.95) 0%, rgba(5,7,11,.35) 28%, rgba(5,7,11,0) 60%),
      linear-gradient(180deg, rgba(5,7,11,.42) 0%, rgba(5,7,11,0) 44%, rgba(5,7,11,.62) 100%),
      url('assets/bigbang-mobile-black-car.jpg') center center / contain no-repeat !important;
    opacity: .72 !important;
    filter: saturate(.9) contrast(1.08) brightness(.88) !important;
    pointer-events: none !important;
    z-index: 0 !important;
  }
  body.home .kb-hero-grid > div:first-child {
    position: relative !important;
    z-index: 2 !important;
  }
  body.home .kb-hero .kb-quote-card.kb-local-calc-hidden {
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }
}

/* OpenClaw fix: desktop car must fade into hero, no visible rectangle */
@media (min-width: 761px) {
  body.home .kb-desktop-hero-car {
    right: -42px !important;
    top: 48px !important;
    width: min(52vw, 720px) !important;
    height: 470px !important;
    background: url('assets/bigbang-mobile-black-car.jpg') center center / contain no-repeat !important;
    opacity: .42 !important;
    filter: saturate(.78) contrast(1.04) brightness(.72) !important;
    mix-blend-mode: screen !important;
    -webkit-mask-image:
      radial-gradient(ellipse at 55% 50%, #000 0%, #000 34%, rgba(0,0,0,.72) 48%, rgba(0,0,0,.25) 62%, transparent 78%),
      linear-gradient(90deg, transparent 0%, #000 18%, #000 82%, transparent 100%),
      linear-gradient(180deg, transparent 0%, #000 16%, #000 82%, transparent 100%) !important;
    -webkit-mask-composite: source-in, source-in !important;
    mask-image:
      radial-gradient(ellipse at 55% 50%, #000 0%, #000 34%, rgba(0,0,0,.72) 48%, rgba(0,0,0,.25) 62%, transparent 78%),
      linear-gradient(90deg, transparent 0%, #000 18%, #000 82%, transparent 100%),
      linear-gradient(180deg, transparent 0%, #000 16%, #000 82%, transparent 100%) !important;
    mask-composite: intersect !important;
  }
  body.home .kb-hero::after {
    display: none !important;
  }
}

/* OpenClaw tweak: push desktop car slightly right and erase right-edge trace */
@media (min-width: 761px) {
  body.home .kb-desktop-hero-car {
    right: -96px !important;
    opacity: .38 !important;
    -webkit-mask-image:
      radial-gradient(ellipse at 52% 50%, #000 0%, #000 30%, rgba(0,0,0,.62) 45%, rgba(0,0,0,.18) 58%, transparent 72%),
      linear-gradient(90deg, transparent 0%, #000 20%, #000 68%, rgba(0,0,0,.28) 78%, transparent 90%),
      linear-gradient(180deg, transparent 0%, #000 18%, #000 78%, transparent 96%) !important;
    mask-image:
      radial-gradient(ellipse at 52% 50%, #000 0%, #000 30%, rgba(0,0,0,.62) 45%, rgba(0,0,0,.18) 58%, transparent 72%),
      linear-gradient(90deg, transparent 0%, #000 20%, #000 68%, rgba(0,0,0,.28) 78%, transparent 90%),
      linear-gradient(180deg, transparent 0%, #000 18%, #000 78%, transparent 96%) !important;
  }
}

/* OpenClaw: when desktop local ride form opens, move car to lower-left empty space */
@media (min-width: 761px) {
  body.home .kb-hero-grid:has(#schedule:not(.kb-local-calc-hidden)) .kb-desktop-hero-car {
    right: auto !important;
    left: clamp(190px, 24vw, 380px) !important;
    top: auto !important;
    bottom: -125px !important;
    width: min(46vw, 650px) !important;
    height: 360px !important;
    background: url('assets/bigbang-mobile-black-car.jpg') center bottom / contain no-repeat !important;
    opacity: .30 !important;
    filter: saturate(.72) contrast(1.02) brightness(.65) !important;
    mix-blend-mode: screen !important;
    -webkit-mask-image:
      radial-gradient(ellipse at 50% 56%, #000 0%, #000 28%, rgba(0,0,0,.55) 44%, rgba(0,0,0,.18) 58%, transparent 74%),
      linear-gradient(90deg, transparent 0%, #000 18%, #000 78%, transparent 100%),
      linear-gradient(180deg, transparent 0%, #000 20%, #000 72%, transparent 100%) !important;
    mask-image:
      radial-gradient(ellipse at 50% 56%, #000 0%, #000 28%, rgba(0,0,0,.55) 44%, rgba(0,0,0,.18) 58%, transparent 74%),
      linear-gradient(90deg, transparent 0%, #000 18%, #000 78%, transparent 100%),
      linear-gradient(180deg, transparent 0%, #000 20%, #000 72%, transparent 100%) !important;
  }
}

/* OpenClaw tweak: lift local-form car into the left empty space */
@media (min-width: 761px) {
  body.home .kb-hero-grid:has(#schedule:not(.kb-local-calc-hidden)) .kb-desktop-hero-car {
    left: clamp(185px, 23vw, 355px) !important;
    top: 305px !important;
    bottom: auto !important;
    width: min(43vw, 610px) !important;
    height: 310px !important;
    opacity: .26 !important;
    filter: saturate(.68) contrast(1.02) brightness(.62) !important;
  }
}

/* OpenClaw tweak: local-form car stays left and below form edge */
@media (min-width: 761px) {
  body.home .kb-hero-grid:has(#schedule:not(.kb-local-calc-hidden)) .kb-desktop-hero-car {
    left: clamp(70px, 10vw, 155px) !important;
    top: 430px !important;
    bottom: auto !important;
    width: min(36vw, 470px) !important;
    height: 255px !important;
    opacity: .24 !important;
    background-position: center center !important;
    filter: saturate(.62) contrast(1.02) brightness(.58) !important;
    -webkit-mask-image:
      radial-gradient(ellipse at 50% 54%, #000 0%, #000 26%, rgba(0,0,0,.5) 42%, rgba(0,0,0,.15) 56%, transparent 72%),
      linear-gradient(90deg, transparent 0%, #000 20%, #000 72%, transparent 100%),
      linear-gradient(180deg, transparent 0%, #000 20%, #000 72%, transparent 100%) !important;
    mask-image:
      radial-gradient(ellipse at 50% 54%, #000 0%, #000 26%, rgba(0,0,0,.5) 42%, rgba(0,0,0,.15) 56%, transparent 72%),
      linear-gradient(90deg, transparent 0%, #000 20%, #000 72%, transparent 100%),
      linear-gradient(180deg, transparent 0%, #000 20%, #000 72%, transparent 100%) !important;
  }
}

/* OpenClaw final tweak: nudge local-form car lower and further left */
@media (min-width: 761px) {
  body.home .kb-hero-grid:has(#schedule:not(.kb-local-calc-hidden)) .kb-desktop-hero-car {
    left: clamp(24px, 5.5vw, 88px) !important;
    top: 485px !important;
    width: min(35vw, 450px) !important;
    height: 240px !important;
    opacity: .23 !important;
  }
}

/* OpenClaw micro tweak: local-form car a bit more left */
@media (min-width: 761px) {
  body.home .kb-hero-grid:has(#schedule:not(.kb-local-calc-hidden)) .kb-desktop-hero-car {
    left: clamp(-24px, 2.8vw, 46px) !important;
  }
}

/* OpenClaw micro tweak: final small left nudge for local-form car */
@media (min-width: 761px) {
  body.home .kb-hero-grid:has(#schedule:not(.kb-local-calc-hidden)) .kb-desktop-hero-car {
    left: clamp(0px, 4vw, 80px) !important;
  }
}

/* OpenClaw micro tweak: one more small left nudge for local-form car */
@media (min-width: 761px) {
  body.home .kb-hero-grid:has(#schedule:not(.kb-local-calc-hidden)) .kb-desktop-hero-car {
    left: clamp(-68px, -0.4vw, 0px) !important;
  }
}

/* OpenClaw tweak: desktop first-page car slightly left, no round mask edge */
@media (min-width: 761px) {
  body.home .kb-hero-grid:not(:has(#schedule:not(.kb-local-calc-hidden))) .kb-desktop-hero-car {
    right: -54px !important;
    opacity: .36 !important;
    filter: saturate(.72) contrast(1.02) brightness(.64) blur(.2px) !important;
    -webkit-mask-image:
      linear-gradient(90deg, transparent 0%, rgba(0,0,0,.28) 9%, #000 24%, #000 62%, rgba(0,0,0,.38) 76%, transparent 94%),
      linear-gradient(180deg, transparent 0%, rgba(0,0,0,.34) 12%, #000 28%, #000 66%, rgba(0,0,0,.28) 82%, transparent 100%) !important;
    -webkit-mask-composite: source-in !important;
    mask-image:
      linear-gradient(90deg, transparent 0%, rgba(0,0,0,.28) 9%, #000 24%, #000 62%, rgba(0,0,0,.38) 76%, transparent 94%),
      linear-gradient(180deg, transparent 0%, rgba(0,0,0,.34) 12%, #000 28%, #000 66%, rgba(0,0,0,.28) 82%, transparent 100%) !important;
    mask-composite: intersect !important;
  }
}

/* OpenClaw fix: use feathered transparent PNG so desktop car dissolves naturally */
@media (min-width: 761px) {
  body.home .kb-desktop-hero-car,
  body.home .kb-hero-grid:has(#schedule:not(.kb-local-calc-hidden)) .kb-desktop-hero-car,
  body.home .kb-hero-grid:not(:has(#schedule:not(.kb-local-calc-hidden))) .kb-desktop-hero-car {
    background: url('assets/bigbang-desktop-car-feather.png') center center / contain no-repeat !important;
    opacity: .42 !important;
    filter: saturate(.62) contrast(1.02) brightness(.60) blur(.45px) !important;
    mix-blend-mode: screen !important;
    -webkit-mask-image: none !important;
    mask-image: none !important;
  }
  body.home .kb-hero-grid:has(#schedule:not(.kb-local-calc-hidden)) .kb-desktop-hero-car {
    left: clamp(-92px, -1.6vw, -24px) !important;
  }
}

/* OpenClaw fix: luma-keyed car only, remove visible image rectangle */
@media (min-width: 761px) {
  body.home .kb-desktop-hero-car,
  body.home .kb-hero-grid:has(#schedule:not(.kb-local-calc-hidden)) .kb-desktop-hero-car,
  body.home .kb-hero-grid:not(:has(#schedule:not(.kb-local-calc-hidden))) .kb-desktop-hero-car {
    background: url('assets/bigbang-desktop-car-luma.png') center center / contain no-repeat !important;
    opacity: .78 !important;
    filter: saturate(.55) contrast(.95) brightness(.72) blur(.25px) !important;
    mix-blend-mode: screen !important;
    -webkit-mask-image: none !important;
    mask-image: none !important;
  }
  body.home .kb-hero-grid:has(#schedule:not(.kb-local-calc-hidden)) .kb-desktop-hero-car {
    left: clamp(-104px, -2.2vw, -34px) !important;
  }
}

/* OpenClaw cleanup: hide internal auto-calc explanation box from customers */
.kb-price-result,
body.home #local-calculator .kb-price-result,
body.home #schedule .kb-schedule-total {
  display: none !important;
}

/* OpenClaw BigBang owner-facing admin portal */
body.bb-admin-portal { margin:0!important; background:#060910!important; color:#f7f3e8!important; font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif!important; }
.bb-admin-shell { max-width:1180px; margin:0 auto; padding:28px 18px 60px; }
.bb-admin-top { display:flex; justify-content:space-between; gap:24px; align-items:flex-start; margin-bottom:22px; }
.bb-admin-eyebrow { color:#f5d28a; font-size:12px; letter-spacing:.14em; font-weight:950; }
.bb-admin-top h1,.bb-admin-card h1,.bb-admin-card h2 { margin:6px 0 8px; color:#fff; }
.bb-admin-top p,.bb-admin-card p,.bb-admin-empty { color:#b8c1d1; line-height:1.55; }
.bb-admin-top nav { display:flex; gap:9px; flex-wrap:wrap; justify-content:flex-end; }
.bb-admin-top nav a,.bb-admin-btn,.bb-admin-back { color:#111!important; background:#f5d28a; border-radius:999px; padding:10px 13px; text-decoration:none!important; font-weight:900; font-size:13px; }
.bb-admin-card,.bb-admin-stats article { background:rgba(255,255,255,.065); border:1px solid rgba(245,210,138,.18); border-radius:22px; padding:18px; box-shadow:0 18px 45px rgba(0,0,0,.28); margin:16px 0; }
.bb-admin-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.bb-admin-stats span,.bb-admin-stats small { display:block; color:#b8c1d1; }
.bb-admin-stats strong { display:block; font-size:28px; color:#f5d28a; margin:5px 0; }
.bb-admin-table-wrap { overflow:auto; }
.bb-admin-table { width:100%; border-collapse:collapse; min-width:850px; }
.bb-admin-table th,.bb-admin-table td { text-align:left; border-bottom:1px solid rgba(255,255,255,.1); padding:12px 10px; vertical-align:top; }
.bb-admin-table th { color:#f5d28a; font-size:12px; text-transform:uppercase; letter-spacing:.08em; }
.bb-admin-table small { display:block; color:#aeb7c7; margin-top:3px; }
.bb-inline-form { display:flex; gap:7px; }
.bb-inline-form select,.bb-inline-form button,.bb-admin-login-card input[type=text],.bb-admin-login-card input[type=password] { border:1px solid rgba(245,210,138,.25); border-radius:12px; background:rgba(255,255,255,.08); color:#fff; padding:10px; }
.bb-inline-form button,.bb-admin-login-card input[type=submit] { background:#f5d28a!important; color:#111!important; font-weight:950; border:0; cursor:pointer; }
.bb-status { display:inline-block; border-radius:999px; padding:6px 9px; font-size:12px; font-weight:950; background:rgba(255,255,255,.12); }
.bb-status-approved { background:rgba(55,190,120,.2); color:#bff7dc; }
.bb-status-pending { background:rgba(245,210,138,.18); color:#f5d28a; }
.bb-status-rejected { background:rgba(255,80,80,.18); color:#ffd0d0; }
.bb-admin-rate-list { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
.bb-admin-rate-list div { border:1px solid rgba(255,255,255,.1); border-radius:14px; padding:12px; display:flex; justify-content:space-between; gap:12px; }
.bb-admin-rate-list span { color:#f5d28a; font-weight:950; }
.bb-admin-login .bb-admin-shell { min-height:100svh; display:grid; place-items:center; }
.bb-admin-login-card { max-width:480px; width:100%; }
.bb-admin-login-card label { display:block; color:#fff7e3; font-weight:850; margin:12px 0 6px; }
.bb-admin-login-card input[type=text],.bb-admin-login-card input[type=password] { width:100%; box-sizing:border-box; }
.bb-admin-login-card input[type=submit] { width:100%; border-radius:999px; padding:13px; margin-top:10px; }
.bb-admin-back { display:inline-block; margin-top:16px; background:rgba(255,255,255,.1); color:#f5d28a!important; }
@media (max-width:800px){ .bb-admin-top{display:block}.bb-admin-top nav{justify-content:flex-start}.bb-admin-grid,.bb-admin-rate-list{grid-template-columns:1fr}.bb-admin-shell{padding:18px 12px 46px} }

/* OpenClaw dispatch priority admin UI */
.bb-dispatch-flow { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin:16px 0; }
.bb-dispatch-flow div { border:1px solid rgba(245,210,138,.2); border-radius:16px; background:rgba(255,255,255,.055); padding:14px; }
.bb-dispatch-flow b { display:inline-grid; place-items:center; width:30px; height:30px; border-radius:999px; background:#f5d28a; color:#111; margin-bottom:9px; }
.bb-dispatch-flow span { display:block; color:#f7f3e8; font-weight:850; line-height:1.35; }
.bb-priority-input { width:64px!important; }
@media (max-width:800px){ .bb-dispatch-flow{grid-template-columns:1fr} .bb-inline-form{flex-wrap:wrap} }

/* OpenClaw editable rates in BigBang admin portal */
.bb-rates-edit-table input[type="text"],
.bb-rates-edit-table input[type="number"],
.bb-rates-edit-table select {
  width: 100%;
  min-width: 120px;
  border: 1px solid rgba(245,210,138,.25);
  border-radius: 10px;
  background: rgba(255,255,255,.08);
  color: #fff;
  padding: 9px 10px;
  box-sizing: border-box;
}
.bb-rates-edit-table input[type="checkbox"] { transform: scale(1.15); }
.bb-admin-save-btn {
  margin-top: 14px;
  border: 0;
  border-radius: 999px;
  background: #f5d28a;
  color: #111;
  padding: 13px 18px;
  font-weight: 950;
  cursor: pointer;
}
.bb-admin-help { display: block; margin-top: 10px; color: #aeb7c7; }
.bb-admin-help code { color: #f5d28a; }

/* OpenClaw admin readability fix: force visible text in dark portal */
body.bb-admin-portal,
body.bb-admin-portal * {
  color: inherit;
}
body.bb-admin-portal .bb-admin-card,
body.bb-admin-portal .bb-admin-table td,
body.bb-admin-portal .bb-admin-table th,
body.bb-admin-portal .bb-admin-rate-list div,
body.bb-admin-portal label,
body.bb-admin-portal p,
body.bb-admin-portal small {
  color: #f7f3e8 !important;
}
body.bb-admin-portal .bb-admin-table th,
body.bb-admin-portal .bb-admin-eyebrow,
body.bb-admin-portal h1,
body.bb-admin-portal h2,
body.bb-admin-portal h3 {
  color: #f5d28a !important;
}
body.bb-admin-portal input,
body.bb-admin-portal select,
body.bb-admin-portal textarea,
body.bb-admin-portal option {
  color: #ffffff !important;
  background-color: #111827 !important;
  border-color: rgba(245,210,138,.32) !important;
  -webkit-text-fill-color: #ffffff !important;
}
body.bb-admin-portal input::placeholder,
body.bb-admin-portal textarea::placeholder {
  color: rgba(255,255,255,.55) !important;
  -webkit-text-fill-color: rgba(255,255,255,.55) !important;
}
body.bb-admin-portal .bb-admin-save-btn,
body.bb-admin-portal .bb-inline-form button,
body.bb-admin-portal input[type="submit"] {
  color: #111111 !important;
  -webkit-text-fill-color: #111111 !important;
  background: #f5d28a !important;
}

/* OpenClaw simple customer-style flat-rate editor */
.bb-simple-rate-admin .bb-admin-table-wrap,
.bb-simple-rate-admin .bb-rates-edit-table { display: none !important; }
.bb-simple-rate-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 16px;
}
.bb-simple-rate-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 14px;
  border: 1px solid rgba(245,210,138,.2);
  border-radius: 18px;
  background: rgba(255,255,255,.055);
}
.bb-simple-rate-name b {
  display: block;
  color: #fff !important;
  line-height: 1.35;
}
.bb-simple-rate-name small {
  display: block;
  margin-top: 4px;
  color: rgba(255,255,255,.58) !important;
  font-size: 12px;
}
.bb-simple-price-control {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: 1px solid rgba(245,210,138,.25);
  border-radius: 999px;
  padding: 5px;
  background: rgba(0,0,0,.22);
}
.bb-simple-price-control span {
  color: #f5d28a !important;
  font-weight: 950;
  padding-left: 4px;
}
.bb-simple-price-control input {
  width: 74px !important;
  text-align: center;
  border: 0 !important;
  background: transparent !important;
  color: #fff !important;
  -webkit-text-fill-color: #fff !important;
  font-size: 18px;
  font-weight: 950;
  padding: 7px 0 !important;
}
.bb-simple-price-control button {
  width: 32px;
  height: 32px;
  border: 0;
  border-radius: 999px;
  background: #f5d28a;
  color: #111;
  font-weight: 950;
  cursor: pointer;
}
@media (max-width: 900px) {
  .bb-simple-rate-list { grid-template-columns: 1fr; }
  .bb-simple-rate-card { align-items: flex-start; flex-direction: column; }
  .bb-simple-price-control { width: 100%; justify-content: space-between; }
}

/* OpenClaw add/delete flat-rate cards */
.bb-simple-rate-toolbar { margin: 14px 0; display:flex; justify-content:flex-end; }
.bb-admin-add-rate { border:0; border-radius:999px; background:rgba(245,210,138,.16); color:#f5d28a; padding:11px 15px; font-weight:950; cursor:pointer; }
.bb-simple-rate-card { position: relative; }
.bb-rate-label-input,
.bb-rate-region-input { width:100%!important; border:1px solid rgba(245,210,138,.22)!important; border-radius:12px!important; background:rgba(255,255,255,.075)!important; color:#fff!important; -webkit-text-fill-color:#fff!important; padding:9px 10px!important; }
.bb-rate-region-input { margin-top:7px; font-size:12px; color:#f5d28a!important; -webkit-text-fill-color:#f5d28a!important; }
.bb-delete-rate { position:absolute; right:12px; bottom:8px; font-size:12px; color:rgba(255,170,170,.92)!important; display:flex; gap:4px; align-items:center; }
.bb-delete-rate input:checked + span { color:#ff8080!important; }
.bb-simple-rate-card:has(.bb-delete-rate input:checked) { opacity:.48; outline:1px solid rgba(255,80,80,.45); }

/* OpenClaw simple option editor mirrors flat-rate editor */
.bb-simple-option-list { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:12px; margin-top:16px; }
.bb-simple-option-card { position:relative; display:flex; align-items:center; justify-content:space-between; gap:14px; padding:14px; border:1px solid rgba(245,210,138,.2); border-radius:18px; background:rgba(255,255,255,.055); }
.bb-option-unit-input { width:100%!important; margin-top:7px; border:1px solid rgba(245,210,138,.22)!important; border-radius:12px!important; background:rgba(255,255,255,.075)!important; color:#f5d28a!important; -webkit-text-fill-color:#f5d28a!important; padding:9px 10px!important; font-size:12px; }
.bb-simple-option-card:has(.bb-delete-rate input:checked) { opacity:.48; outline:1px solid rgba(255,80,80,.45); }
@media (max-width:900px){ .bb-simple-option-list{grid-template-columns:1fr}.bb-simple-option-card{align-items:flex-start;flex-direction:column} }

/* OpenClaw real approve/reject buttons for driver applications */
.bb-driver-action-form {
  align-items: center;
  flex-wrap: wrap;
}
.bb-driver-action-form button {
  border: 0 !important;
  border-radius: 999px !important;
  padding: 9px 12px !important;
  font-weight: 950 !important;
  cursor: pointer !important;
}
.bb-driver-action-form .bb-driver-approve {
  background: #32d583 !important;
  color: #062512 !important;
}
.bb-driver-action-form .bb-driver-reject {
  background: #ff6b6b !important;
  color: #300 !important;
}
.bb-driver-action-form .bb-driver-pending {
  background: rgba(245,210,138,.22) !important;
  color: #f5d28a !important;
}
.bb-driver-action-form .bb-priority-input {
  width: 58px !important;
  text-align: center !important;
}

/* OpenClaw card-style driver approval management */
.bb-driver-approval-section > p { color: #b8c1d1 !important; }
.bb-driver-empty { display: grid; gap: 6px; }
.bb-driver-empty b { color: #f5d28a !important; font-size: 18px; }
.bb-driver-empty span { color: #d9e1ef !important; }
.bb-driver-approval-list { display: grid; gap: 14px; margin-top: 16px; }
.bb-driver-approval-card {
  border: 1px solid rgba(245,210,138,.2);
  border-radius: 20px;
  background: rgba(255,255,255,.055);
  padding: 16px;
  display: grid;
  gap: 14px;
}
.bb-driver-card-pending { border-color: rgba(245,210,138,.42); }
.bb-driver-card-approved { border-color: rgba(50,213,131,.42); }
.bb-driver-card-rejected { border-color: rgba(255,107,107,.42); opacity: .78; }
.bb-driver-card-main {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) 1.5fr;
  gap: 14px;
}
.bb-driver-card-main h3 { margin: 8px 0 4px !important; color: #fff !important; }
.bb-driver-card-main p { margin: 0 !important; color: #aeb7c7 !important; }
.bb-driver-meta { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 8px; }
.bb-driver-meta span {
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 12px;
  padding: 9px 10px;
  color: #f7f3e8 !important;
  background: rgba(0,0,0,.16);
}
.bb-driver-card-actions {
  display: flex !important;
  gap: 9px;
  align-items: center;
  flex-wrap: wrap;
  border-top: 1px solid rgba(255,255,255,.1);
  padding-top: 14px;
}
.bb-driver-card-actions label {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: #f5d28a !important;
  font-weight: 900;
}
.bb-driver-card-actions .bb-priority-input { width: 64px !important; }
@media (max-width: 800px) {
  .bb-driver-card-main { grid-template-columns: 1fr; }
  .bb-driver-meta { grid-template-columns: 1fr; }
  .bb-driver-card-actions button { flex: 1 1 100px; }
}

/* OpenClaw finance dashboard cards */
.bb-finance-stats article { border-color: rgba(50,213,131,.22); }
.bb-finance-stats strong { font-size: 26px !important; }
.bb-admin-empty b { display:block; color:#f5d28a!important; margin-bottom:4px; }
.bb-admin-empty span { color:#d9e1ef!important; }

/* OpenClaw admin tabbed sections */
body.bb-admin-portal .bb-admin-card[id] {
  display: none !important;
}
body.bb-admin-portal .bb-admin-card[id].bb-admin-section-active {
  display: block !important;
}
body.bb-admin-portal .bb-admin-top nav a.active {
  background: #fff7d6 !important;
  color: #111 !important;
  box-shadow: 0 8px 22px rgba(245,210,138,.22);
}
body.bb-admin-portal .bb-admin-stats {
  display: none !important;
}
body.bb-admin-portal[data-admin-tab="bookings"] .bb-admin-stats,
body.bb-admin-portal[data-admin-tab="dispatch"] .bb-admin-stats {
  display: grid !important;
}

/* OpenClaw rate management split: flat vs local calculator */
.bb-rate-mode-buttons { display:flex; gap:10px; margin:16px 0; flex-wrap:wrap; }
.bb-rate-mode-buttons button { border:1px solid rgba(245,210,138,.26); border-radius:999px; background:rgba(255,255,255,.08); color:#f5d28a; padding:12px 16px; font-weight:950; cursor:pointer; }
.bb-rate-mode-buttons button.active { background:#f5d28a; color:#111; }
.bb-rate-mode-panel { display:none; }
.bb-rate-mode-panel.active { display:block; }
.bb-local-rate-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:12px; margin:16px 0; }
.bb-local-rate-grid label { display:grid; gap:7px; color:#f5d28a!important; font-weight:900; }
.bb-local-rate-grid input { border:1px solid rgba(245,210,138,.25)!important; border-radius:14px!important; background:#111827!important; color:#fff!important; -webkit-text-fill-color:#fff!important; padding:12px!important; font-size:17px; font-weight:900; }
.bb-local-rate-preview { border:1px solid rgba(255,255,255,.12); border-radius:16px; padding:13px; color:#d9e1ef; background:rgba(255,255,255,.055); margin-bottom:14px; }
@media (max-width:800px){ .bb-local-rate-grid{grid-template-columns:1fr} }

/* OpenClaw: push default hero car right for desktop */
@media (min-width: 761px) {
  body.home .kb-desktop-hero-car {
    left: clamp(100px, 12vw, 240px) !important;
  }
}

/* OpenClaw fix: default desktop hero car should stay on the right, not left */
@media (min-width: 761px) {
  body.home .kb-hero-grid:not(:has(#schedule:not(.kb-local-calc-hidden))) .kb-desktop-hero-car {
    left: auto !important;
    right: -128px !important;
    top: 48px !important;
  }
}

/* OpenClaw: BigBang OAuth integration cards */
.bb-integrations-admin .bb-integration-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:14px; margin-top:16px; }
.bb-integration-card { border:1px solid rgba(245,210,138,.18); border-radius:18px; padding:16px; background:rgba(255,255,255,.055); display:flex; flex-direction:column; gap:10px; }
.bb-integration-head { display:flex; justify-content:space-between; gap:14px; align-items:flex-start; }
.bb-integration-head span { color:#f5d28a!important; font-size:12px; font-weight:950; letter-spacing:.08em; text-transform:uppercase; }
.bb-integration-head h3 { margin:4px 0 0!important; color:#fff!important; font-size:20px; }
.bb-integration-head b { white-space:nowrap; border-radius:999px; padding:7px 10px; background:rgba(255,255,255,.09); color:#d9e1ef!important; font-size:12px; }
.bb-integration-card p { margin:0!important; color:#c8d1df!important; }
.bb-integration-card small { display:block; color:#aeb7c7!important; }
.bb-integration-note { border-radius:14px; padding:10px 12px; background:rgba(0,0,0,.22); color:#d9e1ef; font-size:13px; line-height:1.45; }
.bb-integration-connected { border-color:rgba(50,213,131,.42); }
.bb-integration-connected .bb-integration-head b { background:rgba(50,213,131,.16); color:#63f09c!important; }
.bb-integration-error { border-color:rgba(248,113,113,.45); }
.bb-integration-error .bb-integration-head b { background:rgba(248,113,113,.16); color:#fca5a5!important; }
.bb-integration-inProgress .bb-integration-head b { background:rgba(245,210,138,.16); color:#f5d28a!important; }
.bb-integration-connect { text-align:center; margin-top:auto; display:block!important; }
.bb-integration-safe { margin-top:14px; padding:12px; border-radius:14px; background:rgba(50,213,131,.08); border:1px solid rgba(50,213,131,.18); color:#d9e1ef!important; }
@media (max-width:800px){ .bb-integrations-admin .bb-integration-grid{grid-template-columns:1fr} }

/* OpenClaw: always-visible shortcut to OAuth integrations */
body.bb-admin-portal .bb-integration-shortcut[data-always-visible="1"] { display:flex!important; justify-content:space-between; gap:18px; align-items:center; border-color:rgba(50,213,131,.32); background:linear-gradient(135deg,rgba(50,213,131,.12),rgba(245,210,138,.08)); }
.bb-integration-shortcut h2 { margin:5px 0!important; }
.bb-integration-shortcut p { margin:0!important; }
.bb-integration-shortcut .bb-admin-save-btn { white-space:nowrap; text-align:center; }
@media (max-width:800px){ body.bb-admin-portal .bb-integration-shortcut[data-always-visible="1"]{display:block!important}.bb-integration-shortcut .bb-admin-save-btn{display:block!important;margin-top:12px} }

/* OpenClaw: OAuth setup guidance must look clickable/resultful */
.bb-oauth-server-setup { margin-top:16px; border:1px dashed rgba(245,210,138,.35); border-radius:16px; padding:14px; background:rgba(245,210,138,.08); line-height:1.65; }
.bb-oauth-server-setup code { display:inline-block; margin:3px 0; padding:2px 7px; border-radius:8px; background:rgba(0,0,0,.28); color:#f5d28a!important; }
.bb-integration-connect[data-ready="0"] { background:rgba(255,255,255,.12)!important; color:#f5d28a!important; border:1px solid rgba(245,210,138,.3)!important; }

/* OpenClaw: no-JS fallback for the real integrations URL */
body.bb-admin-portal[data-initial-admin-tab="integrations"] .bb-admin-card#integrations { display:block!important; }
body.bb-admin-portal[data-initial-admin-tab="integrations"] .bb-admin-stats { display:none!important; }

.bb-integration-open-form { margin:0; }
.bb-integration-open-form button.bb-admin-save-btn { border:0; cursor:pointer; font:inherit; }

/* OpenClaw: provider setup expandable guidance */
.bb-provider-setup { display:none; margin-top:10px; padding:13px; border-radius:14px; border:1px dashed rgba(245,210,138,.34); background:rgba(245,210,138,.08); color:#d9e1ef; line-height:1.55; }
.bb-provider-setup.open { display:block !important; }
.bb-provider-setup b { display:block; color:#f5d28a!important; margin-bottom:6px; }
.bb-provider-setup p { margin:0 0 8px!important; font-size:13px; }
.bb-provider-setup code { display:block; margin:4px 0; padding:5px 8px; border-radius:8px; background:rgba(0,0,0,.30); color:#f5d28a!important; font-size:12px; }
.bb-provider-setup small { display:block; margin-top:8px; color:#aeb7c7!important; }
button.bb-setup-toggle { cursor:pointer; border:1px solid rgba(245,210,138,.35)!important; }

/* OpenClaw final UI fix: integrations only show when the 권한 연결 tab is active */
body.bb-admin-portal .bb-integration-shortcut[data-always-visible="1"] { display: none !important; }
body.bb-admin-portal .bb-admin-card#integrations { display: none !important; order: initial !important; }
body.bb-admin-portal .bb-admin-card#integrations.bb-admin-section-active { display: block !important; }

/* OpenClaw hard override: keep 권한 연결 hidden on every admin tab except integrations */
body.bb-admin-portal .bb-admin-card#integrations.bb-integrations-admin,
body.bb-admin-portal .bb-admin-card#integrations {
  display: none !important;
  order: initial !important;
  border-width: 1px !important;
  box-shadow: 0 14px 34px rgba(0,0,0,.24) !important;
}
body.bb-admin-portal .bb-admin-card#integrations.bb-integrations-admin:before,
body.bb-admin-portal .bb-admin-card#integrations:before {
  display: none !important;
  content: none !important;
}
body.bb-admin-portal[data-admin-tab="integrations"] .bb-admin-card#integrations,
body.bb-admin-portal[data-initial-admin-tab="integrations"] .bb-admin-card#integrations,
body.bb-admin-portal .bb-admin-card#integrations.bb-admin-section-active {
  display: block !important;
}
body.bb-admin-portal:not([data-admin-tab="integrations"]):not([data-initial-admin-tab="integrations"]) .bb-admin-card#integrations {
  display: none !important;
}

/* OpenClaw: hide internal OAuth/server constant names from admin/client-facing UI */
body.bb-admin-portal .bb-oauth-server-setup,
body.bb-admin-portal .bb-provider-setup code {
  display: none !important;
}
body.bb-admin-portal .bb-provider-setup small {
  display: none !important;
}

/* OpenClaw: guided Google Business Profile Smartor invite flow */
.bb-gbp-invite-guide { margin-top:16px; border:1px solid rgba(245,210,138,.24); border-radius:20px; padding:18px; background:linear-gradient(135deg,rgba(50,213,131,.09),rgba(245,210,138,.07)); }
.bb-gbp-guide-head span { color:#63f09c!important; font-size:12px; font-weight:950; letter-spacing:.08em; text-transform:uppercase; }
.bb-gbp-guide-head h3 { margin:6px 0 8px!important; color:#f5d28a!important; }
.bb-gbp-guide-head p { margin:0 0 14px!important; color:#d9e1ef!important; }
.bb-gbp-steps { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:12px; }
.bb-gbp-steps > div { background:rgba(255,255,255,.055); border:1px solid rgba(255,255,255,.12); border-radius:16px; padding:14px; }
.bb-gbp-steps b { display:inline-grid; place-items:center; width:30px; height:30px; border-radius:999px; background:#f5d28a; color:#111!important; margin-bottom:8px; }
.bb-gbp-steps h4 { margin:0 0 6px!important; color:#f5d28a!important; }
.bb-gbp-steps p,.bb-gbp-steps small { color:#d9e1ef!important; }
.bb-gbp-steps code { display:block; margin-top:8px; padding:9px 10px; border-radius:10px; background:rgba(0,0,0,.32); color:#63f09c!important; font-weight:950; user-select:all; }
.bb-gbp-note { margin-top:12px; padding:12px; border-radius:14px; background:rgba(0,0,0,.18); color:#f7f3e8!important; }
@media(max-width:900px){ .bb-gbp-steps{grid-template-columns:1fr} }
