/* Phase 204 CSS bundle: Build true clean shell + inline composer + visual contrast lock */

/* Build shell */
.buildClean204{
  --navy:#13283a;
  --navy-2:#0e1f2e;
  --ink:#172431;
  --muted:#4f5e6b;
  --cream:#fbf4e8;
  --cream-2:#f6ead7;
  --card:#fffdf8;
  --line:rgba(19,40,58,.16);
  --line-strong:rgba(19,40,58,.26);
  --warm:#d66d22;
  --warm-2:#fff0df;
  --good:#116b58;
  --danger:#9a3412;
  background:#fbf7ef;
  color:var(--ink);
}
.buildClean204 *{box-sizing:border-box}
.buildClean204 button,
.buildClean204 input,
.buildClean204 select,
.buildClean204 textarea{font:inherit}
.buildCleanMain{padding:16px 0 84px}
.buildCleanHero{padding:18px 16px 10px}
.buildCleanPill{
  display:inline-flex;
  align-items:center;
  border:1px solid var(--line);
  background:var(--cream-2);
  border-radius:999px;
  padding:6px 10px;
  font-size:12px;
  font-weight:950;
  color:var(--navy);
  letter-spacing:.04em;
  text-transform:uppercase;
}
.buildCleanHero h1{
  margin:10px 0 8px;
  font-family:Inter Tight,Inter,sans-serif;
  font-size:clamp(32px,7vw,64px);
  line-height:.94;
  letter-spacing:-.055em;
  color:var(--navy);
}
.buildCleanHero p{
  margin:0;
  max-width:760px;
  color:var(--muted);
  font-size:16px;
  line-height:1.5;
  font-weight:700;
}
.buildCleanShell{padding:0 16px 14px}
.buildCleanForm{margin:0}
.buildCleanFrame{display:block}
.buildCleanApp{
  overflow:hidden;
  background:var(--card);
  border:1px solid var(--line);
  border-radius:26px;
  box-shadow:0 18px 48px rgba(19,40,58,.08);
}

/* Trip cards */
.buildCleanStepper{
  display:flex;
  gap:8px;
  overflow:auto;
  scrollbar-width:none;
  padding:10px;
  background:linear-gradient(180deg,#fffaf1,#f8ecd9);
  border-bottom:1px solid var(--line);
}
.buildCleanStepper::-webkit-scrollbar{display:none}
.cleanStepPill{
  appearance:none;
  border:1px solid var(--line);
  background:#fffaf2;
  color:var(--navy);
  border-radius:999px;
  padding:7px 10px;
  display:flex;
  gap:7px;
  align-items:center;
  white-space:nowrap;
  font-size:12px;
  font-weight:950;
  cursor:pointer;
}
.cleanStepPill b{
  display:grid;
  place-items:center;
  width:19px;
  height:19px;
  border-radius:50%;
  background:#fff;
  color:var(--navy);
  border:1px solid var(--line);
}
.cleanStepPill.is-active{
  background:var(--navy);
  border-color:var(--navy);
  color:#fff;
}
.cleanStepPill.is-active b{
  background:var(--warm);
  color:#fff;
  border-color:transparent;
}
.buildCleanValidation{
  margin:12px 14px 0;
  padding:10px 12px;
  border:1px solid rgba(154,52,18,.34);
  background:#fff4e6;
  border-radius:16px;
  font-weight:900;
  color:#7c2d12;
}
.cleanStep{display:none;padding:14px}
.cleanStep.is-active{display:block}
.cleanStepHead{display:flex;flex-direction:column;gap:5px;margin-bottom:12px}
.cleanStepHead span{
  color:var(--warm);
  font-size:12px;
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.055em;
}
.cleanStepHead h2{
  margin:0;
  color:var(--navy);
  font-family:Inter Tight,Inter,sans-serif;
  font-size:clamp(22px,4vw,30px);
  line-height:1;
  letter-spacing:-.035em;
}
.cleanModeGrid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
}
.cleanModeCard{
  appearance:none;
  display:flex;
  flex-direction:column;
  text-align:left;
  gap:7px;
  min-height:116px;
  border:1px solid var(--line);
  background:#fff8ed;
  border-radius:22px;
  padding:14px;
  color:var(--ink);
  box-shadow:0 10px 24px rgba(19,40,58,.055);
  cursor:pointer;
}
.cleanModeCard strong{font-size:17px;color:var(--navy);line-height:1.12}
.cleanModeCard span{font-size:13px;line-height:1.35;color:var(--muted);font-weight:760}
.cleanModeCard.is-active{
  background:var(--navy);
  border-color:var(--navy);
  color:#fff;
}
.cleanModeCard.is-active strong,
.cleanModeCard.is-active span{color:#fff}

/* Guest profile */
.guestCounterGrid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.guestCounter{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  border:1px solid var(--line);
  background:#fff8ed;
  border-radius:20px;
  padding:11px 12px;
}
.guestCounter span{font-weight:950;color:var(--navy);line-height:1.2}
.guestCounter div{display:flex;align-items:center;gap:8px}
.guestCounter button,
.guestProfile button,
.ageChips button,
.slotRow button,
.activityFamilyRail button,
.receiptActions button,
.cleanSoftBtn,
.cleanTextBtn,
.cleanDockBtn,
.cleanDockSummary{
  appearance:none;
  border:1px solid var(--line);
  background:#fffdf8;
  border-radius:999px;
  padding:8px 11px;
  color:var(--navy);
  font-weight:950;
  cursor:pointer;
}
.guestCounter button{
  width:34px;
  height:34px;
  padding:0;
  font-size:19px;
  line-height:1;
}
.guestCounter strong{min-width:18px;text-align:center;color:var(--navy)}
.guestProfileGrid{display:grid;gap:8px;margin-top:12px}
.guestProfile{
  border:1px solid var(--line);
  border-radius:18px;
  background:#fffdf8;
  padding:10px;
}
.guestProfile strong{display:block;margin-bottom:8px;color:var(--navy)}
.guestProfileControls{display:flex;flex-wrap:wrap;gap:6px}
.guestProfile button.is-active,
.ageChips button.is-active,
.slotRow button.is-active,
.activityFamilyRail button.is-active{
  background:var(--navy);
  color:#fff;
  border-color:var(--navy);
}
.ageChips{display:flex;gap:4px;flex-wrap:wrap;width:100%}
.ageChips button{padding:5px 8px;font-size:12px}

/* Route builder */
.cleanDateGrid,
.cleanContactGrid,
.composerGrid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.cleanStep label{
  display:flex;
  flex-direction:column;
  gap:6px;
  color:var(--navy);
  font-size:13px;
  font-weight:950;
}
.cleanStep input,
.cleanStep select,
.cleanStep textarea{
  width:100%;
  border:1px solid var(--line);
  border-radius:15px;
  background:#fff;
  padding:11px 12px;
  color:var(--ink);
  font-weight:760;
}
.cleanStep textarea{min-height:104px;resize:vertical}
.cleanNotesLabel{margin-top:10px}
.cleanTrustLine{
  margin:10px 0 0;
  padding:10px 12px;
  border:1px solid rgba(19,40,58,.1);
  border-radius:16px;
  background:#f8ead7;
  color:var(--navy);
  font-weight:850;
  line-height:1.35;
}
.cleanStayPanel{display:grid;gap:10px}
.routeBlocks{display:grid;gap:8px}
.routeRow{
  display:grid;
  grid-template-columns:minmax(0,1fr) 105px 40px;
  gap:8px;
  align-items:end;
  border:1px solid var(--line);
  border-radius:18px;
  background:#fff8ed;
  padding:9px;
}
.routeRemove{
  height:42px;
  border:1px solid var(--line);
  border-radius:14px;
  background:#fff;
  color:var(--danger);
  font-weight:950;
  cursor:pointer;
}

/* Inline composer */
.activityFamilyRail{
  display:flex;
  gap:8px;
  overflow:auto;
  padding-bottom:8px;
  scrollbar-width:none;
}
.activityFamilyRail::-webkit-scrollbar{display:none}
.activityFamilyRail button{
  white-space:nowrap;
  background:#fff8ed;
}
.activityCards{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.activityCard{
  display:grid;
  gap:10px;
  border:1px solid var(--line);
  background:#fff8ed;
  border-radius:22px;
  padding:12px;
  min-width:0;
}
.activityCard.is-active{
  border-color:rgba(214,109,34,.58);
  box-shadow:0 0 0 3px rgba(214,109,34,.11);
  background:#fffaf3;
}
.activityCardTop{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:10px;
  align-items:start;
}
.activityCard strong{display:block;color:var(--navy);line-height:1.14}
.activityCard p{
  margin:4px 0 0;
  color:var(--muted);
  font-size:13px;
  line-height:1.35;
  font-weight:740;
}
.priceChip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  max-width:120px;
  border:1px solid rgba(19,40,58,.18);
  background:#fff;
  color:var(--navy);
  border-radius:999px;
  padding:6px 9px;
  font-size:12px;
  font-weight:950;
  text-align:center;
  white-space:normal;
}
.inlineAdd,
.cleanPrimary{
  appearance:none;
  border:0;
  background:var(--navy);
  color:#fff;
  border-radius:999px;
  padding:10px 13px;
  font-weight:950;
  cursor:pointer;
  text-align:center;
}
.cleanDockBtn:not(.cleanPrimary){
  background:var(--warm);
  border-color:var(--warm);
  color:var(--navy-2);
}
.cleanDockBtn:disabled{
  opacity:.55;
  background:#ece2d2;
  color:#465461;
  border-color:#d7c8b7;
  cursor:not-allowed;
}
.inlineSaved{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  border:1px solid rgba(17,107,88,.22);
  background:#edf8f4;
  border-radius:15px;
  padding:8px;
  color:var(--good);
  font-size:12px;
  font-weight:950;
}
.inlineSaved button{
  appearance:none;
  border:1px solid rgba(17,107,88,.28);
  background:#fff;
  color:var(--navy);
  border-radius:999px;
  padding:6px 9px;
  font-size:12px;
  font-weight:950;
  cursor:pointer;
}
.inlineComposer,
.receiptEditor{
  display:grid;
  gap:10px;
  border:1px solid rgba(214,109,34,.36);
  background:#fff4e6;
  border-radius:18px;
  padding:11px;
}
.composerHead{
  display:flex;
  justify-content:space-between;
  gap:10px;
  align-items:start;
}
.composerHead strong{color:var(--navy)}
.composerHead span{display:block;margin-top:2px;color:var(--muted);font-size:12px;font-weight:780;line-height:1.35}
.slotRow{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:7px;
}
.slotRow button{background:#fff}
.groupMode button.is-active{background:var(--navy);color:#fff}
.transferPreview{
  border:1px dashed rgba(19,40,58,.25);
  background:#fffdf8;
  border-radius:14px;
  padding:8px 10px;
  color:var(--navy);
  font-weight:950;
  line-height:1.25;
}
.participantBox{
  display:flex;
  flex-wrap:wrap;
  gap:7px;
  align-items:center;
}
.participantBox>span{
  width:100%;
  color:var(--navy);
  font-weight:950;
}
.partSummary{
  border:1px solid var(--line);
  background:#fffdf8;
  color:var(--navy);
  border-radius:14px;
  padding:8px 10px;
  font-size:13px;
  font-weight:850;
}
.partChip{
  display:inline-flex!important;
  flex-direction:row!important;
  align-items:center;
  gap:7px!important;
  width:auto!important;
  border:1px solid var(--line);
  background:#fffdf8;
  color:var(--navy);
  border-radius:999px;
  padding:7px 9px;
  font-size:12px!important;
  font-weight:850!important;
  cursor:pointer;
}
.partChip input{width:auto;margin:0;accent-color:var(--warm)}
.partChip.is-active{
  background:var(--navy);
  border-color:var(--navy);
  color:#fff;
}
.partChip.quote{
  border-color:rgba(214,109,34,.55);
  background:var(--warm-2);
  color:var(--navy);
}
.partChip.logistics{
  border-color:rgba(17,107,88,.34);
  background:#eef8f5;
}
.partChip.blocked{
  opacity:.65;
  background:#f3eee8;
  color:#52616d;
}
.composerNote{
  width:100%;
  color:var(--muted);
  font-size:12px;
  font-weight:780;
  line-height:1.35;
}
.composerEstimate{
  display:grid;
  gap:4px;
  border:1px solid var(--line);
  background:#fffdf8;
  border-radius:15px;
  padding:9px 10px;
}
.composerEstimate b{color:var(--navy)}
.composerEstimate small{color:var(--muted);font-weight:780;line-height:1.35}

/* Receipt modal */
.cleanReceiptSheet[hidden]{display:none}
.cleanReceiptSheet{
  position:fixed;
  inset:0;
  z-index:10040;
  display:flex;
  justify-content:center;
  align-items:flex-end;
  padding:16px;
}
.cleanReceiptBackdrop{
  position:absolute;
  inset:0;
  border:0;
  background:rgba(10,22,32,.48);
  cursor:pointer;
}
.cleanReceiptDialog{
  position:relative;
  z-index:1;
  width:min(720px,100%);
  max-height:min(82vh,760px);
  overflow:auto;
  background:#fffdf8;
  color:var(--ink);
  border:1px solid rgba(255,255,255,.5);
  border-radius:26px 26px 18px 18px;
  box-shadow:0 30px 90px rgba(0,0,0,.28);
}
.cleanReceiptDialogHead{
  position:sticky;
  top:0;
  z-index:2;
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  padding:14px;
  background:#fff8ed;
  border-bottom:1px solid var(--line);
}
.cleanReceiptDialogHead span{
  display:block;
  color:var(--warm);
  font-size:12px;
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.05em;
}
.cleanReceiptDialogHead h2{
  margin:2px 0 0;
  color:var(--navy);
  font-family:Inter Tight,Inter,sans-serif;
  font-size:24px;
  letter-spacing:-.03em;
}
#cleanReceiptBody{display:grid;gap:10px;padding:14px}
.receiptMiniHead,
.receiptStatic,
.receiptRow,
.receiptTotal{
  border:1px solid var(--line);
  background:#fffdf8;
  border-radius:18px;
  padding:11px;
}
.receiptMiniHead,
.receiptTotal{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
}
.receiptMiniHead strong,
.receiptTotal strong{color:var(--navy)}
.receiptMiniHead span,
.receiptStatic span,
.receiptStatic small{color:var(--muted);font-weight:780;line-height:1.35}
.receiptStatic{display:grid;gap:4px}
.receiptStatic b{color:var(--navy)}
.receiptRows{display:grid;gap:8px}
.receiptRow{display:grid;gap:8px}
.receiptLine{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:10px;
  align-items:start;
}
.receiptLine strong{display:block;color:var(--navy);line-height:1.18}
.receiptLine span,
.receiptLine small{
  display:block;
  color:var(--muted);
  font-size:13px;
  font-weight:760;
  line-height:1.35;
  overflow-wrap:anywhere;
}
.receiptLine b{
  color:var(--navy);
  background:#fff4e6;
  border:1px solid rgba(214,109,34,.28);
  border-radius:999px;
  padding:6px 9px;
  white-space:nowrap;
}
.receiptFlags{
  margin:0;
  color:var(--danger);
  font-size:12px;
  font-weight:850;
}
.receiptActions{display:flex;flex-wrap:wrap;gap:7px}
.receiptActions button{
  padding:7px 10px;
  font-size:12px;
  background:#fff8ed;
}
.emptyPlan{
  margin:0;
  border:1px dashed var(--line-strong);
  background:#fff8ed;
  border-radius:16px;
  padding:11px;
  color:var(--muted);
  font-weight:850;
}
.receiptTotal{
  background:var(--navy);
  color:#fff;
  border-color:var(--navy);
}
.receiptTotal span,
.receiptTotal strong{color:#fff}

/* Sticky dock */
.cleanDock{
  position:fixed;
  left:max(12px,env(safe-area-inset-left));
  right:max(12px,env(safe-area-inset-right));
  bottom:max(10px,env(safe-area-inset-bottom));
  z-index:9000;
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto auto;
  gap:8px;
  align-items:center;
  width:min(1120px,calc(100vw - 24px));
  margin:0 auto;
  padding:8px;
  border:1px solid rgba(19,40,58,.18);
  background:rgba(255,253,248,.95);
  backdrop-filter:blur(14px);
  border-radius:20px;
  box-shadow:0 18px 50px rgba(19,40,58,.18);
}
.cleanTextBtn{background:#fff8ed;color:var(--navy)}
.cleanDockSummary{
  min-width:0;
  width:100%;
  justify-content:flex-start;
  text-align:left;
  background:#fff8ed;
  color:var(--navy);
  overflow:hidden;
}
.cleanDockSummary span{
  display:block;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.cleanDockBtn,
.cleanDockSummary,
.cleanTextBtn{min-height:40px}
.cleanToast{
  position:fixed;
  left:50%;
  bottom:76px;
  transform:translateX(-50%);
  z-index:10050;
  display:flex;
  gap:10px;
  align-items:center;
  max-width:calc(100vw - 28px);
  background:var(--navy);
  color:#fff;
  border-radius:999px;
  padding:9px 12px;
  box-shadow:0 18px 50px rgba(19,40,58,.24);
  font-weight:900;
}
.cleanToast[hidden]{display:none}
.cleanToast button{
  border:0;
  background:var(--warm);
  color:var(--navy-2);
  border-radius:999px;
  padding:6px 9px;
  font-weight:950;
  cursor:pointer;
}

/* Final contact step */
.cleanContactGrid{align-items:start}

/* Mobile spacing */
@media (max-width:860px){
  .buildCleanMain{padding-top:8px;padding-bottom:76px}
  .buildCleanHero{padding:14px 14px 8px}
  .buildCleanShell{padding:0 12px 10px}
  .buildCleanApp{border-radius:22px}
  .cleanStep{padding:12px}
  .cleanModeGrid,
  .activityCards,
  .guestCounterGrid,
  .cleanDateGrid,
  .cleanContactGrid,
  .composerGrid{grid-template-columns:1fr}
  .cleanModeCard{min-height:auto}
  .activityCardTop{grid-template-columns:1fr}
  .priceChip{justify-self:start;max-width:100%}
  .routeRow{grid-template-columns:1fr 86px 38px}
  .cleanDock{
    grid-template-columns:minmax(0,1fr) auto auto;
    gap:7px;
  }
  .cleanDock .cleanTextBtn{display:none}
  .cleanDockSummary{grid-column:1 / -1;min-height:34px;padding:7px 10px}
  .cleanDockBtn{min-height:38px;padding:8px 12px}
  .cleanReceiptSheet{padding:10px}
  .cleanReceiptDialog{max-height:84vh;border-radius:22px}
}
@media (max-width:420px){
  .cleanStepPill span{max-width:110px;overflow:hidden;text-overflow:ellipsis}
  .guestCounter{padding:10px}
  .activityCard{padding:10px;border-radius:19px}
  .receiptMiniHead,
  .receiptTotal{align-items:flex-start;flex-direction:column}
}

/* Phase 205: Build compact lock and cookie-safe dock state */
body.buildCompact205 .buildCleanMain{padding:8px 0 66px}
body.buildCompact205 .buildCleanHero{padding:10px 14px 6px}
body.buildCompact205 .buildCleanPill{padding:5px 9px;font-size:11px;letter-spacing:.035em}
body.buildCompact205 .buildCleanHero h1{margin:8px 0 6px;font-size:clamp(27px,6.4vw,48px);line-height:.96;letter-spacing:-.052em}
body.buildCompact205 .buildCleanHero p{font-size:14px;line-height:1.38;font-weight:760;max-width:680px}
body.buildCompact205 .buildCleanShell{padding:0 12px 10px}
body.buildCompact205 .buildCleanApp{border-radius:20px;box-shadow:0 12px 32px rgba(19,40,58,.075)}
body.buildCompact205 .buildCleanStepper{gap:6px;padding:8px;background:#fff7eb}
body.buildCompact205 .cleanStepPill{display:grid;grid-template-columns:18px auto;gap:6px;align-items:center;min-height:36px;padding:5px 10px;border-radius:999px;font-size:12px;line-height:1;flex:0 0 auto}
body.buildCompact205 .cleanStepPill b{display:inline-grid;place-items:center;width:18px;height:18px;min-width:18px;line-height:1;font-size:12px;border-radius:50%;font-variant-numeric:tabular-nums;text-align:center;transform:none}
body.buildCompact205 .cleanStepPill span{display:block;line-height:1.02;max-width:118px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
body.buildCompact205 .cleanStep{padding:11px}
body.buildCompact205 .cleanStepHead{gap:4px;margin-bottom:9px}
body.buildCompact205 .cleanStepHead span{font-size:11px;letter-spacing:.05em}
body.buildCompact205 .cleanStepHead h2{font-size:clamp(20px,4.8vw,27px);line-height:1.02;letter-spacing:-.035em}
body.buildCompact205 .cleanModeGrid{gap:8px}
body.buildCompact205 .cleanModeCard{min-height:92px;border-radius:18px;padding:11px;gap:5px;box-shadow:none}
body.buildCompact205 .cleanModeCard strong{font-size:15px;line-height:1.08}
body.buildCompact205 .cleanModeCard span{font-size:12px;line-height:1.28;font-weight:760}
body.buildCompact205 .guestCounter{border-radius:17px;padding:9px 10px}
body.buildCompact205 .guestCounter button{width:31px;height:31px;font-size:17px}
body.buildCompact205 .guestProfile{border-radius:16px;padding:9px}
body.buildCompact205 .activityFamilyRail{gap:6px;padding-bottom:6px}
body.buildCompact205 .activityFamilyRail button{padding:7px 10px;font-size:12px}
body.buildCompact205 .activityCards{gap:8px}
body.buildCompact205 .activityCard{border-radius:18px;padding:10px;gap:8px}
body.buildCompact205 .activityCard strong{font-size:15px;line-height:1.1}
body.buildCompact205 .activityCard p{font-size:12px;line-height:1.28;font-weight:760}
body.buildCompact205 .priceChip{padding:5px 8px;font-size:11px;max-width:108px;line-height:1.05}
body.buildCompact205 .inlineAdd,body.buildCompact205 .cleanPrimary{padding:8px 11px;font-size:13px;min-height:36px}
body.buildCompact205 .inlineComposer,body.buildCompact205 .receiptEditor{border-radius:16px;padding:9px;gap:8px}
body.buildCompact205 .partChip{padding:6px 8px;font-size:11px!important;gap:5px!important}
body.buildCompact205 .cleanStep input,body.buildCompact205 .cleanStep select,body.buildCompact205 .cleanStep textarea{border-radius:13px;padding:9px 10px;font-size:13px}
body.buildCompact205 .cleanDock{grid-template-columns:auto minmax(0,1fr) auto auto;gap:6px;bottom:max(8px,env(safe-area-inset-bottom));padding:7px;border-radius:18px;box-shadow:0 14px 36px rgba(19,40,58,.16)}
body.buildCompact205 .cleanDockBtn,body.buildCompact205 .cleanDockSummary,body.buildCompact205 .cleanTextBtn{min-height:36px;padding:7px 10px;font-size:13px}
body.buildCompact205 .cleanDockSummary{border-radius:999px}
body.buildCompact205 .cleanReceiptDialog{border-radius:22px 22px 16px 16px;max-height:min(82vh,720px)}
body.cookieOpen .cleanDock,body.cookieOpen .cleanToast,html.cookieOpen .cleanDock,html.cookieOpen .cleanToast{display:none!important}
@media (max-width:860px){
  body.buildCompact205 .buildCleanMain{padding-top:5px;padding-bottom:66px}
  body.buildCompact205 .buildCleanHero{padding:9px 12px 5px}
  body.buildCompact205 .buildCleanHero h1{font-size:clamp(26px,8.4vw,36px);line-height:.96;margin:7px 0 5px}
  body.buildCompact205 .buildCleanHero p{font-size:13.5px;line-height:1.35}
  body.buildCompact205 .buildCleanShell{padding:0 10px 8px}
  body.buildCompact205 .buildCleanStepper{padding:7px;gap:6px}
  body.buildCompact205 .cleanStepPill{min-height:34px;padding:5px 9px;grid-template-columns:18px auto}
  body.buildCompact205 .cleanStepPill span{display:none}
  body.buildCompact205 .cleanStepPill::after{content:attr(data-short);display:block;max-width:86px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1;font-size:11.5px;font-weight:950}
  body.buildCompact205 .cleanStep{padding:10px}
  body.buildCompact205 .cleanModeCard{min-height:auto;border-radius:17px;padding:10px}
  body.buildCompact205 .cleanModeCard strong{font-size:14.5px}
  body.buildCompact205 .cleanModeCard span{font-size:11.8px}
  body.buildCompact205 .cleanDock{grid-template-columns:minmax(0,1fr) auto auto;gap:6px;left:12px;right:12px;width:auto;padding:7px;border-radius:18px}
  body.buildCompact205 .cleanDock .cleanTextBtn{display:none}
  body.buildCompact205 .cleanDockSummary{grid-column:1 / -1;min-height:32px;padding:7px 10px;font-size:12.5px}
  body.buildCompact205 .cleanDockBtn{min-height:35px;padding:7px 11px;font-size:13px}
}
@media (max-width:390px){
  body.buildCompact205 .tgzChromeWord strong{font-size:18px!important}
  body.buildCompact205 .cleanStepPill::after{max-width:72px;font-size:11px}
  body.buildCompact205 .cleanStepPill{padding-inline:8px}
  body.buildCompact205 .cleanDockBtn{padding-inline:10px}
}

/* Phase 206: Build package truth + compact closure */
body.buildPackage206 .buildCleanMain{padding-top:4px;padding-bottom:64px}
body.buildPackage206 .buildCleanHero{padding:7px 12px 4px}
body.buildPackage206 .buildCleanHero h1{font-size:clamp(24px,7.1vw,34px);line-height:.98;margin:6px 0 4px;letter-spacing:-.05em}
body.buildPackage206 .buildCleanHero p{font-size:13px;line-height:1.3;max-width:620px}
body.buildPackage206 .buildCleanPill{font-size:10.5px;padding:4px 8px}
body.buildPackage206 .buildCleanShell{padding-inline:9px}
body.buildPackage206 .buildCleanApp{border-radius:18px;box-shadow:0 10px 26px rgba(19,40,58,.07)}
body.buildPackage206 .buildCleanStepper{padding:6px;gap:5px}
body.buildPackage206 .cleanStepPill{min-height:31px;padding:4px 8px;gap:5px;grid-template-columns:17px auto;font-size:11px}
body.buildPackage206 .cleanStepPill b{width:17px;height:17px;min-width:17px;font-size:11px;line-height:1;display:inline-grid;place-items:center;transform:none;margin:0;text-align:center;font-variant-numeric:tabular-nums}
body.buildPackage206 .cleanStepPill::after{line-height:1;align-self:center}
body.buildPackage206 .cleanStep{padding:9px}
body.buildPackage206 .cleanStepHead{margin-bottom:8px;gap:3px}
body.buildPackage206 .cleanStepHead span{font-size:10.5px;letter-spacing:.05em}
body.buildPackage206 .cleanStepHead h2{font-size:clamp(18px,4.9vw,24px);line-height:1.03}
body.buildPackage206 .cleanBookingGrid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
body.buildPackage206 .cleanModeCard{min-height:auto;border-radius:16px;padding:9px;gap:4px;box-shadow:none}
body.buildPackage206 .cleanModeCard strong{font-size:14px;line-height:1.06}
body.buildPackage206 .cleanModeCard span{font-size:11.5px;line-height:1.23}
body.buildPackage206 .cleanOfferCard ul,.cleanPackageCard ul,.receiptStatic ul{margin:5px 0 0;padding:0;list-style:none;display:grid;gap:3px}
body.buildPackage206 .cleanOfferCard li,.cleanPackageCard li,.receiptStatic li{font-size:10.8px;line-height:1.18;font-weight:820;color:inherit;opacity:.92;position:relative;padding-left:12px}
body.buildPackage206 .cleanOfferCard li::before,.cleanPackageCard li::before,.receiptStatic li::before{content:'✓';position:absolute;left:0;top:0;color:var(--warm);font-weight:950}
html[dir="rtl"] body.buildPackage206 .cleanOfferCard li,html[dir="rtl"] body.buildPackage206 .cleanPackageCard li{padding-left:0;padding-right:12px}
html[dir="rtl"] body.buildPackage206 .cleanOfferCard li::before,html[dir="rtl"] body.buildPackage206 .cleanPackageCard li::before{left:auto;right:0}
body.buildPackage206 .cleanModeCard.is-active li::before{color:#fff}
body.buildPackage206 .cleanRouteEntry{justify-content:center}
body.buildPackage206 .cleanPackageChoiceGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin:8px 0}
body.buildPackage206 .cleanPackageCard{appearance:none;text-align:left;border:1px solid var(--line);border-radius:16px;background:#fff8ed;color:var(--navy);padding:9px;display:grid;gap:4px;cursor:pointer}
body.buildPackage206 .cleanPackageCard strong{font-size:14px;line-height:1.05;color:var(--navy)}
body.buildPackage206 .cleanPackageCard span{font-size:11.5px;line-height:1.2;color:var(--muted);font-weight:820}
body.buildPackage206 .cleanPackageCard.is-active{background:var(--navy);border-color:var(--navy);color:#fff}
body.buildPackage206 .cleanPackageCard.is-active strong,body.buildPackage206 .cleanPackageCard.is-active span{color:#fff}
body.buildPackage206 .cleanChangeType{margin-top:2px;width:max-content;max-width:100%;min-height:34px;padding:7px 10px;font-size:12px}
body.buildPackage206 .guestCounter{padding:8px 9px;border-radius:15px}
body.buildPackage206 .guestCounter button{width:29px;height:29px}
body.buildPackage206 .cleanDock{padding:6px;border-radius:16px;gap:5px}
body.buildPackage206 .cleanDockBtn,body.buildPackage206 .cleanDockSummary,body.buildPackage206 .cleanTextBtn{min-height:33px;padding:6px 9px;font-size:12.5px}
@media(max-width:520px){body.buildPackage206 .cleanBookingGrid,body.buildPackage206 .cleanPackageChoiceGrid{grid-template-columns:1fr}body.buildPackage206 .cleanOfferCard ul{grid-template-columns:1fr 1fr;gap:3px 6px}body.buildPackage206 .cleanOfferCard li{font-size:10.6px}body.buildPackage206 .cleanStepPill{min-height:30px}body.buildPackage206 .cleanStepPill::after{font-size:10.8px;max-width:68px}body.buildPackage206 .cleanDock{left:10px;right:10px}}
@media(max-width:370px){body.buildPackage206 .cleanOfferCard ul{grid-template-columns:1fr}body.buildPackage206 .cleanStepPill::after{max-width:58px}}

/* Phase 231 — Build package card safe-state redesign.
   Canonical selected package state: no full navy inversion, no hidden bullets. */
body.buildPackage206 #cleanBookingGrid .cleanModeCard.cleanOfferCard,
body.buildPackage206 #cleanPackageCards .cleanPackageCard{
  position:relative;
  background:#fff8ed;
  color:var(--navy);
  border:1px solid var(--line);
  box-shadow:none;
}
body.buildPackage206 #cleanBookingGrid .cleanModeCard.cleanOfferCard strong,
body.buildPackage206 #cleanBookingGrid .cleanModeCard.cleanOfferCard span,
body.buildPackage206 #cleanBookingGrid .cleanModeCard.cleanOfferCard li,
body.buildPackage206 #cleanPackageCards .cleanPackageCard strong,
body.buildPackage206 #cleanPackageCards .cleanPackageCard span,
body.buildPackage206 #cleanPackageCards .cleanPackageCard li{
  color:var(--navy)!important;
  opacity:1!important;
  -webkit-text-fill-color:currentColor!important;
  text-shadow:none!important;
}
body.buildPackage206 #cleanBookingGrid .cleanModeCard.cleanOfferCard span,
body.buildPackage206 #cleanPackageCards .cleanPackageCard span{
  color:#536271!important;
}
body.buildPackage206 #cleanBookingGrid .cleanModeCard.cleanOfferCard li::before,
body.buildPackage206 #cleanPackageCards .cleanPackageCard li::before{
  color:var(--warm)!important;
  opacity:1!important;
  -webkit-text-fill-color:var(--warm)!important;
}
body.buildPackage206 #cleanBookingGrid .cleanModeCard.cleanOfferCard.is-active,
body.buildPackage206 #cleanPackageCards .cleanPackageCard.is-active,
html body.buildPackage206 button.cleanModeCard.cleanOfferCard.is-active,
html body.buildPackage206 button.cleanPackageCard.is-active{
  background:linear-gradient(180deg,#fffaf1 0%,#fff4df 100%)!important;
  border:2px solid var(--warm)!important;
  color:var(--navy)!important;
  box-shadow:0 12px 28px rgba(220,111,25,.16)!important;
  transform:none!important;
}
body.buildPackage206 #cleanBookingGrid .cleanModeCard.cleanOfferCard.is-active::after,
body.buildPackage206 #cleanPackageCards .cleanPackageCard.is-active::after,
html body.buildPackage206 button.cleanModeCard.cleanOfferCard.is-active::after,
html body.buildPackage206 button.cleanPackageCard.is-active::after{
  content:'✓';
  position:absolute;
  top:9px;
  right:9px;
  width:25px;
  height:25px;
  border-radius:999px;
  display:grid;
  place-items:center;
  background:var(--warm);
  color:#fff!important;
  -webkit-text-fill-color:#fff!important;
  font-weight:950;
  font-size:14px;
  line-height:1;
  box-shadow:0 8px 18px rgba(220,111,25,.24);
}
html[dir="rtl"] body.buildPackage206 #cleanBookingGrid .cleanModeCard.cleanOfferCard.is-active::after,
html[dir="rtl"] body.buildPackage206 #cleanPackageCards .cleanPackageCard.is-active::after,
html[dir="rtl"] body.buildPackage206 button.cleanModeCard.cleanOfferCard.is-active::after,
html[dir="rtl"] body.buildPackage206 button.cleanPackageCard.is-active::after{
  right:auto;
  left:9px;
}
body.buildPackage206 #cleanBookingGrid .cleanModeCard.cleanOfferCard.is-active strong,
body.buildPackage206 #cleanBookingGrid .cleanModeCard.cleanOfferCard.is-active span,
body.buildPackage206 #cleanBookingGrid .cleanModeCard.cleanOfferCard.is-active li,
body.buildPackage206 #cleanPackageCards .cleanPackageCard.is-active strong,
body.buildPackage206 #cleanPackageCards .cleanPackageCard.is-active span,
body.buildPackage206 #cleanPackageCards .cleanPackageCard.is-active li,
html body.buildPackage206 button.cleanModeCard.cleanOfferCard.is-active *,
html body.buildPackage206 button.cleanPackageCard.is-active *{
  color:var(--navy)!important;
  opacity:1!important;
  -webkit-text-fill-color:var(--navy)!important;
  text-shadow:none!important;
}
body.buildPackage206 #cleanBookingGrid .cleanModeCard.cleanOfferCard.is-active span,
body.buildPackage206 #cleanPackageCards .cleanPackageCard.is-active span{
  color:#415260!important;
  -webkit-text-fill-color:#415260!important;
}
body.buildPackage206 #cleanBookingGrid .cleanModeCard.cleanOfferCard.is-active li::before,
body.buildPackage206 #cleanPackageCards .cleanPackageCard.is-active li::before,
html body.buildPackage206 button.cleanModeCard.cleanOfferCard.is-active li::before,
html body.buildPackage206 button.cleanPackageCard.is-active li::before{
  color:var(--warm)!important;
  opacity:1!important;
  -webkit-text-fill-color:var(--warm)!important;
}
body.buildPackage206 #cleanBookingGrid .cleanModeCard.cleanOfferCard:focus-visible,
body.buildPackage206 #cleanPackageCards .cleanPackageCard:focus-visible{
  outline:3px solid rgba(220,111,25,.26);
  outline-offset:3px;
}
@media(max-width:520px){
  body.buildPackage206 #cleanBookingGrid .cleanModeCard.cleanOfferCard.is-active,
  body.buildPackage206 #cleanPackageCards .cleanPackageCard.is-active{padding-right:42px;}
  html[dir="rtl"] body.buildPackage206 #cleanBookingGrid .cleanModeCard.cleanOfferCard.is-active,
  html[dir="rtl"] body.buildPackage206 #cleanPackageCards .cleanPackageCard.is-active{padding-right:9px;padding-left:42px;}
}

/* Phase 232 localized Build package card parity lock */
body.buildPackage206 .cleanModeCard.cleanOfferCard.is-active,body.buildPackage206 .cleanModeCard.cleanOfferCard[aria-pressed="true"],body.buildPackage206 #cleanBookingGrid .cleanModeCard.is-active,body.buildPackage206 #cleanBookingGrid .cleanModeCard[aria-pressed="true"],html body.buildPackage206 button.cleanModeCard.is-active,html body.buildPackage206 button.cleanModeCard[aria-pressed="true"]{background:#fff8ed!important;background-image:linear-gradient(180deg,#fffaf2,#fff6e8)!important;border:2px solid #df6f1f!important;color:#102b3f!important;box-shadow:0 14px 32px rgba(223,111,31,.16)!important;}
body.buildPackage206 .cleanModeCard.cleanOfferCard.is-active *,body.buildPackage206 .cleanModeCard.cleanOfferCard[aria-pressed="true"] *,body.buildPackage206 #cleanBookingGrid .cleanModeCard.is-active *,body.buildPackage206 #cleanBookingGrid .cleanModeCard[aria-pressed="true"] *,html body.buildPackage206 button.cleanModeCard.is-active *,html body.buildPackage206 button.cleanModeCard[aria-pressed="true"] *{color:#102b3f!important;-webkit-text-fill-color:#102b3f!important;opacity:1!important;text-shadow:none!important;}
body.buildPackage206 .cleanModeCard.cleanOfferCard.is-active span,body.buildPackage206 .cleanModeCard.cleanOfferCard[aria-pressed="true"] span,body.buildPackage206 #cleanBookingGrid .cleanModeCard.is-active span,body.buildPackage206 #cleanBookingGrid .cleanModeCard[aria-pressed="true"] span{color:#4d6070!important;-webkit-text-fill-color:#4d6070!important;}
body.buildPackage206 .cleanModeCard.cleanOfferCard.is-active li::before,body.buildPackage206 .cleanModeCard.cleanOfferCard[aria-pressed="true"] li::before,body.buildPackage206 #cleanBookingGrid .cleanModeCard.is-active li::before,body.buildPackage206 #cleanBookingGrid .cleanModeCard[aria-pressed="true"] li::before{color:#df6f1f!important;-webkit-text-fill-color:#df6f1f!important;opacity:1!important;}
body.buildPackage206 .cleanModeCard.cleanOfferCard.is-active::after,body.buildPackage206 .cleanModeCard.cleanOfferCard[aria-pressed="true"]::after{content:'✓';position:absolute;top:14px;right:14px;width:34px;height:34px;display:grid;place-items:center;border-radius:999px;background:#df6f1f;color:#fff!important;-webkit-text-fill-color:#fff!important;font-weight:950;box-shadow:0 8px 20px rgba(223,111,31,.22);}
html[dir="rtl"] body.buildPackage206 .cleanModeCard.cleanOfferCard.is-active::after,html[dir="rtl"] body.buildPackage206 .cleanModeCard.cleanOfferCard[aria-pressed="true"]::after{right:auto;left:14px;}

/* Phase 241: Build button affordance + interaction lock
   Purpose: make every selectable Build element look and feel tappable without changing Build logic. */
body.buildPackage206 .cleanModeCard,
body.buildPackage206 .cleanPackageCard,
body.buildPackage206 .activityCard,
body.buildPackage206 .guestCounter,
body.buildPackage206 .routeRow,
body.buildPackage206 .cleanDockSummary,
body.buildPackage206 .cleanDockBtn,
body.buildPackage206 .cleanTextBtn,
body.buildPackage206 .inlineAdd,
body.buildPackage206 .cleanSoftBtn,
body.buildPackage206 .slotRow button,
body.buildPackage206 .activityFamilyRail button,
body.buildPackage206 .partChip{
  -webkit-tap-highlight-color:rgba(214,109,34,.18);
}
body.buildPackage206 .cleanModeCard,
body.buildPackage206 .cleanPackageCard{
  position:relative;
  border-width:1.5px!important;
  box-shadow:0 8px 20px rgba(19,40,58,.06), inset 0 -1px 0 rgba(19,40,58,.04)!important;
  transition:transform .14s ease,border-color .14s ease,box-shadow .14s ease,background .14s ease;
  padding-bottom:34px!important;
  user-select:none;
  touch-action:manipulation;
}
body.buildPackage206 .cleanModeCard:hover,
body.buildPackage206 .cleanPackageCard:hover{
  border-color:rgba(214,109,34,.56)!important;
  box-shadow:0 12px 26px rgba(19,40,58,.09),0 0 0 3px rgba(214,109,34,.10)!important;
  transform:translateY(-1px);
}
body.buildPackage206 .cleanModeCard:active,
body.buildPackage206 .cleanPackageCard:active,
body.buildPackage206 .activityCard:active,
body.buildPackage206 .inlineAdd:active,
body.buildPackage206 .cleanDockBtn:active,
body.buildPackage206 .cleanDockSummary:active,
body.buildPackage206 .cleanTextBtn:active,
body.buildPackage206 .slotRow button:active,
body.buildPackage206 .activityFamilyRail button:active,
body.buildPackage206 .guestCounter button:active,
body.buildPackage206 .partChip:active{
  transform:scale(.985);
}
body.buildPackage206 .buildTapCue{
  position:absolute;
  left:10px;
  right:10px;
  bottom:8px;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:22px;
  padding:4px 8px;
  border-radius:999px;
  border:1px solid rgba(19,40,58,.14);
  background:#fffdf8;
  color:var(--navy)!important;
  -webkit-text-fill-color:var(--navy)!important;
  font-style:normal;
  font-size:10.5px;
  line-height:1;
  font-weight:950;
  letter-spacing:.015em;
  pointer-events:none;
}
body.buildPackage206 .cleanModeCard.is-active .buildTapCue,
body.buildPackage206 .cleanModeCard[aria-pressed="true"] .buildTapCue,
body.buildPackage206 .cleanPackageCard.is-active .buildTapCue,
body.buildPackage206 .cleanPackageCard[aria-pressed="true"] .buildTapCue{
  background:var(--warm);
  border-color:var(--warm);
  color:#fff!important;
  -webkit-text-fill-color:#fff!important;
  box-shadow:0 8px 18px rgba(214,109,34,.22);
}
body.buildPackage206 .cleanModeCard.cleanRouteEntry.is-active,
body.buildPackage206 .cleanModeCard.cleanRouteEntry[aria-pressed="true"]{
  background:#fff8ed!important;
  background-image:linear-gradient(180deg,#fffaf2,#fff3e2)!important;
  border:2px solid var(--warm)!important;
  color:var(--navy)!important;
  box-shadow:0 14px 32px rgba(214,109,34,.16)!important;
}
body.buildPackage206 .cleanModeCard.cleanRouteEntry.is-active *,
body.buildPackage206 .cleanModeCard.cleanRouteEntry[aria-pressed="true"] *{
  color:var(--navy)!important;
  -webkit-text-fill-color:var(--navy)!important;
}
body.buildPackage206 .cleanModeCard.cleanRouteEntry.is-active .buildTapCue,
body.buildPackage206 .cleanModeCard.cleanRouteEntry[aria-pressed="true"] .buildTapCue{
  color:#fff!important;
  -webkit-text-fill-color:#fff!important;
}
body.buildPackage206 .activityCard{
  position:relative;
  border-width:1.5px;
  cursor:default;
  transition:transform .14s ease,border-color .14s ease,box-shadow .14s ease,background .14s ease;
  box-shadow:0 8px 20px rgba(19,40,58,.055);
}
body.buildPackage206 .activityCard:hover{
  border-color:rgba(214,109,34,.48);
  box-shadow:0 12px 28px rgba(19,40,58,.08),0 0 0 3px rgba(214,109,34,.08);
}
body.buildPackage206 .activityCard.is-active{
  border:2px solid var(--warm);
  box-shadow:0 14px 32px rgba(214,109,34,.15),0 0 0 3px rgba(214,109,34,.10);
}
body.buildPackage206 .activityCard.has-saved{
  border-color:rgba(17,107,88,.36);
  background:#fbfff9;
}
body.buildPackage206 .activityCardTop .priceChip{
  border:1.5px solid rgba(19,40,58,.22);
  background:#fff;
  box-shadow:0 6px 14px rgba(19,40,58,.06);
}
body.buildPackage206 .inlineAdd.cleanActionBtn{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  min-height:40px;
  width:100%;
  border:1px solid var(--navy);
  box-shadow:0 10px 22px rgba(19,40,58,.16);
  transition:transform .14s ease,box-shadow .14s ease,filter .14s ease;
}
body.buildPackage206 .inlineAdd.cleanActionBtn:hover{
  filter:brightness(1.04);
  box-shadow:0 13px 28px rgba(19,40,58,.20);
}
body.buildPackage206 .inlineAdd.cleanActionBtn small{
  font-size:10.5px;
  line-height:1;
  font-weight:900;
  color:rgba(255,255,255,.82);
}
body.buildPackage206 .inlineSaved{
  border:1.5px solid rgba(17,107,88,.28);
  background:linear-gradient(180deg,#f1fbf7,#e8f7f0);
  box-shadow:0 8px 18px rgba(17,107,88,.08);
}
body.buildPackage206 .inlineSaved span{
  color:var(--good);
  font-weight:950;
}
body.buildPackage206 .inlineSaved button{
  appearance:none;
  border:1px solid rgba(17,107,88,.26);
  background:#fff;
  color:var(--navy);
  border-radius:999px;
  padding:7px 10px;
  font-weight:950;
  cursor:pointer;
}
body.buildPackage206 .cleanDock{
  border-width:1.5px;
  box-shadow:0 18px 50px rgba(19,40,58,.22),0 0 0 1px rgba(255,255,255,.65) inset;
}
body.buildPackage206 .cleanDockSummary{
  border:1.5px solid rgba(214,109,34,.32);
  background:#fff3e2;
  box-shadow:0 6px 16px rgba(214,109,34,.10);
  position:relative;
  padding-right:34px!important;
}
body.buildPackage206 .cleanDockSummary::after{
  content:'▴';
  position:absolute;
  right:12px;
  top:50%;
  transform:translateY(-50%);
  color:var(--warm);
  font-size:13px;
  font-weight:950;
}
html[dir="rtl"] body.buildPackage206 .cleanDockSummary{padding-right:9px!important;padding-left:34px!important;text-align:right;}
html[dir="rtl"] body.buildPackage206 .cleanDockSummary::after{right:auto;left:12px;}
body.buildPackage206 .cleanDockBtn.cleanPrimary{
  background:var(--navy)!important;
  color:#fff!important;
  border:1.5px solid var(--navy)!important;
  box-shadow:0 10px 22px rgba(19,40,58,.22);
  position:relative;
  padding-right:28px!important;
}
body.buildPackage206 .cleanDockBtn.cleanPrimary::after{
  content:'→';
  position:absolute;
  right:11px;
  top:50%;
  transform:translateY(-50%);
  font-weight:950;
}
html[dir="rtl"] body.buildPackage206 .cleanDockBtn.cleanPrimary{padding-right:9px!important;padding-left:28px!important;}
html[dir="rtl"] body.buildPackage206 .cleanDockBtn.cleanPrimary::after{content:'←';right:auto;left:11px;}
body.buildPackage206 .cleanDockBtn:not(.cleanPrimary),
body.buildPackage206 .cleanTextBtn{
  border-width:1.5px;
  box-shadow:0 6px 16px rgba(19,40,58,.08);
}
body.buildPackage206 .guestCounter button,
body.buildPackage206 .slotRow button,
body.buildPackage206 .activityFamilyRail button,
body.buildPackage206 .partChip,
body.buildPackage206 .receiptActions button,
body.buildPackage206 .cleanSoftBtn{
  transition:transform .14s ease,border-color .14s ease,box-shadow .14s ease,background .14s ease;
}
body.buildPackage206 .guestCounter button:hover,
body.buildPackage206 .slotRow button:hover,
body.buildPackage206 .activityFamilyRail button:hover,
body.buildPackage206 .partChip:hover,
body.buildPackage206 .receiptActions button:hover,
body.buildPackage206 .cleanSoftBtn:hover{
  border-color:rgba(214,109,34,.48);
  box-shadow:0 6px 14px rgba(19,40,58,.08);
}
body.buildPackage206 button:focus-visible,
body.buildPackage206 input:focus-visible,
body.buildPackage206 select:focus-visible,
body.buildPackage206 textarea:focus-visible,
body.buildPackage206 .partChip:focus-within{
  outline:3px solid rgba(214,109,34,.30)!important;
  outline-offset:2px!important;
}
@media(max-width:520px){
  body.buildPackage206 .cleanModeCard,
  body.buildPackage206 .cleanPackageCard{padding-bottom:32px!important;}
  body.buildPackage206 .buildTapCue{font-size:10px;min-height:21px;bottom:7px;}
  body.buildPackage206 .inlineAdd.cleanActionBtn{min-height:38px;}
}

/* Phase 242 — receipt UX + location route + activities tray polish */
body.buildPackage206 .routePlannerIntro,
body.buildPackage206 .routeMeter,
body.buildPackage206 .activityTray,
body.buildPackage206 .quoteHero,
body.buildPackage206 .quoteSection,
body.buildPackage206 .quoteActions{
  border:1px solid rgba(19,40,58,.12);
  background:linear-gradient(180deg,#fffaf1,#fff4e2);
  border-radius:18px;
  box-shadow:0 10px 24px rgba(19,40,58,.06);
}
body.buildPackage206 .routePlannerIntro{display:grid;gap:4px;padding:12px;margin-bottom:8px}
body.buildPackage206 .routePlannerIntro strong{font-size:14px;color:var(--navy);font-weight:950;line-height:1.1}
body.buildPackage206 .routePlannerIntro span{font-size:12px;color:var(--muted);font-weight:760;line-height:1.35}
body.buildPackage206 .routeSegment{position:relative;grid-template-columns:34px minmax(0,1fr) 96px 38px;align-items:end}
body.buildPackage206 .routeSegmentBadge{display:grid;place-items:center;width:28px;height:28px;border-radius:50%;background:var(--navy);color:#fff;font-weight:950;font-size:12px;margin-bottom:5px}
body.buildPackage206 .routeMeter{margin-top:8px;padding:10px 12px;display:grid;gap:3px;background:#fff7e8}
body.buildPackage206 .routeMeter b{color:var(--navy);font-size:13px;font-weight:950}
body.buildPackage206 .routeMeter span{font-size:12px;line-height:1.3;color:var(--muted);font-weight:760}
body.buildPackage206 .routeMeter.is-ok{border-color:rgba(15,116,84,.25);background:#f0fff7}
body.buildPackage206 .routeMeter.is-ok span{color:#17684e}
body.buildPackage206 .routeMeter.is-warn{border-color:rgba(255,122,24,.4);background:#fff3df}
body.buildPackage206 .activityTray{padding:11px;display:grid;gap:9px;grid-column:1/-1;background:#fff8ea}
body.buildPackage206 .activityTrayHead{display:flex;justify-content:space-between;gap:10px;align-items:center}
body.buildPackage206 .activityTrayHead strong{color:var(--navy);font-weight:950;font-size:14px}
body.buildPackage206 .activityTrayHead span{border:1px solid rgba(19,40,58,.12);border-radius:999px;padding:4px 8px;background:#fff;color:var(--muted);font-size:11px;font-weight:850}
body.buildPackage206 .activityTray p{margin:0;color:var(--muted);font-size:12px;line-height:1.35;font-weight:760}
body.buildPackage206 .activityTrayList{display:grid;gap:7px}
body.buildPackage206 .activityTrayItem{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:center;border:1px solid rgba(19,40,58,.1);border-radius:14px;background:#fff;padding:8px}
body.buildPackage206 .activityTrayItem b{display:block;color:var(--navy);font-size:12.5px;line-height:1.15;font-weight:950}
body.buildPackage206 .activityTrayItem span{display:block;color:var(--muted);font-size:11px;line-height:1.25;font-weight:760;margin-top:2px}
body.buildPackage206 .activityTrayItem div:last-child{display:flex;gap:5px;flex-wrap:wrap;justify-content:flex-end}
body.buildPackage206 .activityTrayItem button,
body.buildPackage206 .quoteActions button{border:1px solid rgba(19,40,58,.14);border-radius:999px;background:#fff;color:var(--navy);font-weight:900;font-size:11px;padding:6px 9px;cursor:pointer}
body.buildPackage206 .activityTrayItem button:hover,
body.buildPackage206 .quoteActions button:hover{border-color:rgba(255,122,24,.45);box-shadow:0 8px 18px rgba(19,40,58,.08)}
body.buildPackage206 .inlineSaved{grid-template-columns:minmax(0,1fr) auto auto;align-items:center}
body.buildPackage206 .inlineSaved button{min-height:28px}
body.buildPackage206 .quoteHero{padding:14px;display:grid;gap:3px;background:linear-gradient(135deg,var(--navy),#1e435c);color:#fff;border-color:transparent}
body.buildPackage206 .quoteHero span{font-size:11px;text-transform:uppercase;letter-spacing:.12em;font-weight:900;color:rgba(255,255,255,.72)}
body.buildPackage206 .quoteHero strong{font-size:30px;line-height:1;color:#fff;font-weight:950}
body.buildPackage206 .quoteHero small{font-size:12px;line-height:1.3;color:rgba(255,255,255,.8);font-weight:760}
body.buildPackage206 .quoteSection{padding:12px;display:grid;gap:8px;background:#fffaf0}
body.buildPackage206 .quoteSection h3{margin:0;color:var(--navy);font-size:13px;font-weight:950;letter-spacing:-.01em}
body.buildPackage206 .quoteLine{display:grid;gap:3px}
body.buildPackage206 .quoteLine b{color:var(--navy);font-size:14px;font-weight:950}
body.buildPackage206 .quoteLine span,
body.buildPackage206 .quoteLine em{color:var(--muted);font-size:12px;line-height:1.3;font-weight:780;font-style:normal}
body.buildPackage206 .quoteList{display:grid;gap:6px;margin:0;padding:0;list-style:none}
body.buildPackage206 .quoteList li{display:grid;grid-template-columns:auto minmax(0,1fr);gap:8px;align-items:center;border:1px solid rgba(19,40,58,.08);border-radius:12px;background:#fff;padding:8px;color:var(--navy)}
body.buildPackage206 .quoteList li span{font-size:11px;color:var(--warm);font-weight:950}
body.buildPackage206 .quoteList li b{font-size:12px;color:var(--navy);font-weight:900;line-height:1.25}
body.buildPackage206 .routeQuoteList li{grid-template-columns:90px minmax(0,1fr)}
body.buildPackage206 .quoteActivitiesSection .receiptRows{gap:8px}
body.buildPackage206 .quoteTotal{margin-top:0;background:var(--navy)!important;border-color:var(--navy)!important}
body.buildPackage206 .quoteActions{display:flex;gap:8px;justify-content:space-between;padding:9px;background:#fff7e8}
body.buildPackage206 .quoteActions button:first-child{background:var(--navy);border-color:var(--navy);color:#fff}
html[dir="rtl"] body.buildPackage206 .routeSegment{grid-template-columns:34px minmax(0,1fr) 96px 38px}
html[dir="rtl"] body.buildPackage206 .activityTrayItem{text-align:right}
@media(max-width:620px){
  body.buildPackage206 .routeSegment{grid-template-columns:30px minmax(0,1fr) 82px 34px;gap:6px}
  body.buildPackage206 .routeSegmentBadge{width:25px;height:25px;font-size:11px}
  body.buildPackage206 .activityTrayItem{grid-template-columns:1fr}
  body.buildPackage206 .activityTrayItem div:last-child{justify-content:flex-start}
  body.buildPackage206 .quoteHero strong{font-size:26px}
  body.buildPackage206 .quoteActions{flex-direction:column}
  body.buildPackage206 .quoteActions button{width:100%;min-height:36px}
}


/* Phase 243 — Build UX completion + pricing eligibility lock */
body.buildPackage206 .cleanStepHint,
body.buildPackage206 .cleanEligibilityNote{
  margin:0 0 10px;
  padding:10px 12px;
  border:1px solid rgba(214,109,34,.22);
  border-radius:16px;
  background:#fff7e8;
  color:var(--muted);
  font-size:12px;
  line-height:1.35;
  font-weight:780;
}
body.buildPackage206 .cleanEligibilityNote{margin-top:8px;background:#f9fcff;border-color:rgba(19,40,58,.12)}
body.buildPackage206 .cleanDateGuestGrid{margin-bottom:10px}
body.buildPackage206 .quoteActivityList{display:grid;gap:8px}
body.buildPackage206 .quoteActivityRow{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:10px;
  align-items:start;
  border:1px solid rgba(19,40,58,.1);
  border-radius:14px;
  background:#fff;
  padding:10px;
}
body.buildPackage206 .quoteActivityRow b{display:block;color:var(--navy);font-size:13px;font-weight:950;line-height:1.15}
body.buildPackage206 .quoteActivityRow span,
body.buildPackage206 .quoteActivityRow small{display:block;margin-top:3px;color:var(--muted);font-size:11px;line-height:1.3;font-weight:760}
body.buildPackage206 .quoteActivityRow strong{color:var(--navy);font-size:12px;font-weight:950;white-space:nowrap}
body.buildPackage206 .quoteHint{margin:0;color:var(--muted);font-size:11px;line-height:1.35;font-weight:760}
body.buildPackage206 .cleanDock{grid-template-columns:minmax(0,1fr) auto auto}
body.buildPackage206 .cleanDock .cleanTextBtn{display:none!important}
body.buildPackage206 .cleanPackageChoiceGrid:empty{display:none!important}
@media(max-width:620px){
  body.buildPackage206 .quoteActivityRow{grid-template-columns:1fr}
  body.buildPackage206 .quoteActivityRow strong{justify-self:start}
  body.buildPackage206 .cleanDock{grid-template-columns:1fr 1fr}
  body.buildPackage206 .cleanDockSummary{grid-column:1 / -1}
}

/* Phase 272 — Build visual safety only; no logic changes */
body.buildV3Active{font-family:var(--tgz-font-body,"Inter",system-ui)}
body.buildV3Active :is(h1,h2,h3,.buildStepTitle){font-family:var(--tgz-font-head,"Inter Tight",system-ui)}
body.buildV3Active :is(.btn,.buildBtn,.buildChoice,.buildOptionCard,.buildWizardActionBar button){overflow-wrap:anywhere;hyphens:auto;line-height:1.08;text-wrap:balance}
body.buildV3Active :is(.buildChoice,.buildOptionCard,.buildSummarySheet,.buildInlineEstimate,.buildWizardTopBar){border-radius:16px;border-color:var(--tgz-sand,#eadfce)}
@media(max-width:720px){body.buildV3Active :is(.buildWizardActionBar button,.btn,.buildBtn){min-height:34px;font-size:.74rem;padding:.5rem .7rem}}
