/* Caterman — Events subpages (Corporate / Weddings / Private Events).
   Dark editorial, builds on the shared .cm-os system. Full-bleed video hero,
   keyworded copy, reused .cm-os-rows photo rows, a light enquiry band wrapping
   the directed Caterman Forms shortcode, and an FAQ. */

/* full-bleed breakout + neutralise the theme content wrapper (child pages of Events) */
.cm-evp { position: relative; width: 100vw; left: 50%; right: 50%; margin-left: -50vw; margin-right: -50vw; background: #000; }
.cm-evp-page #content.site-content { padding-top: 0 !important; padding-bottom: 0 !important; }
.cm-evp-page .kl-blog-page-content,
.cm-evp-page .kl-blog-page-body,
.cm-evp-page #th-content-page { padding: 0 !important; margin: 0 !important; }
.cm-evp-page #content.site-content .container,
.cm-evp-page #content.site-content .row,
.cm-evp-page #content.site-content [class*="col-"] { width: 100% !important; max-width: none !important; padding: 0 !important; margin: 0 !important; }
.cm-evp-page .entry-title, .cm-evp-page .page-title, .cm-evp-page .page-header { display: none !important; }

/* ---- hero ---- */
.cm-evp-hero {
  position: relative; overflow: hidden; background: #000;
  min-height: clamp(620px, 90vh, 980px);  /* consistent with sustainability + Our Story heroes */
  display: flex; align-items: flex-end;
}
.cm-evp-hero__media { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; }
.cm-evp-hero__scrim {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: linear-gradient(180deg, rgba(0,0,0,.38) 0%, rgba(0,0,0,.12) 38%, rgba(0,0,0,.9) 100%);
}
/* spotty overlay over the video — replicates Zion's gridOverlay--1 (as on the Our Story hero) */
.cm-evp-hero::after {
  content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none; opacity: .4;
  background-image: linear-gradient(to right top, transparent 33%, #000 33%, #000 66%, transparent 66%);
  background-size: 3px 3px;
}
.cm-evp-hero__inner {
  position: relative; z-index: 2; width: 88vw; max-width: 1180px; margin: 0 auto;  /* align title to 130px content edge; video stays full-bleed */
  padding: 0 0 clamp(50px, 7vw, 96px);
}
.cm-evp-crumb {
  margin: 0 0 18px; display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  font-family: 'Roboto Condensed', 'Manrope', sans-serif; font-weight: 700; text-transform: uppercase;
  font-size: clamp(13px, 1.1vw, 15px); letter-spacing: .04em;
}
.cm-evp-crumb a { color: #cfcfcf; text-decoration: none; transition: color .2s ease; }
.cm-evp-crumb a:hover { color: #fff; }
.cm-evp-crumb__sep { color: rgba(255,255,255,.5); }
.cm-evp-crumb__here { color: #fff; }
.cm-evp-hero__title {
  margin: 0; color: #fff;
  font-family: 'Roboto Condensed', 'Manrope', sans-serif; font-weight: 700; text-transform: uppercase;
  font-size: clamp(46px, 8vw, 124px); line-height: .88; letter-spacing: -.04em;
  text-shadow: 0 2px 44px rgba(0,0,0,.5);
}
.cm-evp-hero__lede {
  margin: 20px 0 0; max-width: 54ch; color: #ececec;
  font-family: 'Manrope', system-ui, sans-serif; font-size: clamp(16px, 1.5vw, 20px); line-height: 1.6;
}
.cm-evp-cta {
  display: inline-block; margin-top: 30px;
  padding: 12px 34px; border: 1px solid rgba(255,255,255,.4); border-radius: 999px;
  background: rgba(0,0,0,.35); color: #fff; text-decoration: none;
  font-family: 'Roboto Condensed', 'Manrope', sans-serif; font-weight: 700;
  font-size: clamp(17px, 1.6vw, 23px); text-transform: uppercase; line-height: 1.15;
  transition: background .25s cubic-bezier(.16,1,.3,1), border-color .25s ease;
}
.cm-evp-cta:hover { background: rgba(255,255,255,.12); border-color: #fff; }
.cm-evp-hero__actions { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.cm-evp-cta--ghost { background: transparent; border-color: rgba(255,255,255,.28); }
.cm-evp-cta--ghost:hover { background: rgba(255,255,255,.1); border-color: #fff; }

/* ---- copy / statement ---- */
.cm-evp-copy { padding-bottom: clamp(40px, 6vw, 72px); }
.cm-evp-copy__grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(32px, 5vw, 80px); align-items: start; }
.cm-evp-copy__body p { margin: 0 0 1.1em; font-size: clamp(15px, 1.45vw, 18px); line-height: 1.7; color: #c2c2c2; }
.cm-evp-copy__body p:last-child { margin-bottom: 0; }

/* ---- photo rows (reuses .cm-os-rows / .cm-os-row) ---- */
.cm-evp-rows-section { padding-top: clamp(20px, 3vw, 40px); padding-bottom: clamp(8px, 1.5vw, 24px); }  /* trim bottom: the enquire band below supplies the gap */
.cm-evp-rows-section .cm-os-rows { margin-top: 0; gap: clamp(48px, 7vw, 104px); }

/* ---- enquiry band (light, wraps the directed form shortcode) ---- */
.cm-evp-enquire { background: #000; padding: clamp(36px, 5vw, 60px) 6vw clamp(56px, 8vw, 104px); scroll-margin-top: 80px; }
.cm-evp-enquire__inner { max-width: 1180px; margin: 0 auto; }  /* match the page content width (.cm-os-inner) */
/* the form ships its own .cm-shell card; let it breathe on the band */
.cm-evp-enquire .cm-shell { box-shadow: 0 40px 80px -40px rgba(0,0,0,.35); }

/* ---- FAQ ---- */
.cm-evp-faq { border-top: 1px solid rgba(255,255,255,.08); }
.cm-evp-faq__list { margin-top: clamp(34px, 5vw, 56px); border-top: 1px solid rgba(255,255,255,.12); }
.cm-evp-faq__item { border-bottom: 1px solid rgba(255,255,255,.12); }
.cm-evp-faq__q {
  list-style: none; cursor: pointer; padding: clamp(20px, 2.4vw, 30px) 44px clamp(20px, 2.4vw, 30px) 0;
  position: relative; color: #fff;
  font-family: 'Roboto Condensed', 'Manrope', sans-serif; font-weight: 700; text-transform: uppercase;
  font-size: clamp(18px, 2vw, 27px); line-height: 1.15; letter-spacing: -.01em;
}
.cm-evp-faq__q::-webkit-details-marker { display: none; }
.cm-evp-faq__q::after {
  content: "+"; position: absolute; right: 4px; top: 50%; transform: translateY(-50%);
  font-family: 'Manrope', sans-serif; font-weight: 400; font-size: clamp(26px, 3vw, 38px); line-height: 1;
  color: rgba(255,255,255,.7); transition: transform .3s cubic-bezier(.16,1,.3,1);
}
.cm-evp-faq__item[open] .cm-evp-faq__q::after { transform: translateY(-50%) rotate(45deg); }
.cm-evp-faq__a {
  margin: 0; padding: 0 44px clamp(22px, 2.6vw, 32px) 0; max-width: 80ch;
  font-size: clamp(15px, 1.4vw, 18px); line-height: 1.66; color: #b6b6b6;
}
.cm-evp-faq__more { margin: clamp(26px, 3vw, 40px) 0 0; font-size: clamp(15px, 1.4vw, 17px); color: #b6b6b6; }
.cm-evp-faq__more a { color: #fff; text-decoration: underline; text-underline-offset: 3px; text-decoration-color: rgba(255,255,255,.4); }
.cm-evp-faq__more a:hover { text-decoration-color: #fff; }

/* responsive */
@media (max-width: 820px) {
  .cm-evp-copy__grid { grid-template-columns: 1fr; gap: 22px; }
}
