
:root{
  --navy:#0B1F33;
  --navy-700:#163B5C;
  --amber:#F7B500;
  --amber-hover:#D69300;
  --surface:#FFFFFF;
  --surface-soft:#F8FAFC;
  --surface-alt:#EEF4F8;
  --ink:#0F172A;
  --ink-soft:#475569;
  --border:#E2E8F0;
  --border-strong:#C9D4E2;
  --whatsapp:#0F7A42;
  --focus:#2563EB;
  --shadow-sm:0 10px 24px rgba(15,23,42,.06);
  --shadow-md:0 24px 50px rgba(11,31,51,.12);
  --radius-xs:10px;
  --radius-sm:14px;
  --radius-md:18px;
  --radius-lg:24px;
  --radius-xl:32px;
  --container:1240px;
  --space-1:4px;
  --space-2:8px;
  --space-3:12px;
  --space-4:16px;
  --space-5:20px;
  --space-6:24px;
  --space-7:32px;
  --space-8:40px;
  --space-9:48px;
  --space-10:56px;
  --space-11:64px;
  --space-12:80px;
  --space-13:96px;
}
*,
*::before,
*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none !important;transition:none !important}
}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);
  background:var(--surface);
  line-height:1.6;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;height:auto}
svg{display:block}
a{color:inherit;text-decoration:none}
button,input,textarea,select{font:inherit}
button{cursor:pointer}
[hidden]{display:none !important}
main{overflow:clip}
h1,h2,h3,h4{
  margin:0;
  font-weight:800;
  line-height:1.14;
  letter-spacing:-.02em;
}
p{margin:0 0 var(--space-5)}
ul,ol{margin:0;padding:0}
li{list-style:none}
.container{
  max-width:var(--container);
  margin:0 auto;
  padding-inline:32px;
}
.sr-only{
  position:absolute;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);
  white-space:nowrap;border:0
}
.skip-link{
  position:absolute;
  left:16px;top:-48px;
  background:var(--navy);
  color:#fff;
  padding:12px 16px;
  border-radius:12px;
  z-index:2000;
  transition:top .2s ease;
}
.skip-link:focus{top:16px}
:focus-visible{
  outline:3px solid var(--focus);
  outline-offset:3px;
}
body.scrolled .site-header{
  box-shadow:0 12px 40px rgba(11,31,51,.08);
  border-color:rgba(226,232,240,.8)
}
.site-header{
  position:sticky;
  top:0;
  z-index:1000;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(226,232,240,.95);
  transition:box-shadow .25s ease,background .25s ease;
}
.site-header .container{max-width:1600px}
.site-header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  min-height:72px;
  gap:24px;
}
.logo{
  display:flex;
  align-items:center;
  gap:14px;
  min-width:0;
}
.logo-image{
  display:block;
  width:auto;
  height:52px;
  max-width:min(280px,50vw);
  object-fit:contain;
}
.logo-svg{
  display:block;
  width:auto;
  height:52px;
  max-width:min(280px,50vw);
}
.logo--compact .logo-image{
  height:44px;
  max-width:min(220px,58vw);
}
.logo--compact .logo-svg{
  height:44px;
  max-width:min(220px,58vw);
}
.logo--footer .logo-image{
  height:64px;
  max-width:min(300px,100%);
}
.logo-mark{
  width:44px;
  height:50px;
  flex:0 0 44px;
  border-radius:0;
  display:grid;
  place-items:center;
  background:transparent;
  color:inherit;
  box-shadow:none;
  overflow:visible;
}
.logo-mark svg,
.logo-mark img{
  width:100%;
  height:100%;
  display:block;
  object-fit:contain;
}
.logo-copy{display:flex;flex-direction:column;gap:2px;min-width:0}
.logo-copy strong{
  font-size:1rem;
  line-height:1.05;
}
.brand-wordmark{
  display:inline-flex;
  align-items:baseline;
  flex-wrap:wrap;
  column-gap:.16em;
  row-gap:0;
  font-weight:900;
}
.brand-wordmark__noro,
.brand-wordmark__taxi{color:var(--navy)}
.brand-wordmark__madrid{color:var(--amber)}
.logo--footer .brand-wordmark__noro,
.logo--footer .brand-wordmark__taxi{color:#fff}
.logo-copy small{font-size:.82rem;color:var(--ink-soft);white-space:nowrap}
.logo--footer .logo-copy small{color:#CBD5E1}
.logo--compact .logo-copy small{display:none}
.site-nav{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:8px;
  flex:1 1 auto;
  min-width:0;
}
.nav-link{
  display:inline-flex;
  align-items:center;
  min-height:44px;
  padding:10px 14px;
  border-radius:999px;
  color:var(--ink-soft);
  font-weight:600;
}
.nav-link:hover,
.nav-link[aria-current="page"]{
  color:var(--ink);
  background:var(--surface-soft);
}
.header-actions,
.header-mobile-actions{
  display:flex;
  align-items:center;
  gap:12px;
}
.header-actions{
  flex:0 0 auto;
  flex-wrap:nowrap;
}
.header-mobile-actions{display:none}
.header-phone{
  display:inline-flex;
  align-items:center;
  gap:10px;
  min-height:46px;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid var(--border);
  background:#fff;
  font-weight:700;
  white-space:nowrap;
  flex:0 0 auto;
}
.header-phone span:last-child{white-space:nowrap}
.header-phone .icon-svg,
.mobile-call .icon-svg{width:18px;height:18px}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:52px;
  padding:0 20px;
  border-radius:14px;
  border:1px solid transparent;
  font-weight:700;
  letter-spacing:-.01em;
  transition:transform .18s ease,background .18s ease,border-color .18s ease,color .18s ease,box-shadow .18s ease;
}
.btn:hover{transform:translateY(-1px)}
.btn:disabled{
  opacity:.72;
  cursor:wait;
  transform:none;
}
.page-loading-indicator{
  position:fixed;
  inset:0 0 auto;
  z-index:5000;
  display:flex;
  justify-content:center;
  padding:max(10px, env(safe-area-inset-top)) 16px 0;
  pointer-events:none;
}
.page-loading-indicator[hidden]{display:none}
.page-loading-indicator__panel{
  display:inline-flex;
  align-items:center;
  gap:10px;
  min-height:44px;
  max-width:min(92vw,420px);
  padding:8px 14px;
  border:1px solid rgba(226,232,240,.96);
  border-radius:999px;
  background:rgba(255,255,255,.98);
  color:var(--navy);
  box-shadow:0 16px 38px rgba(11,31,51,.18);
  font-size:.92rem;
  font-weight:800;
}
.page-loading-indicator__spinner{
  width:18px;
  height:18px;
  flex:0 0 18px;
  border:3px solid rgba(11,31,51,.16);
  border-top-color:var(--amber);
  border-radius:999px;
  animation:page-loading-spin .8s linear infinite;
}
@keyframes page-loading-spin{
  to{transform:rotate(360deg)}
}
.btn--compact{min-height:46px;padding-inline:16px}
.btn--full{width:100%}
.btn--primary{
  background:var(--amber);
  color:var(--navy);
  text-shadow:0px 0px 1px #ffffff;
  box-shadow:0 10px 20px rgba(247,181,0,.2);
}
.btn--primary:hover{background:var(--amber-hover)}
.btn--request-now{
  box-shadow:0 12px 22px rgba(247,181,0,.26);
}
.btn--secondary{
  background:#fff;
  color:var(--navy);
  border-color:var(--navy);
}
.btn--secondary:hover{background:var(--surface-soft)}
.btn--ghost{
  background:#fff;
  color:var(--navy);
  border-color:var(--border);
}
.btn--ghost:hover{border-color:var(--navy)}
.btn--outline{
  background:transparent;
  color:#fff;
  border-color:rgba(255,255,255,.35);
}
.btn--outline:hover{background:rgba(255,255,255,.12)}
.btn--whatsapp{
  background:#fff;
  color:var(--whatsapp);
  border-color:rgba(15,122,66,.25);
}
.icon-svg{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 auto;
  width:20px;
  height:20px;
  line-height:1;
}
.icon-svg svg{
  width:100%;
  height:100%;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.card-icon svg,
.metric__icon svg,
.process-card__icon svg{
  width:20px;height:20px;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.card-icon svg[fill="currentColor"]{
  stroke:none;
}
.mobile-drawer[hidden]{display:none !important}
.mobile-drawer{
  position:fixed;
  inset:0;
  background:rgba(2,6,23,.55);
  z-index:1200;
  padding:16px;
  display:grid;
  place-items:end;
}
.mobile-drawer__panel{
  margin-left:auto;
  width:min(420px,100%);
  height:100%;
  background:#fff;
  border-radius:8px;
  display:flex;
  flex-direction:column;
  padding:20px;
  box-shadow:var(--shadow-md);
  overflow:auto;
}
.mobile-drawer__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding-bottom:16px;
  border-bottom:1px solid var(--border);
  margin-bottom:16px;
}
.menu-toggle,
.menu-close{
  appearance:none;
  border:1px solid var(--border);
  background:#fff;
  color:var(--navy);
  width:48px;height:48px;
  border-radius:14px;
  display:grid;
  place-items:center;
}
.mobile-drawer__quick{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
  margin-bottom:18px;
}
.mobile-drawer__quick .btn{
  justify-content:center;
}
.mobile-nav{
  display:grid;
  gap:18px;
  padding-bottom:8px;
}
.mobile-drawer__section{
  display:grid;
  gap:8px;
}
.mobile-drawer__section-title{
  margin:0;
  color:var(--ink-soft);
  font-size:.82rem;
  line-height:1.2;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.mobile-drawer__link-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:4px;
}
.mobile-nav__link{
  min-height:44px;
  padding:12px;
  border-radius:8px;
  font-weight:700;
  display:flex;
  align-items:center;
  color:var(--ink);
}
.mobile-nav__link:hover{background:var(--surface-soft)}
.mobile-drawer__actions{
  margin-top:auto;
  display:grid;
  gap:12px;
}
.mobile-action-bar{
  position:fixed;
  left:0;right:0;bottom:0;
  z-index:900;
  display:none;
  align-items:center;
  gap:12px;
  padding:12px 20px calc(12px + env(safe-area-inset-bottom));
  background:rgba(255,255,255,.95);
  border-top:1px solid rgba(226,232,240,.96);
  backdrop-filter:blur(12px);
}
.mobile-action-bar .btn{
  width:100%;
  min-width:0;
  min-height:52px;
  padding-inline:10px;
  gap:6px;
  white-space:nowrap;
  text-align:center;
  line-height:1.05;
  font-size:clamp(.84rem,3.75vw,.95rem);
}
.mobile-action-bar .btn .icon-svg{
  width:17px;
  height:17px;
  flex:0 0 auto;
}
body.no-mobile-action-bar,
body.page--transactional,
body.page--legal{
  padding-bottom:0;
}
body.no-mobile-action-bar .mobile-action-bar,
body.mobile-menu-open .mobile-action-bar,
body.chat-open .mobile-action-bar,
body.is-form-focused .mobile-action-bar,
body.page--transactional .mobile-action-bar,
body.page--legal .mobile-action-bar{
  display:none !important;
}
.section{padding:80px 0}
.section--tight{padding:56px 0}
.section--soft{background:var(--surface-soft)}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin:0 0 12px;
  color:var(--navy-700);
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:.78rem;
}
.section-heading{
  max-width:760px;
  margin-bottom:28px;
}
.section-heading--centered{
  text-align:center;
  margin-inline:auto;
}
.section-heading h2{
  font-size:clamp(1.9rem,2vw + 1rem,2.5rem);
  margin-bottom:12px;
}
.section-lead{
  color:var(--ink-soft);
  font-size:1.08rem;
  line-height:1.75;
}
.hero-home{
  background:
    radial-gradient(circle at top right, rgba(247,181,0,.14), transparent 34%),
    linear-gradient(135deg,var(--navy) 0%, var(--navy-700) 100%);
  color:#fff;
  padding:72px 0 80px;
  overflow:hidden;
}
.hero-home__grid{
  display:grid;
  grid-template-columns:minmax(0,1.15fr) minmax(320px,.85fr);
  gap:48px;
  align-items:center;
}
.hero-badge{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.08);
  font-weight:700;
  font-size:.94rem;
}
.hero-home h1{
  margin-top:20px;
  font-size:clamp(2.3rem,3.2vw + 1rem,3.2rem);
  max-width:12ch;
}
.hero-home__lead{
  margin-top:18px;
  max-width:58ch;
  color:#E2E8F0;
  font-size:1.15rem;
  line-height:1.8;
}
.chip-list{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:24px;
}
.chip-list--tight{margin-top:14px}
.chip{
  display:inline-flex;
  align-items:center;
  min-height:40px;
  padding:0 14px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.08);
  color:inherit;
  font-weight:700;
  font-size:.92rem;
}
.hero-home__actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:28px;
}
.hero-quick{
  background:#fff;
  color:var(--ink);
  border-radius:28px;
  box-shadow:var(--shadow-md);
  overflow:hidden;
}
.hero-quick__body{
  padding:24px;
  display:grid;
  gap:16px;
}
.hero-quick__body h2{
  font-size:1.45rem;
}
.quick-stack{
  display:grid;
  gap:16px;
}
.quick-card{
  border:1px solid var(--border);
  border-radius:18px;
  padding:20px;
  background:var(--surface-soft);
}
.quick-card h3{
  font-size:1.1rem;
  margin-bottom:8px;
}
.quick-card p{
  color:var(--ink-soft);
  margin-bottom:14px;
}
.quick-card__actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.media-panel{
  overflow:hidden;
  border-radius:24px;
  box-shadow:var(--shadow-sm);
  background:var(--surface-soft);
}
.hero-home .media-panel{margin-top:18px}
.media-panel img{
  width:100%;
  aspect-ratio: 16 / 10;
  object-fit:cover;
}
.trust-strip{
  transform:translateY(-28px);
}
.trust-strip__inner{
  background:#fff;
  border-radius:22px;
  border:1px solid var(--border);
  box-shadow:var(--shadow-sm);
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:18px 24px;
  padding:24px 28px;
}
.metric{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  grid-template-areas:
    "icon value"
    "icon label";
  column-gap:14px;
  row-gap:4px;
  align-items:start;
}
.metric__icon{
  grid-area:icon;
  width:44px;height:44px;
  display:grid;place-items:center;
  border-radius:12px;
  background:rgba(22,59,92,.08);
  color:var(--navy-700);
}
.metric strong{
  grid-area:value;
  display:block;
  font-size:1.45rem;
  line-height:1.05;
  margin-top:2px;
}
.metric span{
  grid-area:label;
  min-width:0;
  color:var(--ink-soft);
  line-height:1.5;
}
.grid-2,
.grid-3,
.grid-4{
  display:grid;
  gap:22px;
}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:18px;
  padding:24px;
  box-shadow:var(--shadow-sm);
}
.card h3{
  font-size:1.18rem;
  margin-bottom:12px;
}
.card p{color:var(--ink-soft);margin-bottom:16px}
.card-icon{
  width:44px;height:44px;
  display:grid;place-items:center;
  border-radius:12px;
  background:rgba(22,59,92,.08);
  color:var(--navy-700);
  margin-bottom:14px;
}
.card-icon svg,
.metric__icon svg{width:24px;height:24px}
.text-link{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-weight:800;
  color:var(--navy-700);
}
.text-link .icon-svg{width:16px;height:16px}
.route-card{
  position:relative;
  cursor:pointer;
  transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease;
}
.route-card:hover,
.route-card:focus-within{
  transform:translateY(-2px);
  border-color:rgba(22,59,92,.18);
  box-shadow:0 18px 38px rgba(11,31,51,.1);
}
.route-card:focus-within{
  outline:2px solid rgba(247,181,0,.7);
  outline-offset:4px;
}
.route-card a[href*="reservar"]::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
}
.step-grid{
  display:grid;
  gap:24px;
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.step-card{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  align-items:start;
  column-gap:16px;
  row-gap:8px;
}
.step-number{
  width:34px;height:34px;
  display:grid;place-items:center;
  border-radius:999px;
  background:var(--amber);
  color:var(--navy);
  font-weight:800;
  flex:0 0 auto;
}
.step-card h3{margin:4px 0 0}
.step-card p{
  grid-column:2;
  margin:0;
}
.route-card__meta,
.review-card__top,
.article-meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:12px;
  margin-bottom:14px;
  color:var(--ink-soft);
  font-size:.95rem;
}
.route-card__meta .icon-svg{width:18px;height:18px}
.review-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:18px;
  padding:24px;
  box-shadow:var(--shadow-sm);
}
.review-card h3{
  font-size:1.05rem;
  margin-bottom:10px;
}
.review-card p{color:var(--ink-soft);margin-bottom:0}
.stars{
  display:flex;
  gap:2px;
  color:var(--amber);
}
.stars .icon-svg{width:16px;height:16px}
.pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:32px;
  padding:0 12px;
  border-radius:999px;
  background:rgba(247,181,0,.14);
  color:#7A5800;
  font-size:.82rem;
  font-weight:800;
}
.pill .icon-svg{width:14px;height:14px}
.pill--outline{
  background:#fff;
  border:1px solid var(--border);
  color:var(--ink-soft);
}
.pill--navy{
  background:rgba(22,59,92,.08);
  color:var(--navy-700);
}
.page-intro{
  background:var(--surface-soft);
  padding:48px 0 56px;
}
.page-intro__grid{
  display:grid;
  gap:36px;
  align-items:center;
  grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr);
}
.page-intro h1{
  font-size:clamp(2rem,2vw + 1rem,3rem);
  margin-bottom:16px;
}
.page-intro p{
  color:var(--ink-soft);
  font-size:1.08rem;
  line-height:1.8;
  max-width:60ch;
}
.page-intro__actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:22px;
}
.breadcrumb{
  padding:20px 0 0;
}
.breadcrumb ol{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  color:var(--ink-soft);
  font-size:.95rem;
}
.breadcrumb li+li::before{
  content:"/";
  margin-right:8px;
  color:#94A3B8;
}
.breadcrumb li{display:flex;align-items:center}
.breadcrumb a:hover{color:var(--ink)}
.subnav{
  position:sticky;
  top:88px;
  z-index:5;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  padding:16px 0 4px;
  background:linear-gradient(180deg,#fff 70%, rgba(255,255,255,0));
}
.subnav a{
  min-height:40px;
  display:inline-flex;
  align-items:center;
  padding:0 14px;
  border-radius:999px;
  background:var(--surface-soft);
  color:var(--ink-soft);
  font-weight:700;
}
.subnav a:hover{color:var(--ink)}
.local-layout{
  display:grid;
  gap:36px;
  grid-template-columns:minmax(0,1fr) 320px;
  align-items:start;
}
.sticky-card{
  position:sticky;
  top:124px;
  display:grid;
  gap:16px;
  padding:24px;
  border-radius:20px;
  border:1px solid var(--border);
  background:#fff;
  box-shadow:var(--shadow-sm);
}
.sticky-card__list{
  display:grid;
  gap:12px;
}
.sticky-card__item{
  display:flex;
  gap:12px;
  align-items:flex-start;
  color:var(--ink-soft);
}
.content-stack{
  display:grid;
  gap:56px;
}
.feature-list{
  display:grid;
  gap:14px;
}
.feature-list li{
  display:flex;
  gap:12px;
  align-items:flex-start;
}
.feature-list .icon-svg{
  width:18px;height:18px;
  color:var(--navy-700);
  margin-top:4px;
}
.feature-list span:last-child{color:var(--ink-soft)}
.coverage-search{
  background:#fff;
  border:1px solid var(--border);
  border-radius:22px;
  padding:20px;
  box-shadow:var(--shadow-sm);
}
.search-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:12px;
  align-items:start;
}
.search-row input{
  min-height:54px;
}
.home-town-combobox{
  position:relative;
  min-width:0;
}
.home-town-combobox input{
  width:100%;
  border:1px solid rgba(11,31,51,.14);
  border-radius:14px;
  background:#F7F9FC;
  color:var(--ink);
  padding:0 16px;
  box-shadow:inset 0 0 0 1px transparent;
  transition:border-color .2s ease, box-shadow .2s ease, background .2s ease;
}
.home-town-combobox input:focus{
  outline:none;
  border-color:var(--navy-700);
  background:#fff;
  box-shadow:0 0 0 4px rgba(13,60,94,.12);
}
.home-town-suggestions{
  position:absolute;
  z-index:30;
  top:calc(100% + 8px);
  left:0;
  right:0;
  display:grid;
  gap:4px;
  max-height:286px;
  overflow:auto;
  padding:8px;
  border:1px solid rgba(11,31,51,.12);
  border-radius:16px;
  background:#fff;
  box-shadow:0 18px 40px rgba(11,31,51,.14);
}
.home-town-suggestion{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  width:100%;
  min-height:46px;
  padding:10px 12px;
  border:0;
  border-radius:12px;
  background:transparent;
  color:var(--ink);
  font-weight:800;
  text-align:left;
  cursor:pointer;
}
.home-town-suggestion::after{
  content:"";
  width:8px;
  height:8px;
  flex:0 0 auto;
  border-top:2px solid currentColor;
  border-right:2px solid currentColor;
  transform:rotate(45deg);
  opacity:.42;
}
.home-town-suggestion:hover,
.home-town-suggestion:focus,
.home-town-suggestion.is-active{
  outline:none;
  background:#F0F4F8;
  color:var(--navy-700);
}
.home-town-suggestion[aria-disabled="true"]{
  cursor:default;
  color:var(--ink-soft);
}
.home-town-suggestion[aria-disabled="true"]::after{display:none}
.home-town-suggestion small{
  display:block;
  margin-top:2px;
  color:var(--ink-soft);
  font-weight:600;
}
.search-help{
  margin-top:12px;
  color:var(--ink-soft);
  font-size:.95rem;
}
.coverage-map{
  overflow:hidden;
  border-radius:24px;
  box-shadow:var(--shadow-sm);
}
.coverage-map img,
.coverage-map svg{
  width:100%;
  height:auto;
}
.municipality-card__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}
.band{
  border:1px solid var(--border);
  background:#fff;
  border-radius:22px;
  padding:26px;
  box-shadow:var(--shadow-sm);
}
.band h2,
.band h3{margin-bottom:10px}
.band p{color:var(--ink-soft)}
.band-grid{
  display:grid;
  gap:24px;
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.process-card{
  position:relative;
  padding-left:64px;
}
.process-card__icon{
  position:absolute;
  left:0;top:0;
  width:48px;height:48px;
  display:grid;place-items:center;
  border-radius:14px;
  background:rgba(22,59,92,.08);
  color:var(--navy-700);
}
.process-card h3{margin-bottom:8px}
.faq-list{
  display:grid;
  gap:12px;
}
.faq-item{
  border:1px solid var(--border);
  border-radius:18px;
  background:#fff;
  overflow:hidden;
}
.faq-question{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:20px 22px;
  background:#fff;
  border:0;
  text-align:left;
  font-weight:800;
}
.faq-question > span:first-child{
  flex:1 1 auto;
  min-width:0;
}
.faq-question .icon-svg{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 18px;
  width:18px;height:18px;
  transition:transform .2s ease;
}
.faq-question .icon-svg svg{width:18px;height:18px}
.faq-answer{
  padding:0 22px 22px;
}
.faq-answer p{margin:0;color:var(--ink-soft)}
.form-shell{
  background:#fff;
  border:1px solid var(--border);
  border-radius:18px;
  padding:18px;
  box-shadow:var(--shadow-sm);
  display:grid;
  gap:12px;
}
.form-shell--sidebar{
  position:sticky;top:124px
}
.form-shell--sidebar > *{margin:0}
.form-shell--sidebar > * + *{margin-top:14px}
.form-shell fieldset{
  border:0;
  padding:0;
  margin:0;
}
.form-shell legend{
  font-weight:700;
  margin-bottom:8px;
  font-size:.86rem;
  line-height:1.2;
}
.form-shell--interactive{gap:16px}
.form-progress{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:12px;
}
.form-progress__step{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:0;
  padding:12px 14px;
  border-radius:16px;
  border:1px solid var(--border);
  background:var(--surface-soft);
  color:var(--ink-soft);
}
.form-progress__step-number{
  width:32px;
  height:32px;
  flex:0 0 32px;
  display:grid;
  place-items:center;
  border-radius:999px;
  background:#fff;
  border:1px solid var(--border);
  font-weight:800;
  color:var(--navy);
}
.form-progress__step-copy{
  display:grid;
  gap:2px;
  min-width:0;
}
.form-progress__step-copy strong{
  font-size:.95rem;
  color:var(--ink);
}
.form-progress__step-copy span{
  font-size:.83rem;
}
.form-progress__step.is-active{
  border-color:rgba(11,31,51,.18);
  background:rgba(247,181,0,.12);
  color:var(--ink);
}
.form-progress__step.is-active .form-progress__step-number{
  background:var(--amber);
  border-color:rgba(161,109,0,.24);
}
.form-progress__step.is-complete{
  border-color:rgba(14,116,60,.18);
  background:rgba(22,163,74,.08);
  color:var(--ink);
}
.form-progress__step.is-complete .form-progress__step-number{
  background:rgba(22,163,74,.14);
  border-color:rgba(14,116,60,.2);
}
.form-step{
  display:grid;
  gap:16px;
}
.form-step[hidden]{display:none !important}
.form-step__intro{
  display:grid;
  gap:8px;
}
.form-step__intro h3{
  margin:0;
  font-size:1.2rem;
}
.form-step__intro p{
  margin:0;
  color:var(--ink-soft);
}
.form-step__consent-slot:empty{display:none}
.form-grid{
  display:grid;
  gap:14px;
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.form-grid--single{grid-template-columns:1fr}
.form-grid > .field--full,
.form-grid > .form-subsection,
.form-grid > .form-choice-group,
.form-grid > .consent,
.form-grid > .otp-panel,
.form-grid > .form-details,
.form-grid > .route-stops{
  grid-column:1 / -1;
}
.field{display:grid;gap:5px}
.field label{
  font-weight:700;
  font-size:.84rem;
}
.field__control{
  display:grid;
  gap:6px;
}
.field__control--autocomplete{
  position:relative;
}
.field-inline-action{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:6px;
  align-items:start;
}
.field-inline-action > *{min-width:0}
.field input,
.field textarea,
.field select{
  width:100%;
  border:1px solid var(--border-strong);
  border-radius:12px;
  min-height:44px;
  padding:9px 12px;
  background:#fff;
  color:var(--ink);
  transition:border-color .2s ease, box-shadow .2s ease, background-color .2s ease;
}
.field input::placeholder,
.field textarea::placeholder{color:#7C8A9A;opacity:1}
.field input:focus,
.field textarea:focus,
.field select:focus{
  outline:0;
  border-color:rgba(11,31,51,.42);
  box-shadow:0 0 0 4px rgba(11,31,51,.08);
}
.field textarea{resize:vertical;min-height:76px}
.field small{
  color:var(--ink-soft);
  font-size:.8rem;
  line-height:1.45;
}
.field-action{
  width:max-content;
}
.field-inline-action .field-action{
  width:auto;
  min-height:44px;
  align-self:stretch;
  white-space:nowrap;
}
.form-details{
  border:1px dashed rgba(11,31,51,.14);
  border-radius:18px;
  background:linear-gradient(180deg,#fff 0%, rgba(245,247,251,.72) 100%);
  overflow:hidden;
}
.form-details > summary{
  list-style:none;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:14px 18px;
  cursor:pointer;
}
.form-details > summary::-webkit-details-marker{display:none}
.form-details > summary::after{
  content:"+";
  width:28px;
  height:28px;
  flex:0 0 28px;
  display:grid;
  place-items:center;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(11,31,51,.1);
  color:var(--navy);
  font-weight:800;
  font-size:1rem;
}
.form-details[open] > summary::after{content:"−"}
.form-details > summary span{
  display:grid;
  gap:2px;
}
.form-details > summary strong{
  font-size:.95rem;
  color:var(--ink);
}
.form-details > summary small{
  color:var(--ink-soft);
  font-size:.82rem;
}
.form-details__body{
  display:grid;
  gap:14px;
  padding:0 18px 18px;
}
.form-details.has-value > summary{
  background:rgba(247,181,0,.08);
}
.form-details__hint{
  margin:0;
  color:var(--ink-soft);
  font-size:.84rem;
  line-height:1.45;
}
.route-stops{
  display:grid;
  gap:10px;
  padding:12px 14px;
  border:1px dashed rgba(11,31,51,.14);
  border-radius:14px;
  background:rgba(248,250,252,.78);
}
.route-stops__list{
  display:grid;
  gap:10px;
}
.route-stop-row{
  display:grid;
  grid-template-columns:28px minmax(0,1fr) 38px;
  align-items:center;
  gap:10px;
}
.route-stop-row__index{
  width:28px;
  height:28px;
  display:grid;
  place-items:center;
  border-radius:999px;
  background:var(--navy);
  color:#fff;
  font-weight:800;
  font-size:.82rem;
}
.route-stop-row .field__control{
  position:relative;
}
.route-stop-row input{
  min-height:46px;
}
.route-stop-row__remove,
.route-stops__add{
  border:0;
  background:transparent;
  color:var(--navy);
  font-weight:800;
}
.route-stop-row__remove{
  width:38px;
  height:38px;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(11,31,51,.12);
}
.route-stops__add{
  width:max-content;
  min-height:38px;
  display:inline-flex;
  align-items:center;
  gap:9px;
  padding:2px 4px 2px 2px;
  line-height:1;
}
.route-stops__add-icon{
  position:relative;
  flex:0 0 24px;
  width:24px;
  height:24px;
  display:inline-block;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(11,31,51,.12);
}
.route-stops__add-icon::before,
.route-stops__add-icon::after{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  width:11px;
  height:2px;
  border-radius:999px;
  background:currentColor;
  transform:translate(-50%,-50%);
}
.route-stops__add-icon::after{
  transform:translate(-50%,-50%) rotate(90deg);
}
.route-stops__add-label{
  display:inline-flex;
  align-items:center;
  min-height:24px;
}
.route-stops__add:disabled{
  opacity:.55;
  cursor:not-allowed;
}
.route-stops p{
  margin:0;
  color:var(--ink-soft);
  font-size:.8rem;
  line-height:1.45;
}
.summary-panel--inline{
  margin-top:0;
  padding:20px;
  background:linear-gradient(180deg,#fff 0%, rgba(245,247,251,.92) 100%);
}
.summary-panel--inline h4{
  margin:0;
  font-size:1rem;
}
.summary-grid--compact{
  margin-top:16px;
}
.form-review-extras{
  display:grid;
  gap:12px;
  grid-template-columns:repeat(2,minmax(0,1fr));
  margin-top:16px;
}
.form-review-pill{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:4px 12px;
  align-items:start;
  padding:15px 16px;
  border-radius:16px;
  border:1px solid rgba(11,31,51,.08);
  background:#fff;
}
.form-review-pill--full{
  grid-column:1 / -1;
}
.form-review-pill__icon{
  width:18px;
  height:18px;
  color:var(--navy-700);
  margin-top:2px;
}
.form-review-pill strong{
  grid-column:2;
  display:block;
  font-size:.9rem;
  color:var(--ink-soft);
}
.form-review-pill span{
  grid-column:2;
  color:var(--ink);
  line-height:1.55;
}
.form-verification-shell{
  display:grid;
  gap:16px;
  padding:18px;
  border:1px dashed rgba(11,31,51,.16);
  border-radius:20px;
  background:rgba(245,247,251,.72);
}
.form-verification-shell__copy{
  display:grid;
  gap:6px;
}
.form-verification-shell__copy h4{
  margin:0;
  font-size:1rem;
}
.form-verification-shell__copy p{
  margin:0;
  color:var(--ink-soft);
  line-height:1.55;
}
.form-verification-shell__status{
  margin:0;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid transparent;
  font-size:.9rem;
  line-height:1.45;
}
.form-verification-shell__status[hidden]{display:none}
.form-verification-shell__status--info{
  background:var(--surface-soft);
  color:var(--ink);
  border-color:var(--border);
}
.form-verification-shell__status--success{
  background:rgba(6,118,71,.08);
  color:#067647;
  border-color:rgba(6,118,71,.18);
}
.form-verification-shell__status--warning{
  background:rgba(181,71,8,.08);
  color:#B54708;
  border-color:rgba(181,71,8,.18);
}
.form-verification-shell__status--error{
  background:#FEF3F2;
  color:#B42318;
  border-color:#FDA29B;
}
.field-action.is-loading{
  pointer-events:none;
  opacity:.8;
}
.field.is-invalid input,
.field.is-invalid textarea,
.field.is-invalid select{
  border-color:#D92D20;
  box-shadow:0 0 0 4px rgba(217,45,32,.08);
}
.consent.is-invalid{
  border-radius:16px;
  padding:14px 16px;
  background:#FFF7F5;
}
.consent.is-invalid input{
  outline:2px solid transparent;
}
.field-error{
  margin:0;
  color:#B42318;
  font-size:.88rem;
  line-height:1.45;
}
.field-assistive{
  margin:0;
  font-size:.88rem;
  line-height:1.45;
  color:var(--ink-soft);
}
.field-assistive--success{color:#067647}
.field-assistive--warning{color:#B54708}
.autocomplete-panel{
  position:absolute;
  top:calc(100% + 8px);
  left:0;
  right:0;
  width:100%;
  min-width:100%;
  max-width:100%;
  z-index:30;
  display:grid;
  gap:0;
  background:#fff;
  border:1px solid rgba(11,31,51,.12);
  border-radius:16px;
  box-shadow:0 18px 44px rgba(11,31,51,.16);
  overflow:hidden;
}
.autocomplete-panel[hidden]{display:none}
.autocomplete-panel__list{
  display:grid;
  max-height:280px;
  overflow:auto;
}
.autocomplete-panel__option{
  appearance:none;
  border:0;
  border-bottom:1px solid rgba(11,31,51,.08);
  background:#fff;
  color:var(--ink);
  text-align:left;
  padding:14px 16px;
  font:inherit;
  line-height:1.45;
  cursor:pointer;
  transition:background-color .18s ease,color .18s ease;
}
.autocomplete-panel__option:last-child{border-bottom:0}
.autocomplete-panel__option:hover,
.autocomplete-panel__option.is-active{
  background:rgba(247,181,0,.12);
  color:var(--navy);
}
.autocomplete-panel__status,
.autocomplete-panel__meta{
  margin:0;
  padding:12px 16px;
  font-size:.82rem;
  line-height:1.4;
}
.autocomplete-panel__status{
  color:var(--ink-soft);
  border-top:1px solid rgba(11,31,51,.08);
}
.autocomplete-panel__meta{
  color:var(--ink-soft);
  background:rgba(245,247,251,.9);
  border-top:1px solid rgba(11,31,51,.08);
}
.otp-panel{
  display:grid;
  gap:12px;
  padding:14px 16px;
  border:1px solid rgba(11,31,51,.1);
  border-radius:18px;
  background:linear-gradient(180deg,#fff 0%, rgba(245,247,251,.9) 100%);
}
.otp-panel__header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.otp-panel__copy{
  display:grid;
  gap:6px;
}
.otp-panel__copy strong{
  display:block;
  font-size:.96rem;
}
.otp-panel__copy p{
  margin:0;
  color:var(--ink-soft);
  font-size:.86rem;
  line-height:1.45;
}
.otp-panel__badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:0 12px;
  border-radius:999px;
  background:rgba(6,118,71,.12);
  color:#067647;
  font-size:.82rem;
  font-weight:700;
  white-space:nowrap;
}
.otp-panel__badge[hidden]{display:none}
.otp-panel__actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.otp-panel__actions .btn{
  flex:1 1 180px;
}
.otp-panel__code{
  display:grid;
  gap:12px;
}
.otp-panel__status{
  margin:0;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid transparent;
  font-size:.88rem;
  line-height:1.45;
}
.otp-panel__status[hidden]{display:none}
.otp-panel__status--info{
  background:var(--surface-soft);
  color:var(--ink);
  border-color:var(--border);
}
.otp-panel__status--success{
  background:rgba(6,118,71,.08);
  color:#067647;
  border-color:rgba(6,118,71,.18);
}
.otp-panel__status--warning{
  background:rgba(181,71,8,.08);
  color:#B54708;
  border-color:rgba(181,71,8,.18);
}
.otp-panel__status--error{
  background:#FEF3F2;
  color:#B42318;
  border-color:#FDA29B;
}
.sms-verification-modal{
  position:fixed;
  inset:0;
  z-index:2300;
  display:grid;
  place-items:center;
  padding:18px;
  background:rgba(11,31,51,.58);
  backdrop-filter:blur(10px);
}
.sms-verification-modal[hidden]{
  display:none !important;
}
.sms-verification-modal__dialog{
  position:relative;
  width:min(100%,460px);
  display:grid;
  gap:16px;
  border:1px solid rgba(255,255,255,.52);
  border-radius:24px;
  background:#fff;
  box-shadow:0 28px 80px rgba(11,31,51,.34);
  padding:22px;
}
.sms-verification-modal__header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
}
.sms-verification-modal__copy{
  display:grid;
  gap:7px;
}
.sms-verification-modal__copy h2{
  margin:0;
  color:var(--ink);
  font-size:1.42rem;
  line-height:1.12;
}
.sms-verification-modal__copy p{
  margin:0;
  color:var(--ink-soft);
  line-height:1.5;
}
.sms-verification-modal__close{
  position:relative;
  flex:0 0 auto;
  display:grid;
  place-items:center;
  width:42px;
  height:42px;
  border:1px solid var(--border);
  border-radius:999px;
  background:#fff;
  color:var(--ink);
  cursor:pointer;
}
.sms-verification-modal__close:hover{
  background:var(--surface-soft);
}
.sms-verification-modal__close::before,
.sms-verification-modal__close::after{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  width:16px;
  height:2px;
  border-radius:999px;
  background:currentColor;
  transform:translate(-50%,-50%) rotate(45deg);
}
.sms-verification-modal__close::after{
  transform:translate(-50%,-50%) rotate(-45deg);
}
.sms-verification-modal__step{
  display:grid;
  gap:14px;
}
.sms-verification-modal__step[hidden]{
  display:none !important;
}
.sms-verification-modal__phone-control{
  position:relative;
}
.sms-verification-modal__phone-control input{
  padding-right:52px;
}
.sms-verification-modal__clear{
  position:absolute;
  right:8px;
  top:50%;
  display:grid;
  width:36px;
  height:36px;
  place-items:center;
  border:0;
  border-radius:999px;
  background:transparent;
  color:#9A3412;
  cursor:pointer;
  transform:translateY(-50%);
}
.sms-verification-modal__clear:hover{
  background:#FFF7ED;
}
.sms-verification-modal__clear svg{
  width:20px;
  height:20px;
}
body.is-sms-verification-open{
  overflow:hidden;
}
.verification-status-panel{
  max-width:720px;
  margin-inline:auto;
  display:grid;
  gap:18px;
  text-align:center;
}
.verification-status-panel h1{
  margin:0;
}
.verification-status-panel p{
  margin:0;
  color:var(--ink-soft);
  line-height:1.7;
}
.verification-status-panel .status-icon{
  margin:0 auto;
}
.verification-status-panel .page-intro__actions{
  justify-content:center;
  margin-top:0;
}
.form-status{
  margin:0;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid transparent;
  font-size:.93rem;
  line-height:1.5;
}
.form-status[hidden]{display:none}
.form-status--info{
  background:var(--surface-soft);
  color:var(--ink);
  border-color:var(--border);
}
.form-status--error{
  background:#FEF3F2;
  color:#B42318;
  border-color:#FDA29B;
}
.consent{
  display:flex;
  gap:10px;
  align-items:flex-start;
  margin:0;
}
.consent input{margin-top:4px}
.consent label{
  color:var(--ink-soft);
  font-size:.9rem;
  line-height:1.45;
}
.form-note{
  margin-top:8px;
  color:var(--ink-soft);
  font-size:.86rem;
  line-height:1.45;
}
.form-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  align-items:center;
}
.form-actions .btn{
  flex:1 1 220px;
}
.form-shell.is-submitting .option-card{
  pointer-events:none;
}
.form-subsection{
  display:grid;
  gap:14px;
  padding:18px;
  border:1px dashed rgba(11,31,51,.14);
  border-radius:18px;
  background:linear-gradient(180deg,#fff 0%, rgba(245,247,251,.7) 100%);
}
.form-subsection__title{
  margin:0;
  font-size:1rem;
  font-weight:800;
  color:var(--ink);
}
.form-subsection__copy{
  margin:0;
  color:var(--ink-soft);
  font-size:.92rem;
}
.form-layout{
  display:grid;
  gap:22px;
  grid-template-columns:minmax(0,1fr) 296px;
  align-items:start;
}
.form-layout--simple{
  grid-template-columns:minmax(0,1fr) 312px;
}
.form-choice-group{
  display:grid;
  gap:8px;
}
.inline-options{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,180px));
  gap:10px;
  justify-content:flex-start;
  max-width:350px;
}
.option-card{
  display:flex;
  gap:8px;
  align-items:center;
  border:1px solid var(--border);
  border-radius:12px;
  padding:12px;
  background:var(--surface-soft);
  position:relative;
  min-height:100%;
  cursor:pointer;
  transition:border-color .2s ease, box-shadow .2s ease, background-color .2s ease, transform .2s ease;
}
.option-card:hover{
  transform:translateY(-1px);
  border-color:rgba(11,31,51,.18);
}
.option-card input{
  position:absolute;
  inline-size:1px;
  block-size:1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
}
.option-card.is-selected{
  border-color:rgba(11,31,51,.24);
  background:rgba(247,181,0,.12);
  box-shadow:0 10px 22px rgba(11,31,51,.08);
}
.option-card > span:last-child{
  flex:1 1 auto;
  min-width:0;
  display:grid;
  gap:2px;
}
.option-card__icon{
  width:30px;
  height:30px;
  flex:0 0 30px;
  display:grid;
  place-items:center;
  border-radius:10px;
  background:#fff;
  border:1px solid var(--border);
  color:var(--navy-700);
}
.option-card.is-selected .option-card__icon{
  background:var(--amber);
  border-color:rgba(161,109,0,.24);
}
.option-card__icon svg{width:16px;height:16px}
.option-card strong{display:block;font-size:.92rem;line-height:1.2}
.option-card span{display:block;color:var(--ink-soft);font-size:.82rem;line-height:1.35}
.reservation-schedule-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px 12px;
  align-items:end;
}
.reservation-schedule-row .inline-options{
  flex:0 0 auto;
  width:auto;
  max-width:none;
  grid-template-columns:repeat(2,minmax(126px,1fr));
}
.reservation-schedule-row [data-conditional-field="programada"]{
  flex:1 1 310px;
  min-width:min(100%,310px);
  max-width:440px;
  grid-template-columns:repeat(2,minmax(132px,1fr));
  gap:10px;
  align-items:end;
}
.reservation-schedule-row [data-conditional-field="programada"][hidden]{display:none !important}
.reservation-schedule-row .option-card{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  align-items:center;
  min-height:0;
}
.reservation-schedule-row .option-card__icon{
  align-self:center;
  justify-self:center;
}
.helper-card{
  display:grid;
  gap:12px;
  border:1px solid var(--border);
  background:var(--surface-soft);
  border-radius:18px;
  padding:16px;
  color:var(--ink);
}
.helper-card h3{font-size:1rem}
.helper-card p,
.helper-card li{color:var(--ink-soft)}
.helper-card ul{display:grid;gap:8px}
.price-grid{
  display:grid;
  gap:22px;
  grid-template-columns:repeat(4,minmax(0,1fr));
}
.price-card{
  display:grid;
  gap:12px;
  align-content:start;
}
.price-card .pill{width:max-content}
.filter-bar{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-bottom:24px;
}
.filter-btn{
  appearance:none;
  border:1px solid var(--border);
  background:#fff;
  color:var(--ink-soft);
  min-height:40px;
  padding:0 14px;
  border-radius:999px;
  font-weight:700;
}
.filter-btn.is-active,
.filter-btn:hover{
  color:var(--ink);
  border-color:var(--navy);
}
.notice{
  display:flex;
  gap:12px;
  align-items:flex-start;
  border-left:4px solid var(--amber);
  background:#FFF8E1;
  border-radius:14px;
  padding:16px 18px;
  color:#614400;
}
.notice .icon-svg{
  width:18px;
  height:18px;
  color:#A16D00;
  margin-top:2px;
}
.two-col{
  display:grid;
  gap:32px;
  grid-template-columns:1.1fr .9fr;
  align-items:start;
}
.article-layout{
  display:grid;
  gap:36px;
  grid-template-columns:minmax(0,1fr) 300px;
}
.article-content{
  max-width:72ch;
}
.article-content h2{
  font-size:1.7rem;
  margin:32px 0 14px;
}
.article-content h3{
  font-size:1.25rem;
  margin:24px 0 10px;
}
.article-content p,
.article-content li{
  color:var(--ink-soft);
}
.article-content ul{
  display:grid;
  gap:10px;
  margin:0 0 20px 0;
}
.article-content li{
  list-style:none;
  position:relative;
  padding-left:28px;
}
.article-content li::before{
  content:"";
  position:absolute;
  left:0;top:11px;
  width:10px;height:10px;
  border-radius:999px;
  background:var(--amber);
}
.toc{
  position:sticky;
  top:124px;
  display:grid;
  gap:14px;
  border:1px solid var(--border);
  border-radius:20px;
  background:#fff;
  padding:20px;
  box-shadow:var(--shadow-sm);
}
.toc h3{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:1rem;
}
.toc h3 .icon-svg{width:18px;height:18px;color:var(--navy-700)}
.toc a{
  color:var(--ink-soft);
  font-weight:700;
}
.toc a:hover{color:var(--ink)}
.cta-banner{
  background:
    radial-gradient(circle at right top, rgba(247,181,0,.15), transparent 32%),
    linear-gradient(135deg,var(--navy) 0%, var(--navy-700) 100%);
  color:#fff;
  border-radius:30px;
  padding:32px;
  display:grid;
  align-items:center;
  grid-template-columns:minmax(0,1fr) minmax(280px,460px);
  gap:24px;
  box-shadow:var(--shadow-md);
}
.cta-banner .eyebrow{color:#DCE8F4}
.cta-banner p{color:#DCE8F4}
.cta-banner__actions{
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns:1fr;
  gap:12px;
}
.cta-banner__actions .btn{
  width:100%;
  justify-content:center;
}
.site-footer{
  background:var(--navy);
  color:#F8FAFC;
  margin-top:40px;
  padding-top:56px;
}
.footer-grid{
  display:grid;
  gap:32px;
  grid-template-columns:1.3fr 1fr 1fr 1fr;
}
.footer-copy{
  margin:16px 0 18px;
  color:#CBD5E1;
}
.footer-contact,
.footer-links{
  display:grid;
  gap:12px;
}
.footer-contact li{
  display:flex;
  gap:10px;
  align-items:flex-start;
  color:#E2E8F0;
}
.footer-links a{color:#CBD5E1}
.footer-links a:hover{color:#fff}
.footer-grid h3{
  font-size:1rem;
  margin-bottom:14px;
}
.footer-bottom{
  margin-top:32px;
  padding:18px 0 24px;
  border-top:1px solid rgba(255,255,255,.12);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  color:#CBD5E1;
  font-size:.95rem;
}
body.page--transactional .site-footer{
  margin-top:0;
  padding-top:28px;
}
body.page--transactional .footer-grid{
  grid-template-columns:1fr;
  gap:18px;
}
body.page--transactional .footer-grid > div:not(:first-child){
  display:none;
}
body.page--transactional .footer-copy{
  margin-bottom:12px;
}
body.page--transactional .footer-bottom{
  margin-top:18px;
  padding-bottom:18px;
}
.footer-meta{
  display:flex;
  flex-wrap:wrap;
  gap:16px;
}
.footer-meta a{color:#E2E8F0}
.center-message{
  max-width:720px;
  margin:0 auto;
  text-align:center;
}
.center-message h1{font-size:clamp(2rem,2vw + 1rem,3rem);margin-bottom:14px}
.center-message p{color:var(--ink-soft);font-size:1.08rem;line-height:1.8}
.summary-panel{
  margin-top:26px;
  padding:24px;
  border:1px solid var(--border);
  border-radius:22px;
  background:#fff;
  box-shadow:var(--shadow-sm);
  text-align:left;
  color:var(--ink);
}
.summary-panel h2{margin-bottom:0}
.summary-grid{
  display:grid;
  gap:16px;
  grid-template-columns:repeat(2,minmax(0,1fr));
  margin-top:18px;
}
.summary-grid div{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:4px 12px;
  align-items:start;
  padding:16px;
  border-radius:16px;
  background:var(--surface-soft);
}
.summary-field__icon{
  grid-row:1 / span 2;
  width:18px;
  height:18px;
  color:var(--navy-700);
  margin-top:2px;
}
.summary-grid strong{
  grid-column:2;
  display:block;
  font-size:.9rem;
  color:var(--ink-soft);
  margin-bottom:6px;
}
.summary-grid span{grid-column:2}
.status-icon{
  width:64px;
  height:64px;
  display:grid;
  place-items:center;
  margin:0 auto 18px;
  border-radius:20px;
  background:rgba(22,59,92,.08);
  color:var(--navy-700);
  box-shadow:var(--shadow-sm);
}
.status-icon svg{width:30px;height:30px}
.legal-content{
  max-width:72ch;
}
.legal-content h2{
  font-size:1.5rem;
  margin:28px 0 14px;
}
.legal-content p,
.legal-content li{
  color:var(--ink-soft);
}
.legal-content ul{
  display:grid;
  gap:10px;
  margin-bottom:20px;
}
.legal-review-note{
  margin-top:28px;
  padding:20px;
  border:1px solid rgba(247,181,0,.42);
  border-radius:8px;
  background:rgba(247,181,0,.1);
}
.page-404{
  min-height:60vh;
  display:grid;
  place-items:center;
}
.reservation-modal{
  position:fixed;
  inset:0;
  z-index:2000;
  display:grid;
  place-items:stretch;
  padding:0;
  background:rgba(11,31,51,.56);
  backdrop-filter:blur(10px);
}
.reservation-modal[hidden]{display:none !important}
.reservation-modal__dialog{
  width:100vw;
  height:100dvh;
  max-height:none;
  overflow:hidden;
  display:grid;
  grid-template-rows:auto minmax(0,1fr);
  border-radius:0;
  border:0;
  background:#fff;
  box-shadow:none;
}
.reservation-modal__header{
  display:flex;
  justify-content:space-between;
  gap:18px;
  align-items:flex-start;
  padding:14px 32px;
  border-bottom:1px solid rgba(15,23,42,.08);
  background:#fff;
}
.reservation-modal__eyebrow{
  margin:0 0 4px;
  font-size:.76rem;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--amber-700);
}
.reservation-modal__title{
  margin:0;
  font-size:1.4rem;
  line-height:1.15;
  color:var(--ink);
}
.reservation-modal__copy{
  margin:8px 0 0;
  color:var(--ink-soft);
  max-width:58ch;
}
.reservation-modal__close{
  position:relative;
  display:grid;
  place-items:center;
  flex:0 0 auto;
  width:42px;
  height:42px;
  padding:0;
  border-radius:999px;
  border:1px solid var(--border);
  background:#fff;
  color:var(--ink);
  cursor:pointer;
  line-height:0;
}
.reservation-modal__close:hover{background:var(--surface-soft)}
.reservation-modal__close::before,
.reservation-modal__close::after{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  width:16px;
  height:2px;
  border-radius:999px;
  background:currentColor;
  transform:translate(-50%,-50%) rotate(45deg);
}
.reservation-modal__close::after{
  transform:translate(-50%,-50%) rotate(-45deg);
}
.reservation-modal__close span{
  display:none;
}
.reservation-modal__body{
  overflow:auto;
  padding:32px;
  background:#fff;
}
.reservation-modal__body .form-layout{
  max-width:none;
  margin-inline:auto;
}
.reservation-modal .ride-map-panel{
  position:relative;
  top:auto;
}
.reservation-modal__body .form-shell:not(.ride-booking-form){
  padding:0;
  border:0;
  box-shadow:none;
}
.page-confirmation{
  position:relative;
  overflow:hidden;
  padding:48px 0;
  color:#fff;
  background:
    linear-gradient(104deg, rgba(11,31,51,.94) 0%, rgba(11,31,51,.86) 44%, rgba(11,31,51,.72) 100%),
    var(--hero-bg) center/cover no-repeat;
}
.page-confirmation .container{position:relative}
.confirmation-shell{
  display:grid;
  gap:18px;
  padding:4px 0;
}
.confirmation-hero{
  display:grid;
  gap:10px;
  max-width:760px;
}
.confirmation-hero p{color:#E2E8F0}
.confirmation-badges{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.status-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:36px;
  padding:8px 14px;
  border-radius:999px;
  font-size:.92rem;
  font-weight:700;
  border:1px solid transparent;
}
.status-pill--info{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.16)}
.status-pill--warning{background:rgba(247,181,0,.16);color:#FFE19A;border-color:rgba(247,181,0,.3)}
.status-pill--success{background:rgba(39,174,96,.18);color:#B9F6CA;border-color:rgba(39,174,96,.3)}
.status-pill--accent{background:rgba(69,143,255,.18);color:#D7E8FF;border-color:rgba(69,143,255,.28)}
.status-pill--error{background:rgba(217,45,32,.18);color:#FFD4CF;border-color:rgba(217,45,32,.28)}
.status-pill--ghost{background:rgba(255,255,255,.08);color:#E8EEF7;border-color:rgba(255,255,255,.12)}
.confirmation-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) 320px;
  gap:22px;
  align-items:start;
}
.confirmation-main,
.confirmation-aside{
  display:grid;
  gap:18px;
}
.confirmation-section{
  padding:18px;
  border:1px solid rgba(217,225,236,.92);
  border-radius:16px;
  background:rgba(255,255,255,.98);
  box-shadow:var(--shadow-sm);
  color:var(--ink);
}
.confirmation-section h2{
  margin:0 0 6px;
  color:var(--ink);
}
.confirmation-section > p{
  margin:0;
  color:var(--ink-soft);
}
.detail-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
  margin-top:12px;
}
.detail-item{
  display:grid;
  gap:4px;
  padding:12px;
  border-radius:12px;
  background:var(--surface-soft);
  border:1px solid rgba(11,31,51,.08);
}
.detail-item strong{
  font-size:.8rem;
  line-height:1.2;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--ink-soft);
}
.detail-item span{
  color:var(--ink);
  line-height:1.45;
}
.confirmation-map{
  display:grid;
  gap:14px;
  margin-top:16px;
}
.confirmation-map iframe{
  width:100%;
  aspect-ratio:16 / 10;
  border:0;
  border-radius:18px;
  background:#E9EEF5;
}
.confirmation-inline-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:14px;
}
.confirmation-empty{
  margin-top:16px;
  padding:16px;
  border-radius:16px;
  background:rgba(245,247,251,.92);
  border:1px dashed rgba(11,31,51,.14);
  color:var(--ink-soft);
}
body.page--thanks{
  background:#E8EEF3;
}
body.page--thanks .site-header{
  box-shadow:0 1px 0 rgba(11,31,51,.08);
}
body.page--thanks .site-header-inner{
  min-height:68px;
}
body.page--thanks .site-nav--tracking{
  display:flex;
}
body.page--thanks .site-nav--tracking .nav-link{
  font-weight:800;
}
body.page--thanks .header-actions .btn--primary{
  display:none;
}
body.page--thanks .header-actions .btn--ghost{
  border-color:rgba(11,31,51,.12);
  background:#fff;
}
.reservation-tracker{
  --tracker-panel:450px;
  --tracker-gap:18px;
  min-height:calc(100dvh - 68px);
  padding:18px;
  background:
    linear-gradient(180deg, rgba(232,238,243,.9), rgba(247,249,251,.94)),
    #E8EEF3;
}
.tracker-shell{
  width:min(100%, 1680px);
  min-height:calc(100dvh - 104px);
  margin-inline:auto;
  display:grid;
  grid-template-columns:minmax(400px,var(--tracker-panel)) minmax(0,1fr);
  gap:var(--tracker-gap);
  align-items:stretch;
}
.tracker-panel{
  display:flex;
  flex-direction:column;
  gap:12px;
  min-width:0;
}
.tracker-status-card,
.tracker-driver-card,
.tracker-action-card,
.tracker-notification-card,
.tracker-rating-card,
.tracker-receipt-card,
.tracker-invoice-card,
.tracker-route-card,
.tracker-preferences-card,
.tracker-saved-card,
.tracker-history-card,
.tracker-chat-card,
.tracker-tools-card,
.tracker-details-card{
  border:1px solid rgba(11,31,51,.1);
  border-radius:20px;
  background:rgba(255,255,255,.96);
  color:var(--ink);
  box-shadow:0 14px 36px rgba(11,31,51,.08);
}
.tracker-status-card{
  padding:24px;
  background:
    linear-gradient(135deg, rgba(247,181,0,.14), transparent 42%),
    var(--navy);
  color:#fff;
}
.tracker-status-card .eyebrow{
  color:rgba(255,255,255,.72);
}
.tracker-status-card h1{
  margin:8px 0 8px;
  font-size:2.25rem;
  line-height:1.05;
  letter-spacing:0;
}
.tracker-status-card p{
  max-width:34rem;
  color:rgba(255,255,255,.82);
  font-size:1rem;
  line-height:1.5;
}
.tracker-status-meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
  margin-top:16px;
  color:rgba(255,255,255,.74);
  font-size:.9rem;
}
.tracker-status-meta [data-live-updated],
.tracker-status-meta [data-confirmation-reference]{
  min-height:34px;
  display:inline-flex;
  align-items:center;
  padding:7px 12px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:999px;
  background:rgba(255,255,255,.08);
}
.tracker-driver-card{
  display:grid;
  grid-template-columns:64px minmax(0,1fr);
  gap:14px;
  align-items:start;
  padding:18px;
}
.tracker-driver-avatar{
  width:64px;
  height:64px;
  display:grid;
  place-items:center;
  border-radius:50%;
  background:linear-gradient(135deg,#12395A,#0B1F33);
  color:#fff;
  font-weight:900;
  font-size:1.1rem;
}
.tracker-driver-main h2,
.tracker-action-card h2,
.tracker-route-card h2{
  margin:2px 0 4px;
  font-size:1.15rem;
  letter-spacing:0;
}
.tracker-driver-main p{
  margin:0;
  color:var(--ink-soft);
}
.tracker-vehicle-photo{
  margin:14px 0 0;
  overflow:hidden;
  border:1px solid rgba(11,31,51,.1);
  border-radius:16px;
  background:#eef4f8;
  aspect-ratio:16/9;
}
.tracker-vehicle-photo[hidden]{
  display:none;
}
.tracker-vehicle-photo img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
}
.tracker-vehicle-list{
  display:grid;
  gap:8px;
  margin:14px 0 0;
}
.tracker-vehicle-list div{
  display:grid;
  grid-template-columns:88px minmax(0,1fr);
  gap:10px;
  padding-top:8px;
  border-top:1px solid rgba(11,31,51,.08);
}
.tracker-vehicle-list dt{
  color:var(--ink-soft);
  font-size:.78rem;
  font-weight:800;
  text-transform:uppercase;
}
.tracker-vehicle-list dd{
  margin:0;
  color:var(--ink);
  font-weight:800;
}
.tracker-action-card,
.tracker-notification-card,
.tracker-rating-card,
.tracker-receipt-card,
.tracker-invoice-card,
.tracker-route-card,
.tracker-preferences-card,
.tracker-saved-card,
.tracker-history-card,
.tracker-chat-card,
.tracker-tools-card{
  padding:18px;
}
.tracker-notification-card{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:12px;
  align-items:center;
  background:#fff;
}
.tracker-notification-card[hidden],
.tracker-rating-card[hidden],
.tracker-receipt-card[hidden],
.tracker-invoice-card[hidden],
.tracker-tools-card[hidden]{
  display:none;
}
.tracker-notification-copy strong{
  display:block;
  color:var(--ink);
  font-size:1rem;
}
.tracker-notification-copy p{
  margin:3px 0 0;
  color:var(--ink-soft);
  line-height:1.4;
}
.tracker-notification-card.is-updated{
  animation:trackerCardPulse .7s ease;
}
.tracker-notification-modal{
  position:fixed;
  inset:0;
  z-index:1700;
  display:grid;
  place-items:center;
  padding:18px;
  background:rgba(8,31,51,.52);
  backdrop-filter:blur(8px);
}
.tracker-notification-modal[hidden]{
  display:none !important;
}
.tracker-notification-modal__panel{
  position:relative;
  width:min(100%,440px);
  border:1px solid rgba(216,226,236,.95);
  border-radius:20px;
  background:#fff;
  color:var(--ink);
  box-shadow:0 24px 70px rgba(8,31,51,.24);
  padding:26px;
}
.tracker-notification-modal__panel h2{
  margin:6px 0 10px;
  font-size:1.45rem;
  line-height:1.12;
  letter-spacing:0;
}
.tracker-notification-modal__panel p{
  margin:0 0 12px;
  color:var(--ink-soft);
  line-height:1.48;
}
.tracker-notification-modal__privacy{
  padding:12px 14px;
  border:1px solid #D8E2EC;
  border-radius:14px;
  background:#F6FAFD;
  font-size:.94rem;
}
.tracker-notification-modal__actions{
  display:grid;
  grid-template-columns:1fr auto;
  gap:10px;
  align-items:center;
  margin-top:18px;
}
.tracker-notification-modal__close{
  position:absolute;
  top:12px;
  right:12px;
  display:grid;
  place-items:center;
  width:40px;
  height:40px;
  border:0;
  border-radius:999px;
  background:#F3F7FB;
  color:var(--ink);
  cursor:pointer;
}
.tracker-notification-modal__close:hover{
  background:#E7EEF6;
}
.tracker-notification-modal__close::before,
.tracker-notification-modal__close::after{
  content:"";
  position:absolute;
  width:16px;
  height:2px;
  border-radius:999px;
  background:currentColor;
}
.tracker-notification-modal__close::before{
  transform:rotate(45deg);
}
.tracker-notification-modal__close::after{
  transform:rotate(-45deg);
}
.tracker-notification-modal__close span{
  display:none;
}
.tracker-modal{
  position:fixed;
  inset:0;
  z-index:1720;
  display:grid;
  place-items:center;
  padding:18px;
  border:0 !important;
  border-radius:0 !important;
  background:rgba(8,31,51,.58) !important;
  color:var(--ink);
  box-shadow:none !important;
  backdrop-filter:blur(8px);
}
.tracker-modal[hidden]{
  display:none !important;
}
.tracker-modal__panel{
  position:relative;
  width:min(100%,480px);
  max-height:min(82dvh,760px);
  overflow:auto;
  border:1px solid rgba(216,226,236,.95);
  border-radius:20px;
  background:#fff;
  box-shadow:0 24px 70px rgba(8,31,51,.26);
  padding:26px;
}
.tracker-modal__panel--wide{
  width:min(100%,620px);
}
.tracker-modal__panel h2{
  margin:6px 0 12px;
  font-size:1.45rem;
  line-height:1.12;
  letter-spacing:0;
}
.tracker-modal__close{
  position:absolute;
  top:12px;
  right:12px;
  display:grid;
  place-items:center;
  width:40px;
  height:40px;
  border:0;
  border-radius:999px;
  background:#F3F7FB;
  color:var(--ink);
  cursor:pointer;
}
.tracker-modal__close:hover{
  background:#E7EEF6;
}
.tracker-modal__close::before,
.tracker-modal__close::after{
  content:"";
  position:absolute;
  width:16px;
  height:2px;
  border-radius:999px;
  background:currentColor;
}
.tracker-modal__close::before{
  transform:rotate(45deg);
}
.tracker-modal__close::after{
  transform:rotate(-45deg);
}
.tracker-modal__close span{
  display:none;
}
body.is-tracker-modal-open{
  overflow:hidden;
}
body.is-tracker-loading{
  cursor:wait;
}
.tracker-loading-overlay{
  position:fixed;
  inset:0;
  z-index:1840;
  display:grid;
  place-items:center;
  padding:18px;
  background:rgba(8,31,51,.46);
  color:var(--ink);
  backdrop-filter:blur(7px);
}
.tracker-loading-overlay[hidden]{
  display:none !important;
}
.tracker-loading-overlay__panel{
  width:min(100%,320px);
  display:grid;
  justify-items:center;
  gap:12px;
  padding:24px 22px;
  border:1px solid rgba(216,226,236,.92);
  border-radius:18px;
  background:#fff;
  box-shadow:0 24px 70px rgba(8,31,51,.24);
  text-align:center;
}
.tracker-loading-overlay__spinner{
  width:42px;
  height:42px;
  border:4px solid #E7EEF6;
  border-top-color:var(--amber);
  border-radius:999px;
  animation:trackerLoadingSpin .82s linear infinite;
}
.tracker-loading-overlay__panel strong{
  display:block;
  font-size:1.05rem;
  line-height:1.2;
}
.tracker-loading-overlay__panel p{
  margin:0;
  color:var(--ink-soft);
  font-size:.92rem;
  line-height:1.4;
}
@keyframes trackerLoadingSpin{
  to{transform:rotate(360deg)}
}
.tracker-rating-card h2,
.tracker-receipt-card h2,
.tracker-invoice-card h2,
.tracker-preferences-card h2,
.tracker-saved-card h2,
.tracker-history-card h2,
.tracker-chat-card h2{
  margin:0 0 12px;
  font-size:1.15rem;
}
.tracker-modal.tracker-rating-card h2,
.tracker-modal.tracker-receipt-card h2,
.tracker-modal.tracker-invoice-card h2{
  margin:6px 0 12px;
  font-size:1.45rem;
}
.tracker-rating-buttons{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:8px;
  margin-bottom:12px;
}
.tracker-rating-buttons button{
  min-height:44px;
  border:1px solid rgba(11,31,51,.12);
  border-radius:12px;
  background:#fff;
  color:#A16207;
  font-size:1.35rem;
  line-height:1;
  cursor:pointer;
  transition:background .18s ease,border-color .18s ease,transform .18s ease,color .18s ease;
}
.tracker-rating-buttons button:hover,
.tracker-rating-buttons button:focus-visible,
.tracker-rating-buttons button.is-selected{
  background:var(--amber);
  border-color:var(--amber);
  color:var(--navy);
  transform:translateY(-1px);
}
.tracker-rating-card textarea{
  width:100%;
  min-height:82px;
  resize:vertical;
  border:1px solid rgba(11,31,51,.14);
  border-radius:14px;
  padding:12px 14px;
  color:var(--ink);
  font:inherit;
  line-height:1.4;
  margin-bottom:12px;
}
.tracker-receipt-grid{
  display:grid;
  gap:8px;
  margin-bottom:12px;
}
.tracker-receipt-row{
  display:grid;
  grid-template-columns:112px minmax(0,1fr);
  gap:10px;
  padding:10px 0;
  border-bottom:1px solid rgba(11,31,51,.08);
}
.tracker-receipt-row:last-child{
  border-bottom:0;
}
.tracker-receipt-row dt{
  color:var(--ink-soft);
  font-size:.78rem;
  font-weight:900;
  text-transform:uppercase;
}
.tracker-receipt-row dd{
  margin:0;
  color:var(--ink);
  font-weight:800;
  line-height:1.3;
}
.tracker-invoice-form{
  display:grid;
  gap:14px;
}
.tracker-invoice-form label{
  display:grid;
  gap:6px;
  color:var(--ink);
  font-size:.92rem;
  font-weight:800;
}
.tracker-invoice-form input{
  min-height:44px;
  border:1px solid rgba(11,31,51,.14);
  border-radius:12px;
  padding:0 12px;
  color:var(--ink);
  font:inherit;
}
.tracker-invoice-form .button-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}
.tracker-tools-card{
  overflow:hidden;
}
.tracker-tools-card summary{
  position:relative;
  min-height:54px;
  display:grid;
  grid-template-columns:minmax(0,1fr);
  gap:3px;
  align-items:center;
  margin:-18px;
  padding:16px 18px;
  color:var(--ink);
  cursor:pointer;
  list-style:none;
}
.tracker-tools-card summary::-webkit-details-marker{
  display:none;
}
.tracker-tools-card summary::after{
  content:"+";
  position:absolute;
  right:18px;
  top:17px;
  width:28px;
  height:28px;
  display:grid;
  place-items:center;
  border-radius:999px;
  background:#F3F7FB;
  color:var(--ink);
  font-weight:900;
}
.tracker-tools-card[open] summary::after{
  content:"-";
}
.tracker-tools-card summary span{
  margin:0;
  padding-right:34px;
  font-size:1.05rem;
  font-weight:900;
}
.tracker-tools-card summary small{
  padding-right:34px;
  color:var(--ink-soft);
  line-height:1.35;
}
.tracker-tools-stack{
  display:grid;
  gap:10px;
  margin-top:18px;
}
.tracker-tools-stack .tracker-preferences-card,
.tracker-tools-stack .tracker-saved-card,
.tracker-tools-stack .tracker-history-card,
.tracker-tools-stack .tracker-chat-card{
  box-shadow:none;
  background:#F8FAFC;
}
.tracker-actions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-top:12px;
}
.tracker-actions .btn{
  justify-content:center;
  min-height:48px;
}
.tracker-actions .tracker-action--wide{
  grid-column:1 / -1;
}
.tracker-action-note{
  margin:12px 0 0;
  color:var(--ink-soft);
  font-size:.92rem;
  line-height:1.45;
}
.tracker-action-note--success{
  color:#067647;
}
.tracker-action-note--error{
  color:#B42318;
}
.tracker-route-list{
  display:grid;
  gap:10px;
  margin-top:12px;
}
.tracker-route-list article{
  position:relative;
  display:grid;
  gap:4px;
  padding:14px 14px 14px 42px;
  border:1px solid rgba(11,31,51,.08);
  border-radius:16px;
  background:#F8FAFC;
}
.tracker-route-list article::before{
  content:"";
  position:absolute;
  left:16px;
  top:18px;
  width:13px;
  height:13px;
  border-radius:50%;
  background:var(--amber);
  box-shadow:0 0 0 4px rgba(247,181,0,.16);
}
.tracker-route-list article + article::before{
  background:#12395A;
  box-shadow:0 0 0 4px rgba(18,57,90,.12);
}
.tracker-route-list span{
  color:var(--ink-soft);
  font-size:.78rem;
  font-weight:900;
  text-transform:uppercase;
}
.tracker-route-list strong{
  color:var(--ink);
  line-height:1.25;
}
.tracker-route-list small{
  color:var(--ink-soft);
  line-height:1.35;
}
.tracker-preference-options{
  display:grid;
  gap:8px;
}
.tracker-preference-options label{
  min-height:44px;
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border:1px solid rgba(11,31,51,.1);
  border-radius:14px;
  background:#F8FAFC;
  color:var(--ink);
  font-weight:800;
}
.tracker-preference-options input,
.tracker-map-toggle input{
  accent-color:var(--amber);
}
.tracker-preferences-card textarea{
  width:100%;
  min-height:76px;
  resize:vertical;
  margin-top:10px;
  border:1px solid rgba(11,31,51,.14);
  border-radius:14px;
  padding:11px 13px;
  color:var(--ink);
  font:inherit;
  line-height:1.4;
}
.tracker-save-actions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  margin-bottom:10px;
}
.tracker-save-actions .btn{
  justify-content:center;
}
.tracker-compact-list{
  display:grid;
  gap:8px;
}
.tracker-compact-item{
  display:grid;
  gap:4px;
  padding:11px 12px;
  border:1px solid rgba(11,31,51,.08);
  border-radius:14px;
  background:#F8FAFC;
}
.tracker-compact-item strong{
  color:var(--ink);
  font-size:.95rem;
  line-height:1.25;
}
.tracker-compact-item span,
.tracker-compact-item small{
  color:var(--ink-soft);
  line-height:1.35;
}
.tracker-compact-item a{
  color:#0B3D78;
  font-weight:900;
  text-decoration:none;
}
.tracker-empty-copy{
  margin:0;
  padding:12px;
  border:1px dashed rgba(11,31,51,.14);
  border-radius:14px;
  color:var(--ink-soft);
  background:#F8FAFC;
  line-height:1.4;
}
.tracker-chat-log{
  display:grid;
  gap:8px;
  max-height:220px;
  overflow:auto;
  padding:10px;
  border:1px solid rgba(11,31,51,.08);
  border-radius:14px;
  background:#F8FAFC;
}
.tracker-chat-message{
  max-width:86%;
  display:grid;
  gap:3px;
  padding:9px 11px;
  border-radius:14px;
  background:#fff;
  color:var(--ink);
  box-shadow:0 6px 14px rgba(11,31,51,.06);
}
.tracker-chat-message.is-user{
  justify-self:end;
  background:#12395A;
  color:#fff;
}
.tracker-chat-message strong{
  font-size:.78rem;
}
.tracker-chat-message p{
  margin:0;
  line-height:1.35;
}
.tracker-chat-message time{
  color:inherit;
  opacity:.72;
  font-size:.76rem;
}
.tracker-chat-form{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:8px;
  margin-top:10px;
}
.tracker-chat-form input{
  min-width:0;
  min-height:46px;
  border:1px solid rgba(11,31,51,.14);
  border-radius:999px;
  padding:0 15px;
  color:var(--ink);
  font:inherit;
}
.tracker-details-card{
  padding:0;
  overflow:hidden;
}
.tracker-details-card summary{
  cursor:pointer;
  min-height:54px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px 18px;
  color:var(--ink);
  font-weight:900;
}
.tracker-details-card summary::after{
  content:"+";
  font-size:1.25rem;
  color:var(--ink-soft);
}
.tracker-details-card[open] summary::after{
  content:"-";
}
.summary-panel--tracker{
  padding:0 18px 18px;
  border:0;
  box-shadow:none;
  background:transparent;
}
.tracker-details-card .detail-grid,
.tracker-details-card [data-reservation-status-note]{
  margin:0 18px 18px;
}
.tracker-map-panel{
  position:relative;
  min-width:0;
  min-height:620px;
  border-radius:24px;
  overflow:hidden;
  background:#DDE7EE;
  box-shadow:0 22px 56px rgba(11,31,51,.12);
}
.tracker-map{
  position:relative;
  z-index:1;
  min-height:100%;
  height:100%;
  overflow:hidden;
  background:
    radial-gradient(circle at 22% 28%, rgba(247,181,0,.14), transparent 22rem),
    linear-gradient(145deg,#EAF1F6 0%,#DCE8EF 48%,#EEF4F7 100%);
}
.tracker-live-map{
  position:absolute;
  inset:0;
  z-index:0;
  min-height:100%;
  background:#E7ECF4;
  opacity:0;
  pointer-events:none;
  transition:opacity .24s ease;
}
.tracker-map-panel.has-live-map .tracker-live-map{
  opacity:1;
  pointer-events:auto;
}
.tracker-map-panel.has-live-map .tracker-map__canvas{
  opacity:0;
  pointer-events:none;
}
.tracker-live-map .leaflet-control-attribution{
  font-size:.68rem;
}
.tracker-live-map .leaflet-top.leaflet-left{
  top:auto;
  left:auto;
  right:14px;
  bottom:14px;
}
.tracker-live-map .leaflet-control-zoom{
  overflow:hidden;
  border:0;
  border-radius:12px;
  box-shadow:0 12px 28px rgba(11,31,51,.18);
}
.tracker-live-map .leaflet-control-zoom a{
  width:42px;
  height:42px;
  display:grid;
  place-items:center;
  border:0;
  color:var(--ink);
  font-size:1.45rem;
  line-height:1;
}
.tracker-live-map .leaflet-control-zoom a + a{
  border-top:1px solid rgba(11,31,51,.1);
}
.tracker-live-marker{
  display:grid;
  place-items:center;
}
.tracker-live-marker__pin{
  width:32px;
  height:32px;
  display:grid;
  place-items:center;
  border-radius:50% 50% 50% 0;
  border:3px solid #fff;
  background:var(--amber);
  color:var(--ink);
  box-shadow:0 12px 24px rgba(11,31,51,.26),0 0 0 4px rgba(247,181,0,.18);
  transform:rotate(-45deg);
}
.tracker-live-marker__glyph{
  width:18px;
  height:18px;
  display:grid;
  place-items:center;
  border-radius:999px;
  background:#fff;
  color:#0b1f33;
  font-size:.78rem;
  font-weight:1000;
  line-height:1;
  transform:rotate(45deg);
}
.tracker-live-marker--pickup .tracker-live-marker__pin{
  background:#f5c542;
  color:#0b1f33;
}
.tracker-live-marker--dropoff .tracker-live-marker__pin{
  background:#12395A;
  color:#fff;
  box-shadow:0 12px 24px rgba(11,31,51,.26),0 0 0 4px rgba(18,57,90,.14);
}
.tracker-live-marker--dropoff .tracker-live-marker__glyph{
  background:#fff;
  color:#12395A;
}
.tracker-live-marker--user .tracker-live-marker__pin{
  border-radius:999px;
  background:#fff;
  color:#1E64B7;
}
.tracker-stop-icon{
  display:grid;
  place-items:center;
}
.tracker-stop-icon__pin{
  width:30px;
  height:30px;
  display:grid;
  place-items:center;
  border:3px solid #fff;
  border-radius:10px;
  background:#7C3AED;
  color:#fff;
  font-size:.9rem;
  font-weight:1000;
  box-shadow:0 10px 22px rgba(76,29,149,.24);
}
.tracker-live-marker__taxi-pin{
  width:42px;
  height:48px;
  display:grid;
  place-items:center;
  border:3px solid #173452;
  border-radius:50% 50% 50% 12px;
  background:#fff;
  box-shadow:0 10px 18px rgba(11,31,51,.2);
  transform:rotate(-45deg);
}
.tracker-live-marker__taxi-pin img{
  display:block;
  width:28px;
  height:28px;
  object-fit:contain;
  transform:rotate(45deg);
}
.tracker-live-map-popup{
  min-width:130px;
}
.tracker-live-map-popup strong{
  display:block;
  color:var(--ink);
}
.tracker-live-map-popup span{
  display:block;
  color:var(--ink-soft);
  font-size:.82rem;
}
.tracker-map-panel iframe[data-driver-map]{
  position:absolute;
  inset:0;
  z-index:0;
  width:100%;
  height:100%;
  border:0;
  background:#DDE7EE;
}
.tracker-map-panel.has-real-map .tracker-map{
  background:linear-gradient(180deg,rgba(237,242,247,.14),rgba(237,242,247,.08));
}
.tracker-map-panel.has-real-map .tracker-map__canvas{
  opacity:0;
  pointer-events:none;
}
.tracker-map__canvas{
  position:absolute;
  inset:0;
  transform-origin:center;
  transition:transform .28s ease,filter .28s ease;
}
.tracker-map__grid{
  position:absolute;
  inset:-10%;
  background:
    linear-gradient(28deg, transparent 0 39%, rgba(255,255,255,.86) 39.4% 41.8%, transparent 42.2%),
    linear-gradient(119deg, transparent 0 45%, rgba(255,255,255,.78) 45.4% 47.8%, transparent 48.2%),
    linear-gradient(0deg, transparent 0 53%, rgba(255,255,255,.55) 53.4% 54.6%, transparent 55%),
    linear-gradient(90deg, rgba(11,31,51,.05) 1px, transparent 1px),
    linear-gradient(0deg, rgba(11,31,51,.05) 1px, transparent 1px);
  background-size:auto, auto, auto, 76px 76px, 76px 76px;
}
.tracker-map__route{
  position:absolute;
  left:18%;
  right:20%;
  height:8px;
  border-radius:999px;
  background:linear-gradient(90deg,#7F8FEA,#5F70D5);
  box-shadow:0 7px 16px rgba(95,112,213,.18);
  transform-origin:left center;
}
.tracker-map__route--pickup{
  top:42%;
  width:48%;
  transform:rotate(-15deg);
}
.tracker-map__route--destination{
  top:58%;
  left:34%;
  width:46%;
  transform:rotate(18deg);
  background:linear-gradient(90deg,#7F8FEA,#5F70D5);
  display:none;
}
.tracker-map[data-map-phase="waiting"] .tracker-map__route--pickup,
.tracker-map[data-map-phase="arrived"] .tracker-map__route--pickup{
  background:repeating-linear-gradient(90deg,#6676D9 0 20px, transparent 20px 32px);
}
.tracker-map[data-map-phase="onboard"] .tracker-map__route--pickup,
.tracker-map[data-map-phase="arriving"] .tracker-map__route--pickup,
.tracker-map[data-map-phase="completed"] .tracker-map__route--pickup{
  display:none;
}
.tracker-map[data-map-phase="onboard"] .tracker-map__route--destination,
.tracker-map[data-map-phase="arriving"] .tracker-map__route--destination,
.tracker-map[data-map-phase="completed"] .tracker-map__route--destination{
  display:block;
}
.tracker-map__search-pulse{
  position:absolute;
  left:54%;
  top:39%;
  width:118px;
  height:118px;
  border-radius:50%;
  transform:translate(-50%,-50%);
  background:rgba(247,181,0,.12);
  border:1px solid rgba(247,181,0,.28);
  animation:trackerPulse 2.2s ease-out infinite;
}
.tracker-map:not([data-map-phase="waiting"]) .tracker-map__search-pulse{
  display:none;
}
.tracker-marker{
  --marker-x:50%;
  --marker-y:50%;
  position:absolute;
  left:var(--marker-x);
  top:var(--marker-y);
  transform:translate(-50%,-50%);
  z-index:3;
}
.tracker-marker span{
  position:absolute;
  left:50%;
  top:calc(100% + 9px);
  transform:translateX(-50%);
  white-space:nowrap;
  padding:6px 9px;
  border-radius:999px;
  background:#fff;
  color:var(--ink);
  font-size:.82rem;
  font-weight:900;
  box-shadow:0 8px 18px rgba(11,31,51,.12);
}
.tracker-marker--pickup{
  --marker-x:55%;
  --marker-y:38%;
}
.tracker-marker--dropoff{
  --marker-x:80%;
  --marker-y:68%;
}
.tracker-marker--user{
  --marker-x:46%;
  --marker-y:52%;
}
.tracker-marker--pickup::before,
.tracker-marker--dropoff::before,
.tracker-marker--user::before{
  content:"";
  display:block;
  width:26px;
  height:26px;
  border-radius:50% 50% 50% 0;
  transform:rotate(-45deg);
  background:var(--amber);
  border:3px solid #fff;
  box-shadow:0 10px 20px rgba(11,31,51,.24),0 0 0 4px rgba(247,181,0,.16);
}
.tracker-marker--pickup::after{
  content:"O";
  position:absolute;
  left:50%;
  top:50%;
  width:16px;
  height:16px;
  display:grid;
  place-items:center;
  border-radius:999px;
  background:#fff;
  color:#0b1f33;
  font-size:.68rem;
  font-weight:1000;
  line-height:1;
  transform:translate(-50%,-50%);
}
.tracker-marker--dropoff::before{
  background:#12395A;
}
.tracker-marker--user::before{
  width:18px;
  height:18px;
  border-radius:50%;
  transform:none;
  background:#fff;
  border:5px solid #1E64B7;
}
.tracker-marker--taxi{
  --marker-x:25%;
  --marker-y:50%;
  width:42px;
  height:48px;
  border:3px solid #173452;
  border-radius:50% 50% 50% 12px;
  background:#fff url("/assets/img/vehicles/taxi-icon.png") center/28px 28px no-repeat;
  box-shadow:0 10px 18px rgba(11,31,51,.2);
  transform:translate(-50%,-90%);
  transition:left .35s ease, top .35s ease, transform .35s ease;
}
.tracker-marker--taxi::before{
  content:none;
}
.tracker-marker--taxi::after{
  content:none;
}
.tracker-marker--taxi span{
  top:auto;
  bottom:calc(100% + 6px);
}
.tracker-map[data-map-phase="waiting"] .tracker-marker--taxi{
  display:none;
}
.tracker-map[data-map-phase="assigned"] .tracker-marker--taxi{
  --marker-x:24%;
  --marker-y:53%;
}
.tracker-map[data-map-phase="on_way"] .tracker-marker--taxi{
  --marker-x:36%;
  --marker-y:47%;
}
.tracker-map[data-map-phase="approaching"] .tracker-marker--taxi{
  --marker-x:50%;
  --marker-y:40%;
}
.tracker-map[data-map-phase="arrived"] .tracker-marker--taxi{
  --marker-x:55%;
  --marker-y:38%;
}
.tracker-map[data-map-phase="onboard"] .tracker-marker--taxi{
  --marker-x:48%;
  --marker-y:54%;
  transform:translate(-50%,-90%);
}
.tracker-map[data-map-phase="arriving"] .tracker-marker--taxi{
  --marker-x:72%;
  --marker-y:65%;
  transform:translate(-50%,-90%);
}
.tracker-map[data-map-phase="completed"] .tracker-marker--taxi{
  --marker-x:80%;
  --marker-y:68%;
  opacity:.72;
  transform:translate(-50%,-90%);
}
.tracker-map__topbar,
.tracker-map__controls{
  position:absolute;
  z-index:4;
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
}
.tracker-map__topbar{
  top:18px;
  left:18px;
  right:18px;
  justify-content:space-between;
}
.tracker-map__topbar span{
  min-height:40px;
  display:inline-flex;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.9);
  color:var(--ink);
  font-weight:900;
  box-shadow:0 8px 22px rgba(11,31,51,.1);
}
.tracker-map__controls{
  right:18px;
  bottom:18px;
  justify-content:flex-end;
}
.tracker-map-tools{
  position:absolute;
  left:18px;
  bottom:18px;
  z-index:4;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
}
.tracker-map-segments{
  display:flex;
  overflow:hidden;
  border:1px solid rgba(11,31,51,.1);
  border-radius:999px;
  background:rgba(255,255,255,.92);
  box-shadow:0 8px 22px rgba(11,31,51,.1);
}
.tracker-map-segments button{
  min-height:40px;
  border:0;
  border-right:1px solid rgba(11,31,51,.08);
  padding:0 12px;
  background:transparent;
  color:var(--ink-soft);
  font:inherit;
  font-size:.85rem;
  font-weight:900;
  cursor:pointer;
}
.tracker-map-segments button:last-child{
  border-right:0;
}
.tracker-map-segments button:hover,
.tracker-map-segments button:focus-visible,
.tracker-map-segments button.is-active{
  background:var(--amber);
  color:var(--navy);
}
.tracker-map-toggle{
  min-height:40px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border:1px solid rgba(11,31,51,.1);
  border-radius:999px;
  background:rgba(255,255,255,.92);
  color:var(--ink);
  font-size:.85rem;
  font-weight:900;
  box-shadow:0 8px 22px rgba(11,31,51,.1);
}
.tracker-map[data-map-focus="taxi"] .tracker-map__canvas{
  transform:scale(1.04) translate(1%,1%);
}
.tracker-map[data-map-focus="pickup"] .tracker-map__canvas{
  transform:scale(1.11) translate(-4%,5%);
}
.tracker-map[data-map-focus="dropoff"] .tracker-map__canvas{
  transform:scale(1.1) translate(-9%,-5%);
}
.tracker-map[data-map-traffic="true"] .tracker-map__canvas::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:2;
  pointer-events:none;
  background:
    linear-gradient(28deg, transparent 0 40%, rgba(234,88,12,.78) 40.2% 41.2%, transparent 41.4%),
    linear-gradient(118deg, transparent 0 47%, rgba(22,163,74,.7) 47.2% 48%, transparent 48.2%),
    linear-gradient(0deg, transparent 0 56%, rgba(220,38,38,.62) 56.2% 57%, transparent 57.2%);
  mix-blend-mode:multiply;
  opacity:.7;
}
.tracker-map__controls .btn,
.tracker-map__topbar .btn{
  width:auto;
  min-height:40px;
}
@keyframes trackerPulse{
  0%{transform:translate(-50%,-50%) scale(.72);opacity:.9}
  75%{transform:translate(-50%,-50%) scale(1.35);opacity:.08}
  100%{transform:translate(-50%,-50%) scale(1.35);opacity:0}
}
@keyframes trackerCardPulse{
  0%{box-shadow:0 0 0 0 rgba(247,181,0,.38)}
  100%{box-shadow:0 0 0 14px rgba(247,181,0,0)}
}
.hidden{display:none !important}
[data-town].is-hidden,
[data-review].is-hidden{display:none !important}
.anchor-target{scroll-margin-top:110px}
@media (min-width: 1201px) and (max-width: 1440px){
  .site-header-inner{gap:18px}
  .logo{gap:12px}
  .logo-copy small{display:none}
  .site-nav{gap:4px}
  .nav-link{padding:10px 12px}
  .header-actions{gap:10px}
  .header-phone{padding-inline:12px}
  .btn--compact{padding-inline:14px}
}
@media (min-width: 1201px) and (max-width: 1320px){
  .header-actions .btn--ghost{display:none}
}
@media (max-width: 1200px){
  .site-nav,.header-actions{display:none}
  .header-mobile-actions{display:flex}
  .site-header-inner{
    min-height:64px;
    gap:16px;
  }
  .logo-copy small{display:none}
}
@media (max-width: 520px){
  .site-header > .container .logo:not(.logo--footer) .logo-image,
  .site-header > .container .logo:not(.logo--footer) .logo-svg{
    height:38px;
    max-width:132px;
  }
}
@media (max-width: 1100px){
  .trust-strip__inner,
  .price-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .local-layout,
  .form-layout,
  .article-layout,
  .two-col{grid-template-columns:1fr}
  .toc,
  .sticky-card,
  .form-shell--sidebar{position:static}
}
@media (max-width: 900px){
  .container{padding-inline:20px}
  .hero-home{padding:56px 0 64px}
  .hero-home__grid,
  .page-intro__grid,
  .grid-4,
  .grid-3,
  .grid-2,
  .step-grid,
  .band-grid,
  .trust-strip__inner,
  .price-grid,
  .form-progress,
  .inline-options,
  .form-review-extras,
  .form-grid{grid-template-columns:1fr}
  .hero-home h1{max-width:none}
  .hero-home__lead{font-size:1.02rem}
  .hero-home--photo .hero-home__lead{margin-top:24px}
  .hero-home--photo .hero-quick{transform:none}
  .trust-strip{transform:none;margin-top:-10px}
  .subnav{
    position:relative;
    top:auto;
    padding-top:0;
    background:transparent;
  }
  .cta-banner{
    grid-template-columns:1fr;
    align-items:flex-start;
    padding:28px;
  }
  .cta-banner__actions{
    display:grid;
    grid-auto-flow:row;
    grid-auto-columns:auto;
    width:100%;
    justify-content:flex-start;
  }
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{
    flex-direction:column;
    align-items:flex-start;
  }
  .summary-grid{grid-template-columns:1fr}
  .form-actions{
    flex-direction:column;
    align-items:stretch;
  }
  .form-actions .btn{
    width:100%;
    flex:1 1 auto;
  }
  .confirmation-layout,
  .detail-grid{grid-template-columns:1fr}
  .reservation-modal{padding:0}
  .reservation-modal__dialog{
    width:100%;
    height:100%;
    max-height:none;
    border-radius:0;
  }
  .reservation-modal__header,
  .reservation-modal__body{padding:18px}
  .form-choice-group .inline-options{
    grid-template-columns:repeat(2,minmax(0,1fr));
    max-width:none;
  }
  .field-inline-action{
    grid-template-columns:minmax(0,1fr);
  }
  .field-inline-action .field-action{
    min-height:42px;
  }
}
@media (max-width: 640px){
  body{padding-bottom:82px}
  .hero-home{
    padding-top:16px;
  }
  .mobile-action-bar{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:6px;
    padding:10px 12px calc(10px + env(safe-area-inset-bottom));
  }
  .mobile-action-bar .btn{padding-inline:6px}
  .mobile-drawer{
    padding:0;
    align-items:end;
  }
  .mobile-drawer__panel{
    width:100%;
    height:min(92vh,720px);
    border-radius:8px 8px 0 0;
    padding:18px;
  }
  .mobile-drawer__quick{
    grid-template-columns:1fr;
  }
  .mobile-drawer__link-grid{
    grid-template-columns:1fr 1fr;
  }
  .mobile-nav__link{
    min-height:48px;
    padding:10px 12px;
  }
  .btn,.btn--compact{width:100%;min-height:48px}
  .hero-home__actions,
  .page-intro__actions,
  .quick-card__actions,
  .cta-banner__actions{display:grid;grid-template-columns:1fr}
  .search-row{grid-template-columns:1fr}
  .home-town-suggestions{
    position:static;
    margin-top:8px;
  }
  .header-mobile-actions .btn{width:auto}
  .header-mobile-actions .menu-toggle{width:48px}
  .hero-quick__body{padding:20px}
  .card,.review-card,.coverage-search,.band,.form-shell,.sticky-card,.toc,.summary-panel{padding:20px}
  .section{padding:56px 0}
  .section--tight{padding:42px 0}
  .field-action{width:100%}
}
@media (min-width: 641px) and (max-width: 900px){
  .container{padding-inline:24px}
  .hero-home{padding:64px 0 72px}
  .hero-home__grid,
  .page-intro__grid,
  .hero-split{gap:32px}
  .grid-4,
  .grid-3,
  .grid-2,
  .step-grid,
  .band-grid,
  .trust-strip__inner,
  .price-grid,
  .route-grid,
  .review-grid,
  .stat-band{grid-template-columns:repeat(2,minmax(0,1fr))}
  .quick-stack{grid-template-columns:repeat(2,minmax(0,1fr))}
  .grid-3 > :last-child:nth-child(odd),
  .grid-4 > :last-child:nth-child(odd),
  .band-grid > :last-child:nth-child(odd),
  .step-grid > :last-child:nth-child(odd),
  .price-grid > :last-child:nth-child(odd),
  .route-grid > :last-child:nth-child(odd),
  .review-grid > :last-child:nth-child(odd),
  .stat-band > :last-child:nth-child(odd),
  .quick-stack > :last-child:nth-child(odd){grid-column:1 / -1}
}


.chip-link{border-color:rgba(22,59,92,.16);background:#fff}
.chip-link:hover{border-color:var(--navy);color:var(--ink)}
.form-shell[data-reservation-layout="compact"] .form-progress{display:none}
.form-shell[data-reservation-layout="compact"] .form-step{gap:14px}
.form-shell[data-reservation-layout="compact"] [data-form-step="2"]{
  padding-top:6px;
  border-top:1px solid rgba(11,31,51,.08);
}
.form-shell[data-reservation-layout="compact"] .form-grid{gap:12px}
.form-shell[data-reservation-layout="compact"] .form-step__intro,
.form-shell[data-reservation-layout="compact"] [data-form-step="1"] > .form-actions,
.form-shell[data-reservation-layout="compact"] [data-form-step="1"] > .form-note,
.form-shell[data-reservation-layout="compact"] [data-step-back]{display:none !important}
.page-intro--booking-strip{
  padding:24px 0 20px;
  background:linear-gradient(180deg,rgba(245,247,251,.96) 0%, #fff 100%);
}
.page-intro--booking-strip .center-message{
  max-width:900px;
  margin:0;
  text-align:left;
}
.page-intro--booking-strip .center-message p{
  max-width:none;
  font-size:1rem;
  line-height:1.6;
}
.page-intro--booking-strip .page-intro__actions{margin-top:14px}
body.page--transactional .breadcrumb{
  display:none;
}
body.page--transactional .page-intro--booking-strip{
  padding:18px 0 14px;
}
body.page--transactional .page-intro--booking-strip .center-message{
  max-width:760px;
}
body.page--transactional .page-intro--booking-strip .page-intro__actions{
  display:flex;
  flex-wrap:wrap;
}
body.page--transactional .section--soft{
  padding-top:28px;
}
body.page--transactional .form-layout{
  max-width:1060px;
  margin-inline:auto;
}
body.page--reservation .page-intro--booking-strip{
  display:none;
}
body.page--reservation .section--soft{
  padding:24px 0 56px;
  background:#fff;
}
body.page--reservation .section--soft > .container{
  width:min(100% - 40px, 1840px);
}
body.page--booking-embed{
  --booking-embed-accent:var(--navy);
  background:#fff;
}
body.page--booking-embed .skip-link,
body.page--booking-embed .site-header,
body.page--booking-embed .mobile-action-bar,
body.page--booking-embed .site-footer,
body.page--booking-embed .breadcrumb{
  display:none !important;
}
body.page--booking-embed main{
  overflow:visible;
}
.booking-embed-brand{
  display:flex;
  align-items:center;
  gap:12px;
  width:min(100% - 24px, 1080px);
  margin:12px auto 0;
  padding:10px 12px;
  border:1px solid rgba(15,23,42,.1);
  border-radius:8px;
  background:#fff;
  color:var(--ink);
}
.booking-embed-brand__mark{
  width:42px;
  height:42px;
  flex:0 0 42px;
  display:grid;
  place-items:center;
  border-radius:8px;
  background:var(--booking-embed-accent);
  color:#fff;
  font-size:.82rem;
  font-weight:900;
  overflow:hidden;
}
.booking-embed-brand__mark img{
  width:100%;
  height:100%;
  object-fit:contain;
  background:#fff;
}
.booking-embed-brand__copy{
  min-width:0;
  display:grid;
  gap:2px;
}
.booking-embed-brand__copy strong{
  font-size:.98rem;
  line-height:1.2;
  letter-spacing:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.booking-embed-brand__copy small{
  color:var(--ink-soft);
  font-size:.78rem;
  line-height:1.3;
}
.booking-embed-brand__credit-logo{
  display:block;
  width:auto;
  max-width:132px;
  max-height:28px;
  margin-top:4px;
  object-fit:contain;
}
body.page--booking-embed .section--soft{
  padding:16px 0 20px;
  background:#fff;
}
body.page--booking-embed .section--soft > .container{
  width:100%;
  max-width:1120px;
  padding-inline:12px;
}
body.page--booking-embed-form .page-intro--booking-strip,
body.page--booking-embed-form .ride-map-panel,
body.page--booking-embed-form .form-shell--sidebar{
  display:none !important;
}
body.page--booking-embed-form .form-layout.form-layout--ride-booking{
  grid-template-columns:minmax(0,1fr);
  max-width:720px;
  gap:0;
}
body.page--booking-embed-form .ride-booking-form.form-shell{
  padding:18px;
  border-color:rgba(15,23,42,.12);
  box-shadow:none;
}
body.page--booking-embed-form .ride-booking__title{
  font-size:1.35rem;
}
body.page--booking-embed-form .ride-booking-field,
body.page--booking-embed-form .ride-booking-trigger{
  min-height:62px;
}
body.page--booking-embed-page .page-intro--booking-strip{
  display:block;
  padding:16px 0 4px;
  background:#fff;
}
body.page--booking-embed-page .page-intro--booking-strip .container{
  padding-inline:12px;
}
body.page--booking-embed-page .page-intro--booking-strip .center-message{
  max-width:1080px;
  margin-inline:auto;
}
body.page--booking-embed-page .page-intro--booking-strip h1{
  font-size:clamp(1.6rem, 2.4vw, 2.3rem);
  letter-spacing:0;
}
body.page--booking-embed-chat{
  min-height:100vh;
  overflow:hidden;
}
body.page--booking-embed-chat main > :not(.booking-embed-brand){
  display:none !important;
}
body.page--booking-embed-chat .booking-embed-brand{
  width:calc(100% - 20px);
  margin:10px auto;
}
body.page--booking-embed-chat .ai-webchat{
  position:static;
  z-index:1;
  display:block;
  width:100%;
  padding:0 10px 10px;
  font-size:15px;
}
body.page--booking-embed-chat .ai-webchat__toggle,
body.page--booking-embed-chat .ai-webchat__icon-button{
  display:none !important;
}
body.page--booking-embed-chat .ai-webchat__panel{
  width:100%;
  max-height:none;
  height:calc(100vh - 92px);
  min-height:520px;
  border-radius:8px;
  box-shadow:none;
}
body.page--tracker-embed{
  --booking-embed-accent:var(--navy);
  background:#fff;
}
body.page--tracker-embed .skip-link,
body.page--tracker-embed .site-header,
body.page--tracker-embed .mobile-action-bar,
body.page--tracker-embed .site-footer,
body.page--tracker-embed .breadcrumb{
  display:none !important;
}
body.page--tracker-embed main{
  overflow:visible;
}
body.page--tracker-embed .booking-embed-brand{
  margin-block:10px;
}
body.page--tracker-embed .reservation-tracker{
  min-height:calc(100dvh - 74px);
  padding:12px;
}
body.page--tracker-embed .tracker-shell{
  min-height:calc(100dvh - 98px);
}
.form-layout.form-layout--ride-booking{
  max-width:none;
  grid-template-columns:minmax(340px,440px) minmax(560px,1fr);
  align-items:start;
  gap:32px;
}
.ride-booking-form.form-shell{
  display:block;
  padding:26px;
  border-radius:8px;
  border-color:rgba(15,23,42,.1);
  box-shadow:0 1px 2px rgba(15,23,42,.04);
}
.ride-booking-form .form-progress,
.ride-booking-form > .form-step{
  display:none !important;
}
.ride-booking{
  display:grid;
  gap:16px;
}
.ride-booking__title{
  margin:0 0 8px;
  font-size:1.65rem;
  letter-spacing:0;
}
.ride-booking__stack{
  display:grid;
  gap:12px;
}
.ride-booking__stack .route-stops{
  border-style:solid;
  border-radius:8px;
  background:#fff;
  padding:10px 14px;
}
.ride-booking__stack .route-stop-row{
  grid-template-columns:24px minmax(0,1fr) 36px;
}
.ride-booking__stack .route-stop-row__index{
  width:24px;
  height:24px;
  background:#111827;
}
.ride-booking__stack .route-stops__add{
  min-height:36px;
}
.ride-booking__stack .route-stops p{
  font-size:.78rem;
}
.ride-booking-field{
  --ride-field-panel-left:-56px;
  --ride-field-panel-extra:72px;
  display:grid;
  grid-template-columns:28px minmax(0,1fr);
  align-items:center;
  gap:12px;
  min-height:70px;
  padding:10px 14px;
  border:2px solid transparent;
  border-radius:8px;
  background:#F3F4F6;
  transition:border-color .18s ease, background-color .18s ease, box-shadow .18s ease;
}
.ride-booking-field:focus-within{
  background:#fff;
  border-color:var(--navy);
  box-shadow:0 0 0 3px rgba(11,31,51,.08);
}
.ride-booking-field__icon{
  width:24px;
  height:24px;
  color:#020617;
}
.ride-booking-field__icon svg{
  width:24px;
  height:24px;
}
.ride-booking-field .field__control{
  min-width:0;
  display:grid;
  gap:4px;
}
.ride-booking-form .ride-booking-field input,
.ride-booking-form .ride-booking-field select,
.ride-booking-form .ride-booking-field textarea{
  min-height:42px;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  font-size:1rem;
  color:var(--ink);
}
.ride-booking-form .ride-booking-field input:focus,
.ride-booking-form .ride-booking-field select:focus,
.ride-booking-form .ride-booking-field textarea:focus{
  border:0;
  box-shadow:none;
}
.ride-booking-form .ride-booking-field input::placeholder{
  color:#5B6472;
}
.ride-booking-field .field-inline-action{
  grid-template-columns:minmax(0,1fr) auto;
  align-items:center;
}
.ride-booking-field .field-action{
  width:auto;
  min-height:36px;
  padding-inline:12px;
  border-radius:8px;
  white-space:nowrap;
}
.ride-booking-field .field-error,
.ride-booking-field .field-assistive{
  grid-column:1 / -1;
  margin-left:40px;
}
.ride-booking-form .autocomplete-panel{
  top:calc(100% + 10px);
  left:var(--ride-field-panel-left);
  right:auto;
  width:calc(100% + var(--ride-field-panel-extra));
  min-width:calc(100% + var(--ride-field-panel-extra));
  max-width:none;
  border-radius:8px;
  box-shadow:0 24px 56px rgba(15,23,42,.2);
}
.ride-booking-form .autocomplete-panel__option{
  min-height:58px;
  padding:14px 18px;
  background:#fff;
}
.ride-booking-form .autocomplete-panel__option--action{
  display:grid;
  gap:3px;
  text-align:left;
}
.ride-booking-form .autocomplete-panel__option-title{
  font-weight:800;
  color:var(--ink);
}
.ride-booking-form .autocomplete-panel__option-copy{
  font-size:.9rem;
  color:var(--ink-soft);
}
.ride-booking-form .autocomplete-panel__option:hover,
.ride-booking-form .autocomplete-panel__option.is-active{
  background:#F1F5F9;
  color:var(--ink);
}
.ride-booking-field .field-action--menu-only{
  display:none !important;
}
.ride-booking__schedule{
  position:relative;
}
.ride-booking-form.is-schedule-open .ride-booking__title,
.ride-booking-form.is-schedule-open .ride-booking__stack > :not(.ride-booking__schedule),
.ride-booking-form.is-schedule-open .ride-booking__chips,
.ride-booking-form.is-schedule-open .ride-booking__extra,
.ride-booking-form.is-schedule-open .ride-booking__verification,
.ride-booking-form.is-schedule-open .ride-booking__status,
.ride-booking-form.is-schedule-open .ride-booking__actions{
  display:none !important;
}
.ride-booking-form.is-schedule-open .ride-booking__stack{
  display:block;
}
.ride-booking-form.is-schedule-open .ride-booking__schedule{
  position:static;
}
.ride-booking-form.is-schedule-open .ride-booking-trigger{
  display:none;
}
.ride-booking__native-controls{
  display:none;
}
.ride-booking-trigger{
  width:100%;
  min-height:70px;
  display:grid;
  grid-template-columns:28px minmax(0,1fr) 20px;
  align-items:center;
  gap:12px;
  padding:10px 14px;
  border:2px solid transparent;
  border-radius:8px;
  background:#F3F4F6;
  color:var(--ink);
  text-align:left;
}
.ride-booking-trigger:hover,
.ride-booking-trigger:focus-visible{
  background:#fff;
  border-color:var(--navy);
  box-shadow:0 0 0 3px rgba(11,31,51,.08);
  outline:0;
}
.ride-booking-trigger__icon,
.ride-booking-trigger__chevron{
  width:24px;
  height:24px;
  color:#020617;
}
.ride-booking-trigger__label{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  font-size:1rem;
  font-weight:700;
}
.ride-schedule-panel{
  position:absolute;
  top:calc(100% + 10px);
  left:0;
  right:0;
  z-index:60;
  display:grid;
  gap:16px;
  padding:20px;
  border:1px solid rgba(15,23,42,.12);
  border-radius:8px;
  background:#fff;
  box-shadow:0 28px 70px rgba(15,23,42,.2);
}
.ride-booking-form.is-schedule-open .ride-schedule-panel{
  position:static;
  inset:auto;
  min-height:0;
  padding:2px 0 4px;
  border:0;
  box-shadow:none;
  background:#fff;
  align-content:start;
  gap:22px;
}
.ride-schedule-panel[hidden]{
  display:none !important;
}
.ride-schedule-panel__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.ride-schedule-panel__back{
  width:58px;
  height:58px;
  display:grid;
  place-items:center;
  border:0;
  border-radius:8px;
  background:#F3F4F6;
  color:#020617;
}
.ride-schedule-panel__back svg{
  transform:rotate(180deg);
}
.ride-schedule-panel__clear{
  border:0;
  background:transparent;
  color:#020617;
  font-weight:800;
  min-height:44px;
  padding:0 2px;
  font-size:1rem;
}
.ride-schedule-panel h4{
  margin:0;
  font-size:1.6rem;
  line-height:1.12;
  letter-spacing:0;
}
.ride-schedule-panel__now{
  min-height:64px;
  border:1px solid rgba(15,23,42,.08);
  border-radius:8px;
  background:#F3F4F6;
  color:var(--ink);
  font-weight:800;
  font-size:1.02rem;
}
.ride-schedule-panel__fields{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
}
.ride-booking-form.is-schedule-open .ride-schedule-panel__fields{
  grid-template-columns:1fr;
}
.ride-schedule-panel__field{
  display:grid;
  gap:10px;
}
.ride-schedule-panel__field label{
  font-size:.9rem;
  font-weight:800;
  color:var(--ink);
}
.ride-schedule-panel__field .field__control{
  position:relative;
  display:block;
}
.ride-schedule-panel__field input{
  width:100%;
  min-height:64px;
  padding:0 56px 0 18px;
  border:1px solid var(--border-strong);
  border-radius:8px;
  background:#fff;
  color:var(--ink);
  font-size:1.05rem;
  box-shadow:0 0 0 0 rgba(11,31,51,0);
  transition:border-color .18s ease, box-shadow .18s ease;
}
.ride-schedule-panel__field input:focus{
  border-color:var(--navy);
  box-shadow:0 0 0 5px rgba(11,31,51,.08);
  outline:0;
}
.ride-booking-form.is-schedule-open .ride-schedule-panel__field input{
  min-height:66px;
  font-size:1.08rem;
}
.ride-schedule-panel__field input::-webkit-calendar-picker-indicator{
  opacity:0;
}
.ride-schedule-panel__picker-button{
  position:absolute;
  right:14px;
  top:50%;
  transform:translateY(-50%);
  width:38px;
  height:38px;
  display:grid;
  place-items:center;
  border:0;
  border-radius:8px;
  background:transparent;
  color:#020617;
  cursor:pointer;
}
.ride-schedule-panel__picker-button svg{
  width:22px;
  height:22px;
}
.ride-schedule-panel__picker-button:hover,
.ride-schedule-panel__picker-button:focus-visible{
  background:#F3F4F6;
  outline:0;
}
.ride-schedule-panel__meta{
  display:grid;
  gap:8px;
  padding:0;
  color:var(--ink-soft);
  font-size:.95rem;
  line-height:1.5;
}
.ride-schedule-panel__meta p{
  margin:0;
}
.ride-schedule-panel > .btn{
  min-height:64px;
  border-radius:8px;
  font-size:1rem;
}
.ride-booking__chips{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.ride-booking-field--chip{
  width:max-content;
  max-width:100%;
  min-height:54px;
  grid-template-columns:22px minmax(120px,1fr);
  padding:8px 12px;
}
.ride-booking-field--chip .ride-booking-field__icon,
.ride-booking-field--chip .ride-booking-field__icon svg{
  width:20px;
  height:20px;
}
.ride-booking-form .ride-booking-field--chip select{
  min-height:34px;
  padding-right:20px;
  font-weight:700;
}
.ride-booking__extra{
  display:grid;
  gap:12px;
}
.ride-booking-form .form-details{
  border-style:solid;
  border-radius:8px;
  background:#fff;
}
.ride-booking-form .form-details > summary{
  padding:12px 14px;
}
.ride-booking-form .form-details > summary::after{
  border-radius:8px;
}
.ride-booking-form .form-details__body{
  padding:0 14px 14px;
}
.ride-booking__consent{
  padding:12px;
  border:1px solid rgba(15,23,42,.08);
  border-radius:8px;
  background:#F8FAFC;
}
.ride-booking__consent label{
  font-size:.82rem;
}
.ride-booking__verification:empty,
.ride-booking__status:empty{
  display:none;
}
.ride-booking__actions .btn{
  width:100%;
  min-height:64px;
  border-radius:8px;
  font-size:1rem;
}
.ride-map-panel{
  position:sticky;
  top:24px;
  min-height:min(760px,calc(100dvh - 48px));
  display:grid;
  gap:0;
  align-content:start;
  border-radius:8px;
}
.ride-map-panel__mobile-header{
  display:none;
}
.ride-map-panel__back{
  width:42px;
  height:42px;
  display:grid;
  place-items:center;
  border:0;
  border-radius:8px;
  background:#F3F4F6;
  color:#020617;
}
.ride-map-panel__back svg{
  width:20px;
  height:20px;
  transform:rotate(180deg);
}
.ride-map-panel__mobile-header h3{
  margin:0;
  font-size:1.25rem;
}
.ride-map-panel__mobile-header p{
  margin:4px 0 0;
  color:var(--ink-soft);
  font-size:.92rem;
}
.ride-map{
  position:relative;
  isolation:isolate;
  min-height:min(760px,calc(100dvh - 48px));
  overflow:hidden;
  border:1px solid rgba(15,23,42,.08);
  border-radius:8px;
  background:
    linear-gradient(18deg, transparent 0 44%, rgba(255,255,255,.72) 44.4% 45.2%, transparent 45.6% 100%),
    linear-gradient(145deg, transparent 0 55%, rgba(255,255,255,.66) 55.3% 56%, transparent 56.4% 100%),
    #E7ECF4;
}
.ride-route-map{
  position:absolute;
  inset:0;
  z-index:0;
  min-height:100%;
  background:#E7ECF4;
}
.ride-route-map .leaflet-control-attribution{
  font-size:.68rem;
}
.ride-route-map .leaflet-top.leaflet-left{
  top:auto;
  left:auto;
  right:18px;
  bottom:18px;
}
.ride-route-map .leaflet-control-zoom{
  overflow:hidden;
  border:0;
  border-radius:8px;
  box-shadow:0 14px 30px rgba(15,23,42,.18);
}
.ride-route-map .leaflet-control-zoom a{
  width:48px;
  height:48px;
  display:grid;
  place-items:center;
  border:0;
  color:#020617;
  font-size:1.7rem;
  line-height:1;
}
.ride-route-map .leaflet-control-zoom a + a{
  border-top:1px solid rgba(15,23,42,.1);
}
.ride-route-marker{
  display:grid;
  place-items:center;
}
.ride-route-marker__pin{
  width:32px;
  height:32px;
  display:grid;
  place-items:center;
  border-radius:50% 50% 50% 0;
  border:3px solid #fff;
  background:#f5c542;
  color:#0b1f33;
  box-shadow:0 12px 24px rgba(11,31,51,.26),0 0 0 4px rgba(247,181,0,.18);
  transform:rotate(-45deg);
}
.ride-route-marker__pin span{
  width:18px;
  height:18px;
  display:grid;
  place-items:center;
  border-radius:999px;
  background:#fff;
  color:#0b1f33;
  font-size:.78rem;
  font-weight:1000;
  line-height:1;
  transform:rotate(45deg);
}
.ride-route-marker--destination .ride-route-marker__pin{
  background:#12395A;
  box-shadow:0 12px 24px rgba(11,31,51,.26),0 0 0 4px rgba(18,57,90,.14);
}
.ride-route-marker--destination .ride-route-marker__pin span{
  color:#12395A;
}
.ride-map__frame{
  position:absolute;
  inset:0;
  z-index:0;
  width:100%;
  height:100%;
  border:0;
  background:#E7ECF4;
  filter:saturate(.92) contrast(.96);
}
.ride-map.is-live .ride-map__frame,
.ride-map.is-live .ride-map__overlay{
  display:none;
}
.ride-map__overlay{
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
}
.ride-map::before{
  content:"";
  position:absolute;
  inset:-12%;
  background:
    linear-gradient(25deg, transparent 0 46%, rgba(255,255,255,.68) 46.2% 46.8%, transparent 47% 100%),
    linear-gradient(92deg, transparent 0 52%, rgba(255,255,255,.6) 52.2% 52.8%, transparent 53% 100%),
    linear-gradient(156deg, transparent 0 38%, rgba(255,255,255,.62) 38.2% 38.8%, transparent 39% 100%);
  opacity:.9;
  z-index:-1;
}
.ride-map__park{
  position:absolute;
  background:#A8DEBA;
  border:1px solid rgba(255,255,255,.8);
}
.ride-map__park--one{
  right:-6%;
  bottom:-8%;
  width:46%;
  height:36%;
  transform:skew(-10deg) rotate(-7deg);
}
.ride-map__park--two{
  left:8%;
  top:7%;
  width:22%;
  height:18%;
  border-radius:8px;
  transform:rotate(14deg);
  opacity:.74;
}
.ride-map__road{
  position:absolute;
  display:block;
  border-radius:999px;
  background:#fff;
  box-shadow:0 0 0 1px rgba(148,163,184,.22);
}
.ride-map__road--a6{
  top:18%;
  left:-8%;
  width:70%;
  height:8px;
  transform:rotate(11deg);
  background:#91A7D8;
  box-shadow:0 0 0 2px rgba(255,255,255,.68);
}
.ride-map__road--m40{
  top:49%;
  right:-14%;
  width:74%;
  height:7px;
  transform:rotate(24deg);
  background:#9BAADB;
  box-shadow:0 0 0 2px rgba(255,255,255,.7);
}
.ride-map__road--local-one{
  top:61%;
  left:14%;
  width:58%;
  height:6px;
  transform:rotate(-12deg);
}
.ride-map__road--local-two{
  top:38%;
  left:26%;
  width:48%;
  height:5px;
  transform:rotate(34deg);
}
.ride-map__road--local-three{
  top:72%;
  left:36%;
  width:44%;
  height:5px;
  transform:rotate(10deg);
}
.ride-map__route-line{
  position:absolute;
  top:35%;
  left:28%;
  width:48%;
  height:6px;
  border-radius:999px;
  background:var(--amber);
  transform:rotate(23deg);
  box-shadow:0 0 0 3px rgba(255,255,255,.82),0 8px 18px rgba(15,23,42,.16);
}
.ride-map__badge{
  position:absolute;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:48px;
  min-height:28px;
  padding:0 10px;
  border-radius:6px;
  background:var(--navy-700);
  color:#fff;
  font-weight:800;
  font-size:.82rem;
  box-shadow:0 6px 14px rgba(15,23,42,.16);
}
.ride-map__badge--a6{
  top:13%;
  left:40%;
}
.ride-map__badge--m40{
  top:44%;
  right:23%;
}
.ride-map__label{
  position:absolute;
  color:#334155;
  font-weight:800;
  font-size:1.15rem;
  text-shadow:0 1px 0 rgba(255,255,255,.9);
}
.ride-map__label--madrid{
  right:16%;
  bottom:24%;
}
.ride-map__label--villalba{
  left:12%;
  bottom:38%;
}
.ride-map__label--rozas{
  left:38%;
  bottom:17%;
}
.ride-map__pin{
  position:absolute;
  display:inline-flex;
  align-items:center;
  gap:8px;
  max-width:220px;
  padding:8px 10px;
  border-radius:8px;
  background:#fff;
  color:var(--ink);
  font-weight:800;
  font-size:.82rem;
  box-shadow:0 14px 30px rgba(15,23,42,.18);
}
.ride-map__frame ~ .ride-map__overlay .ride-map__pin{
  box-shadow:0 14px 30px rgba(15,23,42,.22);
}
.ride-map__pin::before{
  content:"";
  width:10px;
  height:10px;
  flex:0 0 10px;
  border-radius:999px;
  background:#020617;
}
.ride-map__pin--origin{
  top:34%;
  left:28%;
}
.ride-map__pin--destination{
  top:54%;
  right:18%;
}
.ride-map__pin--destination::before{
  border-radius:2px;
  background:var(--amber);
}
.ride-map__pin span{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.ride-map__zoom{
  position:absolute;
  right:24px;
  bottom:24px;
  display:grid;
  overflow:hidden;
  width:58px;
  border-radius:8px;
  background:#fff;
  box-shadow:0 14px 30px rgba(15,23,42,.16);
}
.ride-map__zoom span{
  display:grid;
  place-items:center;
  height:52px;
  color:#020617;
  font-size:2rem;
  font-weight:700;
}
.ride-map__zoom span + span{
  border-top:1px solid rgba(15,23,42,.08);
}
.ride-map-tools{
  position:absolute;
  z-index:4;
  left:16px;
  top:16px;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  max-width:min(560px,calc(100% - 32px));
}
.ride-map-tool{
  min-height:40px;
  padding:8px 12px;
  border:1px solid rgba(15,23,42,.12);
  border-radius:8px;
  background:#fff;
  color:var(--ink);
  font-weight:800;
  cursor:pointer;
}
.ride-map-tool.is-active,
.ride-map-tool:hover{
  background:#020617;
  border-color:#020617;
  color:#fff;
}
.ride-map-status{
  position:absolute;
  z-index:4;
  left:16px;
  bottom:16px;
  max-width:min(560px,calc(100% - 112px));
  margin:0;
  padding:10px 12px;
  border-radius:8px;
  border:1px solid rgba(15,23,42,.08);
  background:#F8FAFC;
  color:var(--ink-soft);
  font-size:.9rem;
  box-shadow:0 18px 42px rgba(15,23,42,.14);
}
.ride-map-status[hidden]{display:none !important}
.ride-map-status--success{
  background:rgba(22,163,74,.09);
  border-color:rgba(22,163,74,.18);
  color:#166534;
}
.ride-map-status--warning{
  background:rgba(247,181,0,.12);
  border-color:rgba(247,181,0,.28);
  color:#854D0E;
}
.ride-map-panel__actions{
  display:none;
  gap:10px;
}
.section--reservation-inline{
  padding:42px 0;
}
.section--reservation-inline + .section--tight{
  padding-top:0;
}
.reservation-inline-content{
  scroll-margin-top:110px;
}
.reservation-inline-content > .section-heading{
  max-width:720px;
  margin-bottom:22px;
}
@media (max-width:640px){
  body.page--transactional .page-intro--booking-strip .page-intro__actions{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  body.page--transactional .form-shell--sidebar{
    padding:16px;
  }
  body.page--reservation .section--soft{
    padding:18px 0 88px;
  }
  .ride-booking-form.form-shell{
    padding:16px;
  }
  .ride-booking__title{
    font-size:1.4rem;
  }
  .ride-booking-field,
  .ride-booking-trigger{
    min-height:64px;
  }
  .ride-booking-field .field-inline-action{
    grid-template-columns:minmax(0,1fr) auto;
  }
  .ride-booking-field .field-action{
    width:auto;
    max-width:128px;
  }
  .ride-schedule-panel__fields{
    grid-template-columns:1fr;
  }
}
@media (max-width:1100px){
  body.page--reservation .form-layout--ride-booking{
    grid-template-columns:1fr;
  }
  .ride-map-panel{
    position:relative;
    top:auto;
    min-height:420px;
  }
  .ride-map{
    min-height:420px;
  }
  .ride-schedule-panel{
    position:static;
    margin-top:10px;
  }
}
@media (max-width:640px){
  .ride-map-panel{
    min-height:240px;
  }
  .ride-map{
    min-height:240px;
  }
  .ride-map__label,
  .ride-map__badge,
  .ride-map__pin{
    transform:scale(.86);
    transform-origin:center;
  }
  .ride-map__pin{
    max-width:150px;
  }
}
@media (max-width:700px){
  .form-layout.form-layout--ride-booking{
    gap:0;
  }
  .form-layout--ride-booking[data-mobile-ride-step="form"] .ride-map-panel{
    display:none;
  }
  .form-layout--ride-booking[data-mobile-ride-step="map"] .ride-booking-form{
    display:none;
  }
  .form-layout--ride-booking[data-mobile-ride-step="map"] .ride-map-panel{
    display:grid;
    min-height:calc(100dvh - 108px);
    border-radius:0;
  }
  .form-layout--ride-booking[data-mobile-ride-step="map"] .ride-map{
    min-height:calc(100dvh - 290px);
  }
  .ride-map-panel{
    padding:0;
    border:0;
    background:#fff;
  }
  .ride-map-panel__mobile-header{
    display:grid;
    grid-template-columns:auto minmax(0,1fr);
    align-items:start;
    gap:12px;
  }
  .ride-map-tools{
    position:static;
    max-width:none;
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    margin-top:10px;
  }
  .ride-map-status{
    position:static;
    max-width:none;
    margin-top:10px;
  }
  .ride-map-panel__actions{
    display:grid;
    grid-template-columns:1fr;
  }
  .ride-map-panel__actions .btn{
    width:100%;
  }
}
.page-intro .chip-link{background:rgba(255,255,255,.9)}
.card ul{padding-left:0;margin:0}
.muted{color:var(--ink-soft)}
.page-intro .media-panel img{aspect-ratio:16/10}
.summary-bullets{display:grid;gap:14px;margin-top:18px}
.summary-bullets li{list-style:none;display:flex;gap:12px;align-items:flex-start}
.summary-bullets .icon-svg{width:18px;height:18px;color:var(--navy-700);margin-top:3px}
.review-card[data-review]{height:100%}
.credits-list{display:grid;gap:16px}
.credits-item{padding:18px;border:1px solid var(--border);border-radius:18px;background:#fff}
.credits-item a{color:var(--navy-700);text-decoration:underline}
.map-caption{margin-top:14px;color:var(--ink-soft)}
.inline-icon{display:inline-flex;align-items:center;gap:8px}
.article-cta{margin:32px 0;padding:24px;border:1px solid var(--border);border-radius:20px;background:var(--surface-soft);display:grid;gap:16px}
.inline-stat{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:#fff;border:1px solid var(--border);font-weight:700}
.helper-card .btn,.sticky-card .btn{width:100%}


.credits-item code{
  display:inline-block;
  padding:3px 8px;
  border-radius:8px;
  background:var(--surface-soft);
  border:1px solid var(--border);
}
.article-meta{
  display:flex;
  flex-wrap:wrap;
}

.hero-home__lead p{margin:0 0 8px}
.hero-home__lead p:last-child{margin-bottom:0}
.hero-bullets{display:grid;gap:10px;margin-top:18px}
.hero-bullets li{display:flex;gap:10px;align-items:flex-start;color:#E2E8F0}
.hero-bullets .icon-svg{width:18px;height:18px;color:var(--amber);margin-top:4px}
.kpi-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.kpi-row .pill{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.12)}
.route-grid{display:grid;gap:22px;grid-template-columns:repeat(2,minmax(0,1fr))}
.notice-list{display:grid;gap:14px}
.notice-list li{display:flex;gap:12px;align-items:flex-start;color:var(--ink-soft)}
.notice-list .icon-svg{width:18px;height:18px;color:var(--navy-700);margin-top:4px}
.town-hero-note{margin-top:14px;color:var(--ink-soft)}
.stat-band{display:grid;gap:20px;grid-template-columns:repeat(3,minmax(0,1fr))}
.stat-band div{padding:18px;border-radius:18px;background:var(--surface-soft);border:1px solid var(--border)}
.stat-band strong{display:block;font-size:1.35rem;color:var(--navy);margin-bottom:6px}
.article-summary{display:grid;gap:12px;margin-top:18px}
.article-summary li{display:flex;gap:12px;align-items:flex-start;color:var(--ink-soft)}
.article-summary .icon-svg{width:18px;height:18px;color:var(--navy-700);margin-top:4px}
.service-hero-card{display:grid;gap:14px;background:#fff;border:1px solid var(--border);border-radius:24px;padding:24px;box-shadow:var(--shadow-sm);color:var(--ink)}
.service-hero-card h3{margin:0;font-size:1.12rem;color:var(--ink)}
.service-hero-card p{margin:0;color:var(--ink-soft)}
.service-hero-card .btn{width:100%}
.review-grid{display:grid;gap:22px;grid-template-columns:repeat(3,minmax(0,1fr))}
.municipality-card .chip-list{margin-top:14px}
.municipality-card p:last-child{margin-bottom:0}
.page-intro--dark{background:linear-gradient(135deg,var(--navy) 0%, var(--navy-700) 100%);color:#fff}
.page-intro--dark p{color:#E2E8F0}
.page-intro--dark .pill{background:rgba(255,255,255,.12);color:#fff}
.page-intro--dark .chip{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.18)}
.page-intro--dark .btn--secondary{border-color:#fff;color:#fff;background:transparent}
.page-intro--dark .btn--secondary:hover{background:rgba(255,255,255,.12)}
.page-intro--dark .helper-card{
  background:rgba(255,255,255,.97);
  border-color:rgba(255,255,255,.2);
  box-shadow:var(--shadow-sm);
}
.hero-split{display:grid;gap:24px;grid-template-columns:minmax(0,1.1fr) minmax(300px,.9fr);align-items:center}
.info-list{display:grid;gap:14px}
.info-list li{display:flex;gap:12px;align-items:flex-start;color:var(--ink-soft)}
.info-list .icon-svg{width:18px;height:18px;color:var(--navy-700);margin-top:4px}
.placeholder-note{display:none}
@media (max-width: 900px){.route-grid,.review-grid,.stat-band,.hero-split{grid-template-columns:1fr}}
@media (min-width: 641px) and (max-width: 900px){.route-grid,.review-grid,.stat-band{grid-template-columns:repeat(2,minmax(0,1fr))}}


/* Overrides finales: fondos fotográficos integrados y mejor contraste */
.hero-home--photo{
  background:
    linear-gradient(100deg, rgba(11,31,51,.94) 0%, rgba(11,31,51,.88) 40%, rgba(11,31,51,.78) 62%, rgba(11,31,51,.66) 100%),
    radial-gradient(circle at top right, rgba(247,181,0,.18), transparent 34%),
    url('../images/home-hero-800.webp') center/cover no-repeat;
}
@media (min-width: 901px){
  .hero-home--photo{
    background:
      linear-gradient(100deg, rgba(11,31,51,.94) 0%, rgba(11,31,51,.88) 40%, rgba(11,31,51,.78) 62%, rgba(11,31,51,.66) 100%),
      radial-gradient(circle at top right, rgba(247,181,0,.18), transparent 34%),
      url('../images/home-hero-1200.webp') center/cover no-repeat;
  }
}
@media (min-width: 1440px){
  .hero-home--photo{
    background:
      linear-gradient(100deg, rgba(11,31,51,.94) 0%, rgba(11,31,51,.88) 40%, rgba(11,31,51,.78) 62%, rgba(11,31,51,.66) 100%),
      radial-gradient(circle at top right, rgba(247,181,0,.18), transparent 34%),
      url('../images/home-hero.webp') center/cover no-repeat;
  }
}
.hero-home--photo .hero-home__grid{
  align-items:start;
}
.hero-home--photo .hero-home__lead{margin-top:30px}
.hero-home--photo .hero-quick{
  margin-top:0;
  transform:translateY(-16px);
}
.hero-home--photo .hero-bullets span:last-child{color:#E2E8F0}
@media (max-width: 900px){
  .hero-home--photo .hero-home__grid{align-items:center}
  .hero-home--photo .hero-home__lead{margin-top:24px}
  .hero-home--photo .hero-quick{transform:none}
}
@media (max-width: 640px){
  .hero-home__content{
    display:contents;
  }
  .hero-home__aside{
    order:1;
    width:100%;
    margin-top:0;
    margin-bottom:22px;
  }
  .hero-home__content .hero-badge{order:2}
  .hero-home__content h1{order:3}
  .hero-home__content .hero-home__lead{
    order:4;
    margin-top:22px;
  }
  .hero-home__content .chip-list{order:5}
  .hero-home__content .hero-bullets{order:6}
  .hero-home__content .hero-home__actions{order:7}
  .hero-home--photo .hero-quick{
    margin-top:0;
  }
}
.page-intro--cover,
.page-intro--photo{
  position:relative;
  overflow:hidden;
  color:#fff;
}
.page-intro--cover{
  background:
    linear-gradient(102deg, rgba(11,31,51,.94) 0%, rgba(11,31,51,.86) 46%, rgba(11,31,51,.74) 100%),
    var(--hero-bg) center/cover no-repeat;
  padding:60px 0 68px;
}
.page-intro--photo{
  background:
    linear-gradient(104deg, rgba(11,31,51,.94) 0%, rgba(11,31,51,.88) 38%, rgba(11,31,51,.74) 100%),
    var(--hero-bg) center/cover no-repeat;
}
.page-intro--cover .eyebrow,
.page-intro--photo .eyebrow{color:#DCE8F4}
.page-intro--cover p,
.page-intro--photo p{color:#E2E8F0}
.page-intro--cover .chip,
.page-intro--photo .chip{
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.18);
  color:#fff;
}
.page-intro--cover .btn--secondary,
.page-intro--photo .btn--secondary{
  background:transparent;
  border-color:rgba(255,255,255,.5);
  color:#fff;
}
.page-intro--cover .btn--secondary:hover,
.page-intro--photo .btn--secondary:hover{background:rgba(255,255,255,.12)}
.page-intro--cover .btn--primary,
.page-intro--photo .btn--primary{box-shadow:0 14px 30px rgba(247,181,0,.25)}
.page-intro__grid--single{
  grid-template-columns:minmax(0,1fr);
  max-width:880px;
}
.page-intro__grid--single h1{max-width:14ch}
.page-intro--coverage .page-intro__grid--single,
.page-intro--services .page-intro__grid--single,
.page-intro--companies .page-intro__grid--single,
.page-intro--about .page-intro__grid--single,
.page-intro--credits .page-intro__grid--single{max-width:960px}
.page-intro--coverage .page-intro__grid--single h1,
.page-intro--services .page-intro__grid--single h1,
.page-intro--companies .page-intro__grid--single h1,
.page-intro--about .page-intro__grid--single h1,
.page-intro--credits .page-intro__grid--single h1{max-width:16ch}
.page-intro--photo .service-hero-card{
  background:rgba(255,255,255,.98);
  border-color:rgba(11,31,51,.08);
  color:var(--ink);
}
.page-intro--photo .service-hero-card h3,
.page-intro--photo .service-hero-card li,
.page-intro--photo .service-hero-card span:last-child{color:var(--ink)}
.page-intro--photo .service-hero-card .card-icon{
  background:rgba(22,59,92,.08);
  color:var(--navy-700);
}
.page-intro--photo .service-hero-card .btn--primary{width:100%}
.two-col--single{grid-template-columns:minmax(0,1fr)}
.two-col--single .band{max-width:960px}
.credits-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px}
.credits-list .card p:last-child{margin-bottom:0}
.footer-copy{max-width:48ch}
@media (max-width:900px){
  .credits-list{grid-template-columns:1fr}
  .page-intro--cover,
  .page-intro--photo{padding:52px 0 60px}
  .page-intro__grid--single h1,
  .page-intro--coverage .page-intro__grid--single h1,
  .page-intro--services .page-intro__grid--single h1,
  .page-intro--companies .page-intro__grid--single h1,
  .page-intro--about .page-intro__grid--single h1,
  .page-intro--credits .page-intro__grid--single h1{max-width:none}
}


.page-404--photo{
  position:relative;
  overflow:hidden;
  color:#fff;
  background:
    linear-gradient(104deg, rgba(11,31,51,.94) 0%, rgba(11,31,51,.86) 44%, rgba(11,31,51,.72) 100%),
    var(--hero-bg) center/cover no-repeat;
}
.page-404--photo .center-message p{color:#E2E8F0}
.page-404--photo .summary-panel{background:rgba(255,255,255,.98)}
.page-404--photo .btn--secondary{
  background:transparent;
  border-color:rgba(255,255,255,.5);
  color:#fff;
}
.page-404--photo .btn--secondary:hover{background:rgba(255,255,255,.12)}
@media (max-width:640px){
  .option-card{
    padding:11px 12px;
    align-items:center;
  }
  .option-card__icon{
    width:28px;
    height:28px;
    flex-basis:28px;
  }
  .option-card > span:last-child span:last-child{display:none}
  .status-pill{
    width:100%;
    justify-content:center;
  }
}

.ai-webchat{
  position:fixed;
  right:20px;
  bottom:20px;
  z-index:1200;
  display:grid;
  justify-items:end;
  gap:10px;
  font-size:15px;
}
.ai-webchat__toggle{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:48px;
  padding:0 16px;
  border:2px solid var(--amber);
  border-radius:8px;
  background:var(--navy);
  color:#fff;
  box-shadow:0 16px 36px rgba(11,31,51,.22),0 0 0 1px rgba(247,181,0,.18);
  font-weight:800;
}
.ai-webchat__toggle .icon-svg{width:20px;height:20px;color:var(--amber)}
.ai-webchat__panel{
  width:min(390px,calc(100vw - 32px));
  max-height:min(650px,calc(100vh - 120px));
  display:grid;
  grid-template-rows:auto minmax(180px,1fr) auto auto auto auto;
  overflow:hidden;
  border:1px solid var(--border);
  border-radius:8px;
  background:#fff;
  box-shadow:0 24px 60px rgba(11,31,51,.2);
}
.ai-webchat__header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:14px 14px 12px;
  border-bottom:1px solid var(--border);
}
.ai-webchat__header strong{
  display:block;
  color:var(--ink);
  font-size:1rem;
  letter-spacing:0;
}
.ai-webchat__header span{
  display:block;
  color:var(--ink-soft);
  font-size:.82rem;
  line-height:1.3;
}
.ai-webchat__icon-button{
  width:34px;
  height:34px;
  border:1px solid var(--border);
  border-radius:8px;
  background:var(--surface-soft);
  color:var(--ink);
  font-weight:800;
  line-height:1;
}
.ai-webchat__log{
  min-height:220px;
  overflow:auto;
  padding:14px;
  display:grid;
  align-content:start;
  gap:10px;
  background:linear-gradient(180deg,#fff 0%,var(--surface-soft) 100%);
}
.ai-webchat__message{
  max-width:88%;
  padding:10px 12px;
  border-radius:8px;
  line-height:1.45;
  white-space:pre-wrap;
  overflow-wrap:anywhere;
}
.ai-webchat__message--assistant{
  justify-self:start;
  background:#fff;
  border:1px solid var(--border);
  color:var(--ink);
}
.ai-webchat__message--user{
  justify-self:end;
  background:var(--navy);
  color:#fff;
}
.ai-webchat__chips{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  padding:10px 14px 0;
  background:#fff;
}
.ai-webchat__chip{
  border:1px solid var(--border);
  border-radius:8px;
  background:var(--surface-soft);
  color:var(--ink);
  padding:7px 9px;
  font-size:.84rem;
  font-weight:700;
}
.ai-webchat__quote{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:10px;
  margin:10px 14px 0;
  padding:12px;
  border:1px solid var(--border);
  border-radius:8px;
  background:#fff;
}
.ai-webchat__quote[hidden]{display:none}
.ai-webchat__quote label{
  display:grid;
  gap:5px;
  color:var(--ink);
  font-size:.82rem;
  font-weight:800;
}
.ai-webchat__quote label:nth-child(1),
.ai-webchat__quote label:nth-child(2){
  grid-column:1 / -1;
}
.ai-webchat__quote input,
.ai-webchat__quote select{
  width:100%;
  min-height:38px;
  border:1px solid var(--border-strong);
  border-radius:8px;
  padding:8px 10px;
  color:var(--ink);
  font:inherit;
}
.ai-webchat__quote button{align-self:end}
.ai-webchat__quote-stops{
  grid-column:1 / -1;
  margin:0;
  padding:9px 10px;
  border:1px solid rgba(11,31,51,.08);
  border-radius:8px;
  background:#F6FAFD;
  color:var(--ink-soft);
  font-size:.8rem;
  font-weight:700;
  line-height:1.35;
}
.ai-webchat__quote-stops[hidden]{display:none}
.ai-webchat__verify{
  margin:10px 14px 0;
  padding:12px;
  border:1px solid rgba(247,181,0,.45);
  border-radius:8px;
  background:rgba(247,181,0,.1);
}
.ai-webchat__verify p{
  margin:0 0 10px;
  color:var(--ink);
  line-height:1.45;
}
.ai-webchat__verify-actions{
  display:grid;
  grid-template-columns:auto minmax(90px,1fr) auto;
  gap:8px;
  align-items:center;
}
.ai-webchat__verify input{
  width:100%;
  min-height:38px;
  border:1px solid var(--border-strong);
  border-radius:8px;
  padding:8px 10px;
}
.ai-webchat__verify-status{
  margin:8px 0 0 !important;
  font-size:.85rem;
  color:var(--ink-soft) !important;
}
.ai-webchat__verify-status--success{color:#166534 !important}
.ai-webchat__verify-status--error{color:#991B1B !important}
.ai-webchat__form{
  display:grid;
  grid-template-columns:minmax(0,1fr) 42px;
  gap:8px;
  padding:12px 14px 14px;
  background:#fff;
}
.ai-webchat__form textarea{
  resize:none;
  min-height:42px;
  max-height:120px;
  border:1px solid var(--border-strong);
  border-radius:8px;
  padding:10px 12px;
  line-height:1.35;
}
.ai-webchat__send{
  width:42px;
  height:42px;
  display:grid;
  place-items:center;
  border:0;
  border-radius:8px;
  background:var(--amber);
  color:var(--navy);
}
.ai-webchat__send .icon-svg{width:20px;height:20px}
.ai-webchat.is-loading .ai-webchat__send{opacity:.7}
@media (max-width:640px){
  .ai-webchat{
    right:12px;
    bottom:96px;
  }
  body.no-mobile-action-bar .ai-webchat,
  body.page--legal .ai-webchat,
  body.page--transactional .ai-webchat,
  body.chat-open .ai-webchat{
    bottom:12px;
  }
  body.is-form-focused .ai-webchat:not(.is-open){
    display:none;
  }
  .ai-webchat__panel{
    width:calc(100vw - 24px);
    max-height:calc(100vh - 110px);
  }
  .ai-webchat__verify-actions{grid-template-columns:1fr}
  .ai-webchat__quote{grid-template-columns:1fr}
  .ai-webchat__toggle{min-height:44px}
}

.form-status--success{
  background:#ECFDF3;
  color:#067647;
  border-color:#ABEFC6;
}
.tracker-action-status{
  margin-top:10px;
}
.tracker-actions .tracker-action--danger{
  color:#B42318;
  border-color:#FDA29B;
  background:#fff;
}
.tracker-map__canvas{
  transition:transform .28s ease,filter .28s ease;
}
.tracker-map.is-recentering .tracker-map__canvas{
  transform:scale(1.015);
}
.reservation-tracker.is-state-changing .tracker-status-card,
.reservation-tracker.is-state-changing .tracker-driver-card,
.reservation-tracker.is-state-changing .tracker-action-card,
.reservation-tracker.is-state-changing .tracker-notification-card,
.reservation-tracker.is-state-changing .tracker-rating-card,
.reservation-tracker.is-state-changing .tracker-receipt-card,
.reservation-tracker.is-state-changing .tracker-preferences-card,
.reservation-tracker.is-state-changing .tracker-saved-card,
.reservation-tracker.is-state-changing .tracker-history-card,
.reservation-tracker.is-state-changing .tracker-chat-card{
  animation:trackerStateIn .34s ease both;
}
.reservation-tracker.is-state-changing .tracker-marker--taxi{
  animation:trackerTaxiNudge .45s ease both;
}
@keyframes trackerStateIn{
  from{opacity:.78;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes trackerTaxiNudge{
  0%{filter:drop-shadow(0 0 0 rgba(247,181,0,0))}
  60%{filter:drop-shadow(0 0 12px rgba(247,181,0,.55))}
  100%{filter:drop-shadow(0 0 0 rgba(247,181,0,0))}
}
@media (prefers-reduced-motion: reduce){
  .tracker-map__search-pulse,
  .reservation-tracker.is-state-changing .tracker-status-card,
  .reservation-tracker.is-state-changing .tracker-driver-card,
  .reservation-tracker.is-state-changing .tracker-action-card,
  .reservation-tracker.is-state-changing .tracker-notification-card,
  .reservation-tracker.is-state-changing .tracker-rating-card,
  .reservation-tracker.is-state-changing .tracker-receipt-card,
  .reservation-tracker.is-state-changing .tracker-preferences-card,
  .reservation-tracker.is-state-changing .tracker-saved-card,
  .reservation-tracker.is-state-changing .tracker-history-card,
  .reservation-tracker.is-state-changing .tracker-chat-card,
  .reservation-tracker.is-state-changing .tracker-marker--taxi,
  .tracker-notification-card.is-updated{
    animation:none !important;
  }
}
.reservation-tracker--simple{
  display:flex;
  justify-content:center;
}
.reservation-tracker--simple .tracker-shell{
  width:min(100%,760px);
  grid-template-columns:1fr;
  min-height:auto;
}
.reservation-tracker--simple .tracker-driver-card,
.reservation-tracker--simple .tracker-map-panel{
  display:none;
}
@media (max-width:1180px){
  .reservation-tracker{
    padding:14px;
    min-height:auto;
  }
  .tracker-shell{
    grid-template-columns:1fr;
    min-height:0;
  }
  .tracker-map-panel{
    order:-1;
    min-height:52dvh;
  }
  .tracker-panel{
    max-width:none;
  }
  .tracker-status-card{
    order:1;
  }
  .tracker-action-card{
    order:2;
  }
  .tracker-notification-card{
    order:3;
  }
  .tracker-driver-card{
    order:4;
  }
  .tracker-rating-card,
  .tracker-receipt-card{
    order:5;
  }
  .tracker-route-card{
    order:6;
  }
  .tracker-tools-card{
    order:7;
  }
  .tracker-preferences-card{
    order:7;
  }
  .tracker-saved-card{
    order:8;
  }
  .tracker-history-card{
    order:9;
  }
  .tracker-chat-card{
    order:10;
  }
  .tracker-details-card,
  .confirmation-empty{
    order:11;
  }
}
@media (min-width:900px) and (max-width:1180px) and (orientation:landscape){
  .tracker-shell{
    grid-template-columns:minmax(360px,420px) minmax(0,1fr);
  }
  .tracker-map-panel{
    order:0;
    min-height:calc(100dvh - 96px);
  }
}
@media (max-width:720px){
  body.page--thanks{
    background:#fff;
  }
  body.page--thanks .site-header-inner{
    min-height:60px;
  }
  body.page--thanks .logo-copy small{
    display:none;
  }
  body.page--thanks .site-nav--tracking{
    display:none;
  }
  .reservation-tracker{
    min-height:calc(100dvh - 60px);
    padding:0;
    background:#E8EEF3;
  }
  .tracker-shell{
    display:flex;
    flex-direction:column;
    gap:0;
    min-height:calc(100dvh - 60px);
  }
  .tracker-map-panel{
    order:0;
    height:44dvh;
    min-height:300px;
    border-radius:0;
    box-shadow:none;
  }
  .tracker-panel{
    position:relative;
    z-index:5;
    order:1;
    gap:10px;
    margin-top:-18px;
    padding:0 12px 16px;
  }
  .tracker-panel::before{
    content:"";
    position:absolute;
    top:12px;
    left:50%;
    width:44px;
    height:4px;
    border-radius:999px;
    background:rgba(11,31,51,.2);
    transform:translateX(-50%);
    z-index:2;
  }
  .tracker-status-card{
    order:1;
  }
  .tracker-action-card{
    order:2;
  }
  .tracker-notification-card{
    order:3;
  }
  .tracker-driver-card{
    order:4;
  }
  .tracker-rating-card,
  .tracker-receipt-card{
    order:5;
  }
  .tracker-route-card{
    order:6;
  }
  .tracker-tools-card{
    order:7;
  }
  .tracker-preferences-card{
    order:7;
  }
  .tracker-saved-card{
    order:8;
  }
  .tracker-history-card{
    order:9;
  }
  .tracker-chat-card{
    order:10;
  }
  .tracker-details-card,
  .confirmation-empty{
    order:11;
  }
  .tracker-status-card{
    padding:28px 18px 18px;
    border-radius:24px 24px 18px 18px;
  }
  .tracker-status-card h1{
    font-size:1.78rem;
    line-height:1.08;
  }
  .tracker-status-card p{
    font-size:.97rem;
  }
  .tracker-status-meta{
    gap:6px;
    font-size:.82rem;
  }
  .tracker-status-meta [data-live-updated],
  .tracker-status-meta [data-confirmation-reference]{
    min-height:32px;
    padding:6px 9px;
  }
  .tracker-driver-card{
    grid-template-columns:52px minmax(0,1fr);
    gap:12px;
    padding:14px;
    border-radius:18px;
  }
  .tracker-driver-avatar{
    width:52px;
    height:52px;
  }
  .tracker-vehicle-list div{
    grid-template-columns:82px minmax(0,1fr);
  }
  .tracker-action-card,
  .tracker-notification-card,
  .tracker-rating-card,
  .tracker-receipt-card,
  .tracker-route-card,
  .tracker-preferences-card,
  .tracker-saved-card,
  .tracker-history-card,
  .tracker-chat-card,
  .tracker-tools-card{
    padding:16px;
    border-radius:18px;
  }
  .tracker-tools-card summary{
    margin:-16px;
    padding:15px 16px;
  }
  .tracker-notification-card{
    grid-template-columns:1fr;
  }
  .tracker-notification-modal{
    align-items:end;
    padding:12px;
  }
  .tracker-notification-modal__panel{
    width:100%;
    border-radius:18px;
    padding:22px 18px 18px;
  }
  .tracker-modal{
    align-items:end;
    padding:12px;
  }
  .tracker-modal__panel{
    width:100%;
    max-height:84dvh;
    border-radius:18px;
    padding:22px 18px 18px;
  }
  .tracker-notification-modal__actions{
    grid-template-columns:1fr;
  }
  .tracker-receipt-row{
    grid-template-columns:94px minmax(0,1fr);
  }
  .tracker-actions{
    grid-template-columns:1fr 1fr;
    gap:8px;
  }
  .tracker-actions .btn,
  .tracker-map__controls .btn,
  .tracker-map__topbar .btn{
    width:auto;
    min-width:0;
    min-height:46px;
    padding-inline:12px;
    white-space:normal;
    text-align:center;
    line-height:1.1;
  }
  .tracker-actions .tracker-action--wide{
    grid-column:1 / -1;
    width:100%;
  }
  .tracker-map__topbar{
    top:10px;
    right:10px;
    left:10px;
    display:grid;
    grid-template-columns:minmax(0,1fr) auto;
    gap:8px;
    align-items:start;
  }
  .tracker-map__topbar span{
    min-height:34px;
    max-width:none;
    padding:7px 10px;
    font-size:.74rem;
    line-height:1.18;
    overflow:hidden;
    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
  }
  .tracker-map__controls{
    right:10px;
    bottom:52px;
    left:auto;
    gap:8px;
  }
  .tracker-map-tools{
    left:10px;
    right:10px;
    bottom:12px;
    display:grid;
    grid-template-columns:minmax(0,1fr) auto;
    gap:8px;
  }
  .tracker-map[data-map-phase="waiting"] .tracker-map__controls,
  .tracker-map[data-map-phase="waiting"] .tracker-map-tools,
  .tracker-map[data-map-phase="waiting"] .tracker-map__topbar{
    display:none;
  }
  .tracker-map-panel.has-real-map .tracker-map__topbar{
    display:none;
  }
  .tracker-map-segments{
    min-width:0;
  }
  .tracker-map-segments button{
    flex:1 1 0;
    min-height:34px;
    padding-inline:6px;
    font-size:.72rem;
  }
  .tracker-map-toggle{
    min-height:34px;
    padding:6px 9px;
    font-size:.72rem;
    white-space:nowrap;
  }
  .tracker-marker span{
    max-width:42vw;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
    font-size:.7rem;
    padding:5px 7px;
  }
  .tracker-marker--taxi{
    width:38px;
    height:44px;
  }
  .tracker-details-card{
    border-radius:18px;
  }
}
@media (max-width:420px){
  .tracker-map-panel{
    min-height:290px;
  }
  .tracker-actions{
    grid-template-columns:1fr;
  }
  .tracker-save-actions,
  .tracker-chat-form{
    grid-template-columns:1fr;
  }
  .tracker-actions .btn{
    width:100%;
  }
  .tracker-map-segments{
    flex-basis:auto;
  }
  .tracker-map-toggle{
    min-height:38px;
  }
  .tracker-status-card h1{
    font-size:1.58rem;
  }
  .tracker-map__topbar{
    grid-template-columns:minmax(0,1fr) auto;
  }
  .tracker-map__topbar span{
    max-width:none;
    flex:initial;
  }
  .tracker-map__topbar .btn{
    min-height:34px;
    padding-inline:10px;
    font-size:.74rem;
  }
  .tracker-map__controls .btn{
    min-height:36px;
    padding-inline:10px;
    font-size:.74rem;
  }
}

/* Taxi Conectado SaaS surface */
.saas-page{
  background:#F5F7FA;
  color:#142033;
}
.saas-header{
  position:sticky;
  top:0;
  z-index:1000;
  background:rgba(255,255,255,.94);
  border-bottom:1px solid rgba(20,32,51,.1);
  backdrop-filter:blur(14px);
}
.saas-header__inner{
  min-height:72px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}
.saas-logo{
  display:inline-flex;
  align-items:center;
  gap:12px;
  min-width:0;
}
.saas-logo__mark{
  width:42px;
  height:42px;
  display:grid;
  place-items:center;
  border-radius:8px;
  background:#0B1F33;
  color:#F7B500;
  font-weight:900;
  letter-spacing:0;
}
.saas-logo strong{
  display:block;
  line-height:1;
  color:#0B1F33;
}
.saas-logo small{
  display:block;
  margin-top:3px;
  color:#607085;
  font-size:.82rem;
}
.saas-nav{
  display:flex;
  align-items:center;
  gap:8px;
}
.saas-nav a{
  min-height:42px;
  display:inline-flex;
  align-items:center;
  padding:0 12px;
  border-radius:8px;
  color:#46566B;
  font-weight:800;
}
.saas-nav a:hover{
  background:#EEF3F7;
  color:#0B1F33;
}
.saas-hero{
  min-height:calc(100vh - 144px);
  display:grid;
  align-items:end;
  padding:72px 0 64px;
  color:#fff;
  background:
    linear-gradient(98deg, rgba(8,19,32,.94) 0%, rgba(8,19,32,.88) 44%, rgba(8,19,32,.58) 100%),
    url("../images/home-hero-1200.webp") center/cover no-repeat;
}
.saas-hero__content{
  display:grid;
  align-content:end;
  gap:22px;
  max-width:920px;
}
.saas-eyebrow{
  margin:0;
  color:#F7B500;
  font-size:.82rem;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.saas-hero h1,
.saas-page-hero h1{
  margin:0;
  letter-spacing:0;
}
.saas-hero h1{
  font-size:clamp(3rem,7vw,6.8rem);
  line-height:.94;
}
.saas-hero p:not(.saas-eyebrow),
.saas-page-hero p:not(.saas-eyebrow){
  max-width:760px;
  margin:0;
  color:#E6EDF3;
  font-size:1.16rem;
  line-height:1.75;
}
.saas-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:6px;
}
.saas-hero__metrics{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:18px;
}
.saas-hero__metrics span{
  min-height:44px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:0 14px;
  border:1px solid rgba(255,255,255,.22);
  border-radius:8px;
  background:rgba(255,255,255,.1);
  color:#E6EDF3;
  font-weight:800;
}
.saas-hero__metrics strong{
  color:#fff;
}
.saas-page-hero{
  padding:80px 0 64px;
  background:#0B1F33;
  color:#fff;
}
.saas-page-hero h1{
  max-width:760px;
  margin-top:10px;
  font-size:clamp(2.2rem,4vw,4.2rem);
}
.saas-page-hero--diagnostic{
  padding-bottom:72px;
}
.saas-section-grid{
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(360px,1.1fr);
  gap:36px;
  align-items:start;
}
.saas-feature-list{
  display:grid;
  gap:12px;
}
.saas-feature-list article,
.saas-card,
.saas-price-box,
.saas-form{
  border:1px solid rgba(20,32,51,.1);
  border-radius:8px;
  background:#fff;
  box-shadow:0 14px 34px rgba(20,32,51,.06);
}
.saas-feature-list article{
  padding:18px;
}
.saas-feature-list article.saas-card--highlight{
  border-color:rgba(46,107,87,.35);
  background:#F4FBF7;
}
.saas-feature-list strong,
.saas-card strong{
  display:block;
  margin-bottom:6px;
  color:#0B1F33;
  font-size:1.04rem;
}
.saas-feature-list span,
.saas-card span{
  color:#607085;
  line-height:1.6;
}
.saas-console-wrap{
  display:grid;
  gap:22px;
}
.saas-console{
  overflow:hidden;
  border:1px solid rgba(20,32,51,.12);
  border-radius:8px;
  background:#101C2A;
  color:#E6EDF3;
  box-shadow:0 22px 54px rgba(20,32,51,.18);
}
.saas-console__bar{
  min-height:46px;
  display:flex;
  align-items:center;
  gap:8px;
  padding:0 16px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.saas-console__bar span{
  width:10px;
  height:10px;
  border-radius:999px;
  background:#6C7787;
}
.saas-console__bar span:first-child{background:#F87171}
.saas-console__bar span:nth-child(2){background:#FBBF24}
.saas-console__bar span:nth-child(3){background:#34D399}
.saas-console__bar strong{
  margin-left:8px;
  font-size:.92rem;
}
.saas-console__grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:1px;
  background:rgba(255,255,255,.08);
}
.saas-console__metric{
  padding:22px;
  background:#14263A;
}
.saas-console__metric span{
  display:block;
  color:#9FB1C4;
  font-size:.86rem;
}
.saas-console__metric strong{
  display:block;
  margin-top:8px;
  color:#fff;
  font-size:1.7rem;
}
.saas-console__rows{
  display:grid;
  gap:1px;
  background:rgba(255,255,255,.08);
}
.saas-console__rows span{
  display:flex;
  justify-content:space-between;
  gap:16px;
  padding:16px 20px;
  background:#101C2A;
}
.saas-console__rows em{
  color:#F7B500;
  font-style:normal;
  font-weight:900;
}
.saas-card-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
}
.saas-card{
  padding:20px;
}
.saas-card--link{
  display:block;
  transition:transform .16s ease, border-color .16s ease;
}
.saas-card--link:hover{
  transform:translateY(-2px);
  border-color:#0B1F33;
}
.saas-cta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:28px 32px;
  border:1px solid rgba(20,32,51,.1);
  border-radius:8px;
  background:#fff;
}
.saas-cta p{
  max-width:720px;
  color:#607085;
}
.saas-footer{
  padding:26px 0;
  background:#0B1F33;
  color:#DDE7F0;
}
.saas-footer__inner{
  display:flex;
  justify-content:space-between;
  gap:20px;
}
.saas-footer nav{
  display:flex;
  gap:16px;
}
.saas-pricing-layout{
  display:grid;
  grid-template-columns:minmax(280px,420px) minmax(0,1fr);
  gap:24px;
  align-items:start;
}
.saas-diagnostic-layout{
  display:grid;
  grid-template-columns:minmax(320px,1.05fr) minmax(300px,.95fr);
  gap:24px;
  align-items:start;
}
.saas-activation-layout{
  display:grid;
  grid-template-columns:minmax(280px,420px) minmax(0,1fr);
  gap:24px;
  align-items:start;
}
.saas-onboarding-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(280px,360px);
  gap:24px;
  align-items:start;
}
.saas-onboarding-summary{
  position:sticky;
  top:96px;
  display:grid;
  gap:16px;
  padding:28px;
  border:1px solid rgba(20,32,51,.1);
  border-radius:8px;
  background:#fff;
  box-shadow:0 14px 34px rgba(20,32,51,.06);
}
.saas-onboarding-summary h2{
  margin:0;
  color:#0B1F33;
  font-size:1.7rem;
  letter-spacing:0;
}
.saas-public-flow{
  display:grid;
  gap:8px;
}
.saas-public-flow article{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  gap:2px 10px;
  padding:10px;
  border:1px solid rgba(20,32,51,.1);
  border-radius:8px;
  background:#F6FAFD;
}
.saas-public-flow article span{
  width:26px;
  height:26px;
  display:grid;
  place-items:center;
  grid-row:1 / span 2;
  border-radius:999px;
  background:#0B1F33;
  color:#fff;
  font-size:.78rem;
  font-weight:900;
}
.saas-public-flow article strong{
  min-width:0;
  color:#0B1F33;
  font-size:.9rem;
}
.saas-public-flow article p{
  margin:0;
  color:#607085;
  font-size:.84rem;
  line-height:1.35;
}
.saas-price-box{
  padding:28px;
}
.saas-activation-panel{
  padding:28px;
  border:1px solid rgba(20,32,51,.1);
  border-radius:8px;
  background:#fff;
  box-shadow:0 14px 34px rgba(20,32,51,.06);
}
.saas-activation-panel h2{
  margin:8px 0 12px;
  color:#0B1F33;
}
.saas-activation-panel p{
  color:#607085;
  line-height:1.6;
}
.saas-activation-total{
  display:grid;
  gap:4px;
  margin-top:18px;
  padding:16px;
  border-radius:8px;
  background:#F6FAFD;
  color:#26364A;
}
.saas-activation-total strong{
  color:#0B1F33;
  font-size:1.6rem;
}
.saas-price-box h2{
  margin:8px 0 12px;
  font-size:3.2rem;
}
.saas-price-box h2 span{
  color:#607085;
  font-size:1rem;
}
.saas-price-box small{
  display:block;
  margin-top:14px;
  color:#607085;
  line-height:1.5;
}
.saas-checkout{
  display:grid;
  gap:10px;
  margin-top:18px;
}
.saas-checkout label{
  display:grid;
  gap:5px;
  color:#26364A;
  font-size:.9rem;
  font-weight:800;
}
.saas-checkout input{
  width:100%;
  border:1px solid #C9D4E2;
  border-radius:8px;
  padding:10px 11px;
  color:#142033;
}
.saas-checkout + .btn{
  margin-top:10px;
}
.saas-form{
  display:grid;
  gap:14px;
  padding:24px;
}
.saas-onboarding-form{
  gap:18px;
}
.saas-onboarding-stepper{
  display:grid;
  grid-template-columns:repeat(6,minmax(112px,1fr));
  gap:8px;
  margin-bottom:4px;
}
.saas-onboarding-stepper button{
  min-width:0;
  min-height:92px;
  display:grid;
  grid-template-columns:1fr;
  align-items:center;
  justify-items:center;
  align-content:center;
  gap:5px;
  padding:10px;
  border:1px solid #C9D4E2;
  border-radius:8px;
  background:#fff;
  color:#26364A;
  text-align:center;
}
.saas-onboarding-stepper button span{
  width:26px;
  height:26px;
  display:grid;
  place-items:center;
  border-radius:999px;
  background:#F6FAFD;
  color:#0B1F33;
  font-size:.82rem;
  font-weight:900;
}
.saas-onboarding-stepper button strong,
.saas-onboarding-stepper button em{
  min-width:0;
  overflow:visible;
  overflow-wrap:anywhere;
  text-overflow:clip;
  white-space:normal;
  line-height:1.18;
}
.saas-onboarding-stepper button strong{
  color:#0B1F33;
  font-size:.88rem;
}
.saas-onboarding-stepper button em{
  color:#607085;
  font-size:.72rem;
  font-style:normal;
  font-weight:800;
}
.saas-onboarding-stepper button.is-active{
  border-color:#0B1F33;
  box-shadow:0 0 0 2px rgba(11,31,51,.08);
}
.saas-onboarding-stepper button.is-active span,
.saas-onboarding-stepper button.is-complete span{
  background:#0B1F33;
  color:#fff;
}
.saas-onboarding-stepper button.is-complete{
  border-color:#ABEFC6;
  background:#F2FFF7;
}
.saas-onboarding-intro,
.saas-onboarding-side-status,
.saas-onboarding-live-summary{
  display:grid;
  gap:6px;
  padding:14px 16px;
  border:1px solid #C9D4E2;
  border-radius:8px;
  background:#F6FAFD;
  color:#26364A;
}
.saas-onboarding-intro strong,
.saas-onboarding-side-status strong,
.saas-onboarding-live-summary strong{
  color:#0B1F33;
}
.saas-onboarding-intro span,
.saas-onboarding-side-status span,
.saas-onboarding-live-summary span{
  color:#607085;
  line-height:1.45;
}
.saas-onboarding-live-summary{
  background:#fff;
}
.saas-onboarding-live-summary b{
  color:#0B1F33;
}
.saas-onboarding-next-actions{
  display:grid;
  gap:8px;
  padding:14px;
  border:1px solid #C9D4E2;
  border-radius:8px;
  background:#fff;
}
.saas-onboarding-next-actions strong{
  color:#0B1F33;
  font-size:.95rem;
}
.saas-onboarding-next-actions ul{
  display:grid;
  gap:6px;
  margin:0;
  padding-left:18px;
  color:#26364A;
  font-size:.88rem;
  line-height:1.45;
}
.saas-onboarding-form.is-stepper-ready [data-onboarding-step]{
  display:none;
}
.saas-onboarding-form.is-stepper-ready [data-onboarding-step].is-active{
  display:block;
}
.saas-onboarding-form [data-advanced-field][hidden]{
  display:none !important;
}
.saas-onboarding-intro [data-step-friction-summary]{
  display:block;
  margin-top:6px;
  color:#607085;
  font-size:.82rem;
  font-weight:800;
  line-height:1.35;
}
.saas-onboarding-form.is-guided-setup [data-ai-conversation-preview]{
  margin-top:2px;
}
.saas-onboarding-form.is-advanced-setup [data-advanced-field]{
  outline:1px dashed rgba(11,31,51,.12);
  outline-offset:4px;
}
.saas-choice-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.saas-choice{
  min-width:0;
  min-height:112px;
  display:grid;
  grid-template-rows:auto minmax(0,1fr) auto;
  gap:7px;
  padding:14px;
  border:1px solid #C9D4E2;
  border-radius:8px;
  background:#fff;
  color:#26364A;
  text-align:left;
  cursor:pointer;
  transition:border-color .16s ease,box-shadow .16s ease,background-color .16s ease,transform .16s ease;
}
.saas-choice:hover,
.saas-choice:focus-visible{
  border-color:#0B1F33;
  box-shadow:0 12px 24px rgba(20,32,51,.08);
  transform:translateY(-1px);
}
.saas-choice strong{
  color:#0B1F33;
  font-size:.98rem;
}
.saas-choice span{
  color:#607085;
  font-size:.84rem;
  font-weight:700;
  line-height:1.35;
}
.saas-choice em{
  color:#0B3A5B;
  font-size:.82rem;
  font-style:normal;
  font-weight:900;
}
.saas-choice.is-selected{
  border-color:#0B1F33;
  background:#F6FAFD;
  box-shadow:inset 0 0 0 2px rgba(11,31,51,.08);
}
.saas-choice.is-selected::after{
  content:"Seleccionado";
  justify-self:start;
  min-height:24px;
  display:inline-flex;
  align-items:center;
  padding:3px 8px;
  border-radius:999px;
  background:#0B1F33;
  color:#fff;
  font-size:.72rem;
  font-weight:900;
}
.saas-choice-grid--plans{
  grid-template-columns:repeat(4,minmax(0,1fr));
}
.saas-choice-grid--signup{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.saas-choice-grid--phone{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.saas-choice-grid--service{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.saas-advanced-panel{
  border:1px solid #C9D4E2;
  border-radius:8px;
  background:#F6FAFD;
}
.saas-advanced-panel summary{
  min-height:48px;
  display:flex;
  align-items:center;
  gap:10px;
  padding:0 14px;
  color:#0B1F33;
  font-weight:900;
  cursor:pointer;
}
.saas-advanced-panel summary::marker{
  color:#0B3A5B;
}
.saas-advanced-panel:not([open]) > :not(summary){
  display:none !important;
}
.saas-advanced-panel .saas-form__grid{
  padding:0 14px 14px;
}
.saas-login-layout{
  display:grid;
  grid-template-columns:minmax(280px,420px) minmax(0,1fr);
  gap:24px;
  align-items:start;
}
.saas-login-panel{
  display:grid;
  gap:16px;
  padding:28px;
  border:1px solid rgba(20,32,51,.1);
  border-radius:8px;
  background:#fff;
  box-shadow:0 14px 34px rgba(20,32,51,.06);
}
.saas-login-panel h2{
  margin:0;
  color:#0B1F33;
  font-size:1.7rem;
  letter-spacing:0;
}
.saas-login-tabs{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:6px;
  padding:4px;
  border:1px solid #C9D4E2;
  border-radius:8px;
  background:#F6FAFD;
}
.saas-login-tabs a{
  min-width:0;
  min-height:40px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:8px;
  border-radius:6px;
  color:#26364A;
  font-size:.86rem;
  font-weight:900;
  text-align:center;
}
.saas-login-tabs a.is-active{
  background:#0B1F33;
  color:#fff;
  box-shadow:0 6px 14px rgba(11,31,51,.14);
}
.saas-login-form{
  padding:0;
}
.saas-login-actions{
  display:flex;
  flex-wrap:wrap;
  justify-content:space-between;
  gap:12px;
  color:#0B3A5B;
  font-weight:900;
}
.saas-login-panel--secondary .saas-card{
  box-shadow:none;
}
.saas-form__hint{
  margin:-2px 0 14px;
  color:#607085;
  line-height:1.55;
  font-weight:700;
}
.saas-diagnostic-form{
  gap:20px;
}
.saas-form__section{
  display:grid;
  gap:12px;
}
.saas-form__fieldset{
  min-width:0;
  margin:0;
  padding:0 0 18px;
  border:0;
  border-bottom:1px solid rgba(20,32,51,.1);
}
.saas-form__fieldset:last-of-type{
  border-bottom:0;
  padding-bottom:0;
}
.saas-form__fieldset legend{
  margin:0 0 12px;
  color:#0B1F33;
  font-size:1.08rem;
  font-weight:900;
}
.saas-form__grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.saas-form__wide{
  grid-column:1 / -1;
}
.saas-diagnostic-fields{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.saas-form label{
  display:grid;
  gap:6px;
  color:#26364A;
  font-weight:800;
}
.saas-form label small{
  color:#607085;
  font-size:.8rem;
  font-weight:700;
  line-height:1.45;
}
.saas-form input,
.saas-form textarea,
.saas-form select{
  width:100%;
  border:1px solid #C9D4E2;
  border-radius:8px;
  padding:11px 12px;
  color:#142033;
  background:#fff;
}
.saas-form textarea{
  resize:vertical;
}
.saas-form__label{
  display:block;
  margin:0 0 8px;
  color:#142033;
  font-weight:900;
}
.saas-form .saas-checkbox{
  display:flex;
  align-items:flex-start;
  gap:10px;
  color:#26364A;
  font-weight:700;
  line-height:1.45;
}
.saas-capability-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
}
.saas-capability-grid .saas-checkbox{
  min-height:46px;
  padding:10px;
  border:1px solid #D8E2EC;
  border-radius:8px;
  background:#fff;
}
.saas-form .saas-checkbox input{
  width:18px;
  height:18px;
  margin-top:2px;
  flex:0 0 auto;
}
.saas-form__status{
  margin:0;
  padding:12px;
  border:1px solid #C9D4E2;
  border-radius:8px;
  background:#F6FAFD;
  color:#26364A;
  font-weight:800;
}
[data-plan-scope-guidance],
[data-telephony-guidance],
[data-activation-route-guidance]{
  display:grid;
  gap:6px;
}
[data-plan-scope-guidance] span,
[data-telephony-guidance] span,
[data-activation-route-guidance] span{
  display:block;
  font-weight:700;
  line-height:1.45;
}
.saas-form__status--success{
  border-color:#ABEFC6;
  background:#ECFDF3;
  color:#067647;
}
.saas-form__status--error{
  border-color:#FDA29B;
  background:#FEF3F2;
  color:#B42318;
}
.saas-form__status--warning{
  border-color:#FEDF89;
  background:#FFFAEB;
  color:#93370D;
}
.saas-onboarding-actions{
  display:grid;
  grid-template-columns:auto minmax(110px,1fr) auto auto;
  gap:10px;
  align-items:center;
  padding-top:4px;
}
.saas-onboarding-actions [data-step-counter]{
  color:#607085;
  font-weight:900;
  text-align:center;
}
.saas-onboarding-actions [hidden]{
  display:none !important;
}
.saas-diagnostic-panel{
  position:sticky;
  top:96px;
  display:grid;
  gap:18px;
  padding:28px;
  border:1px solid rgba(20,32,51,.1);
  border-radius:8px;
  background:#fff;
  box-shadow:0 14px 34px rgba(20,32,51,.06);
}
.saas-diagnostic-panel h2{
  margin:0;
  color:#0B1F33;
  font-size:clamp(1.7rem,3vw,2.4rem);
  letter-spacing:0;
}
.saas-diagnostic-panel p{
  margin:0;
  color:#607085;
}
.saas-diagnostic-panel small{
  color:#607085;
  line-height:1.5;
}
.saas-diagnostic-result-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.saas-diagnostic-result{
  display:grid;
  gap:6px;
  padding:14px;
  border:1px solid rgba(20,32,51,.1);
  border-radius:8px;
  background:#F6FAFD;
}
.saas-diagnostic-result span{
  color:#607085;
  font-size:.84rem;
  font-weight:800;
}
.saas-diagnostic-result strong{
  color:#0B1F33;
  font-size:1.18rem;
}
.saas-diagnostic-bar{
  height:12px;
  overflow:hidden;
  border-radius:999px;
  background:#E7EEF5;
}
.saas-diagnostic-bar span{
  display:block;
  width:40%;
  height:100%;
  border-radius:inherit;
  background:linear-gradient(90deg,#F7B500,#0F7A42);
  transition:width .2s ease;
}
.saas-status-pack{
  display:grid;
  gap:16px;
  margin-bottom:18px;
  padding:22px;
  border:1px solid rgba(20,32,51,.1);
  border-radius:8px;
  background:#fff;
  box-shadow:0 14px 34px rgba(20,32,51,.06);
}
.saas-status-pack h3{
  margin:6px 0 0;
  color:#0B1F33;
  font-size:1.35rem;
  letter-spacing:0;
}
.saas-status-pack__actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.saas-status-pack pre{
  overflow:auto;
  max-height:360px;
  margin:0;
  padding:16px;
  border:1px solid #C9D4E2;
  border-radius:8px;
  background:#F6FAFD;
  color:#26364A;
  white-space:pre-wrap;
  line-height:1.55;
}
@media (max-width:900px){
  .saas-nav{display:none}
  .saas-hero{min-height:auto;padding:64px 0 56px}
  .saas-section-grid,
  .saas-pricing-layout,
  .saas-diagnostic-layout,
  .saas-activation-layout,
  .saas-login-layout,
  .saas-onboarding-layout{
    grid-template-columns:1fr;
  }
  .saas-onboarding-stepper{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .saas-onboarding-stepper button{
    align-items:start;
    min-height:82px;
  }
  .saas-onboarding-stepper button strong,
  .saas-onboarding-stepper button em{
    overflow:visible;
    text-overflow:clip;
    white-space:normal;
    line-height:1.2;
  }
  .saas-onboarding-summary{
    position:static;
  }
  .saas-console__grid,
  .saas-card-grid,
  .saas-choice-grid,
  .saas-form__grid,
  .saas-diagnostic-fields,
  .saas-diagnostic-result-grid{
    grid-template-columns:1fr;
  }
  .saas-choice-grid--plans,
  .saas-choice-grid--signup{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .saas-diagnostic-panel{
    position:static;
  }
  .saas-onboarding-actions{
    grid-template-columns:1fr;
  }
  .saas-onboarding-actions [data-step-counter]{
    order:-1;
    text-align:left;
  }
  .saas-cta,
  .saas-footer__inner{
    display:grid;
  }
}
@media (max-width:640px){
  .saas-choice-grid--plans,
  .saas-choice-grid--signup{
    grid-template-columns:1fr;
  }
  .saas-capability-grid{
    grid-template-columns:1fr;
  }
  .saas-choice{
    min-height:96px;
  }
}
