/* datenschutz.css */
.page-hero{
    position:relative;
    min-height:clamp(34rem, 76svh, 48rem);
    display:flex;
    align-items:center;
    overflow:hidden;
    padding-top:clamp(7rem, 11vw, 8rem);
    background:
            linear-gradient(90deg, rgba(43,35,28,.76) 0%, rgba(43,35,28,.50) 42%, rgba(43,35,28,.24) 100%),
            url('../img/zurmuehleIMG.jpg') center center / cover no-repeat;
    color:#fff;
}

.page-hero::after{
    content:"";
    position:absolute;
    inset:auto 0 0 0;
    height:180px;
    background:linear-gradient(to bottom, rgba(244,239,231,0), rgba(244,239,231,1));
}

.hero-content{
    position:relative;
    z-index:2;
    padding-top:clamp(3.5rem, 8vw, 7rem);
    padding-bottom:clamp(2.5rem, 6vw, 5rem);
}

.page-hero h1{
    color:#fff;
    font-size:clamp(3rem, 8vw, 6.1rem);
    line-height:.88;
    max-width:10.5ch;
    margin-bottom:1.2rem;
    overflow-wrap:break-word;
}

.page-hero p{
    font-size:1.12rem;
    color:rgba(255,255,255,.88);
    max-width:min(58ch, 100%);
    margin-bottom:2rem;
    overflow-wrap:break-word;
}

.hero-facts{
    display:flex;
    flex-wrap:wrap;
    gap:.8rem;
    max-width:760px;
}

.hero-fact{
    display:inline-flex;
    align-items:center;
    gap:.55rem;
    padding:.75rem 1rem;
    border-radius:999px;
    color:#fff;
    background:rgba(255,255,255,.12);
    border:1px solid rgba(255,255,255,.18);
    backdrop-filter:blur(10px);
    font-weight:600;
}

.section-warm{
    background:
            radial-gradient(circle at top left, rgba(168,181,154,.12), transparent 30%),
            linear-gradient(180deg, rgba(244,239,231,.98), rgba(255,255,255,.66));
    border-bottom:1px solid var(--line);
}

.section-light{
    background:linear-gradient(180deg, rgba(255,255,255,.62), rgba(248,244,238,.9));
    border-top:1px solid var(--line);
    border-bottom:1px solid var(--line);
}

.contact-card,
.hours-panel,
.map-panel,
.form-card,
.quick-card{
    background:rgba(255,255,255,.72);
    border:1px solid var(--line);
    border-radius:var(--radius-xl);
    box-shadow:var(--shadow);
}

.contact-card{
    padding:clamp(1.5rem, 3vw, 2.4rem);
    height:100%;
}

.privacy-document{
    max-width: 1040px;
    margin: 0 auto;
}

.privacy-content{
    display: grid;
    gap: 1rem;
    margin-top: 1.25rem;
}

.privacy-intro,
.privacy-section-card{
    border: 1px solid var(--line);
    border-radius: 22px;
    background: rgba(255,255,255,.62);
    padding: clamp(1.25rem, 2.5vw, 2rem);
}

.privacy-intro{
    background:
            radial-gradient(circle at top right, rgba(168,181,154,.18), transparent 34%),
            rgba(255,255,255,.72);
}

.privacy-intro h2{
    font-size: clamp(2rem, 4vw, 3rem);
    line-height: 1;
    margin-bottom: 1rem;
}

.privacy-section-heading{
    display: flex;
    align-items: flex-start;
    gap: .9rem;
    margin-bottom: 1rem;
}

.privacy-section-heading > span{
    flex: 0 0 auto;
    min-width: 2.25rem;
    height: 2.25rem;
    border-radius: 999px;
    display: inline-grid;
    place-items: center;
    color: #fff;
    background: var(--green-dark);
    font-size: .9rem;
    font-weight: 800;
    line-height: 1;
}

.privacy-section-heading h3{
    font-size: clamp(1.55rem, 3vw, 2.15rem);
    line-height: 1.05;
    margin: .1rem 0 0;
}

.privacy-content p{
    color: var(--muted);
    margin: 0 0 .9rem;
    line-height: 1.75;
}

.privacy-content p:last-child{ margin-bottom: 0; }

.privacy-definition{
    padding: .85rem 1rem;
    margin: .8rem 0;
    border-radius: 16px;
    background: rgba(116,134,108,.08);
    border: 1px solid rgba(116,134,108,.12);
}

.privacy-definition strong{
    color: var(--green-dark);
    font-size: .95rem;
}

.privacy-section-card--highlight{
    background:
            linear-gradient(135deg, rgba(51,69,56,.94), rgba(116,134,108,.88));
    color: #fff;
}

.privacy-section-card--highlight h3,
.privacy-section-card--highlight p{
    color: #fff;
}

.privacy-section-card--highlight .privacy-section-heading > span{
    color: var(--green-dark);
    background: rgba(255,255,255,.9);
}

.contact-list{
    list-style:none;
    padding:0;
    margin:1.25rem 0 1.5rem;
    display:grid;
    gap:.85rem;
}

.contact-list li{
    display:flex;
    gap:.85rem;
    align-items:flex-start;
    padding:1rem;
    border-radius:18px;
    background:rgba(116,134,108,.06);
    border:1px solid rgba(116,134,108,.10);
}

.contact-list i{
    color:var(--green-dark);
    margin-top:.25rem;
    flex:0 0 auto;
}

.contact-list strong{
    display:block;
    color:var(--text);
    margin-bottom:.15rem;
}

.contact-list a,
.contact-list span{
    color:var(--muted);
    text-decoration:none;
    font-size:.96rem;
}

.contact-list a:hover{ color:var(--green-dark); }

.quick-grid{
    display:grid;
    grid-template-columns:repeat(3, minmax(0,1fr));
    gap:1rem;
}

.quick-card{
    padding:1.4rem 1.2rem;
    height:100%;
}

.quick-card h3{
    font-size:1.65rem;
    margin-bottom:.45rem;
}

.quick-card p{
    color:var(--muted);
    margin-bottom:1rem;
    font-size:.96rem;
}

.form-card{
    padding:clamp(1.4rem, 3vw, 2.4rem);
    overflow:hidden;
}

.contact-form{
    display:grid;
    grid-template-columns:repeat(2, minmax(0,1fr));
    gap:1rem;
}

.form-field{
    display:flex;
    flex-direction:column;
    gap:.45rem;
}

.form-field.full{
    grid-column:1 / -1;
}

.form-field label{
    font-size:.82rem;
    font-weight:800;
    color:var(--ink);
}

.form-control,
.form-select{
    border:1px solid rgba(54,67,59,.14);
    border-radius:18px;
    padding:.95rem 1rem;
    color:var(--ink);
    background:rgba(255,255,255,.84);
    box-shadow:none;
}

.form-control:focus,
.form-select:focus{
    border-color:rgba(125,146,116,.62);
    box-shadow:0 0 0 .22rem rgba(125,146,116,.16);
}

textarea.form-control{
    min-height:150px;
    resize:vertical;
}

.form-note{
    color:var(--muted);
    font-size:.92rem;
    margin:1rem 0 0;
}

.hours-panel{
    padding:clamp(1.5rem, 3vw, 2.35rem);
    background:
            linear-gradient(135deg, rgba(51,69,56,.94), rgba(116,134,108,.9)),
            url('../img/hero.png') center / cover no-repeat;
    color:#fff;
    overflow:hidden;
    height:100%;
}

.hours-panel h2,
.hours-panel h3{ color:#fff; }
.hours-panel p,
.hours-panel li{ color:rgba(255,255,255,.82); }

.hours-list{
    list-style:none;
    padding:0;
    margin:1.2rem 0 0;
    display:grid;
    gap:.8rem;
}

.hours-list li{
    display:flex;
    justify-content:space-between;
    gap:1rem;
    padding-bottom:.75rem;
    border-bottom:1px solid rgba(255,255,255,.16);
}

.hours-list li:last-child{
    border-bottom:0;
    padding-bottom:0;
}

.hours-list strong{ color:#fff; }
.hours-block{
    margin-top:1.2rem;
    padding-top:1.2rem;
    border-top:1px solid rgba(255,255,255,.16);
}

.hours-block h3{
    font-size:1.55rem;
    margin-bottom:.8rem;
}

.map-panel{
    overflow:hidden;
    min-height:420px;
    background:
            linear-gradient(135deg, rgba(244,239,231,.82), rgba(255,255,255,.72)),
            url('../img/hero.png') center / cover no-repeat;
    display:flex;
    align-items:flex-end;
}

.map-content{
    width:100%;
    padding:clamp(1.5rem, 3vw, 2.35rem);
    background:linear-gradient(to top, rgba(255,255,255,.94), rgba(255,255,255,.72), transparent);
}

.restaurant-footer{
    background:var(--footer-bg);
    color:var(--footer-text);
    border-top:1px solid rgba(255,255,255,.06);
    margin-top:0;
}

.footer-top{
    padding:2.6rem 0 1.8rem;
    border-bottom:1px solid var(--footer-border);
}

.footer-logo{
    width:160px;
    max-width:100%;
    height:auto;
    object-fit:contain;
}

.footer-heading{
    color:#fff;
    font-size:1rem;
    font-weight:700;
    margin-bottom:.95rem;
}

.footer-note{
    font-size:.95rem;
    color:var(--footer-muted);
    max-width:34ch;
}

.footer-links{
    list-style:none;
    padding:0;
    margin:0;
}

.footer-links li{ margin-bottom:.55rem; }
.footer-links a,
.footer-contact a,
.footer-bottom a{
    color:var(--footer-text);
    text-decoration:none;
    transition:color .2s ease;
}

.footer-links a:hover,
.footer-contact a:hover,
.footer-bottom a:hover{ color:#fff; }

.footer-contact strong{
    color:#fff;
    display:block;
    margin-bottom:.35rem;
    font-size:1rem;
}

.phone{
    color:#fff;
    font-size:1.1rem;
    font-weight:700;
    margin-bottom:.25rem;
}

.phone i{ color:var(--green-light); margin-right:.35rem; }
.footer-time{ color:var(--footer-muted); font-size:.9rem; }
.footer-bottom{ padding:1rem 0 1.15rem; }

.footer-bottom-inner{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:1rem;
    flex-wrap:wrap;
    font-size:.9rem;
    color:var(--footer-muted);
}

.footer-mini-links{
    display:flex;
    flex-wrap:wrap;
    gap:.55rem;
    align-items:center;
}

.socials{
    display:flex;
    gap:.6rem;
    align-items:center;
}

.socials a{
    width:38px;
    height:38px;
    display:grid;
    place-items:center;
    border-radius:50%;
    background:rgba(255,255,255,.08);
    color:#fff;
    transition:background .2s ease, transform .2s ease;
}

.socials a:hover{
    background:rgba(255,255,255,.16);
    transform:translateY(-1px);
}

@media (max-width: 1199.98px){
    .quick-grid{ grid-template-columns:1fr 1fr; }
}

@media (max-width: 991.98px){
    .main-nav{ border-radius:24px; }
    .navbar-nav{
        background:rgba(255,255,255,.08);
        border-radius:18px;
        padding:.75rem;
        margin-top:.5rem;
        width:100%;
    }
    .navbar-wrap.scrolled .navbar-nav{ background:rgba(51,69,56,.04); }
    .navbar .nav-link{
        width:100%;
        padding:.9rem 1rem !important;
    }
    .navbar .nav-link::after{ display:none; }
    .brand-logo{
        height:46px;
        max-width:150px;
    }
    .brand-mark{
        min-width:auto;
        min-height:46px;
    }
    .footer-bottom-inner{ justify-content:center; text-align:center; }
}

@media (max-width: 767.98px){
    html{ scroll-padding-top:92px; }
    .section-space{ padding:3.5rem 0; }
    .page-hero{ min-height:auto; }
    .page-hero h1{
        max-width:9.8ch;
        font-size:clamp(2.35rem, 9vw, 2.9rem);
        line-height:.92;
    }
    .page-hero p{
        max-width:100%;
        font-size:1rem;
    }
    .lead-soft{
        max-width:100%;
    }
    .hero-fact,
    .quick-card .btn,
    .contact-card .btn{
        width:100%;
        justify-content:center;
    }
    .quick-grid{ grid-template-columns:1fr; }
    .contact-form{ grid-template-columns:1fr; }
    .hours-list li{
        flex-direction:column;
        gap:.15rem;
    }
    .map-panel{ min-height:340px; }
    .footer-logo{ width:140px; }
    .footer-bottom-inner{ flex-direction:column; }
    .footer-mini-links{ justify-content:center; text-align:center; }
}
