/* ==========================================================================
   VCTM — Design-Stylesheet (nach Bricks-Design-Spec, Stand 2026-06-18)
   Schrift: 'Helvetica Neue', Arial, sans-serif  (keine Webfonts)
   ========================================================================== */

:root {
  --color-bg:        #0d0d0d;
  --color-bg-alt:    #111111;
  --color-card:      #1a1a1a;
  --color-accent:    #b9121f;
  --color-accent-dk: #8e0d17;
  --color-text:      #f0f0f0;
  --color-muted:     #999999;
  --color-border:    #2a2a2a;
  --color-white:     #ffffff;
  --font-sans: 'Helvetica Neue', Arial, sans-serif;
}

/* ---- Basis ---------------------------------------------------------------- */
body {
  font-family: var(--font-sans);
  color: var(--color-text);
  background: var(--color-bg);
  -webkit-font-smoothing: antialiased;
}
body h1, body h2, body h3, body h4, body h5, body h6 {
  font-family: var(--font-sans);
  color: var(--color-text);
}
a { color: var(--color-accent); }

/* Sektions-Titel (H2) */
.wp-block-post-content h2.wp-block-heading {
  font-size: 36px;
  font-weight: 700;
  letter-spacing: 1px;
  line-height: 1.2;
}
.wp-block-post-content h3.wp-block-heading { font-size: 28px; font-weight: 700; }
.wp-block-post-content h4.wp-block-heading { font-size: 18px; font-weight: 700; }

/* Subtitle + Divider (60×3 rot) */
.vctm-sub {
  font-size: 18px !important;
  color: var(--color-muted) !important;
  text-align: center;
  margin: 0 auto 2.4rem !important;
  padding-bottom: 0;
}
.vctm-sub::after {
  content: "";
  display: block;
  width: 60px;
  height: 3px;
  background: var(--color-accent);
  margin: 16px auto 0;
}

/* ---- 2.2 INFO BAR --------------------------------------------------------- */
.vctm-infobar { background: var(--color-accent) !important; }
.vctm-infobar .wp-block-column { padding: 4px 24px; }
.vctm-infobar .wp-block-column + .wp-block-column {
  border-left: 1px solid rgba(255,255,255,.2);
}
.vctm-infobar p {
  font-size: 12px !important;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: rgba(255,255,255,.7) !important;
  margin: 0 0 6px !important;
}
.vctm-infobar h4 { font-size: 22px; font-weight: 700; color: #fff; margin: 0; }
.vctm-infobar h4.wp-block-heading { font-size: 22px; }

/* ---- 2.3 CRITERIA + 2.9 RATES (saubere Zeilen, kein Gitter) --------------- */
.vctm-crit-head, .vctm-rates-head {
  font-size: 14px !important;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--color-muted) !important;
  margin-bottom: .6rem;
}
.wp-block-table.vctm-criteria, .wp-block-table.vctm-rates { border: 0 !important; margin: 0 !important; }
.vctm-criteria table, .vctm-rates table { width: 100%; border: 0 !important; border-collapse: collapse !important; }
.vctm-criteria tr, .vctm-rates tr, .vctm-criteria th, .vctm-rates th { border: 0 !important; }
.vctm-criteria td, .vctm-rates td {
  border: 0 !important;
  border-bottom: 1px solid var(--color-border) !important;
  padding: 16px 0 !important;
  vertical-align: top;
}
.vctm-criteria td:first-child {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--color-accent);
  min-width: 110px;
  width: 30%;
  white-space: nowrap;
}
.vctm-criteria td:last-child { font-size: 14px; color: var(--color-muted); }
.vctm-rates td { font-size: 14px; color: var(--color-muted); padding: 6px 0 !important; }
.vctm-rates td:last-child {
  text-align: right;
  color: var(--color-text);
  font-weight: 600;
  white-space: nowrap;
  width: 34%;
}

/* ---- 2.4 EXPECT + Karten allgemein --------------------------------------- */
.vctm-card {
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: 8px;
  padding: 32px 28px;
  text-align: center;
  height: 100%;
  transition: border-color .2s ease, transform .2s ease;
}
.vctm-card:hover { border-color: var(--color-accent); transform: translateY(-2px); }
.vctm-card h4 { font-size: 16px !important; font-weight: 600; color: var(--color-text); margin: 0 0 8px; }
.vctm-card p  { font-size: 14px !important; color: var(--color-muted); line-height: 1.7; margin: 0; }
.vctm-expect .vctm-card p:first-of-type { font-size: 48px !important; line-height: 1; margin: 0 0 14px !important; }
.vctm-card.vctm-hotel { text-align: left; }
.vctm-card.vctm-hotel h3 { font-size: 28px !important; font-weight: 700; margin: 0 0 12px !important; }
.vctm-dinner > * + * { margin-block-start: 8px !important; }
.vctm-dinner h3 { margin-bottom: 10px !important; }
/* What-is-Karte (enthält .vctm-criteria): Fließtext braucht Absatzabstand –
   .vctm-card p {margin:0} ist für Kontaktzeilen (Acc/Dinner) gedacht, plättet hier den Text */
.vctm-card:has(.vctm-criteria) p:not(.vctm-crit-head) + p:not(.vctm-crit-head) { margin-top: 1rem; }

/* ---- 2.5 DJs -------------------------------------------------------------- */
.vctm-dj-card {
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: 8px;
  overflow: hidden;
  padding: 0 !important;                 /* Zonen liegen randbündig */
  height: 100%;
  transition: border-color .2s ease, transform .2s ease;
}
.vctm-dj-card:hover { border-color: var(--color-accent); transform: translateY(-2px); }
/* Zone A: Foto-Bereich (dunkler, #111111), Mat-Rand 14px ums Foto */
.vctm-dj-photo { background: var(--color-bg-alt); }
.vctm-dj-photo .wp-block-post-featured-image { margin: 0; }
.vctm-dj-photo img {
  border: 1px solid var(--color-border);   /* #2a2a2a Rahmenlinie ums Foto */
  border-radius: 4px;
  width: 100%;
  display: block;
}
/* Zone B: Namensfeld (heller, #1a1a1a) */
.vctm-dj-meta { background: var(--color-card); text-align: center; }
.vctm-dj-meta .wp-block-post-title,
.vctm-dj-meta h3 { font-size: 16px !important; font-weight: 700; color: var(--color-text); margin: 0 0 2px; }
.vctm-dj-meta p { font-size: 14px !important; color: var(--color-muted); margin: 2px 0; }
.vctm-dj-card .wp-block-vctm-dj-facebook a,
.vctm-dj-card .wp-block-vctm-dj-facebook svg { color: var(--color-text); fill: var(--color-text); }
.vctm-dj-card .wp-block-vctm-dj-facebook a,
.vctm-dj-card .wp-block-vctm-dj-facebook svg { color: var(--color-text); fill: var(--color-text); }

/* ---- 2.6 PROGRAM ---------------------------------------------------------- */
.vctm-day {
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: 4px;
  overflow: hidden;
  padding: 0 !important;
}
.vctm-day-head { background: var(--color-accent) !important; padding: 16px 20px !important; border-radius: 0 !important; border-bottom: 3px solid var(--color-text) !important; }
.vctm-day-head h4 { font-size: 16px !important; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: #fff; margin: 0; }
.vctm-day-head p  { font-size: 14px !important; color: rgba(255,255,255,.75); font-style: italic; margin: 4px 0 0; }
.vctm-row { padding: 12px 20px !important; border-bottom: 1px solid var(--color-border); }
.vctm-row:last-child { border-bottom: 0; }
.vctm-row.vctm-milonga { background: rgba(185,18,31,.08) !important; }
.vctm-time { font-size: 12px !important; font-weight: 700; letter-spacing: 1px; color: var(--color-accent); font-family: monospace; margin: 0 0 2px !important; }
.vctm-row p:not(.vctm-time) { font-size: 14px !important; color: var(--color-text); margin: 0; letter-spacing: .5px; }
.vctm-row em, .vctm-row i { color: var(--color-muted); font-style: italic; }

/* ---- 2.7 LOCATION (Map + Foto-Grid) -------------------------------------- */
.vctm-map iframe { border: 1px solid var(--color-border) !important; border-radius: 8px; display: block; width: 100%; min-height: 320px; }
.vctm-photo-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.vctm-photo-grid img, .vctm-photos img { width: 100%; height: auto; aspect-ratio: 3 / 2; object-fit: cover; border-radius: 4px; display: block; }

/* ---- 2.8 PRICE ------------------------------------------------------------ */
.vctm-card .vctm-price { font-size: 64px !important; font-weight: 900 !important; color: var(--color-accent) !important; line-height: 1; margin: 8px 0 4px !important; }
.vctm-card h4.vctm-date { font-size: 28px !important; font-weight: 900 !important; color: var(--color-accent) !important; line-height: 1.1; margin: 2px 0 16px !important; }
.vctm-badge { display: inline-block; background: var(--color-accent); color: #fff; font-size: 12px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; padding: 6px 14px; border-radius: 3px; }
.vctm-card--featured { border: 1px solid var(--color-accent) !important; }
.vctm-feat ul { list-style: none; margin: 0; padding: 0; text-align: left; }
.vctm-feat li { font-size: 14px; color: var(--color-muted); padding: 6px 0; border-bottom: 1px solid var(--color-border); }
.vctm-feat li::before { content: "\2713\00a0"; color: var(--color-accent); font-weight: 700; }

/* ---- Promo-/Highlight-Box (Accommodation, Dinner) ------------------------- */
.vctm-promo {
  background: rgba(185,18,31,.1) !important;
  border: 1px solid rgba(185,18,31,.3);
  border-left: 3px solid var(--color-accent) !important;
  border-radius: 0 6px 6px 0;
  padding: 16px 20px;
}

/* ---- Buttons -------------------------------------------------------------- */
.wp-block-button__link {
  padding: 14px 36px;
  border-radius: 4px;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: .5px;
  text-transform: uppercase;
}
.btn--outline > .wp-block-button__link,
.is-style-outline > .wp-block-button__link {
  background: transparent !important;
  color: var(--color-text) !important;
  border: 2px solid var(--color-border) !important;
}
.btn--outline > .wp-block-button__link:hover,
.is-style-outline > .wp-block-button__link:hover { border-color: var(--color-accent) !important; color: var(--color-accent) !important; }
.btn--ghost > .wp-block-button__link {
  background: transparent !important;
  color: #fff !important;
  border: 2px solid rgba(255,255,255,.4) !important;
}
.btn--ghost > .wp-block-button__link:hover { border-color: #fff !important; }

/* ---- 2.11 CTA / 2.12 CONTACT --------------------------------------------- */
.vctm-cta h2.wp-block-heading { font-size: 48px !important; font-weight: 900; text-transform: uppercase; color: #fff; }
.vctm-cta p { font-size: 18px !important; color: rgba(255,255,255,.85); }
.vctm-contact-mail a, a.vctm-mail { font-size: 22px !important; font-weight: 700; color: var(--color-accent); }

/* ==========================================================================
   NAVIGATION  (Logo links, Menü ZENTRIERT)
   ========================================================================== */
.vctm-navwrap {
  position: relative;
  background: rgba(13,13,13,.97);
  border-bottom: 1px solid var(--color-border);
  padding: 12px 24px !important;
}
.vctm-logo {
  position: absolute;
  left: 24px;
  top: 50%;
  transform: translateY(-50%);
  margin: 0 !important;
}
.vctm-logo img { height: 44px; width: auto; display: block; }
.vctm-menu {
  display: flex !important;
  flex-wrap: wrap;
  justify-content: center !important;
  align-items: center;
  gap: 28px !important;
  margin: 0 !important;
  width: 100%;
}
.vctm-menu p { margin: 0 !important; }
.vctm-menu a {
  font-size: 14px;
  font-weight: 500;
  letter-spacing: .5px;
  text-transform: uppercase;
  color: var(--color-muted) !important;
  text-decoration: none;
}
.vctm-menu a:hover { color: var(--color-text) !important; }

/* ==========================================================================
   FOOTER  (minimal: Links + Copyright, kleine Schrift)
   ========================================================================== */
.vctm-foot {
  background: var(--color-card) !important;
  border-top: 1px solid var(--color-border);
  text-align: center;
  padding: 24px !important;
}
.vctm-foot-links {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 28px;
  margin: 0 0 8px !important;
}
.vctm-foot-links p { margin: 0 !important; }
.vctm-foot a { color: var(--color-muted) !important; text-decoration: none; font-size: 14px !important; }
.vctm-foot a:hover { color: var(--color-text) !important; }
.vctm-copy { font-size: 12px !important; color: var(--color-muted) !important; margin: 0 !important; }

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width: 900px) {
  .wp-block-post-content h2.wp-block-heading { font-size: 28px; }
  .vctm-card .vctm-price { font-size: 48px !important; }
  .vctm-logo { position: static; transform: none; margin: 0 auto 10px !important; }
  .vctm-navwrap { text-align: center; }
  .vctm-photo-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .vctm-infobar .wp-block-column + .wp-block-column { border-left: 0; border-top: 1px solid rgba(255,255,255,.2); }
  .vctm-menu { gap: 16px !important; }
}

/* ---- 2.x KONTAKTFORMULAR (Get in Touch) --------------------------------- */
.vctm-contact-wrap { max-width: 640px; }
.vctm-contact .vctm-field { margin: 0 0 18px; }
.vctm-contact label {
  display: block; font-size: 13px; letter-spacing: .5px; text-transform: uppercase;
  color: var(--color-muted); margin: 0 0 6px;
}
.vctm-contact input[type="text"],
.vctm-contact input[type="email"],
.vctm-contact textarea {
  width: 100%; box-sizing: border-box;
  background: #1a1a1a; border: 1px solid var(--color-border); border-radius: 6px;
  color: var(--color-text); font: inherit; font-size: 16px; padding: 12px 14px;
}
.vctm-contact textarea { resize: vertical; min-height: 150px; line-height: 1.6; }
.vctm-contact input:focus,
.vctm-contact textarea:focus { outline: none; border-color: var(--color-accent); }
.vctm-contact .cf-turnstile { margin: 4px 0 18px; }
.vctm-btn {
  display: inline-block; cursor: pointer;
  background: var(--color-accent); color: #fff; border: 0; border-radius: 6px;
  font-size: 15px; font-weight: 600; letter-spacing: .5px; padding: 13px 30px;
  transition: background .2s ease;
}
.vctm-btn:hover { background: var(--color-accent-dk); }
.vctm-form-msg { padding: 12px 16px; border-radius: 6px; margin: 0 0 22px; font-size: 15px; }
.vctm-form-ok  { background: rgba(40,160,80,.12); border: 1px solid rgba(40,160,80,.5); color: #d8f3e0; }
.vctm-form-err { background: rgba(185,18,31,.12); border: 1px solid rgba(185,18,31,.5); color: #f3d7da; }

/* ---- 2.x NEWSLETTER (Stay in Touch) ------------------------------------ */
/* Form erbt .vctm-contact (Inputs/Labels/Focus/Button); nur Zusätze hier.  */
.vctm-subscribe-wrap { max-width: 640px; }
.vctm-subscribe .vctm-name-row { display: flex; gap: 18px; }
.vctm-subscribe .vctm-name-row .vctm-field { flex: 1; margin: 0 0 18px; }
.vctm-subscribe .vctm-nl-note {
  font-size: 13px; line-height: 1.6; color: var(--color-muted); margin: 2px 0 18px;
}
.vctm-subscribe .vctm-nl-note a { color: var(--color-accent); }
@media (max-width: 600px) {
  .vctm-subscribe .vctm-name-row { flex-direction: column; gap: 0; }
}

/* ---- 2.x NEWSLETTER PUBLIC PAGE ([newsletter] / .tnp dark) ------------- */
/* Scope #newsletter-page schlaegt das helle Plugin-style.css (gleiche .tnp-Spezifitaet). */
#newsletter-page .tnp { max-width: 640px; margin: 2rem auto 0; color: var(--color-text); }
#newsletter-page .tnp p,
#newsletter-page .tnp li,
#newsletter-page .tnp div { color: var(--color-text); }
#newsletter-page .tnp .tnp-field { margin: 0 0 18px; }
#newsletter-page .tnp label,
#newsletter-page .tnp .tnp-label {
  display: block; font-size: 13px; letter-spacing: .5px; text-transform: uppercase;
  color: var(--color-muted); margin: 0 0 6px;
}
#newsletter-page .tnp input[type="text"],
#newsletter-page .tnp input[type="email"],
#newsletter-page .tnp select,
#newsletter-page .tnp textarea {
  width: 100%; box-sizing: border-box;
  background: #1a1a1a; border: 1px solid var(--color-border); border-radius: 6px;
  color: var(--color-text); font: inherit; font-size: 16px; padding: 12px 14px;
}
#newsletter-page .tnp input:focus,
#newsletter-page .tnp select:focus,
#newsletter-page .tnp textarea:focus { outline: none; border-color: var(--color-accent); }
#newsletter-page .tnp input[type="submit"],
#newsletter-page .tnp button,
#newsletter-page .tnp .tnp-submit input {
  background: var(--color-accent) !important; color: #fff !important; border: 0 !important;
  border-radius: 6px !important; font-size: 15px !important; font-weight: 600 !important;
  letter-spacing: .5px; padding: 13px 30px !important; width: auto !important; cursor: pointer;
}
#newsletter-page .tnp input[type="submit"]:hover,
#newsletter-page .tnp button:hover { background: var(--color-accent-dk) !important; }
#newsletter-page .tnp a { color: var(--color-accent); }
#newsletter-page .tnp .tnp-privacy-field,
#newsletter-page .tnp .tnp-field-checkbox { color: var(--color-muted); font-size: 13px; text-transform: none; }

/* ---- 2.x NEWSLETTER public page: split (Formular links / Bild rechts) --- */
.vctm-subscribe-split { display: flex; gap: 3rem; align-items: flex-start; }
.vctm-subscribe-split > div { flex: 1; min-width: 0; }
.vctm-subscribe-split .vctm-subscribe-split-form .vctm-subscribe-wrap,
.vctm-subscribe-split .vctm-subscribe-split-form .vctm-contact-wrap { max-width: none; }
.vctm-subscribe-split .vctm-subscribe-split-figure { margin: 0; }
.vctm-subscribe-split .vctm-subscribe-split-figure img { width: 100%; height: auto; display: block; border-radius: 8px; }
@media (max-width: 781px) {
  .vctm-subscribe-split { flex-direction: column; gap: 2rem; }
}

/* ---- 2.x NEWSLETTER profile (na=up) Feinschliff ----------------------- */
#newsletter-page .tnp-profile .tnp-field-gender { display: none; }            /* Geschlecht raus */
#newsletter-page .tnp .tnp-submit:focus,
#newsletter-page .tnp .tnp-submit:focus-visible { outline: 2px solid var(--color-text); outline-offset: 2px; }
#newsletter-page .tnp-profile .tnp-field-button { text-align: center; margin-top: 6px; }
#newsletter-page .vctm-profile-extra { max-width: 640px; margin: 0 auto; text-align: center; }
#newsletter-page .vctm-or { color: var(--color-muted); margin: 14px 0; text-transform: uppercase; letter-spacing: 1px; font-size: 13px; }
#newsletter-page .vctm-profile-cancel { margin: 0 0 22px; }
#newsletter-page .vctm-btn-outline {
  display: inline-block; background: transparent; color: var(--color-text);
  border: 1px solid var(--color-accent); border-radius: 6px; padding: 12px 28px;
  font-size: 15px; font-weight: 600; letter-spacing: .5px; text-decoration: none; cursor: pointer;
}
#newsletter-page .vctm-btn-outline:hover { background: var(--color-accent); color: #fff; }
#newsletter-page .vctm-profile-hint { color: var(--color-muted); font-size: 13px; text-align: center; margin: 0; }

/* ---- 2.x NEWSLETTER unsubscribe (na=u / -ed) englisch + zentriert ----- */
#newsletter-page .vctm-unsub { max-width: 640px; margin: 1rem auto 0; text-align: center; }
#newsletter-page .vctm-unsub .vctm-unsub-text { color: var(--color-text); margin: 0 0 18px; }
#newsletter-page .vctm-unsub .tnp-button-form { display: inline-block; margin: 0; }
#newsletter-page .vctm-unsub .tnp-submit {
  background: var(--color-accent) !important; color: #fff !important; border: 0 !important;
  border-radius: 6px !important; font-size: 15px !important; font-weight: 600 !important;
  letter-spacing: .5px; padding: 13px 30px !important; cursor: pointer;
}
#newsletter-page .vctm-unsub .tnp-submit:hover { background: var(--color-accent-dk) !important; }

/* ---- 2.x DIVIDER (rote Linie unter Ueberschrift, standalone) ---------- */
.vctm-divider { width: 60px; height: 3px; background: var(--color-accent); margin: 16px auto 2.4rem; border: 0; }
/* Marken-R hochgestellt */
.vctm-foot sup, #imprint sup, #terms sup { font-size: 0.62em; }

/* ---- 2.x TERMS & CONDITIONS (modernes nummeriertes Layout) ------------ */
.vctm-terms { max-width: 820px; margin: 0 auto; text-align: left; }
.vctm-terms ol { list-style: none; margin: 0; padding: 0; }
.vctm-terms > ol > li {
  position: relative; padding: 22px 0 22px 60px;
  border-top: 1px solid rgba(185,18,31,0.28); scroll-margin-top: 90px;
}
.vctm-terms > ol > li:first-child { border-top: 0; padding-top: 6px; }
.vctm-term-num {
  position: absolute; left: 0; top: 21px; width: 40px; text-align: center;
  color: var(--color-accent); font-size: 22px; font-weight: 700; line-height: 1; text-decoration: none;
}
.vctm-terms > ol > li:first-child .vctm-term-num { top: 5px; }
.vctm-term-num:hover { text-decoration: underline; }
.vctm-terms .vctm-terms-main { color: var(--color-text); font-weight: 700; line-height: 1.6; }
.vctm-terms ul { list-style: none; margin: 12px 0 0; padding: 0; }
.vctm-terms ul li {
  position: relative; padding: 6px 0 6px 20px; color: var(--color-muted); line-height: 1.6;
}
.vctm-terms ul li::before {
  content: ""; position: absolute; left: 2px; top: 13px;
  width: 6px; height: 6px; background: var(--color-accent); border-radius: 50%;
}
.vctm-terms a { color: var(--color-accent); }
.vctm-terms .vctm-terms-main strong { color: var(--color-text); }
@media (max-width: 600px) {
  .vctm-terms > ol > li { padding-left: 44px; }
  .vctm-term-num { width: 30px; font-size: 18px; }
}

/* ---- 2.x PRIVACY POLICY (eigener Abschnitt unter den Terms) ----------- */
.vctm-privacy-h { margin-top: 3.5rem !important; scroll-margin-top: 90px; }
.vctm-privacy { max-width: 820px; margin: 0 auto; }
.vctm-privacy ul { list-style: none; margin: 0; padding: 0; }
.vctm-privacy > ul > li {
  position: relative; padding: 16px 0 16px 22px; color: var(--color-muted); line-height: 1.6;
  border-top: 1px solid rgba(185,18,31,0.28);
}
.vctm-privacy > ul > li:first-child { border-top: 0; }
.vctm-privacy > ul > li::before {
  content: ""; position: absolute; left: 2px; top: 24px;
  width: 6px; height: 6px; background: var(--color-accent); border-radius: 50%;
}
.vctm-privacy > ul > li strong { color: var(--color-text); }
.vctm-privacy a { color: var(--color-accent); }

/* ---- 2.x DOWNLOAD-PROGRAM Button: auto-ausblenden ohne echten Link ----- */
/* Sichtbar, sobald im Button ein echter Link (kein #/leer) gesetzt ist. */
.vctm-program-btn:has(> a:not([href])),
.vctm-program-btn:has(> a[href=""]),
.vctm-program-btn:has(> a[href="#"]) { display: none !important; }

/* ---- 2.x PROGRAMM: Milonga-Block (rot unterlegt) + DJ-Zeile hervorgehoben ---- */
.vctm-row.vctm-milonga { background: rgba(185,18,31,.13) !important; }
.vctm-row .vctm-dj {
  text-align: center !important;
  font-weight: 700;
  color: #ff2b34 !important;            /* helles Rot, hervorgehoben (Programm-DJ-Zeile) */
  letter-spacing: 1px;
  margin: 14px 0 !important;            /* Abstand oben + unten */
}
.vctm-row .vctm-dj strong { color: inherit; font-weight: 700; }

/* ===== Terms & Conditions + Privacy Policy (Block-basiert, integriert 2026-06-25) =====
   Wirkt NUR auf .vctm-terms-blocks / .vctm-privacy-blocks.
   Werte exakt aus dem Original (Desktop). Nummern automatisch (Counter)
   UND anklickbar (Self-Link). Privacy-Items ebenfalls verlinkbar.
   ==================================================================== */

/* ---------- TERMS ---------- */
.vctm-terms-blocks.wp-block-group{
  max-width:820px !important;
  margin-left:auto !important; margin-right:auto !important;
  text-align:left; counter-reset: vctmterm;
}
.vctm-terms-blocks .vctm-terms-main{
  position:relative; margin:0; padding:22px 0 22px 60px;
  border-top:1px solid rgba(185,18,31,0.28);
  color:var(--color-text); font-weight:700; line-height:1.6;
  scroll-margin-top:90px; counter-increment: vctmterm;
}
.vctm-terms-blocks .vctm-terms-main:has(+ ul){ padding-bottom:0; }
.vctm-terms-blocks > .vctm-terms-main:first-child{ border-top:0; padding-top:6px; }

/* Nummer: automatisch (Counter), exakt Original-Desktop-Werte */
.vctm-terms-blocks .vctm-terms-main::before{
  content: counter(vctmterm);
  position:absolute; left:0; top:21px; width:40px; text-align:center;
  color:var(--color-accent); font-size:22px; font-weight:700; line-height:1;
}
.vctm-terms-blocks > .vctm-terms-main:first-child::before{ top:5px; }
/* anklickbarer Self-Link über der Nummer */
.vctm-terms-blocks .vctm-term-num{
  position:absolute; left:0; top:17px; width:40px; height:1.7em;
  z-index:2; text-decoration:none;
}
.vctm-terms-blocks > .vctm-terms-main:first-child .vctm-term-num{ top:1px; }
.vctm-terms-blocks .vctm-terms-main:hover::before{ text-decoration:underline; }
.vctm-terms-blocks .vctm-terms-main strong{ color:var(--color-text); }

.vctm-terms-blocks ul{ list-style:none; margin:12px 0 22px; padding:0 0 0 60px; }
.vctm-terms-blocks ul li{
  position:relative; padding:6px 0 6px 20px; color:var(--color-muted); line-height:1.6;
}
.vctm-terms-blocks ul li::before{
  content:""; position:absolute; left:2px; top:13px;
  width:6px; height:6px; background:var(--color-accent); border-radius:50%;
}

/* ---------- PRIVACY ---------- */
.vctm-privacy-h{ margin-top:3.5rem !important; scroll-margin-top:90px; }
.vctm-privacy-blocks.wp-block-group{
  max-width:820px !important;
  margin-left:auto !important; margin-right:auto !important;
  text-align:left;
}
.vctm-privacy-blocks .vctm-privacy-item{
  position:relative; margin:0; padding:16px 0 16px 22px;
  border-top:1px solid rgba(185,18,31,0.28);
  color:var(--color-muted); line-height:1.6; scroll-margin-top:90px;
}
.vctm-privacy-blocks > .vctm-privacy-item:first-child{ border-top:0; }
.vctm-privacy-blocks .vctm-privacy-item::before{
  content:""; position:absolute; left:2px; top:24px;
  width:6px; height:6px; background:var(--color-accent); border-radius:50%;
}
.vctm-privacy-blocks .vctm-privacy-item strong{ color:var(--color-text); }
.vctm-privacy-blocks .vctm-privacy-item a{ color:var(--color-accent); }
/* Self-Link am fett gedruckten Titel (großes, intuitives Klick-Target) */
.vctm-privacy-blocks .vctm-privacy-item a.vctm-privacy-num{ color:var(--color-text); text-decoration:none; }
.vctm-privacy-blocks .vctm-privacy-item a.vctm-privacy-num strong{ color:var(--color-text); }
.vctm-privacy-blocks .vctm-privacy-item a.vctm-privacy-num:hover{ text-decoration:underline; cursor:pointer; }

/* ---------- Mobile ---------- */
@media (max-width:600px){
  .vctm-terms-blocks .vctm-terms-main{ padding-left:44px; }
  .vctm-terms-blocks .vctm-terms-main::before{ width:30px; font-size:18px; }
  .vctm-terms-blocks .vctm-term-num{ width:30px; }
  .vctm-terms-blocks ul{ padding-left:44px; }
}

/* ---------- Seitenabstand oben/unten ---------- */
/* über der ersten Überschrift (TERMS); via vctm-divider terms-spezifisch */
.wp-block-post-content > .wp-block-heading:first-child:has(+ .vctm-divider){
  padding-top: 3rem;
}
/* unter dem letzten Block (Privacy-Ende) */
/* unterer Abstand NUR wo die 900px-Huelle fehlt (Testseite); padding statt
   margin, da Theme last-child margin-block-end:0 erzwingt. Live-Seite hat die
   Huelle mit padding-bottom:4.5rem und wird hier nicht getroffen. */
.entry-content > .vctm-privacy-blocks{ padding-bottom: 3.5rem; }

