/* LOCAL FONTS */
@font-face {
font-family: 'Cormorant Garamond';
src: url('fonts/cormorant-garamond-v21-latin-regular.woff2') format('woff2');
font-weight: 400;
font-style: normal;
font-display: swap;
}
@font-face {
font-family: 'Cormorant Garamond';
src: url('fonts/cormorant-garamond-v21-latin-italic.woff2') format('woff2');
font-weight: 400;
font-style: italic;
font-display: swap;
}
@font-face {
font-family: 'Inter';
src: url('fonts/inter-v20-latin-regular.woff2') format('woff2');
font-weight: 400;
font-style: normal;
font-display: swap;
}
@font-face {
font-family: 'Inter';
src: url('fonts/inter-v20-latin-600.woff2') format('woff2');
font-weight: 600;
font-style: normal;
font-display: swap;
}

/* CSS VARIABLES */
:root {
--black:#0a0a0a;
--black-mid:#111111;
--black-card: #161616;
--border: #1f1f1f;
--gold: #c8a96e;
--gold-dim: #8a6f3e;
--white:#f0ece4;
--white-dim:#8e8a85;
--white-bright: #E0E0E0;
--gold-hover: #d4b87a;
--card-hover: #1a1a1a;
--font-display: 'Cormorant Garamond', Georgia, serif;
--font-body:'Inter', system-ui, sans-serif;
--transition: 0.35s cubic-bezier(0.4, 0, 0.2, 1);
--nav-height: 64px;
--max-width:1300px;
}

/* RESET & BASE */
*, *::before, *::after {
box-sizing: border-box;
margin: 0;
padding: 0;
}

html {
scroll-behavior: smooth;
font-size: 20px;
-webkit-text-size-adjust: 100%;
text-size-adjust: 100%;
overflow-x: clip;
}

body {
background-color: var(--black);
color: var(--white);
font-family: var(--font-body);
font-weight: 400;
line-height: 1.7;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-rendering: optimizeLegibility;
overflow-x: clip;
}

body::before {
content: '';
display: block;
height: 2px;
background: linear-gradient(90deg, transparent, var(--gold), transparent);
position: fixed;
top: 0; left: 0; right: 0;
z-index: 100;
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
.skip-link {
position: absolute;
left: 1rem;
top: -100%;
z-index: 200;
padding: 0.35rem 0.75rem;
background: var(--gold);
color: var(--black);
font-size: 0.75rem;
font-weight: 600;
}

.skip-link:focus {
top: 1rem;
}

a:focus-visible,
button:focus-visible {
outline: 2px solid var(--gold);
outline-offset: 3px;
}

/* TYPOGRAPHY */
.display {
font-family: var(--font-display);
font-weight: 400;
letter-spacing: 0.02em;
line-height: 1.1;
}

.eyebrow {
font-family: var(--font-body);
font-size: 0.75rem;
font-weight: 400;
letter-spacing: 0.25em;
text-transform: uppercase;
color: var(--gold);
}

/* LAYOUT */
.container {
max-width: var(--max-width);
margin: 0 auto;
padding: 0 1.5rem;
}

.section {
padding: 4rem 0;
border-bottom: 1px solid var(--border);
}

/* NAVIGATION */
nav {
position: fixed;
top: 0;
left: 0; right: 0;
z-index: 90;
background: rgba(10, 10, 10, 0.3);
backdrop-filter: blur(12px);
-webkit-backdrop-filter: blur(12px);
border-bottom: 1px solid var(--border);
will-change: background;
box-shadow: 0 4px 18px rgba(0, 0, 0, 0.22);
transition: background var(--transition),
            border-color var(--transition),
            box-shadow var(--transition);
}

.nav-inner {
max-width: var(--max-width);
margin: 0 auto;
padding: 0 2rem;
height: 64px;
display: flex;
align-items: center;
justify-content: space-between;
}

.nav-logo {
font-family: var(--font-display);
font-size: 1.25rem;
font-weight: 600;
letter-spacing: 0.1em;
text-transform: uppercase;
color: var(--white);
}

.nav-logo span {
color: var(--gold);
font-style: italic;
}

.nav-links {
display: flex;
gap: 2.5rem;
list-style: none;
}

.nav-links a {
font-size: 0.8rem;
font-weight: 600;
letter-spacing: 0.1em;
text-transform: uppercase;
color: var(--white-dim);
transition: color var(--transition);
}

.nav-links a:hover { color: var(--gold); }

.nav-cta {
font-size: 0.75rem;
font-weight: 600;
letter-spacing: 0.1em;
text-transform: uppercase;
display: flex;
align-items: center;
gap: 8px;
padding: 0.4rem 1.4rem;
border: 2px solid var(--gold-dim);
color: var(--gold);
transition: all var(--transition);
}

.nav-cta:hover, .nav-cta.is-scrolled {
background: var(--gold);
color: var(--black);
border-color: var(--gold);
}

.hamburger {
display: none;
flex-direction: column;
gap: 5px;
cursor: pointer;
padding: 4px;
background: none;
border: none;
}
.hamburger span {
display: block;
width: 24px; height: 1px;
background: var(--white);
transition: var(--transition);
}

/* HERO */
#hero {
margin-top: var(--nav-height);
min-height: calc(100vh - var(--nav-height));
min-height: calc(100svh - var(--nav-height));
display: flex;
align-items: center;
position: relative;
overflow: hidden;
padding-top: 3rem;
padding-bottom: 1rem;
}

.hero-bg {
position: absolute;
inset: 0;
overflow: hidden;
}

.hero-bg img {
position: absolute;
inset: 0;
width: 100%;
height: 100%;
object-fit: cover;
object-position: center;
z-index: 0;
}

.hero-bg::after {
content: '';
position: absolute;
inset: 0;
z-index: 1;
background: linear-gradient(to bottom,
rgba(10,10,10,0.15) 0%,
rgba(10,10,10,0.55) 30%,
rgba(10,10,10,0.85) 100%
);
}

.hero-logo {
flex-shrink: 0;
display: flex;
align-items: center;
}

.hero-logo img {
height: clamp(80px, 11vw, 256px);
width: auto;
display: block;
}

.hero-title-row {
display: flex;
align-items: center;
gap: clamp(1rem, 2.5vw, 2.5rem);
margin-bottom: 1.4rem;
}

.hero-content {
position: relative;
z-index: 2;
max-width: 1100px;
}

.hero-eyebrow {
margin-bottom: 1.5rem;
display: flex;
align-items: center;
gap: 1rem;
}

.hero-eyebrow::after {
content: '';
display: block;
height: 1px;
width: 48px;
background: var(--gold);
}

.hero-title {
font-size: clamp(3.2rem, 7vw, 4.5rem);
line-height: .9;
font-weight: 400;
margin-bottom: 0;
color: var(--white);
}

.display em {
color: var(--gold);
font-style: italic;
}

.hero-h1 {
font-family: var(--font-display);
font-size: 1.25rem;
font-weight: 400;
color: var(--white-bright);
margin-bottom: 2rem;
line-height: 1.3;
letter-spacing: 0.02em;
}

.hero-actions {
display: flex;
gap: 1.5rem;
flex-wrap: wrap;
align-items: center;
}

.btn-primary {
display: inline-flex;
align-items: center;
gap: 0.6rem;
background: var(--gold);
color: var(--black);
font-size: 0.8rem;
font-weight: 600;
letter-spacing: 0.1em;
text-transform: uppercase;
padding: 0.9rem 2rem;
transition: all var(--transition);
}

.btn-primary:hover {
background: var(--gold-hover);
transform: translateY(-1px);
}

.btn-secondary {
display: inline-flex;
align-items: center;
gap: 0.6rem;
color: var(--white-bright);
font-size: 0.8rem;
font-weight: 600;
letter-spacing: 0.1em;
text-transform: uppercase;
padding: 0.8rem 2rem;
border: 2px solid var(--white-bright);
transition: all var(--transition);
}

.btn-secondary:hover {
color: var(--gold);
border-color: var(--gold);
}

/* STATS BAR */
.stats-bar {
background: var(--black-mid);
border-top: 1px solid var(--border);
border-bottom: 1px solid var(--border);
padding: 2rem 0;
}

.stats-grid {
display: grid;
grid-template-columns: repeat(4, 1fr);
gap: 0;
align-items: center;
line-height: 1.4;
}

.stat-item {
padding: 1rem 2rem;
border-right: 1px solid var(--border);
text-align: center;
}

.stat-item:last-child { border-right: none; }

.stat-number {
font-family: var(--font-display);
font-size: 2.2rem;
font-weight: 300;
color: var(--gold);
line-height: 1;
margin-bottom: 0.4rem;
}

.star-icon {
font-size: 0.45em;
vertical-align: middle;
margin-right: 4px;
}

.boost-num {
display: inline-block;
font-size: 1.1em;
margin-top: -3px;
}

.stat-label {
font-size: 0.68rem;
letter-spacing: 0.15em;
text-transform: uppercase;
color: var(--white-dim);
}

/* LEISTUNGEN */
#leistungen { background: var(--black); }
#leistungen .services-grid .service-card:last-child {
  grid-column: span 2;
}

.section-header {
margin-bottom: 4rem;
display: grid;
grid-template-columns: 1fr auto;
align-items: end;
gap: 4rem;
}

#galerie .section-header {
margin-top: 4rem;
margin-bottom: 0;
grid-template-columns: 1fr 3fr;
align-items: start;
}

.galerie-desc { overflow-wrap: break-word; }

.section-title {
font-size: clamp(2rem, 4.2vw, 3rem);
margin-top: 0.75rem;
}

#leistungen .services-grid {
display: grid;
grid-template-columns: repeat(3, minmax(0, 1fr));
gap: 1px;
background: var(--border);
align-items: stretch;
}

.service-card {
background: var(--black-card);
padding: 2.5rem 2rem;
transition: background var(--transition);
position: relative;
overflow: hidden;
display: flex;
flex-direction: column;
}

.service-card::before {
content: '';
position: absolute;
top: 0; left: 0;
width: 100%; height: 2px;
background: var(--gold);
transform: scaleX(0);
transform-origin: left;
transition: transform var(--transition);
}

.service-card:hover { background: var(--card-hover); }
.service-card:hover::before { transform: scaleX(1); }

.service-icon {
width: 18px;
width: 1.3cap;
height: 18px;
height: 1.3cap;
flex-shrink: 0;
color: var(--gold);
}

.service-icon svg {
width: 18px;
width: 1.3cap;
height: 18px;
height: 1.3cap;
fill: currentColor;
stroke: none;
display: block;
}

.service-name {
font-family: var(--font-display);
font-size: 1.4rem;
font-weight: 500;
margin-bottom: 0.75rem;
color: var(--white);
display: flex;
align-items: center;
gap: 0.65rem;
}

.service-desc {
font-size: 0.85rem;
color: var(--white-dim);
margin-bottom: 1.5rem;
flex-grow: 1;
}

.galerie-desc {
font-size: 0.85rem;
color: var(--white-dim);
line-height: 1.7;
}

.service-price {
font-family: var(--font-display);
font-size: 1.7rem;
color: var(--gold);
font-weight: 600;
font-style: italic;
letter-spacing: 0.02em;
margin-top: auto;
}

/* FAQ */
.faq-with-image {
margin-top: 2.5rem;
padding-top: 1.5rem;
border-top: 1px solid var(--border);
display: grid;
grid-template-columns: 1fr 1fr;
gap: 4rem;
align-items: start;
}

.faq-eyebrow {
display: block;
margin-bottom: 1.5rem;
}

.faq-list {
max-width: 100%;
margin: 0;
}

.faq-image-wrap {
border: 1px solid var(--border);
position: relative;
overflow: hidden;
min-height: 480px;
align-self: stretch;
background-color: var(--black-card);
}

.faq-image-wrap::before,
.faq-image-wrap::after {
content: '';
position: absolute;
width: 24px; height: 24px;
border-color: var(--gold);
border-style: solid;
pointer-events: none;
z-index: 2;
}
.faq-image-wrap::before {
top: 16px; left: 16px;
border-width: 1px 0 0 1px;
}
.faq-image-wrap::after {
bottom: 16px; right: 16px;
border-width: 0 1px 1px 0;
}

.faq-image-wrap img,
.about-image-wrap img {
position: absolute;
inset: 0;
width: 100%;
height: 100%;
object-fit: cover;
object-position: center;
z-index: 0;
}

.about-image-wrap img {
object-position: center top;
}

.img-overlay {
position: absolute;
inset: 0;
background: rgba(0, 0, 0, 0.1);
z-index: 1;
pointer-events: none;
}

.faq-item { border-bottom: 1px solid var(--border); }

.faq-question {
width: 100%;
background: none;
border: none;
color: var(--white);
font-family: var(--font-body);
font-size: 1rem;
font-weight: 400;
text-align: left;
padding: 1.75rem 1.5rem;
cursor: pointer;
display: flex;
justify-content: space-between;
align-items: center;
gap: 1rem;
transition: color var(--transition);
}

.faq-question:hover { color: var(--gold); }

.faq-icon {
    position: relative;
    flex-shrink: 0;
    width: 28px;
    height: 28px;
    border: 1.5px solid var(--white-dim);
    border-radius: 50%;
    display: inline-block;
    transition: transform var(--transition), border-color var(--transition), color var(--transition);
    user-select: none;
}

.faq-icon::before,
.faq-icon::after {
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    width: 10px;
    height: 1.5px;
    background: currentColor;
    border-radius: 2px;
    transform: translate(-50%, -50%);
}

.faq-icon::after {
    transform: translate(-50%, -50%) rotate(90deg);
}

.faq-question[aria-expanded="true"] .faq-icon::after {
    transform: translate(-50%, -50%) rotate(0deg);
}

.faq-question[aria-expanded="true"] .faq-icon {
    border-color: var(--gold);
    color: var(--gold);
}

.faq-answer {
font-size: 0.88rem;
color: var(--white-dim);
line-height: 1.75;
max-height: 0;
overflow: hidden;
transition: max-height 0.4s ease, padding 0.4s ease;
}

.faq-item.open .faq-answer {
max-height: 600px;
padding: 0 1.5rem 2rem;
}

.faq-answer[hidden] {
display: block;
max-height: 0;
padding: 0;
overflow: hidden;
}

/* ÜBER UNS */
#ueber-uns { background: var(--black-mid); }

.about-grid {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 4rem;
align-items: center;
}

.about-image-wrap {
background-color: var(--black-card);
border: 1px solid var(--border);
position: relative;
overflow: hidden;
min-height: 480px;
align-self: stretch;
}

.about-image-wrap::before,
.about-image-wrap::after {
content: '';
position: absolute;
width: 24px; height: 24px;
border-color: var(--gold);
border-style: solid;
pointer-events: none;
z-index: 2;
}
.about-image-wrap::before {
top: 16px; left: 16px;
border-width: 1px 0 0 1px;
}
.about-image-wrap::after {
bottom: 16px; right: 16px;
border-width: 0 1px 1px 0;
}

.about-text .section-title { margin-top: 0.75rem; margin-bottom: 2rem; }

.about-body {
font-size: 0.85rem;
color: var(--white-dim);
margin-bottom: 1rem;
}

.about-signature {
font-family: var(--font-display);
font-size: 1.5rem;
font-style: italic;
color: var(--gold);
margin-top: 2rem;
}

/* GALERIE */
#galerie { background: var(--black); }

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

.gallery-item {
background: var(--black-card);
overflow: hidden;
position: relative;
min-width: 0;
}

.gallery-item:nth-child(3),
.gallery-item:nth-child(4),
.gallery-item:nth-child(5) {
aspect-ratio: 1 / 1;
}

.gallery-item:first-child,
.gallery-item--wide {
grid-column: span 2;
aspect-ratio: 16 / 9;
}

.gallery-item img {
width: 100%;
height: 100%;
object-fit: cover;
transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
filter: grayscale(20%);
will-change: transform; 
}

.gallery-item:hover img {
transform: scale(1.04);
filter: grayscale(0%);
}

.gallery-placeholder {
width: 100%; height: 100%;
display: flex;
align-items: center;
justify-content: center;
color: var(--white-dim);
font-size: 0.65rem;
letter-spacing: 0.2em;
text-transform: uppercase;
}

/* KONTAKT */
#kontakt { background: var(--black); }

.kontakt-grid {
display: grid;
grid-template-columns: 1fr 1.4fr;
gap: 4rem;
align-items: stretch;
}

.kontakt-grid > * {
min-width: 0; 
}

.kontakt-info {
display: flex;
flex-direction: column;
}

.kontakt-heading, .kontakt-block { margin-bottom: 2rem; }
.kontakt-heading .section-title { margin-top: 0.75rem; }
.kontakt-block-label, .kontakt-block-label-adresse {
font-size: 0.75rem;
letter-spacing: 0.25em;
text-transform: uppercase;
margin-bottom: 0.75rem;
}

.kontakt-block-label-adresse {color: var(--white-dim);}

.kontakt-block-label{color: var(--gold);}

.kontakt-block-value {
font-family: var(--font-body);
font-size: 1.15rem;
font-weight: 300;
line-height: 1.6;
color: var(--white);
font-style: normal;
}

.kontakt-address-note {
font-size: 0.8rem;
color: var(--white-dim);
}

.hours-grid {
display: grid;
grid-template-columns: auto 1fr;
gap: 0.35rem 1.5rem;
font-size: 0.88rem;
color: var(--white-dim);
}

.hours-day { font-weight: 400; }
.hours-time { color: var(--white); }
.hours-time--closed { color: var(--white-dim); }

.kontakt-actions {
display: flex;
flex-direction: column;
gap: 0.75rem;
margin-top: auto;
padding-top: 0.75rem;
}

.kontakt-btn {
display: flex;
align-items: center;
gap: 1rem;
padding: 0.9rem 1.4rem;
border: 1px solid var(--border);
background: var(--black-card);
color: var(--white);
font-size: 0.82rem;
letter-spacing: 0.05em;
transition: all var(--transition);
}

.kontakt-btn:hover {
border-color: var(--gold-dim);
color: var(--gold);
}

.map-wrapper {
display: flex;
flex-direction: column;
gap: 15px;
align-self: stretch;
}

@media (min-width: 901px) {
.map-wrapper{ height: 100%; min-height: 480px; }
.map-photo{ flex: 1 1 0; aspect-ratio: unset; } 
.map-frame{ flex: 1 1 0; }
}

.map-photo {
position: relative;
overflow: hidden;
border: 1px solid var(--border);
max-height: 43%;
background-color: var(--black-card);
aspect-ratio: 16 / 9; 
}

.map-photo img {
position: absolute;
inset: 0;
width: 100%;
height: 100%;
object-fit: cover;
object-position: center;
z-index: 0;
}

.map-photo::after {
content: '';
position: absolute;
inset: 0;
background: rgba(0, 0, 0, 0.05);
z-index: 1;
pointer-events: none;
}

.map-frame {
overflow: hidden;
position: relative;
border: 1px solid var(--border);
}

.map-frame::after {
content: '';
position: absolute;
inset: 0;
background: rgba(200, 169, 110, 0.08);
pointer-events: none;
z-index: 1;
}

.map-frame iframe {
width: 100%;
height: 100%;
border: none;
display: block;
 /* filter: grayscale(100%) invert(90%) contrast(90%); */
filter: brightness(0.75) contrast(1.2) sepia(15%);

}

.map-consent {
width: 100%;
height: 100%;
min-height: 300px;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 1rem;
padding: 2rem;
background: var(--black-card);
text-align: center;
}

.map-consent-icon {
width: 32px; height: 32px;
fill: var(--gold-dim);
opacity: 0.7;
flex-shrink: 0;
}

.map-consent-text {
font-size: 0.75rem;
color: var(--white-dim);
line-height: 1.65;
max-width:300px;
}

.map-consent-text a {
color: var(--gold);
text-decoration: underline;
text-underline-offset: 2px;
}

.map-consent-text a:hover { color: var(--white); }

.map-consent-btn {
display: inline-flex;
align-items: center;
padding: 0.65rem 1.5rem;
background: transparent;
border: 1px solid var(--gold-dim);
color: var(--gold);
font-family: var(--font-body);
font-size: 0.72rem;
font-weight: 600;
letter-spacing: 0.15em;
text-transform: uppercase;
cursor: pointer;
transition: background var(--transition), color var(--transition), border-color var(--transition);
}

.map-consent-btn:hover {
background: var(--gold);
color: var(--black);
border-color: var(--gold);
}

/* FOOTER */
footer {
background: var(--black-mid);
border-top: 1px solid var(--border);
padding: 2.5rem 0;
}

.footer-inner {
display: flex;
justify-content: space-between;
align-items: center;
gap: 1rem;
flex-wrap: wrap;
}

.footer-logo {
font-family: var(--font-display);
font-size: 1.1rem;
font-weight: 600;
letter-spacing: 0.12em;
text-transform: uppercase;
}

.footer-copy {
font-size: 0.72rem;
color: var(--white-dim);
}

.footer-links {
display: flex;
gap: 2rem;
list-style: none;
}

.footer-links a {
font-size: 0.72rem;
color: var(--white-dim);
letter-spacing: 0.08em;
transition: color var(--transition);
}

.footer-links a:hover { color: var(--gold); }

.sticky-bar {
display: none;
position: fixed;
left: 0;
right: 0;
bottom: 0;
z-index: 200;
padding: 0.75rem 1rem calc(0.75rem + env(safe-area-inset-bottom));
gap: 0.75rem;
background: rgba(10, 10, 10, 0.96);
border-top: 1px solid var(--border);
box-shadow: 0 -10px 30px rgba(0, 0, 0, 0.28);
backdrop-filter: blur(10px);
-webkit-backdrop-filter: blur(10px);
transform: translate3d(0, 110%, 0); 
transition: transform var(--transition);
backface-visibility: hidden;
max-width: 100vw;
}

.sticky-bar.bar-visible {
transform: translate3d(0, 0, 0);
}

.sticky-btn {
flex: 1;
min-height: 48px;
display: inline-flex;
align-items: center;
justify-content: center;
gap: 0.55rem;
border-radius: 0;
font-family: var(--font-body);
font-size: 0.75rem;
font-weight: 600;
letter-spacing: 0.14em;
text-transform: uppercase;
transition: all var(--transition);
}

.sticky-btn--call {
background: var(--gold);
color: var(--black);
border: 1px solid var(--gold);
}

.sticky-btn--call:hover,
.sticky-btn--call:focus-visible {
background: var(--white);
color: var(--black);
border-color: var(--white);
}

.sticky-btn--wa {
background: transparent;
color: var(--white);
border: 1px solid var(--gold-dim);
}

.sticky-btn--wa:hover,
.sticky-btn--wa:focus-visible {
background: var(--gold);
color: var(--black);
border-color: var(--gold);
}

/* SCROLL ANIMATIONS */
.reveal {
opacity: 0;
transform: translateY(24px);
transition: opacity 0.7s ease, transform 0.7s ease;
}

.reveal.visible {
opacity: 1;
transform: translateY(0);
}

.reveal:nth-child(2) { transition-delay: 0.1s; }
.reveal:nth-child(3) { transition-delay: 0.2s; }
.reveal:nth-child(4) { transition-delay: 0.3s; }
.reveal:nth-child(5) { transition-delay: 0.4s; }
.reveal:nth-child(6) { transition-delay: 0.5s; }

/* RESPONSIVE — 3 breakpoints: 1100 / 900 / 600 */
@media (max-width: 1100px) {
.nav-links, .nav-cta { display: none; }
.hamburger { display: flex; }
.service-name { line-height: 1.5rem; }
.section-header { gap: 1rem; }
#galerie .section-header { grid-template-columns: 1fr; }
}

@media (max-width: 900px) {
.section { padding: 4rem 0; }
#leistungen .services-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.about-grid { grid-template-columns: 1fr; gap: 3rem; }
.about-image-wrap { min-height: unset; border: none; padding: 0; }
.about-image-wrap::before,
.about-image-wrap::after { display: none; }
.about-image-wrap img {
position: static; width: 100%; height: auto;
aspect-ratio: 3/4; object-fit: cover; object-position: center top;
}
.about-image-wrap .img-overlay { display: none; }
.faq-image-wrap { order: -1; }
.about-image-wrap { order: 1; }
.about-text { order: 2; }
.faq-with-image { grid-template-columns: 1fr; gap: 2rem; }
.faq-image-wrap { min-height: unset; border: none; padding: 0; }
.faq-image-wrap::before,
.faq-image-wrap::after { display: none; }
.faq-image-wrap img { position: static; width: 100%; height: auto; object-fit: cover; object-position: center; }
.faq-image-wrap .img-overlay { display: none; }
.map-consent-text { max-width: 400px; }
.kontakt-grid { grid-template-columns: 1fr; }
.map-wrapper { height: auto; }
.map-photo { flex: none; min-height: 360px; }
.map-frame { flex: none; aspect-ratio: 3/2; }
.stats-grid { grid-template-columns: repeat(2, 1fr); }
.stat-item:nth-child(2) { border-right: none; }
.gallery-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 6px; }
#galerie .gallery-grid { margin-bottom: 2rem; }
.gallery-item--wide { grid-column: span 1; aspect-ratio: 1 / 1; }
.gallery-item:nth-child(2),
.gallery-item:nth-child(6) { aspect-ratio: 1 / 1; }
.sticky-bar { display: flex; }
body { padding-bottom: calc(72px + env(safe-area-inset-bottom)); }
}

.nav-logo-img { display: none; }

.hamburger span { transition: transform 0.3s ease, opacity 0.3s ease; }
.hamburger.is-open span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.hamburger.is-open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.hamburger.is-open span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

@media (max-width: 600px) {
/* layout */
.section { padding: 2rem 0; }
.section-header { grid-template-columns: 1fr; margin-bottom: 2rem; }
#galerie .section-header { margin-top: 1.5rem; margin-bottom: 0; }
#leistungen .section-header { margin-bottom: 2.5rem; }
/* hero */
#hero { min-height: 80vh; min-height: 80svh; padding-top: 12rem; padding-bottom: 2.5rem; }
.hero-logo { display: none; }
.nav-logo-img {
display: block; position: absolute;
top: 1.5rem; left: 13%; transform: translateX(-13%);
height: 96px; width: auto; z-index: 4;
}
.hero-title { font-size: clamp(2.8rem, 7vw, 4.5rem); }
.hero-title-row { margin-bottom: 1rem; }
.hero-eyebrow { margin-bottom: 0.75rem; }
.hero-eyebrow::after { width: 0; }
.hero-eyebrow .eyebrow, .eyebrow { font-size: 0.56rem; }
.hero-h1 { font-size: 1rem; margin-bottom: 1.75rem; }
.hero-content { max-width: 960px; }
.section {padding: 1rem 0;}
.faq-eyebrow {margin-bottom: 0.5rem;}
.faq-with-image {margin-top: 1.5rem;}
.about-signature {font-size: 1.3em;margin-top: 1.5rem;}
.about-text .section-title {margin-bottom: 1.5rem;}
#leistungen .services-grid .service-card:last-child {grid-column: span 1;}
/* buttons */
.btn-primary, .btn-secondary {
padding: 0.75rem 1rem;letter-spacing: 0.08em;
}
.btn-primary {font-size: 0.8rem;}
.btn-secondary {font-size: 0.7rem;}
.hero-actions > a { width: 100%; min-width: 0; justify-content: center; }
/* nav */
.nav-logo { font-size: 0.9rem; }
/* services */
#leistungen .services-grid { grid-template-columns: 1fr; gap: 1rem; background: var(--black); }
/* gallery */
#galerie .gallery-grid {margin-bottom: 2rem;}
.gallery-grid { grid-template-columns: 1fr; gap: 15px; }
.gallery-item:first-child,
.gallery-item--wide { grid-column: span 1; aspect-ratio: 16 / 9; }
/* stats */
.stats-bar { padding: 1.25rem 0; }
.stat-item { padding: 0.75rem 1rem; }
.stat-number { font-size: 1.6rem; }
/* about */
.about-grid { gap: 1rem; }
/* kontakt */
.kontakt-block { margin-bottom: 1.75rem; }
.kontakt-grid { gap: 3rem; }
.map-wrapper { gap: 10px; }
.map-photo { min-height: 250px; }
.map-frame { aspect-ratio: 1/1; }
/* misc */
.hero-logo img { height: 100px; }
.footer-inner { flex-direction: column; text-align: center; }
footer { padding: 1.75rem 0; }
/* smallest screens */
.container, .nav-inner { padding-left: 1rem; padding-right: 1rem; }
.hero-eyebrow, .hero-actions, .hero-title-row { min-width: 0; }
.hero-eyebrow .eyebrow { min-width: 0; overflow-wrap: anywhere; letter-spacing: 0.12em; }
}

.nav-links.mobile-open {
display: flex;
flex-direction: column;
position: absolute;
top: var(--nav-height);
left: 0; right: 0;
background: rgba(17, 17, 17, 1);
backdrop-filter: blur(32px);
-webkit-backdrop-filter: blur(32px);
border-bottom: 1px solid var(--border);
padding: 1.5rem 2rem 2.5rem 2rem;
gap: 1.5rem;
z-index: 89;
}

.nav-links.mobile-open li:not(.nav-call-item) {
list-style-type: square;
list-style-position: inside;
padding-left: 0;
}
.nav-links.mobile-open li:not(.nav-call-item)::marker { color: var(--gold); }

.nav-links.mobile-open a {
font-size: 1rem;
font-family: 'Cormorant Garamond', Georgia, serif;
font-weight: 400;
color: var(--white);
letter-spacing: 0.1em;
}

.nav-links.mobile-open a:hover { color: var(--gold); }
.nav-call-item {
display: none;
list-style: none;
margin-top: 0.5rem;
}
.nav-call-item::marker { content: none; }

.nav-links.mobile-open .nav-call-item { display: list-item; }
.nav-links.mobile-open .nav-call-btn {
display: inline-flex;
align-items: center;
gap: 0.5rem;
padding: 0.7rem 1.4rem;
border: 1px solid var(--gold-dim);
color: var(--gold);
font-family: var(--font-body);
font-size: 0.85rem;
font-weight: 600;
letter-spacing: 0.1em;
text-transform: uppercase;
transition: all var(--transition);
}

.nav-links.mobile-open .nav-call-btn:hover {
background: var(--gold);
color: var(--black);
border-color: var(--gold);
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }

  .reveal {
    opacity: 1;
    transform: none;
  }

  .faq-answer {
    transition: none;
  }

  .faq-icon,
  .gallery-item img,
  .service-card,
  .sticky-btn,
  .sticky-bar,
  .btn-primary,
  .btn-secondary {
    transition: none;
  }
}

@media (hover: none) and (pointer: coarse) and (orientation: landscape) {
  nav,
  .sticky-bar,
  .nav-links.mobile-open {
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }

  nav {
    background: rgba(10, 10, 10, 0.96);
  }

  .sticky-bar {
    background: rgba(10, 10, 10, 0.98);
    box-shadow: 0 -6px 16px rgba(0, 0, 0, 0.35);
  }

  .nav-links.mobile-open {
    background: rgba(17, 17, 17, 1);
  }
}