@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@500;600;700&family=Manrope:wght@400;500;600;700&display=swap');

.page-template-page-landing,
.page-template-page-landing-php {
  --rostock-ink: var(--bs-body-color, inherit);
  --rostock-muted: color-mix(in srgb, var(--bs-body-color, currentColor) 66%, transparent);
  --rostock-bg: var(--bs-body-bg, transparent);
  --rostock-paper: color-mix(in srgb, var(--bs-body-bg, transparent) 90%, var(--bs-body-color, currentColor) 10%);
  --rostock-soft: color-mix(in srgb, var(--bs-body-bg, transparent) 82%, var(--bs-body-color, currentColor) 18%);
  --rostock-accent: var(--ve-dark-accent, var(--ve-accent-light, var(--bs-primary, #0d6efd)));
  --rostock-accent-strong: color-mix(in srgb, var(--rostock-accent) 76%, var(--bs-body-color, currentColor) 24%);
  --rostock-border: color-mix(in srgb, var(--rostock-accent) 28%, transparent);
  --rostock-shadow: 0 20px 38px color-mix(in srgb, var(--bs-body-color, currentColor) 20%, transparent);
}

.page-template-page-landing .rostock-onepage,
.page-template-page-landing-php .rostock-onepage {
  background:
    radial-gradient(circle at 7% 10%, color-mix(in srgb, var(--rostock-accent) 15%, transparent), transparent 36%),
    radial-gradient(circle at 89% 12%, color-mix(in srgb, var(--rostock-accent) 10%, transparent), transparent 34%),
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--rostock-bg) 97%, var(--rostock-accent) 3%) 0%,
      color-mix(in srgb, var(--rostock-bg) 93%, var(--rostock-accent) 7%) 48%,
      color-mix(in srgb, var(--rostock-bg) 97%, var(--rostock-accent) 3%) 100%
    );
  color: var(--rostock-ink);
  font-family: 'Manrope', 'Segoe UI', sans-serif;
}

.page-template-page-landing .rostock-section,
.page-template-page-landing-php .rostock-section {
  position: relative;
}

.page-template-page-landing .rostock-section-soft,
.page-template-page-landing-php .rostock-section-soft {
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--rostock-bg) 92%, var(--rostock-accent) 8%) 0%,
    color-mix(in srgb, var(--rostock-bg) 84%, var(--rostock-accent) 16%) 100%
  );
}

.page-template-page-landing .landing-header,
.page-template-page-landing-php .landing-header {
  background: color-mix(in srgb, var(--rostock-bg) 86%, transparent);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--rostock-border);
}

.page-template-page-landing .landing-header .nav-link,
.page-template-page-landing-php .landing-header .nav-link {
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--rostock-accent) 35%, transparent);
  color: color-mix(in srgb, var(--rostock-accent) 72%, var(--rostock-ink) 28%);
  font-family: 'Manrope', 'Segoe UI', sans-serif;
  font-weight: 600;
  letter-spacing: 0.02em;
  padding: 0.42rem 0.9rem;
  transition: all 0.25s ease;
}

.page-template-page-landing .landing-header .nav-link:hover,
.page-template-page-landing .landing-header .nav-link:focus-visible,
.page-template-page-landing-php .landing-header .nav-link:hover,
.page-template-page-landing-php .landing-header .nav-link:focus-visible {
  background: color-mix(in srgb, var(--rostock-accent) 18%, transparent);
  border-color: color-mix(in srgb, var(--rostock-accent) 56%, transparent);
}

.page-template-page-landing .landing-header .nav-link.active,
.page-template-page-landing-php .landing-header .nav-link.active {
  background: color-mix(in srgb, var(--rostock-accent) 24%, transparent);
  border-color: color-mix(in srgb, var(--rostock-accent) 68%, transparent);
  color: color-mix(in srgb, var(--rostock-accent) 82%, var(--rostock-ink) 18%);
}

.page-template-page-landing .rostock-eyebrow,
.page-template-page-landing-php .rostock-eyebrow {
  color: var(--rostock-muted);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  margin-bottom: 1rem;
  text-transform: uppercase;
}

.page-template-page-landing .rostock-hero-title,
.page-template-page-landing-php .rostock-hero-title {
  color: var(--rostock-ink);
  font-family: 'Cinzel', Georgia, serif;
  font-size: clamp(2.2rem, 5.2vw, 4rem);
  font-weight: 700;
  letter-spacing: 0.01em;
  line-height: 1.07;
  margin-bottom: 0.9rem;
}

.page-template-page-landing .rostock-divider,
.page-template-page-landing-php .rostock-divider {
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--rostock-accent) 84%, transparent),
    color-mix(in srgb, var(--rostock-accent) 46%, transparent),
    color-mix(in srgb, var(--rostock-accent) 0%, transparent)
  );
  height: 2px;
  margin-bottom: 1.2rem;
  max-width: 420px;
}

.page-template-page-landing .rostock-hero-description,
.page-template-page-landing-php .rostock-hero-description {
  color: color-mix(in srgb, var(--rostock-ink) 86%, transparent);
  font-size: clamp(1rem, 2vw, 1.12rem);
  line-height: 1.72;
  max-width: 700px;
}

.page-template-page-landing .rostock-stat-card,
.page-template-page-landing-php .rostock-stat-card {
  background: color-mix(in srgb, var(--rostock-paper) 84%, transparent);
  border: 1px solid var(--rostock-border);
  border-radius: 1rem;
  box-shadow: 0 12px 24px color-mix(in srgb, var(--rostock-ink) 12%, transparent);
  padding: 0.86rem 1rem;
}

.page-template-page-landing .rostock-stat-value,
.page-template-page-landing-php .rostock-stat-value {
  color: var(--rostock-accent-strong);
  font-family: 'Cinzel', Georgia, serif;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1;
}

.page-template-page-landing .rostock-stat-label,
.page-template-page-landing-php .rostock-stat-label {
  color: var(--rostock-muted);
  font-size: 0.84rem;
  margin-top: 0.25rem;
}

.page-template-page-landing .rostock-heraldic-card,
.page-template-page-landing-php .rostock-heraldic-card {
  background: linear-gradient(
    160deg,
    color-mix(in srgb, var(--rostock-paper) 92%, transparent),
    color-mix(in srgb, var(--rostock-soft) 92%, transparent)
  );
  border: 1px solid var(--rostock-border);
  border-radius: 1.35rem;
  box-shadow: var(--rostock-shadow);
  padding: 1.2rem;
}

.page-template-page-landing .rostock-heraldic-figure,
.page-template-page-landing-php .rostock-heraldic-figure {
  border-radius: 1rem;
  overflow: hidden;
  margin-bottom: 0.95rem;
}

.page-template-page-landing .rostock-heraldic-figure img,
.page-template-page-landing-php .rostock-heraldic-figure img {
  display: block;
  width: 100%;
  height: auto;
}

.page-template-page-landing .rostock-heraldic-caption,
.page-template-page-landing-php .rostock-heraldic-caption {
  color: color-mix(in srgb, var(--rostock-ink) 76%, transparent);
  font-size: 0.87rem;
  line-height: 1.55;
  text-align: center;
}

.page-template-page-landing .rostock-kicker,
.page-template-page-landing-php .rostock-kicker {
  color: var(--rostock-accent-strong);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.page-template-page-landing .rostock-section-title,
.page-template-page-landing-php .rostock-section-title {
  color: var(--rostock-ink);
  font-family: 'Cinzel', Georgia, serif;
  font-size: clamp(1.85rem, 4.2vw, 3.2rem);
  font-weight: 700;
  line-height: 1.08;
}

.page-template-page-landing .rostock-section-subtitle,
.page-template-page-landing-php .rostock-section-subtitle {
  color: color-mix(in srgb, var(--rostock-ink) 78%, transparent);
  line-height: 1.66;
}

.page-template-page-landing .rostock-meta-chip,
.page-template-page-landing-php .rostock-meta-chip {
  border: 1px solid color-mix(in srgb, var(--rostock-accent) 44%, transparent);
  border-radius: 999px;
  color: color-mix(in srgb, var(--rostock-accent) 78%, var(--rostock-ink) 22%);
  display: inline-flex;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  padding: 0.42rem 0.82rem;
  text-transform: uppercase;
}

.page-template-page-landing .rostock-tree-root,
.page-template-page-landing-php .rostock-tree-root {
  background: color-mix(in srgb, var(--rostock-paper) 84%, transparent);
  border: 1px solid var(--rostock-border);
  border-radius: 1.2rem;
  box-shadow: 0 16px 30px color-mix(in srgb, var(--rostock-ink) 12%, transparent);
  padding: 1rem;
}

.page-template-page-landing .rostock-tree-node,
.page-template-page-landing-php .rostock-tree-node {
  border-radius: 1rem;
  position: relative;
}

.page-template-page-landing .rostock-tree-node--root,
.page-template-page-landing-php .rostock-tree-node--root {
  background: linear-gradient(
    145deg,
    color-mix(in srgb, var(--rostock-accent) 78%, var(--rostock-bg) 22%),
    color-mix(in srgb, var(--rostock-accent-strong) 84%, var(--rostock-bg) 16%)
  );
  color: color-mix(in srgb, var(--rostock-bg) 84%, var(--rostock-ink) 16%);
  font-family: 'Cinzel', Georgia, serif;
  font-size: 1.35rem;
  font-weight: 700;
  margin: 0 auto 1.1rem;
  max-width: 320px;
  padding: 0.82rem 1rem;
  text-align: center;
}

.page-template-page-landing .rostock-tree-branches,
.page-template-page-landing-php .rostock-tree-branches {
  display: grid;
  gap: 0.95rem;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.page-template-page-landing .rostock-tree-node--branch,
.page-template-page-landing-php .rostock-tree-node--branch {
  background: linear-gradient(
    165deg,
    color-mix(in srgb, var(--rostock-paper) 90%, transparent),
    color-mix(in srgb, var(--rostock-soft) 84%, transparent)
  );
  border: 1px solid var(--rostock-border);
  box-shadow: 0 12px 24px color-mix(in srgb, var(--rostock-ink) 10%, transparent);
  height: 100%;
  padding: 0.95rem;
}

.page-template-page-landing .rostock-tree-period,
.page-template-page-landing-php .rostock-tree-period {
  color: var(--rostock-accent-strong);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.page-template-page-landing .rostock-tree-node--branch h3,
.page-template-page-landing-php .rostock-tree-node--branch h3 {
  color: var(--rostock-ink);
  font-family: 'Cinzel', Georgia, serif;
  font-size: 1.2rem;
  font-weight: 700;
  margin-bottom: 0.48rem;
}

.page-template-page-landing .rostock-tree-node--branch p,
.page-template-page-landing-php .rostock-tree-node--branch p {
  color: color-mix(in srgb, var(--rostock-ink) 82%, transparent);
  font-size: 0.9rem;
  line-height: 1.58;
}

.page-template-page-landing .rostock-tree-node--branch li,
.page-template-page-landing-php .rostock-tree-node--branch li {
  color: color-mix(in srgb, var(--rostock-ink) 78%, transparent);
  font-size: 0.84rem;
  line-height: 1.48;
}

.page-template-page-landing .rostock-tree-node--branch li i,
.page-template-page-landing-php .rostock-tree-node--branch li i {
  color: var(--rostock-accent-strong);
  margin-top: 0.18rem;
}

.page-template-page-landing .rostock-footnote,
.page-template-page-landing-php .rostock-footnote {
  color: color-mix(in srgb, var(--rostock-ink) 72%, transparent);
  font-size: 0.83rem;
}

.page-template-page-landing .rostock-map-shell,
.page-template-page-landing-php .rostock-map-shell {
  background: color-mix(in srgb, var(--rostock-paper) 86%, transparent);
  border: 1px solid var(--rostock-border);
  border-radius: 1.2rem;
  box-shadow: 0 20px 38px color-mix(in srgb, var(--rostock-ink) 14%, transparent);
  overflow: hidden;
  padding: 0.52rem;
}

.page-template-page-landing .rostock-world-map,
.page-template-page-landing-php .rostock-world-map {
  border-radius: 0.88rem;
  height: min(64vh, 600px);
  min-height: 400px;
  width: 100%;
}

.page-template-page-landing .rostock-map-list,
.page-template-page-landing-php .rostock-map-list {
  background: color-mix(in srgb, var(--rostock-paper) 82%, transparent);
  border: 1px solid var(--rostock-border);
  border-radius: 1.1rem;
  box-shadow: 0 14px 32px color-mix(in srgb, var(--rostock-ink) 12%, transparent);
  padding: 1rem;
}

.page-template-page-landing .rostock-map-list h3,
.page-template-page-landing-php .rostock-map-list h3 {
  color: var(--rostock-ink);
  font-family: 'Cinzel', Georgia, serif;
  font-weight: 700;
}

.page-template-page-landing .rostock-map-point-btn,
.page-template-page-landing-php .rostock-map-point-btn {
  background: color-mix(in srgb, var(--rostock-paper) 90%, transparent);
  border: 1px solid color-mix(in srgb, var(--rostock-accent) 24%, transparent);
  border-radius: 0.84rem;
  color: color-mix(in srgb, var(--rostock-ink) 86%, transparent);
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  padding: 0.7rem 0.75rem;
  text-align: left;
  transition: all 0.22s ease;
  width: 100%;
}

.page-template-page-landing .rostock-map-point-btn:hover,
.page-template-page-landing .rostock-map-point-btn:focus-visible,
.page-template-page-landing-php .rostock-map-point-btn:hover,
.page-template-page-landing-php .rostock-map-point-btn:focus-visible {
  background: color-mix(in srgb, var(--rostock-accent) 10%, var(--rostock-paper) 90%);
  border-color: color-mix(in srgb, var(--rostock-accent) 46%, transparent);
  transform: translateY(-1px);
}

.page-template-page-landing .rostock-map-point-btn.is-focused,
.page-template-page-landing-php .rostock-map-point-btn.is-focused {
  background: color-mix(in srgb, var(--rostock-accent) 18%, var(--rostock-paper) 82%);
  border-color: color-mix(in srgb, var(--rostock-accent) 66%, transparent);
}

.page-template-page-landing .rostock-map-point-btn.is-hidden,
.page-template-page-landing-php .rostock-map-point-btn.is-hidden {
  display: none;
}

.page-template-page-landing .rostock-map-point-city,
.page-template-page-landing-php .rostock-map-point-city {
  font-size: 0.92rem;
  font-weight: 700;
}

.page-template-page-landing .rostock-map-point-meta,
.page-template-page-landing-php .rostock-map-point-meta {
  color: color-mix(in srgb, var(--rostock-ink) 68%, transparent);
  font-size: 0.76rem;
}

.page-template-page-landing .rostock-timeline-card,
.page-template-page-landing-php .rostock-timeline-card {
  background: linear-gradient(
    165deg,
    color-mix(in srgb, var(--rostock-paper) 90%, transparent),
    color-mix(in srgb, var(--rostock-soft) 84%, transparent)
  );
  border: 1px solid var(--rostock-border);
  border-radius: 1rem;
  box-shadow: 0 12px 28px color-mix(in srgb, var(--rostock-ink) 10%, transparent);
  padding: 1rem;
}

.page-template-page-landing .rostock-timeline-year,
.page-template-page-landing-php .rostock-timeline-year {
  color: var(--rostock-accent-strong);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.page-template-page-landing .rostock-timeline-card h3,
.page-template-page-landing-php .rostock-timeline-card h3 {
  color: var(--rostock-ink);
  font-family: 'Cinzel', Georgia, serif;
  font-size: 1.08rem;
  font-weight: 700;
  margin-bottom: 0.45rem;
}

.page-template-page-landing .rostock-timeline-card p,
.page-template-page-landing-php .rostock-timeline-card p {
  color: color-mix(in srgb, var(--rostock-ink) 80%, transparent);
  font-size: 0.89rem;
  line-height: 1.58;
}

/* Modernizacao da arvore genealogica */
.page-template-page-landing .rostock-tree-root--modern,
.page-template-page-landing-php .rostock-tree-root--modern {
  background:
    radial-gradient(circle at 12% 18%, color-mix(in srgb, var(--rostock-accent) 10%, transparent) 0%, transparent 46%),
    radial-gradient(circle at 88% 84%, color-mix(in srgb, var(--rostock-accent-strong) 12%, transparent) 0%, transparent 48%),
    color-mix(in srgb, var(--rostock-paper) 88%, transparent);
  border: 1px solid color-mix(in srgb, var(--rostock-border) 84%, transparent);
  border-radius: 1.35rem;
  box-shadow: 0 24px 46px color-mix(in srgb, var(--rostock-ink) 13%, transparent);
  overflow: hidden;
  padding: 1.2rem 1.15rem 1.05rem;
  position: relative;
}

.page-template-page-landing .rostock-tree-root--modern .rostock-tree-node--root,
.page-template-page-landing-php .rostock-tree-root--modern .rostock-tree-node--root {
  border: 1px solid color-mix(in srgb, var(--rostock-paper) 52%, transparent);
  box-shadow: 0 14px 28px color-mix(in srgb, var(--rostock-ink) 22%, transparent);
  margin-bottom: 0.95rem;
  position: relative;
  z-index: 2;
}

.page-template-page-landing .rostock-tree-root--modern .rostock-tree-node--root::after,
.page-template-page-landing-php .rostock-tree-root--modern .rostock-tree-node--root::after {
  background: color-mix(in srgb, var(--rostock-accent-strong) 55%, var(--rostock-paper) 45%);
  border-radius: 999px;
  content: '';
  display: block;
  height: 2rem;
  left: 50%;
  position: absolute;
  top: calc(100% + 0.05rem);
  transform: translateX(-50%);
  width: 2px;
}

.page-template-page-landing .rostock-tree-branches--modern,
.page-template-page-landing-php .rostock-tree-branches--modern {
  gap: 1rem;
  margin-top: 1.35rem;
  padding-top: 1.1rem;
  position: relative;
}

.page-template-page-landing .rostock-tree-branches--modern::before,
.page-template-page-landing-php .rostock-tree-branches--modern::before {
  background: color-mix(in srgb, var(--rostock-accent-strong) 34%, transparent);
  border-radius: 999px;
  content: '';
  height: 2px;
  left: 8%;
  position: absolute;
  right: 8%;
  top: 0;
}

.page-template-page-landing .rostock-tree-node--branch-modern,
.page-template-page-landing-php .rostock-tree-node--branch-modern {
  border-left: 4px solid color-mix(in srgb, var(--rostock-accent) 64%, var(--rostock-bg) 36%);
  border-radius: 1rem;
  min-height: 100%;
  padding: 1.05rem 1rem 0.95rem;
  position: relative;
  transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease;
}

.page-template-page-landing .rostock-tree-node--branch-modern::before,
.page-template-page-landing-php .rostock-tree-node--branch-modern::before {
  background: color-mix(in srgb, var(--rostock-accent-strong) 46%, var(--rostock-paper) 54%);
  border-radius: 999px;
  content: '';
  height: 1rem;
  left: calc(50% - 1px);
  position: absolute;
  top: -1rem;
  width: 2px;
}

.page-template-page-landing .rostock-tree-node--branch-modern:hover,
.page-template-page-landing .rostock-tree-node--branch-modern:focus-within,
.page-template-page-landing-php .rostock-tree-node--branch-modern:hover,
.page-template-page-landing-php .rostock-tree-node--branch-modern:focus-within {
  border-left-color: color-mix(in srgb, var(--rostock-accent-strong) 76%, var(--rostock-accent) 24%);
  box-shadow: 0 18px 34px color-mix(in srgb, var(--rostock-ink) 17%, transparent);
  transform: translateY(-3px);
}

.page-template-page-landing .rostock-tree-node--branch-modern .list-unstyled,
.page-template-page-landing-php .rostock-tree-node--branch-modern .list-unstyled {
  margin-top: 0.18rem;
}

/* Regua temporal moderna */
.page-template-page-landing .rostock-timeline-ruler,
.page-template-page-landing-php .rostock-timeline-ruler {
  position: relative;
}

.page-template-page-landing .rostock-timeline-ruler::before,
.page-template-page-landing-php .rostock-timeline-ruler::before {
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--rostock-accent) 72%, transparent),
    color-mix(in srgb, var(--rostock-accent-strong) 64%, transparent)
  );
  border-radius: 999px;
  content: '';
  height: 3px;
  left: calc(var(--bs-gutter-x) * 0.5);
  position: absolute;
  right: calc(var(--bs-gutter-x) * 0.5);
  top: 0.6rem;
}

.page-template-page-landing .rostock-timeline-step,
.page-template-page-landing-php .rostock-timeline-step {
  position: relative;
}

.page-template-page-landing .rostock-timeline-card--ruler,
.page-template-page-landing-php .rostock-timeline-card--ruler {
  border: 1px solid color-mix(in srgb, var(--rostock-border) 86%, transparent);
  margin-top: 1.2rem;
  padding-top: 1.15rem;
  position: relative;
  transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease;
}

.page-template-page-landing .rostock-timeline-card--ruler::before,
.page-template-page-landing-php .rostock-timeline-card--ruler::before {
  background: linear-gradient(
    145deg,
    color-mix(in srgb, var(--rostock-accent) 72%, var(--rostock-bg) 28%),
    color-mix(in srgb, var(--rostock-accent-strong) 78%, var(--rostock-bg) 22%)
  );
  border: 3px solid color-mix(in srgb, var(--rostock-paper) 92%, transparent);
  border-radius: 999px;
  box-shadow: 0 6px 16px color-mix(in srgb, var(--rostock-ink) 24%, transparent);
  content: '';
  height: 1rem;
  left: 50%;
  position: absolute;
  top: -1.7rem;
  transform: translateX(-50%);
  width: 1rem;
}

.page-template-page-landing .rostock-timeline-card--ruler:hover,
.page-template-page-landing .rostock-timeline-card--ruler:focus-within,
.page-template-page-landing-php .rostock-timeline-card--ruler:hover,
.page-template-page-landing-php .rostock-timeline-card--ruler:focus-within {
  border-color: color-mix(in srgb, var(--rostock-accent) 56%, var(--rostock-border) 44%);
  box-shadow: 0 18px 36px color-mix(in srgb, var(--rostock-ink) 18%, transparent);
  transform: translateY(-3px);
}

.page-template-page-landing .rostock-contact,
.page-template-page-landing-php .rostock-contact {
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--rostock-bg) 92%, var(--rostock-accent) 8%) 0%,
    color-mix(in srgb, var(--rostock-bg) 84%, var(--rostock-accent) 16%) 100%
  );
}

.page-template-page-landing .rostock-contact-text,
.page-template-page-landing-php .rostock-contact-text {
  color: color-mix(in srgb, var(--rostock-ink) 82%, transparent);
  line-height: 1.74;
}

.page-template-page-landing .rostock-contact-links,
.page-template-page-landing-php .rostock-contact-links {
  background: color-mix(in srgb, var(--rostock-paper) 88%, transparent);
  border: 1px solid var(--rostock-border);
  border-radius: 1.05rem;
  box-shadow: 0 14px 32px color-mix(in srgb, var(--rostock-ink) 12%, transparent);
}

.page-template-page-landing .rostock-onepage .btn.btn-primary,
.page-template-page-landing-php .rostock-onepage .btn.btn-primary {
  background: var(--rostock-accent);
  border-color: var(--rostock-accent);
  color: var(--bs-body-bg, #fff);
}

.page-template-page-landing .rostock-onepage .btn.btn-primary:hover,
.page-template-page-landing .rostock-onepage .btn.btn-primary:focus-visible,
.page-template-page-landing-php .rostock-onepage .btn.btn-primary:hover,
.page-template-page-landing-php .rostock-onepage .btn.btn-primary:focus-visible {
  background: color-mix(in srgb, var(--rostock-accent) 88%, var(--rostock-ink) 12%);
  border-color: color-mix(in srgb, var(--rostock-accent) 80%, var(--rostock-ink) 20%);
}

.page-template-page-landing .rostock-onepage .btn.btn-outline-secondary,
.page-template-page-landing-php .rostock-onepage .btn.btn-outline-secondary {
  border-color: color-mix(in srgb, var(--rostock-accent) 48%, transparent);
  color: color-mix(in srgb, var(--rostock-accent) 80%, var(--rostock-ink) 20%);
}

.page-template-page-landing .rostock-onepage .btn.btn-outline-secondary:hover,
.page-template-page-landing .rostock-onepage .btn.btn-outline-secondary:focus-visible,
.page-template-page-landing-php .rostock-onepage .btn.btn-outline-secondary:hover,
.page-template-page-landing-php .rostock-onepage .btn.btn-outline-secondary:focus-visible {
  background: color-mix(in srgb, var(--rostock-accent) 16%, transparent);
  border-color: color-mix(in srgb, var(--rostock-accent) 66%, transparent);
}

.page-template-page-landing .rostock-reveal,
.page-template-page-landing-php .rostock-reveal {
  animation: rostock-rise 0.9s cubic-bezier(0.22, 1, 0.36, 1) both;
  opacity: 0;
}

.page-template-page-landing .rostock-reveal-delay-1,
.page-template-page-landing-php .rostock-reveal-delay-1 {
  animation-delay: 120ms;
}

.page-template-page-landing .rostock-reveal-delay-2,
.page-template-page-landing-php .rostock-reveal-delay-2 {
  animation-delay: 240ms;
}

.page-template-page-landing .rostock-reveal-delay-3,
.page-template-page-landing-php .rostock-reveal-delay-3 {
  animation-delay: 360ms;
}

.page-template-page-landing .rostock-reveal-delay-4,
.page-template-page-landing-php .rostock-reveal-delay-4 {
  animation-delay: 500ms;
}

@keyframes rostock-rise {
  from {
    opacity: 0;
    transform: translateY(22px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 1199.98px) {
  .page-template-page-landing .rostock-tree-branches,
  .page-template-page-landing-php .rostock-tree-branches {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .page-template-page-landing .rostock-tree-branches--modern::before,
  .page-template-page-landing-php .rostock-tree-branches--modern::before {
    left: 3%;
    right: 3%;
  }
}

@media (max-width: 991.98px) {
  .page-template-page-landing .rostock-hero-title,
  .page-template-page-landing-php .rostock-hero-title {
    font-size: clamp(2rem, 7vw, 3rem);
  }

  .page-template-page-landing .rostock-world-map,
  .page-template-page-landing-php .rostock-world-map {
    min-height: 340px;
  }
}

@media (max-width: 767.98px) {
  .page-template-page-landing .rostock-tree-branches,
  .page-template-page-landing-php .rostock-tree-branches {
    grid-template-columns: minmax(0, 1fr);
  }

  .page-template-page-landing .rostock-hero-title,
  .page-template-page-landing-php .rostock-hero-title {
    letter-spacing: 0;
  }

  .page-template-page-landing .rostock-world-map,
  .page-template-page-landing-php .rostock-world-map {
    min-height: 300px;
    height: 52vh;
  }

  .page-template-page-landing .rostock-tree-root--modern,
  .page-template-page-landing-php .rostock-tree-root--modern {
    padding: 1rem 0.9rem 0.9rem;
  }

  .page-template-page-landing .rostock-tree-root--modern .rostock-tree-node--root::after,
  .page-template-page-landing-php .rostock-tree-root--modern .rostock-tree-node--root::after,
  .page-template-page-landing .rostock-tree-branches--modern::before,
  .page-template-page-landing-php .rostock-tree-branches--modern::before {
    display: none;
  }

  .page-template-page-landing .rostock-tree-node--branch-modern::before,
  .page-template-page-landing-php .rostock-tree-node--branch-modern::before {
    left: 1.2rem;
    top: -0.65rem;
  }

  .page-template-page-landing .rostock-timeline-ruler::before,
  .page-template-page-landing-php .rostock-timeline-ruler::before {
    bottom: 0.8rem;
    height: auto;
    left: 1.08rem;
    right: auto;
    top: 0.6rem;
    width: 3px;
  }

  .page-template-page-landing .rostock-timeline-card--ruler,
  .page-template-page-landing-php .rostock-timeline-card--ruler {
    margin-left: 1.2rem;
    margin-top: 0.55rem;
    padding-top: 0.95rem;
  }

  .page-template-page-landing .rostock-timeline-card--ruler::before,
  .page-template-page-landing-php .rostock-timeline-card--ruler::before {
    left: -1.22rem;
    top: 0.85rem;
    transform: none;
  }

  .page-template-page-landing [data-map-filter],
  .page-template-page-landing-php [data-map-filter] {
    flex: 1 1 calc(50% - 0.5rem);
    justify-content: center;
  }
}
