/* ============================================================
   Pension Langerwehe – gemeinsames Stylesheet
   ============================================================ */
:root{
  --green:#1f3d2b; --green-2:#2c5640; --gold:#c8924a; --gold-2:#e0b574;
  --cream:#faf6ef; --sand:#f1e9db; --ink:#23211d; --muted:#6f6a60;
  --white:#ffffff; --radius:18px; --shadow:0 18px 50px -22px rgba(31,61,43,.55);
  --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:"Segoe UI",system-ui,-apple-system,"Helvetica Neue",Arial,sans-serif;
  color:var(--ink);background:var(--cream);line-height:1.65;overflow-x:hidden}
h1,h2,h3,h4{font-family:Georgia,"Times New Roman",serif;line-height:1.15;font-weight:600}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{display:inline-block;letter-spacing:.22em;text-transform:uppercase;
  font-size:.72rem;font-weight:700;color:var(--gold);margin-bottom:14px}
.btn{display:inline-flex;align-items:center;gap:.55em;border:none;cursor:pointer;
  font-size:.98rem;font-weight:600;padding:15px 30px;border-radius:999px;transition:.25s;font-family:inherit}
.btn-gold{background:linear-gradient(135deg,var(--gold-2),var(--gold));color:#3a2a12;
  box-shadow:0 12px 28px -10px rgba(200,146,74,.8)}
.btn-gold:hover{transform:translateY(-3px);box-shadow:0 18px 34px -10px rgba(200,146,74,.9)}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border:1.5px solid rgba(255,255,255,.55)}
.btn-ghost:hover{background:rgba(255,255,255,.22)}
.btn-dark{background:var(--green);color:#fff}
.btn-dark:hover{background:var(--green-2);transform:translateY(-3px)}

/* NAV */
header{position:fixed;inset:0 0 auto 0;z-index:50;transition:.3s}
header.scrolled,header.solid{background:rgba(250,246,239,.95);backdrop-filter:blur(10px);
  box-shadow:0 6px 24px -16px rgba(0,0,0,.5)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:12px;color:#fff;transition:.3s}
header.scrolled .brand,header.solid .brand{color:var(--green)}
.brand .mark{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--gold-2),var(--gold));color:#3a2a12;flex:none;box-shadow:var(--shadow)}
.brand b{font-family:Georgia,serif;font-size:1.18rem;font-weight:600}
.brand span{display:block;font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;opacity:.85;font-family:"Segoe UI",sans-serif}
.logo-pill{background:#fff;border-radius:12px;padding:8px 14px;display:block;box-shadow:0 10px 26px -14px rgba(0,0,0,.5)}
.logo-pill img{height:34px;width:auto;display:block}
@media(max-width:620px){.logo-pill img{height:28px}}
.menu{display:flex;gap:26px;list-style:none;font-size:.92rem;font-weight:500;color:#fff;transition:.3s}
header.scrolled .menu,header.solid .menu{color:var(--green)}
.menu a{position:relative;opacity:.92}
.menu a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--gold);transition:.25s}
.menu a:hover::after,.menu a.active::after{width:100%}
.menu a.active{opacity:1;color:var(--gold)}
.nav .btn{padding:11px 22px;font-size:.88rem}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;z-index:60}
.burger span{width:26px;height:2.5px;background:#fff;border-radius:2px;transition:.3s}
header.scrolled .burger span,header.solid .burger span{background:var(--green)}
/* mobile drawer */
.drawer{position:fixed;inset:0;background:rgba(22,39,29,.97);backdrop-filter:blur(6px);
  z-index:55;display:flex;flex-direction:column;justify-content:center;gap:6px;padding:40px;
  transform:translateX(100%);transition:.35s;list-style:none}
.drawer.open{transform:none}
.drawer a{color:#fff;font-family:Georgia,serif;font-size:1.5rem;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.12)}
.drawer a:hover{color:var(--gold-2)}

/* HERO (home) */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;
  background-image:linear-gradient(115deg,rgba(15,27,19,.9),rgba(20,40,30,.55)),
    var(--bg,radial-gradient(120% 120% at 80% 10%,#3a6b4d 0%,#234032 45%,#16271d 100%));
  background-size:cover;background-position:center;color:#fff;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;opacity:.5;
  background-image:radial-gradient(circle at 18% 78%,rgba(200,146,74,.35),transparent 38%),
  radial-gradient(circle at 92% 22%,rgba(224,181,116,.25),transparent 40%)}
.hills{position:absolute;left:0;right:0;bottom:-2px;width:100%;height:auto;display:block}
.hero-inner{position:relative;z-index:2;padding:120px 0 160px}
.hero h1{font-size:clamp(2.5rem,6vw,4.4rem);max-width:14ch;margin:8px 0 22px;text-shadow:0 4px 30px rgba(0,0,0,.35)}
.hero h1 i{color:var(--gold-2);font-style:normal}
.hero p{font-size:1.18rem;max-width:52ch;opacity:.92;margin-bottom:34px}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap}
.hero-badges{display:flex;gap:28px;margin-top:46px;flex-wrap:wrap}
.hero-badges div{display:flex;align-items:center;gap:10px;font-size:.92rem;opacity:.92}

/* PAGE HERO (subpages) */
.page-hero{position:relative;padding:150px 0 160px;color:#fff;overflow:hidden;
  background-image:linear-gradient(115deg,rgba(15,27,19,.88),rgba(20,40,30,.62)),
    var(--bg,radial-gradient(120% 140% at 80% 0%,#3a6b4d,#234032 55%,#16271d));
  background-size:cover;background-position:center}
.page-hero::before{content:"";position:absolute;inset:0;opacity:.45;
  background-image:radial-gradient(circle at 15% 90%,rgba(200,146,74,.4),transparent 40%)}
.page-hero .inner{position:relative;z-index:2}
.page-hero h1{font-size:clamp(2.2rem,5vw,3.4rem);margin:6px 0 14px;max-width:18ch}
.page-hero p{max-width:56ch;opacity:.9;font-size:1.1rem}
.crumb{font-size:.82rem;opacity:.7;margin-bottom:6px}
.crumb a:hover{color:var(--gold-2)}
.page-hero .hills{bottom:-1px}

/* SECTION SHELL */
section{padding:96px 0}
.head{text-align:center;max-width:640px;margin:0 auto 56px}
.head h2{font-size:clamp(2rem,4vw,2.8rem);color:var(--green);margin-bottom:14px}
.head p{color:var(--muted);font-size:1.05rem}

/* GRID + CARDS */
.usp{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card{background:var(--white);border:1px solid #ece4d6;border-radius:var(--radius);
  padding:38px 30px;transition:.3s;box-shadow:0 10px 30px -24px rgba(31,61,43,.6)}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--gold-2)}
.ico{width:58px;height:58px;border-radius:16px;display:grid;place-items:center;margin-bottom:20px;
  background:linear-gradient(135deg,#eaf3ec,#d8e8dd);color:var(--green-2)}
.card h3{font-size:1.28rem;color:var(--green);margin-bottom:10px}
.card p{color:var(--muted);font-size:.97rem}

/* ROOMS */
.rooms-sec{background:linear-gradient(180deg,var(--sand),var(--cream))}
.rooms{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.room{background:var(--white);border-radius:var(--radius);overflow:hidden;
  box-shadow:0 12px 34px -26px rgba(31,61,43,.7);transition:.3s;display:flex;flex-direction:column}
.room:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.room .pic{height:210px;position:relative;display:grid;place-items:center;color:#fff;
  background-size:cover;background-position:center}
.room .pic::before{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.28),rgba(0,0,0,0) 45%)}
.room .pic span{position:absolute;top:14px;right:14px;background:var(--gold);color:#3a2a12;
  font-size:.74rem;font-weight:700;padding:6px 13px;border-radius:999px;z-index:2}
.r1{background:linear-gradient(135deg,#6b8f76,#3c5e49)}
.r2{background:linear-gradient(135deg,#c8924a,#9c6b2f)}
.r3{background:linear-gradient(135deg,#7d8aa5,#4a5872)}
.room .body{padding:26px 26px 30px;flex:1;display:flex;flex-direction:column}
.room h3{font-size:1.35rem;color:var(--green);margin-bottom:8px}
.room .feat{list-style:none;margin:14px 0 22px;color:var(--muted);font-size:.93rem}
.room .feat li{padding:5px 0 5px 24px;position:relative}
.room .feat li::before{content:"✓";position:absolute;left:0;color:var(--gold);font-weight:700}
.price{margin-top:auto;display:flex;align-items:baseline;justify-content:space-between}
.price b{font-family:Georgia,serif;font-size:1.7rem;color:var(--green)}
.price small{color:var(--muted);font-size:.82rem}

/* SPLIT */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.split.rev > :first-child{order:2}
.split .visual{height:420px;border-radius:24px;position:relative;overflow:hidden;
  background:radial-gradient(120% 120% at 30% 20%,#6b8f76,#234032);box-shadow:var(--shadow)}
.split .visual svg{position:absolute;bottom:0;width:100%}
.stat-row{display:flex;gap:34px;margin-top:28px;flex-wrap:wrap}
.stat b{font-family:Georgia,serif;font-size:2rem;color:var(--gold);display:block}
.stat small{color:var(--muted);font-size:.85rem}
.split h2{color:var(--green);font-size:clamp(1.9rem,3.5vw,2.6rem);margin-bottom:18px}
.split p{color:var(--muted);margin-bottom:14px}

/* PROSE / generic content */
.prose{max-width:760px;margin:0 auto}
.prose h2{color:var(--green);font-size:1.7rem;margin:36px 0 12px}
.prose h3{color:var(--green);font-size:1.25rem;margin:26px 0 8px}
.prose p{color:#46443d;margin-bottom:14px}
.prose ul{margin:0 0 16px 0;padding-left:0;list-style:none}
.prose ul li{position:relative;padding:6px 0 6px 26px;color:#46443d}
.prose ul li::before{content:"✓";position:absolute;left:0;color:var(--gold);font-weight:700}
.prose a{color:var(--green-2);text-decoration:underline;text-decoration-color:var(--gold-2)}

/* TABLE */
.tbl{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;
  box-shadow:0 10px 30px -24px rgba(31,61,43,.6);margin:10px 0}
.tbl th{background:var(--green);color:#fff;text-align:left;padding:15px 20px;font-family:Georgia,serif;font-weight:600}
.tbl td{padding:14px 20px;border-top:1px solid #efe7d8;color:#46443d}
.tbl tr:nth-child(even) td{background:#faf6ef}
.tbl td b{color:var(--green)}

/* FEATURE CHIPS */
.chips{display:flex;flex-wrap:wrap;gap:12px;margin:18px 0}
.chip{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid #e7ddcd;
  padding:10px 16px;border-radius:999px;font-size:.9rem;color:var(--green-2);box-shadow:0 6px 18px -16px rgba(31,61,43,.6)}

/* TESTIMONIAL */
.quotes{background:var(--green);color:#fff}
.quotes .head h2{color:#fff}
.quotes .head p{color:rgba(255,255,255,.7)}
.qgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.q{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:var(--radius);padding:30px}
.stars{color:var(--gold-2);margin-bottom:14px;letter-spacing:3px}
.q p{font-size:.99rem;opacity:.95;margin-bottom:16px;font-style:italic}
.q b{font-size:.92rem}
.q small{display:block;opacity:.6;font-size:.8rem}

/* FORM */
.form{background:#fff;border-radius:var(--radius);padding:34px;box-shadow:var(--shadow);border:1px solid #ece4d6}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{margin-bottom:18px}
.field label{display:block;font-size:.86rem;font-weight:600;color:var(--green);margin-bottom:6px}
.field input,.field textarea,.field select{width:100%;padding:13px 15px;border:1.5px solid #e2d8c6;
  border-radius:12px;font-family:inherit;font-size:.95rem;background:#fdfbf7;transition:.2s}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--gold);background:#fff}
.note{font-size:.8rem;color:var(--muted);margin-top:10px}

/* CONTACT CARDS */
.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.cc{background:#fff;border:1px solid #ece4d6;border-radius:var(--radius);padding:30px;text-align:center;transition:.3s}
.cc:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--gold-2)}
.cc .ico{margin:0 auto 16px}
.cc h3{color:var(--green);font-size:1.15rem;margin-bottom:6px}
.cc a{color:var(--green-2);font-weight:600}

/* GALLERY */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.gallery .g{aspect-ratio:1/1;border-radius:16px;overflow:hidden;background-size:cover;
  background-position:center;transition:.4s;box-shadow:0 12px 30px -22px rgba(31,61,43,.7)}
.gallery .g:hover{transform:scale(1.03)}

/* PARTNERS */
.partners{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.partner{background:#fff;border:1px solid #ece4d6;border-radius:var(--radius);padding:30px 24px;
  text-align:center;transition:.3s;display:flex;flex-direction:column;align-items:center;gap:12px}
.partner:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--gold-2)}
.partner .logo{width:64px;height:64px;border-radius:16px;display:grid;place-items:center;color:#fff;font-family:Georgia,serif;font-size:1.6rem;font-weight:700}
.partner img.plogo{height:56px;width:auto;max-width:90%;object-fit:contain}
.partner h3{color:var(--green);font-size:1.05rem}
.partner p{color:var(--muted);font-size:.88rem}

/* ACCORDION */
.acc{max-width:780px;margin:0 auto}
.acc details{background:#fff;border:1px solid #ece4d6;border-radius:14px;margin-bottom:14px;overflow:hidden}
.acc summary{cursor:pointer;padding:20px 24px;font-family:Georgia,serif;font-size:1.1rem;color:var(--green);
  list-style:none;display:flex;justify-content:space-between;align-items:center}
.acc summary::-webkit-details-marker{display:none}
.acc summary::after{content:"+";font-size:1.5rem;color:var(--gold);transition:.2s}
.acc details[open] summary::after{transform:rotate(45deg)}
.acc .ac-body{padding:0 24px 22px;color:#46443d}

/* CTA BAND */
.band{background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#3a2a12;text-align:center;
  border-radius:28px;padding:62px 30px;margin:0 24px;box-shadow:var(--shadow)}
.band h2{font-size:clamp(1.9rem,4vw,2.7rem);margin-bottom:14px}
.band p{max-width:46ch;margin:0 auto 28px;font-size:1.06rem;color:#503a17}

/* EMBED */
.embed{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);background:#fff;border:1px solid #ece4d6}
.embed iframe{width:100%;min-height:760px;border:0;display:block}

/* FOOTER */
footer{background:#16271d;color:#cdd7cf;padding:70px 0 28px;margin-top:96px}
.fgrid{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:40px}
footer h4{color:#fff;font-family:Georgia,serif;font-size:1.05rem;margin-bottom:16px}
footer a,footer p{color:#aebcb1;font-size:.92rem;display:block;margin-bottom:9px;transition:.2s}
footer a:hover{color:var(--gold-2)}
.fbrand b{font-family:Georgia,serif;color:#fff;font-size:1.3rem}
.fbar{border-top:1px solid rgba(255,255,255,.1);margin-top:46px;padding-top:22px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.82rem;color:#7e8c81}
.fbar a{display:inline;margin:0 0 0 18px;color:#7e8c81}

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

@media(max-width:900px){
  .menu,.nav>.btn.desk{display:none}
  .burger{display:flex}
  .usp,.rooms,.qgrid,.contact-grid,.partners{grid-template-columns:1fr 1fr}
  .split,.fgrid,.form .row{grid-template-columns:1fr;gap:32px}
  .fgrid{grid-template-columns:1fr 1fr}
  .split.rev > :first-child{order:0}
  .gallery{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:620px){
  .usp,.rooms,.qgrid,.fgrid,.contact-grid,.partners{grid-template-columns:1fr}
  section{padding:70px 0}
  .hero-inner{padding:120px 0 130px}
  .form .row{grid-template-columns:1fr}
}
