
/* ── PAGE HERO VIDEO BACKGROUND ── */
.page-hero--video {
  position: relative;
  overflow: hidden;
  min-height: 100vh !important;
  height: auto !important;
}

.page-hero__video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  z-index: 0;
  pointer-events: none;
}

.page-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(10, 5, 2, 0.25) 0%,    /* Was 0.50 — lighter top */
    rgba(10, 5, 2, 0.40) 60%,   /* Was 0.65 — lighter middle */
    rgba(10, 5, 2, 0.55) 100%   /* Was 0.75 — lighter bottom */
  );
  z-index: 1;
}

/* Text white + center */
.page-hero--video .container {
  text-align: center !important;
}

.page-hero--video .page-hero-label,
.page-hero--video h1,em,
.page-hero--video p {
  color: #ffffff !important;
  text-shadow: 0 1px 6px rgba(0,0,0,0.4);
}

/* Breadcrumb specifically left */
.page-hero--video .breadcrumb,
.page-hero--video .tll-breadcrumb,
.page-hero--video nav.breadcrumb,
.page-hero--video .container > *:first-child {
  text-align: left !important;
  margin-top: 24px !important;
  margin-bottom: 28px !important;
  display: block !important;
}

/* Mobile */
@media (max-width: 768px) {
  .page-hero--video {
    min-height: 70vh !important;
  }
}

@media (max-width: 480px) {
  .page-hero--video {
    min-height: 60vh !important;
  }
}
/* ═══════════════════════════════════════════
   TLL CITY CRAFT SECTION — Premium White
═══════════════════════════════════════════ */

.tll-city-craft-section {
  background: #ffffff;
  width: 100%;
  overflow: hidden;
  margin-top: 60px;
  margin-bottom: 60px;
  border-top: 1px solid rgba(201,169,110,0.25);
  border-bottom: 1px solid rgba(201,169,110,0.25);
}

.tll-city-craft-wrap {
  width: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 88vh;
  position: relative;
}

.tll-city-craft-wrap::after {
  content: '';
  position: absolute;
  left: 50%;
  top: 5%;
  transform: translateX(-50%);
  width: 1px;
  height: 90%;
  background: linear-gradient(to bottom, transparent, #60091A, transparent);
  z-index: 1;
  pointer-events: none;
}

.tll-city-craft-content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding: 60px 64px;
  position: relative;
  z-index: 2;
}

.tll-city-craft-eyebrow {
  font-size: 10px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: #60091A;
  margin-bottom: 16px;
  font-weight: 700;
}

.tll-city-craft-title {
  font-family: var(--font-display, Georgia, serif);
  font-size: clamp(28px, 3vw, 46px);
  line-height: 1.1;
  letter-spacing: -0.01em;
  color: #101010;
  margin: 0 0 20px;
  font-weight: 400;
}

.tll-city-craft-title em {
  font-style: italic;
  color: #60091A;
  font-weight: 300;
  display: block;
}

.tll-city-craft-ornament {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0 auto 22px;
}

.tll-city-craft-ornament span {
  display: block;
  width: 48px;
  height: 1px;
  background:#7E4939;
}

.tll-city-craft-ornament span:last-child {
  background: linear-gradient(to left, transparent, #ffffff);
}

.tll-city-craft-ornament svg {
  flex-shrink: 0;
}

.tll-city-craft-text p {
  font-size: 15px;
  line-height: 1.7;
  color: #60091A;
  margin: 0 0 10px;
  max-width: 520px;
}

.tll-city-craft-text p:last-child {
  margin-bottom: 0;
}

.tll-city-craft-media {
  position: relative;
  z-index: 2;
  padding: 40px 40px 40px 32px;
  display: flex;
  align-items: center;
}

.tll-city-craft-media-inner {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 500px;
  overflow: hidden;
  
}

.tll-city-craft-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  position: absolute;
  inset: 0;
}

@media (max-width: 1024px) {
  .tll-city-craft-section {
    margin-top: 40px;
    margin-bottom: 40px;
  }
  .tll-city-craft-wrap {
    grid-template-columns: 1fr;
    min-height: auto;
  }
  .tll-city-craft-wrap::after {
    display: none;
  }
  .tll-city-craft-content {
    padding: 48px 48px 36px;
    order: 1;
  }
  .tll-city-craft-media {
    order: 2;
    padding: 0 32px 48px;
    min-height: 420px;
  }
  .tll-city-craft-media-inner {
    min-height: 420px;
  }
}

@media (max-width: 768px) {
  .tll-city-craft-section {
    margin-top: 28px;
    margin-bottom: 28px;
  }
  .tll-city-craft-content {
    padding: 36px 24px 28px;
    order: 1;
  }
  .tll-city-craft-title {
    font-size: clamp(24px, 7vw, 34px);
  }
  .tll-city-craft-eyebrow {
    font-size: 9px;
    letter-spacing: 4px;
    margin-bottom: 12px;
  }
  .tll-city-craft-ornament {
    margin-bottom: 18px;
  }
  .tll-city-craft-ornament span {
    width: 32px;
  }
  .tll-city-craft-text p {
    font-size: 13px;
    line-height: 1.65;
    margin-bottom: 8px;
  }
  .tll-city-craft-media {
    order: 2;
    padding: 0 16px 36px;
    min-height: 0;
  }
  .tll-city-craft-media-inner {
    min-height: 0;
    padding-bottom: 75%;
    height: 0;
  }
  .tll-city-craft-video {
    position: absolute;
    inset: 0;
    height: 100%;
  }
}

@media (max-width: 480px) {
  .tll-city-craft-section {
    margin-top: 20px;
    margin-bottom: 20px;
  }
  .tll-city-craft-content {
    padding: 28px 16px 24px;
  }
  .tll-city-craft-title {
    font-size: clamp(22px, 6.5vw, 28px);
  }
  .tll-city-craft-media {
    padding: 0 12px 28px;
  }
  .tll-city-craft-media-inner {
    padding-bottom: 80%;
  }
  .tll-city-craft-text p {
    font-size: 12.5px;
  }
}
/* ============================================================================
   18. CITY GRID
   ============================================================================ */
.city-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.city-card { background: var(--white); border-radius: 16px; overflow: hidden; border: 1px solid var(--light-gray); cursor: pointer; transition: all 0.4s ease; text-align: center; }
.city-card:hover { transform: translateY(-6px); box-shadow: 0 20px 50px rgba(26,18,11,0.09); border-color: rgba(139,94,60,0.25); }
.city-img  { height: 160px; display: flex; align-items: center; justify-content: center; font-size: 48px; }
.city-body { padding: 20px 16px 24px; }
.city-body p { font-size: 13px; color: #60091A; line-height: 1.5; }
.city-tag  { font-size: 11px; font-weight: 700; color: var(--deep-green); letter-spacing: 1px; text-transform: uppercase; margin-bottom: 8px; }
.city-name { font-family: var(--font-body); font-size: 20px; font-weight: 600; margin-bottom: 4px; }

/*important css for video overlay*/
.page-hero--video::before {
  display: none !important;
}