﻿/* ===================================
   Ronny Backert  ·  city.css
   Stadtseiten  ·  Teal / Blau / Amber-Akzent
   =================================== */

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

:root {
    --blue:         #009097;
    --blue-mid:     #006395;
    --blue-light:   #006395;
    --blue-xlight:  #96c4ce;
    --steel:        #96c4ce;
    --steel-light:  #96c4ce;
    --anthrazit:    #1E293B;
    --gray-dark:    #2D3748;
    --gray-mid:     #4A5568;
    --gray-soft:    #718096;
    --gray-200:     #E8ECF0;
    --gray-100:     #F4F6F8;
    --gray-50:      #FDF9F5;
    --white:        #FFFFFF;
    --accent:       #db964a;
    --accent-dark:  #0096B7;
    --accent-light: #48CAE4;
    --accent-pale:  #E0F7FA;
    --shadow-xs:    0 1px 3px rgba(0,144,151,0.07);
    --shadow-sm:    0 4px 12px rgba(0,144,151,0.12);
    --shadow-md:    0 8px 24px rgba(0,144,151,0.16);
    --r-sm: 6px; --r-md: 12px; --r-lg: 20px;
    --ease: cubic-bezier(0.4,0,0.2,1);
    --t: all 0.25s var(--ease);
}

/* scrollbar-gutter: stable reserviert dauerhaft Platz für die Scrollleiste,
   damit zentrierte Inhalte beim Seitenwechsel nicht seitlich "verrutschen". */
html { scroll-behavior:smooth; overflow-x:hidden; scrollbar-gutter:stable; }
body {
    font-family:'Segoe UI',system-ui,-apple-system,sans-serif;
    color:var(--gray-dark); line-height:1.65; font-size:16px;
    background:var(--white);
}
img { max-width:100%; height:auto; display:block; }
a   { text-decoration:none; color:inherit; transition:var(--t); }

h1,h2,h3,h4 { font-weight:700; line-height:1.18; color:var(--anthrazit); margin-bottom:0.8rem; letter-spacing:-0.02em; }
h1 { font-size:clamp(1.9rem,4.5vw,3.1rem); font-weight:800; line-height:1.07; }
h2 { font-size:clamp(1.5rem,3vw,2.4rem); }
h3 { font-size:clamp(1rem,2vw,1.28rem); }
p  { color:var(--gray-soft); line-height:1.72; margin-bottom:0.9rem; font-size:0.9625rem; }

.container { width:100%; max-width:1160px; margin:0 auto; padding:0 1.5rem; }

/* =====================
   TOPBAR
   ===================== */
.topbar {
    background: linear-gradient(135deg, #009097 0%, #006395 100%);
    padding:0.55rem 0; font-size:0.82rem;
    position:fixed; top:0; left:0; width:100%;
    z-index:1001;
    border-bottom:1px solid rgba(255,255,255,0.15);
}
.topbar-content { display:flex; justify-content:space-between; align-items:center; gap:1rem; }
.topbar-info { display:flex; align-items:center; gap:1.5rem; flex-wrap:wrap; }
.topbar-item { display:flex; align-items:center; gap:0.4rem; color:rgba(255,255,255,0.92); font-size:0.79rem; }
.topbar-item svg { width:12px; height:12px; fill:rgba(255,255,255,0.9); flex-shrink:0; }
.topbar-buttons { display:flex; gap:0.5rem; }
.topbar-btn { padding:0.3rem 0.85rem; border-radius:4px; font-weight:600; font-size:0.77rem; white-space:nowrap; transition:var(--t); }
.topbar-btn-primary { background:var(--accent); color:var(--white); }
.topbar-btn-primary:hover { background:var(--accent-dark); }
.topbar-btn-secondary { border:1px solid rgba(255,255,255,0.2); color:rgba(255,255,255,0.78); }
.topbar-btn-secondary:hover { background:rgba(255,255,255,0.1); }

/* =====================
   HEADER
   ===================== */
.header {
    position:fixed; top:51px; left:0; width:100%;
    background:var(--white);
    border-bottom:1px solid var(--gray-200);
    z-index:1000; transition:box-shadow 0.3s var(--ease);
}
.header.scrolled { box-shadow:var(--shadow-md); }
.header-content { display:flex; justify-content:space-between; align-items:center; padding:1.05rem 1.5rem; }
.logo a { display:flex; align-items:center; }
.logo img { height:66px; transition:height 0.25s var(--ease); }
/* Text-Logo */
.logo-text { display:flex; flex-direction:column; line-height:1.05; }
.logo-name {
    font-size:1.55rem; font-weight:800; letter-spacing:-0.02em;
    color:var(--anthrazit); text-transform:none;
}
.logo-sub {
    font-size:0.66rem; font-weight:700; letter-spacing:0.18em;
    text-transform:uppercase; color:var(--blue); margin-top:7px;
}
.nav { display:flex; gap:0.1rem; align-items:center; }
.nav a {
    color:var(--gray-dark); font-weight:600; font-size:0.88rem;
    padding:0.42rem 0.85rem; border-radius:var(--r-sm); transition:var(--t);
}
.nav a:hover, .nav a.active { color:var(--blue); background:var(--blue-xlight); }
.nav-toggle { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:4px; z-index:1002; }
.nav-toggle span { display:block; width:22px; height:2px; background:var(--anthrazit); border-radius:2px; transition:var(--t); }

/* =====================
   WHATSAPP
   ===================== */
.whatsapp-button {
    position:fixed; bottom:28px; right:28px;
    width:54px; height:54px; background:#25D366; border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    box-shadow:0 4px 16px rgba(37,211,102,0.4);
    z-index:999; transition:var(--t);
}
.whatsapp-button:hover { transform:scale(1.1); }
.whatsapp-button svg { width:28px; height:28px; fill:white; }

/* =====================
   BUTTONS
   ===================== */
.btn {
    display:inline-flex; align-items:center; gap:0.45rem;
    padding:0.875rem 2rem; border-radius:var(--r-md);
    font-weight:700; font-size:0.9375rem;
    border:2px solid transparent; cursor:pointer;
    transition:var(--t); white-space:nowrap;
}
.btn-primary { background:var(--blue); color:var(--white); box-shadow:0 4px 16px rgba(0,144,151,0.32); }
.btn-primary:hover { background:var(--blue-mid); transform:translateY(-2px); box-shadow:0 8px 24px rgba(0,144,151,0.5); }
.btn-secondary { background:rgba(255,255,255,0.1); border-color:rgba(255,255,255,0.45); color:var(--white); }
.btn-secondary:hover { background:var(--white); color:var(--blue); border-color:var(--white); transform:translateY(-2px); }
.btn-outline { background:transparent; border-color:var(--blue); color:var(--blue); }
.btn-outline:hover { background:var(--blue); color:var(--white); }

/* =====================
   HERO
   ===================== */
.hero {
    background: linear-gradient(150deg, var(--anthrazit) 0%, var(--blue) 65%, var(--blue-mid) 100%);
    padding-top:148px; padding-bottom:5rem;
    position:relative; overflow:hidden;
    color:var(--white);
}
.hero::before {
    content:'';
    position:absolute; inset:0;
    background-image:
        linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
    background-size:55px 55px;
    pointer-events:none;
}
.hero::after {
    content:'';
    position:absolute; top:-100px; right:-100px;
    width:500px; height:500px;
    background:radial-gradient(circle, rgba(219,150,74,0.28) 0%, transparent 65%);
    border-radius:50%; pointer-events:none;
}
.hero-badge {
    display:inline-flex; align-items:center; gap:0.45rem;
    background:rgba(0,180,216,0.2);
    border:1px solid rgba(0,180,216,0.45);
    color:var(--accent-light);
    font-size:0.72rem; font-weight:800;
    letter-spacing:0.1em; text-transform:uppercase;
    padding:0.32rem 0.9rem; border-radius:20px;
    margin-bottom:1.25rem; width:fit-content;
    position:relative; z-index:2;
}
.hero-badge::before { content:'●'; font-size:0.45rem; color:var(--accent-light); }
.hero h1 { color:var(--white); position:relative; z-index:2; margin-bottom:1rem; }
.hero-subtitle {
    font-size:1.05rem; color:rgba(255,255,255,0.75);
    margin-bottom:2rem; max-width:580px; line-height:1.68;
    position:relative; z-index:2;
}
.hero-pills { display:flex; flex-wrap:wrap; gap:0.6rem; margin-bottom:2.2rem; position:relative; z-index:2; }
.hero-pill {
    display:flex; align-items:center; gap:0.38rem;
    background:rgba(255,255,255,0.08);
    border:1px solid rgba(255,255,255,0.14);
    color:rgba(255,255,255,0.88);
    font-size:0.82rem; font-weight:600;
    padding:0.38rem 0.85rem; border-radius:20px;
}
.hero-pill::before { content:'✓'; color:var(--accent-light); font-size:0.72rem; font-weight:800; }
.hero-actions { display:flex; gap:0.9rem; flex-wrap:wrap; position:relative; z-index:2; }

/* =====================
   SECTIONS
   ===================== */
section { padding:5rem 0; }
.section-label {
    display:inline-flex; align-items:center; gap:0.38rem;
    background:var(--accent-pale); color:var(--accent-dark);
    font-size:0.7rem; font-weight:800;
    letter-spacing:0.12em; text-transform:uppercase;
    padding:0.27rem 0.8rem; border-radius:20px;
    margin-bottom:0.7rem;
}
.section-title { text-align:center; margin-bottom:3rem; }
.section-title .section-label { justify-content:center; }
.section-title h2 { margin-bottom:0.6rem; }
.section-title p { max-width:580px; margin:0 auto; font-size:0.9875rem; }

/* =====================
   LEISTUNGEN – GRID
   ===================== */
#leistungen { background:var(--gray-50); }
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; }
.service-card {
    background:var(--white);
    border-radius:var(--r-lg);
    padding:1.85rem 1.65rem;
    border:1px solid var(--gray-200);
    box-shadow:var(--shadow-xs);
    transition:var(--t);
    position:relative; overflow:hidden;
}
.service-card::after {
    content:'';
    position:absolute; top:0; left:0; right:0; height:3px;
    background:linear-gradient(90deg, var(--blue), var(--accent));
    transform:scaleX(0); transform-origin:left;
    transition:transform 0.3s var(--ease);
}
.service-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-md); border-color:rgba(0,144,151,0.3); }
.service-card:hover::after { transform:scaleX(1); }
.service-num { font-size:0.7rem; font-weight:800; letter-spacing:0.1em; color:var(--steel); margin-bottom:0.9rem; opacity:0.65; }
.service-card h3 { font-size:1.05rem; margin-bottom:0.55rem; color:var(--anthrazit); }
.service-card p  { font-size:0.9rem; margin:0; }

/* =====================
   VORTEILE – WHY GRID
   ===================== */
#vorteile { background:var(--white); }
.why-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:1.25rem; }
.why-item {
    display:flex; gap:1.1rem;
    padding:1.6rem 1.65rem;
    background:var(--gray-50);
    border-radius:var(--r-lg);
    border:1px solid var(--gray-200);
    transition:var(--t);
}
.why-item:hover { border-color:rgba(0,144,151,0.38); box-shadow:0 4px 16px rgba(0,144,151,0.1); }
.why-icon {
    width:50px; height:50px; min-width:50px;
    background:linear-gradient(135deg, var(--blue), var(--blue-mid));
    color:var(--white);
    border-radius:var(--r-md);
    display:flex; align-items:center; justify-content:center;
    font-size:1.3rem; font-weight:800; flex-shrink:0;
}
.why-content h3 { font-size:1.02rem; margin-bottom:0.38rem; }
.why-content p  { margin:0; font-size:0.9rem; }

/* =====================
   ABLAUF – PROZESS
   ===================== */
#ablauf { background:linear-gradient(135deg, var(--anthrazit) 0%, var(--blue) 100%); }
#ablauf .section-title h2 { color:var(--white); }
#ablauf .section-title p  { color:rgba(255,255,255,0.62); }
#ablauf .section-label    { background:rgba(0,180,216,0.22); color:var(--accent-light); }

.process-grid {
    display:grid; grid-template-columns:repeat(5,1fr);
    gap:1rem; position:relative;
}
.process-grid::before {
    content:'';
    position:absolute; top:35px; left:10%; right:10%; height:1px;
    background:linear-gradient(90deg, transparent, rgba(59,130,246,0.35), transparent);
    pointer-events:none;
}
.process-step { text-align:center; position:relative; }
.process-number {
    width:70px; height:70px;
    background:rgba(255,255,255,0.1);
    border:2px solid rgba(0,180,216,0.45);
    color:var(--accent-light);
    border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    font-size:1.5rem; font-weight:800;
    margin:0 auto 1.2rem;
    transition:var(--t);
}
.process-step:hover .process-number { background:var(--accent); border-color:var(--accent); color:var(--white); }
.process-number svg { width:32px; height:32px; fill:currentColor; }
.process-step h3 { color:var(--white); font-size:0.97rem; margin-bottom:0.45rem; }
.process-step p  { color:rgba(255,255,255,0.55); font-size:0.83rem; margin:0; }

/* =====================
   TESTIMONIALS
   ===================== */
#referenzen { background:var(--gray-50); }
.testimonials-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; }
.testimonial {
    background:var(--white);
    border-radius:var(--r-lg);
    padding:1.65rem;
    border:1px solid var(--gray-200);
    box-shadow:var(--shadow-xs);
    display:flex; flex-direction:column; gap:0.85rem;
    transition:var(--t);
}
.testimonial:hover { transform:translateY(-3px); box-shadow:var(--shadow-md); border-color:rgba(0,144,151,0.3); }
.stars { display:flex; gap:2px; color:#F59E0B; font-size:0.9rem; }
.testimonial-text { font-size:0.9375rem; color:var(--gray-dark); line-height:1.65; font-style:italic; flex:1; margin:0; }
.testimonial-author { display:flex; align-items:center; gap:0.85rem; padding-top:0.9rem; border-top:1px solid var(--gray-100); }
.testimonial-avatar {
    width:42px; height:42px; border-radius:var(--r-sm);
    background:linear-gradient(135deg, var(--blue), var(--blue-light));
    color:var(--white);
    display:flex; align-items:center; justify-content:center;
    font-weight:700; font-size:0.82rem; flex-shrink:0;
}
.testimonial-info h4 { font-size:0.88rem; margin:0; color:var(--anthrazit); }
.testimonial-info p  { font-size:0.78rem; margin:0; color:var(--gray-soft); }

/* =====================
   KONTAKT
   ===================== */
#kontakt { background:var(--white); }
.contact-wrapper { display:grid; grid-template-columns:1fr 1.4fr; gap:3rem; align-items:start; }
.contact-info,
.contact-info-list { display:flex; flex-direction:column; gap:0.9rem; }
.contact-item {
    display:flex; gap:1rem; padding:1.35rem 1.4rem;
    background:var(--gray-50); border-radius:var(--r-lg);
    border:1px solid var(--gray-200); transition:var(--t);
}
.contact-item:hover { border-color:rgba(0,144,151,0.38); box-shadow:0 4px 14px rgba(0,144,151,0.1); }
.contact-icon {
    width:46px; height:46px; min-width:46px;
    background:linear-gradient(135deg, var(--blue), var(--blue-mid));
    border-radius:var(--r-sm);
    display:flex; align-items:center; justify-content:center;
    font-size:1.25rem; flex-shrink:0; color:var(--white);
}
.contact-icon::after { content:'☎'; }
.contact-item:nth-child(2) .contact-icon::after { content:'✉'; }
.contact-item:nth-child(3) .contact-icon::after { content:'⚑'; }
.contact-item-content h3 { font-size:0.83rem; font-weight:700; letter-spacing:0.04em; text-transform:uppercase; color:var(--gray-soft); margin-bottom:0.28rem; }
.contact-item-content p  { margin:0; font-size:0.93rem; color:var(--gray-dark); }
.contact-item-content a  { color:var(--blue); font-weight:700; }
.contact-item-content a:hover { color:var(--accent); }

/* FORM */
.contact-form { background:var(--gray-50); padding:2.1rem; border-radius:var(--r-lg); border:1px solid var(--gray-200); }
.form-group { margin-bottom:1.1rem; }
.form-group label { display:block; margin-bottom:0.37rem; font-size:0.81rem; font-weight:700; letter-spacing:0.04em; text-transform:uppercase; color:var(--anthrazit); }
.form-group input,
.form-group textarea,
.form-group select {
    width:100%; padding:0.82rem 1rem;
    border:1.5px solid var(--gray-200); border-radius:var(--r-sm);
    font-family:inherit; font-size:0.93rem;
    background:var(--white); color:var(--gray-dark);
    transition:var(--t);
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus { outline:none; border-color:var(--blue); box-shadow:0 0 0 3px rgba(0,144,151,0.15); }
.form-group textarea { resize:vertical; min-height:125px; }
.form-checkbox { display:flex; align-items:flex-start; gap:0.6rem; }
.form-checkbox input[type="checkbox"] { width:auto; margin-top:3px; accent-color:var(--blue); }
.form-checkbox label { margin:0; font-size:0.85rem; font-weight:400; text-transform:none; letter-spacing:0; color:var(--gray-soft); }
.form-error { color:#DC2626; font-size:0.78rem; margin-top:0.28rem; display:none; }
.form-group.error input,
.form-group.error textarea { border-color:#DC2626; }
.form-group.error .form-error { display:block; }
.form-success { background:#E0F7FA; border:1px solid rgba(0,180,216,0.35); color:#0096B7; padding:0.9rem 1.1rem; border-radius:var(--r-sm); margin-bottom:1.1rem; font-size:0.9rem; display:none; }
.form-success.show { display:block; }

/* =====================
   CTA BOX
   ===================== */
.cta-box {
    background:linear-gradient(135deg, var(--blue) 0%, var(--anthrazit) 100%);
    color:var(--white); padding:3.25rem 2.75rem;
    border-radius:var(--r-lg); text-align:center;
    margin:3.5rem auto; position:relative; overflow:hidden;
}
.cta-box::before {
    content:''; position:absolute; top:-60px; right:-60px;
    width:260px; height:260px;
    background:rgba(219,150,74,0.22); border-radius:50%;
    pointer-events:none;
}
.cta-box h2 { color:var(--white); margin-bottom:0.7rem; position:relative; z-index:1; }
.cta-box p  { color:rgba(255,255,255,0.82); font-size:1.02rem; margin-bottom:1.85rem; position:relative; z-index:1; }
.cta-box .btn { position:relative; z-index:1; }

/* =====================
   FOOTER
   ===================== */
.footer { background:var(--anthrazit); color:rgba(255,255,255,0.78); padding:3.5rem 0 0; }
.footer-content {
    display:grid; grid-template-columns:1.2fr 1fr 1fr;
    gap:3rem; padding-bottom:2.5rem;
    border-bottom:1px solid rgba(255,255,255,0.07);
}
.footer-section h3 {
    color:var(--white); font-size:0.95rem; font-weight:700;
    margin-bottom:1.15rem; padding-bottom:0.42rem;
    border-bottom:2px solid var(--steel); display:inline-block;
}
.footer-section p,
.footer-section a { font-size:0.84rem; color:rgba(255,255,255,0.62); margin-bottom:0.5rem; display:block; line-height:1.58; }
.footer-section a:hover { color:var(--accent-light); }
.footer-links { list-style:none; }
.footer-links li { margin-bottom:0.38rem; }
.footer-links li a { color:rgba(255,255,255,0.62); font-size:0.84rem; display:flex; align-items:center; gap:0.35rem; transition:var(--t); }
.footer-links li a::before { content:'›'; color:var(--steel-light); font-size:1.05rem; line-height:1; }
.footer-links li a:hover { color:var(--accent-light); padding-left:3px; }
.footer-bottom { text-align:center; padding:1.4rem 0; font-size:0.78rem; color:rgba(255,255,255,0.38); }
.footer-bottom a { color:rgba(255,255,255,0.42); }
.footer-bottom a:hover { color:var(--accent-light); }

/* FOOTER COPYRIGHT */
.footer-copyright { padding:1.1rem 0 1.6rem; text-align:center; border-top:1px solid rgba(255,255,255,0.05); }
.copyright-divider { width:40px; height:2px; background:linear-gradient(90deg, transparent, var(--steel-light), transparent); margin:0 auto 0.9rem; opacity:0.45; border-radius:2px; }
.copyright-text { display:flex; align-items:center; justify-content:center; gap:0.45rem; font-size:0.78rem; color:rgba(255,255,255,0.4); flex-wrap:wrap; margin:0; }
.copyright-icon { font-size:0.88rem; }
.copyright-link { display:inline-flex; align-items:center; gap:2px; padding:0.18rem 0.6rem; background:rgba(0,144,151,0.15); border:1px solid rgba(0,144,151,0.3); border-radius:20px; transition:var(--t); }
.copyright-link:hover { background:rgba(0,144,151,0.28); border-color:var(--steel); transform:translateY(-1px); }
.it-v    { font-weight:800; color:var(--steel-light); font-size:0.82rem; }
.it-text { font-weight:600; color:rgba(255,255,255,0.78); font-size:0.82rem; }

/* =====================
   RESPONSIVE – 1024px
   ===================== */
@media (max-width:1024px) {
    .services-grid { grid-template-columns:repeat(2,1fr); }
    .process-grid  { grid-template-columns:repeat(3,1fr); }
    .process-grid::before { display:none; }
    .footer-content { grid-template-columns:1fr 1fr; }
}

/* =====================
   RESPONSIVE – 768px
   ===================== */
@media (max-width:768px) {
    /* Topbar */
    .topbar-content { flex-direction:column; gap:0.35rem; }
    .topbar-info    { flex-direction:column; gap:0.2rem; text-align:center; }
    .topbar-buttons { justify-content:center; width:100%; }
    .topbar-btn     { padding:0.35rem 1rem; }

    /* Header */
    .header { top:88px; }
    .header-content { padding:0.7rem 1rem; }
    .logo img { height:52px; }
    .logo-name { font-size:1.3rem; }
    .logo-sub  { font-size:0.58rem; letter-spacing:0.14em; margin-top:5px; }

    /* Hero */
    .hero { padding-top:168px; padding-bottom:3rem; }
    .hero-badge { font-size:0.68rem; }
    .hero h1 { font-size:clamp(1.65rem,5.5vw,2.4rem); }
    .hero-subtitle { font-size:1rem; margin-bottom:1.5rem; }
    .hero-pills { gap:0.45rem; }
    .hero-pill { font-size:0.8rem; padding:0.33rem 0.75rem; }
    .hero-actions { gap:0.75rem; }
    .hero-actions .btn { padding:0.85rem 1.5rem; font-size:0.9rem; }

    /* Nav */
    .nav {
        position:fixed; inset:0; background:var(--white);
        flex-direction:column; justify-content:center; align-items:center; gap:0.3rem;
        transform:translateX(100%); transition:transform 0.3s ease; z-index:1002;
        padding:2rem;
    }
    .nav.active { transform:translateX(0); }
    .nav a { font-size:1.2rem; padding:0.8rem 2rem; width:100%; text-align:center; border-radius:var(--r-sm); }
    .nav-toggle { display:flex; z-index:1003; }
    .nav-toggle.active span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
    .nav-toggle.active span:nth-child(2) { opacity:0; }
    .nav-toggle.active span:nth-child(3) { transform:rotate(-45deg) translate(4px,-4px); }

    /* Sections */
    section { padding:3rem 0; }
    .section-title { margin-bottom:2.5rem; }
    .section-title h2 { font-size:clamp(1.35rem,5vw,2rem); }

    /* Grids */
    .services-grid    { grid-template-columns:1fr; gap:0.9rem; }
    .why-grid         { grid-template-columns:1fr; }
    .process-grid     { grid-template-columns:repeat(2,1fr); gap:1rem; }
    .process-grid::before { display:none; }
    .testimonials-grid { grid-template-columns:1fr; }

    /* Contact */
    .contact-wrapper  { grid-template-columns:1fr; gap:1.75rem; }
    .contact-form     { padding:1.5rem; }

    /* CTA */
    .cta-box { padding:2.25rem 1.6rem; margin:2.5rem auto; }

    /* Footer */
    .footer-content { grid-template-columns:1fr; gap:1.5rem; }
    .footer-section { text-align:center; }
    .footer-section h3 { display:inline-block; }
    .footer-links li a { justify-content:center; }
}

/* =====================
   RESPONSIVE – 480px
   ===================== */
@media (max-width:480px) {
    .container { padding:0 1rem; }
    h1 { font-size:1.65rem; }
    h2 { font-size:1.35rem; }
    p  { font-size:0.9rem; }

    /* Topbar */
    .topbar-info    { display:none; }
    .topbar-content { flex-direction:row; justify-content:center; }
    .header { top:47px; }
    .header-content { padding:0.55rem 0.9rem; }
    .logo img { height:44px; }
    .logo-name { font-size:1.12rem; }
    .logo-sub  { font-size:0.5rem; letter-spacing:0.1em; margin-top:4px; }

    /* Hero */
    .hero { padding-top:110px; padding-bottom:2.5rem; }
    .hero-badge { font-size:0.65rem; padding:0.28rem 0.75rem; }
    .hero h1 { font-size:1.6rem; }
    .hero-subtitle { font-size:0.93rem; }
    .hero-pills { display:none; }
    .hero-actions { flex-direction:column; }
    .hero-actions .btn { width:100%; justify-content:center; font-size:0.88rem; padding:0.82rem 1.2rem; }

    /* Sections */
    section { padding:2.5rem 0; }
    .section-title { margin-bottom:1.75rem; }

    /* Service Cards */
    .service-card { padding:1.35rem 1.15rem; border-radius:var(--r-md); }
    .service-num  { font-size:0.65rem; }
    .service-card h3 { font-size:0.98rem; }

    /* Why / Vorteile */
    .why-item   { padding:1.1rem; gap:0.85rem; }
    .why-icon   { width:44px; height:44px; min-width:44px; font-size:1.1rem; }
    .why-content h3 { font-size:0.95rem; }

    /* Process */
    .process-grid { grid-template-columns:1fr; }
    .process-step { display:flex; gap:1rem; text-align:left; align-items:flex-start; }
    .process-number { margin:0; flex-shrink:0; width:52px; height:52px; font-size:1.2rem; }

    /* Testimonials */
    .testimonial { padding:1.25rem; }
    .testimonial-text { font-size:0.88rem; }

    /* Contact */
    .contact-item { padding:1rem 1.1rem; }
    .contact-icon { width:42px; height:42px; min-width:42px; font-size:1.1rem; }
    .contact-item-content h3 { font-size:0.78rem; }
    .contact-item-content p  { font-size:0.88rem; }
    .contact-form { padding:1.25rem; }
    .form-group label { font-size:0.75rem; }
    .form-group input,
    .form-group textarea,
    .form-group select { padding:0.72rem 0.85rem; font-size:0.88rem; }

    /* CTA */
    .cta-box { padding:1.9rem 1.15rem; border-radius:var(--r-md); }
    .cta-box h2 { font-size:1.35rem; }
    .cta-box p  { font-size:0.9rem; margin-bottom:1.25rem; }
    .cta-box .btn { width:100%; justify-content:center; }

    /* Buttons */
    .btn { padding:0.8rem 1.4rem; font-size:0.88rem; }

    /* WhatsApp */
    .whatsapp-button { width:50px; height:50px; bottom:80px; right:16px; }
    .whatsapp-button svg { width:26px; height:26px; }

    /* Footer */
    .footer { padding:2.5rem 0 0; }
    .footer-section h3 { font-size:0.9rem; }
    .footer-section p,
    .footer-section a { font-size:0.82rem; }
    .footer-bottom { font-size:0.75rem; }
}

/* =====================
   COOKIE BANNER
   ===================== */
.cookie-banner {
    position: fixed;
    bottom: 0; left: 0; right: 0;
    z-index: 9999;
    background: var(--anthrazit);
    border-top: 3px solid var(--blue);
    box-shadow: 0 -8px 32px rgba(0,0,0,0.35);
    padding: 1.25rem 0;
    transform: translateY(100%);
    transition: transform 0.4s cubic-bezier(0.4,0,0.2,1);
}
.cookie-banner.visible { transform: translateY(0); }
.cookie-banner-inner {
    display: flex; align-items: center;
    gap: 1.5rem; flex-wrap: wrap;
}
.cookie-icon { font-size: 2rem; flex-shrink: 0; line-height: 1; }
.cookie-text { flex: 1; min-width: 220px; }
.cookie-text h3 { color: var(--white); font-size: 0.95rem; margin-bottom: 0.3rem; font-weight: 700; }
.cookie-text p  { color: rgba(255,255,255,0.68); font-size: 0.82rem; margin: 0; line-height: 1.55; }
.cookie-text a  { color: var(--accent-light); text-decoration: underline; font-size: 0.82rem; }
.cookie-text a:hover { color: var(--white); }
.cookie-actions { display: flex; gap: 0.65rem; flex-shrink: 0; flex-wrap: wrap; }
.cookie-btn {
    padding: 0.6rem 1.4rem; border-radius: var(--r-sm);
    font-weight: 700; font-size: 0.85rem;
    cursor: pointer; border: none; transition: var(--t); white-space: nowrap;
}
.cookie-btn-accept   { background: var(--accent); color: var(--white); }
.cookie-btn-accept:hover { background: var(--accent-dark); transform: translateY(-1px); }
.cookie-btn-essential {
    background: rgba(255,255,255,0.1); color: rgba(255,255,255,0.85);
    border: 1px solid rgba(255,255,255,0.2) !important;
}
.cookie-btn-essential:hover { background: rgba(255,255,255,0.18); color: var(--white); }
.cookie-btn-reject {
    background: transparent; color: rgba(255,255,255,0.5);
    font-size: 0.78rem; padding: 0.4rem 0.7rem; text-decoration: underline;
}
.cookie-btn-reject:hover { color: rgba(255,255,255,0.85); }

@media (max-width:768px) {
    .cookie-banner-inner { flex-direction:column; align-items:flex-start; gap:0.9rem; }
    .cookie-actions { width:100%; }
    .cookie-btn-accept, .cookie-btn-essential { flex:1; text-align:center; }
}
@media (max-width:480px) {
    .cookie-banner { padding:1rem 0; }
    .cookie-icon { display:none; }
    .cookie-text h3 { font-size:0.88rem; }
    .cookie-text p  { font-size:0.78rem; }
    .cookie-btn { font-size:0.8rem; padding:0.52rem 0.9rem; }
}

/* =====================
   MEHR LEBEN – Animationen
   ===================== */
@keyframes pulse-teal {
    0%, 100% { box-shadow: 0 4px 16px rgba(0,144,151,0.38); }
    50%       { box-shadow: 0 8px 28px rgba(0,144,151,0.65); }
}
.btn-primary { animation: pulse-teal 2.8s ease-in-out infinite; }
.btn-primary:hover, .btn-primary:focus { animation: none; }

/* Kühle Section-Hintergründe */
#leistungen { background: linear-gradient(180deg, #F5FAFB 0%, #E8F1F4 100%); }

/* =====================
   ORTSTEILE / EINSATZORTE
   ===================== */
.ortsteile-section { background: linear-gradient(180deg, #F5FAFB 0%, #E8F1F4 100%); }
.ortsteil-list {
    display: flex; flex-wrap: wrap; gap: 0.7rem;
    justify-content: center; max-width: 900px; margin: 0 auto;
}
.ortsteil-chip {
    display: inline-flex; align-items: center;
    background: #ffffff; border: 1px solid #d8e3e8;
    color: #1E293B; font-size: 1rem; font-weight: 600;
    padding: 0.6rem 1.2rem; border-radius: 30px;
    box-shadow: 0 2px 10px rgba(0,99,149,0.06);
}
.ortsteil-chip::before {
    content: '📍'; margin-right: 0.45rem; font-size: 0.95rem;
}
.ortsteil-chip-main {
    background: linear-gradient(135deg, #009097 0%, #006395 100%);
    color: #ffffff; border-color: transparent;
}

/* =====================
   ORTE-GRID (Hub-Seiten: Liste der Städte/Gemeinden)
   ===================== */
.orte-grid {
    display:grid;
    grid-template-columns:repeat(auto-fill, minmax(190px, 1fr));
    gap:0.85rem;
}
.orte-grid a {
    display:flex; align-items:center; gap:0.6rem;
    background:#fff; border:1px solid #e0e6ea; border-radius:10px;
    padding:0.85rem 1rem; color:var(--anthrazit);
    font-weight:600; font-size:0.97rem;
    transition:all .2s;
}
.orte-grid a::before {
    content:''; flex-shrink:0;
    width:8px; height:8px; border-radius:50%;
    background:var(--blue);
    transition:all .2s;
}
.orte-grid a:hover {
    background:linear-gradient(135deg,#009097 0%,#006395 100%);
    border-color:transparent; color:#fff;
    transform:translateY(-2px);
    box-shadow:0 6px 18px rgba(0,144,151,0.25);
}
.orte-grid a:hover::before { background:#fff; }

/* =====================
   HERO – Einblendung von oben nach unten (gestaffelt)
   ===================== */
@keyframes heroDrop {
    from { opacity: 0; transform: translateY(-28px); }
    to   { opacity: 1; transform: translateY(0); }
}
@media (prefers-reduced-motion: no-preference) {
    .hero-badge,
    .hero h1,
    .hero-subtitle,
    .hero-pills,
    .hero-actions {
        opacity: 0;
        animation: heroDrop 0.7s cubic-bezier(0.22, 0.61, 0.36, 1) both;
    }
    .hero-badge    { animation-delay: 0.10s; }
    .hero h1       { animation-delay: 0.25s; }
    .hero-subtitle { animation-delay: 0.40s; }
    .hero-pills    { animation-delay: 0.55s; }
    .hero-actions  { animation-delay: 0.70s; }
}

/* Topbar Icon-Farbe */
.topbar-item svg { fill: rgba(255,255,255,0.9) !important; }