/*
 * 0.38.25 – Öffentliche Zuchtanlagenübersicht auf der Frontend-Foundation.
 * Astra owns normal typography and button appearance. This file owns only the
 * facilities hero, section surfaces, grids and page-specific responsive layout.
 */
body.ftpm-public-page--facilities {
  --ftpm-facilities-container: var(--ast-container-width, 1200px);
  --ftpm-facilities-edge: clamp(18px, 3vw, 36px);
  --ftpm-facilities-radius: clamp(18px, 2vw, 28px);
  --ftpm-facilities-border: color-mix(in srgb, var(--ast-global-color-0, #123b24) 18%, transparent);
  --ftpm-facilities-surface: #fff;
  --ftpm-facilities-surface-soft: color-mix(in srgb, var(--ast-global-color-6, #eef3ee) 68%, #fff);
  --ftpm-facilities-brand: var(--ast-global-color-0, #123b24);
  --ftpm-facilities-brand-alt: var(--ast-global-color-1, #2f5d3a);
}

/* Full-width shell is needed only for the full-width hero. */
body.ftpm-public-page--facilities .site-content > .ast-container,
body.ftpm-public-page--facilities .content-area,
body.ftpm-public-page--facilities .site-main,
body.ftpm-public-page--facilities article,
body.ftpm-public-page--facilities .entry-content {
  width: 100% !important;
  max-width: none !important;
  margin-inline: 0 !important;
  padding-inline: 0 !important;
}

body.ftpm-public-page--facilities .entry-header,
body.ftpm-public-page--facilities .entry-title {
  display: none !important;
}

body.ftpm-public-page--facilities .wp-block-cover.ftpm-public-hero--facilities {
  --ftpm-public-hero-title-width: 17ch;
  --ftpm-public-hero-content-width: 860px;
  --ftpm-public-hero-title-size: clamp(2.75rem, 5.15vw, 4.75rem);
  --ftpm-public-hero-intro-width: 720px;
  --ftpm-public-hero-container: var(--ftpm-facilities-container);
  --ftpm-public-hero-edge: var(--ftpm-facilities-edge);
  --ftpm-public-hero-padding-block: clamp(56px, 6vw, 86px);
  --ftpm-public-hero-title-width: 17ch;
  position: relative;
  isolation: isolate;
  display: flex;
  align-items: center;
  width: 100%;
  min-height: clamp(430px, 38vw, 610px) !important;
  margin: 0 0 clamp(38px, 5vw, 70px) !important;
  padding: 0 !important;
  overflow: hidden;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  background:
    radial-gradient(circle at 16% 8%, rgba(229,199,95,.18), transparent 30%),
    linear-gradient(115deg,
      color-mix(in srgb, var(--ftpm-facilities-brand-alt) 84%, #000 16%) 0%,
      var(--ftpm-facilities-brand) 50%,
      color-mix(in srgb, var(--ftpm-facilities-brand-alt) 80%, #0b1f2a 20%) 100%) !important;
}

body.ftpm-public-page--facilities .wp-block-cover.ftpm-public-hero--facilities::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(110deg, transparent 0 52%, rgba(255,255,255,.065) 52% 62%, transparent 62% 100%);
}

body.ftpm-public-page--facilities .wp-block-cover.ftpm-public-hero--facilities > .wp-block-cover__background {
  z-index: 1;
  background: transparent !important;
}

body.ftpm-public-page--facilities .ftpm-public-hero__actions,
body.ftpm-public-page--facilities .ftpm-public-button-group {
  gap: 14px;
  margin-top: 30px !important;
}

/* Every editable content section re-enters Astra's configured container width. */
body.ftpm-public-page--facilities .ftpm-public-section--facilities {
  width: min(calc(100% - (2 * var(--ftpm-facilities-edge))), var(--ftpm-facilities-container)) !important;
  max-width: var(--ftpm-facilities-container) !important;
  margin: 0 auto clamp(30px, 4vw, 52px) !important;
  padding: clamp(30px, 4vw, 54px) !important;
  border: 1px solid var(--ftpm-facilities-border) !important;
  border-radius: var(--ftpm-facilities-radius) !important;
  background: var(--ftpm-facilities-surface) !important;
  box-shadow: 0 18px 44px rgba(14,54,31,.07) !important;
}

body.ftpm-public-page--facilities .ftpm-public-section--facilities > :first-child { margin-top: 0 !important; }
body.ftpm-public-page--facilities .ftpm-public-section--facilities > :last-child { margin-bottom: 0 !important; }
body.ftpm-public-page--facilities .ftpm-public-section--facilities > h2,
body.ftpm-public-page--facilities .ftpm-public-section--facilities > p,
body.ftpm-public-page--facilities .ftpm-public-section--facilities > ul {
  max-width: none;
  margin-inline: 0;
}

body.ftpm-public-page--facilities .ftpm-public-card-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: clamp(18px, 2.4vw, 28px) !important;
  width: 100%;
  margin: clamp(28px, 4vw, 42px) 0 0 !important;
}

body.ftpm-public-page--facilities .ftpm-public-card {
  display: flex;
  flex-direction: column;
  min-width: 0;
  height: 100%;
  margin: 0 !important;
  padding: clamp(22px, 2.5vw, 30px) !important;
  border: 1px solid var(--ftpm-facilities-border) !important;
  border-radius: clamp(16px, 1.7vw, 22px) !important;
  background: var(--ftpm-facilities-surface-soft) !important;
  box-shadow: none !important;
}

body.ftpm-public-page--facilities .ftpm-public-card h3 { margin: 0 0 12px !important; }
body.ftpm-public-page--facilities .ftpm-public-card p { margin: 0 !important; }

body.ftpm-public-page--facilities .ftpm-facilities-live {
  padding-inline: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

body.ftpm-public-page--facilities .ftpm-facilities-live > h2,
body.ftpm-public-page--facilities .ftpm-facilities-live > p {
  width: min(calc(100% - (2 * var(--ftpm-facilities-edge))), var(--ftpm-facilities-container));
  margin-inline: auto !important;
}

body.ftpm-public-page--facilities .ftpm-facilities-live .wp-block-ftpm-facility-cards,
body.ftpm-public-page--facilities .ftpm-facilities-live .ftpm-facility-cards-anchor {
  width: min(calc(100% - (2 * var(--ftpm-facilities-edge))), var(--ftpm-facilities-container));
  max-width: var(--ftpm-facilities-container);
  margin-inline: auto;
}

body.ftpm-public-page--facilities .ftpm-facilities-faq > h3 {
  max-width: none;
  margin: 30px 0 8px !important;
}

body.ftpm-public-page--facilities .ftpm-facilities-species {
  background:
    radial-gradient(circle at 88% 10%, rgba(229,199,95,.16), transparent 30%),
    color-mix(in srgb, var(--ftpm-facilities-surface-soft) 72%, #fff) !important;
}

body.ftpm-public-page--facilities .entry-content > p:empty:last-child { display: none !important; }

@media (max-width: 980px) {
  body.ftpm-public-page--facilities .ftpm-public-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 700px) {
  body.ftpm-public-page--facilities .wp-block-cover.ftpm-public-hero--facilities {
    min-height: auto !important;
  }
  body.ftpm-public-page--facilities .wp-block-cover.ftpm-public-hero--facilities > .wp-block-cover__inner-container > .wp-block-group {
    padding-block: 46px 54px;
  }
  body.ftpm-public-page--facilities .ftpm-public-hero--facilities {
    --ftpm-public-hero-title-width: 100%;
    --ftpm-public-hero-title-size: clamp(2.35rem, 11vw, 3.5rem);
  }
  body.ftpm-public-page--facilities .ftpm-public-card-grid {
    grid-template-columns: 1fr !important;
  }
  body.ftpm-public-page--facilities .ftpm-public-section--facilities {
    padding: 26px 22px !important;
  }
  body.ftpm-public-page--facilities .ftpm-public-hero__actions,
  body.ftpm-public-page--facilities .ftpm-public-hero__actions .wp-block-button,
  body.ftpm-public-page--facilities .ftpm-public-hero__actions .wp-block-button__link {
    width: 100%;
  }
}


/* 0.38.28 – Genuine Gutenberg button structure.
 * Astra owns every visual property; FTPM owns placement only. */
body.ftpm-public-page--facilities .ftpm-facility-card .ftpm-facility-action {
  align-self: flex-start;
  width: auto;
  margin-top: 20px;
}

@media (max-width: 640px) {
  body.ftpm-public-page--facilities .ftpm-facility-card .ftpm-facility-action,
  body.ftpm-public-page--facilities .ftpm-facility-card .ftpm-facility-action .wp-block-button__link {
    width: 100%;
  }
}
