/* V29 — page-by-page premium UX pass */
:root{
  --v29-navy:#0b2f52;
  --v29-ink:#0f2034;
  --v29-soft:#f5f8fc;
  --v29-line:rgba(11,47,82,.12);
  --v29-card:#ffffff;
  --v29-warm:#fff4df;
  --v29-sea:#e9f6ff;
}
body{background:linear-gradient(180deg,#f7fbff 0%,#ffffff 22%,#f9fbfd 100%)}
.heroContent h1{letter-spacing:-.03em}
.heroPill{backdrop-filter:blur(8px)}
.heroWrapV18{overflow:hidden}
.visualHeroRail,.routeRibbon,.planningScenarios,.editorialRow,.sceneSplit,.contactJourney,.liveDashGrid,.liveSpotScenes,.bookChapterRail,.bookHeroRail,.bookCompass,.weatherCompass{display:grid;gap:16px}
.visualHeroRail{grid-template-columns:repeat(3,minmax(0,1fr));margin-top:18px}
.routeRibbon{grid-template-columns:repeat(3,minmax(0,1fr))}
.planningScenarios{grid-template-columns:1.15fr .85fr;align-items:start}
.sceneSplit{grid-template-columns:1.15fr .85fr;align-items:center}
.editorialRow{grid-template-columns:repeat(3,minmax(0,1fr))}
.contactJourney{grid-template-columns:repeat(3,minmax(0,1fr))}
.liveDashGrid{grid-template-columns:1.1fr .9fr;align-items:start}
.liveSpotScenes{grid-template-columns:repeat(3,minmax(0,1fr))}
.bookHeroRail{grid-template-columns:1.12fr .88fr;align-items:start;margin-top:14px}
.bookChapterRail{grid-template-columns:repeat(4,minmax(0,1fr))}
.bookCompass{grid-template-columns:repeat(3,minmax(0,1fr));margin-top:14px}
.weatherCompass{grid-template-columns:repeat(4,minmax(0,1fr));margin-top:16px}
.v29Card,.v29Panel,.v29Metric,.v29Route,.v29Scene,.v29Chapter,.v29StepHint,.v29LiveStat,.v29ContactPoint,.dockPanelCard,.receiptHeroCard{
  background:var(--v29-card);
  border:1px solid var(--v29-line);
  border-radius:22px;
  box-shadow:0 18px 42px rgba(15,32,52,.07);
}
.v29Panel{padding:20px}
.v29Card{overflow:hidden}
.v29Card img,.v29Scene img,.v29Route img,.v29SpotShot img{display:block;width:100%;height:100%;object-fit:cover}
.v29CardBody,.v29RouteBody,.v29SceneBody{padding:18px}
.v29RouteBody p,.v29CardBody p,.v29SceneBody p{margin:8px 0 0;color:#405266}
.v29RouteTop,.v29CardTop{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.v29Eyebrow,.v29Tag{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;background:var(--v29-soft);font-size:12px;font-weight:800;color:var(--v29-navy)}
.v29Price{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;background:linear-gradient(90deg,#ffe08b,#8ce7d8);font-weight:900;color:#17324d;font-size:13px}
.v29MiniList{display:grid;gap:8px;margin:14px 0 0;padding:0;list-style:none}
.v29MiniList li{display:flex;gap:10px;align-items:flex-start;color:#2d4258;font-size:14px}
.v29MiniList .microIcon{flex:0 0 16px;margin-top:2px}
.v29Scene{display:grid;grid-template-columns:.92fr 1.08fr;overflow:hidden;min-height:240px}
.v29SceneBody{display:flex;flex-direction:column;justify-content:center}
.v29SceneActions,.v29DockActions{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.v29StatStrip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:16px}
.v29Metric{padding:16px 16px 14px}
.v29Metric b{display:block;font-size:13px;color:#4e657a;text-transform:uppercase;letter-spacing:.04em}
.v29Metric strong{display:block;font-size:26px;line-height:1.05;margin-top:4px;color:var(--v29-ink)}
.v29Metric small{display:block;margin-top:6px;color:#5d7187}
.v29Route{overflow:hidden}
.v29RouteMedia{aspect-ratio:1.25/1}
.v29RouteBody .metaChips{margin-top:12px}
.v29Compare{display:grid;grid-template-columns:1fr 320px;gap:16px}
.v29CompareCard{padding:18px}
.v29CompareCard table{width:100%}
.v29AsideStack{display:grid;gap:16px}
.v29AsideNote{padding:18px}
.v29AsideNote h3{margin:0 0 8px}
.v29AsideNote p,.v29AsideNote li{color:#526578}
.v29AsideNote ul{margin:10px 0 0 18px;padding:0}

/* Smart Dock redesign */
.smartDock{position:fixed;right:12px;left:auto;bottom:86px;max-width:360px;z-index:45}
.smartDockBar{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.94);backdrop-filter:blur(16px);border:1px solid rgba(11,47,82,.12);border-radius:999px;padding:8px 10px;box-shadow:0 14px 32px rgba(11,24,40,.16)}
.smartDockToggle{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;background:none;border:none;padding:0;width:100%;text-align:left;color:inherit;min-width:0}
.smartDockText{display:grid;gap:2px;min-width:0}
.smartDockText em{font-style:normal;font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#506278}
.smartDockText strong{font-size:13px;line-height:1.15;color:var(--v29-ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.smartDockText small{font-size:11px;line-height:1.25;color:#5c6f82;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.smartDockBadge{display:inline-flex;align-items:center;justify-content:center;min-width:58px;height:34px;padding:0 12px;border-radius:999px;background:linear-gradient(90deg,#ffe08b,#84e2d6);font-size:11px;font-weight:900;color:#16324d}
.smartDockClose,.smartDockCloseSheet{width:34px;height:34px;border-radius:999px;border:1px solid rgba(11,47,82,.15);background:#fff;color:#17324d;display:inline-flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer;flex:0 0 34px}
.smartDockPanel{position:fixed;right:12px;left:12px;bottom:144px;max-width:520px;margin-left:auto;padding:14px;border-radius:24px;background:rgba(255,255,255,.98);border:1px solid rgba(11,47,82,.12);box-shadow:0 22px 48px rgba(11,24,40,.18);max-height:min(78vh,720px);overflow:auto}
.smartDockSheetHead{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:10px}
.smartDockSheetHead h3{margin:4px 0 0;font-size:18px;color:#10253b}
.smartDockSummaryCard,.smartDockActionCard,.smartDockResumeCard,.smartDockMiniCard{padding:14px;border-radius:18px;border:1px solid rgba(11,47,82,.1);background:#f8fbff}
.smartDockSummaryCard h3,.smartDockActionCard h3,.smartDockResumeCard h3{margin:0;font-size:15px}
.smartDockKicker{display:block;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:#62809b;margin-bottom:6px;font-weight:800}
.smartDockMetrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:10px}
.smartDockMiniCard .notice{margin:0}
.smartDockMiniCard b{display:block;font-size:12px;color:#5a7188;text-transform:uppercase;letter-spacing:.04em}
.smartDockMiniCard strong{display:block;margin-top:4px;font-size:18px;color:#10253b}
.smartDockMiniCard small{display:block;margin-top:4px;color:#5d7187}
.smartDockSpotChips{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0 0}
.smartDockSpotChips .chip{padding:7px 10px;font-size:12px}
.smartDockActionCard p,.smartDockSummaryCard p,.smartDockResumeCard p{margin:8px 0 0;color:#587089;font-size:13px;line-height:1.45}
.smartDockActions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}
.smartDockActions .btn:last-child{grid-column:1/-1}
.smartDockResumeCard{margin-top:12px;background:linear-gradient(180deg,#f8fcff,#eef7ff)}
.smartDockResumeTop{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}
.smartDockMeta{margin-top:12px;padding-top:12px;border-top:1px dashed rgba(11,47,82,.12);font-size:12px;color:#607488}
.siteLiveWidgetReopen{position:fixed;right:12px;bottom:86px;z-index:44;border:none;border-radius:999px;background:#16324d;color:#fff;padding:9px 12px;box-shadow:0 16px 32px rgba(11,24,40,.18);font-weight:800}
.smartDock.is-open .smartDockBadge{background:#16324d;color:#fff}

/* Book page / receipt */
.bookHeroRail{position:relative}
.bookHeroVisualCard{overflow:hidden;min-height:240px}
.bookHeroVisualCard img{width:100%;height:100%;object-fit:cover}
.bookHeroVisualOverlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,26,45,.08),rgba(7,26,45,.48))}
.bookHeroVisualInner{position:absolute;left:20px;right:20px;bottom:18px;color:#fff;display:grid;gap:10px}
.bookHeroVisualInner h3{margin:0;font-size:28px;line-height:1.02}
.bookHeroVisualInner p{margin:0;color:rgba(255,255,255,.86)}
.bookChapterRail{margin-top:18px}
.v29Chapter{padding:16px}
.v29ChapterHead{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.v29ChapterHead .iconBadge{width:34px;height:34px}
.v29Chapter b{font-size:15px;color:var(--v29-ink)}
.v29Chapter p{margin:0;color:#587089;font-size:13px;line-height:1.45}
.v29PillList{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.v29PillList span{display:inline-flex;align-items:center;gap:6px;padding:7px 10px;border-radius:999px;background:#f3f8fd;color:#22415e;font-size:12px;font-weight:700}
.buildInlineEstimate{padding:16px 18px 14px;border:1px solid rgba(11,47,82,.12);background:linear-gradient(180deg,#f8fbff,#ffffff);border-radius:22px;box-shadow:0 18px 40px rgba(11,24,40,.06)}
.buildInlineEstimateTop{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.buildInlineEstimateTop strong{font-size:14px;letter-spacing:.06em;text-transform:uppercase;color:#557089}
#inlineEstimateTotal{font-size:26px;font-weight:950;color:#10253b;white-space:nowrap}
.buildInlineEstimateMeta{margin-top:6px;font-size:13px;color:#5e748a}
.buildInlineEstimateLines{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px}
.buildInlineEstimateLines .receiptChip{display:inline-flex;align-items:center;padding:7px 10px;border-radius:999px;background:var(--v29-soft);font-size:12px;font-weight:700;color:#23445f}
.buildInlineEstimateActions{margin-top:12px;display:flex;gap:10px;align-items:center;justify-content:space-between}
.builderGridV24{align-items:start;gap:24px}
.receiptShell{display:grid;gap:12px}
.receiptHeroCard{padding:18px 18px 14px;background:linear-gradient(180deg,#0d3358,#173f6a);color:#fff}
.receiptHeroCard strong{display:block;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.72)}
.receiptHeroCard b{display:block;font-size:28px;line-height:1.02;margin-top:8px}
.receiptHeroCard p{margin:8px 0 0;color:rgba(255,255,255,.82)}
.receiptHighlights{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:14px}
.receiptHighlights span{display:flex;align-items:center;justify-content:center;padding:9px 10px;border-radius:14px;background:rgba(255,255,255,.12);font-size:12px;font-weight:800}
.stickySummary{position:sticky;top:98px;display:grid;gap:12px;background:transparent;border:none;box-shadow:none;padding:0}
#priceSummary{background:#fff;border:1px solid rgba(11,47,82,.12);border-radius:22px;box-shadow:0 18px 40px rgba(11,24,40,.06);padding:14px}
.sumSection{padding:10px 2px 4px;border-bottom:1px solid rgba(11,47,82,.07)}
.sumSection:last-of-type{border-bottom:none}
.sumSection h3{margin:0 0 10px;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:#56728d}
.sumLine{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:flex-start;padding:9px 0}
.sumLine span:last-child{font-weight:900;color:#16324d;white-space:nowrap;display:block;text-align:right}
.sumLine b{display:block;color:#16324d;font-size:14px;line-height:1.25}
.sumLine small{display:block;margin-top:4px;color:#637a90;line-height:1.35;font-size:12px}
.sumLine.isIncluded span:last-child{color:#0f7a60}
.sumLine.isIncluded{background:linear-gradient(90deg,rgba(11,180,117,.06),transparent);padding-left:10px;padding-right:10px;border-radius:12px}
.sumLine.isNote{background:rgba(11,47,82,.04);padding-left:10px;padding-right:10px;border-radius:12px}
.sumTotal{margin-top:6px;padding-top:14px;border-top:1px solid rgba(11,47,82,.1);font-size:18px}
.sumFooterNote{background:#f8fbff;border-radius:14px;padding:10px 12px;color:#5f7487;font-size:12px}
.fold summary{padding:16px 18px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.fold summary::-webkit-details-marker{display:none}
.fold .foldTitle{font-size:18px;font-weight:900;color:#16324d;display:flex;align-items:center;gap:10px}
.fold .foldMeta{margin-left:auto;max-width:46%;font-size:12px;color:#607489;text-align:right;line-height:1.35}
.fold[open]{border-color:rgba(18,87,142,.32);box-shadow:0 14px 34px rgba(11,24,40,.06)}
.stepBody{padding:0 18px 18px}
.stepNextWrap{display:flex;justify-content:flex-end;margin-top:14px}
.buildSummaryPanel{border-radius:24px 24px 0 0;padding:18px 16px 16px;max-height:78vh}
.buildSummaryMeta{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.buildSummaryMeta .chip{font-size:12px;padding:7px 10px}
.buildSummaryBody .sumSection{padding:8px 0 2px}
.buildSummaryBody .sumLine{grid-template-columns:minmax(0,1fr) auto}


.buildPage .hero .heroWrap{min-height:clamp(360px,56vw,520px)}
.buildPage .heroContent{max-width:640px}
.buildPage .heroContent p{max-width:38ch}
.bookHeroCompactRail{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.compactBuildGuide{margin:0 0 12px;font-size:13px}
.compactReceipt{padding:0;border:none;background:transparent;box-shadow:none}
.buildInlineEstimateButton{display:block;width:100%;text-align:left;background:#f8fbff;border:1px solid rgba(11,47,82,.12);border-radius:18px;padding:12px 14px;box-shadow:0 12px 28px rgba(11,24,40,.05)}
.buildInlineEstimateButton:hover{background:#f2f8ff}
.buildInlineEstimateActions,.buildInlineEstimateLines,.badgeRow.compactBadges,.bookCompass,.buildUtilityBar.compactOnly{display:none!important}
.desktopReceiptShell .compactHint{font-size:12px}
.receiptShell{display:grid;gap:10px}
.buildMobileBar{padding:8px 10px 10px;border-radius:18px}
.buildMobileRow{display:grid!important;grid-template-columns:auto minmax(0,1fr) auto;gap:8px;align-items:center}
.buildNavBtn{min-width:0;padding:11px 12px!important}
.buildEstimateBtn{display:grid!important;grid-template-rows:auto auto auto;gap:2px;align-items:start;justify-items:start;padding:10px 12px!important;min-width:0}
.buildEstimateBtn .receiptKicker{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:#6b7f93;font-weight:800}
.buildEstimateBtn strong{font-size:16px;line-height:1;color:#10253b}
.buildEstimateBtn small{font-size:11px;line-height:1.2;color:#5c7085;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.buildInlineEstimate{position:sticky;top:74px;z-index:20;margin-bottom:12px}
#priceSummary{padding:12px}
.sumLine{padding:8px 0}
.sumLine b{font-size:13px}
.fold summary{padding:14px 16px}
.fold .foldTitle{font-size:17px}
.fold .foldMeta{font-size:11px;max-width:42%}
@media (max-width:900px){
  .buildPage .hero .heroWrap{min-height:430px}
  .buildPage .heroContent{padding-bottom:18px}
  .buildPage .heroContent h1{font-size:clamp(2.1rem,10vw,3.1rem)}
  .bookHeroCompactRail{display:none}
  .compactBuildGuide{display:none}
  .desktopReceiptShell{display:none}
  .buildInlineEstimate{top:68px}
  body.buildPage .buildMobileBar{display:block;bottom:82px!important;left:10px!important;right:10px!important}
}
@media (max-width:640px){
  .smartDock{left:12px;right:12px;max-width:none;bottom:82px}
  .smartDockBar{padding:7px 9px}
  .smartDockText small{display:none}
  .smartDockPanel{left:0;right:0;bottom:0;max-width:none;border-radius:24px 24px 0 0;padding:14px 14px 110px}
  .smartDockMetrics{grid-template-columns:1fr}
  .smartDockActions{grid-template-columns:1fr}
  .buildInlineEstimateButton{padding:10px 12px}
  .buildInlineEstimateTop strong{font-size:12px}
  #inlineEstimateTotal{font-size:22px}
  .buildEstimateBtn{padding:9px 10px!important}
  .buildEstimateBtn strong{font-size:15px}
  .fold summary{display:block}
  .fold .foldMeta{display:block;max-width:none;text-align:left;margin-left:0;margin-top:6px}
}

/* Weather / ocean dashboards */
.liveHeroPanel{padding:18px;background:linear-gradient(180deg,#0d3358,#1f4f77);color:#fff}
.liveHeroPanel p{color:rgba(255,255,255,.84)}
.liveHeroStats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:14px}
.liveHeroStats .v29Metric{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.08);box-shadow:none;color:#fff}
.liveHeroStats .v29Metric b,.liveHeroStats .v29Metric strong,.liveHeroStats .v29Metric small{color:inherit}
.liveControlPanel{padding:18px}
.liveSwitchPills{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:14px}
.liveSwitchPills .btn{margin:0}
.liveDashboardCard{padding:16px}
.liveDashboardCard h3{margin:0 0 10px}
.liveDashboardNote{font-size:13px;color:#5e748a;margin-top:10px}
.v29SpotShot{overflow:hidden;border-radius:18px;border:1px solid rgba(11,47,82,.1);background:#fff;box-shadow:0 14px 32px rgba(11,24,40,.06)}
.v29SpotShot img{display:block;width:100%;aspect-ratio:1.25/1;object-fit:cover}
.v29SpotShotBody{padding:14px}
.v29SpotShotBody b{display:block;color:#133352;font-size:15px}
.v29SpotShotBody small{display:block;margin-top:6px;color:#607488;line-height:1.45}
.kpiRow{gap:12px}
.kpi{border-radius:18px;border:1px solid rgba(11,47,82,.1);background:#fff;box-shadow:0 14px 32px rgba(11,24,40,.05);padding:14px 14px 12px}
.kpi b{display:block;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:#597289}
.kpi span{display:block;margin-top:6px;font-size:20px;font-weight:900;color:#16324d;line-height:1.1}

/* contact */
.contactTrustRow{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:16px}
.contactTrustRow .v29Metric strong{font-size:18px}
.contactQuickActions{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}
.contactFormPanelPro .fieldCard{background:#fff;border:1px solid rgba(11,47,82,.1);border-radius:18px;padding:12px}
.contactFormPanelPro .fieldCard label{display:block;margin-bottom:8px;font-weight:800;color:#153451;font-size:13px}
.contactFormPanelPro input,.contactFormPanelPro textarea{width:100%;border:none;outline:none;background:transparent;font-size:15px;color:#17324d}
.contactFormPanelPro textarea{min-height:150px;resize:vertical}

/* home / packages */
.v29Mosaic{display:grid;grid-template-columns:1.08fr .92fr;gap:16px;align-items:start}
.v29MosaicSmall{display:grid;gap:16px}
.v29StoryCard{padding:18px}
.v29StoryCard h3{margin:0 0 8px}
.v29StoryCard p{margin:0;color:#5c7288}
.v29FlowList{display:grid;gap:10px;margin-top:14px}
.v29FlowList li{display:flex;gap:10px;align-items:flex-start;color:#294158}
.v29FlowList strong{display:block}
.v29FlowList small{display:block;color:#5d7389}

/* Mobile */
@media (max-width:900px){
  .planningScenarios,.sceneSplit,.v29Mosaic,.v29Compare,.liveDashGrid,.bookHeroRail,.visualHeroRail,.routeRibbon,.editorialRow,.contactJourney,.liveSpotScenes,.bookChapterRail,.bookCompass,.weatherCompass,.v29StatStrip,.contactTrustRow,.liveHeroStats{grid-template-columns:1fr}
  .stickySummary{position:static}
  .builderGridV24{grid-template-columns:1fr}
}
@media (max-width:640px){
  .visualHeroRail,.routeRibbon,.editorialRow,.contactJourney,.liveSpotScenes,.bookChapterRail,.bookCompass,.weatherCompass,.v29StatStrip,.contactTrustRow,.liveHeroStats,.receiptHighlights{grid-template-columns:1fr}
  .bookHeroVisualInner h3{font-size:22px}
  .sumLine{grid-template-columns:minmax(0,1fr)}
  .sumLine span:last-child{text-align:left}
}

/* V29.2 booking logic + responsive media */
.smartDateCard{border:1px solid rgba(11,47,82,.12);background:linear-gradient(180deg,#f8fbff,#fff);border-radius:20px;padding:14px 14px 10px;margin-bottom:12px;box-shadow:0 10px 24px rgba(11,24,40,.05)}
.smartDateHead{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}
.smartDateHead b{display:block;font-size:15px;color:#0f2940}
.smartDateHead small{display:block;color:#64748b;margin-top:2px}
.smartDatePreview{display:inline-flex;align-items:center;padding:8px 10px;border-radius:999px;background:#fff;border:1px solid rgba(11,47,82,.10);font-size:12px;font-weight:800;color:#23445f;white-space:nowrap}
.smartDateFields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.compactCoreGrid{grid-template-columns:repeat(2,minmax(0,1fr))}
.bookingModeMessage{margin-top:10px}
body.buildPage .twoColBlocks{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
body.buildPage .twoColBlocks > div{min-width:0}
.sumLine.isNote span:last-child{color:#9f1239;font-weight:800}
.routeRibbon{align-items:stretch}
.routeRibbon .v29Route{height:100%}
@media (max-width: 900px){
  body.buildPage .twoColBlocks{grid-template-columns:1fr}
}
@media (max-width: 760px){
  .smartDateHead{align-items:flex-start;flex-direction:column}
  .smartDateFields,.compactCoreGrid{grid-template-columns:1fr 1fr}
  .routeRibbon{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;gap:12px;padding-bottom:4px;-webkit-overflow-scrolling:touch}
  .routeRibbon::-webkit-scrollbar{display:none}
  .routeRibbon .v29Route{flex:0 0 88%;scroll-snap-align:start}
}
@media (max-width: 420px){
  .smartDateFields,.compactCoreGrid{grid-template-columns:1fr}
}
