/* ======================================================
   styles.css
   Konsolidierte WordPress Basis
====================================================== */

/*
   Hinweis:
   Wiederkehrende Layoutregeln fuer Leistungsseiten liegen in
   assets/css/service-pages.css. Diese Datei bleibt fuer globale
   Basis-, Header-, Navigations- und Startseitenregeln zustaendig.
*/

:root {

    --navy: #0d2948;
    --navy-2: #13355b;

    --ivory: #f7f2ea;
    --ivory-2: #fbf8f2;

    --sand: #f2eadf;

    --brass: #b8873b;

    --ink: #1f1f1d;
    --ink-soft: #3e3a35;

    --muted: #6a635b;

    --line: rgba(38,35,29,.1);

    --shadow-soft:
        0 14px 35px rgba(13,41,72,.06);

    --shadow-deep:
        0 28px 60px rgba(13,41,72,.12);

    --radius-xl: 32px;
    --radius-lg: 22px;

    --container: 1240px;

    --header-open: 118px;
    --header-compact: 82px;
}

/* ======================================================
   RESET
====================================================== */

* {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {

    margin: 0;

    font-family:
        "Inter",
        system-ui,
        sans-serif;

    background: var(--ivory);

    color: var(--ink);

    line-height: 1.72;

    -webkit-font-smoothing: antialiased;

    text-rendering: optimizeLegibility;
}

body.nav-open {
    overflow: hidden;
}

a {
    color: inherit;
    text-decoration: none;
}

img {
    display: block;
    max-width: 100%;
}

button {
    font: inherit;
}

ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.container {

    width:
        min(calc(100% - 48px), var(--container));

    margin-inline: auto;
}

/* ======================================================
   TYPOGRAPHY
====================================================== */

h1,
h2,
h3 {

    margin: 0;

    font-family:
        "Cormorant Garamond",
        Georgia,
        serif;

    font-weight: 600;

    line-height: 1.05;

    letter-spacing: -.02em;

    color: var(--ink);
}

h1 {
    font-size: clamp(2rem, 3.5vw, 3.4rem);
}

h2 {
    font-size: clamp(2rem, 3vw, 3rem);
}

h3 {
    font-size: clamp(1.4rem, 2vw, 2rem);
}

p {
    margin: 0;
    color: var(--muted);
}

p + p {
    margin-top: 1rem;
}

/* ======================================================
   BUTTONS
====================================================== */

.btn {

    display: inline-flex;

    align-items: center;
    justify-content: center;

    gap: .6rem;

    padding: .84rem 1.12rem;

    border-radius: 12px;

    border: 1px solid var(--navy);

    background: var(--navy);

    color: #fff;

    font-size: .9rem;
    font-weight: 700;

    line-height: 1;

    transition:
        transform .18s ease,
        background .18s ease;
}

.btn:hover {

    transform: translateY(-1px);

    background: var(--navy-2);
}

/* ======================================================
   HEADER
====================================================== */

.site-header {

    position: sticky;
    top: 0;

    z-index: 1000;

    background:
        rgba(247,242,234,.92);

    border-bottom:
        1px solid rgba(31,31,29,.08);

    backdrop-filter: blur(18px);

    transition:
        background .25s ease,
        box-shadow .25s ease;
}

body.scrolled .site-header {

    background:
        rgba(247,242,234,.96);

    box-shadow:
        0 14px 30px rgba(13,41,72,.07);
}

.header-inner {

    min-height: var(--header-open);

    display: grid;

    grid-template-columns:
        auto
        1fr
        auto;

    align-items: center;

    gap: clamp(1.5rem, 3vw, 3rem);

    transition:
        min-height .28s ease;
}

body.scrolled .header-inner {
    min-height: var(--header-compact);
}

/* ======================================================
   NAVIGATION
====================================================== */

.main-nav {
    justify-self: center;
}

.nav-list {

    display: flex;

    align-items: center;

    gap: .1rem;
}

.nav-item {
    position: relative;
}

.nav-link {

    position: relative;

    display: inline-flex;

    align-items: center;
    gap: .35rem;

    border: 0;

    background: transparent;

    color: var(--ink);

    padding:
        .82rem
        .78rem;

    border-radius: 12px;

    font-weight: 600;

    cursor: pointer;

    transition:
        color .2s ease,
        background .2s ease;

    white-space: nowrap;
}

.nav-link:hover,
.nav-item:hover > .nav-link,
.nav-item.is-open > .nav-link {

    color: var(--navy);

    background:
        rgba(13,41,72,.04);
}

.nav-chevron {

    width: .82rem;
    height: .82rem;

    transition:
        transform .2s ease;
}

.nav-item.is-open .nav-chevron {
    transform: rotate(180deg);
}

/* ======================================================
   DROPDOWNS
====================================================== */

.dropdown {

    position: absolute;
    top: calc(100% + 10px);
    left: 0;

    min-width: 0 !important;
    width: auto !important;
    max-width: 240px !important;
    white-space: normal !important;

    padding: .35rem .4rem;

    background: rgba(255,255,255,.98);
    border: 1px solid rgba(31,31,29,.08);
    border-radius: 16px;
    box-shadow: var(--shadow-deep);

    opacity: 0;
    visibility: hidden;
    transform: translateY(8px);
    pointer-events: none;

    transition: opacity .2s ease, visibility .2s ease, transform .2s ease;
    z-index: 100;
}


.dropdown-grid {

    display: flex;

    flex-direction: column;

}

.dropdown--narrow .dropdown-grid {
    grid-template-columns: 1fr;
}

.dropdown a {

    display: inline-flex;

    align-items: center;

    padding:
        .45rem
        .55rem;

    border-radius: 10px;

    font-weight: 600;

    line-height: 1.18;

    color: var(--ink-soft);

    white-space: normal;

    transition:
        background .2s ease,
        color .2s ease;
}

.dropdown a:hover {

    background:
        rgba(13,41,72,.045);

    color: var(--navy);
}

.nav-item.is-open .dropdown {

    opacity: 1;

    visibility: visible;

    transform: translateY(0);

    pointer-events: auto;
}

/* ======================================================
   HEADER ACTIONS
====================================================== */

.header-actions {

    display: flex;

    align-items: center;

    gap: .8rem;
}

/* ======================================================
   MOBILE MENU BUTTON
====================================================== */

.menu-toggle {

    display: none;

    width: 46px;
    height: 46px;

    border: 0;

    border-radius: 14px;

    background: #fff;

    box-shadow: var(--shadow-soft);

    position: relative;

    cursor: pointer;
}

.menu-toggle span {

    position: absolute;

    left: 12px;
    right: 12px;

    height: 2px;

    background: var(--navy);

    border-radius: 999px;

    transition:
        transform .22s ease,
        opacity .22s ease;
}

.menu-toggle span:nth-child(1) {
    top: 15px;
}

.menu-toggle span:nth-child(2) {
    top: 22px;
}

.menu-toggle span:nth-child(3) {
    top: 29px;
}

body.nav-open .menu-toggle span:nth-child(1) {

    transform:
        translateY(7px)
        rotate(45deg);
}

body.nav-open .menu-toggle span:nth-child(2) {
    opacity: 0;
}

body.nav-open .menu-toggle span:nth-child(3) {

    transform:
        translateY(-7px)
        rotate(-45deg);
}

/* ======================================================
   HERO
====================================================== */

.hero {

    padding:
        1.2rem 0 4rem;

    background:
        linear-gradient(
            180deg,
            rgba(247,242,234,1) 0%,
            rgba(247,242,234,.94) 100%
        );
}

.hero-stage {

    position: relative;

    border-radius: var(--radius-xl);

    overflow: hidden;

    box-shadow: var(--shadow-deep);

    background: transparent;
}

.hero-image {
    margin: 0;
}

.hero-image img {

    width: 100%;

    height:
        min(760px,
        calc(100vh - var(--header-open) - 24px));

    min-height: 640px;

    object-fit: contain;

    object-position: center right;

    background:
        linear-gradient(
            180deg,
            #f1e8dc 0%,
            #f8f4ed 100%
        );
}

.hero-stage::after {

    content: "";

    position: absolute;

    inset: 0;

    background:
        linear-gradient(
            90deg,
            rgba(247,242,234,.82) 0%,
            rgba(247,242,234,.68) 28%,
            rgba(247,242,234,.38) 46%,
            rgba(247,242,234,.10) 66%,
            rgba(247,242,234,0) 82%
        );
}

.hero-overlay {

    position: absolute;

    left:
        clamp(2rem, 5vw, 4.25rem);

    top: 50%;

    transform: translateY(-50%);

    z-index: 2;

    width:
        min(520px, calc(100% - 3rem));
}

.hero-overline {

    margin-bottom: 1rem;

    font-size: .78rem;

    font-weight: 800;

    letter-spacing: .17em;

    text-transform: uppercase;

    color: var(--brass);
}

.hero-text {

    max-width: 43ch;

    margin-top: 1.1rem;

    color: var(--ink-soft);

    font-size: 1.05rem;
}

.button-row {

    display: flex;

    flex-wrap: wrap;

    gap: .9rem;

    margin-top: 1.9rem;
}

/* ======================================================
   MOBILE
====================================================== */

@media (max-width: 1180px) {

    .menu-toggle {
        display: block;
    }

    .main-nav {

        position: fixed;

        top:
            calc(var(--header-compact) + 12px);

        left: 16px;
        right: 16px;

        max-height:
            calc(100vh - var(--header-compact) - 28px);

        overflow: auto;

        padding: .9rem;

        border-radius: 22px;

        border:
            1px solid var(--line);

        background:
            rgba(255,255,255,.98);

        box-shadow: var(--shadow-deep);

        opacity: 0;

        visibility: hidden;

        pointer-events: none;

        transform: translateY(-8px);

        transition:
            opacity .22s ease,
            visibility .22s ease,
            transform .22s ease;
    }

    body.nav-open .main-nav {

        opacity: 1;

        visibility: visible;

        pointer-events: auto;

        transform: translateY(0);
    }

    .nav-list {

        display: grid;

        gap: .2rem;
    }

    .nav-link {

        width: 100%;

        justify-content: space-between;
    }

    .dropdown {

        position: static;

        width: 100%;

        margin-top: .35rem;

        padding: .55rem;

        border-radius: 16px;

        box-shadow: none;

        display: none;

        opacity: 1;

        visibility: visible;

        transform: none;

        pointer-events: auto;

        background:
            rgba(13,41,72,.025);
    }

    .nav-item.is-open .dropdown {
        display: block;
    }

    .dropdown-grid,
    .dropdown--narrow .dropdown-grid {

        grid-template-columns: 1fr;
    }

    .benefit-grid .mini-card h3 {

        font-size: 1.42rem;
    }
}

@media (max-width: 760px) {

    .container {

        width:
            min(calc(100% - 28px), var(--container));
    }

    .header-inner {

        grid-template-columns:
            1fr auto;

        min-height: var(--header-compact);
    }

    .hero-overlay {

        position: relative;

        left: auto;
        right: auto;
        top: auto;

        transform: none;

        width: auto;

        padding:
            1.2rem
            1.1rem
            1.4rem;

        margin-top: -10px;
    }

    .hero-image img {

        width: 100%;

        height: auto;

        min-height: 0;
    }

    .button-row {
        flex-direction: column;
    }

    .button-row .btn {
        width: 100%;
    }

}
/* ======================================================
   SECTION
   Steuerberatung und Steuerrecht gehören zusammen
====================================================== */

.section {

    padding:
        clamp(5rem, 8vw, 7rem)
        0;
}

.section-light {

    background:
        linear-gradient(
            180deg,
            rgba(255,255,255,.82),
            rgba(255,255,255,.82)
        ),
        var(--ivory-2);
}

/* =========================================
   SECTION HEADINGS
========================================= */

.section-heading {

    max-width: 940px;

    margin:
        0 auto 3rem;
}

.section-heading.centered {
    text-align: center;
}

.section-heading.narrow {
    max-width: 840px;
}

.section-heading h2 {

    margin-bottom: 1rem;
}

.section-heading p {

    font-size: 1.04rem;

    color: var(--muted);
}

/* =========================================
   BENEFITS GRID
========================================= */

.benefit-grid {

    display: grid;

    grid-template-columns:
        repeat(4,minmax(0,1fr));

    gap: 1.15rem;
}

/* =========================================
   CARDS
========================================= */

.mini-card {

    padding: 1.7rem;

    background:
        rgba(255,255,255,.86);

    border:
        1px solid var(--line);

    border-radius: var(--radius-lg);

    box-shadow: var(--shadow-soft);

    transition:
        transform .18s ease,
        box-shadow .18s ease,
        border-color .18s ease;
}

.mini-card:hover {

    transform: translateY(-3px);

    border-color:
        rgba(184,135,59,.35);

    box-shadow: var(--shadow-deep);
}

.mini-card h3 {

    margin-bottom: .75rem;

    font-size:
        clamp(1.35rem, 1.7vw, 1.8rem);

    line-height: 1.12;
}

.mini-card p {

    color: var(--muted);

    line-height: 1.65;
}

/* =========================================
   RESPONSIVE
========================================= */

@media (max-width: 980px) {

    .benefit-grid {

        grid-template-columns:
            repeat(2,minmax(0,1fr));
    }
}

@media (max-width: 760px) {

    .section {

        padding:
            4rem 0;
    }

    .benefit-grid {

        grid-template-columns: 1fr;
    }

    .mini-card {

        padding: 1.5rem;
    }

}
/* =========================================
   ICONS
========================================= */

.line-icon {

    width: 56px;
    height: 56px;

    display: grid;

    place-items: center;

    margin-bottom: 1rem;

    border-radius: 18px;

    background:
        rgba(184,135,59,.09);

    color: var(--brass);
}

.line-icon svg {

    width: 30px;
    height: 30px;
}
/* ======================================================
   ANLIEGEN / LEISTUNGEN
====================================================== */

.section-contrast {

    background:
        radial-gradient(
            circle at 84% 12%,
            rgba(184,135,59,.07),
            transparent 24%
        ),
        linear-gradient(
            180deg,
            #f8f2ea 0%,
            #f2e8dc 100%
        );
}

/* =========================================
   SERVICE GRID
========================================= */

.service-grid {

    display: grid;

    grid-template-columns:
        repeat(3,minmax(0,1fr));

    gap: 1.15rem;
}

/* =========================================
   SERVICE CARDS
========================================= */

.service-card {
    min-height: 100%;

    display: flex;

    flex-direction: column;

    padding: 1.7rem;

    background:
        rgba(255,255,255,.86);

    border:
        1px solid var(--line);

    border-radius: var(--radius-lg);

    box-shadow: var(--shadow-soft);

    transition:
        transform .18s ease,
        box-shadow .18s ease,
        border-color .18s ease;
}

.service-card:hover {

    transform: translateY(-3px);

    border-color:
        rgba(184,135,59,.35);

    box-shadow: var(--shadow-deep);
}

.service-card h3 {

    margin-bottom: .35rem;
}

.service-card h4 {

    margin:
        .15rem 0 .8rem;

    font-size: .98rem;

    line-height: 1.45;

    color: var(--ink-soft);

    font-weight: 700;
}

.service-card p {

    color: var(--muted);

    line-height: 1.7;
}

.service-card .btn {

    margin-top: auto;

    align-self: flex-start;
}

/* =========================================
   RESPONSIVE
========================================= */

@media (max-width: 1040px) {

    .service-grid {

        grid-template-columns:
            repeat(2,minmax(0,1fr));
    }
}

@media (max-width: 760px) {

    .service-grid {

        grid-template-columns: 1fr;
    }

    .service-card {

        padding: 1.5rem;
    }

}
/* ======================================================
   IMMOBILIEN / GESTALTUNG
====================================================== */

.split-grid {

    display: grid;

    grid-template-columns:
        1fr
        1fr;

    gap: clamp(2rem, 6vw, 4rem);

    align-items: center;
}

.content-col h2 {

    margin-bottom: 1.6rem;
}

.content-col p {

    max-width: 62ch;
}

/* =========================================
   IMAGE PANEL
========================================= */

.statement-image {

    margin: 0;

    display: flex;

    align-items: center;
    justify-content: center;

    overflow: hidden;

    border-radius: var(--radius-xl);

    background:
        linear-gradient(
            180deg,
            #f1e8dc 0%,
            #f8f4ed 100%
        );

    border:
        1px solid var(--line);

    box-shadow: var(--shadow-soft);
}

.statement-image img {

    width: 100%;

    height: auto;

    object-fit: contain;

    object-position: center;
}

/* ======================================================
   SAND SECTION
====================================================== */

.section-sand {

    background:
        linear-gradient(
            180deg,
            #f1e8dc 0%,
            #fbf8f2 100%
        );
}

/* ======================================================
   RESPONSIVE
====================================================== */

@media (max-width: 1040px) {

    .split-grid {

        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {

    .statement-image {

        padding: .5rem;
    }
}
/* =========================================
   WIDE CARD
========================================= */

.service-card-wide {

    grid-column: 2 / 4;
}

/* =========================================
   RESPONSIVE
========================================= */

@media (max-width: 1040px) {

    .service-card-wide {

        grid-column: auto;
    }
}
/* ======================================================
   FÜR WEN WIR ARBEITEN
====================================================== */

.section-sand {

    background:
        linear-gradient(
            180deg,
            #f1e8dc 0%,
            #fbf8f2 100%
        );
}
/* ======================================================
   TARGET GROUP CARDS FIX
====================================================== */

.benefit-grid .mini-card {
    min-width: 0;
}

.benefit-grid .mini-card h3 {

    font-size:
        clamp(1.22rem, 1.55vw, 1.7rem);

    line-height: 1.12;

    overflow-wrap: anywhere;

    hyphens: auto;

    max-width: 100%;
}
/* ======================================================
   UNSERE BERATUNGSBEREICHE
====================================================== */

.area-grid {

    display: grid;

    grid-template-columns:
        repeat(2,minmax(0,1fr));

    gap: 1.4rem;
}

/* =========================================
   AREA CARDS
========================================= */

.area-card {

    display: flex;

    flex-direction: column;

    padding: 2rem;

    background:
        rgba(255,255,255,.86);

    border:
        1px solid var(--line);

    border-radius: var(--radius-xl);

    box-shadow: var(--shadow-soft);

    transition:
        transform .18s ease,
        box-shadow .18s ease,
        border-color .18s ease;
}

.area-card:hover {

    transform: translateY(-3px);

    border-color:
        rgba(184,135,59,.35);

    box-shadow: var(--shadow-deep);
}

.area-card h3 {

    margin-bottom: .9rem;

    font-size:
        clamp(1.7rem, 2.4vw, 2.3rem);

    line-height: 1.04;
}

.area-card p {

    color: var(--muted);

    line-height: 1.7;
}

/* =========================================
   LINK LIST
========================================= */

.link-list {

    display: grid;

    gap: .65rem;

    margin:
        1.4rem 0;
}

.link-list a {

    display: inline-flex;

    align-items: center;

    gap: .55rem;

    color: var(--ink-soft);

    font-weight: 600;

    transition:
        color .2s ease,
        transform .2s ease;
}

.link-list a::before {

    content: "›";

    color: var(--brass);

    font-weight: 800;
}

.link-list a:hover {

    color: var(--navy);

    transform: translateX(2px);
}

/* =========================================
   BUTTONS
========================================= */

.area-card .btn {

    margin-top: auto;

    align-self: flex-start;
}

/* =========================================
   RESPONSIVE
========================================= */

@media (max-width: 1040px) {

    .area-grid {

        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {

    .area-card {

        padding: 1.6rem;
    }

    .area-card h3 {

        font-size: 1.9rem;
    }
}
/* ======================================================
   WIE WIR BERATEN
====================================================== */

.process-grid {

    display: grid;

    grid-template-columns:
        repeat(3,minmax(0,1fr));

    gap: 1.2rem;
}

/* =========================================
   PROCESS STEP
========================================= */

.process-step {

    text-align: center;

    padding:
        2rem
        1.5rem;

    background:
        rgba(255,255,255,.78);

    border:
        1px solid var(--line);

    border-radius: var(--radius-lg);

    box-shadow: var(--shadow-soft);

    transition:
        transform .18s ease,
        box-shadow .18s ease,
        border-color .18s ease;
}

.process-step:hover {

    transform: translateY(-3px);

    border-color:
        rgba(184,135,59,.35);

    box-shadow: var(--shadow-deep);
}

/* =========================================
   NUMBER
========================================= */

.process-step span {

    width: 54px;
    height: 54px;

    display: grid;

    place-items: center;

    margin:
        0 auto 1rem;

    border-radius: 50%;

    background: var(--navy);

    color: #fff;

    font-weight: 800;

    font-size: 1rem;
}

/* =========================================
   TYPO
========================================= */

.process-step h3 {

    margin-bottom: .7rem;

    line-height: 1.12;
}

.process-step p {

    color: var(--muted);

    line-height: 1.7;
}

/* =========================================
   RESPONSIVE
========================================= */

@media (max-width: 1040px) {

    .process-grid {

        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {

    .process-step {

        padding:
            1.7rem
            1.3rem;
    }
}
/* ======================================================
   SCHWERPUNKT IMMOBILIENBESTEUERUNG
====================================================== */

.realestate-panel {

    display: grid;

    grid-template-columns:
        1fr
        .9fr;

    gap: clamp(2rem, 5vw, 4rem);

    padding:
        clamp(2rem, 4vw, 3rem);

    background:
        radial-gradient(
            circle at 16% 16%,
            rgba(184,135,59,.08),
            transparent 23%
        ),
        linear-gradient(
            180deg,
            #fff,
            #fbf8f2
        );

    border-radius: var(--radius-xl);

    border:
        1px solid var(--line);

    box-shadow: var(--shadow-soft);
}

/* =========================================
   TEXT
========================================= */

.realestate-panel h2 {

    margin-bottom: 1.35rem;
}

.realestate-panel p {

    max-width: 62ch;

    line-height: 1.75;
}

.realestate-panel p + p {

    margin-top: 1rem;
}

.realestate-panel .btn {

    margin-top: 1.7rem;
}

/* =========================================
   LINK PANEL
========================================= */

.link-list-panel {

    display: grid;

    gap: .75rem;
}

.link-list-panel a {

    width: 100%;

    padding:
        .82rem
        1rem;

    border-radius: 14px;

    background:
        rgba(13,41,72,.035);

    border:
        1px solid rgba(13,41,72,.05);

    transition:
        background .2s ease,
        border-color .2s ease,
        transform .2s ease;
}

.link-list-panel a:hover {

    background:
        rgba(13,41,72,.06);

    border-color:
        rgba(184,135,59,.3);

    transform: translateX(2px);
}

/* =========================================
   RESPONSIVE
========================================= */

@media (max-width: 1040px) {

    .realestate-panel {

        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {

    .realestate-panel {

        padding:
            1.6rem;
    }
}
/* ======================================================
   STEUERLICHE KONFLIKTE
====================================================== */

.section-navy {

    background:
        radial-gradient(
            circle at 10% 18%,
            rgba(184,135,59,.16),
            transparent 24%
        ),
        linear-gradient(
            135deg,
            #081b2c 0%,
            #0b2741 52%,
            #071521 100%
        );

    color: #fff;
}

.section-navy h2,
.section-navy h3,
.section-navy p {

    color: #fff;
}

/* =========================================
   GRID
========================================= */

.conflict-grid {

    display: grid;

    grid-template-columns:
        1fr
        auto;

    gap: clamp(2rem, 5vw, 4rem);

    align-items: end;
}

/* =========================================
   TYPO
========================================= */

.conflict-grid h2 {

    margin-bottom: 1.4rem;
}

.conflict-grid p {

    max-width: 70ch;

    color:
        rgba(255,255,255,.82);

    line-height: 1.8;
}

.conflict-grid p + p {

    margin-top: 1rem;
}

/* =========================================
   BUTTON
========================================= */

.section-navy .btn {

    background: #fff;

    color: var(--navy);

    border-color:
        rgba(255,255,255,.72);

    box-shadow:
        0 12px 26px rgba(0,0,0,.14);
}

.section-navy .btn:hover {

    background: #f7f2ea;

    color: var(--navy-2);
}

/* =========================================
   RESPONSIVE
========================================= */

@media (max-width: 1040px) {

    .conflict-grid {

        grid-template-columns: 1fr;
    }

    .conflict-cta {

        margin-top: 1rem;
    }
}
/* ======================================================
   PERSÖNLICH BERATEN
====================================================== */

.firm-grid {

    display: grid;

    grid-template-columns:
        .95fr
        1.05fr;

    gap: clamp(2rem, 6vw, 4rem);

    align-items: center;
}

/* =========================================
   IMAGE
========================================= */

.firm-image {

    margin: 0;

    overflow: hidden;

    border-radius: var(--radius-xl);

    background:
        linear-gradient(
            180deg,
            #f1e8dc 0%,
            #f8f4ed 100%
        );

    border:
        1px solid var(--line);

    box-shadow: var(--shadow-deep);
}

.firm-image img {

    width: 100%;

    height: auto;

    object-fit: contain;

    object-position: center;
}

/* =========================================
   TEXT
========================================= */

.firm-grid h2 {

    margin-bottom: 1.5rem;
}

.firm-grid p {

    max-width: 62ch;

    line-height: 1.8;
}

.firm-grid .button-row {

    margin-top: 1.8rem;
}

/* =========================================
   RESPONSIVE
========================================= */

@media (max-width: 1040px) {

    .firm-grid {

        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {

    .firm-grid {

        gap: 2rem;
    }
}
/* ======================================================
   WISSEN
====================================================== */

/* =========================================
   TABS
========================================= */

.tabs {

    display: flex;

    justify-content: center;

    flex-wrap: wrap;

    gap: .8rem;

    margin-bottom: 2.2rem;
}

.tabs a {

    padding:
        .75rem
        1.05rem;

    border-radius: 999px;

    background: #fff;

    border:
        1px solid var(--line);

    font-weight: 700;

    color: var(--ink-soft);

    transition:
        color .2s ease,
        border-color .2s ease,
        transform .2s ease;
}

.tabs a:hover {

    color: var(--navy);

    border-color:
        rgba(184,135,59,.4);

    transform: translateY(-1px);
}

/* =========================================
   ARTICLE GRID
========================================= */

.article-grid {

    display: grid;

    grid-template-columns:
        repeat(3,minmax(0,1fr));

    gap: 1.2rem;
}

/* =========================================
   ARTICLE CARD
========================================= */

.article-card {

    display: flex;

    flex-direction: column;

    padding: 1.7rem;

    background:
        rgba(255,255,255,.86);

    border:
        1px solid var(--line);

    border-radius: var(--radius-lg);

    box-shadow: var(--shadow-soft);

    transition:
        transform .18s ease,
        box-shadow .18s ease,
        border-color .18s ease;
}

.article-card:hover {

    transform: translateY(-3px);

    border-color:
        rgba(184,135,59,.35);

    box-shadow: var(--shadow-deep);
}

.article-card h3 {

    margin-bottom: .8rem;

    line-height: 1.1;
}

.article-card p {

    color: var(--muted);

    line-height: 1.7;
}

/* =========================================
   LINKS
========================================= */

.article-card a {

    display: inline-flex;

    margin-top: auto;

    padding-top: 1rem;

    color: var(--navy);

    font-weight: 800;

    transition:
        color .2s ease,
        transform .2s ease;
}

.article-card a:hover {

    color: var(--navy-2);

    transform: translateX(2px);
}

/* =========================================
   RESPONSIVE
========================================= */

@media (max-width: 1040px) {

    .article-grid {

        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {

    .article-card {

        padding: 1.5rem;
    }

    .tabs {

        gap: .6rem;
    }
}
/* ======================================================
   CTA
====================================================== */

.section-cta {

    padding-bottom: 0;

    background: transparent;
}
/* =========================================
   PANEL
========================================= */

.cta-panel {

    display: grid;

    grid-template-columns:
        1.15fr
        .85fr;

    gap: clamp(2rem, 5vw, 4rem);

    align-items: center;

    padding:
        clamp(2rem, 4vw, 3rem);

    border-radius: var(--radius-xl);

    background:
        radial-gradient(
            circle at 10% 15%,
            rgba(184,135,59,.16),
            transparent 26%
        ),
        linear-gradient(
            135deg,
            #123862 0%,
            #0d2948 60%,
            #0a213b 100%
        );

    box-shadow: var(--shadow-deep);
}

/* =========================================
   COPY
========================================= */

.cta-copy {

    max-width: 58ch;
}

.cta-eyebrow {

    margin-bottom: .9rem;

    font-size: .78rem;

    font-weight: 800;

    letter-spacing: .16em;

    text-transform: uppercase;

    color: rgba(255,255,255,.68);
}

.cta-panel h2 {

    margin-bottom: 1rem;

    color: #fff;

    line-height: 1.02;
}

.cta-panel p {

    color:
        rgba(255,255,255,.82);

    line-height: 1.75;
}

.cta-note {

    margin-top: 1rem;

    font-size: .92rem;

    color:
        rgba(255,255,255,.62);
}

/* =========================================
   BUTTONS
========================================= */

.cta-actions {

    display: flex;

    flex-direction: column;

    gap: .9rem;

    align-items: flex-start;
}

.cta-panel .btn {

    min-width: 240px;

    background: #fff;

    color: var(--navy);

    border-color:
        rgba(255,255,255,.72);

    box-shadow:
        0 12px 26px rgba(0,0,0,.14);
}

.cta-panel .btn:hover {

    background: #f7f2ea;

    color: var(--navy-2);
}

/* =========================================
   RESPONSIVE
========================================= */

@media (max-width: 1040px) {

    .cta-panel {

        grid-template-columns: 1fr;
    }

    .cta-copy {

        max-width: none;
    }
}

@media (max-width: 760px) {

    .cta-actions {

        align-items: stretch;
    }

    .cta-panel .btn {

        width: 100%;

        min-width: 0;
    }
}
/* ======================================================
   WordPress Navigation Compatibility
====================================================== */

.main-nav .sub-menu {

    position: absolute;

    top: calc(100% + 14px);
    left: 0;

    min-width: 0;

    width: max-content;

    max-width: 340px;

    padding: .45rem;

    margin: 0;

    list-style: none;

    background:
        rgba(255,255,255,.92);
    
    backdrop-filter: blur(18px);

    border:
        1px solid rgba(31,31,29,.08);

    border-radius: 16px;

    box-shadow: var(--shadow-deep);

    opacity: 0;

    visibility: hidden;

    transform: translateY(8px);

    pointer-events: none;

    border-radius: 12px;

    transition:
        opacity .2s ease,
        visibility .2s ease,
        transform .2s ease;

    display: flex;

    flex-direction: column;

    gap: .28rem;

    z-index: 1000;
}

.main-nav .sub-menu li {
    list-style: none;
}

.main-nav .sub-menu a {

    display: inline-flex;

    align-items: center;

    width: fit-content;

    max-width: 100%;

    padding:
        .62rem
        .82rem;

    border-radius: 10px;

    font-weight: 600;

    line-height: 1.18;

    color: var(--ink-soft);

    white-space: nowrap;
}

.main-nav .sub-menu a:hover {
    background: rgba(13,41,72,.045);
    color: var(--navy);
    transform: translateX(2px);
}

/* Dropdown sichtbar */
.nav-item:hover > .sub-menu,
.nav-item.is-open > .sub-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: auto;
}

/* Mobile */
@media (max-width: 1180px) {

    .main-nav .sub-menu {
        position: static;
        width: 100%;
        margin-top: .3rem;

        border-radius: 16px;
        box-shadow: none;

        display: none;

        opacity: 1;
        visibility: visible;
        transform: none;
        pointer-events: auto;

        grid-template-columns: 1fr;
    }

    .nav-item.is-open > .sub-menu {
        display: grid;
    }
}
/* ======================================================
   ACTIVE NAVIGATION
====================================================== */

.current-menu-item > .nav-link,
.current_page_item > .nav-link,
.current-menu-ancestor > .nav-link {

    color: var(--navy);

    background:
        rgba(13,41,72,.05);
}

.current-menu-item > .nav-link::after,
.current_page_item > .nav-link::after,
.current-menu-ancestor > .nav-link::after {

    content: "";

    position: absolute;

    left: .9rem;
    right: .9rem;
    bottom: .45rem;

    height: 2px;

    border-radius: 999px;

    background:
        linear-gradient(
            90deg,
            var(--brass),
            rgba(184,135,59,.35)
        );
}
/* ======================================================
   Kontaktseite: Formular direkt sichtbar
   Ergänzung für assets/css/service-pages.css
====================================================== */

body.service-page--kontakt .service-main > svg.svg-defs,
body.service-page--kontakt .service-main svg.svg-defs,
body.service-page--kontakt .service-main .svg-defs {
    position: absolute !important;
    width: 0 !important;
    height: 0 !important;
    overflow: hidden !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    line-height: 0 !important;
    pointer-events: none !important;
    clip: rect(0 0 0 0) !important;
    clip-path: inset(50%) !important;
}

body.service-page--kontakt .contact-immediate-section {
    padding-top: clamp(2.25rem, 4vw, 3.75rem);
    padding-bottom: clamp(4.5rem, 7vw, 6.25rem);
    background: #ffffff;
    scroll-margin-top: calc(var(--header-compact) + 24px);
}

body.service-page--kontakt .contact-layout {
    display: grid;
    grid-template-columns: minmax(0, .88fr) minmax(420px, 1.12fr);
    gap: clamp(2rem, 5vw, 4.25rem);
    align-items: start;
}

body.service-page--kontakt .contact-layout--immediate {
    align-items: stretch;
}

body.service-page--kontakt .contact-layout--immediate > div:first-child {
    align-self: center;
}

body.service-page--kontakt .contact-info-list {
    display: grid;
    gap: .78rem;
    margin-top: 1.6rem;
    padding: 0;
    list-style: none;
}

body.service-page--kontakt .contact-info-list li {
    position: relative;
    padding-left: 1.45rem;
    color: var(--ink-soft);
    line-height: 1.6;
}

body.service-page--kontakt .contact-info-list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: .68em;
    width: .48rem;
    height: .48rem;
    border-radius: 50%;
    background: var(--brass);
}

body.service-page--kontakt .contact-form-card,
body.service-page--kontakt .contact-form {
    width: 100%;
    padding: clamp(1.35rem, 3vw, 2.25rem);
    border: 1px solid var(--line);
    border-radius: var(--radius-xl);
    background:
        radial-gradient(circle at 12% 12%, rgba(184,135,59,.10), transparent 30%),
        rgba(255,255,255,.92);
    box-shadow: var(--shadow-soft);
}

body.service-page--kontakt .form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

body.service-page--kontakt .form-row {
    display: grid;
    gap: .45rem;
    min-width: 0;
}

body.service-page--kontakt .form-row--full,
body.service-page--kontakt .form-row--checkbox,
body.service-page--kontakt .form-actions {
    grid-column: 1 / -1;
}

body.service-page--kontakt .form-row label {
    color: var(--ink);
    font-size: .9rem;
    font-weight: 800;
    line-height: 1.25;
}

body.service-page--kontakt .form-row input,
body.service-page--kontakt .form-row select,
body.service-page--kontakt .form-row textarea {
    width: 100%;
    min-height: 48px;
    padding: .78rem .9rem;
    border: 1px solid rgba(38,35,29,.16);
    border-radius: 12px;
    background: #ffffff;
    color: var(--ink);
    font: inherit;
    line-height: 1.45;
    outline: none;
    transition:
        border-color .18s ease,
        box-shadow .18s ease,
        background .18s ease;
}

body.service-page--kontakt .form-row textarea {
    min-height: 160px;
    resize: vertical;
}

body.service-page--kontakt .form-row input:focus,
body.service-page--kontakt .form-row select:focus,
body.service-page--kontakt .form-row textarea:focus {
    border-color: rgba(184,135,59,.65);
    box-shadow: 0 0 0 4px rgba(184,135,59,.12);
}

body.service-page--kontakt .form-row--checkbox label {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: .7rem;
    align-items: start;
    color: var(--ink-soft);
    font-size: .92rem;
    font-weight: 500;
    line-height: 1.55;
}

body.service-page--kontakt .form-row--checkbox input {
    width: 18px;
    height: 18px;
    min-height: 0;
    margin-top: .2rem;
    accent-color: var(--navy);
}

body.service-page--kontakt .form-row--checkbox a,
body.service-page--kontakt .form-note a,
body.service-page--kontakt .quick-contact-card a,
body.service-page--kontakt .intro-panel a {
    color: var(--navy);
    font-weight: 700;
}

body.service-page--kontakt .form-actions {
    margin-top: .2rem;
}

body.service-page--kontakt .form-note {
    margin-top: 1.15rem;
    color: var(--muted);
    font-size: .92rem;
    line-height: 1.65;
}

body.service-page--kontakt .contact-honeypot {
    position: absolute;
    left: -9999px;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

body.service-page--kontakt .quick-contact-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    margin-top: 2rem;
}

body.service-page--kontakt .quick-contact-card {
    min-width: 0;
    padding: 1.25rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-lg);
    background: rgba(255,255,255,.86);
    box-shadow: var(--shadow-soft);
}

body.service-page--kontakt .quick-contact-card h3 {
    margin-bottom: .45rem;
    font-size: clamp(1.25rem, 1.6vw, 1.55rem);
}

body.service-page--kontakt .quick-contact-card address {
    color: var(--muted);
    font-style: normal;
    line-height: 1.6;
}

body.service-page--kontakt .address-panel {
    display: grid;
    grid-template-columns: minmax(380px, .92fr) minmax(0, 1fr);
    gap: clamp(2rem, 5vw, 4rem);
    align-items: center;
}

body.service-page--kontakt .address-card {
    padding: clamp(1.6rem, 3vw, 2.35rem);
    border: 1px solid var(--line);
    border-radius: var(--radius-xl);
    background: rgba(255,255,255,.86);
    box-shadow: var(--shadow-soft);
}

body.service-page--kontakt .address-card address {
    margin: 1.4rem 0;
    color: var(--ink-soft);
    font-style: normal;
    line-height: 1.7;
}

body.service-page--kontakt .address-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .85rem;
    margin-top: 1.5rem;
}

@media (max-width: 1080px) {
    body.service-page--kontakt .contact-layout,
    body.service-page--kontakt .address-panel {
        grid-template-columns: 1fr;
    }

    body.service-page--kontakt .quick-contact-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    body.service-page--kontakt .contact-immediate-section {
        padding-top: 3rem;
    }

    body.service-page--kontakt .form-grid {
        grid-template-columns: 1fr;
    }

    body.service-page--kontakt .contact-form-card,
    body.service-page--kontakt .contact-form {
        padding: 1.25rem;
        border-radius: var(--radius-lg);
    }

    body.service-page--kontakt .form-actions .btn,
    body.service-page--kontakt .address-actions .btn {
        width: 100%;
    }
}
/* ======================================================
   Header Dropdown: Hover-Lücke schließen
====================================================== */

.site-header .main-nav .nav-item.has-dropdown {
    position: relative;
}

.site-header .main-nav .nav-item.has-dropdown::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
    height: 22px;
    display: block;
}

.site-header .main-nav .sub-menu {
    top: calc(100% + 6px);
}

.site-header .main-nav .nav-item.has-dropdown:hover > .sub-menu,
.site-header .main-nav .nav-item.has-dropdown:focus-within > .sub-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: auto;
}