.autogrid_grid{display:grid;margin-left:-15px;margin-right:-15px}.autogrid_grid .column{padding-left:15px;padding-right:15px}.autogrid_grid.gutter_none{margin-left:0;margin-right:0}.autogrid_grid.gutter_none>.column{padding-left:0;padding-right:0}.autogrid_grid.gutter_s{margin-left:-15px;margin-right:-15px}.autogrid_grid.gutter_s>.column{padding-left:15px;padding-right:15px}.autogrid_grid.gutter_m{margin-left:-30px;margin-right:-30px}.autogrid_grid.gutter_m>.column{padding-left:30px;padding-right:30px}.autogrid_grid.gutter_l{margin-left:-40px;margin-right:-40px}.autogrid_grid.gutter_l>.column{padding-left:40px;padding-right:40px}.autogrid_grid.same_height>.column>.attributes{height:100%}.autogrid_grid .column .attributes{background-size:cover;position:relative}.autogrid_grid .column .attributes.p-xl{padding:200px 40px 200px 40px}.autogrid_grid .column .attributes.p-l{padding:160px 40px 160px 40px}.autogrid_grid .column .attributes.p-m{padding:115px 40px 115px 40px}.autogrid_grid .column .attributes.p-s{padding:80px 40px 80px 40px}.autogrid_grid .column .attributes.p-xs{padding:40px 40px 40px 40px}.autogrid_grid .column.align_left_top{text-align:left}.autogrid_grid .column.align_left_center{text-align:left;align-self:center}.autogrid_grid .column.align_left_bottom{text-align:left;align-self:flex-end}.autogrid_grid .column.align_center_top{text-align:center}.autogrid_grid .column.align_center_center{text-align:center;align-self:center}.autogrid_grid .column.align_center_bottom{text-align:center;align-self:flex-end}.autogrid_grid .column.align_right_top{text-align:right}.autogrid_grid .column.align_right_center{text-align:right;align-self:center}.autogrid_grid .column.align_right_bottom{text-align:right;align-self:flex-end}.autogrid_grid.same_height>.column{align-self:unset}.autogrid_grid.same_height>.column>.attributes{display:flex;flex-wrap:wrap;height:100%}.autogrid_grid.same_height>.column>.attributes>.same-height-wrap{width:100%;flex:0 0 100%}.autogrid_grid.same_height>.column.align_left_center>.attributes{align-items:center}.autogrid_grid.same_height>.column.align_left_bottom>.attributes{align-items:flex-end}.autogrid_grid.same_height>.column.align_center_center>.attributes{align-items:center}.autogrid_grid.same_height>.column.align_center_bottom>.attributes{align-items:flex-end}.autogrid_grid.same_height>.column.align_right_center>.attributes{align-items:center}.autogrid_grid.same_height>.column.align_right_bottom>.attributes{align-items:flex-end}.autogrid_grid .column>.attributes .image_mob{display:none}.autogrid_wrapper,.autogrid_row{margin-left:-15px;margin-right:-15px;display:flex;flex-wrap:wrap;box-sizing:border-box}.autogrid,.autogrid_row>.column{padding-left:15px;padding-right:15px;flex-basis:1;flex-grow:1;width:100%;position:relative;box-sizing:border-box}.autogrid_clear{flex:0 0 100%;height:0}.col_1{flex:0 0 calc((100% / 12) * 1);max-width:calc((100% / 12) * 1)}.col_2{flex:0 0 calc((100% / 12) * 2);max-width:calc((100% / 12) * 2)}.col_3{flex:0 0 calc((100% / 12) * 3);max-width:calc((100% / 12) * 3)}.col_4{flex:0 0 calc((100% / 12) * 4);max-width:calc((100% / 12) * 4)}.col_5{flex:0 0 calc((100% / 12) * 5);max-width:calc((100% / 12) * 5)}.col_6{flex:0 0 calc((100% / 12) * 6);max-width:calc((100% / 12) * 6)}.col_7{flex:0 0 calc((100% / 12) * 7);max-width:calc((100% / 12) * 7)}.col_8{flex:0 0 calc((100% / 12) * 8);max-width:calc((100% / 12) * 8)}.col_9{flex:0 0 calc((100% / 12) * 9);max-width:calc((100% / 12) * 9)}.col_10{flex:0 0 calc((100% / 12) * 10);max-width:calc((100% / 12) * 10)}.col_11{flex:0 0 calc((100% / 12) * 11);max-width:calc((100% / 12) * 11)}.col_12{flex:0 0 calc((100% / 12) * 12);max-width:calc((100% / 12) * 12)}.autogrid_row>.column>.attributes{background-size:cover}.autogrid_row>.column>.attributes.p-xl{padding:200px 40px 200px 40px}.autogrid_row>.column>.attributes.p-l{padding:160px 40px 160px 40px}.autogrid_row>.column>.attributes.p-m{padding:115px 40px 115px 40px}.autogrid_row>.column>.attributes.p-s{padding:80px 40px 80px 40px}.autogrid_row>.column>.attributes.p-xs{padding:40px 40px 40px 40px}.autogrid_wrapper.gutter_none,.autogrid_row.gutter_none{margin-left:0;margin-right:0}.autogrid_wrapper.gutter_none>div,.autogrid_row.gutter_none>div{padding-left:0;padding-right:0}.autogrid_wrapper.gutter_s,.autogrid_row.gutter_s{margin-left:-15px;margin-right:-15px}.autogrid_wrapper.gutter_s>div,.autogrid_row.gutter_s>div{padding-left:15px;padding-right:15px}.autogrid_wrapper.gutter_m,.autogrid_row.gutter_m{margin-left:-30px;margin-right:-30px}.autogrid_wrapper.gutter_m>div,.autogrid_row.gutter_m>div{padding-left:30px;padding-right:30px}.autogrid_wrapper.gutter_l,.autogrid_row.gutter_l{margin-left:-40px;margin-right:-40px}.autogrid_wrapper.gutter_l>div,.autogrid_row.gutter_l>div{padding-left:40px;padding-right:40px}.autogrid_row>.column>.attributes{position:relative}.autogrid_row>.column.align_left_top{text-align:left}.autogrid_row>.column.align_left_center{text-align:left;align-self:center}.autogrid_row>.column.align_left_bottom{text-align:left;align-self:flex-end}.autogrid_row>.column.align_center_top{text-align:center}.autogrid_row>.column.align_center_center{text-align:center;align-self:center}.autogrid_row>.column.align_center_bottom{text-align:center;align-self:flex-end}.autogrid_row>.column.align_right_top{text-align:right}.autogrid_row>.column.align_right_center{text-align:right;align-self:center}.autogrid_row>.column.align_right_bottom{text-align:right;align-self:flex-end}.autogrid_row.same_height>.column{align-self:unset}.autogrid_row.same_height>.column>.attributes{display:flex;flex-wrap:wrap;height:100%}.autogrid_row.same_height>.column>.attributes>.same-height-wrap{width:100%;flex:0 0 100%}.autogrid_row.same_height>.column.align_left_center>.attributes{align-items:center}.autogrid_row.same_height>.column.align_left_bottom>.attributes{align-items:flex-end}.autogrid_row.same_height>.column.align_center_center>.attributes{align-items:center}.autogrid_row.same_height>.column.align_center_bottom>.attributes{align-items:flex-end}.autogrid_row.same_height>.column.align_right_center>.attributes{align-items:center}.autogrid_row.same_height>.column.align_right_bottom>.attributes{align-items:flex-end}.autogrid_row .column>.attributes .image_mob{display:none}.autogrid_row>.column.sticky .attributes{position:sticky;top:0}.order_1{order:1}.order_2{order:2}.order_3{order:3}.order_4{order:4}.order_5{order:5}.order_6{order:6}.full{flex:0 0 100%}.one_half{flex:0 0 calc(100% / 2)}.one_third{flex:0 0 calc(100% / 3)}.one_fourth{flex:0 0 calc(100% / 4)}.one_fifth{flex:0 0 calc(100% / 5)}.one_sixth{flex:0 0 calc(100% / 6)}.two_third{flex:0 0 calc((100% / 3) * 2)}.two_fourth{flex:0 0 calc((100% / 4) * 2)}.three_fourth{flex:0 0 calc((100% / 4) * 3)}.two_fifth{flex:0 0 calc((100% / 5) * 2)}.three_fifth{flex:0 0 calc((100% / 5) * 3)}.four_fifth{flex:0 0 calc((100% / 5) * 4)}.two_sixth{flex:0 0 calc((100% / 6) * 2)}.three_sixth{flex:0 0 calc((100% / 6) * 3)}.four_sixth{flex:0 0 calc((100% / 6) * 4)}.five_sixth{flex:0 0 calc((100% / 6) * 5)}.offset_col_1{margin-left:calc((100% / 12) * 1)}.offset_col_2{margin-left:calc((100% / 12) * 2)}.offset_col_3{margin-left:calc((100% / 12) * 3)}.offset_col_4{margin-left:calc((100% / 12) * 4)}.offset_col_5{margin-left:calc((100% / 12) * 5)}.offset_col_6{margin-left:calc((100% / 12) * 6)}.offset_col_7{margin-left:calc((100% / 12) * 7)}.offset_col_8{margin-left:calc((100% / 12) * 8)}.offset_col_9{margin-left:calc((100% / 12) * 9)}.offset_col_10{margin-left:calc((100% / 12) * 10)}.offset_col_11{margin-left:calc((100% / 12) * 11)}.autogrid.no_gutter{padding-left:0;padding-right:0}@media only screen and (min-width :768px) and (max-width :1024px){.col_1_t{flex:0 0 calc((100% / 12) * 1);max-width:calc((100% / 12) * 1)}.col_2_t{flex:0 0 calc((100% / 12) * 2);max-width:calc((100% / 12) * 2)}.col_3_t{flex:0 0 calc((100% / 12) * 3);max-width:calc((100% / 12) * 3)}.col_4_t{flex:0 0 calc((100% / 12) * 4);max-width:calc((100% / 12) * 4)}.col_5_t{flex:0 0 calc((100% / 12) * 5);max-width:calc((100% / 12) * 5)}.col_6_t{flex:0 0 calc((100% / 12) * 6);max-width:calc((100% / 12) * 6)}.col_7_t{flex:0 0 calc((100% / 12) * 7);max-width:calc((100% / 12) * 7)}.col_8_t{flex:0 0 calc((100% / 12) * 8);max-width:calc((100% / 12) * 8)}.col_9_t{flex:0 0 calc((100% / 12) * 9);max-width:calc((100% / 12) * 9)}.col_10_t{flex:0 0 calc((100% / 12) * 10);max-width:calc((100% / 12) * 10)}.col_11_t{flex:0 0 calc((100% / 12) * 11);max-width:calc((100% / 12) * 11)}.col_12_t{flex:0 0 calc((100% / 12) * 12);max-width:calc((100% / 12) * 12)}.order_1_t{order:1}.order_2_t{order:2}.order_3_t{order:3}.order_4_t{order:4}.order_5_t{order:5}.order_6_t{order:6}}.autogrid_row>.column.sticky_column>.attributes{position:sticky;top:0;z-index:10;height:auto !important}@media only screen and (max-width:767px){[class*="col_"],.one_half,.one_third,.one_fourth,.one_fifth,.one_sixth,.two_third,.two_fourth,.three_fourth,.two_fifth,.three_fifth,.four_fifth,.two_sixth,.three_sixth .four_sixth,.five_sixth{flex:0 0 100%;max-width:none}.column[class*="col_"]:not([class*="_m"]),.autogrid_grid .column:not([class*="_m"]){padding-left:0 !important;padding-right:0 !important;margin-bottom:25px}.column[class*="offset_"],.autogrid[class*="offset_"],.autogrid_grid[class*="offset_"]{margin-left:0}.autogrid_wrapper,.autogrid_row,.autogrid_grid{margin-left:0 !important;margin-right:0 !important}.column:empty,.column .attributes:empty,.column:has(>.attributes:empty){display:none}.autogrid_grid>.column>.attributes.has-image.empty>.image_mob,.autogrid_grid>.column>.attributes.has-image.empty>.same-height-wrap>.image_mob,.autogrid_row>.column>.attributes.has-image.empty>.image_mob,.autogrid_row>.column>.attributes.has-image.empty>.same-height-wrap>.image_mob{display:block}.autogrid_grid>.column>.attributes.has-image.empty,.autogrid_row>.column>.attributes.has-image.empty{background:none !important}.col_1_m{flex:0 0 calc((100% / 12) * 1);max-width:calc((100% / 12) * 1)}.col_2_m{flex:0 0 calc((100% / 12) * 2);max-width:calc((100% / 12) * 2)}.col_3_m{flex:0 0 calc((100% / 12) * 3);max-width:calc((100% / 12) * 3)}.col_4_m{flex:0 0 calc((100% / 12) * 4);max-width:calc((100% / 12) * 4)}.col_5_m{flex:0 0 calc((100% / 12) * 5);max-width:calc((100% / 12) * 5)}.col_6_m{flex:0 0 calc((100% / 12) * 6);max-width:calc((100% / 12) * 6)}.col_7_m{flex:0 0 calc((100% / 12) * 7);max-width:calc((100% / 12) * 7)}.col_8_m{flex:0 0 calc((100% / 12) * 8);max-width:calc((100% / 12) * 8)}.col_9_m{flex:0 0 calc((100% / 12) * 9);max-width:calc((100% / 12) * 9)}.col_10_m{flex:0 0 calc((100% / 12) * 10);max-width:calc((100% / 12) * 10)}.col_11_m{flex:0 0 calc((100% / 12) * 11);max-width:calc((100% / 12) * 11)}.col_12_m{flex:0 0 calc((100% / 12) * 12);max-width:calc((100% / 12) * 12)}.order_1_m{order:1}.order_2_m{order:2}.order_3_m{order:3}.order_4_m{order:4}.order_5_m{order:5}.order_6_m{order:6}.autogrid_grid>.column>.attributes.p-xl,.autogrid_grid>.column>.attributes.p-l,.autogrid_grid>.column>.attributes.p-m,.autogrid_grid>.column>.attributes.p-s,.autogrid_grid>.column>.attributes.p-xs,.autogrid_row>.column .attributes.p-xl,.autogrid_row>.column .attributes.p-l,.autogrid_row>.column .attributes.p-m,.autogrid_row>.column .attributes.p-s,.autogrid_row>.column .attributes.p-xs{padding:20px}.autogrid_grid .column.m_align_left_top{text-align:left}.autogrid_grid .column.m_align_left_center{text-align:left;align-self:center}.autogrid_grid .column.m_align_left_bottom{text-align:left;align-self:flex-end}.autogrid_grid .column.m_align_center_top{text-align:center}.autogrid_grid .column.m_align_center_center{text-align:center;align-self:center}.autogrid_grid .column.m_align_center_bottom{text-align:center;align-self:flex-end}.autogrid_grid .column.m_align_right_top{text-align:right}.autogrid_grid .column.m_align_right_center{text-align:right;align-self:center}.autogrid_grid .column.m_align_right_bottom{text-align:right;align-self:flex-end}.autogrid_row>.column.m_align_left_top{text-align:left}.autogrid_row>.column.m_align_left_center{text-align:left;align-self:center}.autogrid_row>.column.m_align_left_bottom{text-align:left;align-self:flex-end}.autogrid_row>.column.m_align_center_top{text-align:center}.autogrid_row>.column.m_align_center_center{text-align:center;align-self:center}.autogrid_row>.column.m_align_center_bottom{text-align:center;align-self:flex-end}.autogrid_row>.column.m_align_right_top{text-align:right}.autogrid_row>.column.m_align_right_center{text-align:right;align-self:center}.autogrid_row>.column.m_align_right_bottom{text-align:right;align-self:flex-end}}body.edge column[class*="col_"]{flex-basis:1}@media only screen and (max-width:767px){body.edge column[class*="col_"]{flex-basis:100%}}
/* =============================================================================
 * ce_icon_text
 * ========================================================================== */

.ce_icon_text {
	display: flex;
	align-items: center;
}

.ce_icon_text .text,
.ce_icon_text .text p {
	margin: 0;
}

.ce_icon_text .text a {
	text-decoration: underline;
}

.ce_icon_text a {
  color: inherit;
}

.ce_icon_text > a {
	display: flex;
	align-items: center;
}

.ce_icon_text i {
	width: 15px;
}

.ce_icon_text .icon {
	line-height: 1;
}

.ce_icon_text[data-align="center"] {
	justify-content: center;
}

.ce_icon_text[data-align="right"] {
	justify-content: right;
}

.ce_icon_text[data-color="accent-color"] .text,
.ce_icon_text[data-color="accent-color"] .text a,
.ce_icon_text[data-color="accent-color"]  i {
	color: var(--accentColor);
}

.ce_icon_text[data-color="second-color"] .text,
.ce_icon_text[data-color="second-color"] .text a,
.ce_icon_text[data-color="second-color"]  i {
	color: var(--socondColor);
}

.ce_icon_text[data-color="white"] .text,
.ce_icon_text[data-color="white"] .text a,
.ce_icon_text[data-color="white"]  i {
	color: #ffffff;
}

.ce_icon_text[data-color="black"] .text,
.ce_icon_text[data-color="black"] .text a,
.ce_icon_text[data-color="black"]  i {
	color: #000000;
}

.ce_icon_text[data-color="light-gray"] .text,
.ce_icon_text[data-color="light-gray"] .text a,
.ce_icon_text[data-color="light-gray"]  i {
	color: #b4b4b4;
}

.ce_icon_text[data-color="dark-gray"] .text,
.ce_icon_text[data-color="dark-gray"] .text a,
.ce_icon_text[data-color="dark-gray"]  i {
	color: #7f7f7f;
}

.ce_icon_text[data-color="custom1"] .text,
.ce_icon_text[data-color="custom1"] .text a,
.ce_icon_text[data-color="custom1"]  i {
	color: var(--customColor1);
}

.ce_icon_text[data-color="custom2"] .text,
.ce_icon_text[data-color="custom2"] .text a,
.ce_icon_text[data-color="custom2"]  i {
	color: var(--customColor2);
}

.ce_icon_text[data-icon-pos="before"] .icon {
	margin-right: 1em;
}

.ce_icon_text[data-icon-pos="after"] .icon {
	order: 2;
	margin-left: 1em;
}

.ce_icon_text[data-icon-pos="after"] .text {
	order: 1;
}
/* =============================================================================
 * mod_breadcrumb.html5
 * ========================================================================== */

.mod_breadcrumb {
	border-top: 1px solid rgba(0,0,0,0.1);
	border-bottom: 1px solid rgba(0,0,0,0.1);
}

.mod_breadcrumb .mod_breadcrumb_inside {
	position: relative;
}

.mod_breadcrumb .mod_breadcrumb_inside:before {
	content: '';
	border-top: 1px solid rgba(0,0,0,0.1);
	position: absolute;
	top: 0;
	left: 40px;
	right: 40px;
	height: 1px;
}

.mod_breadcrumb .mod_breadcrumb_inside:after {
	content: '';
	border-top: 1px solid rgba(0,0,0,0.1);
	position: absolute;
	bottom: 0;
	left: 40px;
	right: 40px;
	height: 1px;
}

.mod_breadcrumb .mod_breadcrumb_inside:before,
.mod_breadcrumb .mod_breadcrumb_inside:after {
	display: none;
}

.mod_breadcrumb ul {
	font-size: 0.9rem;
	line-height: 0.9rem;
	text-align: center;
	display: inline-block;
	float: none;
	padding: 11px 0;
}

.mod_breadcrumb li {
	display: inline-block;
	margin-right: 5px;
}

.mod_breadcrumb li:before {
	font-family: "FontAwesome";
	content: "\f101";
	margin-right: 5px;
}

.mod_breadcrumb li.first:before {
	display: none;
}

.mod_breadcrumb .pagetitle {
	display: none;
}

/* =============================================================================
* smart phones  (s / small screens)
* ========================================================================== */
@media only screen and (max-width: 767px) {
	.mod_breadcrumb {
		display: none;
	}
}


/* =============================================================
   madmoses – Werbeagentur Landshut
   style.css
   -------------------------------------------------------------
   Aufbau:
   1.  Reset & Basics
   2.  Design Tokens (Custom Properties)
   3.  Typografie
   4.  Layout-Primitives
   5.  Header / Navigation
   6.  Hero
   7.  Manifest
   8.  Spektrum (Leistungen)
   9.  Projekte / Cases
   10. Trust / Zahlen
   11. Kreativbude (Blog)
   12. Kontakt
   13. Footer
   14. Mask-Components & Sprechblasen
   15. Sektions-Übergänge / Erzähler
   16. Detail-Seiten (Spektrum, Projekte)
   17. Animationen
   18. Reduced Motion
   ============================================================= */


/* -------------------------------------------------------------
   1. Reset & Basics
   ------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body, h1, h2, h3, h4, h5, h6, p, figure, blockquote, dl, dd { margin: 0; }
ul, ol { margin: 0; padding: 0; list-style: none; }
img, picture, video, canvas, svg { display: block; max-width: 100%; height: auto; }
button { font: inherit; background: none; border: 0; cursor: pointer; color: inherit; padding: 0; }
a { color: inherit; text-decoration: none; }
:focus-visible { outline: 2px solid var(--color-spark); outline-offset: 4px; border-radius: 2px; }


/* -------------------------------------------------------------
   2. Design Tokens
   ------------------------------------------------------------- */
:root {

  /* Farben – Grundbühne */
  --color-bg:        #FAFAF7;   /* warmes Off-White */
  --color-bg-deep:   #F2F1EC;   /* eine Stufe wärmer für Sektionswechsel */
  --color-ink:       #161614;   /* tiefes Schwarz, leicht warm */
  --color-ink-soft:  #4A4A47;   /* Sekundärtext */
  --color-line:      rgba(22, 22, 20, 0.12);
  --color-line-soft: rgba(22, 22, 20, 0.06);

  /* Farben – Akzente (4 Personae) */
  --color-spark:     #E54B25;   /* Korall-Orange – der „Spark of Madness", Energie */
  --color-wurzel:    #1F3D2F;   /* Forest Green – Substanz, 23 Jahre Erfahrung */
  --color-schmaeh:   #F2C94C;   /* Butter-Gelb – niederbayerische Wärme, Witz */
  --color-tiefe:     #1B2B5C;   /* Tiefes Indigo – Premium, Souveränität */

  /* Semantische Aliase */
  --color-accent:    var(--color-spark);
  --color-on-spark:  #FFFFFF;
  --color-on-wurzel: #FAFAF7;
  --color-on-schmaeh:#161614;
  --color-on-tiefe:  #FAFAF7;

  /* Typografie
     -------------------------------------------------------------
     "Vary" ist die Hausschrift. Sie wird selbst eingebunden
     (siehe @font-face-Block direkt unter den Tokens, dort liegt
     der Platzhalter für die WOFF2-Datei). Bis das Vary-File
     produktiv hochgeladen ist, fällt die Schrift auf
     "Bricolage Grotesque" zurück – ein moderner, charakterstarker
     Sans, der dem editorialen Spring/Summer-Look nahekommt.
  ------------------------------------------------------------- */
  --font-display: "Vary", "Bricolage Grotesque", "Fraunces", Georgia, serif;
  --font-body:    "Poppins", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  /* Spacing-Skala */
  --space-3xs: 0.25rem;
  --space-2xs: 0.5rem;
  --space-xs:  0.75rem;
  --space-s:   1rem;
  --space-m:   1.5rem;
  --space-l:   2.5rem;
  --space-xl:  4rem;
  --space-2xl: 6rem;
  --space-3xl: 9rem;
  --space-4xl: 12rem;

  /* Container */
  --container-max: 1440px;
  --container-pad: clamp(1.25rem, 4vw, 3rem);

  /* Radien */
  --radius-s: 4px;
  --radius-m: 12px;
  --radius-l: 24px;

  /* Schatten – sehr dezent */
  --shadow-soft: 0 6px 24px rgba(22, 22, 20, 0.06);
  --shadow-lift: 0 18px 48px rgba(22, 22, 20, 0.10);

  /* Animation */
  --ease-out:  cubic-bezier(0.22, 1, 0.36, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
  --dur-quick: 200ms;
  --dur-base:  450ms;
  --dur-slow:  900ms;
}


/* -------------------------------------------------------------
   Vary – Webfont-Platzhalter
   -------------------------------------------------------------
   PLATZHALTER: Sobald die Vary-Webfont-Files (WOFF2/WOFF)
   vorliegen, hier den korrekten Pfad eintragen. Aktuell wirkt
   nur der Fallback "Bricolage Grotesque".
   ------------------------------------------------------------- */
@font-face {
  font-family: "Vary";
  src: url("/fonts/Vary-Regular.woff2") format("woff2"),
       url("/fonts/Vary-Regular.woff")  format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Vary";
  src: url("/fonts/Vary-Bold.woff2") format("woff2"),
       url("/fonts/Vary-Bold.woff")  format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}


/* -------------------------------------------------------------
   3. Typografie
   ------------------------------------------------------------- */
body {
  font-family: var(--font-body);
  font-size: clamp(1rem, 0.95rem + 0.2vw, 1.0625rem);
  line-height: 1.6;
  color: var(--color-ink);
  background: var(--color-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

.t-display {
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: -0.025em;
  line-height: 0.92;
}

.t-eyebrow {
  font-family: var(--font-body);
  font-size: 0.78rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--color-ink-soft);
}

.t-lead {
  font-family: var(--font-body);
  font-size: clamp(1.125rem, 1rem + 0.6vw, 1.375rem);
  line-height: 1.55;
  font-weight: 400;
  color: var(--color-ink-soft);
}

.t-quote {
  font-family: var(--font-display);
  font-size: clamp(2rem, 1.4rem + 3vw, 4rem);
  line-height: 1.05;
  letter-spacing: -0.02em;
  font-weight: 700;
}

::selection { background: var(--color-spark); color: #fff; }


/* -------------------------------------------------------------
   4. Layout-Primitives
   ------------------------------------------------------------- */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-pad);
}

.section {
  padding-block: clamp(4rem, 8vw, 9rem);
}
.section--tight { padding-block: clamp(3rem, 5vw, 5rem); }
.section--bg-deep    { background: var(--color-bg-deep); }
.section--bg-ink     { background: var(--color-ink);    color: var(--color-bg); }
.section--bg-wurzel  { background: var(--color-wurzel); color: var(--color-on-wurzel); }
.section--bg-schmaeh { background: var(--color-schmaeh);color: var(--color-on-schmaeh); }
.section--bg-spark   { background: var(--color-spark);  color: var(--color-on-spark); }
.section--bg-tiefe   { background: var(--color-tiefe);  color: var(--color-on-tiefe); }


/* -------------------------------------------------------------
   5. Header / Navigation
   ------------------------------------------------------------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--color-bg);
  border-bottom: 1px solid transparent;
  transition: border-color var(--dur-quick) var(--ease-out),
              background    var(--dur-quick) var(--ease-out);
}
.site-header.is-scrolled {
  border-color: var(--color-line);
  background: rgba(250, 250, 247, 0.92);
  backdrop-filter: saturate(140%) blur(10px);
}

.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-l);
  height: 76px;
}

.site-logo {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2xs);
}
.site-logo img { height: 28px; width: auto; }

.site-nav { display: none; }
@media (min-width: 880px) {
  .site-nav { display: block; }
  .site-nav__list {
    display: flex;
    gap: var(--space-l);
    align-items: center;
  }
}
.site-nav__link {
  position: relative;
  font-size: 0.95rem;
  font-weight: 500;
  padding-block: var(--space-2xs);
  transition: color var(--dur-quick) var(--ease-out);
}
.site-nav__link::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -2px;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--dur-base) var(--ease-out);
}
.site-nav__link:hover::after,
.site-nav__link[aria-current="page"]::after { transform: scaleX(1); }

.nav-cta {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2xs);
  padding: 0.65rem 1.1rem;
  border: 1px solid var(--color-ink);
  border-radius: 999px;
  font-size: 0.9rem;
  font-weight: 500;
  transition: background var(--dur-quick) var(--ease-out),
              color      var(--dur-quick) var(--ease-out);
}
.nav-cta:hover { background: var(--color-ink); color: var(--color-bg); }
.nav-cta__dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--color-spark);
}

/* Burger / Mobile */
.nav-burger {
  display: inline-flex;
  flex-direction: column;
  gap: 5px;
  padding: 12px;
  margin-right: -12px;
}
@media (min-width: 880px) { .nav-burger { display: none; } }
.nav-burger span {
  display: block;
  width: 22px; height: 2px;
  background: var(--color-ink);
  transition: transform var(--dur-quick) var(--ease-out),
              opacity   var(--dur-quick) var(--ease-out);
}
.nav-burger[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-burger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-burger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.mobile-nav {
  position: fixed;
  inset: 76px 0 0 0;
  background: var(--color-bg);
  z-index: 40;
  padding: var(--space-xl) var(--container-pad);
  transform: translateY(-100%);
  transition: transform var(--dur-base) var(--ease-out);
  overflow-y: auto;
}
.mobile-nav.is-open { transform: translateY(0); }
.mobile-nav__list { display: flex; flex-direction: column; gap: var(--space-m); }
.mobile-nav__link {
  font-family: var(--font-display);
  font-size: clamp(2rem, 8vw, 3rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1;
}
.mobile-nav__meta {
  margin-top: var(--space-xl);
  padding-top: var(--space-l);
  border-top: 1px solid var(--color-line);
  font-size: 0.95rem;
  color: var(--color-ink-soft);
  display: grid; gap: var(--space-2xs);
}
@media (min-width: 880px) { .mobile-nav { display: none; } }


/* -------------------------------------------------------------
   6. Hero
   ------------------------------------------------------------- */
.hero {
  position: relative;
  padding-top: clamp(2rem, 4vw, 4rem);
  padding-bottom: clamp(3rem, 6vw, 6rem);
  overflow: hidden;
}

.hero__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-l);
  align-items: end;
}
@media (min-width: 1000px) {
  .hero__inner {
    grid-template-columns: 1.25fr 1fr;
    gap: var(--space-xl);
  }
}

.hero__claim {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(3.5rem, 13vw, 13.5rem);
  line-height: 0.86;
  letter-spacing: -0.04em;
  margin-block: var(--space-m) var(--space-s);
}
.hero__claim .accent  { color: var(--color-spark); font-style: italic; font-weight: 400; }
.hero__claim .accent-2{ display: block; }

.hero__sub {
  max-width: 28ch;
  font-size: clamp(1.15rem, 1rem + 0.4vw, 1.35rem);
  color: var(--color-ink-soft);
  line-height: 1.5;
  margin-bottom: var(--space-l);
}

.hero__visual {
  position: relative;
  align-self: stretch;
  display: flex; align-items: flex-end;
  justify-content: center;
}
.hero__visual::before {
  content: "";
  position: absolute;
  inset: 8% -8% -8% 8%;
  background: var(--color-schmaeh);
  border-radius: var(--radius-l);
  z-index: 0;
}
.hero__visual img {
  position: relative;
  z-index: 1;
  width: min(100%, 520px);
  height: auto;
  object-fit: contain;
  filter: drop-shadow(0 30px 50px rgba(22,22,20,0.18));
  will-change: transform;
}

.hero__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-m);
  padding-top: var(--space-l);
  margin-top: var(--space-l);
  border-top: 1px solid var(--color-line);
  font-size: 0.92rem;
  color: var(--color-ink-soft);
}
.hero__meta strong { color: var(--color-ink); font-weight: 600; }
.hero__meta-divider {
  width: 4px; height: 4px;
  border-radius: 50%;
  background: var(--color-line);
}

.hero__awards {
  margin-top: var(--space-m);
  padding-top: var(--space-m);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-s) var(--space-m);
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--color-ink-soft);
}
.hero__awards span:first-child { font-weight: 600; color: var(--color-ink); }

.scroll-indicator {
  display: none;
  position: absolute;
  bottom: var(--space-l);
  right: var(--container-pad);
  font-size: 0.8rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-ink-soft);
  writing-mode: vertical-rl;
}
@media (min-width: 1000px) { .scroll-indicator { display: block; } }
.scroll-indicator::after {
  content: "";
  display: block;
  width: 1px;
  height: 60px;
  background: var(--color-ink);
  margin-top: var(--space-s);
  margin-inline: auto;
  animation: scrollNudge 2.4s var(--ease-in-out) infinite;
  transform-origin: top;
}


/* -------------------------------------------------------------
   7. Manifest
   ------------------------------------------------------------- */
.manifest {
  position: relative;
}
.manifest__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-xl);
  align-items: start;
}
@media (min-width: 900px) {
  .manifest__grid { grid-template-columns: 1fr 2fr; }
}

.manifest__label { padding-top: 0.5rem; }

.manifest__statement {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(2rem, 1.5rem + 3.5vw, 4.75rem);
  line-height: 1.02;
  letter-spacing: -0.025em;
}
.manifest__statement em {
  font-style: italic;
  font-weight: 400;
  color: var(--color-spark);
}
.manifest__statement .quiet {
  display: block;
  color: var(--color-ink-soft);
}

.manifest__signature {
  margin-top: var(--space-l);
  font-size: 0.92rem;
  color: var(--color-ink-soft);
  letter-spacing: 0.04em;
}
.manifest__signature::before {
  content: "—— ";
  margin-right: var(--space-2xs);
  color: var(--color-spark);
}


/* -------------------------------------------------------------
   8. Spektrum
   ------------------------------------------------------------- */
.spektrum__head {
  display: flex; flex-direction: column;
  gap: var(--space-m);
  margin-bottom: var(--space-xl);
}
.spektrum__head .heading {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 2rem + 4vw, 6rem);
  line-height: 0.95;
  letter-spacing: -0.025em;
  font-weight: 700;
  max-width: 16ch;
}

.spektrum__grid {
  display: grid;
  grid-template-columns: 1fr;
  border-top: 1px solid var(--color-line);
}
@media (min-width: 700px)  { .spektrum__grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1100px) { .spektrum__grid { grid-template-columns: repeat(3, 1fr); } }

.spektrum-card {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: var(--space-l);
  padding: clamp(1.75rem, 3vw, 2.75rem) clamp(1.5rem, 2.5vw, 2.25rem);
  border-bottom: 1px solid var(--color-line);
  border-right: 1px solid var(--color-line);
  min-height: 320px;
  isolation: isolate;
  overflow: hidden;
  transition: background var(--dur-base) var(--ease-out);
}
@media (min-width: 700px) {
  .spektrum-card:nth-child(2n)  { border-right: 0; }
}
@media (min-width: 1100px) {
  .spektrum-card:nth-child(2n)  { border-right: 1px solid var(--color-line); }
  .spektrum-card:nth-child(3n)  { border-right: 0; }
}

.spektrum-card__num {
  font-family: var(--font-display);
  font-size: 0.95rem;
  font-weight: 500;
  color: var(--color-ink-soft);
  letter-spacing: 0.08em;
}

.spektrum-card__title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 1.4rem + 1.6vw, 2.6rem);
  line-height: 1;
  letter-spacing: -0.02em;
  font-weight: 700;
  margin-bottom: var(--space-2xs);
}

.spektrum-card__line {
  font-size: 1.05rem;
  color: var(--color-ink-soft);
  max-width: 32ch;
}

.spektrum-card__more {
  align-self: flex-start;
  font-size: 0.85rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  border-bottom: 1px solid currentColor;
  padding-bottom: 2px;
  transition: gap var(--dur-quick), color var(--dur-quick);
  display: inline-flex; align-items: center; gap: 0.5rem;
}
.spektrum-card__more::after {
  content: "→";
  display: inline-block;
  transition: transform var(--dur-quick) var(--ease-out);
}
.spektrum-card:hover .spektrum-card__more::after { transform: translateX(4px); }

.spektrum-card--usp {
  background: var(--color-wurzel);
  color: var(--color-on-wurzel);
}
.spektrum-card--usp .spektrum-card__num,
.spektrum-card--usp .spektrum-card__line { color: rgba(250,250,247,0.75); }
.spektrum-card--usp .spektrum-card__usp-tag {
  display: inline-block;
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 0.35rem 0.7rem;
  border: 1px solid rgba(250,250,247,0.4);
  border-radius: 999px;
  margin-bottom: var(--space-s);
}


/* -------------------------------------------------------------
   9. Projekte / Cases
   ------------------------------------------------------------- */
.cases__head {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-m);
  align-items: end;
  margin-bottom: var(--space-xl);
}
@media (min-width: 900px) { .cases__head { grid-template-columns: 1.5fr 1fr; } }

.cases__heading {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 2rem + 4vw, 6rem);
  line-height: 0.95;
  letter-spacing: -0.025em;
  font-weight: 700;
  max-width: 12ch;
}

.cases__list {
  display: grid;
  gap: var(--space-2xl);
}

.case {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-l);
  align-items: center;
}
@media (min-width: 900px) {
  .case { grid-template-columns: 1.4fr 1fr; gap: var(--space-2xl); }
  .case--reverse { grid-template-columns: 1fr 1.4fr; }
  .case--reverse .case__visual { order: 2; }
  .case--reverse .case__body   { order: 1; }
}

.case__visual {
  position: relative;
  aspect-ratio: 4 / 3;
  border-radius: var(--radius-m);
  overflow: hidden;
}
.case__visual--mockup {
  background:
    linear-gradient(135deg, rgba(255,255,255,0.6) 0%, rgba(255,255,255,0) 50%),
    var(--mock-bg, var(--color-bg-deep));
  display: grid;
  place-items: center;
  padding: clamp(1.5rem, 4vw, 3rem);
}
.case__mock-frame {
  width: 92%;
  height: 80%;
  background: #fff;
  border-radius: var(--radius-s);
  box-shadow: var(--shadow-lift);
  position: relative;
  overflow: hidden;
}
.case__mock-frame::before {
  content: "";
  position: absolute; top: 0; left: 0; right: 0;
  height: 26px;
  background: linear-gradient(180deg, rgba(0,0,0,0.04), transparent);
  border-bottom: 1px solid rgba(0,0,0,0.06);
}
.case__mock-frame::after {
  content: "";
  position: absolute;
  top: 9px; left: 12px;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: rgba(0,0,0,0.18);
  box-shadow: 14px 0 0 rgba(0,0,0,0.10), 28px 0 0 rgba(0,0,0,0.06);
}
.case__mock-content {
  position: absolute; inset: 36px 18px 18px 18px;
  display: flex; flex-direction: column; gap: 10px;
}
.case__mock-content .bar {
  height: 10px;
  background: var(--mock-fg, var(--color-ink));
  border-radius: 2px;
  opacity: 0.85;
}
.case__mock-content .bar.short { width: 38%; }
.case__mock-content .bar.med   { width: 64%; }
.case__mock-content .bar.long  { width: 100%; opacity: 0.55; }
.case__mock-content .block {
  margin-top: auto;
  height: 38%;
  border-radius: 4px;
  background: var(--mock-fg, var(--color-ink));
  opacity: 0.92;
}

.case__body { max-width: 44ch; }

.case__client {
  display: inline-block;
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-ink-soft);
  margin-bottom: var(--space-s);
}

.case__title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 1.3rem + 2.5vw, 3.25rem);
  line-height: 1;
  letter-spacing: -0.02em;
  font-weight: 700;
  margin-bottom: var(--space-m);
}

.case__tags {
  display: flex; flex-wrap: wrap; gap: var(--space-2xs);
  margin-top: var(--space-m);
}
.case__tag {
  font-size: 0.78rem;
  padding: 0.4rem 0.8rem;
  border: 1px solid var(--color-line);
  border-radius: 999px;
  color: var(--color-ink-soft);
}

.case__link {
  margin-top: var(--space-l);
  display: inline-flex; align-items: center; gap: 0.5rem;
  font-weight: 500;
  border-bottom: 1px solid var(--color-ink);
  padding-bottom: 2px;
}
.case__link::after {
  content: "→";
  transition: transform var(--dur-quick) var(--ease-out);
}
.case__link:hover::after { transform: translateX(4px); }

.cases__more {
  margin-top: var(--space-2xl);
  text-align: center;
}
.cases__more a {
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 1rem + 1vw, 1.75rem);
  font-weight: 700;
  letter-spacing: -0.01em;
  border-bottom: 2px solid var(--color-spark);
  padding-bottom: 4px;
}


/* -------------------------------------------------------------
   10. Trust / Zahlen
   ------------------------------------------------------------- */
.trust__numbers {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-xl);
  border-block: 1px solid currentColor;
  padding-block: clamp(2.5rem, 5vw, 4.5rem);
}
@media (min-width: 800px) {
  .trust__numbers { grid-template-columns: repeat(3, 1fr); }
}

.trust__number {
  display: flex; flex-direction: column; gap: var(--space-2xs);
}
.trust__big {
  font-family: var(--font-display);
  font-size: clamp(4rem, 3rem + 6vw, 9rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 0.9;
}
.trust__big sup {
  font-size: 0.4em;
  font-weight: 400;
  vertical-align: super;
  margin-left: 0.1em;
  color: var(--color-spark);
}
.trust__label {
  font-size: 0.85rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  opacity: 0.7;
}

.trust__statement {
  text-align: center;
  margin-top: var(--space-xl);
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 1rem + 1.4vw, 2.25rem);
  font-weight: 400;
  font-style: italic;
  letter-spacing: -0.01em;
  opacity: 0.85;
}

.trust__logos {
  margin-top: var(--space-xl);
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-m);
  align-items: center;
}
@media (min-width: 600px)  { .trust__logos { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1000px) { .trust__logos { grid-template-columns: repeat(6, 1fr); } }

.trust__logo {
  height: 56px;
  display: grid;
  place-items: center;
  font-family: var(--font-display);
  font-weight: 600;
  letter-spacing: 0.05em;
  font-size: 1rem;
  color: currentColor;
  opacity: 0.45;
  transition: opacity var(--dur-quick) var(--ease-out);
  border: 1px solid currentColor;
  border-radius: var(--radius-s);
  text-align: center;
  padding: 0 .75rem;
}
.trust__logo:hover { opacity: 1; }


/* -------------------------------------------------------------
   11. Kreativbude (Blog)
   ------------------------------------------------------------- */
.blog__head {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-m);
  align-items: end;
  margin-bottom: var(--space-xl);
}
@media (min-width: 900px) { .blog__head { grid-template-columns: 1.5fr 1fr; } }

.blog__heading {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 2rem + 4vw, 6rem);
  line-height: 0.95;
  letter-spacing: -0.025em;
  font-weight: 700;
  max-width: 14ch;
}

.blog__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-xl);
}
@media (min-width: 700px)  { .blog__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .blog__grid { grid-template-columns: repeat(3, 1fr); } }

.blog-card {
  display: flex; flex-direction: column;
  gap: var(--space-m);
}
.blog-card__media {
  aspect-ratio: 4 / 3;
  border-radius: var(--radius-m);
  background: var(--card-bg, var(--color-bg-deep));
  position: relative;
  overflow: hidden;
  display: grid;
  place-items: center;
  color: var(--card-fg, var(--color-ink));
  transition: transform var(--dur-base) var(--ease-out);
}
.blog-card__media-symbol {
  font-family: var(--font-display);
  font-size: clamp(3rem, 8vw, 6rem);
  font-weight: 700;
  letter-spacing: -0.04em;
}
.blog-card:hover .blog-card__media { transform: scale(1.02); }

.blog-card__meta {
  display: flex; gap: var(--space-s); align-items: center;
  font-size: 0.78rem; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--color-ink-soft);
}
.blog-card__meta-divider { width: 4px; height: 4px; border-radius: 50%; background: var(--color-line); }

.blog-card__title {
  font-family: var(--font-display);
  font-size: clamp(1.4rem, 1.2rem + 0.6vw, 1.85rem);
  line-height: 1.05;
  letter-spacing: -0.015em;
  font-weight: 700;
}

.blog-card__teaser {
  color: var(--color-ink-soft);
  font-size: 1rem;
  line-height: 1.55;
  max-width: 38ch;
}

.blog-card__link {
  margin-top: auto;
  align-self: flex-start;
  font-size: 0.9rem;
  font-weight: 500;
  border-bottom: 1px solid currentColor;
  padding-bottom: 2px;
}


/* -------------------------------------------------------------
   12. Kontakt
   ------------------------------------------------------------- */
.contact {
  position: relative;
  padding-block: clamp(5rem, 9vw, 10rem);
  overflow: hidden;
}
.contact__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-xl);
  align-items: center;
}
@media (min-width: 1000px) {
  .contact__inner { grid-template-columns: 1.4fr 1fr; }
}

.contact__heading {
  font-family: var(--font-display);
  font-size: clamp(3rem, 2rem + 7vw, 9rem);
  line-height: 0.9;
  letter-spacing: -0.035em;
  font-weight: 700;
  margin-bottom: var(--space-l);
}
.contact__heading em { font-style: italic; font-weight: 400; color: var(--color-spark); }

.contact__lead {
  max-width: 38ch;
  font-size: clamp(1.1rem, 1rem + 0.4vw, 1.3rem);
  color: rgba(250,250,247,0.78);
  margin-bottom: var(--space-xl);
}

.contact__details { display: grid; gap: var(--space-l); }
.contact__detail {
  display: flex; flex-direction: column; gap: var(--space-3xs);
  padding-top: var(--space-s);
  border-top: 1px solid rgba(250,250,247,0.18);
}
.contact__detail-label {
  font-size: 0.78rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: rgba(250,250,247,0.55);
}
.contact__detail-value {
  font-family: var(--font-display);
  font-size: clamp(1.2rem, 1rem + 0.8vw, 1.6rem);
  font-weight: 700;
  letter-spacing: -0.01em;
}
.contact__detail-value a {
  position: relative;
  display: inline-block;
}
.contact__detail-value a::after {
  content: "";
  position: absolute; left: 0; right: 0; bottom: -2px;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--dur-base) var(--ease-out);
}
.contact__detail-value a:hover::after { transform: scaleX(1); }

.contact__cta {
  margin-top: var(--space-xl);
  display: inline-flex; align-items: center; gap: var(--space-s);
  padding: 1.25rem 2rem;
  background: var(--color-spark);
  color: #fff;
  border-radius: 999px;
  font-weight: 600;
  font-size: 1.05rem;
  transition: transform var(--dur-quick) var(--ease-out),
              background var(--dur-quick) var(--ease-out);
}
.contact__cta:hover { transform: translateY(-2px); background: #ff5a31; }
.contact__cta::after { content: "→"; transition: transform var(--dur-quick) var(--ease-out); }
.contact__cta:hover::after { transform: translateX(4px); }


/* -------------------------------------------------------------
   13. Footer
   ------------------------------------------------------------- */
.site-footer {
  background: var(--color-ink);
  color: var(--color-bg);
  padding-block: var(--space-2xl) var(--space-l);
}
.site-footer__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-xl);
  margin-bottom: var(--space-2xl);
}
@media (min-width: 800px) { .site-footer__grid { grid-template-columns: 1.6fr 1fr 1fr 1fr; } }

.site-footer__claim {
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 1.2rem + 1.2vw, 2.5rem);
  line-height: 1.05;
  font-weight: 700;
  letter-spacing: -0.02em;
  max-width: 22ch;
}
.site-footer__claim em { font-style: italic; font-weight: 400; color: var(--color-spark); }

.site-footer__col h4 {
  font-size: 0.78rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: rgba(250,250,247,0.55);
  margin-bottom: var(--space-s);
  font-weight: 500;
}
.site-footer__col ul { display: grid; gap: var(--space-2xs); }
.site-footer__col a:hover { color: var(--color-spark); }

.site-footer__bottom {
  display: flex; flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-m);
  padding-top: var(--space-l);
  border-top: 1px solid rgba(250,250,247,0.12);
  font-size: 0.85rem;
  color: rgba(250,250,247,0.55);
}
.site-footer__hashtag {
  color: var(--color-spark);
  font-weight: 500;
}


/* -------------------------------------------------------------
   14. Mask-Components & Sprechblasen
   ------------------------------------------------------------- */
.mask-figure {
  position: relative;
  display: inline-block;
}
.mask-figure img {
  width: 100%;
  height: auto;
  border-radius: var(--radius-l);
  filter: drop-shadow(0 18px 40px rgba(22,22,20,0.12));
}

.speech-bubble {
  position: absolute;
  background: var(--color-bg);
  color: var(--color-ink);
  border-radius: 22px;
  padding: 1rem 1.25rem;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(0.95rem, 0.85rem + 0.4vw, 1.25rem);
  line-height: 1.1;
  letter-spacing: -0.01em;
  max-width: 14ch;
  box-shadow: var(--shadow-soft);
  z-index: 2;
}
.speech-bubble::after {
  content: "";
  position: absolute;
  width: 22px; height: 22px;
  background: inherit;
  bottom: -8px; left: 28px;
  transform: rotate(45deg);
  border-radius: 4px;
  z-index: -1;
}
.speech-bubble--top-right    { top: 8%;  right: -8%; }
.speech-bubble--top-left     { top: 8%;  left: -8%;  }
.speech-bubble--bottom-right { bottom: 12%; right: -8%; }
.speech-bubble--bottom-left  { bottom: 12%; left: -8%;  }
.speech-bubble--bottom-right::after,
.speech-bubble--top-right::after { left: auto; right: 28px; }

.speech-bubble--spark   { background: var(--color-spark);   color: #fff; }
.speech-bubble--wurzel  { background: var(--color-wurzel);  color: #FAFAF7; }
.speech-bubble--schmaeh { background: var(--color-schmaeh); color: var(--color-ink); }
.speech-bubble--tiefe   { background: var(--color-tiefe);   color: #FAFAF7; }


/* -------------------------------------------------------------
   15. Sektions-Übergang / Erzähler
   ------------------------------------------------------------- */
.narrator {
  padding-block: clamp(3rem, 6vw, 6rem);
  overflow: hidden;
}
.narrator__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-l);
  align-items: center;
}
@media (min-width: 800px) {
  .narrator__inner { grid-template-columns: 1fr 1.4fr; gap: var(--space-2xl); }
  .narrator--right .narrator__figure { order: 2; }
  .narrator--right .narrator__text   { order: 1; }
}

.narrator__figure {
  position: relative;
  max-width: 380px;
  width: 100%;
  margin-inline: auto;
}
.narrator__figure::before {
  content: "";
  position: absolute;
  inset: -6% -10% -6% 6%;
  background: var(--narrator-bg, var(--color-bg-deep));
  border-radius: var(--radius-l);
  z-index: 0;
}
.narrator__figure img { position: relative; z-index: 1; border-radius: var(--radius-l); }

.narrator__text {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 1.4rem + 2vw, 3rem);
  line-height: 1.05;
  font-weight: 700;
  letter-spacing: -0.02em;
  max-width: 18ch;
}
.narrator__text em { font-style: italic; font-weight: 400; color: var(--color-spark); }
.narrator__caption {
  display: block;
  margin-top: var(--space-m);
  font-family: var(--font-body);
  font-size: 0.85rem; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--color-ink-soft);
  font-weight: 500;
}


/* -------------------------------------------------------------
   16. Detail-Seiten (Spektrum, Projekte)
   ------------------------------------------------------------- */
/* Page-Hero (für Detail-Seiten) */
.page-hero {
  padding-top: clamp(3rem, 6vw, 6rem);
  padding-bottom: clamp(3rem, 6vw, 6rem);
  border-bottom: 1px solid var(--color-line);
}
.page-hero__crumbs {
  display: flex; gap: var(--space-2xs); align-items: center;
  font-size: 0.82rem; color: var(--color-ink-soft);
  letter-spacing: 0.14em; text-transform: uppercase;
  margin-bottom: var(--space-l);
}
.page-hero__crumbs a:hover { color: var(--color-ink); }

.page-hero__title {
  font-family: var(--font-display);
  font-size: clamp(3.5rem, 2rem + 9vw, 12rem);
  line-height: 0.86;
  letter-spacing: -0.04em;
  font-weight: 700;
  margin-bottom: var(--space-l);
}
.page-hero__title em { font-style: italic; font-weight: 400; color: var(--color-spark); }

.page-hero__lead {
  max-width: 56ch;
  font-size: clamp(1.15rem, 1rem + 0.5vw, 1.4rem);
  color: var(--color-ink-soft);
  line-height: 1.55;
}

/* Two-Column-Sektion für Detailseiten */
.two-col {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-xl);
  align-items: start;
  padding-block: clamp(3rem, 6vw, 6rem);
}
@media (min-width: 900px) { .two-col { grid-template-columns: 1fr 1.6fr; gap: var(--space-2xl); } }

.two-col__label {
  font-size: 0.82rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--color-ink-soft);
  position: sticky;
  top: 100px;
}
.two-col__body p {
  font-size: clamp(1.05rem, 1rem + 0.3vw, 1.25rem);
  line-height: 1.65;
  margin-bottom: var(--space-m);
  max-width: 60ch;
}
.two-col__body p:last-child { margin-bottom: 0; }

.two-col__body h3 {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 1.3rem + 1vw, 2.25rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin-block: var(--space-l) var(--space-s);
}

.two-col__body h3:first-child { margin-top: 0; }

/* Werkliste (Tag-Cluster auf Detailseite) */
.tag-cluster {
  display: flex; flex-wrap: wrap; gap: var(--space-2xs);
  margin-top: var(--space-m);
}
.tag-cluster span {
  font-size: 0.82rem;
  padding: 0.45rem 0.85rem;
  border: 1px solid var(--color-line);
  border-radius: 999px;
  color: var(--color-ink);
}

/* Filter (Projekte-Übersicht) */
.filter-bar {
  display: flex; flex-wrap: wrap; gap: var(--space-2xs);
  align-items: center;
  padding-block: var(--space-l);
  border-bottom: 1px solid var(--color-line);
}
.filter-bar__label {
  font-size: 0.78rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--color-ink-soft);
  margin-right: var(--space-s);
}
.filter-bar button {
  font-size: 0.9rem;
  padding: 0.5rem 1rem;
  border-radius: 999px;
  border: 1px solid var(--color-line);
  color: var(--color-ink-soft);
  transition: all var(--dur-quick) var(--ease-out);
}
.filter-bar button:hover { border-color: var(--color-ink); color: var(--color-ink); }
.filter-bar button.is-active {
  background: var(--color-ink);
  color: var(--color-bg);
  border-color: var(--color-ink);
}

/* Projekte-Grid (Übersichtsseite) */
.projects-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-xl);
  padding-block: var(--space-xl);
}
@media (min-width: 700px)  { .projects-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-xl); } }
@media (min-width: 1100px) { .projects-grid { grid-template-columns: repeat(3, 1fr); gap: var(--space-xl); } }

.project-card {
  display: flex; flex-direction: column; gap: var(--space-m);
  transition: transform var(--dur-base) var(--ease-out);
}
.project-card:hover { transform: translateY(-4px); }
.project-card__visual {
  aspect-ratio: 4/3;
  border-radius: var(--radius-m);
  overflow: hidden;
  background: var(--card-bg, var(--color-bg-deep));
  display: grid;
  place-items: center;
  position: relative;
}
.project-card__visual::before {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.4), rgba(255,255,255,0));
  pointer-events: none;
}
.project-card__visual span {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(2rem, 5vw, 3.5rem);
  letter-spacing: -0.02em;
  color: var(--card-fg, var(--color-ink));
  position: relative;
}
.project-card__meta {
  display: flex; gap: var(--space-s);
  font-size: 0.78rem;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--color-ink-soft);
}
.project-card__title {
  font-family: var(--font-display);
  font-size: clamp(1.35rem, 1.2rem + 0.6vw, 1.75rem);
  font-weight: 700;
  letter-spacing: -0.015em;
  line-height: 1.05;
}

/* Großes "Alle Projekte"-Bühnenformat (für Featured) */
.project-card--featured { grid-column: span 1; }
@media (min-width: 1100px) {
  .project-card--featured { grid-column: span 2; }
  .project-card--featured .project-card__visual { aspect-ratio: 16/9; }
}


/* -------------------------------------------------------------
   17. Animationen
   ------------------------------------------------------------- */
.reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity var(--dur-slow) var(--ease-out),
              transform var(--dur-slow) var(--ease-out);
  will-change: opacity, transform;
}
.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}
.reveal-delay-1 { transition-delay: 80ms; }
.reveal-delay-2 { transition-delay: 160ms; }
.reveal-delay-3 { transition-delay: 240ms; }
.reveal-delay-4 { transition-delay: 320ms; }

@keyframes scrollNudge {
  0%, 100% { transform: scaleY(1); transform-origin: top; }
  50%      { transform: scaleY(0.6); transform-origin: top; }
}


/* -------------------------------------------------------------
   18. Reduced Motion
   ------------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  .reveal { opacity: 1; transform: none; }
  .scroll-indicator::after { animation: none; }
}


/* -------------------------------------------------------------
   Utility
   ------------------------------------------------------------- */
.sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}
.skip-link {
  position: absolute;
  top: -40px; left: 0;
  background: var(--color-ink); color: var(--color-bg);
  padding: var(--space-2xs) var(--space-s);
  z-index: 100;
  font-size: 0.9rem;
}
.skip-link:focus { top: 0; }

/* ============================================================
   madmoses · case.css
   ------------------------------------------------------------
   Zusätzliche Styles für Case-Detail-Seiten.
   Wird NACH der style.css geladen. Nutzt vorhandene Tokens.
   ============================================================ */


/* ============================================================
   Case-Hero
   ------------------------------------------------------------
   Brotkrumen, Eyebrow, großer Titel mit Spark-Italic,
   Lead-Text, Meta-Tabelle, Hero-Bild rechts.
   ============================================================ */

.case-hero {
  padding: var(--space-2xl) 0 var(--space-2xl);
  background: var(--color-bg);
  position: relative;
  overflow: hidden;
}

.case-hero__crumbs {
  display: flex;
  gap: 0.5rem;
  font-family: var(--font-body);
  font-size: 0.85rem;
  color: var(--color-muted, #6B6B66);
  margin-bottom: var(--space-xl);
}

.case-hero__crumbs a {
  color: var(--color-muted, #6B6B66);
  text-decoration: none;
}

.case-hero__crumbs a:hover {
  color: var(--color-spark);
}

.case-hero__inner {
  display: grid;
  gap: var(--space-2xl);
  grid-template-columns: 1fr;
}

@media (min-width: 900px) {
  .case-hero__inner {
    grid-template-columns: 1.2fr 1fr;
    align-items: end;
  }
}

.case-hero__eyebrow {
  font-family: var(--font-body);
  font-size: 0.85rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-spark);
  margin: 0 0 1.5rem 0;
}

.case-hero__title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(2.5rem, 1.5rem + 4vw, 4.5rem);
  line-height: 1.05;
  letter-spacing: -0.025em;
  color: var(--color-ink);
  margin: 0 0 1.5rem 0;
}

.case-hero__title em {
  font-style: italic;
  font-weight: 400;
  color: var(--color-spark);
}

.case-hero__lead {
  font-family: var(--font-body);
  font-size: 1.15rem;
  line-height: 1.55;
  color: var(--color-ink);
  margin: 0 0 var(--space-xl) 0;
  max-width: 38rem;
}

.case-hero__meta {
  display: grid;
  gap: 1.25rem 2rem;
  grid-template-columns: 1fr 1fr;
  margin: 0;
  padding-top: var(--space-l);
  border-top: 1px solid rgba(22, 22, 20, 0.1);
}

.case-hero__meta div {
  margin: 0;
}

.case-hero__meta dt {
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-muted, #6B6B66);
  margin-bottom: 0.3rem;
}

.case-hero__meta dd {
  font-family: var(--font-body);
  font-size: 0.95rem;
  font-weight: 500;
  color: var(--color-ink);
  margin: 0;
}

.case-hero__visual {
  background: linear-gradient(135deg,
    rgba(229, 75, 37, 0.08),
    rgba(31, 61, 47, 0.05));
  border-radius: var(--radius-l);
  aspect-ratio: 4/5;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-body);
  font-size: 0.85rem;
  color: var(--color-muted, #6B6B66);
  text-align: center;
  padding: var(--space-l);
}


/* ============================================================
   Case-Sections (Aufgabe, Lösung)
   ------------------------------------------------------------
   Two-Column-Layout: links Eyebrow + großer Titel,
   rechts Lead + Fließtext + ggf. Checklist.
   ============================================================ */

.case-section {
  padding: var(--space-2xl) 0;
}

.case-section--task {
  background: rgba(31, 61, 47, 0.03);
}

.case-section--solution {
  background: var(--color-bg);
}

.case-section__grid {
  display: grid;
  gap: var(--space-2xl);
  grid-template-columns: 1fr;
}

@media (min-width: 900px) {
  .case-section__grid {
    grid-template-columns: 1fr 1.6fr;
  }
}

.case-section__eyebrow {
  font-family: var(--font-body);
  font-size: 0.8rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-spark);
  margin: 0 0 1rem 0;
}

.case-section__title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(2rem, 1.2rem + 3vw, 3.25rem);
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--color-ink);
  margin: 0;
}

.case-section__body p.lead {
  font-family: var(--font-body);
  font-size: 1.2rem;
  font-weight: 500;
  line-height: 1.45;
  color: var(--color-ink);
  margin: 0 0 1.5rem 0;
}

.case-section__body p {
  font-family: var(--font-body);
  font-size: 1.05rem;
  line-height: 1.65;
  color: var(--color-ink);
  margin: 0 0 1.25rem 0;
  max-width: 42rem;
}

.case-checklist {
  margin: var(--space-l) 0 0 0;
  padding: 0;
  list-style: none;
}

.case-checklist li {
  position: relative;
  padding-left: 1.75rem;
  margin: 0 0 0.6rem 0;
  font-family: var(--font-body);
  font-size: 1rem;
  line-height: 1.5;
  color: var(--color-ink);
}

.case-checklist li::before {
  content: "→";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--color-spark);
  font-weight: 500;
}


/* ============================================================
   Mockup-Galerie
   ------------------------------------------------------------
   Volle-Breite-Mockups und 2-Spalten-Reihen mit Bildunterschriften
   ============================================================ */

.case-mockups {
  display: grid;
  gap: var(--space-l);
  margin-top: var(--space-2xl);
  padding: 0 var(--space-l);
  max-width: 1400px;
  margin-left: auto;
  margin-right: auto;
}

.case-mockup {
  margin: 0;
}

.case-mockup__visual {
  background: linear-gradient(135deg,
    rgba(31, 61, 47, 0.08),
    rgba(229, 75, 37, 0.04));
  border-radius: var(--radius-l);
  aspect-ratio: 16/9;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-body);
  font-size: 0.85rem;
  color: var(--color-muted, #6B6B66);
  text-align: center;
  padding: var(--space-l);
  margin-bottom: 0.75rem;
}

.case-mockup--wide .case-mockup__visual {
  aspect-ratio: 21/9;
}

.case-mockup figcaption {
  font-family: var(--font-body);
  font-size: 0.9rem;
  color: var(--color-muted, #6B6B66);
  font-style: italic;
  text-align: center;
}

.case-mockup-row {
  display: grid;
  gap: var(--space-l);
  grid-template-columns: 1fr;
}

@media (min-width: 800px) {
  .case-mockup-row {
    grid-template-columns: 1fr 1fr;
  }
}


/* ============================================================
   Case-Stats
   ------------------------------------------------------------
   Vier große Kennzahlen, in Display-Schrift,
   plus Kunden-Zitat darunter.
   ============================================================ */

.case-stats {
  padding: var(--space-2xl) 0;
  background: var(--color-ink);
  color: var(--color-bg);
}

.case-stats__head {
  margin-bottom: var(--space-2xl);
  max-width: 36rem;
}

.case-stats .case-section__eyebrow {
  color: var(--color-schmaeh, #F2C94C);
}

.case-stats .case-section__title {
  color: var(--color-bg);
}

.case-stats__grid {
  list-style: none;
  margin: 0 0 var(--space-2xl) 0;
  padding: 0;
  display: grid;
  gap: var(--space-l);
  grid-template-columns: 1fr 1fr;
}

@media (min-width: 800px) {
  .case-stats__grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

.case-stat {
  border-top: 1px solid rgba(250, 250, 247, 0.2);
  padding-top: var(--space-l);
}

.case-stat__value {
  display: block;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(2.75rem, 2rem + 3vw, 4.5rem);
  line-height: 1;
  letter-spacing: -0.025em;
  color: var(--color-bg);
  margin-bottom: 0.5rem;
}

.case-stat__value .case-stat__unit {
  font-size: 0.5em;
  color: var(--color-spark);
  font-weight: 400;
  font-style: italic;
}

.case-stat__label {
  display: block;
  font-family: var(--font-body);
  font-size: 0.9rem;
  line-height: 1.4;
  color: rgba(250, 250, 247, 0.7);
}

.case-stats__quote {
  max-width: 50rem;
  margin: 0;
  padding: var(--space-l) 0 0 0;
  border-top: 1px solid rgba(250, 250, 247, 0.2);
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.25rem, 0.9rem + 1.2vw, 1.6rem);
  line-height: 1.45;
  font-weight: 400;
  color: var(--color-bg);
}

.case-stats__quote cite {
  display: block;
  margin-top: 1rem;
  font-family: var(--font-body);
  font-style: normal;
  font-size: 0.85rem;
  color: rgba(250, 250, 247, 0.6);
  font-weight: 400;
}


/* ============================================================
   Case-Tags
   ------------------------------------------------------------
   "Was wir hier eingesetzt haben" – Tag-Cluster mit Verlinkung
   ============================================================ */

.case-tags {
  padding: var(--space-2xl) 0;
  background: var(--color-bg);
}

.case-tags__title {
  font-family: var(--font-body);
  font-size: 0.8rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-muted, #6B6B66);
  margin: 0 0 1.5rem 0;
}

.tag-cluster--small span {
  font-size: 0.8rem;
  padding: 0.3rem 0.7rem;
}

.case-tags .tag-cluster span a {
  color: inherit;
  text-decoration: none;
  font-weight: 500;
}

.case-tags .tag-cluster span a:hover {
  color: var(--color-spark);
}


/* ============================================================
   Case-Related
   ------------------------------------------------------------
   "Auch interessant" – zwei Project-Cards
   ============================================================ */

.case-related {
  padding: var(--space-2xl) 0;
  background: rgba(31, 61, 47, 0.03);
  border-top: 1px solid rgba(22, 22, 20, 0.06);
}

.case-related__head {
  margin-bottom: var(--space-xl);
  max-width: 32rem;
}

.case-related__head h2 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(1.5rem, 1.1rem + 1.5vw, 2.25rem);
  letter-spacing: -0.02em;
  color: var(--color-ink);
  margin: 0 0 0.75rem 0;
}

.case-related__head p {
  font-family: var(--font-body);
  font-size: 1rem;
  color: var(--color-muted, #6B6B66);
  margin: 0;
}

.case-related__grid {
  display: grid;
  gap: var(--space-l);
  grid-template-columns: 1fr;
}

@media (min-width: 800px) {
  .case-related__grid {
    grid-template-columns: 1fr 1fr;
  }
}


/* ============================================================
   Case-CTA Banner
   ------------------------------------------------------------
   Großer CTA am Ende der Case, mit Spark als Akzent
   ============================================================ */

.case-cta {
  padding: var(--space-2xl) 0;
  background: var(--color-bg);
}

.case-cta__inner {
  max-width: 56rem;
  margin: 0 auto;
  text-align: center;
  padding: var(--space-2xl) var(--space-l);
  background: var(--color-ink);
  color: var(--color-bg);
  border-radius: var(--radius-l);
  position: relative;
  overflow: hidden;
}

.case-cta__inner::before {
  content: "";
  position: absolute;
  top: -30%;
  right: -10%;
  width: 50%;
  height: 160%;
  background: radial-gradient(circle, rgba(229, 75, 37, 0.18), transparent 65%);
  pointer-events: none;
}

.case-cta__eyebrow {
  position: relative;
  z-index: 1;
  font-family: var(--font-body);
  font-size: 0.8rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-schmaeh, #F2C94C);
  margin: 0 0 1.5rem 0;
}

.case-cta__title {
  position: relative;
  z-index: 1;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(2rem, 1.2rem + 3vw, 3.5rem);
  line-height: 1.05;
  letter-spacing: -0.025em;
  color: var(--color-bg);
  margin: 0 0 1.5rem 0;
}

.case-cta__title em {
  font-style: italic;
  font-weight: 400;
  color: var(--color-spark);
}

.case-cta__lead {
  position: relative;
  z-index: 1;
  font-family: var(--font-body);
  font-size: 1.05rem;
  line-height: 1.6;
  color: rgba(250, 250, 247, 0.85);
  margin: 0 auto var(--space-xl) auto;
  max-width: 32rem;
}

.case-cta .btn {
  position: relative;
  z-index: 1;
}


/* ============================================================
   ENDE case.css
   ============================================================ */


/* ============================================================
   Nachträge: Klassen, die im HTML genutzt werden,
   aber im Haupt-CSS noch nicht definiert sind
   ============================================================ */

.case-hero__body {
  /* einfacher Wrapper, kein Extra-Layout nötig */
}

.case-section__head {
  /* einfacher Wrapper für Eyebrow + Titel im Section-Grid */
}


/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.85rem 1.5rem;
  font-family: var(--font-body);
  font-size: 0.95rem;
  font-weight: 500;
  text-decoration: none;
  border-radius: 999px;
  border: 0;
  cursor: pointer;
  transition: background 0.2s ease, color 0.2s ease, transform 0.15s ease;
}

.btn--primary {
  background: var(--color-spark);
  color: #fff;
}

.btn--primary:hover {
  background: #c63d1c;
  transform: translateY(-1px);
}

.btn--primary span:last-child {
  transition: transform 0.2s ease;
}

.btn--primary:hover span:last-child {
  transform: translateX(3px);
}

