:root{
    --bg:#ffffff;        /* page background (white) */
    --panel:#ffffff;     /* default section bg */
    --panel-alt:#fafafb; /* light zebra sections */
    --text:#0f172a;      /* primary text */
    --muted:#6b7280;     /* secondary text */
    --accent:#0ea5a6;    /* CTA accent (teal) */
    --border:#e6e8eb;    /* subtle light border */
    --radius:12px;
    --gap:clamp(16px, 2.5vw, 28px);
    --container:1100px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
    margin:0;
    background:var(--bg);
    color:var(--text);
    font-family:ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans";
    line-height:1.5;
}

/* Utilities */
.container{max-width:var(--container); margin-inline:auto; padding-inline:clamp(16px, 4vw, 28px)}
.section{
    padding:clamp(48px, 8vw, 96px) 0;
    background:var(--panel);
    scroll-margin-top:100px; /* Platz für sticky Header bei Ankern */
}
.section--alt{background:var(--panel-alt)}
.section--highlight{background:linear-gradient(180deg, #ffffff, #f6f7fb)}
.h1{font-size:clamp(28px, 4.2vw, 48px); line-height:1.2; margin:0 0 12px}
.h2{font-size:clamp(22px, 3vw, 32px); line-height:1.25; margin:0 0 12px}
.lead{font-size:clamp(16px, 2.2vw, 20px); color:var(--muted); margin:0 0 16px}
.muted{color:var(--muted)}
.center{text-align:center}

/* Topbar */
.topbar{position:sticky; top:0; z-index:50; background:#ffffff; border-bottom:1px solid var(--border)}
.topbar__inner{display:flex; gap:12px; align-items:center; justify-content:space-between; padding-block:10px}
.topbar__link{color:var(--text); text-decoration:none}
.dot{opacity:.5; margin-inline:8px; color:var(--muted)}

/* Header */
.site-header{
    position: sticky;
    top: 42px;
    z-index: 40;
    backdrop-filter: saturate(180%) blur(6px);
    background: rgba(255,255,255,.75);
    border-bottom: 1px solid var(--border);
}

/* 3-Spalten Layout: Logo | Nav (mittig) | CTA */
.header__inner{
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 16px;
}

/* Logo */
.logo{
    font-weight: 700;
    letter-spacing: .02em;
    text-decoration: none;
    color: var(--text);
}

/* Nav */
.nav{
    margin-left: auto;
    position: relative; /* neu: Dropdown hängt jetzt an der Nav */
}
.nav__toggle{
    display: none;               /* bleibt Desktop-verborgen */
    background: #ffffff;
    border: 1px solid var(--border);
    border-radius: 10px;
    width: 40px; height: 40px;   /* klare Touch-Fläche */
    line-height: 1;
    display: none;               /* Desktop aus */
    align-items: center;
    justify-content: center;
    color: var(--text);
    padding: 0;                  /* kein Innenpadding nötig */
}
.nav__list{
    display: flex;
    align-items: center;
    gap: 22px;                 /* gleichmäßiger Abstand */
    list-style: none;
    margin: 0;
    padding: 0;
    flex-wrap: nowrap;         /* keine hässlichen Zeilenumbrüche */
}
.nav__list li{ display: block; }
.nav__list a{
    display: block;
    padding: 10px 8px;         /* größere Klickfläche */
    white-space: nowrap;       /* „Website Design“ bleibt auf einer Zeile */
    color: var(--text);
    text-decoration: none;
    opacity: .9;
    border-radius: 8px;
}
.nav__list a:hover{
    opacity: 1;
    background: rgba(14,165,166,.08); /* dezentes Hover */
}

/* CTA rechts etwas kompakter */
.btn--soft{ padding: 10px 14px; }

/* Breakpoint: bevor Mobile-Menü greift, etwas enger setzen */
@media (max-width: 1200px){
    .nav__list{ gap: 14px; }
    .btn--soft{ padding: 8px 12px; }
}

/* Mobile-Menü: wie gehabt */
@media (max-width: 960px){
    /* Header Layout: Zeile 1 = Logo | Burger, Zeile 2 = CTA full-width */
    .header__inner{
        display: grid;
        grid-template-columns: 1fr auto;
        grid-template-areas:
      "logo nav"
      "cta  cta";
        align-items: center;
        gap: 12px;
    }
    .logo{ grid-area: logo; }
    .nav{ grid-area: nav; justify-self: end; }
    .header__inner > .btn{
        grid-area: cta;
        justify-self: stretch;
        width: 100%;
        text-align: center;
        padding: 12px 14px;
        border-radius: 12px;
    }

    /* Burger sichtbar */
    .nav__toggle{ display: flex; }

    /* Dropdown: an die Nav „angedockt“, schön breit & mit Schatten */
    .nav__list{
        display: none;
        position: absolute;
        right: 0;
        top: calc(100% + 8px);
        background: #ffffff;
        border: 1px solid var(--border);
        border-radius: 12px;
        padding: 10px;
        flex-direction: column;
        width: min(92vw, 320px);
        gap: 6px;
        box-shadow: 0 12px 26px rgba(2,6,23,.12);
        z-index: 60;
    }
    .nav__list.open{ display: flex; }
    .nav__list a{ padding: 12px; }

    /* Grids wie gehabt einkolumnig */
    .hero__grid, .about__grid, .gallery{ grid-template-columns: 1fr; }
    .cards--3{ grid-template-columns: 1fr; }
    .cards--4{ grid-template-columns: 1fr 1fr; }
    .site-header{ top: 36px; } /* unter der Topbar */
}

/* Buttons */
.btn{display:inline-block; padding:10px 14px; border-radius:10px; border:1px solid var(--accent); color:var(--text); text-decoration:none; background:#ffffff}
.btn--soft{border-color:var(--border); background:#ffffff}
.btn--ghost{border-color:var(--border); background:#ffffff}

/* Hero */
.hero{padding-top:clamp(28px, 6vw, 48px)}
.hero__grid{display:grid; grid-template-columns:1.1fr .9fr; gap:var(--gap); align-items:center}
.hero__media .ph{min-height:260px}
/* Hero: große Schlagzeilen-Liste */
.h1-list{
    /* wie eine H1, nur als Liste */
    font-size: clamp(28px, 4.4vw, 40px);
    line-height: 1.18;
    font-weight: 800;
    letter-spacing: -0.01em;
    margin: 0 0 14px 0;    /* Abstand zur Lead */
    padding-left: 1.15em;  /* Platz für die Bullet-Dots */
    list-style: disc;
    color: var(--text);
}
.h1-list li{ margin: 0 0 6px 0; }

/* damit "Buchungen statt Leerlauf" nicht umbrechen kann */
.nowrap{ white-space: nowrap; }

/* Badges bewusst kleiner halten als die Schlagzeilen */
.badges{
    margin: 14px 0 0;
    color: var(--muted);
    font-size: 0.95rem;   /* kleiner als Standard-Text */
}
.badges li{ margin: 0 0 6px; }

/* Cards */
.cards{display:grid; gap:var(--gap)}
.cards--3{grid-template-columns:repeat(3,1fr)}
.cards--4{grid-template-columns:repeat(4,1fr)}
.card{background:#ffffff; border:1px dashed var(--border); border-radius:var(--radius); padding:18px}
.card h3{margin:0 0 8px}

/* Steps */
.steps{display:grid; gap:10px; padding:0; margin:0 0 12px}
.steps li{list-style:none; background:#ffffff; border:1px dashed var(--border); border-radius:var(--radius); padding:14px 16px}

/* Gallery */
.gallery{display:grid; grid-template-columns:1fr 1fr; gap:var(--gap)}

/* About */
.about__grid{display:grid; grid-template-columns:.9fr 1.1fr; gap:var(--gap); align-items:center}

/* Footer */
.site-footer{background:#f7f8fa; border-top:1px solid var(--border)}
.footer__grid{display:grid; grid-template-columns:1.2fr .8fr; gap:var(--gap); padding-block:22px}
.footer__title{margin:0 0 6px}
.footer__links{list-style:none; display:grid; gap:6px; padding:0; margin:0}
.footer__links a{color:var(--text); text-decoration:none; opacity:.85}
.footer__links a:hover{opacity:1}

/* Platzhalter (visuelle Boxen statt Bilder) */
.ph{display:grid; place-items:center; min-height:180px; border:1px dashed var(--border); border-radius:var(--radius); color:#98a2b3; font-size:14px; background:#ffffff}
.ph--collage{min-height:320px}

/* FAQ */
.faq{background:#ffffff; border:1px dashed var(--border); border-radius:var(--radius); padding:12px 14px; margin:10px 0}
.faq>summary{cursor:pointer}

/* Responsive */
@media (max-width:960px){
    .nav__toggle{display:inline-block}
    .nav__list{display:none; position:absolute; right:16px; top:100%; background:#ffffff; border:1px solid var(--border); border-radius:10px; padding:10px; flex-direction:column; width:min(90vw, 320px)}
    .nav__list.open{display:flex}
    .hero__grid, .about__grid, .gallery{grid-template-columns:1fr}
    .cards--3{grid-template-columns:1fr}
    .cards--4{grid-template-columns:1fr 1fr}
    .site-header{top:36px}
}

/* Motion respect & Focus */
@media (prefers-reduced-motion:reduce){
    *{animation:none !important; transition:none !important}
}
.nav__toggle:focus-visible,
.nav__list a:focus-visible,
.btn:focus-visible{
    outline:2px solid var(--accent);
    outline-offset:2px;
    border-radius:10px;
}

/* === Hero linksbündig ausrichten (nur Hero, Rest bleibt zentriert) === */
.hero .container{
    margin-left: 10px;      /* un-centert die Container-Breite links */
    margin-right: auto;  /* Platz bleibt nach rechts offen */
}

/* etwas kontrollierteres Spaltenverhältnis auf großen Screens */
@media (min-width: 961px){
    .hero__grid{
        grid-template-columns: minmax(520px, 700px) 1fr; /* Text-Spalte breiter, bleibt links */
        /* optional mehr Abstand: gap: clamp(24px, 5vw, 56px); */
    }
}

/* === DENSITY TUNING: mehr Inhalt sichtbar, weniger Weißraum === */

/* 1) Mehr Inhaltbreite + weniger Seiten-Padding */
:root{ --container: 1280px; }                 /* vorher 1100px */
.container{ padding-inline: clamp(10px, 1.8vw, 18px); }

/* 2) Sections generell dichter – Hero bleibt großzügig */
.section{ padding-block: clamp(32px, 5vw, 56px); }    /* vorher 48–96 */
.hero.section{ padding-block: clamp(48px, 7vw, 90px); } /* Hero „groß“ */

/* 3) Überschriften/Intro etwas kompakter */
.h2{ margin: 0 0 6px; }
.muted{ margin: 0 0 12px; }   /* <— wichtig: kein Zeichen nach dem ; */

/* 4) Karten & Grids dichter */
.cards{ gap: clamp(10px, 1.6vw, 18px); }
.card{ padding: 12px 14px; }  /* vorher 18px */

/* 5) Steps etwas knapper */
.steps{ gap: 8px; }
.steps li{ padding: 10px 14px; }

/* 6) Galerie/Platzhalter leicht straffen */
.gallery{ gap: clamp(12px, 2vw, 20px); }
.ph{ min-height: 160px; }

/* Hero linksbündig beibehalten (falls gewünscht) */
.hero .container{ margin-left: 10px; margin-right: auto; }

@media (min-width: 961px){
    .hero__grid{
        grid-template-columns: minmax(520px, 700px) 1fr;
    }
}