/* === GLOBAL BASE STYLES (FORCED) === */

* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  scroll-behavior: smooth;
}

main {
  max-width: 1600px;
  margin-inline: auto;
  width: 100%;
}

.container {
  margin-inline: auto;
}

body {
  overflow-x: hidden;
}

/* Über Uns: avoid horizontal scroll on tablet from rotated/bleed decor and wide grids */
html[data-page="uber-uns.html"] main {
  overflow-x: clip;
}

html[data-page="index.html"] main {
  overflow-x: clip;
}

section {
  width: 100%;
}

.utility-shell {
  width: min(980px, calc(100% - 24px));
  margin: 0 auto;
  padding: 28px 0 56px;
}

.utility-page--with-header .utility-shell {
  padding-top: calc(
    28px +
    var(
      --utility-chrome-offset,
      calc(var(--spacing-6, 48px) + var(--spacing-4, 32px))
    )
  );
}

@media (max-width: 720px) {
  .utility-shell {
    width: min(100% - 16px, 980px);
    padding-top: 16px;
    padding-bottom: 36px;
  }

  .utility-page--with-header .utility-shell {
    padding-top: calc(
      16px +
      var(
        --utility-chrome-offset-mobile,
        calc(var(--spacing-4, 32px) + var(--spacing-3, 24px))
      )
    );
  }
}

/* --- SVG icons (local sprite) --- */
.icon {
  width: 1.25rem;
  height: 1.25rem;
  display: inline-block;
  vertical-align: middle;
  flex: 0 0 auto;
}

/* g2 palette ssot start */
:root {
  --g2-palette-dark: #172033;
  --g2-palette-light: #f5efe5;
  --g2-palette-accent: #1d6b62;
  --g2-palette-text: #172033;
  --g2-color-primary: var(--g2-palette-accent);
  --g2-color-accent: var(--g2-palette-accent);
  --g2-color-text: var(--g2-palette-text);
}
/* g2 palette ssot end */

/* --- Contact: text-base + safe wrap (narrow columns / long mailto & map URLs) --- */
.site-mobileNav__contact,
.site-footer__contact {
  min-width: 0;
}

.site-mobileNav__contact a,
.site-footer__contactLink {
  font-size: 1rem;
  line-height: 1.5rem;
  max-width: 100%;
  overflow-wrap: anywhere;
}

.site-mobileNav__contact a[href^="mailto:"],
.site-footer__contactLink[href^="mailto:"] {
  word-break: break-all;
}

.utility-prose a[href^="mailto:"] {
  font-size: 1rem;
  line-height: 1.5rem;
  overflow-wrap: anywhere;
  word-break: break-all;
}

.utility-prose a[href^="tel:"],
.utility-prose a[href*="google.com/maps"],
.utility-prose a[href*="goo.gl/"] {
  font-size: 1rem;
  line-height: 1.5rem;
  overflow-wrap: anywhere;
}

/* Main pages: Kontakt rows (Tailwind columns beside forms) */
.site-contact-block {
  min-width: 0;
}

.site-contact-block > .flex,
.site-contact-block > a.flex {
  min-width: 0;
}

.site-contact-block > .flex > div:last-child,
.site-contact-block > a.flex > div:last-child {
  min-width: 0;
}

.site-contact-block a[href^="mailto:"],
.site-contact-block a[href^="tel:"],
.site-contact-block a[href^="https:"] {
  font-size: 1rem;
  line-height: 1.5rem;
  overflow-wrap: anywhere;
}

.site-contact-block a[href^="mailto:"] {
  word-break: break-all;
}

/* Footer: legal document links stack on narrow viewports */
@media (max-width: 640px) {
  .site-footer__legal-links {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
    width: 100%;
  }
}
