:root {
    --bg: #fbfaff;
    --text: #1f2937;
    --muted: #6b7280;
    --primary: #7c3aed;
    --secondary: #ec4899;
    --card: #ffffff;
    --soft: #f3e8ff;
    --border: #eadcfb;
    --success: #047857;
    --danger: #b91c1c;
    --shadow: 0 24px 60px rgba(31, 41, 55, .10);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    color: var(--text);
    background: radial-gradient(circle at 20% 0%, #f3e8ff 0%, transparent 34%), var(--bg);
    line-height: 1.6;
}
a { color: inherit; }
.container { width: min(1120px, calc(100% - 36px)); margin: 0 auto; }
.header {
    position: sticky;
    top: 0;
    z-index: 10;
    background: rgba(255,255,255,.82);
    backdrop-filter: blur(16px);
    border-bottom: 1px solid rgba(234, 220, 251, .8);
}
.nav { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 14px 0; }
.logo { display: inline-flex; align-items: center; text-decoration: none; }
.logo img {
    width: 380px;
    max-width: 38vw;
    height: auto;
    display: block;
}
.nav-links { display: flex; gap: 18px; align-items: center; font-size: 15px; }
.nav-links a { text-decoration: none; color: #374151; font-weight: 600; }
.button, button {
    border: 0;
    border-radius: 999px;
    padding: 12px 20px;
    font-weight: 800;
    cursor: pointer;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--primary), var(--secondary));
    color: #fff;
    box-shadow: 0 12px 28px rgba(124,58,237,.25);
}
.button.secondary { background: #fff; color: var(--primary); border: 1px solid var(--border); box-shadow: none; }
.hero { padding: 82px 0 64px; }
.hero-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 38px; align-items: center; }
.eyebrow { color: var(--primary); font-weight: 900; text-transform: uppercase; letter-spacing: .12em; font-size: 13px; }
h1 { font-size: clamp(38px, 6vw, 68px); line-height: 1.03; margin: 12px 0 20px; letter-spacing: -0.055em; }
h2 { font-size: clamp(30px, 4vw, 46px); line-height: 1.1; margin: 0 0 16px; letter-spacing: -0.04em; }
h3 { font-size: 21px; margin: 0 0 8px; }
.lead { font-size: 20px; color: #4b5563; max-width: 700px; }
.hero-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 28px; }
.hero-card {
    background: rgba(255,255,255,.88);
    border: 1px solid var(--border);
    border-radius: 32px;
    padding: 28px;
    box-shadow: var(--shadow);
}
.pulse {
    width: 100%; aspect-ratio: 1/1; border-radius: 32px;
    background: radial-gradient(circle at center, rgba(236,72,153,.18), rgba(124,58,237,.10) 40%, rgba(255,255,255,.9) 70%);
    display: grid; place-items: center; position: relative; overflow: hidden;
}
.pulse::before, .pulse::after {
    content: ""; position: absolute; width: 58%; height: 58%; border: 2px solid rgba(124,58,237,.22); border-radius: 50%;
    animation: pulse 3.2s infinite ease-out;
}
.pulse::after { animation-delay: 1.2s; }
.pulse span { width: 128px; height: 128px; border-radius: 50%; background: linear-gradient(135deg, var(--primary), var(--secondary)); box-shadow: var(--shadow); }
@keyframes pulse { from { transform: scale(.82); opacity: 1; } to { transform: scale(1.75); opacity: 0; } }
.section { padding: 74px 0; }
.section.soft { background: rgba(255,255,255,.62); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 26px; align-items: start; }
.card {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: 26px;
    padding: 24px;
    box-shadow: 0 16px 38px rgba(31,41,55,.07);
}
.card p { color: var(--muted); margin: 0; }
.checklist { list-style: none; padding: 0; margin: 18px 0 0; display: grid; gap: 10px; }
.checklist li { padding-left: 30px; position: relative; color: #374151; }
.checklist li::before { content: "✓"; position: absolute; left: 0; color: var(--primary); font-weight: 900; }
.notice { background: #fffbeb; border: 1px solid #fde68a; padding: 18px; border-radius: 20px; color: #78350f; }
.booking-box { background: #fff; border-radius: 28px; border: 1px solid var(--border); padding: 24px; box-shadow: var(--shadow); }
.booking-controls { display: flex; gap: 10px; flex-wrap: wrap; margin: 18px 0; }
.booking-controls input, .booking-form input, .booking-form textarea {
    width: 100%; border: 1px solid var(--border); border-radius: 16px; padding: 13px 14px; font: inherit; background: #fff;
}
.slots { display: grid; grid-template-columns: repeat(auto-fit, minmax(110px, 1fr)); gap: 10px; margin: 18px 0; }
.slot { border: 1px solid var(--border); background: #fff; color: var(--primary); box-shadow: none; border-radius: 16px; }
.slot[disabled] { opacity: .42; color: #9ca3af; cursor: not-allowed; background: #f9fafb; }
.slot.active { background: linear-gradient(135deg, var(--primary), var(--secondary)); color: white; }
.booking-form { display: grid; gap: 12px; margin-top: 18px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.message { padding: 14px 16px; border-radius: 16px; display: none; }
.message.ok { display: block; background: #ecfdf5; color: var(--success); border: 1px solid #a7f3d0; }
.message.error { display: block; background: #fef2f2; color: var(--danger); border: 1px solid #fecaca; }
.footer { padding: 36px 0; color: var(--muted); border-top: 1px solid var(--border); }
.admin-table { width: 100%; border-collapse: collapse; background: #fff; border-radius: 16px; overflow: hidden; }
.admin-table th, .admin-table td { padding: 12px; border-bottom: 1px solid var(--border); text-align: left; }
.admin-login { max-width: 420px; margin: 80px auto; }
@media (max-width: 860px) {
    .hero-grid, .grid-2, .grid-3 { grid-template-columns: 1fr; }
    .nav { align-items: flex-start; }
    .nav-links { display: none; }
    .form-row { grid-template-columns: 1fr; }
    .hero { padding-top: 48px; }
}


/* Logo auf Mobilgeräten größer, aber passend halten */

@media (max-width: 860px) {
    .logo img {
        width: 250px;
        max-width: 70vw;
    }
}
