/* Lieblingsplatz · lieblingsplatz.site · Phase 1
   Brand: "Nicht perfekt. Aber echt." · Design-Guide V2.2
   Farben: Sand/Grün/Kupfer · Typo: Playfair Display + Work Sans */

:root{
  --green:#3d4a2e; --green-d:#2c3621; --green-l:#566b40;
  --ochre:#b87333; --ochre-d:#a5631f; --ochre-l:#d98f43;
  --sand:#f6f1e6; --sand-2:#efe7d6; --cream:#fbf8f1;
  --ink:#2a2823; --muted:#6f6a5c; --line:#e3dccb;
  --radius:16px; --shadow:0 12px 34px rgba(46,40,25,.10);
  --serif:"Playfair Display",Georgia,"Times New Roman",serif;
  --sans:"Work Sans",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--cream);line-height:1.6;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}

/* header */
header{position:sticky;top:0;z-index:50;background:rgba(251,248,241,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;gap:26px;height:74px}
.logo{display:flex;align-items:center;gap:11px;font-family:var(--serif);font-weight:800;font-style:italic;color:var(--green);font-size:21px;letter-spacing:-.3px}
.logo img{width:42px;height:42px;border-radius:10px;object-fit:cover;flex:none}
.nav ul{display:flex;gap:22px;list-style:none;margin-left:14px;font-size:15px;color:#4a4639;font-weight:500}
.nav ul a:hover{color:var(--ochre-d)}
.nav .spacer{flex:1}
.lang{font-size:13px;color:var(--muted);display:flex;gap:7px;align-items:center}
.lang a{padding:3px 7px;border-radius:7px;font-weight:600}
.lang a.active{background:var(--green);color:#fff}
.lang a:not(.active):hover{color:var(--green)}
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:15px;border-radius:999px;padding:11px 22px;cursor:pointer;border:0;transition:.18s;font-family:var(--sans)}
.btn-primary{background:var(--ochre);color:#fff;box-shadow:0 6px 16px rgba(184,115,51,.32)}
.btn-primary:hover{background:var(--ochre-d)}
.btn-ghost{background:transparent;border:1.5px solid var(--green);color:var(--green)}
.btn-ghost:hover{background:var(--green);color:#fff}
.btn-light{background:#fff;color:var(--green)}
.btn-light:hover{background:var(--sand)}

/* hero */
.hero{position:relative;min-height:638px;display:flex;align-items:flex-end;color:#fff;overflow:hidden;
  background:linear-gradient(180deg,rgba(34,40,22,.18),rgba(28,33,18,.74)),
  radial-gradient(120% 80% at 70% 20%,#7c8a55 0%,#566b40 38%,#3d4a2e 100%);background-size:cover;background-position:center}
.hero .photo-tag{position:absolute;top:16px;right:22px;font-size:12px;color:#f3ecd8;background:rgba(0,0,0,.28);padding:5px 11px;border-radius:999px}
.hero-inner{padding:56px 0 46px;max-width:760px}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:13.5px;letter-spacing:1.4px;text-transform:uppercase;color:#f1d9ad;font-weight:600;margin-bottom:18px}
.hero h1{font-family:var(--serif);font-size:54px;line-height:1.06;font-weight:800;letter-spacing:-.5px;margin-bottom:16px;text-shadow:0 2px 24px rgba(0,0,0,.3)}
.hero h1 i{font-style:italic;color:#f0c489}
.hero p.lead{font-size:19px;color:#f2ede1;max-width:560px;margin-bottom:14px}
.rating{display:flex;align-items:center;gap:10px;font-size:15px;color:#f6efe0;margin-bottom:26px;flex-wrap:wrap}
.stars{color:#f6c969;letter-spacing:2px;font-size:16px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}

/* booking bar */
.bookbar{max-width:1180px;margin:-38px auto 0;position:relative;z-index:5;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);
  display:grid;grid-template-columns:1.1fr 1fr 1fr auto;border:1px solid var(--line);overflow:hidden}
.bookbar .field{padding:16px 22px;border-right:1px solid var(--line)}
.bookbar .field label{display:block;font-size:11.5px;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);font-weight:700;margin-bottom:3px}
.bookbar .field .val{font-size:16px;color:var(--ink);font-weight:600;display:flex;align-items:center;gap:8px}
.bookbar .field .val .ic{color:var(--ochre)}
.bookbar .go{padding:14px;display:flex;align-items:center}
.bookbar .go .btn{width:100%;justify-content:center;height:100%}

section{padding:78px 0}
.center{text-align:center}
.kicker{color:var(--ochre-d);font-weight:700;letter-spacing:1.4px;text-transform:uppercase;font-size:13px;margin-bottom:12px}
h2{font-family:var(--serif);font-size:36px;line-height:1.12;font-weight:800;letter-spacing:-.4px;color:var(--green-d)}
.sub{color:var(--muted);font-size:18px;max-width:620px;margin:14px auto 0}

/* trust strip */
.trust{background:var(--sand);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:30px 0}
.trust .row{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.trust .item{display:flex;align-items:center;gap:13px;font-size:15px;font-weight:600;color:var(--green-d)}
.trust .ic{width:42px;height:42px;border-radius:12px;background:#fff;border:1px solid var(--line);display:grid;place-items:center;color:var(--ochre);font-size:20px;flex:none}
.trust .item small{display:block;font-weight:400;color:var(--muted);font-size:13px}

/* units */
.units{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:46px}
.card{background:#fff;border-radius:var(--radius);border:1px solid var(--line);overflow:hidden;box-shadow:0 6px 22px rgba(46,40,25,.06);display:flex;flex-direction:column;transition:.18s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card .ph{height:208px;position:relative;display:grid;place-items:center;color:#fff;background-size:cover;background-position:center}
.ph-1{background:linear-gradient(135deg,#6f8049,#46562f)}
.ph-2{background:linear-gradient(135deg,#c98a4e,#9a5f2c)}
.ph-3{background:linear-gradient(135deg,#8a9a6a,#5d6b44)}
.card .ph .cap{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(0deg,rgba(0,0,0,.42),transparent);padding:14px;font-size:12.5px;color:#f3ecd8}
.card .ph .price{position:absolute;top:14px;right:14px;background:#fff;color:var(--green-d);font-weight:700;font-size:14px;padding:6px 12px;border-radius:999px;box-shadow:0 4px 10px rgba(0,0,0,.12)}
.card .ph .save{position:absolute;top:14px;left:14px;background:var(--green);color:#f3c98a;font-weight:700;font-size:11px;letter-spacing:.4px;text-transform:uppercase;padding:5px 10px;border-radius:999px}
.card .body{padding:20px 22px 24px;flex:1;display:flex;flex-direction:column}
.card h3{font-size:21px;color:var(--green-d);font-weight:700;margin-bottom:5px}
.card .loc{font-size:12.5px;color:var(--ochre-d);font-weight:700;letter-spacing:.6px;text-transform:uppercase;margin-bottom:11px}
.card .feat{list-style:none;display:flex;flex-wrap:wrap;gap:7px;margin:6px 0 18px}
.card .feat li{background:var(--sand);color:#4a4639;font-size:12.5px;padding:5px 11px;border-radius:999px;font-weight:500}
.card .foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:10px}
.card .foot .meta{font-size:13px;color:var(--muted)}

/* experience / location */
.exp{background:var(--green-d);color:#f3ecd8}
.exp h2{color:#fff}
.exp .grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.exp .list{list-style:none;margin-top:26px;display:flex;flex-direction:column;gap:18px}
.exp .list li{display:flex;gap:15px;align-items:flex-start}
.exp .list .ic{width:44px;height:44px;border-radius:12px;background:rgba(243,236,216,.1);display:grid;place-items:center;color:#f3c98a;font-size:20px;flex:none;border:1px solid rgba(243,236,216,.18)}
.exp .list b{color:#fff;font-size:16px;display:block}
.exp .list small{color:#c9c4b2;font-size:14px}
.exp .map{background:linear-gradient(135deg,#5d6b44,#46562f);border-radius:var(--radius);min-height:360px;position:relative;overflow:hidden;border:1px solid rgba(243,236,216,.14)}
.exp .map .pin{position:absolute;display:flex;align-items:center;gap:7px;background:#fff;color:var(--green-d);font-size:12.5px;font-weight:700;padding:6px 11px;border-radius:999px;box-shadow:0 6px 14px rgba(0,0,0,.2)}
.exp .map .dot{width:10px;height:10px;background:var(--ochre);border-radius:50%;box-shadow:0 0 0 5px rgba(184,115,51,.3)}

/* gallery */
.gal{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:170px 170px;gap:14px;margin-top:42px}
.gal div{border-radius:13px;color:#fff;font-size:12.5px;display:flex;align-items:flex-end;padding:13px;font-weight:500;background-size:cover;background-position:center}
.gal .g1{grid-row:span 2;background:linear-gradient(160deg,#7c8a55,#3d4a2e)}
.g2{background:linear-gradient(160deg,#cf954f,#9a5f2c)}
.g3{background:linear-gradient(160deg,#8a9a6a,#566b40)}
.g4{background:linear-gradient(160deg,#b9824a,#7c5226)}
.g5{background:linear-gradient(160deg,#6f8049,#46562f)}

/* testimonials */
.tmls{background:var(--sand)}
.tml-row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:44px}
.tml{background:#fff;border-radius:var(--radius);border:1px solid var(--line);padding:26px 24px;display:flex;flex-direction:column}
.tml .stars{color:#e0a32f;letter-spacing:2px;margin-bottom:12px}
.tml p{font-size:15px;color:#46443c;flex:1}
.tml .who{display:flex;align-items:center;gap:12px;margin-top:18px}
.tml .av{width:42px;height:42px;border-radius:50%;background:var(--green);color:#f3c98a;display:grid;place-items:center;font-weight:700;flex:none}
.tml .who b{display:block;font-size:14.5px;color:var(--green-d)}
.tml .who small{color:var(--muted);font-size:12.5px}

/* direct-booking band */
.direct{background:var(--cream)}
.direct .box{max-width:880px;margin:0 auto;background:#fff;border:1px solid var(--line);border-left:5px solid var(--green-l);border-radius:var(--radius);padding:30px 34px;box-shadow:0 6px 22px rgba(46,40,25,.06)}
.direct h3{font-family:var(--serif);font-size:24px;color:var(--green-d);margin-bottom:8px}
.direct p{color:#4a463c;font-size:16px}
.direct .pts{list-style:none;margin-top:16px;display:grid;grid-template-columns:1fr 1fr;gap:10px}
.direct .pts li{font-size:14.5px;color:#4a463c;padding-left:24px;position:relative}
.direct .pts li:before{content:"✓";position:absolute;left:0;color:var(--green-l);font-weight:800}

/* faq */
.faq-list{max-width:780px;margin:42px auto 0;display:flex;flex-direction:column;gap:12px}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:13px;padding:18px 22px}
.faq-item .q{display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:16.5px;color:var(--green-d);cursor:pointer;gap:14px}
.faq-item .q .pl{color:var(--ochre);font-size:22px;font-weight:400;transition:.18s;flex:none}
.faq-item .a{color:var(--muted);font-size:15px;margin-top:11px;display:none}
.faq-item.open .a{display:block}
.faq-item.open .q .pl{transform:rotate(45deg)}

/* final cta */
.final{background:linear-gradient(120deg,#b87333,#a5631f);color:#fff;text-align:center}
.final h2{color:#fff}
.final .sub{color:#fbe8cf}
.final .btn{margin-top:26px}

/* footer */
footer{background:var(--green-d);color:#cdc8b6;padding:56px 0 30px;font-size:14.5px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:36px}
footer h4{color:#f3ecd8;font-size:13px;letter-spacing:1px;text-transform:uppercase;margin-bottom:15px;font-weight:700}
footer ul{list-style:none;display:flex;flex-direction:column;gap:9px}
footer a:hover{color:#f3c98a}
footer .logo{color:#fff;margin-bottom:14px}
.foot-bottom{border-top:1px solid rgba(243,236,216,.13);margin-top:34px;padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:13px;color:#9c977f}

@media(max-width:920px){
  .nav ul{display:none}
  .bookbar{grid-template-columns:1fr 1fr}
  .trust .row{grid-template-columns:1fr 1fr}
  .units,.tml-row,.foot-grid{grid-template-columns:1fr}
  .exp .grid{grid-template-columns:1fr}
  .gal{grid-template-columns:1fr 1fr}
  .direct .pts{grid-template-columns:1fr}
  .hero h1{font-size:38px}
  