/*
Theme Name: Berthold Service Pro
Theme URI: https://hsug-berthold.com
Author: Stev Berthold
Author URI: https://hsug-berthold.com
Description: Professionelles WordPress-Theme für Hausmeisterservice & Gartenpflege Berthold mit Startseite, Kontaktbereich und Preisrechner.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: berthold-service-pro
*/

:root {
    --berthold-green: #0f4f2b;
    --berthold-green-2: #1f7a3a;
    --berthold-green-soft: #eaf6ee;
    --berthold-orange: #ff9800;
    --berthold-orange-dark: #e58400;
    --berthold-ink: #14231b;
    --berthold-muted: #65726b;
    --berthold-border: #dde7e1;
    --berthold-bg: #f6f8f6;
    --berthold-white: #ffffff;
    --berthold-shadow: 0 18px 45px rgba(12,42,27,.13);
    --berthold-radius: 22px;
    --berthold-container: 1180px;
}

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

html {
    scroll-behavior: smooth
}

body {
    margin: 0;
    color: var(--berthold-ink);
    background: var(--berthold-bg);
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
    line-height: 1.65;
    text-rendering: optimizeLegibility;
}

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

a {
    color: var(--berthold-green-2);
    text-decoration: none
}

    a:hover {
        color: var(--berthold-orange)
    }

button, input, select, textarea {
    font: inherit
}

.container {
    width: min(calc(100% - 32px), var(--berthold-container));
    margin-inline: auto;
}

.screen-reader-text {
    border: 0;
    clip: rect(1px,1px,1px,1px);
    clip-path: inset(50%);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
    word-wrap: normal !important;
}

/* Header */
.site-header {
    position: sticky;
    top: 0;
    z-index: 1000;
    background: rgba(255,255,255,.92);
    backdrop-filter: blur(18px);
    border-bottom: 1px solid rgba(15,79,43,.12);
}

.admin-bar .site-header {
    top: 32px
}

.header-inner {
    min-height: 86px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 22px;
}

.site-branding {
    display: flex;
    align-items: center;
    gap: 14px;
    min-width: 190px
}

.site-logo-link {
    display: inline-flex;
    align-items: center
}

.site-logo {
    width: auto;
    max-width: 235px;
    max-height: 76px;
    object-fit: contain;
    display: block;
}

.custom-logo {
    max-height: 76px;
    width: auto
}

.site-title-text {
    font-weight: 900;
    letter-spacing: -.03em;
    color: var(--berthold-green);
    line-height: 1.1
}

.main-navigation {
    display: flex;
    align-items: center;
    gap: 20px
}

    .main-navigation ul {
        margin: 0;
        padding: 0;
        list-style: none;
        display: flex;
        align-items: center;
        gap: 6px
    }

    .main-navigation a {
        display: block;
        padding: 10px 13px;
        color: var(--berthold-ink);
        font-weight: 800;
        font-size: .94rem;
        border-radius: 999px;
    }

        .main-navigation a:hover, .main-navigation .current-menu-item > a {
            background: var(--berthold-green-soft);
            color: var(--berthold-green);
        }

.header-actions {
    display: flex;
    align-items: center;
    gap: 10px
}

.mobile-toggle {
    display: none;
    width: 46px;
    height: 46px;
    border: 1px solid var(--berthold-border);
    border-radius: 14px;
    background: var(--berthold-white);
    color: var(--berthold-green);
    cursor: pointer;
}

    .mobile-toggle span {
        display: block;
        width: 20px;
        height: 2px;
        margin: 4px auto;
        background: currentColor;
        border-radius: 2px
    }

/* Buttons */
.btn, .wp-block-button__link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .55rem;
    min-height: 48px;
    padding: 13px 20px;
    border-radius: 999px;
    border: 0;
    cursor: pointer;
    font-weight: 900;
    line-height: 1.2;
    transition: transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease;
}

    .btn:hover, .wp-block-button__link:hover {
        transform: translateY(-2px)
    }

.btn-primary, .wp-block-button__link {
    color: #fff;
    background: linear-gradient(135deg,var(--berthold-green),var(--berthold-green-2));
    box-shadow: 0 12px 24px rgba(15,79,43,.22);
}

    .btn-primary:hover {
        color: #fff;
        background: linear-gradient(135deg,var(--berthold-green-2),var(--berthold-green))
    }

.btn-accent {
    color: #fff;
    background: linear-gradient(135deg,var(--berthold-orange),var(--berthold-orange-dark));
    box-shadow: 0 12px 24px rgba(255,152,0,.22)
}

    .btn-accent:hover {
        color: #fff;
        background: linear-gradient(135deg,var(--berthold-orange-dark),var(--berthold-orange))
    }

.btn-ghost {
    color: var(--berthold-green);
    background: var(--berthold-white);
    border: 1px solid var(--berthold-border)
}

    .btn-ghost:hover {
        background: var(--berthold-green-soft)
    }

/* Sections */
.section {
    padding: 86px 0
}

.section-sm {
    padding: 56px 0
}

.section-title {
    margin: 0 0 18px;
    color: var(--berthold-ink);
    font-size: clamp(2rem,3.6vw,3.25rem);
    line-height: 1.08;
    letter-spacing: -.045em;
}

.section-kicker {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 14px;
    padding: 7px 13px;
    color: var(--berthold-green);
    background: var(--berthold-green-soft);
    border: 1px solid rgba(31,122,58,.16);
    border-radius: 999px;
    font-weight: 900;
    font-size: .88rem;
}

.section-lead {
    max-width: 760px;
    margin: 0;
    color: var(--berthold-muted);
    font-size: 1.13rem
}

.section-head {
    display: flex;
    justify-content: space-between;
    align-items: end;
    gap: 28px;
    margin-bottom: 34px
}

    .section-head .section-lead {
        margin-top: 0
    }

/* Hero */
.hero {
    position: relative;
    overflow: hidden;
    padding: 82px 0 72px;
    background: radial-gradient(circle at 16% 15%,rgba(102,187,106,.34),transparent 34%), radial-gradient(circle at 80% 12%,rgba(255,152,0,.18),transparent 35%), linear-gradient(135deg,#f7fbf8 0%,#edf5ef 54%,#fff 100%);
}

    .hero::before {
        content: "";
        position: absolute;
        inset: auto -80px -140px auto;
        width: 420px;
        height: 420px;
        background: linear-gradient(135deg,rgba(15,79,43,.16),rgba(255,152,0,.08));
        border-radius: 48% 52% 55% 45%;
        transform: rotate(17deg);
    }

.hero-grid {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0,1.35fr) minmax(330px,.65fr);
    align-items: center;
    gap: 64px;
}

.hero h1 {
    margin: 0 0 18px;
    color: var(--berthold-green);
    font-size: clamp(2.55rem,4.8vw,4.85rem);
    line-height: .99;
    letter-spacing: -.055em;
}

.hero-subtitle {
    margin: 0 0 18px;
    font-size: clamp(1.2rem,2vw,1.55rem);
    color: var(--berthold-ink);
    font-weight: 900;
}

.hero-copy {
    margin: 0;
    color: var(--berthold-muted);
    font-size: 1.12rem;
    max-width: 660px
}

.hero-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 13px;
    margin-top: 30px
}

.hero-trust {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 28px
}

    .hero-trust span {
        display: inline-flex;
        align-items: center;
        gap: 7px;
        padding: 9px 12px;
        background: rgba(255,255,255,.75);
        border: 1px solid var(--berthold-border);
        border-radius: 999px;
        font-weight: 800;
        color: var(--berthold-green);
    }

.hero-card {
    position: relative;
	  padding: 8px;
    border-radius: 32px;
    background: rgba(255,255,255,.78);
    border: 1px solid rgba(255,255,255,.7);
    box-shadow: var(--berthold-shadow);
    justify-self: end;
    width: 100%;
    max-width: 455px;
    margin-left: 26px;
}

.hero-logo-panel {
    display: grid;
    place-items: center;
    min-height: 270px;
    border-radius: 26px;
    background: linear-gradient(155deg,#113b24,#0b1c13);
    overflow: hidden;
    position: relative;
}

    .hero-logo-panel::before {
        content: "";
        position: absolute;
        inset: -40%;
        background: radial-gradient(circle,rgba(102,187,106,.34),transparent 36%);
        animation: softpulse 8s ease-in-out infinite;
    }

    .hero-logo-panel img {
        position: relative;
        width: min(88%,390px);
        filter: drop-shadow(0 12px 22px rgba(0,0,0,.3))
    }

.hero-info-strip {
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 10px;
    margin-top: 14px;
}

    .hero-info-strip div {
        padding: 14px;
        border-radius: 18px;
        background: var(--berthold-white);
        border: 1px solid var(--berthold-border)
    }

    .hero-info-strip strong {
        display: block;
        color: var(--berthold-green);
        font-size: 1.15rem
    }

    .hero-info-strip small {
        color: var(--berthold-muted);
        font-weight: 800
    }

@keyframes softpulse {
    0%,100% {
        transform: translate(0,0)
    }

    50% {
        transform: translate(7%,5%)
    }
}

/* Cards */
.grid-4 {
    display: grid;
    grid-template-columns: repeat(4,1fr);
    gap: 18px
}

.grid-3 {
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 20px
}

.card {
    background: var(--berthold-white);
    border: 1px solid var(--berthold-border);
    border-radius: var(--berthold-radius);
    padding: 26px;
    box-shadow: 0 10px 24px rgba(12,42,27,.05);
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

    .card:hover {
        transform: translateY(-4px);
        box-shadow: var(--berthold-shadow);
        border-color: rgba(31,122,58,.24)
    }

.card-icon {
    width: 54px;
    height: 54px;
    border-radius: 18px;
    display: grid;
    place-items: center;
    background: var(--berthold-green-soft);
    font-size: 1.65rem;
    margin-bottom: 18px
}

.card h3 {
    margin: 0 0 10px;
    font-size: 1.2rem;
    line-height: 1.25;
    color: var(--berthold-ink)
}

.card p {
    margin: 0;
    color: var(--berthold-muted)
}

.card a {
    display: inline-block;
    margin-top: 16px;
    font-weight: 900;
    color: var(--berthold-green)
}

/* Split / Feature */
.split {
    display: grid;
    grid-template-columns: minmax(0,1fr) minmax(320px,.82fr);
    gap: 42px;
    align-items: center
}

.feature-panel {
    background: var(--berthold-green);
    color: #fff;
    border-radius: 32px;
    padding: 34px;
    box-shadow: var(--berthold-shadow);
    position: relative;
    overflow: hidden
}

    .feature-panel::after {
        content: "";
        position: absolute;
        right: -50px;
        bottom: -70px;
        width: 210px;
        height: 210px;
        background: rgba(255,255,255,.1);
        border-radius: 50%
    }

.feature-list {
    display: grid;
    gap: 14px;
    margin: 24px 0 0;
    padding: 0;
    list-style: none
}

    .feature-list li {
        display: flex;
        gap: 12px;
        align-items: flex-start;
        background: rgba(255,255,255,.11);
        padding: 14px;
        border-radius: 16px;
        font-weight: 800
    }

        .feature-list li::before {
            content: "✓";
            display: grid;
            place-items: center;
            flex: 0 0 24px;
            height: 24px;
            border-radius: 50%;
            background: var(--berthold-orange);
            color: #fff;
            font-weight: 900
        }

/* Process */
.process {
    counter-reset: step;
    display: grid;
    grid-template-columns: repeat(4,1fr);
    gap: 18px
}

.process-step {
    position: relative;
    background: var(--berthold-white);
    border: 1px solid var(--berthold-border);
    border-radius: var(--berthold-radius);
    padding: 24px
}

    .process-step::before {
        counter-increment: step;
        content: counter(step);
        display: grid;
        place-items: center;
        width: 44px;
        height: 44px;
        border-radius: 14px;
        background: var(--berthold-green);
        color: #fff;
        font-weight: 900;
        margin-bottom: 18px
    }

    .process-step h3 {
        margin: 0 0 8px;
        font-size: 1.1rem
    }

    .process-step p {
        margin: 0;
        color: var(--berthold-muted)
    }

/* Testimonials */
.testimonial {
    background: #fff;
    border: 1px solid var(--berthold-border);
    border-radius: var(--berthold-radius);
    padding: 26px;
    position: relative
}

    .testimonial::before {
        content: "“";
        position: absolute;
        top: 8px;
        right: 20px;
        color: rgba(31,122,58,.16);
        font-size: 5rem;
        line-height: 1;
        font-weight: 900
    }

    .testimonial p {
        margin: 0 0 14px;
        color: var(--berthold-ink);
        font-weight: 700
    }

    .testimonial strong {
        color: var(--berthold-green)
    }

/* Contact */
.contact-band {
    background: linear-gradient(135deg,var(--berthold-green),#0b2d1a);
    color: #fff;
    border-radius: 34px;
    padding: 38px;
    display: grid;
    grid-template-columns: minmax(0,1fr) minmax(320px,.75fr);
    gap: 28px;
    align-items: center;
    box-shadow: var(--berthold-shadow);
    overflow: hidden;
    position: relative
}

    .contact-band::after {
        content: "";
        position: absolute;
        right: -80px;
        top: -80px;
        width: 240px;
        height: 240px;
        border-radius: 50%;
        background: rgba(255,255,255,.09)
    }

    .contact-band h2 {
        margin: 0 0 10px;
        font-size: clamp(2rem,4vw,3.2rem);
        line-height: 1.05;
        letter-spacing: -.05em
    }

    .contact-band p {
        margin: 0;
        color: rgba(255,255,255,.84)
    }

.contact-box {
    position: relative;
    background: rgba(255,255,255,.11);
    border: 1px solid rgba(255,255,255,.18);
    border-radius: 24px;
    padding: 24px
}

    .contact-box a {
        color: #fff;
        font-weight: 900
    }

    .contact-box .btn {
        margin-top: 16px
    }

.cf7-wrap {
    margin-top: 26px;
    background: #fff;
    border-radius: 26px;
    border: 1px solid var(--berthold-border);
    padding: 26px;
    box-shadow: 0 10px 24px rgba(12,42,27,.05)
}

.wpcf7 input, .wpcf7 textarea, .wpcf7 select {
    width: 100%;
    padding: 13px 14px;
    border: 1px solid var(--berthold-border);
    border-radius: 14px;
    background: #fff;
    color: var(--berthold-ink)
}

    .wpcf7 input[type="submit"] {
        width: auto;
        border: 0;
        background: var(--berthold-green);
        color: #fff;
        font-weight: 900;
        border-radius: 999px;
        cursor: pointer;
        padding: 14px 22px
    }

/* Page content */
.page-shell {
    padding: 68px 0
}

.content-card {
    background: #fff;
    border: 1px solid var(--berthold-border);
    border-radius: var(--berthold-radius);
    padding: clamp(24px,4vw,44px);
    box-shadow: 0 10px 24px rgba(12,42,27,.05)
}

    .content-card h1 {
        margin-top: 0;
        color: var(--berthold-white);
        font-size: clamp(2rem,4vw,3.2rem);
        line-height: 1.1
    }

.entry-content > *:first-child {
    margin-top: 0
}

.entry-content > *:last-child {
    margin-bottom: 0
}

.site-footer {
    background: #0e1b14;
    color: rgba(255,255,255,.82);
    padding: 54px 0 24px;
    margin-top: 0
}

.footer-grid {
    display: grid;
    grid-template-columns: 1.3fr .8fr .8fr;
    gap: 28px
}

.footer-brand img {
    max-width: 230px;
    max-height: 90px;
    object-fit: contain;
    filter: drop-shadow(0 8px 16px rgba(0,0,0,.3))
}

.footer-grid h3 {
    color: #fff;
    margin: 0 0 14px
}

.footer-grid p, .footer-grid ul {
    margin: 0;
    color: rgba(255,255,255,.72)
}

.footer-grid a {
    color: rgba(255,255,255,.9);
    font-weight: 800
}

    .footer-grid a:hover {
        color: var(--berthold-orange)
    }

.footer-menu {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 8px
}

.footer-bottom {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    flex-wrap: wrap;
    border-top: 1px solid rgba(255,255,255,.12);
    margin-top: 36px;
    padding-top: 18px;
    font-size: .92rem;
    color: rgba(255,255,255,.62)
}

    .footer-bottom a {
        color: rgba(255,255,255,.8)
    }

@media(max-width:1060px) {
    .header-actions .btn-ghost {
        display: none
    }

    .grid-4, .process {
        grid-template-columns: repeat(2,1fr)
    }

    .grid-3 {
        grid-template-columns: 1fr 1fr
    }

    .hero-grid, .split, .contact-band {
        grid-template-columns: 1fr
    }

    .hero-card {
        max-width: 620px;
        margin-left: 0;
        justify-self: center
    }
}

@media(max-width:860px) {
    .admin-bar .site-header {
        top: 0
    }

    .header-inner {
        min-height: 74px
    }

    .mobile-toggle {
        display: inline-block
    }

    .main-navigation {
        position: absolute;
        left: 16px;
        right: 16px;
        top: calc(100% + 8px);
        display: none;
        padding: 14px;
        background: #fff;
        border: 1px solid var(--berthold-border);
        border-radius: 22px;
        box-shadow: var(--berthold-shadow);
    }

    body.nav-open .main-navigation {
        display: block
    }

    .main-navigation ul {
        display: grid;
        gap: 4px
    }

    .main-navigation a {
        padding: 13px 14px
    }

    .header-actions .btn-accent {
        display: none
    }

    .site-logo {
        max-width: 190px;
        max-height: 66px
    }

    .section {
        padding: 64px 0
    }

    .section-head {
        display: block
    }

        .section-head .btn {
            margin-top: 20px
        }

    .footer-grid {
        grid-template-columns: 1fr
    }
}

@media(max-width:620px) {
    .container {
        width: min(calc(100% - 24px), var(--berthold-container))
    }

    .hero {
        padding: 54px 0
    }

    .hero-buttons .btn {
        width: 100%
    }

    .hero-info-strip {
        grid-template-columns: 1fr
    }

    .grid-4, .grid-3, .process {
        grid-template-columns: 1fr
    }

    .contact-band {
        padding: 26px;
        border-radius: 26px
    }

    .cf7-wrap {
        padding: 18px
    }
}
