/* =============================================================
   AD SYSTEM — LAYOUTS
   -------------------------------------------------------------
   Eight brand-color event-ad layouts + house-ad variants. Every
   color is expressed through var(--ad-*) tokens from
   static/css/ad/index.css — zero raw hex values in this file.

   COMPONENT INDEX
     .ep-ad-event--v1   Amber Ticket Stub        DARK  bucket
     .ep-ad-event--v2   Memphis Pop              LIGHT bucket
     .ep-ad-event--v3   Bold Header Band         MID   bucket
     .ep-ad-event--v4   Big Date Block           DARK  bucket
     .ep-ad-event--v5   Curved Two-Tone          DARK  bucket
     .ep-ad-event--v6   Memphis Decorations      LIGHT bucket
     .ep-ad-event--v7   Corner Triangle          LIGHT bucket
     .ep-ad-event--v8   Postcard Badge           DARK  bucket

     .ep-ad-house                                 base
     .ep-ad-house--house-v1                       image only
     .ep-ad-house--house-v2                       image + caption overlay
     .ep-ad-house--house-v3                       gradient + CTA
   ============================================================= */


/* =============================================================
   v1 — Amber Ticket Stub
   Ticket body on brand color with a perforated right-edge stub
   that inverts to --ad-fg.
   ============================================================= */
.ep-ad-event--v1 .ep-ad-event-inner {
  padding-right: 72px;
}
.ep-ad-event--v1 .ep-ad-event-perf {
  position: absolute;
  top: 8px;
  bottom: 8px;
  right: 58px;
  width: 0;
  border-right: 2px dashed var(--ad-fg-50);
}
.ep-ad-event--v1 .ep-ad-event-stub {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: 58px;
  background: var(--ad-fg);
  color: var(--ad-brand);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.ep-ad-event--v1 .ep-ad-event-stub-day {
  font-size: 26px;
  font-weight: 900;
  line-height: 1;
}
.ep-ad-event--v1 .ep-ad-event-stub-month {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-top: 2px;
}
.ep-ad-event--v1 .ep-ad-event-cta {
  background: var(--ad-fg-18);
  color: var(--ad-fg);
  border: 1px solid var(--ad-fg-50);
}


/* =============================================================
   v2 — Memphis Pop
   Brand background with an oversized off-card shape in fg-22.
   ============================================================= */
.ep-ad-event--v2 .ep-ad-event-bg-figure {
  position: absolute;
  top: -40px;
  right: -40px;
  width: 160px;
  height: 160px;
  border-radius: 50%;
  background: var(--ad-fg-22);
}
.ep-ad-event--v2 .ep-ad-event-bg-figure::after {
  content: '';
  position: absolute;
  left: 30px;
  top: 40px;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--ad-fg-28);
}
.ep-ad-event--v2 .ep-ad-event-inner { padding-right: 90px; }


/* =============================================================
   v3 — Bold Header Band
   Brand background with a fg-tinted header band carrying the day.
   ============================================================= */
.ep-ad-event--v3 .ep-ad-event-header-band {
  background: var(--ad-fg-18);
  color: var(--ad-fg);
  padding: 8px var(--ad-pad-x);
  display: flex;
  align-items: baseline;
  gap: 10px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.ep-ad-event--v3 .ep-ad-event-header-day {
  font-size: 22px;
  font-weight: 900;
  line-height: 1;
}
.ep-ad-event--v3 .ep-ad-event-inner {
  padding: 8px var(--ad-pad-x) var(--ad-pad-y);
}
.ep-ad-event--v3 .ep-ad-event-cta {
  position: absolute;
  right: var(--ad-pad-x);
  bottom: var(--ad-pad-y);
}


/* =============================================================
   v4 — Big Date Block
   Left column carrying a huge day/month in fg-22 on brand.
   ============================================================= */
.ep-ad-event--v4 .ep-ad-event-date-block {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 72px;
  background: var(--ad-fg-22);
  color: var(--ad-fg);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.ep-ad-event--v4 .ep-ad-event-date-day {
  font-size: 28px;
  font-weight: 900;
  line-height: 1;
}
.ep-ad-event--v4 .ep-ad-event-date-month {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-top: 2px;
}
.ep-ad-event--v4 .ep-ad-event-inner {
  padding-left: 84px;
}
.ep-ad-event--v4 .ep-ad-event-cta {
  background: var(--ad-fg);
  color: var(--ad-brand);
}


/* =============================================================
   v5 — Curved Two-Tone
   Brand "top" with a curved bottom edge peeling down to a tinted
   base (brand + fg-08 mix) that holds meta/CTA.
   ============================================================= */
.ep-ad-event--v5 {
  background: color-mix(in srgb, var(--ad-fg) 8%, var(--ad-brand));
}
.ep-ad-event--v5 .ep-ad-event-top {
  background: var(--ad-brand);
  padding: 10px var(--ad-pad-x) 18px;
  position: relative;
}
.ep-ad-event--v5 .ep-ad-event-top::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  height: 14px;
  background: color-mix(in srgb, var(--ad-fg) 8%, var(--ad-brand));
  border-radius: 50% 50% 0 0 / 100% 100% 0 0;
}
.ep-ad-event--v5 .ep-ad-event-top .ep-ad-event-title {
  font-size: 16px;
  margin-bottom: 0;
}
.ep-ad-event--v5 .ep-ad-event-inner {
  padding: 6px var(--ad-pad-x) var(--ad-pad-y);
}
.ep-ad-event--v5 .ep-ad-event-cta {
  position: absolute;
  right: var(--ad-pad-x);
  bottom: var(--ad-pad-y);
}


/* =============================================================
   v6 — Memphis Decorations
   Brand background with fg dot/ring/circle decorations.
   ============================================================= */
.ep-ad-event--v6 .ep-ad-event-deco-circle {
  position: absolute;
  top: -30px;
  right: -30px;
  width: 110px;
  height: 110px;
  border-radius: 50%;
  background: var(--ad-fg-22);
}
.ep-ad-event--v6 .ep-ad-event-deco-arc {
  position: absolute;
  bottom: -22px;
  left: -22px;
  width: 70px;
  height: 70px;
  border-radius: 50%;
  border: 6px solid var(--ad-fg-28);
}
.ep-ad-event--v6 .ep-ad-event-deco-dot1 {
  position: absolute;
  top: 60px;
  right: 28px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--ad-fg);
}
.ep-ad-event--v6 .ep-ad-event-inner {
  position: absolute;
  inset: 0;
  padding: var(--ad-pad-y) 80px var(--ad-pad-y) var(--ad-pad-x);
}
.ep-ad-event--v6 .ep-ad-event-cta {
  position: absolute;
  right: var(--ad-pad-x);
  bottom: var(--ad-pad-y);
}


/* =============================================================
   v7 — Corner Triangle
   Brand background with a fg-80 corner triangle carrying the date
   that inverts to --ad-brand.
   ============================================================= */
.ep-ad-event--v7 .ep-ad-event-corner {
  position: absolute;
  top: 0;
  right: 0;
  width: 0;
  height: 0;
  border-top: 70px solid var(--ad-fg-80);
  border-left: 70px solid transparent;
}
.ep-ad-event--v7 .ep-ad-event-corner-date {
  position: absolute;
  top: 10px;
  right: 8px;
  color: var(--ad-brand);
  font-size: 13px;
  font-weight: 800;
  line-height: 1;
  text-align: right;
  z-index: 1;
}
.ep-ad-event--v7 .ep-ad-event-corner-date small {
  display: block;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.1em;
  margin-top: 2px;
}
.ep-ad-event--v7 .ep-ad-event-inner {
  position: absolute;
  inset: 0;
  padding: var(--ad-pad-y) 80px var(--ad-pad-y) var(--ad-pad-x);
}
.ep-ad-event--v7 .ep-ad-event-title {
  font-weight: 900;
  text-transform: uppercase;
  line-height: 1.1;
}
.ep-ad-event--v7 .ep-ad-event-cta {
  position: absolute;
  right: var(--ad-pad-x);
  bottom: var(--ad-pad-y);
}


/* =============================================================
   v8 — Postcard Badge
   Brand background with a fg-18 semicircle and a fg-filled circular
   date badge. Ghost CTA tinted from --ad-fg-25.
   ============================================================= */
.ep-ad-event--v8 .ep-ad-event-deco-semi {
  position: absolute;
  top: -50px;
  right: -50px;
  width: 140px;
  height: 140px;
  border-radius: 50%;
  background: var(--ad-fg-18);
}
.ep-ad-event--v8 .ep-ad-event-date-badge {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 54px;
  height: 54px;
  border-radius: 50%;
  background: var(--ad-fg);
  color: var(--ad-brand);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  z-index: 1;
}
.ep-ad-event--v8 .ep-ad-event-date-badge .d {
  font-size: 20px;
  font-weight: 900;
  line-height: 1;
}
.ep-ad-event--v8 .ep-ad-event-date-badge .m {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.1em;
}
.ep-ad-event--v8 .ep-ad-event-inner {
  position: absolute;
  inset: 0;
  padding: var(--ad-pad-y) 80px var(--ad-pad-y) var(--ad-pad-x);
}
.ep-ad-event--v8 .ep-ad-event-org {
  position: absolute;
  right: var(--ad-pad-x);
  bottom: var(--ad-pad-y);
  margin-bottom: 0;
}
.ep-ad-event--v8 .ep-ad-event-cta {
  position: absolute;
  left: var(--ad-pad-x);
  bottom: var(--ad-pad-y);
  background: var(--ad-fg-25);
  color: var(--ad-fg);
  border: 1px solid var(--ad-fg-50);
}


/* =============================================================
   HOUSE ADS
   Static Renatus self-promo slots rendered by explore.js.
   Tokens come from static/css/tokens/* (platform palette).
   ============================================================= */
.ep-ad-house {
  display: block;
  position: relative;
  overflow: hidden;
  border-radius: 12px;
  text-decoration: none;
  color: var(--ink);
}

.ep-ad-house-img-real,
.ep-ad-house-img {
  display: block;
  width: 100%;
  height: 135px;
  object-fit: cover;
  border-radius: 0;
}

.ep-ad-house-img {
  background: var(--pink);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255, 255, 255, 0.85);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.ep-ad-house--house-v1 .ep-ad-house-img {
  background: var(--pink);
}

.ep-ad-house--house-v2 .ep-ad-house-img {
  background: var(--coral);
}

.ep-ad-house--house-v2 .ep-ad-house-caption {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(0deg, rgba(0, 0, 0, 0.75) 0%, transparent 100%);
  color: #fff;
  padding: 24px 16px 14px;
  font-size: 13px;
  font-weight: 600;
  line-height: 1.3;
}

.ep-ad-house--house-v3 {
  background: var(--amber);
  color: #fff;
  padding: 22px 20px;
  min-height: 135px;
}
.ep-ad-house--house-v3 .ep-ad-house-eyebrow {
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 700;
  opacity: 0.9;
  margin-bottom: 8px;
}
.ep-ad-house--house-v3 .ep-ad-house-title {
  font-size: 17px;
  font-weight: 700;
  line-height: 1.25;
  margin-bottom: 10px;
}
.ep-ad-house--house-v3 .ep-ad-house-cta {
  display: inline-block;
  background: var(--white);
  color: var(--fuchsia);
  font-size: 12px;
  font-weight: 700;
  padding: 7px 14px;
  border-radius: 999px;
}
