:root{
    --bg-weak: #0b1020;
    --primary: #0fb26b; /* motherboard green */
    --accent: #a8ff7a; /* soft lime */
    --muted: #95a1a3;
    --card-bg: rgba(255,255,255,0.96);
    --text: #072127;
    --success: #0fb26b;
    --border: #e0e0e0;
    --light: #f8fffc;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html {
    scroll-behavior: smooth;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-size-adjust: 100%;
    height: 100%;
}

body {
    margin: 0;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    /* mainboard background image chosen to match the tech theme */
    background: linear-gradient(180deg, rgba(2,6,10,0.45), rgba(2,6,10,0.45)), url('https://images.unsplash.com/photo-1518770660439-4636190af475?auto=format&fit=crop&w=1600&q=60') center/cover no-repeat fixed;
    background-attachment: fixed;
    font-family: 'Segoe UI', Roboto, -apple-system, BlinkMacSystemFont, 'Helvetica Neue', Arial, sans-serif;
    box-sizing: border-box;
    padding-top: 80px; /* space for fixed header */
    color: var(--text);
    line-height: 1.6;
}

main {
    flex: 1 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
}

.box {
    flex: 1 0 auto;
}

.box {
    width: min(1040px, 94%);
    display: flex;
    text-align: center;
    align-items: center;
    justify-content: center;
    background: linear-gradient(180deg, rgba(5,28,20,0.95), rgba(2,18,14,0.95));
    box-shadow: 0 18px 60px rgba(2,8,6,0.6);
    border-radius: 20px;
    padding: 72px 56px;
    color: #fff;
}

/* Trust Badges on Homepage */
.trust-badges {
    display: flex;
    gap: 16px;
    justify-content: center;
    flex-wrap: wrap;
    margin: 24px 0;
}

.trust-badge {
    display: flex;
    align-items: center;
    gap: 8px;
    background: rgba(15,178,107,0.15);
    border: 2px solid rgba(15,178,107,0.3);
    border-radius: 999px;
    padding: 10px 18px;
    transition: all 0.2s ease;
}

.trust-badge:hover {
    background: rgba(15,178,107,0.25);
    border-color: rgba(15,178,107,0.5);
    transform: translateY(-2px);
}

.badge-icon {
    font-size: 1.2rem;
    color: var(--accent);
    font-weight: 900;
}

.badge-text {
    color: white;
    font-weight: 700;
    font-size: 0.9rem;
    white-space: nowrap;
}

@media (max-width: 600px) {
    .trust-badges {
        gap: 10px;
    }
    .trust-badge {
        padding: 8px 14px;
    }
    .badge-text {
        font-size: 0.85rem;
    }
}

.site-header {
    position: fixed;
    top: 12px;
    left: 50%;
    transform: translateX(-50%);
    width: min(1100px, 96%);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    background: var(--card-bg);
    padding: 10px 16px;
    border-radius: 12px;
    box-shadow: 0 10px 30px rgba(4,23,33,0.06);
    z-index: 1100;
}
.site-header .logo { display:flex; align-items:center; gap:10px; text-decoration:none; color:var(--text); }
.site-header .logo img { height:34px; width:34px; }
.site-header .logo .brand { font-weight:800; letter-spacing:0.2px; }
.main-nav { display:flex; align-items:center; position:relative; }
.main-nav ul { list-style:none; margin:0; padding:0; display:flex; gap:18px; align-items:center; }
.main-nav a { text-decoration:none; color:var(--text); font-weight:700; padding:6px 10px; border-radius:8px; }
.main-nav a:hover { background: rgba(11,135,147,0.06); }

.menu-toggle { display:none; background:none; border:none; font-size:1.5rem; cursor:pointer; color:var(--text); }

.mobile-menu { display:none; position:fixed; top:60px; left:0; right:0; background:white; flex-direction:column; gap:8px; padding:16px; box-shadow:0 4px 12px rgba(0,0,0,0.1); z-index:100; }
.mobile-menu.active { display:flex; }
.mobile-menu a { text-decoration:none; color:var(--text); font-weight:700; padding:12px 16px; border-radius:8px; border:2px solid rgba(15,178,107,0.1); display:block; }
.mobile-menu a:hover { background: rgba(15,178,107,0.08); border-color:var(--primary); }

.text1 {
    font-weight: 700;
    font-size: clamp(1.1rem, 2.4vw, 1.8rem);
    line-height: 1.25;
    margin: 0;
}

.btn {
    display: inline-block;
    background: var(--accent);
    color: #072127;
    padding: 10px 16px;
    border-radius: 10px;
    text-decoration: none;
    font-weight: 800;
    box-shadow: 0 8px 18px rgba(11,135,147,0.08);
}
.btn:hover { transform: translateY(-1px); }

/* special hero button style for homepage */
.hero-btn {
    background: transparent;
    color: var(--primary);
    border: 2px solid var(--primary);
    padding: 14px 22px;
    font-size: 1.05rem;
    border-radius: 999px;
    box-shadow: 0 10px 30px rgba(15,178,107,0.08);
    transition: transform .12s ease, background .12s ease, color .12s ease;
}
.hero-btn:hover { background: var(--primary); color: #04231c; transform: translateY(-3px); }

/* Booking form and contact form styles */
.form-card {
    width: min(760px, 94%);
    margin: 36px auto;
    background: var(--card-bg);
    padding: 20px 22px;
    border-radius: 12px;
    box-shadow: 0 12px 34px rgba(4,23,33,0.06);
    color: var(--text);
}
.form-row { display:flex; gap:12px; flex-wrap:wrap; }
.form-row input[type="text"], .form-row input[type="email"], .form-row input[type="date"], .form-row input[type="time"], textarea {
    flex:1 1 220px;
    padding:10px 12px;
    border:1px solid #ddd;
    border-radius:8px;
    font-size:0.95rem;
}
textarea { min-height:120px; resize:vertical; }
.form-actions { text-align:right; margin-top:12px; }
.form-actions .btn { background:#1f8feb; }
.form-actions .btn:hover {cursor: pointer;}

@media (max-width: 480px) {
    .main-nav ul { gap: 6px; font-size: 0.85rem; }
    .main-nav a { padding: 4px 6px; font-size: 0.85rem; }
    .text1 { font-size: 1rem; line-height: 1.3; }
    .box { padding: 20px 16px; }
    .site-header { padding: 8px 12px; top: 8px; }
    .site-header .logo img { height: 28px; width: 28px; }
    .site-header .logo .brand { font-size: 0.9rem; }
    .trust-badge { padding: 6px 10px; }
    .badge-text { font-size: 0.75rem; }
    .btn.hero-btn { padding: 10px 16px; font-size: 0.9rem; }
    .form-card { padding: 16px; }
    .form-card h2 { font-size: 1.4rem; }
}

/* About page with photo styling */
.about-intro-with-photo { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; align-items: center; margin-bottom: 32px; }
@media (max-width: 768px) { .about-intro-with-photo { grid-template-columns: 1fr; gap: 24px; } }

.about-photo-section { text-align: center; }
.about-photo { width: 100%; max-width: 320px; border-radius: 12px; box-shadow: 0 12px 40px rgba(15,178,107,0.2); border: 3px solid rgba(15,178,107,0.15); object-fit: cover; }

/* Reviews ticker styles */
.reviews-ticker { width:100%; overflow:hidden; margin:20px 0 8px; }
.reviews-track { display:flex; gap:18px; align-items:center; padding:12px 6px; }
.review-pill { background: var(--card-bg); color: var(--text); padding:10px 14px; border-radius:999px; white-space:nowrap; font-weight:600; box-shadow: 0 6px 20px rgba(2,8,6,0.06); border: 1px solid rgba(2,8,6,0.04); }
.reviews-track.anim { animation: scroll-left 18s linear infinite; }

@keyframes scroll-left { from { transform: translateX(0);} to { transform: translateX(-50%);} }

/* Custom select styling */
.custom-select-wrap { position: relative; display:inline-block; }
.custom-select { appearance:none; -webkit-appearance:none; -moz-appearance:none; padding:10px 36px 10px 12px; border-radius:10px; border:1px solid rgba(2,8,6,0.06); background: var(--card-bg); color: var(--text); font-weight:700; }
.custom-select::placeholder{ color:var(--muted); }
.custom-select-wrap::after{ content:'▾'; position:absolute; right:10px; top:50%; transform:translateY(-50%); pointer-events:none; color:var(--primary); font-weight:800; }

/* Chat widget */
.chat-widget-btn{ position:fixed; right:18px; bottom:18px; width:64px; height:64px; border-radius:50%; background:var(--primary); display:flex; align-items:center; justify-content:center; box-shadow:0 14px 40px rgba(6,20,16,0.5); z-index:2000; cursor:pointer; border:none; transition: all 0.2s ease; }
.chat-widget-btn:hover{ transform: scale(1.1); box-shadow:0 20px 50px rgba(6,20,16,0.6); }
.chat-widget-btn img{ width:34px; height:34px; background:transparent; object-fit:contain; }
.chat-popup{ position:fixed; right:18px; bottom:96px; width:340px; max-width:92vw; background:var(--card-bg); border-radius:12px; box-shadow:0 20px 50px rgba(2,8,6,0.5); z-index:2000; display:none; flex-direction:column; overflow:hidden; }
.chat-header{ padding:10px 12px; background:linear-gradient(90deg, var(--primary), rgba(15,178,107,0.9)); color:#04231c; font-weight:800; display:flex; align-items:center; justify-content:space-between; }
.chat-header-actions{ display:flex; gap:6px; }
.chat-close, .chat-clear{ background:transparent; border:0; font-size:18px; line-height:1; padding:6px 8px; cursor:pointer; color:#000; border-radius:0; }
.chat-close:hover, .chat-clear:hover{ background: transparent; }

/* Quick reply buttons at top of chat */
.chat-quick-replies{ display:grid; grid-template-columns: 1fr 1fr; gap:8px; padding:8px; border-bottom:1px solid rgba(0,0,0,0.06); background:rgba(255,255,255,0.4); }
.chat-quick-btn{ background: linear-gradient(135deg, rgba(15,178,107,0.14), rgba(168,255,122,0.08)); color:#04231c; border:1px solid rgba(15,178,107,0.2); padding:10px 8px; border-radius:8px; font-weight:700; font-size:0.85rem; cursor:pointer; transition: all .12s ease; white-space:nowrap; text-overflow:ellipsis; overflow:hidden; }
.chat-quick-btn:hover{ background: linear-gradient(135deg, rgba(15,178,107,0.22), rgba(168,255,122,0.14)); transform:translateY(-1px); box-shadow:0 8px 16px rgba(2,8,6,0.08); border-color:rgba(15,178,107,0.3); }
.chat-quick-btn:active{ transform:translateY(0); }

.chat-body{ padding:12px; height:240px; overflow:auto; background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0.02)); }

/* Typing indicator spinner */
.chat-typing{ display:none; align-items:center; gap:6px; padding:12px; }
.chat-typing span{ width:8px; height:8px; border-radius:50%; background:var(--primary); animation: typing 1.4s infinite; }
.chat-typing span:nth-child(2){ animation-delay:0.2s; }
.chat-typing span:nth-child(3){ animation-delay:0.4s; }
@keyframes typing{ 0%, 60%, 100%{ transform:translateY(0); opacity:0.6; } 30%{ transform:translateY(-8px); opacity:1; } }

.chat-input{ display:flex; gap:8px; padding:10px; border-top:1px solid rgba(0,0,0,0.06); }
.chat-input input{ flex:1; padding:8px 10px; border-radius:8px; border:1px solid #ddd; }
.chat-msg{ margin:8px 0; padding:8px 10px; border-radius:8px; max-width:82%; }
.chat-msg.user{ background:var(--accent); color:#04231c; margin-left:auto; }
.chat-msg.bot{ background: var(--card-bg); color: var(--text); border:1px solid rgba(2,8,6,0.06); box-shadow: 0 6px 18px rgba(2,8,6,0.06); }

/* Chat Bewertung */
.chat-rating{ margin-top:8px; padding-top:6px; border-top:1px solid rgba(0,0,0,0.04); font-size:0.85rem; display:flex; gap:8px; align-items:center; }
.rating-btn{ background: transparent; border:none; font-size:1rem; cursor:pointer; padding:2px 6px; border-radius:4px; transition: background .12s ease; }
.rating-btn:hover{ background: rgba(15,178,107,0.1); }

/* Chat Footer mit Kontakt-Buttons */
.chat-footer{ display:flex; gap:6px; padding:8px; border-top:1px solid rgba(0,0,0,0.06); background:rgba(255,255,255,0.5); justify-content:space-between; }
.chat-contact-btn{ flex:1; background: rgba(15,178,107,0.12); color:#04231c; border:1px solid rgba(15,178,107,0.18); padding:8px 6px; border-radius:6px; font-weight:700; font-size:0.75rem; cursor:pointer; transition: all .12s ease; }
.chat-contact-btn:hover{ background: rgba(15,178,107,0.18); box-shadow:0 6px 16px rgba(15,178,107,0.12); transform:translateY(-1px); }
.chat-contact-btn:active{ transform:translateY(0); }

/* Suggestion buttons inside bot messages */
.chat-suggestions{ margin-top:8px; display:flex; gap:8px; flex-wrap:wrap; }
.chat-suggestion{ background: rgba(15,178,107,0.10); color:#04231c; border:1px solid rgba(15,178,107,0.18); padding:6px 10px; border-radius:999px; font-weight:800; font-size:0.9rem; cursor:pointer; box-shadow:0 6px 18px rgba(2,8,6,0.04); transition: transform .08s ease, box-shadow .12s ease, background .12s ease; }
.chat-suggestion:hover{ transform: translateY(-2px); background: rgba(15,178,107,0.16); box-shadow:0 10px 22px rgba(2,8,6,0.08); }
.chat-suggestion:active{ transform: translateY(0); }
.chat-suggestion:focus{ outline:2px solid rgba(15,178,107,0.14); outline-offset:2px; }

/* About page styling */
.about-intro, .about-mission, .about-services, .about-values, .about-booking, .about-cta{ margin-bottom: 28px; }
.about-intro h3, .about-mission h3, .about-services h3, .about-values h3, .about-booking h3{ color: var(--primary); margin-bottom: 12px; font-size: 1.3rem; }
.about-intro p:first-of-type{ font-weight: 700; color: var(--muted); font-size: 0.95rem; }
.service-list{ list-style: none; padding: 0; margin: 12px 0; }
.service-list li{ padding: 10px 0; padding-left: 24px; position: relative; line-height: 1.5; }
.service-list li:before{ content: "✓"; position: absolute; left: 0; color: var(--primary); font-weight: bold; font-size: 1.1rem; }
.about-values p{ margin: 10px 0; }
.about-cta{ text-align: center; padding: 20px; background: linear-gradient(135deg, rgba(15,178,107,0.08), rgba(168,255,122,0.04)); border-radius: 12px; }

/* Services Grid */
.services-grid{ display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 16px; margin: 24px 0; }
.service-card{ background: linear-gradient(135deg, rgba(255,255,255,0.97), rgba(248,255,252,0.98)); border: 1px solid rgba(15,178,107,0.15); border-radius: 12px; padding: 20px; text-align: center; transition: all 0.2s ease; box-shadow: 0 6px 20px rgba(2,8,6,0.06); }
.service-card:hover{ transform: translateY(-4px); border-color: rgba(15,178,107,0.3); box-shadow: 0 12px 32px rgba(15,178,107,0.12); }
.service-icon{ font-size: 2.4rem; margin-bottom: 12px; }
.service-card h3{ color: var(--text); font-size: 1.2rem; margin: 12px 0; }
.service-desc{ color: var(--muted); font-size: 0.95rem; margin: 10px 0 16px 0; line-height: 1.4; }
.service-pricing{ display: flex; justify-content: space-around; margin: 16px 0; padding: 12px 0; border-top: 1px solid rgba(15,178,107,0.1); border-bottom: 1px solid rgba(15,178,107,0.1); }
.price{ font-weight: 700; color: var(--primary); font-size: 1.1rem; }
.duration{ color: var(--muted); font-size: 0.9rem; }
.service-btn{ display: inline-block; margin-top: 12px; padding: 8px 16px; background: linear-gradient(90deg, var(--primary), rgba(15,178,107,0.9)); color: white; border-radius: 8px; text-decoration: none; font-weight: 700; font-size: 0.9rem; transition: all 0.2s ease; }
.service-btn:hover{ box-shadow: 0 8px 20px rgba(15,178,107,0.3); transform: translateY(-2px); }

/* Pricing Info Box */
.pricing-info{ background: linear-gradient(135deg, rgba(15,178,107,0.08), rgba(168,255,122,0.05)); border-left: 4px solid var(--primary); border-radius: 8px; padding: 20px; margin: 24px 0; }
.pricing-info h3{ color: var(--primary); margin-bottom: 12px; }
.pricing-info ul li{ padding: 8px 0; color: var(--text); }

/* CTA Section */
.cta-section{ text-align: center; padding: 24px; background: linear-gradient(135deg, rgba(15,178,107,0.05), rgba(168,255,122,0.03)); border-radius: 12px; margin: 24px 0; }
.cta-section h3{ color: var(--primary); margin-bottom: 8px; }

/* Booking Styles */
.booking-container{ display: grid; grid-template-columns: 1fr 1fr; gap: 32px; margin: 24px 0; }
@media (max-width: 900px){ .booking-container{ grid-template-columns: 1fr; } }

.calendar-section{ background: linear-gradient(135deg, rgba(15,178,107,0.05), rgba(168,255,122,0.03)); border: 1px solid rgba(15,178,107,0.2); border-radius: 12px; padding: 20px; }
.calendar-section h3{ color: var(--primary); margin-bottom: 16px; }

.calendar-nav{ display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; }
.calendar-month{ font-weight: 700; color: var(--text); font-size: 1.1rem; text-transform: capitalize; }
.calendar-btn{ background: var(--primary); color: white; border: none; padding: 6px 12px; border-radius: 6px; cursor: pointer; font-weight: 700; font-size: 0.9rem; transition: all 0.2s; }
.calendar-btn:hover{ background: rgba(15,178,107,0.8); }

.calendar-grid{ display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; }
.calendar-weekday{ font-weight: 700; color: var(--primary); text-align: center; padding: 8px; font-size: 0.85rem; }
.calendar-day{ padding: 12px 8px; background: white; border: 2px solid rgba(15,178,107,0.2); border-radius: 6px; cursor: pointer; font-weight: 600; color: var(--text); transition: all 0.2s; }
.calendar-day:not(.disabled):hover{ border-color: var(--primary); background: linear-gradient(135deg, rgba(15,178,107,0.1), rgba(168,255,122,0.05)); }
.calendar-day.available{ border-color: var(--primary); background: rgba(15,178,107,0.05); }
.calendar-day.available:hover{ background: rgba(15,178,107,0.15); }
.calendar-day.disabled{ opacity: 0.4; cursor: not-allowed; background: #f5f5f5; }
.calendar-day.full{ background: rgba(200,200,200,0.2); border-color: var(--muted); }

.booking-form-section h3{ color: var(--primary); margin-top: 24px; margin-bottom: 16px; font-size: 1.1rem; }
.booking-form-section h3:first-of-type{ margin-top: 0; }

.time-slots{ margin: 20px 0; padding: 16px; background: rgba(15,178,107,0.05); border-radius: 8px; }
.time-slots h4{ color: var(--primary); margin-bottom: 12px; margin-top: 0; }
.time-grid{ display: grid; grid-template-columns: repeat(auto-fit, minmax(80px, 1fr)); gap: 8px; }
.time-slot{ padding: 10px; background: white; border: 2px solid rgba(15,178,107,0.3); border-radius: 6px; cursor: pointer; font-weight: 600; color: var(--text); transition: all 0.2s; }
.time-slot:hover:not(.booked){ background: rgba(15,178,107,0.1); border-color: var(--primary); }
.time-slot.active{ background: var(--primary); color: white; border-color: var(--primary); }
.time-slot.booked{ opacity: 0.4; cursor: not-allowed; background: #e0e0e0; }

.booking-status{ background: rgba(168,255,122,0.1); border-left: 3px solid var(--accent); padding: 12px; border-radius: 6px; margin: 20px 0; }
.booking-status p{ margin: 0; }

.booking-info{ background: rgba(15,178,107,0.05); border-left: 4px solid var(--primary); padding: 20px; border-radius: 8px; margin-top: 24px; }
.booking-info h3{ color: var(--primary); margin-top: 0; margin-bottom: 12px; }
.booking-info ol{ margin: 12px 0; padding-left: 24px; color: var(--text); }
.booking-info li{ margin-bottom: 8px; }
.booking-info p{ margin: 12px 0; color: var(--text); }

/* Thank You Page Styling */
.thank-you-card {
    width: min(520px, 94%);
    margin: 48px auto;
    background: var(--card-bg);
    border-radius: 16px;
    padding: 48px 32px;
    text-align: center;
    box-shadow: 0 20px 50px rgba(2,8,6,0.15);
    animation: slideUp 0.5s ease;
}

@keyframes slideUp {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}

.thank-you-icon {
    font-size: 4rem;
    margin-bottom: 20px;
    animation: bounce 0.6s ease;
}

@keyframes bounce {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.1); }
}

.thank-you-card h1 {
    color: var(--primary);
    font-size: 2rem;
    margin: 0 0 12px 0;
}

.thank-you-subtitle {
    color: var(--muted);
    font-size: 1.05rem;
    margin-bottom: 32px;
}

.thank-you-content {
    text-align: left;
    margin: 32px 0;
    background: rgba(15,178,107,0.05);
    border-radius: 12px;
    padding: 24px;
}

.check-item {
    display: flex;
    gap: 16px;
    margin-bottom: 20px;
    align-items: flex-start;
}

.check-item:last-child { margin-bottom: 0; }

.check-icon {
    font-size: 1.8rem;
    min-width: 40px;
    display: flex;
    align-items: center;
}

.check-item h3 {
    color: var(--text);
    margin: 0 0 6px 0;
    font-size: 1rem;
}

.check-item p {
    color: var(--muted);
    margin: 0;
    font-size: 0.95rem;
    line-height: 1.4;
}

.thank-you-actions {
    display: flex;
    gap: 12px;
    margin: 32px 0;
    flex-wrap: wrap;
    justify-content: center;
}

/* Buttons */
.btn, .btn-primary, .btn-secondary {
    display: inline-block;
    padding: 12px 24px;
    border-radius: 8px;
    text-decoration: none;
    font-weight: 700;
    font-size: 0.95rem;
    transition: all 0.2s ease;
    border: none;
    cursor: pointer;
    text-align: center;
    min-height: 44px; /* Touch-friendly minimum */
    line-height: 1.4;
}

.btn-primary {
    background: linear-gradient(135deg, var(--primary), rgba(15,178,107,0.9));
    color: white;
    box-shadow: 0 6px 18px rgba(15,178,107,0.25);
}

.btn-primary:hover, .btn-primary:focus {
    transform: translateY(-2px);
    box-shadow: 0 10px 28px rgba(15,178,107,0.35);
    outline: 2px solid var(--primary);
    outline-offset: 2px;
}

.btn-primary:active {
    transform: translateY(0);
}

.btn-secondary {
    background: rgba(15,178,107,0.12);
    color: var(--primary);
    border: 2px solid rgba(15,178,107,0.25);
}

.btn-secondary:hover, .btn-secondary:focus {
    background: rgba(15,178,107,0.18);
    border-color: var(--primary);
    transform: translateY(-2px);
    outline: 2px solid var(--primary);
    outline-offset: 2px;
}

.btn-secondary:active {
    transform: translateY(0);
}

.thank-you-footer {
    margin-top: 32px;
    padding-top: 24px;
    border-top: 1px solid rgba(15,178,107,0.1);
    color: var(--text);
    font-size: 0.95rem;
}

.link-green {
    color: var(--primary);
    text-decoration: none;
    font-weight: 700;
    transition: all 0.2s ease;
}

.link-green:hover {
    text-decoration: underline;
}

@media (max-width: 480px) {
    .thank-you-card { padding: 32px 20px; }
    .thank-you-card h1 { font-size: 1.5rem; }
    .thank-you-actions { flex-direction: column; }
    .btn-primary, .btn-secondary { width: 100%; text-align: center; }
}

/* FAQ Page Styling */
.faq-section { margin-bottom: 32px; width: 100%; max-width: 100%; }
.faq-section h3 { color: var(--primary); margin-bottom: 16px; font-size: 1.3rem; }

.faq-item { 
    background: rgba(15,178,107,0.05); 
    border: 1px solid rgba(15,178,107,0.15); 
    border-radius: 8px; 
    margin-bottom: 12px; 
    overflow: hidden; 
    width: 100%; 
    max-width: 100%;
    box-sizing: border-box; 
}

.faq-item summary { 
    padding: 16px 20px; 
    cursor: pointer; 
    font-weight: 700; 
    color: var(--text); 
    font-size: 1rem; 
    list-style: none; 
    transition: all 0.2s ease; 
    display: flex; 
    align-items: center; 
    width: 100%; 
    box-sizing: border-box; 
}

.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::before { content: '+'; margin-right: 12px; font-size: 1.3rem; color: var(--primary); font-weight: 700; flex-shrink: 0; width: 20px; }
.faq-item[open] summary::before { content: '−'; }
.faq-item summary:hover { background: rgba(15,178,107,0.08); }

.faq-answer { 
    padding: 0 20px 20px 52px; 
    color: var(--text); 
    line-height: 1.6; 
    width: 100%; 
    max-width: 100%;
    box-sizing: border-box; 
    word-wrap: break-word; 
    overflow-wrap: break-word;
}

.faq-answer p { margin: 8px 0; max-width: 100%; }
.faq-answer ul { margin: 12px 0; padding-left: 24px; max-width: 100%; list-style-position: outside; }
.faq-answer li { margin-bottom: 8px; word-wrap: break-word; max-width: 100%; }
.faq-answer strong { color: var(--primary); }
.faq-answer a { color: var(--primary); text-decoration: none; font-weight: 700; }
.faq-answer a:hover { text-decoration: underline; }

.faq-cta { text-align: center; padding: 32px 24px; background: linear-gradient(135deg, rgba(15,178,107,0.08), rgba(168,255,122,0.05)); border-radius: 12px; margin-top: 32px; }
.faq-cta h3 { color: var(--primary); margin-bottom: 8px; }

/* Pricing Page Styling */
.pricing-table { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 20px; margin: 32px 0; }

.pricing-card { background: linear-gradient(135deg, rgba(255,255,255,0.98), rgba(248,255,252,0.98)); border: 2px solid rgba(15,178,107,0.15); border-radius: 12px; overflow: hidden; transition: all 0.3s ease; }
.pricing-card:hover { transform: translateY(-6px); border-color: rgba(15,178,107,0.4); box-shadow: 0 16px 40px rgba(15,178,107,0.15); }

.pricing-card-highlight { border-color: var(--primary); border-width: 3px; }
.pricing-card-highlight .pricing-header { background: linear-gradient(135deg, var(--primary), rgba(15,178,107,0.9)); }

.pricing-header { background: linear-gradient(135deg, rgba(15,178,107,0.12), rgba(168,255,122,0.08)); padding: 24px 20px; text-align: center; }
.pricing-icon { font-size: 2.5rem; display: block; margin-bottom: 8px; }
.pricing-header h3 { color: var(--text); margin: 0; font-size: 1.2rem; }

.pricing-body { padding: 24px 20px; }
.pricing-price { font-size: 2rem; font-weight: 800; color: var(--primary); text-align: center; margin-bottom: 8px; }
.pricing-duration { text-align: center; color: var(--muted); font-size: 0.9rem; margin-bottom: 20px; }
.pricing-features { list-style: none; padding: 0; margin: 0; }
.pricing-features li { padding: 8px 0; padding-left: 28px; position: relative; color: var(--text); }
.pricing-features li::before { content: '✓'; position: absolute; left: 0; color: var(--primary); font-weight: 900; }

.pricing-info-box { background: linear-gradient(135deg, rgba(15,178,107,0.08), rgba(168,255,122,0.05)); border-left: 4px solid var(--primary); border-radius: 8px; padding: 24px; margin: 32px 0; }
.pricing-info-box h3 { color: var(--primary); margin-top: 0; margin-bottom: 20px; }

.pricing-info-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 20px; }
.pricing-info-item { display: flex; gap: 12px; align-items: flex-start; }
.info-icon { font-size: 1.5rem; color: var(--primary); font-weight: 900; min-width: 24px; }
.pricing-info-item h4 { margin: 0 0 4px 0; color: var(--text); font-size: 1rem; }
.pricing-info-item p { margin: 0; color: var(--muted); font-size: 0.9rem; line-height: 1.4; }

.pricing-guarantee { background: rgba(168,255,122,0.1); border: 2px solid rgba(168,255,122,0.3); border-radius: 12px; padding: 24px; margin: 32px 0; text-align: center; }
.pricing-guarantee h3 { color: var(--primary); margin-top: 0; }
.pricing-guarantee p { margin: 12px 0; color: var(--text); line-height: 1.6; }

/* Kontakt Seite Styles */
.contact-options {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 20px;
    margin-bottom: 40px;
}

.contact-card {
    background: linear-gradient(135deg, var(--light) 0%, #f8f9fa 100%);
    border: 2px solid var(--border);
    border-radius: 16px;
    padding: 28px 20px;
    text-align: center;
    text-decoration: none;
    color: var(--text);
    transition: all 0.3s ease;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    position: relative;
}

.contact-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 20px rgba(74, 144, 226, 0.2);
    border-color: var(--primary);
}

.contact-card-primary {
    background: linear-gradient(135deg, #e8f4fd 0%, #d4ebf9 100%);
    border-color: var(--primary);
}

.contact-card-primary:hover {
    background: linear-gradient(135deg, #d4ebf9 0%, #c0e3f7 100%);
}

.contact-icon {
    font-size: 2.5rem;
    margin-bottom: 8px;
}

.contact-card h3 {
    font-size: 1.3rem;
    margin: 0;
    color: var(--text);
}

.contact-detail {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--primary);
    margin: 4px 0;
}

.contact-desc {
    font-size: 0.85rem;
    color: var(--muted);
    margin: 0;
}

.contact-badge {
    background: var(--success);
    color: white;
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 0.75rem;
    font-weight: 600;
    margin-top: 8px;
}

.contact-hours {
    background: linear-gradient(135deg, #fff9e6 0%, #fff3d4 100%);
    border: 2px solid #ffd966;
    border-radius: 16px;
    padding: 28px;
    margin-bottom: 32px;
}

.contact-hours h3 {
    text-align: center;
    margin-bottom: 20px;
    color: var(--text);
}

.hours-grid {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.hours-item {
    background: white;
    border-radius: 10px;
    padding: 16px;
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 8px;
    align-items: center;
    box-shadow: 0 2px 8px rgba(0,0,0,0.05);
}

.hours-item-closed {
    opacity: 0.6;
}

.hours-day {
    font-weight: 600;
    color: var(--text);
    grid-column: 1 / -1;
}

.hours-time {
    color: var(--primary);
    font-weight: 600;
    font-size: 1.1rem;
}

.hours-note {
    color: var(--muted);
    font-size: 0.85rem;
    font-style: italic;
}

.contact-area {
    background: linear-gradient(135deg, #e8f9e8 0%, #d4f1d4 100%);
    border: 2px solid var(--success);
    border-radius: 16px;
    padding: 28px;
    margin-bottom: 32px;
}

.contact-area h3 {
    text-align: center;
    margin-bottom: 12px;
    color: var(--text);
}

.contact-form-section {
    background: var(--light);
    border: 2px solid var(--border);
    border-radius: 16px;
    padding: 28px;
    margin-bottom: 32px;
}

.contact-form-section h3 {
    text-align: center;
    margin-bottom: 20px;
    color: var(--text);
}

.contact-links {
    background: linear-gradient(135deg, #f3e8ff 0%, #e8d9ff 100%);
    border: 2px solid #b794f4;
    border-radius: 16px;
    padding: 28px;
}

.contact-links h3 {
    text-align: center;
    margin-bottom: 8px;
    color: var(--text);
}

@media (max-width: 768px) {
    .main-nav ul { display:none; }
    .menu-toggle { display:block; }
    .pricing-table { grid-template-columns: 1fr; }
    .pricing-info-grid { grid-template-columns: 1fr; }
    .services-grid { grid-template-columns: 1fr; }
    .contact-options { grid-template-columns: 1fr; gap: 16px; }
    .calendar-grid { gap: 4px; }
    .calendar-day { padding: 10px 6px; font-size: 0.9rem; }
    .calendar-weekday { font-size: 0.8rem; padding: 6px; }
    .time-grid { grid-template-columns: repeat(auto-fit, minmax(70px, 1fr)); }
    .form-group input, .form-group textarea, .form-group select { font-size: 16px; }
}

/* Tablet (iPad) Optimierung */
@media (min-width: 769px) and (max-width: 1024px) {
    .site-header { padding: 12px 24px; }
    .main-nav ul { gap: 12px; }
    .main-nav a { font-size: 0.9rem; padding: 6px 8px; }
    .services-grid { grid-template-columns: repeat(2, 1fr); gap: 20px; }
    .pricing-table { grid-template-columns: repeat(2, 1fr); gap: 20px; }
    .contact-options { grid-template-columns: repeat(2, 1fr); }
    .booking-container { grid-template-columns: 1fr; gap: 24px; }
    .form-card, .box { max-width: 700px; margin: 24px auto; }
    .thank-you-card { max-width: 600px; padding: 40px 28px; }
    .check-icon { font-size: 1.8rem; }
    .chat-widget-btn { width: 60px; height: 60px; right: 24px; bottom: 24px; }
    .chat-popup { width: 380px; right: 24px; }
}

@media (max-width: 600px) and (orientation: portrait) {
    .booking-container { gap: 20px; }
    .calendar-section, .booking-form-section { padding: 16px; }
    .thank-you-card { padding: 24px 16px; margin: 20px auto; }
    .thank-you-card h1 { font-size: 1.5rem; margin-bottom: 8px; }
    .thank-you-subtitle { font-size: 0.95rem; margin-bottom: 20px; }
    .thank-you-content { padding: 16px; margin: 20px 0; }
    .check-item { gap: 12px; margin-bottom: 16px; }
    .check-icon { font-size: 1.8rem; min-width: 40px; }
    .check-item h3 { font-size: 0.95rem; margin-bottom: 4px; }
    .check-item p { font-size: 0.85rem; }
    .thank-you-actions { gap: 8px; margin: 20px 0; flex-direction: column; }
    .btn-primary, .btn-secondary { width: 100%; padding: 14px 16px; font-size: 0.9rem; text-align: center; }
    .thank-you-footer { margin-top: 20px; padding-top: 16px; font-size: 0.9rem; }
    .chat-widget-btn { width: 56px; height: 56px; bottom: 20px; right: 20px; }
    .chat-popup { bottom: 80px; right: 20px; width: calc(100vw - 40px); max-width: 360px; }
    .contact-card { padding: 20px 16px; }
    .contact-hours, .contact-area, .contact-form-section, .contact-links { padding: 20px; }
    .faq-item summary { padding: 12px 16px; font-size: 0.95rem; }
    .faq-answer { padding: 0 16px 16px 44px; }
    .pricing-card { margin-bottom: 16px; }
    .pricing-header { padding: 20px 16px; }
    .pricing-body { padding: 20px 16px; }
}

@media (max-width: 900px) and (orientation: landscape) {
    .thank-you-card { padding: 32px 24px; margin: 24px auto; }
    .thank-you-card h1 { font-size: 1.6rem; }
    .thank-you-subtitle { font-size: 0.9rem; margin-bottom: 16px; }
    .thank-you-content { padding: 16px; margin: 16px 0; }
    .check-item { gap: 12px; margin-bottom: 12px; }
    .check-icon { font-size: 1.6rem; }
    .check-item h3 { font-size: 0.9rem; }
    .check-item p { font-size: 0.8rem; }
    .thank-you-actions { gap: 8px; margin: 16px 0; }
    .btn-primary, .btn-secondary { padding: 10px 16px; font-size: 0.85rem; }
    .thank-you-footer { margin-top: 16px; padding-top: 12px; font-size: 0.85rem; }
}

/* Large Desktop Screens (4K etc.) */
@media (min-width: 1440px) {
    .box, .form-card { max-width: 1200px; }
    .services-grid { grid-template-columns: repeat(3, 1fr); gap: 28px; }
    .pricing-table { grid-template-columns: repeat(3, 1fr); gap: 28px; }
    .contact-options { grid-template-columns: repeat(4, 1fr); gap: 24px; }
    .site-header { padding: 16px 48px; }
    .main-nav ul { gap: 24px; }
}

/* Site Footer */
.site-footer {
    background: rgba(7, 33, 39, 0.95);
    color: #fff;
    text-align: center;
    padding: 24px 20px;
    margin-top: auto;
    border-top: 3px solid var(--primary);
    width: 100%;
    flex-shrink: 0;
}

.site-footer p {
    margin: 0;
    font-size: 0.9rem;
    line-height: 1.6;
}

.site-footer a {
    color: var(--accent);
    text-decoration: none;
    font-weight: 600;
    margin: 0 8px;
}

.site-footer a:hover {
    color: var(--primary);
    text-decoration: underline;
}

@media (max-width: 600px) {
    .site-footer {
        padding: 20px 16px;
        font-size: 0.85rem;
    }
    
    .site-footer a {
        display: inline-block;
        margin: 4px 6px;
    }
}

@media (max-width: 480px) {
    body { padding-top: 60px; }
    .service-card h3 { font-size: 1.05rem; }
    .service-desc { font-size: 0.9rem; }
    .about-photo { max-width: 240px; }
    .contact-icon { font-size: 2rem; }
    .contact-card h3 { font-size: 1.1rem; }
    .hours-item { padding: 12px; }
    .faq-section h3 { font-size: 1.15rem; }
    .pricing-price { font-size: 1.6rem; }
    .pricing-icon { font-size: 2rem; }
}

@media (max-width: 380px) {
    .main-nav ul { gap: 4px; }
    .main-nav a { padding: 3px 4px; font-size: 0.75rem; }
    .site-header .logo .brand { font-size: 0.85rem; }
    .trust-badges { gap: 8px; }
    .trust-badge { padding: 6px 8px; }
    .badge-text { font-size: 0.7rem; }
    .calendar-day { padding: 8px 4px; font-size: 0.85rem; }
    .time-slot { padding: 8px 6px; font-size: 0.9rem; }
}

/* Form Group Styling */
.form-group{ margin-bottom: 18px; text-align: left; }
.form-group label{ display: block; font-weight: 700; color: var(--text); margin-bottom: 8px; font-size: 0.95rem; }
.form-group input, .form-group textarea, .form-group select{ width: 100%; padding: 12px 14px; border: 2px solid rgba(15,178,107,0.2); border-radius: 8px; font-size: 0.95rem; font-family: inherit; background: white; color: var(--text); transition: all 0.2s ease; }
.form-group input:focus, .form-group textarea:focus, .form-group select:focus{ outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px rgba(15,178,107,0.1); background: rgba(255,255,255,0.98); }
.form-group textarea{ resize: vertical; min-height: 100px; }
.form-group select{ cursor: pointer; appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%230fb26b' d='M6 9L1 4h10z'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 12px center; padding-right: 36px; }

/* Calendar Buttons Enhanced */
.calendar-btn{ background: linear-gradient(135deg, var(--primary), rgba(15,178,107,0.9)); color: white; border: none; padding: 10px 14px; border-radius: 8px; cursor: pointer; font-weight: 700; font-size: 0.9rem; transition: all 0.2s ease; box-shadow: 0 4px 12px rgba(15,178,107,0.2); }
.calendar-btn:hover{ background: linear-gradient(135deg, rgba(15,178,107,0.95), var(--primary)); transform: translateY(-2px); box-shadow: 0 6px 16px rgba(15,178,107,0.3); }
.calendar-btn:active{ transform: translateY(0); box-shadow: 0 2px 8px rgba(15,178,107,0.2); }

/* Calendar Day Buttons Enhanced */
.calendar-day{ padding: 14px 8px; background: white; border: 2px solid rgba(15,178,107,0.2); border-radius: 8px; cursor: pointer; font-weight: 600; color: var(--text); transition: all 0.2s ease; box-shadow: 0 2px 6px rgba(0,0,0,0.04); }
.calendar-day:not(.disabled):hover{ border-color: var(--primary); background: linear-gradient(135deg, rgba(15,178,107,0.12), rgba(168,255,122,0.08)); transform: translateY(-2px); box-shadow: 0 6px 16px rgba(15,178,107,0.15); }
.calendar-day.available{ border-color: var(--primary); background: linear-gradient(135deg, rgba(15,178,107,0.08), rgba(168,255,122,0.05)); font-weight: 700; }
.calendar-day.available:hover{ background: linear-gradient(135deg, rgba(15,178,107,0.18), rgba(168,255,122,0.12)); box-shadow: 0 8px 20px rgba(15,178,107,0.18); }
.calendar-day.disabled{ opacity: 0.35; cursor: not-allowed; background: #f5f5f5; }
.calendar-day.full{ background: rgba(200,200,200,0.15); border-color: var(--muted); opacity: 0.6; }

/* Time Slot Buttons Enhanced */
.time-slot{ padding: 12px 10px; background: white; border: 2px solid rgba(15,178,107,0.25); border-radius: 8px; cursor: pointer; font-weight: 600; color: var(--text); transition: all 0.2s ease; box-shadow: 0 2px 8px rgba(0,0,0,0.04); }
.time-slot:hover:not(.booked){ background: linear-gradient(135deg, rgba(15,178,107,0.1), rgba(168,255,122,0.05)); border-color: var(--primary); transform: translateY(-2px); box-shadow: 0 6px 16px rgba(15,178,107,0.15); }
.time-slot.active{ background: linear-gradient(135deg, var(--primary), rgba(15,178,107,0.9)); color: white; border-color: var(--primary); box-shadow: 0 8px 20px rgba(15,178,107,0.3); transform: scale(1.05); }
.time-slot.booked{ opacity: 0.35; cursor: not-allowed; background: #e8e8e8; border-color: #ccc; }

/* Submit Button Enhanced */
.btn[type="submit"]{ width: 100%; padding: 14px 16px; background: linear-gradient(135deg, var(--primary), rgba(15,178,107,0.9)); color: white; border: none; border-radius: 8px; font-weight: 800; font-size: 1rem; cursor: pointer; transition: all 0.2s ease; box-shadow: 0 6px 18px rgba(15,178,107,0.25); margin-top: 12px; }
.btn[type="submit"]:hover:not(:disabled){ background: linear-gradient(135deg, rgba(15,178,107,0.95), var(--primary)); transform: translateY(-2px); box-shadow: 0 10px 28px rgba(15,178,107,0.35); }
.btn[type="submit"]:active:not(:disabled){ transform: translateY(0); box-shadow: 0 4px 12px rgba(15,178,107,0.25); }
.btn[type="submit"]:disabled{ opacity: 0.5; cursor: not-allowed; }

/* Booking Container */
.booking-form-section{ padding: 20px; background: rgba(255,255,255,0.5); border-radius: 8px; }
.booking-form-section form{ margin: 0; }

.booking-info{ background: rgba(15,178,107,0.05); border-left: 4px solid var(--primary); padding: 20px; border-radius: 8px; margin-top: 24px; }
.booking-info h3{ color: var(--primary); margin-top: 0; margin-bottom: 12px; }
.booking-info ol{ margin: 12px 0; padding-left: 24px; color: var(--text); }
.booking-info li{ margin-bottom: 8px; }
.booking-info p{ margin: 12px 0; color: var(--text); }

/* Kalender auf Services-Seite */
.calendar-quick{ background: linear-gradient(135deg, rgba(15,178,107,0.08), rgba(168,255,122,0.05)); border: 2px solid rgba(15,178,107,0.2); border-radius: 12px; padding: 24px; margin-bottom: 32px; }
.calendar-quick h3{ color: var(--primary); margin-top: 0; margin-bottom: 16px; font-size: 1.1rem; }