/* Signature Tours Morocco — Tailor-Made Builder (matches site / #tb) */
.ttb-root {
  --ttb-terra: #C44B27;
  --ttb-terra-dark: #8B3520;
  --ttb-cream: #F9F5F0;
  --ttb-ink: #1a1a1a;
  --ttb-muted: #888;
  --ttb-border: #e5ddd4;
  --ttb-white: #fff;
  --ttb-serif: 'ivypresto-display', 'Playfair Display', Georgia, serif;
  font-family: 'Kanit', 'Helvetica Neue', sans-serif;
  color: var(--ttb-ink);
  background: var(--ttb-cream);
  margin: 0 calc(50% - 50vw);
  width: 100vw;
  max-width: 100vw;
  min-height: 60vh;
  padding-bottom: 88px;
  box-sizing: border-box;
}

.ttb-root *,
.ttb-root *::before,
.ttb-root *::after {
  box-sizing: border-box;
}

/* ── Hero (same language as homepage / old #tb) ── */
.ttb-hero {
  background: linear-gradient(135deg, #1a1a1a 0%, #3a1508 50%, var(--ttb-terra-dark) 100%);
  padding: 56px 40px 48px;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.ttb-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  opacity: 0.5;
}

.ttb-hero-inner {
  position: relative;
  z-index: 1;
  max-width: 720px;
  margin: 0 auto;
}

.ttb-eyebrow {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 3px;
  color: rgba(255, 255, 255, 0.55);
  margin: 0 0 14px;
  font-weight: 500;
}

.ttb-hero-title,
.ttb-hero h1.ttb-hero-title,
.ttb-root .ttb-hero .ttb-hero-title {
  font-family: var(--ttb-serif);
  font-size: clamp(30px, 5vw, 42px);
  font-weight: 400;
  color: #ffffff !important;
  line-height: 1.2;
  margin: 0 0 14px;
}

.ttb-hero-sub {
  font-size: 15px;
  color: rgba(255, 255, 255, 0.72);
  font-weight: 300;
  line-height: 1.7;
  max-width: 560px;
  margin: 0 auto 28px;
}

.ttb-trust {
  display: flex;
  justify-content: center;
  gap: 28px;
  flex-wrap: wrap;
}

.ttb-trust-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  color: rgba(255, 255, 255, 0.65);
  font-weight: 400;
}

.ttb-trust-item svg {
  color: var(--ttb-terra);
  flex-shrink: 0;
}

@media (max-width: 768px) {
  .ttb-hero {
    padding: 40px 20px 36px;
  }
}

/* ── Step progress (site #tb style) ── */
.ttb-progress {
  background: var(--ttb-white);
  border-bottom: 1px solid var(--ttb-border);
  padding: 0 40px;
  position: sticky;
  top: 0;
  z-index: 200;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.05);
}

.ttb-steps {
  max-width: 860px;
  margin: 0 auto;
  display: flex;
  align-items: stretch;
}

.ttb-step-dot {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 14px 8px 12px;
  gap: 5px;
  position: relative;
}

.ttb-step-dot:not(:last-child)::after {
  content: '';
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 1px;
  height: 28px;
  background: var(--ttb-border);
}

.ttb-dot {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 2px solid var(--ttb-border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 700;
  color: #aaa;
  background: var(--ttb-white);
  transition: all 0.3s;
}

.ttb-step-dot.active .ttb-dot {
  background: var(--ttb-terra);
  border-color: var(--ttb-terra);
  color: #fff;
}

.ttb-step-dot.done .ttb-dot {
  background: var(--ttb-ink);
  border-color: var(--ttb-ink);
  color: #fff;
}

.ttb-dot-lbl {
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: #aaa;
  white-space: nowrap;
}

.ttb-step-dot.active .ttb-dot-lbl {
  color: var(--ttb-terra);
  font-weight: 600;
}

.ttb-step-dot.done .ttb-dot-lbl {
  color: var(--ttb-ink);
}

.ttb-dot-check {
  display: none;
}

.ttb-step-dot.done .ttb-dot-check {
  display: block;
}

.ttb-step-dot.done .ttb-dot-num {
  display: none;
}

@media (max-width: 768px) {
  .ttb-progress {
    padding: 0 8px;
  }

  .ttb-dot-lbl {
    font-size: 8px;
  }
}

/* ── Layout ── */
.ttb-layout {
  display: grid;
  grid-template-columns: 1fr 260px;
  gap: 32px;
  max-width: 960px;
  margin: 0 auto;
  padding: 36px 32px 0;
  align-items: start;
}

@media (max-width: 900px) {
  .ttb-layout {
    grid-template-columns: 1fr;
    padding: 24px 16px 0;
  }

  .ttb-sidebar {
    order: -1;
    position: static !important;
  }
}

/* ── Panels ── */
.ttb-panel {
  display: none;
}

.ttb-panel.on {
  display: block;
  animation: ttbFadeIn 0.3s ease;
}

.ttb-panel.leaving {
  animation: ttbFadeOut 0.15s ease forwards;
}

@keyframes ttbFadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes ttbFadeOut {
  from { opacity: 1; }
  to { opacity: 0; }
}

.ttb-panel-head {
  margin-bottom: 28px;
}

.ttb-panel-head h2 {
  font-family: var(--ttb-serif);
  font-size: 28px;
  font-weight: 700;
  margin: 0 0 6px;
  color: var(--ttb-ink);
  position: relative;
  padding-left: 18px;
}

.ttb-panel-head h2::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.45em;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--ttb-terra);
}

.ttb-panel-head p {
  color: var(--ttb-muted);
  font-size: 13px;
  font-weight: 300;
  line-height: 1.6;
  margin: 0;
}

.ttb-sec-label {
  display: block;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  color: var(--ttb-muted);
  font-weight: 600;
  margin: 20px 0 12px;
}

/* ── Destination cards (editorial black / terra) ── */
.ttb-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}

@media (max-width: 900px) {
  .ttb-cards {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 480px) {
  .ttb-cards {
    grid-template-columns: 1fr;
  }
}

.ttb-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
  padding: 18px 16px;
  border: 2px solid #2a2a2a;
  border-radius: 6px;
  background: var(--ttb-ink);
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s, transform 0.2s;
  text-align: left;
  font-family: inherit;
  color: #fff;
}

.ttb-card:hover {
  border-color: var(--ttb-terra);
  transform: translateY(-2px);
}

.ttb-card.sel {
  border-color: rgba(255, 255, 255, 0.35);
  background: var(--ttb-terra);
}

.ttb-card-icon {
  width: 44px;
  height: 44px;
  border-radius: 8px;
  background: #fff;
  border: 1px solid var(--ttb-border);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ttb-terra);
}

.ttb-card.sel .ttb-card-icon {
  background: rgba(255, 255, 255, 0.15);
  border-color: rgba(255, 255, 255, 0.4);
  color: #fff;
}

.ttb-card-icon .ttb-svg {
  width: 24px;
  height: 24px;
}

.ttb-card strong {
  font-family: var(--ttb-serif);
  font-size: 15px;
  font-weight: 600;
  color: #fff;
}

.ttb-card-desc {
  font-size: 11px;
  color: rgba(255, 255, 255, 0.62);
  line-height: 1.45;
}

.ttb-card.sel .ttb-card-desc {
  color: rgba(255, 255, 255, 0.85);
}

.ttb-shake {
  animation: ttbShake 0.45s ease;
}

@keyframes ttbShake {
  0%, 100% { transform: translateX(0); }
  25% { transform: translateX(-6px); }
  75% { transform: translateX(6px); }
}

/* ── Duration ── */
.ttb-duration-wrap {
  background: var(--ttb-white);
  border: 1.5px solid var(--ttb-border);
  border-radius: 6px;
  padding: 28px 24px;
  text-align: center;
  margin-bottom: 20px;
}

.ttb-range {
  width: 100%;
  accent-color: var(--ttb-terra);
  margin-bottom: 12px;
}

.ttb-duration-display {
  font-size: 16px;
  color: var(--ttb-ink);
}

.ttb-duration-display strong {
  font-family: var(--ttb-serif);
  font-size: 36px;
  color: var(--ttb-terra);
  font-weight: 600;
}

/* ── Style chips (site style-row) ── */
.ttb-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 8px;
}

.ttb-chip {
  padding: 10px 18px;
  border: 2px solid var(--ttb-border);
  border-radius: 30px;
  background: var(--ttb-white);
  font-size: 12px;
  font-weight: 500;
  color: #555;
  cursor: pointer;
  transition: all 0.2s;
  font-family: inherit;
}

.ttb-chip:hover {
  border-color: var(--ttb-terra);
  color: var(--ttb-terra);
}

.ttb-chip.sel {
  background: var(--ttb-terra);
  border-color: var(--ttb-terra);
  color: #fff;
}

/* ── Activities ── */
.ttb-checks {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 10px;
  margin-bottom: 8px;
}

.ttb-check {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 16px;
  border: 1.5px solid var(--ttb-border);
  border-radius: 6px;
  background: var(--ttb-white);
  cursor: pointer;
  font-size: 13px;
  transition: border-color 0.2s;
}

.ttb-check:hover {
  border-color: var(--ttb-terra);
}

.ttb-check input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.ttb-check-box {
  width: 18px;
  height: 18px;
  border: 2px solid var(--ttb-border);
  border-radius: 3px;
  flex-shrink: 0;
  position: relative;
}

.ttb-check input:checked + .ttb-check-box {
  background: var(--ttb-terra);
  border-color: var(--ttb-terra);
}

.ttb-check input:checked + .ttb-check-box::after {
  content: '';
  position: absolute;
  left: 5px;
  top: 2px;
  width: 5px;
  height: 9px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

.ttb-check-text {
  flex: 1;
  font-weight: 500;
}

.ttb-check-price {
  font-size: 11px;
  color: var(--ttb-terra);
  font-weight: 600;
}

/* ── Transport grid (#tb tp-card) ── */
.ttb-tp-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 12px;
}

.ttb-tp-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  padding: 16px 14px;
  border: 2px solid var(--ttb-border);
  border-radius: 6px;
  background: var(--ttb-white);
  cursor: pointer;
  text-align: left;
  font-family: inherit;
  color: inherit;
  transition: all 0.2s;
}

.ttb-tp-card:hover {
  border-color: var(--ttb-terra);
  box-shadow: 0 4px 16px rgba(196, 75, 39, 0.1);
}

.ttb-tp-card.sel {
  border-color: var(--ttb-terra);
  background: #fdf3ee;
  box-shadow: 0 0 0 3px rgba(196, 75, 39, 0.1);
}

.ttb-tp-icon {
  width: 52px;
  height: 52px;
  border-radius: 12px;
  background: #fff;
  border: 1px solid var(--ttb-border);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ttb-terra);
}

.ttb-tp-card.sel .ttb-tp-icon {
  border-color: var(--ttb-terra);
}

.ttb-tp-icon .ttb-svg {
  width: 26px;
  height: 26px;
}

.ttb-tp-name {
  font-family: var(--ttb-serif);
  font-size: 14px;
  font-weight: 600;
  color: var(--ttb-ink);
}

.ttb-tp-desc {
  font-size: 11px;
  color: var(--ttb-muted);
  line-height: 1.4;
}

/* ── Form fields ── */
.ttb-field {
  margin-bottom: 16px;
}

.ttb-field label {
  display: block;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--ttb-muted);
  margin-bottom: 6px;
  font-weight: 600;
}

.ttb-input,
.ttb-select {
  width: 100%;
  padding: 10px 12px;
  border: 1.5px solid var(--ttb-border);
  border-radius: 6px;
  font-family: inherit;
  font-size: 14px;
  color: var(--ttb-ink);
  background: var(--ttb-white);
  outline: none;
  transition: border-color 0.2s;
}

.ttb-input:focus,
.ttb-select:focus {
  border-color: var(--ttb-terra);
}

.ttb-form-card {
  background: var(--ttb-white);
  border: 1.5px solid var(--ttb-border);
  border-radius: 6px;
  padding: 22px 24px;
}

.ttb-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

@media (max-width: 600px) {
  .ttb-form-row {
    grid-template-columns: 1fr;
  }
}

.ttb-form-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 8px;
  padding-top: 16px;
  border-top: 1px solid var(--ttb-border);
}

/* ── Sidebar ── */
.ttb-sidebar {
  background: var(--ttb-white);
  border: 1.5px solid var(--ttb-border);
  border-radius: 6px;
  padding: 20px 18px;
  position: sticky;
  top: 72px;
}

.ttb-sidebar h3 {
  font-family: var(--ttb-serif);
  font-size: 17px;
  margin: 0 0 14px;
  font-weight: 600;
}

.ttb-summary {
  margin: 0 0 14px;
  font-size: 13px;
}

.ttb-summary dt {
  color: var(--ttb-muted);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  margin-top: 10px;
  font-weight: 600;
}

.ttb-summary dt:first-child {
  margin-top: 0;
}

.ttb-summary dd {
  margin: 2px 0 0;
  font-weight: 500;
}

.ttb-sidebar-price {
  border-top: 1px solid var(--ttb-border);
  padding-top: 14px;
}

.ttb-sidebar-price span {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--ttb-muted);
  font-weight: 600;
  display: block;
  margin-bottom: 4px;
}

.ttb-sidebar-price strong {
  font-family: var(--ttb-serif);
  font-size: 28px;
  color: var(--ttb-terra);
  font-weight: 600;
}

/* ── Itinerary ── */
.ttb-itinerary {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 22px;
}

.ttb-day {
  display: flex;
  gap: 14px;
  background: var(--ttb-white);
  border: 1.5px solid var(--ttb-border);
  border-radius: 6px;
  padding: 16px 18px;
}

.ttb-day-num {
  flex-shrink: 0;
  min-width: 48px;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-weight: 600;
  color: var(--ttb-terra);
  padding-top: 2px;
}

.ttb-day-body h4 {
  font-family: var(--ttb-serif);
  font-size: 16px;
  margin: 0 0 8px;
  font-weight: 600;
}

.ttb-day-body ul {
  margin: 0;
  padding: 0 0 0 16px;
  font-size: 13px;
  color: #555;
  line-height: 1.6;
}

/* ── Price (cream card, not gradient) ── */
.ttb-price-box {
  background: var(--ttb-white);
  border: 1.5px solid var(--ttb-border);
  border-left: 4px solid var(--ttb-terra);
  border-radius: 6px;
  padding: 20px 24px;
  margin-bottom: 22px;
}

.ttb-price-label {
  display: block;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  color: var(--ttb-muted);
  font-weight: 600;
  margin-bottom: 4px;
}

.ttb-price-value {
  display: block;
  font-family: var(--ttb-serif);
  font-size: 36px;
  font-weight: 600;
  color: var(--ttb-terra);
  margin-bottom: 6px;
}

.ttb-price-note {
  font-size: 12px;
  color: var(--ttb-muted);
  font-weight: 300;
  line-height: 1.5;
}

/* ── Buttons (site CTA: 6px radius, outline secondary) ── */
.ttb-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  height: 42px;
  padding: 0 22px;
  border-radius: 6px;
  font-family: inherit;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.3px;
  cursor: pointer;
  border: none;
  text-decoration: none;
  transition: all 0.2s;
  white-space: nowrap;
}

.ttb-btn-primary {
  background: var(--ttb-terra);
  color: #fff;
}

.ttb-btn-primary:hover {
  background: var(--ttb-terra-dark);
  color: #fff;
}

.ttb-btn-primary:disabled {
  background: #ccc;
  cursor: default;
}

.ttb-btn-back {
  background: var(--ttb-white);
  color: #555;
  border: 1.5px solid var(--ttb-border);
}

.ttb-btn-back:hover {
  border-color: var(--ttb-ink);
  color: var(--ttb-ink);
}

.ttb-btn-outline {
  background: transparent;
  color: var(--ttb-terra);
  border: 2px solid var(--ttb-terra);
}

.ttb-btn-outline:hover {
  background: var(--ttb-terra);
  color: #fff;
}

/* ── Fixed bottom nav (#tb-nav) ── */
.ttb-nav {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 300;
  background: var(--ttb-white);
  border-top: 1px solid var(--ttb-border);
  padding: 12px 40px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.07);
}

.ttb-nav-info {
  font-size: 11px;
  color: #aaa;
  text-align: center;
  flex: 1;
  padding: 0 12px;
}

@media (max-width: 600px) {
  .ttb-nav {
    padding: 10px 14px;
  }

  .ttb-nav-info {
    display: none;
  }
}

/* ── Success ── */
.ttb-success {
  display: none;
  max-width: 520px;
  margin: 50px auto 90px;
  padding: 0 20px;
  text-align: center;
}

.ttb-success:not([hidden]) {
  display: block;
}

.ttb-success-ring {
  width: 70px;
  height: 70px;
  border-radius: 50%;
  background: #fdf3ee;
  border: 2px solid var(--ttb-terra);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 24px;
  color: var(--ttb-terra);
}

.ttb-success h2 {
  font-family: var(--ttb-serif);
  font-size: 28px;
  margin: 0 0 10px;
}

.ttb-success p {
  font-size: 14px;
  color: #555;
  font-weight: 300;
  line-height: 1.75;
  margin: 0 0 20px;
}
