/* =========================================================
   Ferienwohnung Afferde – Stylesheet
   Modern & hell, warme Naturtöne
   ========================================================= */
:root{
  --bg:#f7fafb;
  --bg-soft:#e8f1f5;
  --surface:#ffffff;
  --ink:#06303f;         /* navy aus dem Logo */
  --muted:#5c7682;
  --line:#d7e4ea;
  --accent:#ef8e12;      /* sonnen-orange */
  --accent-dark:#d2760a;
  --accent-soft:#fceed6;
  --navy:#06303f;
  --navy-soft:#0b465c;
  --blue:#1690c0;        /* wasser-blau */
  --blue-soft:#e3f1f7;
  --green:#6f9d2f;
  --radius:16px;
  --shadow:0 12px 40px rgba(40,36,30,.10);
  --shadow-sm:0 4px 16px rgba(40,36,30,.08);
  --max:1180px;
  --serif:"Cormorant Garamond",Georgia,"Times New Roman",serif;
  --sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--sans);color:var(--ink);background:var(--bg);
  line-height:1.65;font-size:17px;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit}
h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.1;letter-spacing:.2px;margin:0 0 .4em}
h1{font-size:clamp(2.6rem,6vw,4.4rem)}
h2{font-size:clamp(2rem,4vw,3rem)}
h3{font-size:1.5rem}
p{margin:0 0 1.1em}
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--sans);text-transform:uppercase;letter-spacing:.28em;
  font-size:.72rem;font-weight:600;color:var(--blue);margin-bottom:1rem;display:block}
.center{text-align:center}
.muted{color:var(--muted)}

/* ---------- Header ---------- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:50;transition:.35s ease;
  padding:6px 0;border-bottom:1px solid transparent}
.site-header.scrolled{background:rgba(247,250,251,.94);backdrop-filter:blur(10px);
  border-bottom-color:var(--line);padding:4px 0}
.nav{display:flex;align-items:center;justify-content:space-between;max-width:var(--max);margin:0 auto;padding:0 24px}
.brand{display:flex;align-items:center;text-decoration:none}
.brand img{height:122px;width:auto;display:block;transition:height .35s ease}
.site-header.scrolled .brand img{height:90px}
.brand .logo-full{display:none}
.brand .logo-white{display:block}
.site-header.scrolled .logo-white{display:none}
.site-header.scrolled .logo-full{display:block}
.site-header:not(.scrolled) .nav-links a{color:#fff}
.nav-links{display:flex;gap:30px;align-items:center;list-style:none;margin:0;padding:0}
.mobile-menu-head{display:none}
.nav-links a{text-decoration:none;font-size:.92rem;font-weight:500;letter-spacing:.02em;transition:.2s;position:relative;padding-bottom:3px}
.nav-links a:hover{color:var(--accent)}
.nav-links a.active{color:var(--accent)}
.nav-links a.nav-cta{background:var(--accent);color:#fff!important;padding:11px 24px;border-radius:999px;
  font-weight:600;display:inline-flex;align-items:center;justify-content:center;line-height:1}
.nav-cta:hover{background:var(--accent-dark)}
.burger{display:none;background:none;border:0;cursor:pointer;width:30px;height:24px;position:relative}
.burger span{position:absolute;left:0;right:0;height:2px;background:currentColor;transition:.3s}
.burger span:nth-child(1){top:0}.burger span:nth-child(2){top:11px}.burger span:nth-child(3){top:22px}
.site-header:not(.scrolled) .burger{color:#fff}.site-header.scrolled .burger{color:var(--ink)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.5em;background:var(--accent);color:#fff;
  text-decoration:none;padding:14px 30px;border-radius:999px;font-weight:600;font-size:.95rem;
  transition:.25s;border:0;cursor:pointer}
.btn:hover{background:var(--accent-dark);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.btn.ghost{background:transparent;border:1.5px solid var(--line);color:var(--ink)}
.btn.ghost:hover{border-color:var(--accent);color:var(--accent);background:transparent}
.btn.light{background:#fff;color:var(--ink)}
.btn-row{display:flex;gap:14px;flex-wrap:wrap}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero-media{position:absolute;inset:0;z-index:-2}
.hero-media img,.hero-media video{width:100%;height:100%;object-fit:cover}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(20,18,15,.45),rgba(20,18,15,.25) 45%,rgba(20,18,15,.6))}
.hero-inner{max-width:760px}
.hero h1{margin-bottom:.25em}
.hero p{font-size:1.2rem;max-width:560px;color:rgba(255,255,255,.92)}
.hero .btn-row{margin-top:2rem}

/* page hero (interior pages) */
.page-hero{position:relative;padding:200px 0 70px;color:#fff;text-align:center;overflow:hidden}
.page-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2}
.page-hero::after{content:"";position:absolute;inset:0;z-index:-1;background:rgba(28,25,20,.5)}
.page-hero p{max-width:600px;margin:0 auto;color:rgba(255,255,255,.92)}

/* ---------- Sections ---------- */
section{padding:90px 0}
.section-tight{padding:60px 0}
.bg-soft{background:var(--bg-soft)}
.lead{font-size:1.22rem;max-width:720px;color:var(--muted)}

/* split intro */
.split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.split img{border-radius:var(--radius);box-shadow:var(--shadow)}

/* highlight cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:34px 28px;box-shadow:var(--shadow-sm);transition:.25s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card .ico{width:46px;height:46px;border-radius:12px;background:var(--blue-soft);
  display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:var(--blue)}
.card h3{font-family:var(--sans);font-size:1.1rem;font-weight:700;margin-bottom:.4em}
.card p{font-size:.96rem;color:var(--muted);margin:0}

/* facts strip */
.facts{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.facts .num{font-family:var(--serif);font-size:2.8rem;color:var(--accent-dark);line-height:1}
.facts .lbl{font-size:.82rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin-top:6px}

/* amenities list */
.amen{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 40px;list-style:none;padding:0;margin:0}
.amen li{display:flex;gap:12px;align-items:flex-start;padding:8px 0;border-bottom:1px solid var(--line)}
.amen svg{flex:0 0 auto;color:var(--accent);margin-top:3px}

/* room blocks */
.room{display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:center;margin-bottom:60px}
.room:nth-child(even){direction:rtl}
.room:nth-child(even)>*{direction:ltr}
.room img{border-radius:var(--radius);box-shadow:var(--shadow)}

/* gallery */
.gallery{columns:3;column-gap:16px}
.gallery figure{margin:0 0 16px;break-inside:avoid;border-radius:14px;overflow:hidden;cursor:pointer;box-shadow:var(--shadow-sm);position:relative}
.gallery img{transition:.5s ease;width:100%}
.gallery figure:hover img{transform:scale(1.05)}
.gallery figcaption{position:absolute;left:0;right:0;bottom:0;padding:16px 14px 12px;color:#fff;
  font-size:.85rem;letter-spacing:.04em;background:linear-gradient(transparent,rgba(0,0,0,.6));opacity:0;transition:.3s}
.gallery figure:hover figcaption{opacity:1}

/* lightbox */
.lb{position:fixed;inset:0;background:rgba(20,18,15,.94);z-index:100;display:none;
  align-items:center;justify-content:center}
.lb.open{display:flex}
.lb img{max-width:90vw;max-height:86vh;border-radius:8px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.lb-btn{position:absolute;background:rgba(255,255,255,.12);border:0;color:#fff;width:52px;height:52px;
  border-radius:50%;font-size:1.6rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.2s}
.lb-btn:hover{background:rgba(255,255,255,.25)}
.lb-prev{left:24px;top:50%;transform:translateY(-50%)}
.lb-next{right:24px;top:50%;transform:translateY(-50%)}
.lb-close{top:24px;right:24px;width:46px;height:46px;font-size:1.3rem}

/* video */
.video-wrap{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);background:#000}
.video-wrap video{width:100%;display:block}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px}
.contact-card{display:flex;gap:16px;align-items:flex-start;padding:22px;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--radius);margin-bottom:16px;text-decoration:none;transition:.2s}
.contact-card:hover{box-shadow:var(--shadow-sm);transform:translateY(-2px);border-color:var(--accent)}
.contact-card .ci{width:46px;height:46px;flex:0 0 auto;border-radius:12px;background:var(--blue-soft);
  display:flex;align-items:center;justify-content:center;color:var(--blue)}
.contact-card strong{display:block;font-size:1.02rem}
.contact-card span{color:var(--muted);font-size:.94rem}
form label{display:block;font-size:.85rem;font-weight:600;margin:0 0 6px;letter-spacing:.02em}
form input,form textarea{width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:10px;
  font:inherit;background:#fff;margin-bottom:18px;transition:.2s}
form input:focus,form textarea:focus{outline:0;border-color:var(--accent)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.map-embed{border:0;width:100%;height:100%;min-height:340px;border-radius:var(--radius);filter:grayscale(.15)}

/* CTA band */
.cta-band{background:var(--accent);color:#fff;text-align:center;border-radius:24px;padding:64px 24px;margin:0 24px}
.cta-band h2{color:#fff}
.cta-band p{color:rgba(255,255,255,.9);max-width:560px;margin:0 auto 1.6em}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy);color:#bcd2dc;padding:64px 0 28px;font-size:.92rem}
.footer-logo{height:64px;width:auto;margin-bottom:18px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:40px}
.site-footer h4{font-family:var(--serif);color:#fff;font-size:1.3rem;margin:0 0 14px}
.site-footer a{color:#bcd2dc;text-decoration:none}
.site-footer a:hover{color:#fff}
.site-footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.foot-bottom{border-top:1px solid #1c4f63;padding-top:22px;display:flex;justify-content:space-between;
  flex-wrap:wrap;gap:10px;color:#7a9aa8;font-size:.85rem}

/* reveal animation */
.reveal{opacity:0;transform:translateY(24px);transition:.7s cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .split,.contact-grid{grid-template-columns:1fr;gap:32px}
  .room,.room:nth-child(even){grid-template-columns:1fr;direction:ltr;gap:24px}
  .cards{grid-template-columns:1fr}
  .facts{grid-template-columns:repeat(2,1fr);gap:32px 20px}
  .gallery{columns:2}
  .amen{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:28px}
}
@media(max-width:640px){
  body{font-size:16px}
  section{padding:64px 0}
  .brand img,.site-header.scrolled .brand img{height:84px}
  .page-hero{padding:150px 0 60px}
  .mobile-menu-head{display:flex!important;align-items:center;justify-content:space-between;
    width:100%;padding-bottom:18px;margin-bottom:14px;border-bottom:1px solid var(--line)}
  .mm-logo{height:74px;width:auto;display:block}
  .mm-close{background:none;border:0;color:var(--accent);font-size:2.6rem;line-height:1;
    cursor:pointer;padding:0 4px}
  .nav-links .nav-cta{display:inline-flex;align-items:center;justify-content:center;text-align:center}
  .nav-links{position:fixed;inset:0 0 0 auto;width:80%;max-width:340px;background:var(--bg);
    flex-direction:column;align-items:flex-start;justify-content:flex-start;padding:24px 30px;gap:20px;
    overflow-y:auto;transform:translateX(100%);transition:.35s;box-shadow:-10px 0 40px rgba(0,0,0,.15)}
  .nav-links.open{transform:none}
  .nav-links a,.site-header:not(.scrolled) .nav-links a{color:var(--ink);font-size:1.1rem}
  .burger{display:block;z-index:60}
  .form-row{grid-template-columns:1fr}
  .gallery{columns:1}
  .cta-band{margin:0 16px;padding:48px 22px}
}
