/*
 * MHS Child Theme – Custom CSS
 * Farben von mhs-service.eu (via TwentyTwentyFour theme.json)
 * Brand: #d8613c | Beige: #cfcabe | Dunkel: #1a1a1a
 * Fonts: Cardo (Headings) + Inter (Body)
 */

/* ── CSS Custom Properties ─────────────────────────────────────────────────── */

:root {
    --mhs-brand:        #d8613c;
    --mhs-brand-dark:   #b84d2c;
    --mhs-brand-light:  rgba(216, 97, 60, 0.08);
    --mhs-warm-beige:   #cfcabe;
    --mhs-warm-tan:     #c2a990;
    --mhs-sage:         #b1c5a4;
    --mhs-cool-gray:    #b5bdbc;
    --mhs-base:         #f9f9f9;
    --mhs-white:        #ffffff;
    --mhs-text:         #1a1a1a;
    --mhs-text-muted:   #636363;
    --mhs-text-light:   #a4a4a4;
    --mhs-border:       rgba(0, 0, 0, 0.08);
    --mhs-shadow-sm:    0 1px 8px rgba(0, 0, 0, 0.05);
    --mhs-shadow:       0 3px 20px rgba(0, 0, 0, 0.07);
    --mhs-shadow-lg:    0 8px 40px rgba(0, 0, 0, 0.12);
    --mhs-radius:       6px;
    --mhs-radius-lg:    12px;
    --mhs-radius-xl:    20px;
    --mhs-transition:   0.2s ease;
    --mhs-font-heading: "Cardo", Georgia, "Times New Roman", serif;
    --mhs-font-body:    "Inter", system-ui, -apple-system, sans-serif;
    --mhs-content-max:  1200px;
    --mhs-content-pad:  clamp(1.25rem, 5vw, 3rem);
}

/* ── Reset & Base ──────────────────────────────────────────────────────────── */

*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    font-family: var(--mhs-font-body);
    font-size: 1rem;
    line-height: 1.7;
    color: var(--mhs-text);
    background-color: var(--mhs-base);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

/* ── Typografie ────────────────────────────────────────────────────────────── */

h1, h2, h3, h4 {
    font-family: var(--mhs-font-heading);
    font-weight: 400;
    line-height: 1.2;
    letter-spacing: -0.01em;
    color: var(--mhs-text);
}

h1 { font-size: clamp(2.2rem, 5vw, 3.5rem); }
h2 { font-size: clamp(1.75rem, 3.5vw, 2.6rem); }
h3 { font-size: clamp(1.3rem, 2.5vw, 1.8rem); }
h4 { font-size: clamp(1.1rem, 2vw, 1.4rem); }

h5, h6 {
    font-family: var(--mhs-font-body);
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    font-size: 0.78rem;
    color: var(--mhs-text);
}

p {
    font-family: var(--mhs-font-body);
    line-height: 1.75;
    margin-bottom: 1rem;
}

p:last-child {
    margin-bottom: 0;
}

strong {
    font-weight: 600;
}

/* Eyebrow Label – z.B. über Sektionsüberschriften */
.mhs-eyebrow,
.wp-block-paragraph.is-style-eyebrow {
    font-family: var(--mhs-font-body);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--mhs-brand);
    display: block;
    margin-bottom: 0.6rem;
}

/* ── Header & Navigation ────────────────────────────────────────────────────── */

.wp-block-template-part[data-slug="header"],
header.wp-block-template-part {
    position: sticky;
    top: 0;
    z-index: 200;
    background-color: var(--mhs-white);
    border-bottom: 1px solid var(--mhs-border);
    box-shadow: var(--mhs-shadow-sm);
    transition: box-shadow var(--mhs-transition);
}

/* Header innerer Container – Padding reduzieren */
.wp-block-template-part[data-slug="header"] > .wp-block-group,
header.wp-block-template-part > .wp-block-group,
.wp-block-template-part[data-slug="header"] .wp-block-group:first-child {
    padding-top: 0.5rem !important;
    padding-bottom: 0.5rem !important;
    min-height: unset !important;
}

/* Header Row – vertikal zentriert */
.wp-block-template-part[data-slug="header"] .wp-block-group,
header.wp-block-template-part .wp-block-group {
    align-items: center !important;
}

/* Site Logo */
.wp-block-site-logo img {
    max-height: 48px !important;
    width: auto !important;
}

/* Logo-Block selbst: kein Extra-Abstand */
.wp-block-template-part[data-slug="header"] .wp-block-site-logo,
header.wp-block-template-part .wp-block-site-logo {
    margin: 0 !important;
    line-height: 1 !important;
}

/* Site Title */
.wp-block-site-title {
    margin: 0;
}

.wp-block-site-title a {
    font-family: var(--mhs-font-heading) !important;
    font-size: clamp(1rem, 2vw, 1.35rem) !important;
    font-weight: 700 !important;
    letter-spacing: -0.02em !important;
    color: var(--mhs-text) !important;
    text-decoration: none !important;
    transition: color var(--mhs-transition);
}

.wp-block-site-title a:hover {
    color: var(--mhs-brand) !important;
}

/* Navigation Menu */
.wp-block-navigation a:not(.wp-block-button__link) {
    font-family: var(--mhs-font-body) !important;
    font-size: 0.9rem !important;
    font-weight: 500 !important;
    letter-spacing: 0.02em !important;
    color: var(--mhs-text) !important;
    text-decoration: none !important;
    padding: 0.4rem 0.8rem !important;
    border-radius: 4px;
    transition: color var(--mhs-transition), background-color var(--mhs-transition);
}

.wp-block-navigation a:hover,
.wp-block-navigation .current-menu-item > a,
.wp-block-navigation .current-page-ancestor > a {
    color: var(--mhs-brand) !important;
    background-color: var(--mhs-brand-light) !important;
}

/* Mobile Navigation */
.wp-block-navigation__responsive-container-open svg,
.wp-block-navigation__responsive-container-close svg {
    fill: var(--mhs-text);
}

.wp-block-navigation__responsive-container.is-menu-open {
    background-color: var(--mhs-white) !important;
    padding: 1.5rem;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container {
    gap: 0.25rem;
}

/* ── Buttons ────────────────────────────────────────────────────────────────── */

.wp-block-button__link,
.wp-element-button,
a.wp-element-button,
input[type="submit"].wp-element-button {
    background-color: var(--mhs-brand) !important;
    color: var(--mhs-white) !important;
    border: none !important;
    border-radius: var(--mhs-radius) !important;
    padding: 0.875rem 2.25rem !important;
    font-family: var(--mhs-font-body) !important;
    font-weight: 600 !important;
    font-size: 0.85rem !important;
    letter-spacing: 0.07em !important;
    text-transform: uppercase !important;
    text-decoration: none !important;
    display: inline-block;
    transition: background-color var(--mhs-transition), transform var(--mhs-transition), box-shadow var(--mhs-transition) !important;
    cursor: pointer;
    line-height: 1.4 !important;
}

.wp-block-button__link:hover,
.wp-element-button:hover {
    background-color: var(--mhs-brand-dark) !important;
    color: var(--mhs-white) !important;
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(216, 97, 60, 0.28) !important;
    text-decoration: none !important;
}

.wp-block-button__link:active,
.wp-element-button:active {
    transform: translateY(0);
}

/* Outline-Variante */
.wp-block-button.is-style-outline .wp-block-button__link {
    background-color: transparent !important;
    color: var(--mhs-brand) !important;
    border: 2px solid var(--mhs-brand) !important;
}

.wp-block-button.is-style-outline .wp-block-button__link:hover {
    background-color: var(--mhs-brand) !important;
    color: var(--mhs-white) !important;
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(216, 97, 60, 0.28) !important;
}

/* ── Hero / Cover Block ─────────────────────────────────────────────────────── */

.wp-block-cover {
    min-height: 78vh !important;
}

.wp-block-cover .wp-block-cover__inner-container {
    width: 100%;
    max-width: 800px;
    margin: 0 auto;
    text-align: center;
    padding: 0 var(--mhs-content-pad);
}

.wp-block-cover h1,
.wp-block-cover .wp-block-heading {
    font-family: var(--mhs-font-heading) !important;
    font-weight: 400 !important;
    line-height: 1.12 !important;
    margin-bottom: 1.25rem !important;
}

.wp-block-cover p {
    font-size: clamp(1rem, 1.8vw, 1.2rem);
    line-height: 1.7;
    opacity: 0.92;
    margin-bottom: 2.5rem;
    max-width: 620px;
    margin-left: auto;
    margin-right: auto;
}

/* Overlay-Farbanpassung */
.wp-block-cover .wp-block-cover__background {
    opacity: 0.55 !important;
}

/* ── Sektionen / Gruppen ────────────────────────────────────────────────────── */

.wp-block-group.alignfull {
    padding-top: clamp(3rem, 6vw, 5.5rem);
    padding-bottom: clamp(3rem, 6vw, 5.5rem);
    padding-left: var(--mhs-content-pad);
    padding-right: var(--mhs-content-pad);
}

/* Innerer Container maximale Breite */
.wp-block-group .wp-block-group__inner-container,
.wp-block-group > .wp-block-columns,
.wp-block-group > .wp-block-group {
    max-width: var(--mhs-content-max);
    margin-left: auto;
    margin-right: auto;
    width: 100%;
}

/* Warm Beige Hintergrund */
.wp-block-group.has-accent-background-color,
.has-accent-background-color {
    background-color: var(--mhs-warm-beige) !important;
}

/* Salbei Hintergrund */
.wp-block-group.has-accent-4-background-color,
.has-accent-4-background-color {
    background-color: var(--mhs-sage) !important;
}

/* ── Service-Karten ─────────────────────────────────────────────────────────── */

.wp-block-columns.mhs-services {
    gap: 1.75rem !important;
    align-items: stretch;
}

.wp-block-columns.mhs-services .wp-block-column {
    display: flex;
    flex-direction: column;
}

/* Karte – auf jede Gruppe innerhalb einer Spalte anwenden */
.mhs-services .wp-block-column > .wp-block-group,
.wp-block-group.mhs-card {
    background-color: var(--mhs-white);
    border-radius: var(--mhs-radius-lg);
    padding: 2.25rem;
    box-shadow: var(--mhs-shadow);
    border-top: 4px solid var(--mhs-brand);
    transition: transform var(--mhs-transition), box-shadow var(--mhs-transition);
    flex: 1;
    display: flex;
    flex-direction: column;
}

.mhs-services .wp-block-column > .wp-block-group:hover,
.wp-block-group.mhs-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--mhs-shadow-lg);
}

.mhs-services .wp-block-column > .wp-block-group img,
.wp-block-group.mhs-card img {
    width: 60px;
    height: 60px;
    object-fit: contain;
    margin-bottom: 1.25rem;
}

.mhs-services .wp-block-column > .wp-block-group h3,
.wp-block-group.mhs-card h3 {
    font-size: 1.35rem;
    margin-bottom: 0.6rem;
    color: var(--mhs-text);
}

.mhs-services .wp-block-column > .wp-block-group p,
.wp-block-group.mhs-card p {
    color: var(--mhs-text-muted);
    font-size: 0.95rem;
    line-height: 1.7;
    flex: 1;
}

/* Dienstleistungs-Icon Wrapper */
.wp-block-image.mhs-service-icon img {
    width: 64px;
    height: 64px;
    object-fit: contain;
}

/* ── Features / Kernwerte ────────────────────────────────────────────────────── */

.wp-block-columns.mhs-features {
    gap: 2rem !important;
}

.wp-block-columns.mhs-features .wp-block-column {
    text-align: center;
    padding: 1.75rem 1rem;
    position: relative;
}

.wp-block-columns.mhs-features .wp-block-column::before {
    content: '';
    display: block;
    width: 40px;
    height: 3px;
    background-color: var(--mhs-brand);
    margin: 0 auto 1.25rem;
    border-radius: 2px;
}

.wp-block-columns.mhs-features img {
    width: 52px;
    height: 52px;
    margin: 0 auto 1rem;
    display: block;
    object-fit: contain;
}

.wp-block-columns.mhs-features h3,
.wp-block-columns.mhs-features h4 {
    font-family: var(--mhs-font-body);
    font-weight: 700;
    font-size: 0.9rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--mhs-text);
    margin-bottom: 0.6rem;
}

.wp-block-columns.mhs-features p {
    color: var(--mhs-text-muted);
    font-size: 0.9rem;
    line-height: 1.65;
    margin: 0;
}

/* ── Über Uns / Media-Text ────────────────────────────────────────────────────── */

.wp-block-media-text {
    gap: clamp(2rem, 5vw, 4.5rem) !important;
    align-items: center !important;
}

.wp-block-media-text .wp-block-media-text__media img {
    border-radius: var(--mhs-radius-lg);
    box-shadow: var(--mhs-shadow);
    width: 100%;
    height: auto;
    object-fit: cover;
}

.wp-block-media-text .wp-block-media-text__content {
    padding: 0 !important;
}

.wp-block-media-text .wp-block-media-text__content h2,
.wp-block-media-text .wp-block-media-text__content h3 {
    margin-bottom: 1rem;
}

.wp-block-media-text .wp-block-media-text__content p {
    color: var(--mhs-text-muted);
    line-height: 1.8;
}

/* ── Trennlinien ─────────────────────────────────────────────────────────────── */

.wp-block-separator {
    border-color: var(--mhs-border) !important;
    border-top-width: 1px !important;
    opacity: 1 !important;
    margin: 0 !important;
}

.wp-block-separator.has-accent-3-color {
    border-color: var(--mhs-brand) !important;
    border-top-width: 3px !important;
}

/* ── Zitat ────────────────────────────────────────────────────────────────────── */

blockquote,
.wp-block-quote {
    border-left: 4px solid var(--mhs-brand);
    padding: 1rem 1.5rem;
    margin: 1.5rem 0;
    background-color: var(--mhs-brand-light);
    border-radius: 0 var(--mhs-radius) var(--mhs-radius) 0;
}

blockquote p,
.wp-block-quote p {
    font-family: var(--mhs-font-heading);
    font-style: italic;
    font-size: 1.15rem;
    line-height: 1.65;
    color: var(--mhs-text);
    margin: 0;
}

.wp-block-quote cite,
.wp-block-quote .wp-block-quote__citation {
    font-family: var(--mhs-font-body);
    font-size: 0.85rem;
    font-style: normal;
    color: var(--mhs-text-muted);
    display: block;
    margin-top: 0.5rem;
}

/* ── Kontakt Bereich ─────────────────────────────────────────────────────────── */

.mhs-contact-block {
    background-color: var(--mhs-white);
    border-radius: var(--mhs-radius-lg);
    padding: 2.5rem;
    box-shadow: var(--mhs-shadow);
}

.mhs-contact-block a {
    color: var(--mhs-brand);
    text-decoration: none;
    font-weight: 500;
}

.mhs-contact-block a:hover {
    color: var(--mhs-brand-dark);
    text-decoration: underline;
}

/* ── Formular ────────────────────────────────────────────────────────────────── */

.wp-block-form input[type="text"],
.wp-block-form input[type="email"],
.wp-block-form input[type="tel"],
.wp-block-form textarea,
input[type="text"],
input[type="email"],
input[type="tel"],
textarea,
select {
    font-family: var(--mhs-font-body);
    font-size: 0.95rem;
    border: 1px solid rgba(0, 0, 0, 0.14);
    border-radius: var(--mhs-radius);
    padding: 0.8rem 1rem;
    width: 100%;
    background-color: var(--mhs-white);
    color: var(--mhs-text);
    transition: border-color var(--mhs-transition), box-shadow var(--mhs-transition);
    appearance: none;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
textarea:focus,
select:focus {
    outline: none;
    border-color: var(--mhs-brand);
    box-shadow: 0 0 0 3px rgba(216, 97, 60, 0.12);
}

input[type="submit"],
button[type="submit"] {
    background-color: var(--mhs-brand);
    color: var(--mhs-white);
    border: none;
    border-radius: var(--mhs-radius);
    padding: 0.875rem 2.25rem;
    font-family: var(--mhs-font-body);
    font-weight: 600;
    font-size: 0.85rem;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    cursor: pointer;
    transition: background-color var(--mhs-transition), transform var(--mhs-transition);
}

input[type="submit"]:hover,
button[type="submit"]:hover {
    background-color: var(--mhs-brand-dark);
    transform: translateY(-1px);
}

label {
    font-family: var(--mhs-font-body);
    font-weight: 600;
    font-size: 0.875rem;
    display: block;
    margin-bottom: 0.4rem;
    color: var(--mhs-text);
}

/* ── Newsletter ─────────────────────────────────────────────────────────────── */

.wp-block-search__input {
    font-family: var(--mhs-font-body) !important;
    border: 1px solid rgba(0, 0, 0, 0.14) !important;
    border-radius: var(--mhs-radius) 0 0 var(--mhs-radius) !important;
    padding: 0.75rem 1rem !important;
    font-size: 0.95rem !important;
}

.wp-block-search__button {
    background-color: var(--mhs-brand) !important;
    color: var(--mhs-white) !important;
    border: none !important;
    border-radius: 0 var(--mhs-radius) var(--mhs-radius) 0 !important;
    padding: 0.75rem 1.25rem !important;
    font-weight: 600 !important;
    font-size: 0.85rem !important;
    cursor: pointer;
    transition: background-color var(--mhs-transition);
}

.wp-block-search__button:hover {
    background-color: var(--mhs-brand-dark) !important;
}

/* ── Social Icons ────────────────────────────────────────────────────────────── */

.wp-block-social-links {
    gap: 0.6rem !important;
}

.wp-block-social-link a {
    padding: 0.5rem !important;
}

.wp-block-social-link {
    border-radius: 50% !important;
    transition: background-color var(--mhs-transition), transform var(--mhs-transition) !important;
}

.wp-block-social-link:hover {
    transform: translateY(-2px) !important;
}

/* Dunkler Footer: Social Icons heller */
.wp-block-template-part[data-slug="footer"] .wp-block-social-link,
footer .wp-block-social-link {
    background-color: rgba(255, 255, 255, 0.1) !important;
}

footer .wp-block-social-link:hover {
    background-color: var(--mhs-brand) !important;
}

footer .wp-block-social-link a,
footer .wp-block-social-link svg {
    color: var(--mhs-white) !important;
    fill: var(--mhs-white) !important;
}

/* ── Footer ──────────────────────────────────────────────────────────────────── */

.wp-block-template-part[data-slug="footer"],
footer.wp-block-template-part,
.site-footer {
    background-color: #1c1c1c !important;
    color: rgba(255, 255, 255, 0.75) !important;
    padding-top: clamp(2.5rem, 5vw, 4rem) !important;
    padding-bottom: clamp(1.5rem, 3vw, 2.5rem) !important;
}

.wp-block-template-part[data-slug="footer"] *,
footer.wp-block-template-part *,
.site-footer * {
    color: rgba(255, 255, 255, 0.75);
}

.wp-block-template-part[data-slug="footer"] h2,
.wp-block-template-part[data-slug="footer"] h3,
.wp-block-template-part[data-slug="footer"] h4,
.wp-block-template-part[data-slug="footer"] h5,
footer h2, footer h3, footer h4, footer h5 {
    color: var(--mhs-white) !important;
    font-family: var(--mhs-font-body) !important;
    font-weight: 700 !important;
    font-size: 0.75rem !important;
    letter-spacing: 0.15em !important;
    text-transform: uppercase !important;
    margin-bottom: 1.25rem !important;
}

.wp-block-template-part[data-slug="footer"] a,
footer a {
    color: rgba(255, 255, 255, 0.65) !important;
    text-decoration: none;
    font-size: 0.9rem;
    transition: color var(--mhs-transition);
}

.wp-block-template-part[data-slug="footer"] a:hover,
footer a:hover {
    color: var(--mhs-brand) !important;
}

.wp-block-template-part[data-slug="footer"] p,
footer p {
    font-size: 0.9rem;
    line-height: 1.65;
    color: rgba(255, 255, 255, 0.6) !important;
}

/* Footer Navigation List */
.wp-block-template-part[data-slug="footer"] .wp-block-navigation,
footer .wp-block-navigation {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.25rem;
}

.wp-block-template-part[data-slug="footer"] .wp-block-navigation a,
footer .wp-block-navigation a {
    padding: 0.2rem 0 !important;
    display: block;
}

/* Footer Copyright Linie */
.mhs-footer-bottom {
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    padding-top: 1.25rem;
    margin-top: 2.5rem;
}

/* Footer Logo */
.wp-block-template-part[data-slug="footer"] .wp-block-site-logo img,
footer .wp-block-site-logo img {
    max-height: 48px;
    width: auto;
    filter: brightness(0) invert(1);
    opacity: 0.85;
}

/* ── Breadcrumbs / Navigation ────────────────────────────────────────────────── */

.wp-block-post-navigation-link a {
    color: var(--mhs-brand);
    font-weight: 500;
    text-decoration: none;
    transition: color var(--mhs-transition);
}

.wp-block-post-navigation-link a:hover {
    color: var(--mhs-brand-dark);
    text-decoration: underline;
}

/* ── Seiten-Titel ────────────────────────────────────────────────────────────── */

.wp-block-post-title,
.entry-title {
    font-family: var(--mhs-font-heading);
    font-weight: 400;
    line-height: 1.15;
}

/* ── Bild Block ──────────────────────────────────────────────────────────────── */

.wp-block-image img {
    border-radius: var(--mhs-radius);
}

.wp-block-image.is-style-rounded img {
    border-radius: 50%;
}

/* ── Galerie ─────────────────────────────────────────────────────────────────── */

.wp-block-gallery .wp-block-image img {
    border-radius: var(--mhs-radius);
}

/* ── Tabellen ────────────────────────────────────────────────────────────────── */

.wp-block-table table {
    font-family: var(--mhs-font-body);
    border-collapse: collapse;
    width: 100%;
}

.wp-block-table th {
    background-color: var(--mhs-brand);
    color: var(--mhs-white);
    font-weight: 600;
    font-size: 0.85rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    padding: 0.75rem 1rem;
    text-align: left;
}

.wp-block-table td {
    padding: 0.75rem 1rem;
    border-bottom: 1px solid var(--mhs-border);
    font-size: 0.95rem;
}

.wp-block-table tr:nth-child(even) td {
    background-color: rgba(0, 0, 0, 0.02);
}

/* ── Listen ──────────────────────────────────────────────────────────────────── */

.wp-block-list,
ul:not([class]),
ol:not([class]) {
    padding-left: 1.5rem;
    line-height: 1.75;
}

.wp-block-list li,
ul:not([class]) li,
ol:not([class]) li {
    margin-bottom: 0.4rem;
    font-family: var(--mhs-font-body);
    font-size: 0.975rem;
}

/* Checkmark-Liste */
.wp-block-list.is-style-checkmark-list li,
.mhs-list-check li {
    list-style: none;
    padding-left: 1.75rem;
    position: relative;
}

.wp-block-list.is-style-checkmark-list li::before,
.mhs-list-check li::before {
    content: '✓';
    position: absolute;
    left: 0;
    color: var(--mhs-brand);
    font-weight: 700;
}

/* ── Utility Klassen ─────────────────────────────────────────────────────────── */

.mhs-text-brand  { color: var(--mhs-brand) !important; }
.mhs-bg-white    { background-color: var(--mhs-white) !important; }
.mhs-bg-beige    { background-color: var(--mhs-warm-beige) !important; }
.mhs-bg-dark     { background-color: #1c1c1c !important; color: var(--mhs-white) !important; }
.mhs-text-center { text-align: center; }
.mhs-text-muted  { color: var(--mhs-text-muted) !important; }
.mhs-mt-0  { margin-top: 0 !important; }
.mhs-mb-0  { margin-bottom: 0 !important; }

/* Brand-Linie unter Überschrift */
.mhs-has-line {
    position: relative;
    padding-bottom: 1rem;
}
.mhs-has-line::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 44px;
    height: 3px;
    background-color: var(--mhs-brand);
    border-radius: 2px;
}
.mhs-has-line.mhs-text-center::after {
    left: 50%;
    transform: translateX(-50%);
}

/* ── Responsive ──────────────────────────────────────────────────────────────── */

@media (max-width: 1024px) {
    .wp-block-columns.mhs-services {
        flex-wrap: wrap;
        gap: 1.25rem !important;
    }
    .wp-block-columns.mhs-services .wp-block-column {
        flex: 1 1 calc(50% - 1.25rem);
        min-width: 280px;
    }
}

@media (max-width: 768px) {
    .wp-block-cover {
        min-height: 60vh !important;
    }

    .wp-block-cover h1 {
        font-size: clamp(1.8rem, 8vw, 2.5rem) !important;
    }

    .wp-block-cover p {
        font-size: 1rem;
        margin-bottom: 2rem;
    }

    .wp-block-columns {
        flex-direction: column;
    }

    .wp-block-column {
        flex-basis: 100% !important;
        width: 100% !important;
        min-width: 100% !important;
    }

    .wp-block-media-text {
        grid-template-columns: 1fr !important;
    }

    .wp-block-media-text .wp-block-media-text__media {
        order: -1;
    }

    .wp-block-group.alignfull {
        padding-top: 2.5rem;
        padding-bottom: 2.5rem;
        padding-left: 1.25rem;
        padding-right: 1.25rem;
    }

    .mhs-services .wp-block-column > .wp-block-group,
    .wp-block-group.mhs-card {
        padding: 1.75rem;
    }
}

@media (max-width: 480px) {
    h1 { font-size: clamp(1.75rem, 9vw, 2.2rem); }
    h2 { font-size: clamp(1.4rem, 7vw, 1.85rem); }

    .wp-block-button__link,
    .wp-element-button {
        padding: 0.8rem 1.75rem !important;
        font-size: 0.8rem !important;
    }
}

/* ── Accessibility ───────────────────────────────────────────────────────────── */

a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible,
[tabindex]:focus-visible {
    outline: 2px solid var(--mhs-brand);
    outline-offset: 3px;
    border-radius: 2px;
}

.screen-reader-text {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border-width: 0;
}

/* Skip Link */
.skip-link:focus {
    position: fixed;
    top: 1rem;
    left: 1rem;
    z-index: 9999;
    background-color: var(--mhs-brand);
    color: var(--mhs-white);
    padding: 0.75rem 1.5rem;
    border-radius: var(--mhs-radius);
    font-weight: 600;
    font-size: 0.9rem;
    text-decoration: none;
}

/* =============================================================
   UNTERSEITEN PAGE-BANNER (Elementor-Seiten)
   Geprüfte Element-IDs (via curl + Elementor CSS):
     6f56534 = Über Uns      (post-51)
     8666048 = Kontakt       (post-60)
     a70d23e = Dienstleistungen (post-54)
     d3e38b4 = Dienstleistungen Detailliert (post-57)

   Was Elementor setzt (post-{id}.css):
     background-image: linear-gradient(210deg, #5846DF 38%, #0A122B 0%)
     margin-top: -135px  ← bleibt! kompensiert Sticky-Header-Höhe
     padding:  180px 0 100px 0  ← viel zu groß, wird reduziert

   Titel-Farbe (--e-global-color-cb5d53b = #FFFFFF) bleibt weiß.
   NUR Hintergrund, Padding und Akzentlinie werden geändert.
   ============================================================= */

/* ── Banner-Hintergrund & Padding ───────────────────────────── */

.elementor-element-6f56534,
.elementor-element-8666048,
.elementor-element-a70d23e,
.elementor-element-d3e38b4 {
    /* Dunkelblaues Gradient – passend zur Startseite */
    background-image:
        radial-gradient(ellipse at 70% 50%, rgba(88, 70, 223, 0.38) 0%, transparent 62%),
        linear-gradient(135deg, #0a0d1f 0%, #121640 60%, #1a1060 100%) !important;
    background-color: #0a0d1f !important;
    /* Padding reduziert: margin-top -135px bleibt, nur Größe schrumpft */
    padding-top:    160px !important;
    padding-bottom:  50px !important;
    /* Kein overflow:hidden – Inhalt muss sichtbar bleiben */
    position: relative !important;
}

/* ── Background-Overlay leise halten ───────────────────────── */
/* Elementor setzt hier Group-107.png als Textur (opacity 0.2–0.5).
   Wir reduzieren auf fast unsichtbar damit unser Gradient sauber wirkt. */
.elementor-element-6f56534 > .elementor-background-overlay,
.elementor-element-8666048 > .elementor-background-overlay,
.elementor-element-a70d23e > .elementor-background-overlay,
.elementor-element-d3e38b4 > .elementor-background-overlay {
    opacity: 0.06 !important;
}

/* ── Orangene Akzentlinie am unteren Rand ───────────────────── */

.elementor-element-6f56534::after,
.elementor-element-8666048::after,
.elementor-element-a70d23e::after,
.elementor-element-d3e38b4::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 56px;
    height: 3px;
    background-color: #d8613c;
    border-radius: 2px 2px 0 0;
}

/* ── Untertitel etwas gedämpfter ────────────────────────────── */
/* H1 = bereits #FFFFFF via --e-global-color-cb5d53b, bleibt unberührt.
   Nur der Untertitel (als <p> gerendert) wird leicht gedämpft.  */
.elementor-element-9cbbf62 .elementor-heading-title,
.elementor-element-38f9580 .elementor-heading-title {
    color: rgba(255, 255, 255, 0.72) !important;
}

/* ── Tablet ─────────────────────────────────────────────────── */
@media (max-width: 1024px) {
    .elementor-element-6f56534,
    .elementor-element-8666048,
    .elementor-element-a70d23e,
    .elementor-element-d3e38b4 {
        padding-top: 115px !important;
        padding-bottom:  40px !important;
    }
}

/* ── Mobile ─────────────────────────────────────────────────── */
@media (max-width: 767px) {
    .elementor-element-6f56534,
    .elementor-element-8666048,
    .elementor-element-a70d23e,
    .elementor-element-d3e38b4 {
        padding-top:  95px !important;
        padding-bottom: 30px !important;
    }
}

/* =============================================================
   HERO SECTION – Elementor (Startseite, post-48)
   Quellen: elementor/css/post-48.css, Hover-Farbe #5846DF
   dd419eb = Hero-Container | 2f780eb = H1
   ee38ff2 = Subtext      | ce37dfd = Button
   5f1bcbd = Bild-Spalte
   ============================================================= */

/* ── Lade-Animationen ───────────────────────────────────────── */

@keyframes mhs-fade-up {
    from { opacity: 0; transform: translateY(26px); }
    to   { opacity: 1; transform: translateY(0);    }
}

@keyframes mhs-fade-in {
    from { opacity: 0; }
    to   { opacity: 1; }
}

@keyframes mhs-slide-right {
    from { opacity: 0; transform: translateX(36px); }
    to   { opacity: 1; transform: translateX(0);    }
}

@keyframes mhs-shimmer {
    from { left: -100%; }
    to   { left: 160%;  }
}

/* ── Hero Container ─────────────────────────────────────────── */

.elementor-element-dd419eb {
    overflow: hidden !important;
    position: relative !important;
}

/* Subtile Tiefe: radiale Vignette ohne Elementor-Overlay zu stören */
.elementor-element-dd419eb > .elementor-background-overlay {
    opacity: 0.08 !important;
    background: radial-gradient(ellipse at 20% 50%, rgba(0,0,0,0) 55%, rgba(0,0,0,0.18) 100%) !important;
}

/* ── H1 – Überschrift ───────────────────────────────────────── */

.elementor-element-2f780eb {
    animation: mhs-fade-up 0.8s cubic-bezier(0.22, 1, 0.36, 1) 0.05s both;
}

.elementor-element-2f780eb .elementor-heading-title {
    font-family: var(--mhs-font-heading) !important;
    font-size: clamp(2rem, 4vw, 3.25rem) !important;
    font-weight: 400 !important;
    line-height: 1.1 !important;
    letter-spacing: -0.02em !important;
    text-shadow: 0 2px 24px rgba(0, 0, 0, 0.18) !important;
}

/* ── Subtext / Beschreibung ─────────────────────────────────── */

.elementor-element-ee38ff2 {
    animation: mhs-fade-up 0.8s cubic-bezier(0.22, 1, 0.36, 1) 0.2s both;
}

.elementor-element-ee38ff2 p,
.elementor-element-ee38ff2 .elementor-widget-container {
    font-size: clamp(0.95rem, 1.4vw, 1.1rem) !important;
    line-height: 1.8 !important;
    opacity: 0.92;
}

/* ── KONTAKTIEREN Button ────────────────────────────────────── */

.elementor-element-ce37dfd {
    animation: mhs-fade-up 0.8s cubic-bezier(0.22, 1, 0.36, 1) 0.35s both;
}

/* Weißer Button – maximaler Kontrast auf lila/blauem Hintergrund */
.elementor-element-ce37dfd .elementor-button {
    background-color: #ffffff !important;
    color: #3d2db8 !important;
    border: none !important;
    border-radius: 7px !important;
    padding: 1.05rem 2.75rem !important;
    font-family: var(--mhs-font-body) !important;
    font-weight: 700 !important;
    font-size: 0.88rem !important;
    letter-spacing: 0.09em !important;
    text-transform: uppercase !important;
    position: relative !important;
    overflow: hidden !important;
    box-shadow:
        0 6px 20px rgba(0, 0, 0, 0.22),
        0 2px 6px rgba(0, 0, 0, 0.14),
        inset 0 1px 0 rgba(255, 255, 255, 0.8) !important;
    transition:
        transform 0.22s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.22s ease,
        background-color 0.18s ease !important;
}

/* Shimmer beim Hover */
.elementor-element-ce37dfd .elementor-button::after {
    content: '';
    position: absolute !important;
    top: 0 !important;
    left: -120% !important;
    width: 55% !important;
    height: 100% !important;
    background: linear-gradient(
        90deg,
        transparent,
        rgba(255, 255, 255, 0.45),
        transparent
    ) !important;
    pointer-events: none !important;
    transition: none !important;
}

.elementor-element-ce37dfd .elementor-button:hover::after {
    animation: mhs-shimmer 0.55s ease forwards;
}

.elementor-element-ce37dfd .elementor-button:hover {
    background-color: #f2f2ff !important;
    color: #2d1fa8 !important;
    transform: translateY(-3px) !important;
    box-shadow:
        0 12px 32px rgba(0, 0, 0, 0.26),
        0 4px 10px rgba(0, 0, 0, 0.16) !important;
}

.elementor-element-ce37dfd .elementor-button:active {
    transform: translateY(-1px) !important;
    box-shadow:
        0 4px 14px rgba(0, 0, 0, 0.2),
        0 2px 6px rgba(0, 0, 0, 0.12) !important;
}

.elementor-element-ce37dfd .elementor-button-text {
    position: relative !important;
    z-index: 1 !important;
}

/* ── Laptop-Bilder (Bild-Spalte) ────────────────────────────── */

.elementor-element-5f1bcbd {
    animation: mhs-slide-right 1s cubic-bezier(0.22, 1, 0.36, 1) 0.15s both;
}

/* Drop-Shadow für Tiefe */
.elementor-element-5f1bcbd .elementor-widget-image img,
.elementor-element-5f1bcbd img {
    filter:
        drop-shadow(0 24px 48px rgba(0, 0, 0, 0.24))
        drop-shadow(0 8px 16px rgba(0, 0, 0, 0.14)) !important;
    transition:
        transform 0.5s cubic-bezier(0.22, 1, 0.36, 1),
        filter 0.4s ease !important;
    will-change: transform;
}

.elementor-element-5f1bcbd:hover img {
    transform: translateY(-8px) !important;
    filter:
        drop-shadow(0 36px 60px rgba(0, 0, 0, 0.3))
        drop-shadow(0 12px 22px rgba(0, 0, 0, 0.18)) !important;
}

/* ── Mobile Hero (max 767px) ────────────────────────────────── */

@media (max-width: 767px) {

    /* Bilder unter den Text */
    .elementor-element-5f1bcbd {
        order: 2 !important;
    }

    /* Spalte mit Bild ans Ende */
    .elementor-element-dd419eb .elementor-column:has(.elementor-element-5f1bcbd),
    .elementor-element-dd419eb .e-con:has(.elementor-element-5f1bcbd) {
        order: 2 !important;
    }

    /* Spalte mit Text nach vorne */
    .elementor-element-dd419eb .elementor-column:has(.elementor-element-2f780eb),
    .elementor-element-dd419eb .e-con:has(.elementor-element-2f780eb) {
        order: 1 !important;
    }

    /* H1 mobil: größer + zentriert */
    .elementor-element-2f780eb .elementor-heading-title {
        font-size: clamp(1.8rem, 9vw, 2.5rem) !important;
        text-align: center !important;
        line-height: 1.15 !important;
    }

    /* Subtext zentriert */
    .elementor-element-ee38ff2,
    .elementor-element-ee38ff2 .elementor-widget-container {
        text-align: center !important;
    }

    /* Button zentriert */
    .elementor-element-ce37dfd {
        text-align: center !important;
    }

    .elementor-element-ce37dfd .elementor-button {
        padding: 0.95rem 2.25rem !important;
        font-size: 0.85rem !important;
    }

    /* Laptop-Bild mobile: kleiner, zentriert */
    .elementor-element-5f1bcbd .elementor-widget-image {
        text-align: center !important;
    }

    .elementor-element-5f1bcbd img {
        max-width: 80% !important;
        margin: 0 auto !important;
        display: block !important;
    }
}

/* ── Print ────────────────────────────────────────────────────────────────────── */

@media print {
    header,
    footer,
    .wp-block-navigation,
    .wp-block-button,
    nav {
        display: none !important;
    }

    body {
        font-size: 12pt;
        color: #000;
        background: #fff;
    }

    a {
        color: #000 !important;
        text-decoration: underline;
    }

    h1, h2, h3 {
        page-break-after: avoid;
    }

    img {
        max-width: 100%;
        page-break-inside: avoid;
    }
}
