:root {
  --color-ink-900: #1C2230;
  --color-ink-700: #3A4256;
  --color-ink-500: #5B6478;
  --color-paper: #FAF7F2;
  --color-paper-tint: #F2EDE4;
  --color-surface: #FFFFFF;
  --color-primary: #24304B;
  --color-primary-light: #2B3552;
  --color-accent-terracotta: #D98A54;
  --color-accent-gold: #E8B04B;
  --color-sage: #7C9482;
  --gradient-accent: linear-gradient(135deg, #D98A54 0%, #E8B04B 100%);
  --gradient-hero: linear-gradient(155deg, #1C2230 0%, #242C42 55%, #2B3552 100%);

  --shadow-sm: 0 1px 2px rgba(28,34,48,0.06), 0 1px 1px rgba(28,34,48,0.04);
  --shadow-md: 0 4px 12px rgba(28,34,48,0.08), 0 2px 4px rgba(28,34,48,0.06);
  --shadow-lg: 0 12px 32px rgba(28,34,48,0.12), 0 4px 12px rgba(28,34,48,0.08);
  --shadow-xl: 0 24px 60px rgba(28,34,48,0.18), 0 8px 20px rgba(28,34,48,0.1);

  --radius-sm: 8px;
  --radius-md: 14px;
  --radius-lg: 22px;
  --radius-xl: 32px;
  --radius-full: 999px;

  --space-xs: 0.5rem;
  --space-sm: 1rem;
  --space-md: 1.5rem;
  --space-lg: 2.5rem;
  --space-xl: 4rem;
  --space-2xl: 6rem;
  --space-3xl: 8rem;
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; overflow-x: hidden; }
body {
  margin: 0;
  font-family: 'Inter', sans-serif;
  color: var(--color-ink-700);
  background: var(--color-paper);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}
h1, h2, h3, h4 { font-family: 'Lora', serif; color: var(--color-ink-900); margin: 0 0 1rem; font-weight: 600; }
p { margin: 0 0 1rem; }
a { color: inherit; }
img { max-width: 100%; display: block; border-radius: var(--radius-md); }
ul { list-style: none; margin: 0; padding: 0; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }


.nav-link-item {
  color: rgba(250,247,242,0.85);
  text-decoration: none;
  font-weight: 500;
  font-size: 0.95rem;
  padding: 0.5rem 0.25rem;
  margin: 0 0.6rem;
  position: relative;
  transition: color 0.3s ease;
}
.nav-link-item:hover, .nav-link-item--active { color: #fff; }
.nav-link-item--active::after {
  content: ''; position: absolute; left: 0; bottom: -2px; width: 100%; height: 2px;
  background: var(--gradient-accent); border-radius: var(--radius-full);
}
.primary-navigation-links { display: flex; align-items: center; }
.header-cta-button-with-dot {
  position: relative;
  display: inline-flex; align-items: center; gap: 0.6rem;
  background: var(--gradient-accent);
  color: #1C2230;
  font-weight: 600;
  font-size: 0.9rem;
  padding: 0.7rem 1.4rem;
  border-radius: var(--radius-full);
  text-decoration: none;
  box-shadow: var(--shadow-md);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.header-cta-button-with-dot:hover { transform: translateY(-2px); box-shadow: var(--shadow-lg); }
.notification-pulse-dot {
  width: 8px; height: 8px; border-radius: 50%; background: #fff;
  position: relative;
}
.notification-pulse-dot::after {
  content: ''; position: absolute; inset: 0; border-radius: 50%;
  background: #fff; animation: pulseDotAnim 1.8s infinite;
}
@keyframes pulseDotAnim {
  0% { transform: scale(1); opacity: 0.7; }
  100% { transform: scale(2.8); opacity: 0; }
}
.mobile-menu-toggle-button { display: none; color: #FAF7F2; font-size: 1.4rem; min-width: 44px; min-height: 44px; align-items: center; justify-content: center; }


.mobile-navigation-overlay {
  position: fixed; inset: 0; background: rgba(20,24,34,0.55);
  opacity: 0; visibility: hidden; transition: opacity 0.4s ease, visibility 0.4s ease;
  z-index: 1100;
}
.mobile-navigation-overlay.mobile-navigation-overlay--visible { opacity: 1; visibility: visible; }
.mobile-navigation-panel {
  position: fixed; top: 0; right: 0; height: 100vh; width: min(85vw, 360px);
  background: var(--color-primary); z-index: 1200;
  transform: translateX(100%); transition: transform 0.45s cubic-bezier(.4,0,.2,1);
  padding: 2rem 2rem; display: flex; flex-direction: column;
  box-shadow: var(--shadow-xl);
}
.mobile-navigation-panel.mobile-navigation-panel--open { transform: translateX(0); }
.mobile-panel-close-button { align-self: flex-end; color: #FAF7F2; font-size: 1.5rem; min-width: 44px; min-height: 44px; }
.mobile-panel-links { display: flex; flex-direction: column; gap: 1.75rem; margin-top: 3rem; }
.mobile-panel-links a {
  color: #FAF7F2; text-decoration: none; font-family: 'Lora', serif; font-size: 1.4rem; font-weight: 600;
  padding: 0.5rem 0; transition: color 0.3s ease, padding-left 0.3s ease;
}
.mobile-panel-links a:hover { color: var(--color-accent-gold); padding-left: 0.5rem; }


.hero-eyebrow-label {
  display: inline-block; color: var(--color-accent-gold); font-weight: 600; font-size: 0.85rem;
  letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 1rem;
}
.hero-supporting-text { color: rgba(250,247,242,0.82); font-size: 1.05rem; max-width: 560px; margin-bottom: 2rem; }
.hero-benefit-icon-list { display: flex; flex-direction: column; gap: 1.1rem; }
.hero-benefit-icon-item { display: flex; align-items: center; gap: 1rem; color: #FAF7F2; font-weight: 500; }
.hero-benefit-icon-circle {
  min-width: 44px; height: 44px; border-radius: 50%; display: flex; align-items: center; justify-content: center;
  background: rgba(233,176,75,0.15); color: var(--color-accent-gold); font-size: 1.1rem;
  border: 1px solid rgba(233,176,75,0.3);
  transition: transform 0.3s ease, background 0.3s ease;
}
.hero-benefit-icon-item:hover .hero-benefit-icon-circle { transform: scale(1.08); background: rgba(233,176,75,0.28); }

.hero-form-card-elevated {
  background: var(--color-surface);
  border-radius: var(--radius-xl);
  padding: 2.2rem;
  box-shadow: var(--shadow-xl);
  position: relative;
}
.hero-form-card-elevated::before {
  content: ''; position: absolute; top: -3px; left: 20px; right: 20px; height: 6px;
  background: var(--gradient-accent); border-radius: var(--radius-full);
}
.hero-form-card-title { font-size: 1.4rem; margin-bottom: 0.4rem; }
.hero-form-card-subtext { color: var(--color-ink-500); font-size: 0.92rem; margin-bottom: 1.5rem; }
.hero-form-submit-button { width: 100%; justify-content: center; margin-top: 0.5rem; }


.contact-form-field-group { margin-bottom: 1.1rem; display: flex; flex-direction: column; gap: 0.4rem; }
.contact-form-field-group label { font-size: 0.85rem; font-weight: 600; color: var(--color-ink-700); }
.contact-form-field-group input[type="text"],
.contact-form-field-group input[type="email"],
.contact-form-field-group textarea {
  padding: 0.85rem 1rem; border: 1.5px solid #E4DFD5; border-radius: var(--radius-md);
  font-family: 'Inter', sans-serif; font-size: 0.95rem; background: var(--color-paper);
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
  min-height: 44px;
}
.contact-form-field-group textarea { resize: vertical; min-height: 90px; }
.contact-form-field-group input:focus, .contact-form-field-group textarea:focus {
  outline: none; border-color: var(--color-accent-terracotta); box-shadow: 0 0 0 3px rgba(217,138,84,0.15);
}
.contact-form-privacy-group { flex-direction: row; align-items: flex-start; gap: 0.7rem; }
.contact-form-privacy-group input[type="checkbox"] { min-width: 20px; min-height: 20px; margin-top: 0.15rem; }
.contact-form-privacy-group label { font-weight: 400; font-size: 0.85rem; color: var(--color-ink-500); }
.contact-form-privacy-group a { color: var(--color-accent-terracotta); text-decoration: underline; }


.gradient-accent-button {
  display: inline-flex; align-items: center; gap: 0.6rem;
  background: var(--gradient-accent); color: #1C2230;
  font-weight: 600; font-size: 0.95rem; padding: 0.9rem 1.8rem;
  border-radius: var(--radius-full); text-decoration: none;
  box-shadow: var(--shadow-md); transition: transform 0.3s ease, box-shadow 0.3s ease;
  min-height: 44px;
}
.gradient-accent-button:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }


.gradient-fade-transition-hero {
  height: 110px; width: 100%;
  background: linear-gradient(to bottom, #2B3552 0%, var(--color-paper) 100%);
}


.content-module-section { padding: var(--space-2xl) 1.5rem; }
.content-module-section--intro { background: var(--color-paper); }
.content-module-section--modules { background: var(--color-paper-tint); padding: var(--space-3xl) 1.5rem; }
.content-module-section--persona { background: var(--color-paper); }
.content-module-section--glossary { background: var(--color-primary); padding: var(--space-2xl) 1.5rem; }
.content-module-section--cta { background: var(--color-paper-tint); padding: var(--space-2xl) 1.5rem var(--space-3xl); }
.content-module-section--process { background: var(--color-paper-tint); }
.content-module-section--foundation { background: var(--color-paper); }
.content-module-section--gallery-strip { background: var(--color-paper-tint); }
.content-module-section--contact-main { background: var(--color-paper); padding-top: var(--space-2xl); }

.section-eyebrow-label {
  display: inline-block; color: var(--color-accent-terracotta); font-weight: 600; font-size: 0.82rem;
  letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 0.8rem;
}
.section-heading-large { font-size: clamp(1.7rem, 3.4vw, 2.6rem); line-height: 1.25; max-width: 720px; }
.section-intro-paragraph { max-width: 620px; color: var(--color-ink-500); }
.section-header-block { max-width: 1280px; margin: 0 auto var(--space-xl); }


.asymmetric-split-container {
  max-width: 1280px; margin: 0 auto; display: grid; gap: var(--space-xl); align-items: center;
}
.asymmetric-split-container--60-40 { grid-template-columns: 1.5fr 1fr; }
.asymmetric-split-container--40-60 { grid-template-columns: 1fr 1.5fr; }
.asymmetric-split-container--55-45 { grid-template-columns: 1.2fr 1fr; }
.asymmetric-split-image img { width: 100%; height: 100%; object-fit: cover; aspect-ratio: 4/3; box-shadow: var(--shadow-lg); }
.asymmetric-split-text p { color: var(--color-ink-500); }


.modular-cards-grid--varied {
  max-width: 1280px; margin: 0 auto; display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-md);
}
.module-card-item {
  background: var(--color-surface); border-radius: var(--radius-lg); overflow: hidden;
  box-shadow: var(--shadow-md); transition: transform 0.35s ease, box-shadow 0.35s ease;
  display: flex; flex-direction: column;
}
.module-card-item:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.module-card-item--large { grid-column: span 2; grid-row: span 1; }
.module-card-item--tall { grid-column: span 2; }
.module-card-image-wrap img { border-radius: 0; aspect-ratio: 16/9; object-fit: cover; }
.module-card-body { padding: 1.6rem; }
.module-card-number {
  display: inline-block; font-size: 0.78rem; font-weight: 600; color: var(--color-accent-terracotta);
  letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 0.5rem;
}
.module-card-body h3 { font-size: 1.15rem; margin-bottom: 0.5rem; }
.module-card-body p { color: var(--color-ink-500); font-size: 0.92rem; margin: 0; }


.persona-cards-asymmetric-grid {
  max-width: 1280px; margin: 0 auto; display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-md);
}
.persona-card-item {
  background: var(--color-surface); border-radius: var(--radius-lg); padding: 1.6rem;
  box-shadow: var(--shadow-sm); position: relative; overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.persona-card-item:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.persona-card-item h3 { font-size: 1.05rem; margin-bottom: 0.5rem; }
.persona-card-item p { color: var(--color-ink-500); font-size: 0.9rem; margin: 0; }
.persona-card-item--wide { grid-column: span 2; padding: 0; display: flex; flex-direction: column; }
.persona-card-item--wide img { aspect-ratio: 16/9; object-fit: cover; border-radius: 0; }
.persona-card-overlay-text { padding: 1.6rem; }
.persona-card-item--image-bottom { display: flex; flex-direction: column; }
.persona-card-item--image-bottom img { margin-top: 1rem; aspect-ratio: 16/10; object-fit: cover; }


.content-module-section--glossary .section-header-block h2,
.content-module-section--glossary .section-eyebrow-label { color: #FAF7F2; }
.content-module-section--glossary .section-intro-paragraph { color: rgba(250,247,242,0.75); }
.glossary-terms-grid { max-width: 1280px; margin: 0 auto; display: flex; flex-wrap: wrap; gap: 0.9rem; }
.glossary-term-chip {
  display: inline-block; padding: 0.75rem 1.3rem; border-radius: var(--radius-full);
  background: rgba(233,176,75,0.12); border: 1px solid rgba(233,176,75,0.35);
  color: var(--color-accent-gold); font-weight: 500; font-size: 0.92rem; cursor: help;
  transition: background 0.3s ease, transform 0.3s ease;
}
.glossary-term-chip:hover { background: rgba(233,176,75,0.25); transform: translateY(-2px); }


.cta-asymmetric-container {
  max-width: 1280px; margin: 0 auto; display: grid; grid-template-columns: 1.3fr 1fr; gap: var(--space-xl);
  align-items: center; background: var(--color-primary); border-radius: var(--radius-xl); padding: var(--space-xl);
  box-shadow: var(--shadow-xl); position: relative; overflow: hidden;
}
.cta-asymmetric-container::after {
  content: ''; position: absolute; top: -60px; right: -60px; width: 220px; height: 220px;
  background: var(--gradient-accent); border-radius: 50%; opacity: 0.18; filter: blur(10px);
}
.cta-text-block h2 { color: #FAF7F2; font-size: clamp(1.5rem, 3vw, 2.1rem); }
.cta-text-block p { color: rgba(250,247,242,0.78); margin-bottom: 1.5rem; }
.cta-image-block img { aspect-ratio: 4/3; object-fit: cover; box-shadow: var(--shadow-lg); }


.process-steps-asymmetric-list { max-width: 1000px; margin: 0 auto; display: flex; flex-direction: column; gap: 1.3rem; }
.process-step-item {
  display: flex; gap: 1.6rem; align-items: flex-start; background: var(--color-surface);
  border-radius: var(--radius-lg); padding: 1.6rem 1.8rem; box-shadow: var(--shadow-sm);
  width: 90%; transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.process-step-item:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.process-step-item--offset { margin-left: auto; }
.process-step-number {
  font-family: 'Lora', serif; font-size: 1.6rem; font-weight: 700; color: var(--color-accent-terracotta); min-width: 50px;
}
.process-step-item h3 { font-size: 1.05rem; margin-bottom: 0.4rem; }
.process-step-item p { color: var(--color-ink-500); margin: 0; font-size: 0.92rem; }


.gallery-strip-asymmetric-grid, .office-gallery-asymmetric-grid {
  max-width: 1280px; margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-md);
}
.gallery-strip-asymmetric-grid { grid-template-columns: 1.4fr 1fr; }
.gallery-strip-asymmetric-grid img, .office-gallery-asymmetric-grid img {
  width: 100%; height: 100%; object-fit: cover; aspect-ratio: 4/3; box-shadow: var(--shadow-md);
  transition: transform 0.4s ease;
}
.gallery-strip-asymmetric-grid img:hover, .office-gallery-asymmetric-grid img:hover { transform: scale(1.02); }


.contact-detail-list { display: flex; flex-direction: column; gap: 0.9rem; margin: 1.5rem 0; }
.contact-detail-list li { display: flex; align-items: center; gap: 0.8rem; color: var(--color-ink-700); }
.contact-detail-list i { color: var(--color-accent-terracotta); width: 20px; }
.contact-map-embed-wrap { border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-md); }
.contact-form-card-elevated { background: var(--color-surface); border-radius: var(--radius-xl); padding: 2rem; box-shadow: var(--shadow-xl); }


.accordion-field-section { border: 1.5px solid #E4DFD5; border-radius: var(--radius-md); margin-bottom: 1rem; overflow: hidden; }
.accordion-section-toggle {
  width: 100%; display: flex; align-items: center; justify-content: space-between;
  padding: 1rem 1.2rem; font-weight: 600; color: var(--color-ink-900); background: var(--color-paper-tint);
  transition: background 0.3s ease; min-height: 44px;
}
.accordion-section-toggle:hover { background: #EDE6D9; }
.accordion-section-toggle i:last-child { transition: transform 0.3s ease; }
.accordion-field-section--open .accordion-section-toggle i:last-child { transform: rotate(180deg); }
.accordion-section-content {
  max-height: 0; overflow: hidden; transition: max-height 0.4s ease, padding 0.4s ease;
  padding: 0 1.2rem;
}
.accordion-field-section--open .accordion-section-content { max-height: 600px; padding: 1.2rem; }
.contact-form-submit-button { width: 100%; justify-content: center; margin-top: 0.5rem; }


.site-footer-main { background: var(--color-ink-900); color: rgba(250,247,242,0.7); padding: var(--space-2xl) 1.5rem var(--space-md); margin-top: auto; }
.footer-content-grid {
  max-width: 1280px; margin: 0 auto; display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: var(--space-lg);
  padding-bottom: var(--space-lg); border-bottom: 1px solid rgba(250,247,242,0.1);
}
.footer-brand-column p { font-size: 0.9rem; max-width: 280px; }
.footer-links-column h4, .footer-legal-links h4 { color: #FAF7F2; font-size: 0.95rem; margin-bottom: 1rem; }
.footer-links-column a, .footer-legal-links a { display: block; color: rgba(250,247,242,0.7); text-decoration: none; margin-bottom: 0.7rem; font-size: 0.9rem; transition: color 0.3s ease; }
.footer-links-column a:hover, .footer-legal-links a:hover { color: var(--color-accent-gold); }
.footer-links-column p { font-size: 0.9rem; margin-bottom: 0.6rem; display: flex; align-items: center; gap: 0.5rem; }
.footer-links-column p i { color: var(--color-accent-terracotta); }
.footer-bottom-bar { max-width: 1280px; margin: 0 auto; padding-top: var(--space-md); font-size: 0.82rem; text-align: center; }


.legal-page-narrative-section, .impressum-content-section { padding: var(--space-2xl) 1.5rem var(--space-3xl); background: var(--color-paper); }
.legal-page-narrative-content, .impressum-content-wrap { max-width: 820px; margin: 0 auto; }
.legal-page-narrative-content h2 { font-size: 1.3rem; margin-top: 2.2rem; }
.legal-page-narrative-content p { color: var(--color-ink-700); }
.impressum-content-wrap h2 { font-size: 1.2rem; margin-top: 2rem; }
.impressum-data-table { width: 100%; border-collapse: collapse; margin: 1rem 0 1.5rem; }
.impressum-data-table td { padding: 0.7rem 1rem; border: 1px solid #E4DFD5; font-size: 0.92rem; }
.impressum-data-table td:first-child { font-weight: 600; width: 35%; background: var(--color-paper-tint); }


.thanks-page-content-card {
  background: var(--color-surface); border-radius: var(--radius-xl); padding: 3.5rem 3rem; max-width: 560px;
  text-align: center; box-shadow: var(--shadow-xl);
}
.thanks-page-icon { font-size: 3.5rem; color: var(--color-accent-terracotta); margin-bottom: 1.2rem; display: block; }
.thanks-page-content-card p { color: var(--color-ink-500); margin-bottom: 1.8rem; }


.cookie-consent-corner-modal {
  position: fixed; bottom: 1.2rem; left: 1.2rem; max-width: 360px; width: calc(100% - 2.4rem);
  background: var(--color-surface); border-radius: var(--radius-lg); box-shadow: var(--shadow-xl);
  padding: 1.4rem; z-index: 2000; transform: translateY(20px); opacity: 0; visibility: hidden;
  transition: transform 0.4s ease, opacity 0.4s ease, visibility 0.4s ease;
}
.cookie-consent-corner-modal.cookie-consent-corner-modal--visible { transform: translateY(0); opacity: 1; visibility: visible; }
.cookie-consent-corner-modal h3 { font-size: 1rem; margin-bottom: 0.5rem; }
.cookie-consent-corner-modal p { font-size: 0.85rem; color: var(--color-ink-500); margin-bottom: 1rem; }
.cookie-consent-button-stack { display: flex; flex-direction: column; gap: 0.6rem; }
.cookie-consent-button-stack button {
  padding: 0.7rem 1rem; border-radius: var(--radius-md); font-weight: 600; font-size: 0.88rem;
  min-height: 44px; transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.cookie-consent-btn-accept { background: var(--gradient-accent); color: #1C2230; }
.cookie-consent-btn-reject { background: var(--color-paper-tint); color: var(--color-ink-700); }
.cookie-consent-btn-customize { background: none; color: var(--color-accent-terracotta); text-decoration: underline; }
.cookie-consent-button-stack button:hover { transform: translateY(-2px); }
.cookie-consent-customize-panel { max-height: 0; overflow: hidden; transition: max-height 0.4s ease, margin 0.4s ease; }
.cookie-consent-customize-panel.cookie-consent-customize-panel--open { max-height: 400px; margin-top: 1rem; }
.cookie-consent-category-row { display: flex; align-items: center; justify-content: space-between; padding: 0.5rem 0; border-bottom: 1px solid #EEE9DF; font-size: 0.85rem; }
.cookie-consent-category-row:last-child { border-bottom: none; }
.cookie-consent-save-button { margin-top: 0.8rem; width: 100%; background: var(--color-primary); color: #FAF7F2; padding: 0.7rem; border-radius: var(--radius-md); font-weight: 600; font-size: 0.88rem; min-height: 44px; }


.tippy-box[data-theme~='custom'] {
  background-color: var(--color-ink-900); color: #FAF7F2; font-size: 0.85rem; border-radius: var(--radius-sm);
  box-shadow: var(--shadow-lg); padding: 0.2rem;
}
.tippy-box[data-theme~='custom'] .tippy-arrow { color: var(--color-ink-900); }


@media (max-width: 1024px) {
  .hero-content-grid { grid-template-columns: 1fr; }
  .asymmetric-split-container--60-40, .asymmetric-split-container--40-60, .asymmetric-split-container--55-45 { grid-template-columns: 1fr; }
  .asymmetric-split-image { order: -1; }
  .modular-cards-grid--varied { grid-template-columns: repeat(2, 1fr); }
  .module-card-item--large, .module-card-item--tall { grid-column: span 2; }
  .persona-cards-asymmetric-grid { grid-template-columns: repeat(2, 1fr); }
  .persona-card-item--wide { grid-column: span 2; }
  .footer-content-grid { grid-template-columns: 1fr 1fr; }
  .cta-asymmetric-container { grid-template-columns: 1fr; }
  .cta-image-block { order: -1; }
  .process-step-item, .process-step-item--offset { width: 100%; margin-left: 0; }
}

@media (max-width: 768px) {
  .primary-navigation-links { display: none; }
  .header-cta-button-with-dot span { display: none; }
  .header-cta-button-with-dot { padding: 0.8rem; }
  .header-cta-button-with-dot::before { content: '\f0e0'; font-family: 'Font Awesome 6 Free'; font-weight: 900; }
  .mobile-menu-toggle-button { display: flex; }
  .gallery-strip-asymmetric-grid, .office-gallery-asymmetric-grid { grid-template-columns: 1fr; }
  .footer-content-grid { grid-template-columns: 1fr; }
  .modular-cards-grid--varied { grid-template-columns: 1fr; }
  .module-card-item--large, .module-card-item--tall { grid-column: span 1; }
  .persona-cards-asymmetric-grid { grid-template-columns: 1fr; }
  .persona-card-item--wide { grid-column: span 1; }
  .homepage-hero-section { padding-top: 7rem; min-height: auto; }
  .content-module-section { padding: var(--space-xl) 1.2rem; }
  .cta-asymmetric-container { padding: var(--space-lg); }
  .cookie-consent-corner-modal { left: 0.7rem; bottom: 0.7rem; max-width: calc(100% - 1.4rem); }
}

@media (max-width: 480px) {
  .hero-headline-text { font-size: clamp(1.8rem, 8vw, 2.4rem); }
  .thanks-page-content-card { padding: 2.5rem 1.6rem; }
}