@import url('https://fonts.googleapis.com/css2?family=Lexend+Exa:wght@700;800&family=Karla:ital,wght@0,300;0,400;0,500;0,700;1,300&display=swap');

/* ══════════════════════════════════════════
   RESET ELEMENTOR CONTAINER
══════════════════════════════════════════ */
.elementor-widget-vch_hero,
.elementor-widget-vch_hero > .elementor-widget-container {
  padding:   0 !important;
  margin:    0 !important;
  width:     100% !important;
  max-width: 100% !important;
}

/* ══════════════════════════════════════════
   POSTER SHELL
══════════════════════════════════════════ */
.vch-poster {
  width:      100%;
  max-width:  100%;
  overflow:   hidden;
  font-family:'Karla', sans-serif;
  display:    block;
}

/* ══════════════════════════════════════════
   INNER — orange background area
══════════════════════════════════════════ */
.vch-poster-inner {
  width:            100%;
  padding:          36px 40px 36px;
  display:          block;
  background-color: #c84820;
}

.vch-badge-panel {
  background-color: #3a1c08;
  border:           1px solid #e8b860;
}

.vch-bar {
  background-color: #3a1c08;
}

/* ── Eyebrow ── */
.vch-eyebrow {
  display:       flex;
  align-items:   center;
  gap:           10px;
  margin-bottom: 20px;
}
.vch-eyebrow-line {
  width:         28px;
  height:        3px;
  border-radius: 1px;
  flex-shrink:   0;
  background:    #3a1c08;
}
.vch-eyebrow-text {
  font-family:    'Lexend Exa', sans-serif;
  font-size:      9px;
  font-weight:    700;
  letter-spacing: .2em;
  text-transform: uppercase;
  color:          #3a1c08;
}

/* ── Desktop grid: text left, image right ── */
.vch-d-grid {
  display:               grid;
  grid-template-columns: 1.5fr 1fr;
  gap:                   40px;
  align-items:           start;
}

/* ── LEFT: text ── */
.vch-left { min-width: 0; }

.vch-headline {
  font-family:    'Lexend Exa', sans-serif !important;
  font-size:      40px !important;
  font-weight:    800 !important;
  line-height:    1 !important;
  letter-spacing: -.04em !important;
  color:          #f4ede0;
  text-transform: uppercase !important;
  margin:         0 0 16px !important;
  padding:        0 !important;
  word-break:     break-word;
}

.vch-excerpt {
  font-size:     14px;
  font-weight:   300;
  font-style:    italic;
  line-height:   1.65;
  color:         #3a1c08;
  opacity:       .85;
  margin:        0 0 20px;
}

.vch-bottom {
  display:        flex;
  flex-direction: column;
  gap:            10px;
}

.vch-meta {
  display:        flex;
  align-items:    center;
  gap:            6px;
  flex-wrap:      wrap;
  font-size:      10px;
  font-weight:    500;
  letter-spacing: .06em;
  text-transform: uppercase;
  color:          #3a1c08;
  opacity:        .6;
}
.vch-dot { opacity: .4; }

.vch-btn {
  display:         inline-flex;
  align-items:     center;
  gap:             8px;
  font-family:     'Lexend Exa', sans-serif;
  font-size:       9px;
  font-weight:     700;
  letter-spacing:  .12em;
  text-transform:  uppercase;
  padding:         12px 24px;
  border-radius:   2px;
  text-decoration: none !important;
  width:           fit-content;
  transition:      opacity .15s;
  background:      #3a1c08;
  color:           #f4ede0;
}
.vch-btn:hover { opacity: .85; }

/* ── RIGHT: image ── */
.vch-img-col {
  position:      relative;
  width:         100%;
}
.vch-featured-img,
.vch-img-placeholder {
  width:         100%;
  aspect-ratio:  3 / 2;
  object-fit:    cover;
  display:       block;
  border-radius: 3px;
}
.vch-img-placeholder {
  background:      linear-gradient(145deg, #b0a080, #c8b090, #a89070);
  display:         flex;
  align-items:     center;
  justify-content: center;
  color:           rgba(58,28,8,.3);
  font-family:     'Lexend Exa', sans-serif;
  font-size:       8px;
  font-weight:     700;
  letter-spacing:  .1em;
  text-transform:  uppercase;
}

/* Destination badge on image */
.vch-badge-panel {
  position:      absolute;
  bottom:        10px;
  right:         10px;
  padding:       5px 10px;
  border-radius: 2px;
  display:       flex;
  align-items:   center;
  gap:           5px;
}
.vch-badge-flag {
  font-size:   14px;
  line-height: 1;
  display:     inline !important;
}
.vch-badge-name {
  font-family:    'Lexend Exa', sans-serif;
  font-size:      8px;
  font-weight:    700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color:          #e8b860;
  display:        inline !important;
}
/* hide old badge sub-elements not used in this layout */
.vch-badge,
.vch-badge-divider,
.vch-badge-sub,
.vch-badge-img { display: none !important; }

/* ── PILLS BAR ── */
.vch-bar {
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  padding:         10px 40px;
  border-top:      3px solid #e8cc68;
  gap:             16px;
  flex-wrap:       wrap;
  width:           100%;
}
.vch-bar-label {
  font-family:    'Lexend Exa', sans-serif;
  font-size:      8px;
  font-weight:    700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color:          #e8b860;
  flex-shrink:    0;
}
.vch-bar-pills {
  display:   flex;
  gap:       6px;
  flex-wrap: wrap;
}
.vch-pill {
  font-family:     'Lexend Exa', sans-serif;
  font-size:       8px;
  font-weight:     700;
  letter-spacing:  .1em;
  text-transform:  uppercase;
  padding:         5px 12px;
  border-radius:   2px;
  text-decoration: none !important;
  transition:      opacity .15s;
  display:         inline-block;
}
.vch-pill:hover { opacity: .8; }

/* ══════════════════════════════════════════
   TABLET  ≤ 860px
══════════════════════════════════════════ */
@media (max-width: 860px) {
  .vch-d-grid       { gap: 24px; }
  .vch-headline     { font-size: 32px !important; }
  .vch-poster-inner { padding: 28px 28px 28px; }
  .vch-bar          { padding: 10px 28px; }
}

/* ══════════════════════════════════════════
   MOBILE  ≤ 600px
   Stack: eyebrow → image (full-width) → title → excerpt → btn → pills
══════════════════════════════════════════ */
@media (max-width: 600px) {

  .vch-poster-inner {
    padding: 20px 20px 20px;
  }

  /* Use flex column so we can reorder image to top */
  .vch-d-grid {
    display:        flex;
    flex-direction: column;
  }

  /* Image: order -1 puts it above text, inset with padding + rounded corners */
  .vch-img-col {
    order:  -1;
    width:  100%;
    margin: 0 0 20px;
  }
  .vch-featured-img,
  .vch-img-placeholder {
    aspect-ratio: 16 / 9;
    width:        100%;
    /* radius inherited from Elementor slider, not forced to 0 */
  }

  .vch-headline {
    font-size:     22px !important;
    margin-bottom: 10px !important;
  }

  .vch-excerpt {
    font-size:     13px;
    margin-bottom: 14px;
  }

  .vch-btn {
    width:           100% !important;
    justify-content: center !important;
    padding:         13px 20px !important;
    box-sizing:      border-box;
  }

  .vch-bar {
    padding:         10px 20px;
    justify-content: flex-start;
    margin-top:      4px;
  }
  .vch-bar-label { display: none; }
  .vch-pill      { font-size: 8px; padding: 5px 10px; }
}

/* ══════════════════════════════════════════
   VERY SMALL  ≤ 380px
══════════════════════════════════════════ */
@media (max-width: 380px) {
  .vch-poster-inner { padding: 16px 16px 16px; }
  .vch-headline     { font-size: 18px !important; }
  .vch-bar          { padding: 8px 16px; }
}
