/* Auto-generated by ContentBlocks bundler – do not edit manually. */

/* --- ContentBlocks Preview --- */
/* ContentBlocks Preview – Gemeinsame Layout-Stile für alle preview.php-Seiten.
   Wird per <link rel="stylesheet" href="../contentblockspreview.css"> in jede preview.php eingebunden.
   Wird außerdem vom Bundler (bundler.php) in contentblocks_combined.css aufgenommen.
   Der body-Selektor ist auf .contentblockspreviewPage gescoped, damit er im Bundle
   keine Auswirkungen auf die Main-Site hat. */

body.contentblockspreviewPage {
    font-family: sans-serif;
    background: #f0f0f0;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100vh;
    margin: 0;
}

.contentblockspreview_wrapper {
    background: #fff;
    border-radius: 8px;
    padding: 24px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, .15);
    min-width: 320px;
}

.contentblockspreview_col {
    flex: 1;
    background: #e8e8e8;
    border-radius: 6px;
    padding: 16px;
    min-height: 80px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #777;
    font-size: 0.85em;
}

.contentblockspreview_flexRow {
    display: flex;
    gap: 12px;
}

.contentblockspreview_flexColumn {
    display: flex;
    flex-direction: column;
}

.contentblockspreview_bar {
    height: 20px;
    background: #dcdcdc;
    border-radius: 4px;
}

.contentblockspreview_placeholder {
    background: #e8e8e8;
    border-radius: 6px;
    height: 200px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    font-size: 2em;
    color: #777;
}

/* --- ContentBlock: animatedtext --- */
/* ContentBlock: animatedtext */

.contentblocks_animatedtext_holder {
  text-align: center;
  padding: var(--distance_normal) 0;
}

.contentblocks_animatedtext_text {
  font-size: clamp(1rem, 2.5vw, 1.3rem);
  line-height: 1.6;
  color: var(--css_color_contentblocks_animatedtext_text_fg, var(--css_color_element_fg));
  margin: 0;
}

.contentblocks_animatedtext_highlight {
  color: var(--css_color_contentblocks_animatedtext_highlight_fg, var(--css_color_intense_bg));
  font-weight: 800;
  display: inline-block;
  transition: opacity 0.4s ease, transform 0.4s ease;
}

.contentblocks_animatedtext_wordsEditor {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--distance_quarter);
  margin-top: var(--distance_normal);
}

.contentblocks_animatedtext_wordsLabel {
  font-size: var(--fontsize_small);
  color: var(--css_color_contentblocks_animatedtext_text_fg, var(--css_color_element_fg));
  opacity: 0.7;
}

.contentblocks_animatedtext_wordsInput {
  font-size: var(--fontsize_small);
  padding: var(--distance_quarter) var(--distance_half);
  border: 1px solid var(--css_color_element_border);
  border-radius: var(--border_radius_small);
  min-width: 280px;
}

/* --- ContentBlock: audio --- */
/* ContentBlock: audio */

.contentblocks_audio_holder {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: var(--distance_normal);
    padding-top: var(--distance_normal);
    padding-bottom: var(--distance_normal);
    padding-left: var(--distance_half);
    padding-right: var(--distance_half);
    border-radius: 0px;
    text-align: center;
    min-height: 40px;
}

.contentblocks_audio_player {
    display: block;
    min-width: 350px;
    max-width: 800px;
    margin-bottom: var(--distance_half);
}

.contentblocks_audio_subtitles ul {
    padding: 0;
    margin: 0;
}

.contentblocks_audio_subtitles {
    position: relative;
    flex: 1;
    flex-grow: 1;
    flex-shrink: 1;
    flex-basis: 40%;
    max-height: 30vh;
    height: max-content;
    min-width: min(100%, 500px);
    border-radius: var(--border_radius_normal);
    overflow-y: scroll;
    background-color: var(--css_color_element_bg);
    color: var(--css_color_element_fg);
}

.contentblocks_audio_subtitles li {
    list-style: none;
    cursor: pointer;
    margin-bottom: var(--distance_normal);
    font-size: 1.2rem;
    line-height: 1.5rem;
}

.contentblocks_audio_activeSubtitleLine {
    background-color: var(--css_color_activeSelection_bg);
}

.contentblocks_audio_activeSubtitleLineSpanExtended {
    color: var(--css_color_element_fg);
    transition: var(--layoutProperty_transitionspeed);
}

.contentblocks_audio_activeSubtitleLineSpan {
    color: var(--css_color_activeSelection_fg);
    transition: 0s;
}

/* --- ContentBlock: audioHLS --- */
/* ContentBlock: audioHLS */

.contentblocks_audioHLS_holder {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: var(--distance_normal);
    padding-top: var(--distance_normal);
    padding-bottom: var(--distance_normal);
    padding-left: var(--distance_half);
    padding-right: var(--distance_half);
    border-radius: 0px;
    text-align: center;
    min-height: 40px;
}

.contentblocks_audioHLS_player {
    display: block;
    min-width: 350px;
    max-width: 800px;
    margin-bottom: var(--distance_half);
}

.contentblocks_audioHLS_subtitles ul {
    padding: 0;
    margin: 0;
}

.contentblocks_audioHLS_subtitles {
    position: relative;
    flex: 1;
    flex-grow: 1;
    flex-shrink: 1;
    flex-basis: 40%;
    max-height: 30vh;
    height: max-content;
    min-width: min(100%, 500px);
    border-radius: var(--border_radius_normal);
    overflow-y: scroll;
    background-color: var(--css_color_element_bg);
    color: var(--css_color_element_fg);
}

.contentblocks_audioHLS_subtitles li {
    list-style: none;
    cursor: pointer;
    margin-bottom: var(--distance_normal);
    font-size: 1.2rem;
    line-height: 1.5rem;
}

.contentblocks_audioHLS_activeSubtitleLine {
    background-color: var(--css_color_activeSelection_bg);
}

.contentblocks_audioHLS_activeSubtitleLineSpanExtended {
    color: var(--css_color_element_fg);
    transition: var(--layoutProperty_transitionspeed);
}

.contentblocks_audioHLS_activeSubtitleLineSpan {
    color: var(--css_color_activeSelection_fg);
    transition: 0s;
}

/* --- ContentBlock: button --- */
/* ContentBlock: button */

.contentblocks_button_holder {
    width: 100%;
    display: flex;
    justify-content: center;
    padding: var(--distance_half) 0;
    box-sizing: border-box;
}

.contentblocks_button_link {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    min-width: 160px;
    padding: 10px 18px;
    border-radius: 999px;
    border: 1px solid var(--css_color_contentblocks_button_primary_border, var(--css_color_buttonPrimary_border));
    background: var(--css_color_contentblocks_button_primary_bg, var(--css_color_buttonPrimary_bg));
    color: var(--css_color_contentblocks_button_primary_fg, var(--css_color_buttonPrimary_fg));
    font-weight: 600;
    text-decoration: none;
    transition: var(--layoutProperty_transitionspeed);
}

.contentblocks_button_link:hover {
    border-color: var(--css_color_contentblocks_button_primary_border_hover, var(--css_color_buttonPrimary_border_hover));
    background: var(--css_color_contentblocks_button_primary_bg_hover, var(--css_color_buttonPrimary_bg_hover));
    color: var(--css_color_contentblocks_button_primary_fg_hover, var(--css_color_buttonPrimary_fg_hover));
}

.contentblocks_button_link--edit {
    pointer-events: none;
}

.contentblocks_button_link--outline {
    border-color: var(--css_color_contentblocks_button_outline_border, var(--css_color_buttonPrimary_bg));
    background: var(--css_color_contentblocks_button_outline_bg, transparent);
    color: var(--css_color_contentblocks_button_outline_fg, var(--css_color_buttonPrimary_bg));
}

.contentblocks_button_link--outline:hover {
    border-color: var(--css_color_contentblocks_button_outline_border_hover, var(--css_color_buttonPrimary_bg_hover));
    background: var(--css_color_contentblocks_button_outline_bg_hover, color-mix(in srgb, var(--css_color_buttonPrimary_bg) 8%, transparent));
    color: var(--css_color_contentblocks_button_outline_fg_hover, var(--css_color_buttonPrimary_bg_hover));
}

.contentblocks_button_link--subtle {
    border-color: var(--css_color_contentblocks_button_subtle_border, var(--css_color_border_fg));
    background: var(--css_color_contentblocks_button_subtle_bg, var(--css_color_element_bg));
    color: var(--css_color_contentblocks_button_subtle_fg, var(--css_color_element_fg));
}

.contentblocks_button_link--subtle:hover {
    border-color: var(--css_color_contentblocks_button_subtle_border_hover, var(--css_color_border_fg));
    background: var(--css_color_contentblocks_button_subtle_bg_hover, var(--css_color_element_bg_hover));
    color: var(--css_color_contentblocks_button_subtle_fg_hover, var(--css_color_element_fg_hover));
}

/* --- ContentBlock: callout --- */
/* ContentBlock: callout */

.contentblocks_callout_holder {
    display: flex;
    align-items: flex-start;
    gap: var(--distance_normal);
    width: 100%;
    box-sizing: border-box;
    padding: var(--distance_normal);
    border-radius: var(--border_radius_normal);
    border-left: 4px solid currentColor;
}

.contentblocks_callout_icon {
    margin-top: 2px;
    flex-shrink: 0;
}

.contentblocks_callout_text {
    flex: 1;
    line-height: 1.5;
}

.contentblocks_callout_holder--info {
    color: var(--css_color_contentblocks_callout_info_color, #4f8ef7);
    background: color-mix(in srgb, var(--css_color_contentblocks_callout_info_color, #4f8ef7) 12%, transparent);
}

.contentblocks_callout_holder--warning {
    color: var(--css_color_contentblocks_callout_warning_color, #f1a63f);
    background: color-mix(in srgb, var(--css_color_contentblocks_callout_warning_color, #f1a63f) 14%, transparent);
}

.contentblocks_callout_holder--success {
    color: var(--css_color_contentblocks_callout_success_color, #41a76d);
    background: color-mix(in srgb, var(--css_color_contentblocks_callout_success_color, #41a76d) 14%, transparent);
}

.contentblocks_callout_holder--error {
    color: var(--css_color_contentblocks_callout_error_color, #d66363);
    background: color-mix(in srgb, var(--css_color_contentblocks_callout_error_color, #d66363) 14%, transparent);
}

.contentblocks_callout_holder--neutral {
    color: var(--css_color_element_fg);
    background: var(--css_color_element_bg);
    box-shadow: inset 0 0 0 1px var(--css_color_border_fg);
}

.contentblocks_callout_holder--question {
    color: var(--css_color_buttonPrimary_bg);
    background: var(--css_color_element_bg);
    box-shadow: inset 0 0 0 1px var(--css_color_buttonPrimary_bg);
}

/* --- ContentBlock: ctasection --- */
/* ContentBlock: ctasection */

.contentblocks_ctasection_holder {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--distance_normal);
  padding: var(--distance_triple) var(--distance_normal);
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--css_color_contentblocks_ctasection_accent_bg, var(--css_color_intense_bg)) 8%, transparent),
    color-mix(in srgb, var(--css_color_contentblocks_ctasection_accent_bg, var(--css_color_intense_bg)) 4%, transparent)
  );
  border-radius: var(--border_radius_large);
  margin: var(--distance_double) 0;
}

.contentblocks_ctasection_headline {
  font-size: clamp(1.4rem, 3.5vw, 2.2rem);
  font-weight: 800;
  line-height: 1.2;
  color: var(--css_color_contentblocks_ctasection_headline_fg, var(--css_color_headline_fg));
  max-width: 580px;
  margin: 0;
}

.contentblocks_ctasection_subline {
  font-size: clamp(0.95rem, 2vw, 1.1rem);
  line-height: 1.55;
  color: var(--css_color_contentblocks_ctasection_text_fg, var(--css_color_element_fg));
  max-width: 520px;
  opacity: 0.85;
  margin: 0;
}

.contentblocks_ctasection_button--edit {
  cursor: text;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

@media only screen and (max-width: 600px) {
  .contentblocks_ctasection_holder {
    padding: var(--distance_double) var(--distance_half);
    border-radius: var(--border_radius_normal);
  }
}

/* --- ContentBlock: divider --- */
/* ContentBlock: divider */

.contentblocks_divider_holder {
    width: 100%;
    padding: 10px 0;
}

.contentblocks_divider_holder::before {
    content: "";
    display: block;
    width: 100%;
    height: 2px;
    border-radius: 999px;
    background: var(--css_color_border_fg);
}

.contentblocks_divider_holder--dashed::before {
    height: 0;
    border-top: 2px dashed var(--css_color_border_fg);
    background: none;
}

.contentblocks_divider_holder--dotted::before {
    height: 0;
    border-top: 2px dotted var(--css_color_border_fg);
    background: none;
}

.contentblocks_divider_holder--gradient::before {
    background: linear-gradient(to right, transparent, var(--css_color_border_fg), transparent);
}

.contentblocks_divider_holder--double::before {
    height: 8px;
    background: linear-gradient(
        to bottom,
        var(--css_color_border_fg) 0,
        var(--css_color_border_fg) 2px,
        transparent 2px,
        transparent 6px,
        var(--css_color_border_fg) 6px,
        var(--css_color_border_fg) 8px
    );
}

.contentblocks_divider_holder--accent::before {
    height: 4px;
    background: linear-gradient(to right, var(--css_color_intense_bg), var(--css_color_border_fg));
}

/* --- ContentBlock: featurecard --- */
/* ContentBlock: featurecard */

.contentblocks_featurecard_holder {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: var(--distance_1_5);
    border-radius: var(--border_radius_normal);
    background: var(--css_color_element_bg);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.contentblocks_featurecard_holder:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
}

.contentblocks_featurecard_iconHolder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: var(--css_color_intense_bg);
    margin-bottom: var(--distance_normal);
}

.contentblocks_featurecard_icon {
    font-size: 1.4rem;
    color: var(--css_color_intense_fg);
}

.contentblocks_featurecard_title {
    font-size: var(--fontsize_bigger);
    font-weight: 700;
    margin: 0 0 var(--distance_half) 0;
    color: var(--css_color_headline_fg);
}

.contentblocks_featurecard_description {
    font-size: var(--fontsize_normal);
    line-height: 1.5;
    margin: 0;
    color: var(--css_color_element_fg);
    opacity: 0.85;
}

/* --- ContentBlock: flex --- */
/* ContentBlock: flex */

.contentblocks_flex_insertSeparator {
    display: flex;
    align-items: center;
    width: 100%;
    min-height: 32px;
    cursor: pointer;
    opacity: 0.55;
    transition: opacity 0.2s, min-height 0.2s;
    box-sizing: border-box;
    gap: 8px;
    padding: 2px 0;
}
.contentblocks_flex_insertSeparator::before,
.contentblocks_flex_insertSeparator::after {
    content: '';
    flex: 1;
    height: 2px;
    background: var(--css_color_element_fg);
}
.contentblocks_flex_insertSeparatorLabel {
    display: flex;
    align-items: center;
    gap: 5px;
    white-space: nowrap;
    font-size: 14px;
    color: var(--css_color_element_fg);
    border: 1.5px dashed var(--css_color_element_fg);
    padding: var(--distance_half) var(--distance_normal);
    border-radius: var(--distance_half);
    line-height: 1.4;
}
.contentblocks_flex_insertSeparator:hover {
    opacity: 1;
    min-height: 32px;
}
.contentblocks_flex_insertSeparatorEnd {
    opacity: 0.7;
}

/* --- ContentBlock: headline --- */
/* ContentBlock: headline */
.contentblocks_headline_holder { padding: 8px 0; }
.contentblocks_headline_text { margin: 0; }
.contentblocks_headline_text--large { font-size: clamp(2rem, 4vw, 3rem); }
.contentblocks_headline_text--medium { font-size: clamp(1.5rem, 3vw, 2.2rem); }
.contentblocks_headline_text--small { font-size: clamp(1.15rem, 2.2vw, 1.5rem); }

/* --- ContentBlock: highlightitem --- */
/* ContentBlock: highlightitem */

.contentblocks_highlightitem_holder {
  display: flex;
  align-items: flex-start;
  gap: var(--distance_normal);
  flex: 1 1 260px;
}

.contentblocks_highlightitem_iconHolder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  min-width: 48px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--css_color_intense_bg) 12%, transparent);
}

.contentblocks_highlightitem_icon {
  font-size: 1.2rem;
  color: var(--css_color_intense_bg);
}

.contentblocks_highlightitem_content {
  display: flex;
  flex-direction: column;
  gap: var(--distance_quarter);
  flex: 1;
}

.contentblocks_highlightitem_title {
  font-size: var(--fontsize_normal);
  font-weight: 700;
  color: var(--css_color_headline_fg);
  margin: 0;
  line-height: 1.3;
}

.contentblocks_highlightitem_description {
  font-size: var(--fontsize_normal);
  line-height: 1.55;
  color: var(--css_color_element_fg);
  opacity: 0.85;
  margin: 0;
}

/* --- ContentBlock: image --- */
/* ContentBlock: image */

.contentblocks_image_holderOuter{
  position:relative;
  vertical-align: middle;
  text-align: center;
  padding: 4px;
  overflow:hidden;
  box-sizing: border-box;
  max-height: min(1920px, 100%);
  max-width: min(1920px, 100%);
}

.contentblocks_image_holderInner{
    display: block;
    object-fit: scale-down;
    margin:auto;
    max-width: calc(100% - 8px);
    height: calc(100% - 16px);
    max-height: calc(70vh - 64px);
}

/* --- ContentBlock: imageBanner --- */
/* ContentBlock: imageBanner */

.contentblocks_imageBanner_holderOuter{
  position:relative;
	vertical-align: middle;
	text-align: center;
	overflow:hidden;
  box-sizing: border-box;
  max-height: 100%;
  height: 100%;
  max-width: 100%;
  width: 100%;
}

.contentblocks_imageBanner_holderInner{
    display: block;
    object-fit: cover;
    margin: auto;
    width: 100%;
    max-width: 100%;
    max-height: 15vh;
    height: 100%;
}

.contentblocks_imageBanner_holderText {
  display: flex;
  position: absolute;
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 15vh;
  flex-direction: column;
  justify-content: center;
  align-content: center;
  font-size: var(--fontsize_double);
  pointer-events: none;
  line-height: var(--lineheight_double);
  }

/* --- ContentBlock: imageComparison --- */
/* ContentBlock: imageComparison */

.contentblocks_imageComparison_holder {
    position: relative;
    overflow: hidden;
    user-select: none;
    touch-action: pan-y;
    border-radius: var(--border_radius_normal);
    cursor: ew-resize;
    height: calc(70vh - 64px);
    max-width: min(1920px, 100%);
    box-sizing: border-box;
}

.contentblocks_imageComparison_pictureBefore {
    display: block;
    width: 100%;
    height: 100%;
}

.contentblocks_imageComparison_imageBefore {
    display: block;
    width: 100%;
    height: 100%;
    pointer-events: none;
    object-fit: var(--contentblocks-imageComparison-object-fit, contain);
    object-position: center center;
}

.contentblocks_imageComparison_afterWrapper {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    clip-path: inset(0 0 0 var(--contentblocks-imageComparison-split, 50%));
    transition: clip-path 0s;
}

.contentblocks_imageComparison_pictureAfter {
    display: block;
    width: 100%;
    height: 100%;
}

.contentblocks_imageComparison_imageAfter {
    display: block;
    width: 100%;
    height: 100%;
    pointer-events: none;
    object-fit: var(--contentblocks-imageComparison-object-fit, contain);
    object-position: center center;
}

.contentblocks_imageComparison_divider {
    position: absolute;
    top: 0;
    bottom: 0;
    left: var(--contentblocks-imageComparison-split, 50%);
    width: 2px;
    background-color: var(--css_color_contentblocks_imageComparison_divider_bg, var(--css_color_border_fg));
    transform: translateX(-50%);
    pointer-events: none;
    box-shadow: 0 0 4px rgba(0, 0, 0, 0.3);
}

.contentblocks_imageComparison_handle {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background-color: var(--css_color_contentblocks_imageComparison_divider_bg, var(--css_color_border_fg));
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.3);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--css_color_contentblocks_imageComparison_handle_fg, var(--css_color_element_bg));
    font-size: 0.85em;
}

.contentblocks_imageComparison_labelBefore,
.contentblocks_imageComparison_labelAfter {
    position: absolute;
    bottom: 10px;
    padding: 3px 8px;
    border-radius: 4px;
    background-color: var(--css_color_contentblocks_imageComparison_label_bg, color-mix(in srgb, var(--css_color_mainpage_bg) 55%, transparent));
    color: var(--css_color_contentblocks_imageComparison_label_fg, var(--css_color_mainpage_fg));
    font-size: 0.75em;
    font-weight: 600;
    letter-spacing: 0.02em;
    pointer-events: none;
    white-space: nowrap;
}

.contentblocks_imageComparison_labelBefore {
    left: 10px;
}

.contentblocks_imageComparison_labelAfter {
    right: 10px;
}

.contentblocks_imageComparison_slider {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    cursor: ew-resize;
    margin: 0;
    z-index: 10;
    -webkit-appearance: none;
    appearance: none;
}

/* --- ContentBlock: internalmedia --- */
/* ContentBlock: internalmedia */

/* --- ContentBlock: internalmediabanner --- */
/* ContentBlock: internalmediabanner */

/* --- ContentBlock: landinghero --- */
/* ContentBlock: landinghero */

.contentblocks_landinghero_holder {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: var(--distance_triple) var(--distance_normal) var(--distance_double);
  gap: var(--distance_normal);
}

.contentblocks_landinghero_tagline {
  display: inline-block;
  font-size: var(--fontsize_small);
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--css_color_intense_bg);
  background: color-mix(in srgb, var(--css_color_intense_bg) 12%, transparent);
  padding: var(--distance_quarter) var(--distance_normal);
  border-radius: 999px;
}

.contentblocks_landinghero_headline {
  font-size: clamp(2rem, 5vw, 3.2rem);
  font-weight: 800;
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--css_color_headline_fg);
  max-width: 720px;
  margin: 0;
}

.contentblocks_landinghero_subline {
  font-size: clamp(1rem, 2.5vw, 1.3rem);
  line-height: 1.5;
  color: var(--css_color_element_fg);
  max-width: 600px;
  opacity: 0.85;
  margin: 0;
}

.contentblocks_landinghero_actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--distance_normal);
  justify-content: center;
  margin-top: var(--distance_half);
}

.contentblocks_landinghero_ctaPrimary--edit {
  cursor: text;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.contentblocks_landinghero_ctaSecondary {
  display: inline-flex;
  align-items: center;
  gap: var(--distance_quarter);
  font-size: var(--fontsize_normal);
  font-weight: 600;
  color: var(--css_color_intense_bg);
  text-decoration: none;
  padding: var(--distance_half) var(--distance_normal);
  border: 2px solid var(--css_color_intense_bg);
  border-radius: var(--border_radius_normal);
  transition: background 0.2s ease, color 0.2s ease;
  cursor: pointer;
  background: transparent;
}

.contentblocks_landinghero_ctaSecondary:hover {
  background: var(--css_color_intense_bg);
  color: var(--css_color_intense_fg);
}

@media only screen and (max-width: 600px) {
  .contentblocks_landinghero_holder {
    padding: var(--distance_double) var(--distance_half) var(--distance_1_5);
  }
}

/* --- ContentBlock: liveevent --- */
/* ContentBlock: liveevent */

.contentblocks_liveevent_holder {
	margin-bottom: 0px;
	margin-top: 0px;
	margin-left: auto;
	margin-right: auto;
	padding: 0px;
	border-radius: 0px;
	height: auto;
	max-width: 100%;
	justify-content: center;
	align-items: center;
	vertical-align: middle;
	object-fit: scale-down;
	overflow: hidden;
}

/* --- ContentBlock: numberedstep --- */
/* ContentBlock: numberedstep */

.contentblocks_numberedstep_holder {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--distance_half);
  flex: 1 1 200px;
  padding: var(--distance_normal);
}

.contentblocks_numberedstep_number {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  min-width: 52px;
  border-radius: 50%;
  background: var(--css_color_intense_bg);
  color: var(--css_color_intense_fg);
  font-size: 1.4rem;
  font-weight: 800;
  line-height: 1;
}

.contentblocks_numberedstep_title {
  font-size: var(--fontsize_large);
  font-weight: 700;
  color: var(--css_color_headline_fg);
  margin: 0;
}

.contentblocks_numberedstep_description {
  font-size: var(--fontsize_normal);
  line-height: 1.55;
  color: var(--css_color_element_fg);
  opacity: 0.85;
  margin: 0;
  max-width: 280px;
}

/* --- ContentBlock: popup --- */
/* ContentBlock: popup */

.contentblocks_popup_holder {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: var(--distance_normal);
    width: 100%;
}

.contentblocks_popup_trigger {
    border: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: 10px 18px;
    font-weight: 600;
    cursor: pointer;
    transition: var(--layoutProperty_transitionspeed);
}

.contentblocks_popup_trigger:hover {
    filter: brightness(1.05);
}

.contentblocks_popup_trigger--primary {
    background: var(--css_color_buttonPrimary_bg);
    color: var(--css_color_buttonPrimary_fg);
}

.contentblocks_popup_trigger--outline {
    background: transparent;
    color: var(--css_color_buttonPrimary_bg);
    box-shadow: inset 0 0 0 2px var(--css_color_buttonPrimary_bg);
}

.contentblocks_popup_trigger--subtle {
    background: var(--css_color_element_bg);
    color: var(--css_color_element_fg);
    box-shadow: inset 0 0 0 1px var(--css_color_border_fg);
}

.contentblocks_popup_editorControls {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: var(--distance_half);
    box-sizing: border-box;
    padding: var(--distance_normal);
    background: var(--css_color_element_bg);
    color: var(--css_color_element_fg);
    border-radius: var(--border_radius_normal);
    box-shadow: inset 0 0 0 1px var(--css_color_border_fg);
}

.contentblocks_popup_editorFieldLabel {
    font-size: 0.85rem;
    font-weight: 600;
}

.contentblocks_popup_editorField {
    width: 100%;
    box-sizing: border-box;
    padding: var(--distance_half) var(--distance_normal);
    border-radius: var(--border_radius_normal);
    background: var(--css_color_element_bg);
    color: var(--css_color_element_fg);
}

.contentblocks_popup_editorTitle {
    font-size: 1.1rem;
    font-weight: 700;
}

.contentblocks_popup_editorDialogButton {
    border: none;
    border-radius: var(--border_radius_normal);
    padding: var(--distance_half) var(--distance_normal);
    background: var(--css_color_buttonPrimary_bg);
    color: var(--css_color_buttonPrimary_fg);
    font-weight: 600;
    cursor: pointer;
    align-self: flex-start;
}

.contentblocks_popup_editorDialogButton:hover {
    filter: brightness(1.05);
}

.contentblocks_popup_editorDialog {
    flex-direction: column;
    width: min(860px, calc(100vw - var(--distance_double) * 2));
    max-height: calc(100vh - var(--distance_double) * 2);
    padding: 0;
}

.contentblocks_popup_editorDialogSection {
    display: flex;
    flex-direction: column;
    gap: var(--distance_half);
    padding: var(--distance_normal);
    overflow-y: auto;
}

.contentblocks_popup_dialog {
    flex-direction: column;
    width: min(720px, calc(100vw - var(--distance_double) * 2));
    max-height: calc(100vh - var(--distance_double) * 2);
    padding: 0;
}

.contentblocks_popup_dialogSection {
    display: flex;
    flex: 1;
    overflow: hidden;
}

.contentblocks_popup_dialogBody {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--distance_normal);
    overflow-y: auto;
}

.contentblocks_popup_dialogTitle {
    font-size: 1.25rem;
    font-weight: 700;
}

.contentblocks_popup_dialogContentLayout {
    display: flex;
    flex-direction: column;
    gap: var(--distance_half);
    line-height: 1.5;
}

.contentblocks_popup_editorContent {
    min-height: 220px;
    max-height: 45vh;
    overflow-y: auto;
    border-radius: var(--border_radius_normal);
    padding: var(--distance_normal);
    background: var(--css_color_element_bg);
    color: var(--css_color_element_fg);
    box-shadow: inset 0 0 0 1px var(--css_color_border_fg);
}

.contentblocks_popup_emptyContent {
    opacity: 0.75;
    font-style: italic;
}

/* --- ContentBlock: ppt --- */
/* ContentBlock: ppt */

.contentblocks_ppt_holderOuter {
	position: relative;
	max-width: 100%;
	max-height: 100%;
	margin-left: auto;
	margin-right: auto;
	/*min-width: var(--minElementWidth2);*/
	width: 100%;
	height: 100%;
	}

.contentblocks_ppt_holderInner {
	position: relative;
	margin-bottom: 0px;
	margin-top: 0px;
	margin-left: auto;
	margin-right: auto;
	padding:10px;
	width: calc(100% - 20px);
	padding-bottom: 56.25%;
	min-height: 70px;
	}

.contentblocks_ppt_player {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
	/*max-width: min(880px, 100%);*/
    height: 100%;
}

/* --- ContentBlock: profiletext --- */
/* ContentBlock: profiletext */

.contentblocks_profiletext_holder {
    display: flex;
    align-items: center;
    flex-wrap: nowrap;
    padding: 8px;
}

.contentblocks_profiletext_image {
    position: relative;
    left: 0px;
    object-fit: cover;
    width: 100px;
    height: 100px;
    border-radius: 50%;
    flex: 0 0 100px;
    z-index: 2;
}

.contentblocks_profiletext_text {
    position: relative;
    border: 1px solid transparent;
    left: -16px;
    min-height: 60px;
    max-height: 90px;
    min-width: 50%;
    box-shadow: 0px 0px 5px 0px rgb(0 0 0 / 50%);
    padding: var(--distance_normal);
    border-radius: var(--border_radius_normal);
    padding-left: var(--distance_double);
    background: var(--css_color_element_bg);
    color: var(--css_color_element_fg);
    box-sizing: border-box;
    overflow-y: auto;
}

/* --- ContentBlock: quiz --- */
/* ContentBlock: quiz */

.contentblocks_quiz_holder {
    min-width: var(--minElementWidth);
}

/* --- ContentBlock: quote --- */
/* ContentBlock: quote */

.contentblocks_quote_holder {
    display: flex;
    align-items: flex-start;
    gap: var(--distance_normal);
    width: 100%;
    box-sizing: border-box;
    margin: 0;
    padding: var(--distance_normal);
    border-radius: var(--border_radius_normal);
    background: var(--css_color_contentblocks_quote_bg, var(--css_color_element_bg));
    color: var(--css_color_contentblocks_quote_fg, var(--css_color_element_fg));
}

.contentblocks_quote_icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 1.75rem;
    height: 1.75rem;
    border-radius: 999px;
    flex-shrink: 0;
}

.contentblocks_quote_text {
    margin: 0;
    line-height: 1.6;
    font-style: italic;
    white-space: pre-wrap;
}

.contentblocks_quote_holder--classic {
    border-left: 4px solid var(--css_color_contentblocks_quote_accent, var(--css_color_buttonPrimary_bg));
}

.contentblocks_quote_holder--classic .contentblocks_quote_icon {
    background: color-mix(in srgb, var(--css_color_contentblocks_quote_accent, var(--css_color_buttonPrimary_bg)) 14%, transparent);
    color: var(--css_color_contentblocks_quote_accent, var(--css_color_buttonPrimary_bg));
}

.contentblocks_quote_holder--accent {
    border-left: 4px solid var(--css_color_contentblocks_quote_success_fg, var(--css_color_success_fg));
    background: color-mix(in srgb, var(--css_color_contentblocks_quote_success_fg, var(--css_color_success_fg)) 10%, var(--css_color_contentblocks_quote_bg, var(--css_color_element_bg)));
}

.contentblocks_quote_holder--accent .contentblocks_quote_icon {
    background: color-mix(in srgb, var(--css_color_contentblocks_quote_success_fg, var(--css_color_success_fg)) 14%, transparent);
    color: var(--css_color_contentblocks_quote_success_fg, var(--css_color_success_fg));
}

.contentblocks_quote_holder--minimal {
    border: 1px solid var(--css_color_contentblocks_quote_border, var(--css_color_border_fg));
}

.contentblocks_quote_holder--minimal .contentblocks_quote_icon {
    background: transparent;
    color: var(--css_color_contentblocks_quote_fg, var(--css_color_element_fg));
}

.contentblocks_quote_holder--highlight {
    border-left: 4px solid var(--css_color_contentblocks_quote_error_fg, var(--css_color_error_fg));
    background: color-mix(in srgb, var(--css_color_contentblocks_quote_error_fg, var(--css_color_error_fg)) 11%, var(--css_color_contentblocks_quote_bg, var(--css_color_element_bg)));
}

.contentblocks_quote_holder--highlight .contentblocks_quote_icon {
    background: color-mix(in srgb, var(--css_color_contentblocks_quote_error_fg, var(--css_color_error_fg)) 18%, transparent);
    color: var(--css_color_contentblocks_quote_error_fg, var(--css_color_error_fg));
}

/* --- ContentBlock: sectionheader --- */
/* ContentBlock: sectionheader */

.contentblocks_sectionheader_holder {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--distance_half);
  padding-bottom: var(--distance_1_5);
}

.contentblocks_sectionheader_label {
  display: inline-block;
  font-size: var(--fontsize_small);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--css_color_intense_bg);
  background: color-mix(in srgb, var(--css_color_intense_bg) 10%, transparent);
  padding: var(--distance_quarter) var(--distance_normal);
  border-radius: 999px;
}

.contentblocks_sectionheader_headline {
  font-size: clamp(1.4rem, 3.5vw, 2rem);
  font-weight: 800;
  line-height: 1.2;
  letter-spacing: -0.01em;
  color: var(--css_color_headline_fg);
  max-width: 640px;
  margin: 0;
}

.contentblocks_sectionheader_subline {
  font-size: clamp(0.95rem, 2vw, 1.1rem);
  line-height: 1.5;
  color: var(--css_color_element_fg);
  max-width: 540px;
  opacity: 0.85;
  margin: 0;
}

/* --- ContentBlock: spacer --- */
/* ContentBlock: spacer */
.contentblocks_spacer_holder { display: block; }
.contentblocks_spacer_holderVertical { display: block; }
.contentblocks_spacer_holderHorizontal { display: block; }
.contentblocks_spacer_holderEdit {
    border: 1px dashed var(--css_color_border_fg);
    box-sizing: border-box;
}

/* --- ContentBlock: spoiler --- */
/* ContentBlock: spoiler */

.contentblocks_spoiler_holder {
    display: flex;
    flex-direction: column;
    gap: var(--distance_half);
    width: 100%;
}

.contentblocks_spoiler_toggle {
    width: 100%;
    border: none;
    display: flex;
    align-items: center;
    cursor: pointer;
    background: var(--css_color_element_bg);
    color: var(--css_color_element_fg);
    border-radius: var(--border_radius_normal);
    box-shadow: inset 0 0 0 1px var(--css_color_border_fg);
    padding-top: var(--distance_normal);
    padding-right: var(--distance_normal);
    padding-bottom: var(--distance_normal);
    box-sizing: border-box;
    text-align: left;
}

.contentblocks_spoiler_toggleText {
    display: block;
    width: 100%;
    font-weight: 600;
}

.contentblocks_spoiler_panel {
    background: var(--css_color_element_bg);
    color: var(--css_color_element_fg);
    border-radius: var(--border_radius_normal);
    box-shadow: inset 0 0 0 1px var(--css_color_border_fg);
}

.contentblocks_spoiler_content {
    padding: var(--distance_normal);
}

.contentblocks_spoiler_content.editableMarker {
    min-height: 80px;
}

/* --- ContentBlock: statbar --- */
/* ContentBlock: statbar */

.contentblocks_statbar_holder {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--distance_double);
  padding: var(--distance_1_5) var(--distance_normal);
  border-top: 1px solid color-mix(in srgb, var(--css_color_element_fg) 10%, transparent);
  border-bottom: 1px solid color-mix(in srgb, var(--css_color_element_fg) 10%, transparent);
}

.contentblocks_statbar_item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--distance_quarter);
  min-width: 120px;
}

.contentblocks_statbar_value {
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 800;
  color: var(--css_color_intense_bg);
  line-height: 1;
}

.contentblocks_statbar_label {
  font-size: var(--fontsize_small);
  font-weight: 600;
  color: var(--css_color_element_fg);
  opacity: 0.7;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

@media only screen and (max-width: 600px) {
  .contentblocks_statbar_holder {
    gap: var(--distance_normal);
  }
}

/* --- ContentBlock: tab-element --- */
/* ContentBlock: tab-element */

.contentblocks_tab-element_holder {
    display: flex;
    flex-direction: column;
    gap: var(--distance_half);
}

.contentblocks_tab-element_titleRow {
    display: flex;
    align-items: center;
    gap: var(--distance_half);
}

.contentblocks_tab-element_title {
    font-weight: 600;
}

.contentblocks_tab-element_content {
    display: flex;
    flex-direction: column;
    gap: var(--distance_normal);
}

/* --- ContentBlock: tabs-steps --- */
/* ContentBlock: tabs-steps */

/* --- ContentBlock: tabs --- */
/* ContentBlock: tabs */

.contentblocks_tabs_holder {
    display: flex;
    flex-direction: column;
}

.contentblocks_tabs_tabHeaderRow {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
}

.contentblocks_tabs_tabButton {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    gap: var(--distance_quarter);
    background: var(--css_color_contentblocks_tabs_head_bg, var(--css_color_frametabsHead_bg));
    color: var(--css_color_contentblocks_tabs_head_fg, var(--css_color_frametabsHead_fg));
    border: 1px solid transparent;
    border-bottom: 1px solid var(--css_color_contentblocks_tabs_border, var(--css_color_border_fg));
    border-radius: var(--border_radius_normal) var(--border_radius_normal) 0 0;
    padding: var(--distance_normal);
    cursor: pointer;
    font: inherit;
    font-size: 1rem;
    white-space: nowrap;
    transition: var(--layoutProperty_transitionspeed);
    user-select: none;
}

.contentblocks_tabs_tabButton[draggable="true"] {
    cursor: grab;
}

.contentblocks_tabs_tabButton--dragging {
    opacity: 0.4;
}

.contentblocks_tabs_tabButton--dragOver {
    border-left: 3px solid var(--css_color_contentblocks_tabs_head_active_fg, var(--css_color_frametabsHeadActive_fg));
    background: var(--css_color_contentblocks_tabs_head_bg_hover, var(--css_color_frametabsHead_bg_hover));
}

.contentblocks_tabs_tabButton:hover {
    color: var(--css_color_contentblocks_tabs_head_fg_hover, var(--css_color_frametabsHead_fg_hover));
    background: var(--css_color_contentblocks_tabs_head_bg_hover, var(--css_color_frametabsHead_bg_hover));
}

.contentblocks_tabs_tabLabel {
    color: inherit;
    display: inline-flex;
    align-items: center;
}

.contentblocks_tabs_tabButton--active {
    background: var(--css_color_contentblocks_tabs_head_active_bg, var(--css_color_frametabsHeadActive_bg));
    color: var(--css_color_contentblocks_tabs_head_active_fg, var(--css_color_frametabsHeadActive_fg));
    border-bottom: 1px solid transparent;
    border-left: 1px solid var(--css_color_contentblocks_tabs_border, var(--css_color_border_fg));
    border-right: 1px solid var(--css_color_contentblocks_tabs_border, var(--css_color_border_fg));
    border-top: 1px solid var(--css_color_contentblocks_tabs_head_active_fg, var(--css_color_frametabsHeadActive_fg));
}

.contentblocks_tabs_tabButton--active:hover {
    background: var(--css_color_contentblocks_tabs_head_active_bg_hover, var(--css_color_frametabsHeadActive_bg_hover));
    color: var(--css_color_contentblocks_tabs_head_active_fg_hover, var(--css_color_frametabsHeadActive_fg_hover));
}

.contentblocks_tabs_tabNumber {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 1.4rem;
    height: 1.4rem;
    border-radius: 999px;
    background: var(--css_color_contentblocks_tabs_head_fg, var(--css_color_frametabsHead_fg));
    color: var(--css_color_contentblocks_tabs_head_bg, var(--css_color_frametabsHead_bg));
    font-size: 0.75rem;
    line-height: 1;
}

.contentblocks_tabs_tabButton--active .contentblocks_tabs_tabNumber {
    background: var(--css_color_contentblocks_tabs_head_active_fg, var(--css_color_frametabsHeadActive_fg));
    color: var(--css_color_contentblocks_tabs_head_active_bg, var(--css_color_frametabsHeadActive_bg));
}


.contentblocks_tabs_tabEditButton {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.4rem;
    height: 1.4rem;
    border: 1px solid transparent;
    background: transparent;
    color: var(--css_color_contentblocks_tabs_head_fg, var(--css_color_frametabsHead_fg));
    border-radius: var(--border_radius_normal);
    cursor: pointer;
    font-size: 0.7rem;
    opacity: 0.7;
    transition: var(--layoutProperty_transitionspeed);
}

.contentblocks_tabs_tabEditButton:hover {
    opacity: 1;
    background: var(--css_color_contentblocks_tabs_head_bg_hover, var(--css_color_frametabsHead_bg_hover));
    color: var(--css_color_contentblocks_tabs_head_fg_hover, var(--css_color_frametabsHead_fg_hover));
    border-color: var(--css_color_contentblocks_tabs_border, var(--css_color_border_fg));
}

.contentblocks_tabs_renameRow {
    display: inline-flex;
    align-items: center;
    gap: var(--distance_quarter);
    border-bottom: 1px solid var(--css_color_contentblocks_tabs_border, var(--css_color_border_fg));
    padding-bottom: 4px;
    padding-right: 4px;
}

.contentblocks_tabs_renameInput {
    padding: 4px 8px;
    height: 2rem;
    font-size: 1rem;
    min-width: 8rem;
    border-radius: var(--border_radius_normal);
}

.contentblocks_tabs_addButton {
    gap: var(--distance_half);
    margin-left: var(--distance_quarter);
    border: 1px dashed var(--css_color_contentblocks_tabs_border, var(--css_color_border_fg));
    border-radius: var(--border_radius_normal) var(--border_radius_normal) 0 0;
    background: transparent;
    color: var(--css_color_contentblocks_tabs_head_fg, var(--css_color_frametabsHead_fg));
    cursor: pointer;
    font: inherit;
    font-size: 1rem;
    transition: var(--layoutProperty_transitionspeed);
}
.contentblocks_tabs_addButton:hover {
    background: var(--css_color_contentblocks_tabs_head_bg_hover, var(--css_color_frametabsHead_bg_hover));
    color: var(--css_color_contentblocks_tabs_head_fg_hover, var(--css_color_frametabsHead_fg_hover));
}

.contentblocks_tabs_contentArea {
    display: flex;
    flex-direction: column;
    gap: var(--distance_normal);
    border-left: 1px solid var(--css_color_contentblocks_tabs_border, var(--css_color_border_fg));
    border-right: 1px solid var(--css_color_contentblocks_tabs_border, var(--css_color_border_fg));
    border-bottom: 1px solid var(--css_color_contentblocks_tabs_border, var(--css_color_border_fg));
    border-radius: 0 0 var(--border_radius_normal) var(--border_radius_normal);
    padding: var(--distance_normal);
    background: var(--css_color_contentblocks_tabs_head_active_bg, var(--css_color_frametabsHeadActive_bg));
    color: var(--css_color_contentblocks_tabs_head_active_fg, var(--css_color_frametabsHeadActive_fg));
}

.contentblocks_tabs_tabPanel {
    display: none;
}

.contentblocks_tabs_tabPanel--active {
    display: flex;
    flex-direction: column;
    gap: var(--distance_normal);
}

.contentblocks_tabs_emptyState {
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px dashed var(--css_color_contentblocks_tabs_border, var(--css_color_border_fg));
    border-radius: var(--border_radius_normal);
    color: var(--css_color_contentblocks_tabs_head_fg, var(--css_color_frametabsHead_fg));
    padding: var(--distance_normal);
}

/* Steps-Variante */

.contentblocks_tabs_holder--default .contentblocks_tabs_tabNumber {
    display: none;
}

.contentblocks_tabs_holder--steps .contentblocks_tabs_tabButton {
    border: none;
    border-bottom: 1px solid transparent;
    border-radius: 999px;
    padding: var(--distance_quarter) var(--distance_half) var(--distance_quarter) var(--distance_quarter);
    background: transparent;
    opacity: 0.5;
}

.contentblocks_tabs_holder--steps .contentblocks_tabs_tabButton:hover {
    opacity: 0.75;
    background: var(--css_color_contentblocks_tabs_head_bg_hover, var(--css_color_frametabsHead_bg_hover));
}

.contentblocks_tabs_holder--steps .contentblocks_tabs_tabButton--active {
    background: var(--css_color_contentblocks_tabs_head_active_bg, var(--css_color_frametabsHeadActive_bg));
    border: 1px solid var(--css_color_contentblocks_tabs_head_active_fg, var(--css_color_frametabsHeadActive_fg));
    border-bottom: 1px solid transparent;
    border-radius: 999px 999px 0 0;
    opacity: 1;
}

/* --- ContentBlock: testimonial --- */
/* ContentBlock: testimonial */

.contentblocks_testimonial_holder {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: var(--distance_double);
    margin: 0;
    border-radius: var(--border_radius_bigger);
    background: var(--css_color_contentblocks_testimonial_bg, var(--css_color_element_bg));
}

.contentblocks_testimonial_quoteIcon {
    font-size: 1.8rem;
    color: var(--css_color_contentblocks_testimonial_icon_fg, var(--css_color_intense_bg));
    margin-bottom: var(--distance_normal);
    opacity: 0.6;
}

.contentblocks_testimonial_text {
    font-size: var(--fontsize_bigger);
    line-height: 1.6;
    font-style: italic;
    margin: 0 0 var(--distance_1_5) 0;
    max-width: 640px;
    color: var(--css_color_contentblocks_testimonial_text_fg, var(--css_color_element_fg));
}

.contentblocks_testimonial_author {
    display: flex;
    align-items: center;
    gap: var(--distance_half);
}

.contentblocks_testimonial_authorInitial {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--css_color_contentblocks_testimonial_avatar_bg, var(--css_color_intense_bg));
    color: var(--css_color_contentblocks_testimonial_avatar_fg, var(--css_color_intense_fg));
    font-weight: 700;
    font-size: var(--fontsize_bigger);
}

.contentblocks_testimonial_authorInfo {
    display: flex;
    flex-direction: column;
    text-align: left;
}

.contentblocks_testimonial_authorName {
    font-weight: 700;
    font-style: normal;
    font-size: var(--fontsize_normal);
    color: var(--css_color_contentblocks_testimonial_author_fg, var(--css_color_headline_fg));
}

.contentblocks_testimonial_authorRole {
    font-size: var(--fontsize_small);
    color: var(--css_color_contentblocks_testimonial_role_fg, var(--css_color_element_fg));
    opacity: 0.7;
}

/* --- ContentBlock: text --- */
/* ContentBlock: text */

.contentblocks_text_holder {
	padding-left: var(--distance_normal);
	padding-right: var(--distance_normal);
	line-height: var(--lineheight_normal);
	font-size: 1em;
	min-height: 48px;
	white-space: pre-wrap;
}

.contentblocks_text_holderAreaText {
	padding-top: var(--distance_half);
	padding-left: var(--distance_normal);
	padding-right: var(--distance_normal);
	padding-bottom: var(--distance_half);
	border-radius: var(--border_radius_normal);
	line-height: var(--lineheight_normal);
	font-size: 1em;
	min-height: 64px;
	height: fit-content;
	field-sizing: content;
	resize: none;
	color: var(--css_color_inputfields_fg);
	background-color: var(--css_color_inputfields_bg);
	transition: var(--layoutProperty_transitionspeed);
}

.contentblocks_text_holderAreaText:hover {
	color: var(--css_color_inputfields_fg_hover);
	background-color: var(--css_color_inputfields_bg_hover);
	transition: var(--layoutProperty_transitionspeed);
}

/* --- ContentBlock: video --- */
/* ContentBlock: video */

.contentblocks_video_holder {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: var(--distance_normal);
    position: relative;
    padding: 0px;
    border-radius: 0px;
    text-align: center;
    min-width: var(--minElementWidth);
    max-height: min(1920px, 100%);
    max-width: min(1920px, 100%);
    width: 100%;
    vertical-align: middle;
}

.contentblocks_video_player {
    flex: 1 1 50%;
    display: block;
    object-fit: contain;
    border-radius: var(--border_radius_normal);
    margin:auto;
    width: 100%;
    min-width: min(100%, 600px);
    max-width: 100%;
    max-height: 70vh;
}

.contentblocks_video_subtitles ul {
    padding: 0;
    margin: 0;
}

.contentblocks_video_subtitles {
    position: relative;
    flex: 1;
    flex-grow: 1;
    flex-shrink: 1;
    flex-basis: 40%;
    max-height: 30vh;
    height: max-content;
    min-width: min(100%, 500px);
    border-radius: var(--border_radius_normal);
    overflow-y: scroll;
    background-color: var(--css_color_element_bg);
    color: var(--css_color_element_fg);
}

.contentblocks_video_subtitles li {
    list-style: none;
    cursor: pointer;
    margin-bottom: var(--distance_normal);
    font-size: 1.2rem;
    line-height: 1.5rem;
}

.contentblocks_video_activeSubtitleLine {
    background-color: var(--css_color_activeSelection_bg);
}

.contentblocks_video_activeSubtitleLineSpanExtended {
    color: var(--css_color_element_fg);
    transition: var(--layoutProperty_transitionspeed);
}

.contentblocks_video_activeSubtitleLineSpan {
    color: var(--css_color_activeSelection_fg);
    transition: 0s;
}

/* --- ContentBlock: videoBanner --- */
/* ContentBlock: videoBanner */

.contentblocks_videoBanner_holder {
    display: flex;
    position: relative;
    margin-bottom: 0px;
    margin-top: 0px;
    margin-left: auto;
    margin-right: auto;
    padding: 0px;
    border-radius: 0px;
    text-align: center;
    min-width: 100%;
    width: 100%;
    max-width: 100%;
    max-height: 100%;
    justify-content: center;
    align-items: center;
    vertical-align: middle;
}

.contentblocks_videoBanner_player {
    display: block;
    object-fit: cover;
    border-radius: var(--border_radius_normal);
    margin:auto;
    width: 100%;
    height: 100%;
    max-width: 100%;
    /*max-height: min(15vh, 100px);*/
    max-height: 20vh;
    aspect-ratio: 5 / 1;
}

.contentblocks_videoBanner_holderText {
    display: flex;
    position: absolute;
    max-height: 15vh;
    flex-direction: column;
    justify-content: center;
    align-content: center;
    font-size: var(--fontsize_bigger2);
    pointer-events: none;
    line-height: var(--lineheight_double);
    padding: var(--distance_half);
    border-radius: var(--border_radius_normal);
    background: var(--css_color_overlay_bg);
    color: var(--css_color_overlay_fg);

    @media only screen and (min-width: 600px) {
        font-size: var(--fontsize_double);
        padding: var(--distance_normal);
    }
}

/* --- ContentBlock: videoHLS --- */
/* ContentBlock: videoHLS */

.contentblocks_videoHLS_holder {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: var(--distance_normal);
    position: relative;
    padding: 0px;
    border-radius: 0px;
    text-align: center;
    min-width: var(--minElementWidth);
    max-height: min(1920px, 100%);
    max-width: min(1920px, 100%);
    width: 100%;
    vertical-align: middle;
}

.contentblocks_videoHLS_player {
    flex: 1 1 50%;
    display: block;
    object-fit: contain;
    border-radius: var(--border_radius_normal);
    margin:auto;
    width: 100%;
    min-width: min(100%, 600px);
    max-width: 100%;
    max-height: 70vh;
}

.contentblocks_videoHLS_subtitles ul {
    padding: 0;
    margin: 0;
}

.contentblocks_videoHLS_subtitles {
    position: relative;
    flex: 1;
    flex-grow: 1;
    flex-shrink: 1;
    flex-basis: 40%;
    max-height: 30vh;
    height: max-content;
    min-width: min(100%, 500px);
    border-radius: var(--border_radius_normal);
    overflow-y: scroll;
    background-color: var(--css_color_element_bg);
    color: var(--css_color_element_fg);
}

.contentblocks_videoHLS_subtitles li {
    list-style: none;
    cursor: pointer;
    margin-bottom: var(--distance_normal);
    font-size: 1.2rem;
    line-height: 1.5rem;
}

.contentblocks_videoHLS_activeSubtitleLine {
    background-color: var(--css_color_activeSelection_bg);
}

.contentblocks_videoHLS_activeSubtitleLineSpanExtended {
    color: var(--css_color_element_fg);
    transition: var(--layoutProperty_transitionspeed);
}

.contentblocks_videoHLS_activeSubtitleLineSpan {
    color: var(--css_color_activeSelection_fg);
    transition: 0s;
}

/* --- ContentBlock: vimeo --- */
/* ContentBlock: vimeo */

.contentblocks_vimeo_holderOuter {
	position: relative;
	max-width: 1000px;
	margin-left: auto;
	margin-right: auto;
	min-width: var(--minElementWidth);
}

.contentblocks_vimeo_holderInner {
	position: relative;
	margin-bottom: 0px;
	margin-top: 0px;
	margin-left: auto;
	margin-right: auto;
	padding: 10px;
	width: calc(100% - 20px);
	max-height: 0;
	padding-bottom: 56.25%;
	min-height: 70px;
}

.contentblocks_vimeo_player {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

/* --- ContentBlock: vslist --- */
/* ContentBlock: vslist */

.contentblocks_vslist_holder {
    display: flex;
    flex-direction: column;
    gap: var(--distance_normal);
    width: 100%;
}

.contentblocks_vslist_lists {
    display: flex;
    flex-wrap: wrap;
    gap: var(--distance_normal);
    width: 100%;
}

.contentblocks_vslist_list {
    display: flex;
    flex-direction: column;
    gap: var(--distance_half);
    flex: 1 1 220px;
    min-width: 220px;
    border-radius: var(--border_radius_normal);
    border: 1px solid color-mix(in srgb, var(--contentblocks-vslist-list-color, var(--css_color_contentblocks_vslist_border, var(--css_color_border_fg))) 55%, transparent);
    padding: var(--distance_normal);
    box-sizing: border-box;
    background: color-mix(in srgb, var(--contentblocks-vslist-list-color, var(--css_color_contentblocks_vslist_fg, var(--css_color_element_fg))) 8%, var(--css_color_contentblocks_vslist_bg, var(--css_color_element_bg)));
}

.contentblocks_vslist_listTitle {
    margin: 0;
    font-size: 1rem;
    line-height: 1.4;
    color: var(--contentblocks-vslist-list-color, var(--css_color_contentblocks_vslist_fg, var(--css_color_element_fg)));
}

.contentblocks_vslist_items {
    display: flex;
    flex-direction: column;
    gap: var(--distance_half);
    margin: 0;
    padding-left: 1.2rem;
}

.contentblocks_vslist_item {
    line-height: 1.45;
}

.contentblocks_vslist_items--disc {
    list-style-type: disc;
}

.contentblocks_vslist_items--circle {
    list-style-type: circle;
}

.contentblocks_vslist_items--square {
    list-style-type: square;
}

.contentblocks_vslist_items--dash,
.contentblocks_vslist_items--check,
.contentblocks_vslist_items--arrow {
    list-style: none;
    padding-left: 0;
}

.contentblocks_vslist_items--dash .contentblocks_vslist_item::before,
.contentblocks_vslist_items--check .contentblocks_vslist_item::before,
.contentblocks_vslist_items--arrow .contentblocks_vslist_item::before {
    color: var(--contentblocks-vslist-list-color, var(--css_color_contentblocks_vslist_fg, var(--css_color_element_fg)));
    margin-right: 0.4rem;
}

.contentblocks_vslist_items--dash .contentblocks_vslist_item::before {
    content: "–";
}

.contentblocks_vslist_items--check .contentblocks_vslist_item::before {
    content: "✓";
}

.contentblocks_vslist_items--arrow .contentblocks_vslist_item::before {
    content: "➜";
}

.contentblocks_vslist_dataField {
    display: none;
}

.contentblocks_vslist_editorDialog {
    max-width: min(920px, 100vw - 32px);
}

.contentblocks_vslist_editorSection {
    display: flex;
    flex-direction: column;
    gap: var(--distance_normal);
    max-height: calc(100vh - 12rem);
    overflow: auto;
    padding: var(--distance_normal);
    box-sizing: border-box;
}

.contentblocks_vslist_editorLists {
    display: flex;
    flex-direction: column;
    gap: var(--distance_normal);
}

.contentblocks_vslist_editorList {
    display: flex;
    flex-direction: column;
    gap: var(--distance_half);
    border: 1px solid var(--css_color_contentblocks_vslist_border, var(--css_color_border_fg));
    border-radius: var(--border_radius_normal);
    padding: var(--distance_normal);
}

.contentblocks_vslist_editorRow {
    display: flex;
    flex-wrap: wrap;
    gap: var(--distance_half);
    align-items: center;
}

.contentblocks_vslist_editorInput,
.contentblocks_vslist_editorSelect {
    border: 1px solid var(--css_color_contentblocks_vslist_border, var(--css_color_border_fg));
    border-radius: var(--border_radius_normal);
    background: var(--css_color_contentblocks_vslist_bg, var(--css_color_element_bg));
    color: var(--css_color_contentblocks_vslist_fg, var(--css_color_element_fg));
    padding: 0.4rem 0.5rem;
    font: inherit;
    box-sizing: border-box;
}

.contentblocks_vslist_editorInput--title {
    flex: 1 1 220px;
}

.contentblocks_vslist_editorInput--color {
    width: 3.2rem;
    height: 2.2rem;
    padding: 0.15rem;
}

.contentblocks_vslist_editorItems {
    display: flex;
    flex-direction: column;
    gap: var(--distance_half);
}

.contentblocks_vslist_editorItem {
    display: flex;
    gap: var(--distance_half);
    align-items: center;
}

.contentblocks_vslist_editorInput--item {
    flex: 1 1 auto;
}

.contentblocks_vslist_editorButton {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    border: 1px solid var(--css_color_contentblocks_vslist_border, var(--css_color_border_fg));
    border-radius: var(--border_radius_normal);
    background: var(--css_color_contentblocks_vslist_bg, var(--css_color_element_bg));
    color: var(--css_color_contentblocks_vslist_fg, var(--css_color_element_fg));
    padding: 0.35rem 0.55rem;
    cursor: pointer;
}

.contentblocks_vslist_editorButton--danger {
    color: var(--css_color_contentblocks_vslist_error_fg, var(--css_color_error_fg));
}

.contentblocks_vslist_editorActions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--distance_half);
}

.contentblocks_vslist_editorActionButton {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    border: 1px solid var(--css_color_contentblocks_vslist_border, var(--css_color_border_fg));
    border-radius: var(--border_radius_normal);
    background: var(--css_color_contentblocks_vslist_bg, var(--css_color_element_bg));
    color: var(--css_color_contentblocks_vslist_fg, var(--css_color_element_fg));
    padding: 0.45rem 0.7rem;
    cursor: pointer;
}

.contentblocks_vslist_editorActionButton--primary {
    background: var(--css_color_contentblocks_vslist_primary_bg, var(--css_color_buttonPrimary_bg));
    border-color: var(--css_color_contentblocks_vslist_primary_bg, var(--css_color_buttonPrimary_bg));
    color: var(--css_color_contentblocks_vslist_primary_fg, var(--css_color_buttonPrimary_fg));
}

/* --- ContentBlock: youtube --- */
/* ContentBlock: youtube */

.contentblocks_youtube_holderOuter {
	position: relative;
	max-width: 1000px;
	margin-left: auto;
	margin-right: auto;
	min-width: var(--minElementWidth);
	border-radius: var(--border_radius_normal);
}

.contentblocks_youtube_holderInner {
	position: relative;
	margin-bottom: 0px;
	margin-top: 0px;
	margin-left: auto;
	margin-right: auto;
	padding: 10px;
	width: calc(100% - 20px);
	max-height: 0;
	padding-bottom: 56.25%;
	min-height: 70px;
	border-radius: var(--border_radius_normal);
}

.contentblocks_youtube_player {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

