/* =========================================================================
   Laurentius – Startseiten-Module (nur auf der Front-Page geladen)
   Hero · Split/Gastgeber · Feature-Bänder · Promo · Newsletter/Kontakt
   ========================================================================= */

/* HERO ------------------------------------------------------------------- */
.hero { position: relative; min-height: min(88vh, 820px); display: flex; align-items: center; overflow: hidden; }
.hero__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center 60%; }
.hero__overlay { position: absolute; inset: 0; background:
	linear-gradient(180deg, rgba(20,12,10,.45) 0%, rgba(20,12,10,.15) 35%, rgba(20,12,10,.55) 100%),
	linear-gradient(90deg, rgba(20,12,10,.5) 0%, rgba(20,12,10,0) 60%); }
.hero__inner { position: relative; z-index: 2; color: #fff; padding-block: clamp(4rem, 10vh, 8rem); max-width: min(1120px, 100%); }
.hero__inner .kicker { color: var(--c-gold-soft); font-size: 1.02rem; letter-spacing: .3em; margin-bottom: 1.1rem; text-shadow: 0 1px 12px rgba(0,0,0,.45); }
.hero__title { font-family: var(--ff-body); font-weight: 300; text-transform: uppercase; letter-spacing: .07em; color: #fff; font-size: clamp(2.1rem, 1.4rem + 3vw, 3.9rem); line-height: 1.18; text-shadow: 0 2px 30px rgba(0,0,0,.45); margin: 0; }
.hero__sub { color: #f3ece4; font-size: clamp(1.1rem, 1rem + .6vw, 1.45rem); margin-top: 1.25rem; max-width: 48ch; }
.hero__actions { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 2.25rem; }
.hero__scroll { position: absolute; left: 50%; bottom: 1.75rem; transform: translateX(-50%); z-index: 2; width: 26px; height: 42px; border: 2px solid rgba(255,255,255,.7); border-radius: 14px; }
.hero__scroll span { position: absolute; left: 50%; top: 8px; width: 4px; height: 8px; background: #fff; border-radius: 2px; transform: translateX(-50%); animation: scrolldot 1.8s var(--ease) infinite; }
@keyframes scrolldot { 0% { opacity: 0; transform: translate(-50%, 0); } 40% { opacity: 1; } 80%,100% { opacity: 0; transform: translate(-50%, 14px); } }

/* --- Cinematischer Auftritt -------------------------------------------- */
/* Langsamer, lebendiger Ken-Burns-Drift auf dem Hero-Bild. */
.hero__img { transform-origin: center 55%; animation: heroDrift 32s ease-in-out infinite alternate; }
@keyframes heroDrift { from { transform: scale(1); } to { transform: scale(1.07); } }

/* Gold-Linie unter der Überschrift, zeichnet sich ein. */
.hero__rule { display: block; height: 2px; width: 0; margin-top: 1.6rem; background: var(--c-gold); opacity: 0; animation: heroRule 1s var(--ease) .6s forwards; }
@keyframes heroRule { from { width: 0; opacity: 0; } to { width: 76px; opacity: 1; } }

/* Gestaffeltes Einblenden von Kicker, Titel, Subline und Buttons. */
.hero__inner .kicker,
.hero__title,
.hero__sub,
.hero__actions { opacity: 0; animation: heroRise .9s var(--ease) forwards; }
.hero__inner .kicker { animation-delay: .15s; }
.hero__title        { animation-delay: .35s; }
.hero__sub          { animation-delay: .6s; }
.hero__actions      { animation-delay: .85s; }
@keyframes heroRise { from { opacity: 0; transform: translateY(26px); } to { opacity: 1; transform: none; } }

@media (prefers-reduced-motion: reduce) {
	.hero__img { animation: none; }
	.hero__rule { animation: none; opacity: 1; width: 76px; }
	.hero__inner .kicker,
	.hero__title,
	.hero__sub,
	.hero__actions { animation: none; opacity: 1; }
}

/* SPLIT (Gastgeber) ------------------------------------------------------ */
.split__grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: clamp(2rem, 5vw, 5rem); align-items: center; }
.split__media { display: flex; justify-content: center; }
.split__badge { width: min(280px, 70%); height: auto; border-radius: 50%; }
/* Gastgeber-Porträt mit dezentem JRE-Badge in der Ecke */
.split__figure { position: relative; margin: 0; width: 100%; }
.split__figure img { width: 100%; aspect-ratio: 3 / 2; object-fit: cover; object-position: 50% 30%; border-radius: var(--radius); box-shadow: var(--shadow-sm); display: block; }
.split__figure-badge { position: absolute; right: -14px; bottom: -14px; width: clamp(64px, 9vw, 92px) !important; height: auto !important; aspect-ratio: 1 !important; border-radius: 50%; background: var(--c-cream); padding: 10px; box-shadow: var(--shadow-sm); }
.pull-quote { font-family: var(--ff-head); font-size: clamp(1.6rem, 1.2rem + 1.6vw, 2.4rem); line-height: 1.25; color: var(--c-wine); margin: 1rem 0 1.5rem; font-style: italic; }
/* Dezenter Inline-Hinweis (z. B. Märktle-Öffnung für Hotelgäste) */
.note-inline { display: inline-flex; align-items: baseline; gap: .55rem; font-size: .96rem; color: var(--c-wine); font-style: italic; }
.note-inline::before { content: ""; flex: 0 0 auto; align-self: center; width: .5rem; height: .5rem; border-radius: 50%; background: var(--c-gold); }

/* Auszeichnungen (JRE, Weinhotel) */
.awards { display: flex; flex-wrap: wrap; align-items: center; gap: 1rem; list-style: none; padding: 0; margin: 1.75rem 0 0; }
.awards__item { display: flex; align-items: center; justify-content: center; height: 76px; padding: .6rem 1rem; background: var(--c-white); border: 1px solid var(--c-line); border-radius: var(--radius); }
.awards__item img { max-height: 100%; width: auto; display: block; }
@media (max-width: 760px) { .split__grid { grid-template-columns: 1fr; } .split__media { order: -1; } }

/* Foto-Split (Märktle): rechteckiges Bild statt rundem Badge */
.split__grid.split--photo { grid-template-columns: 1.05fr 1fr; align-items: center; }
.split__photo img { width: 100%; aspect-ratio: 3 / 2; object-fit: cover; border-radius: var(--radius); box-shadow: var(--shadow-sm); }
@media (max-width: 760px) { .split__grid.split--photo { grid-template-columns: 1fr; } .split__photo { order: -1; } }

/* FEATURE-BAND (Restaurant / TauberPhilharmonie) ------------------------- */
.feature { position: relative; display: flex; align-items: center; min-height: clamp(420px, 60vh, 620px); overflow: hidden; }
.feature--tall { min-height: clamp(460px, 70vh, 720px); }
.feature__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.feature__overlay { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(83,20,23,.82) 0%, rgba(83,20,23,.5) 55%, rgba(83,20,23,.2) 100%); }
/* Neutral-dunkler Overlay (kein Rotstich) – z. B. Restaurant-Band */
.feature--neutral .feature__overlay { background: linear-gradient(90deg, rgba(20,14,12,.78) 0%, rgba(20,14,12,.45) 55%, rgba(20,14,12,.15) 100%); }
.feature__inner { position: relative; z-index: 2; color: #fff; padding-block: clamp(3rem, 7vw, 6rem); max-width: 680px; }
.feature__inner .kicker { color: var(--c-gold-soft); }
.feature__title { color: #fff; font-weight: 300; }
.feature__lead { color: #f3ece4; font-size: clamp(1.05rem, 1rem + .5vw, 1.35rem); margin-top: 1rem; letter-spacing: .04em; }

/* PROMO (Arrangements / Feiern) ------------------------------------------ */
.promo { display: flex; flex-direction: column; background: #fff; border: 1px solid var(--c-line); border-radius: var(--radius); overflow: hidden; }
.promo__media { aspect-ratio: 16 / 10; overflow: hidden; }
.promo__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s var(--ease); }
.promo:hover .promo__media img { transform: scale(1.04); }
.promo__body { padding: clamp(1.5rem, 3vw, 2.5rem); display: flex; flex-direction: column; gap: .75rem; }

/* Zimmer-Karte: Fuß mit Details + Buchen ---------------------------------- */
.card--room .card__foot { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-top: auto; padding-top: .5rem; flex-wrap: wrap; }
.card--room .card__foot .btn { padding: .6em 1.1em; font-size: .72rem; }

/* NEWSLETTER / KONTAKT --------------------------------------------------- */
.contact-grid { align-items: start; gap: clamp(2rem, 4vw, 4rem); }
.contact-card { background: #fff; border: 1px solid var(--c-line); border-radius: var(--radius); padding: clamp(1.75rem, 3vw, 2.5rem); }
.contact-card h3 { margin-bottom: 1rem; }
.contact-card__hours { margin-bottom: 1.25rem; line-height: 1.7; }
.contact-card__address { font-style: normal; line-height: 1.8; margin-bottom: 1.5rem; }
.muted { color: var(--c-muted); font-size: .92em; }

.newsletter { margin-top: 1.5rem; }
.newsletter__row { display: flex; gap: .75rem; flex-wrap: wrap; }
.newsletter__row input[type="email"] { flex: 1; min-width: 220px; padding: .85em 1em; border: 1px solid var(--c-line); border-radius: var(--radius); background: #fff; }
.newsletter__row input[type="email"]:focus-visible { outline: 2px solid var(--c-gold); outline-offset: 1px; }
.newsletter__consent { display: flex; gap: .6rem; align-items: flex-start; margin-top: 1rem; font-size: .9rem; color: var(--c-charcoal); }
.newsletter__consent input { margin-top: .25rem; }
.newsletter__note { font-size: .82rem; color: var(--c-muted); margin-top: .6rem; }

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