/* ═══════════════════════════════════════════════════════════════
   Cam-Itinerary — Transport Detail page styles (Sambor tokens)
   Complements stay-detail.css (reuses .sd-wrap, .sd-gallery, .sd-head,
   .sd-section, .amen-grid, .rules-grid, .sd-map, .rev-*, .sd-book,
   .bw-*, .sd-stickybar, .sd-lightbox).
   ═══════════════════════════════════════════════════════════════ */

/* Two-column: content + sticky booking widget */
.td-wrap { max-width: 1200px; margin: 0 auto; padding: 8px 32px 96px; }
.td-cols { display: grid; grid-template-columns: 1fr 360px; gap: 40px; align-items: start; }
@media (max-width: 1040px) { .td-cols { grid-template-columns: 1fr; gap: 8px; } .td-book-col { display: none; } }
.td-main { min-width: 0; max-width: 760px; }

/* Spec strip under the title */
.td-specs { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin: 22px 0 4px; }
@media (max-width: 680px) { .td-specs { grid-template-columns: repeat(2, 1fr); } }
.td-spec { display: flex; align-items: center; gap: 12px; padding: 14px 16px; border: 1px solid var(--color-gray-100); border-radius: var(--radius-lg); background: white; }
.td-spec .ts-ic { width: 40px; height: 40px; border-radius: var(--radius-md); background: var(--color-forest-50); color: var(--color-forest-700); display: grid; place-items: center; flex-shrink: 0; }
.td-spec .ts-ic svg { width: 21px; height: 21px; stroke-width: 1.85; }
.td-spec .ts-k { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: var(--tracking-sub); color: var(--fg-3); }
.td-spec .ts-v { font-size: 14px; font-weight: 800; color: var(--fg-1); line-height: 1.25; }

/* Included / not-included list */
.td-incl { display: grid; grid-template-columns: 1fr 1fr; gap: 10px 26px; }
@media (max-width: 680px) { .td-incl { grid-template-columns: 1fr; } }
.td-incl .li { display: flex; align-items: flex-start; gap: 10px; font-size: 14px; color: var(--fg-1); line-height: 1.45; }
.td-incl .li svg { width: 18px; height: 18px; flex-shrink: 0; margin-top: 1px; stroke-width: 2.6; }
.td-incl .li.yes svg { color: var(--color-forest-500); }
.td-incl .li.no { color: var(--fg-3); }
.td-incl .li.no svg { color: var(--color-gray-400); }

/* How it works — step chevrons */
.td-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
@media (max-width: 680px) { .td-steps { grid-template-columns: 1fr 1fr; } }
.td-step { position: relative; padding: 18px 16px; border: 1px solid var(--color-gray-100); border-radius: var(--radius-lg); background: white; }
.td-step .st-n { width: 30px; height: 30px; border-radius: var(--radius-md); background: var(--bg-brand); color: var(--fg-on-forest); display: grid; place-items: center; font-family: var(--font-display); font-weight: 800; font-size: 14px; margin-bottom: 12px; }
.td-step .st-t { font-weight: 800; font-size: 14px; margin: 0 0 5px; letter-spacing: -0.01em; }
.td-step .st-d { font-size: 12.5px; color: var(--fg-2); line-height: 1.5; }

/* Driver / operator strip */
.td-host { display: flex; align-items: center; gap: 16px; padding: 18px; border: 1px solid var(--color-gray-100); border-radius: var(--radius-xl); background: var(--bg-sunken); }
.td-host .th-av { width: 56px; height: 56px; border-radius: 999px; background-size: cover; background-position: center; flex-shrink: 0; box-shadow: var(--shadow-1); }
.td-host .th-n { font-family: var(--font-display); font-weight: 800; font-size: 16px; letter-spacing: -0.01em; display: flex; align-items: center; gap: 7px; }
.td-host .th-n .vf { display: inline-flex; color: var(--color-forest-600); }
.td-host .th-n .vf svg { width: 16px; height: 16px; fill: var(--color-forest-50); stroke: var(--color-forest-500); }
.td-host .th-s { font-size: 13px; color: var(--fg-2); margin-top: 2px; }
.td-host .th-meta { margin-left: auto; text-align: right; }
.td-host .th-meta .r { font-family: var(--font-display); font-weight: 800; font-size: 17px; display: inline-flex; align-items: center; gap: 5px; }
.td-host .th-meta .r svg { width: 15px; height: 15px; fill: var(--color-amber-500); }
.td-host .th-meta .c { font-size: 12px; color: var(--fg-3); }
@media (max-width: 680px) { .td-host .th-meta { margin-left: 0; } }

/* Booking widget extras */
.sd-book .bw-head { font-family: var(--font-display); font-weight: 800; font-size: 16px; margin: 0 0 14px; letter-spacing: -0.01em; }
.bw-note { font-size: 12px; color: var(--fg-3); line-height: 1.5; margin: 12px 2px 0; text-align: center; }

/* Back link */
.td-back { display: inline-flex; align-items: center; gap: 7px; font-size: 13.5px; font-weight: 700; color: var(--color-forest-600); margin: 2px 0 4px; }
.td-back svg { width: 16px; height: 16px; stroke-width: 2.2; }
