:root{
  --bg:#FAF7F1;
  --bg-card:#F1E9DB;
  --ink:#221E18;
  --ink-soft:#6B6357;
  --rust:#B0502E;
  --rust-deep:#8A3C20;
  --line:#E3D8C4;
  --moss:#56624A;
  --display:'Cormorant Garamond', Georgia, serif;
  --body:'DM Sans', system-ui, -apple-system, sans-serif;
}
*{box-sizing:border-box; margin:0; padding:0;}
html{scroll-behavior:smooth;}
section[id]{scroll-margin-top:96px;}
body{font-family:var(--body); color:var(--ink); background:var(--bg); line-height:1.65; -webkit-font-smoothing:antialiased;}
img{display:block; max-width:100%;}
a{color:inherit; text-decoration:none;}
ul{list-style:none;}
section{position:relative;}
.wrap{max-width:1200px; margin:0 auto; padding:0 32px;}

.eyebrow{
  font-family:var(--body); font-weight:600; letter-spacing:0.16em; text-transform:uppercase;
  font-size:0.78rem; color:var(--rust);
}
.eyebrow--light{color:#E9C9B4;}
.btn{
  display:inline-flex; align-items:center; gap:10px; font-family:var(--body); font-weight:600; font-size:0.95rem;
  padding:14px 28px; border-radius:999px; border:1px solid transparent; cursor:pointer;
  transition:transform .25s ease, background .25s ease, color .25s ease, border-color .25s ease;
}
.btn--solid{background:var(--rust); color:#FFF8EF;}
.btn--solid:hover{background:var(--rust-deep); transform:translateY(-2px);}
.btn--ghost{border-color:rgba(255,248,239,.55); color:#FFF8EF;}
.btn--ghost:hover{background:rgba(255,248,239,.12); transform:translateY(-2px);}
.btn--ghost-dark{border-color:rgba(34,30,24,.35); color:var(--ink);}
.btn--ghost-dark:hover{background:rgba(34,30,24,.06); transform:translateY(-2px);}
.reveal{opacity:0; transform:translateY(16px); transition:opacity .7s ease, transform .7s ease;}
.reveal.is-visible{opacity:1; transform:none;}
@media (prefers-reduced-motion: reduce){.reveal{opacity:1; transform:none; transition:none;} *{animation:none !important; transition:none !important;}}

/* NAV */
.nav{position:sticky; top:0; z-index:50; background:rgba(250,247,241,.92); backdrop-filter:blur(8px); border-bottom:1px solid var(--line);}
.nav__inner{max-width:1200px; margin:0 auto; padding:18px 32px; display:flex; align-items:center; justify-content:space-between; gap:24px;}
.nav__logo{font-family:var(--display); font-weight:600; font-size:1.6rem; letter-spacing:.01em;}
.nav__links{display:flex; gap:30px;}
.nav__links a{font-size:0.92rem; font-weight:500; color:var(--ink-soft); position:relative; padding-bottom:3px;}
.nav__links a:hover{color:var(--ink);}
.nav__actions{display:flex; align-items:center; gap:20px;}
.nav__phone{font-size:0.88rem; color:var(--ink-soft); display:none; align-items:center; gap:7px;}
.nav__phone svg{width:15px; height:15px; flex-shrink:0;}
.nav__toggle{display:none; background:none; border:1px solid var(--line); color:var(--ink); font-size:1.3rem; width:40px; height:40px; border-radius:50%;}
@media (min-width:860px){.nav__phone{display:inline-flex;}}
@media (max-width:860px){
  .nav__links{position:absolute; top:100%; left:0; right:0; flex-direction:column; background:var(--bg); padding:6px 32px 0;
    border-bottom:1px solid var(--line); max-height:0; overflow:hidden; transition:max-height .3s ease;}
  .nav__links.is-open{max-height:300px; padding:18px 32px 26px; gap:18px;}
  .nav__toggle{display:block;}
}
@media (max-width:600px){
  .nav__inner{padding:14px 18px; gap:10px;}
  .nav__logo{font-size:1.3rem;}
  .nav__actions{gap:10px;}
  .nav__actions .btn{padding:9px 14px; font-size:0.78rem; white-space:nowrap;}
  .nav__toggle{width:36px; height:36px; font-size:1.15rem; flex-shrink:0;}
}

/* HERO */
.hero{position:relative; min-height:92vh; display:flex; align-items:flex-end; color:#FFF8EF; overflow:hidden;}
.hero__bg{position:absolute; inset:0; background-image:url('img/EKN_0105.jpg'); background-size:cover; background-position:center 70%;}
.hero__scrim{position:absolute; inset:0;
  background:
    linear-gradient(100deg, rgba(15,13,10,.78) 0%, rgba(15,13,10,.55) 38%, rgba(15,13,10,.22) 65%, rgba(15,13,10,.05) 100%),
    linear-gradient(180deg, rgba(15,13,10,.32) 0%, rgba(15,13,10,.18) 30%, rgba(15,13,10,.55) 68%, rgba(15,13,10,.9) 100%);
}
.hero__inner{position:relative; z-index:2; max-width:1200px; margin:0 auto; padding:0 32px 64px; width:100%;}
.hero__title, .hero__sub, .hero__status, .eyebrow--light{text-shadow:0 2px 18px rgba(0,0,0,.45);}
.hero__title{font-family:var(--display); font-weight:600; font-size:clamp(2.8rem, 7vw, 5.6rem); line-height:1.04; max-width:16ch; margin:16px 0 22px;}
.hero__title em{font-style:italic; color:inherit;}
.hero__sub{font-size:1.08rem; max-width:46ch; opacity:.96; margin-bottom:32px;}
.hero__ctas{display:flex; gap:16px; flex-wrap:wrap; margin-bottom:28px;}
.hero__status{display:inline-flex; align-items:center; gap:9px; font-size:0.88rem; opacity:.92;}
.dot{width:8px; height:8px; border-radius:50%; background:#9ECB8E; box-shadow:0 0 0 0 rgba(158,203,142,.6); animation:pulse 2.4s infinite;}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(158,203,142,.5);} 70%{box-shadow:0 0 0 7px rgba(158,203,142,0);} 100%{box-shadow:0 0 0 0 rgba(158,203,142,0);}}

/* HAUS / ABOUT */
.haus{background:var(--bg); padding:110px 0;}
.haus__grid{display:grid; grid-template-columns:1fr; gap:48px; align-items:center;}
@media (min-width:920px){.haus__grid{grid-template-columns:0.85fr 1.15fr; gap:72px;}}
.haus__photo{border-radius:4px; overflow:hidden; box-shadow:0 30px 60px -30px rgba(34,30,24,.35);}
.haus__photo img{width:100%; height:460px; object-fit:cover;}
.haus__title{font-family:var(--display); font-weight:600; font-size:clamp(2.1rem,4vw,3rem); margin:14px 0 22px; max-width:16ch;}
.haus__text{color:var(--ink-soft); margin-bottom:20px; max-width:50ch;}
.haus__quote{font-family:var(--display); font-style:italic; font-weight:500; font-size:clamp(1.25rem,2.2vw,1.55rem);
  color:var(--rust-deep); padding:28px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); margin:30px 0;}
.haus__quote span{display:block; font-family:var(--body); font-style:normal; font-weight:500; font-size:0.82rem;
  letter-spacing:.04em; color:var(--ink-soft); margin-top:12px;}
.haus__facts{display:flex; flex-wrap:wrap; gap:10px;}
.haus__facts li{font-size:0.82rem; font-weight:600; color:var(--moss); background:var(--bg-card); border:1px solid var(--line);
  padding:8px 14px; border-radius:999px;}

/* ATMOSPHÄRE GALLERY */
.atmo{background:var(--bg-card); padding:100px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line);}
.atmo__head{max-width:640px; margin:0 auto 50px; text-align:center;}
.atmo__head h2{font-family:var(--display); font-weight:600; font-size:clamp(2rem,3.6vw,2.7rem); margin:14px 0 0;}
.atmo__grid{display:grid; grid-template-columns:repeat(4,1fr); gap:20px; list-style:none;}
.atmo__grid a{display:block; overflow:hidden; border-radius:6px;}
.atmo__grid img{width:100%; aspect-ratio:3/2; object-fit:cover; transition:transform .5s ease;}
.atmo__grid a:hover img{transform:scale(1.06);}
@media (max-width:980px){.atmo__grid{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.atmo__grid{grid-template-columns:1fr;}}

/* MITTAGSTISCH */
.mittag{background:var(--bg); padding:110px 0;}
.mittag__head{max-width:680px; margin:0 auto 50px; text-align:center;}
.mittag__head h2{font-family:var(--display); font-weight:600; font-size:clamp(2.1rem,4vw,2.9rem); margin:14px 0 18px;}
.mittag__head p{color:var(--ink-soft); max-width:56ch; margin:0 auto;}
.mittag__cards{display:grid; grid-template-columns:1fr 1fr; gap:28px; max-width:880px; margin:48px auto 0;}
.mittag__card{background:var(--bg-card); border:1px solid var(--line); border-radius:6px; padding:32px;}
.mittag__card .eyebrow{display:block; margin-bottom:10px;}
.mittag__card h3{font-family:var(--display); font-weight:600; font-size:1.4rem; margin-bottom:10px;}
.mittag__card p{color:var(--ink-soft); font-size:0.94rem;}
.mittag__cta{text-align:center; margin-top:44px;}
.mittag__note{font-size:0.8rem; color:var(--ink-soft); opacity:.8; margin-top:14px;}
@media (max-width:700px){.mittag__cards{grid-template-columns:1fr;}}

/* FEIERN */
.feiern{position:relative; padding:120px 0 0; color:#FFF8EF; overflow:hidden;}
.feiern__bg{position:absolute; inset:0; background-image:url('img/EKN_4436.jpg'); background-size:cover; background-position:center;}
.feiern__scrim{position:absolute; inset:0; background:linear-gradient(120deg, rgba(20,17,13,.92) 0%, rgba(20,17,13,.86) 45%, rgba(20,17,13,.72) 100%);}
.feiern__inner{position:relative; z-index:2; max-width:780px; margin:0 auto; padding:0 32px 110px; text-align:center;}
.feiern__title{font-family:var(--display); font-weight:600; font-size:clamp(2.1rem,4vw,3rem); margin:14px auto 20px; max-width:14ch;}
.feiern__text{opacity:.94; margin:0 auto 28px; max-width:52ch;}
.feiern__signature{display:flex; align-items:center; justify-content:center; gap:14px; margin-top:30px;}
.feiern__signature .name{font-family:var(--display); font-style:italic; font-size:1.15rem;}
.feiern__signature .phone{font-size:0.85rem; opacity:.8;}

.feiern__gallery{background:var(--bg-card); padding:90px 0 100px;}
.feiern__photos{max-width:980px; margin:0 auto; padding:0 32px; display:grid; grid-template-columns:1fr 1fr; gap:24px;}
.feiern__photos img{width:100%; aspect-ratio:3/2; object-fit:cover; border-radius:6px;}
@media (max-width:700px){.feiern__photos{grid-template-columns:1fr; max-width:480px;}}

/* KONTAKT */
.kontakt{background:var(--bg-card); padding:110px 0; border-top:1px solid var(--line);}
.kontakt__head{max-width:640px; margin:0 auto 50px; text-align:center;}
.kontakt__head h2{font-family:var(--display); font-weight:600; font-size:clamp(2rem,3.6vw,2.7rem); margin:14px 0 0;}
.kontakt__inner{display:grid; grid-template-columns:1.15fr 0.85fr; gap:48px; align-items:start;}
.kontakt h2{font-family:var(--display); font-weight:600; font-size:1.7rem; margin:10px 0 24px;}
.hours-table{width:100%; border-collapse:collapse; margin-bottom:18px;}
.hours-table th{font-weight:600; letter-spacing:.04em; font-size:0.78rem; text-transform:uppercase; text-align:left; color:var(--moss); padding-bottom:10px;}
.hours-table td{padding:10px 0; border-top:1px solid var(--line); font-size:0.94rem;}
.hours-table td:first-child{color:var(--ink-soft);}
.hours-table td:last-child{text-align:right; font-weight:500;}
.kontakt__note{font-size:0.86rem; color:var(--ink-soft); margin-top:18px;}
.kontakt__note a{font-weight:600; color:var(--rust-deep);}
.kontakt__side{display:flex; flex-direction:column; gap:24px;}
.kontakt__card{background:var(--bg); border:1px solid var(--line); border-radius:6px; padding:28px;}
.map-card{background:var(--bg); border:1px solid var(--line); border-radius:6px; overflow:hidden;}
.map-card iframe{width:100%; height:220px; border:0; display:block;}
.map-card__body{padding:24px;}
.map-card .addr{font-size:0.98rem; font-weight:600; margin-bottom:6px;}
.map-card .meta{font-size:0.86rem; color:var(--ink-soft); margin-bottom:4px;}
@media (max-width:900px){.kontakt__inner{grid-template-columns:1fr; gap:40px;}}

/* RESERVIERUNGSFORMULAR */
.res-form{background:var(--bg); border:1px solid var(--line); border-radius:6px; padding:36px;}
.res-form__row{display:grid; grid-template-columns:1fr 1fr; gap:18px;}
.res-form__field{display:flex; flex-direction:column; gap:6px; margin-bottom:18px;}
.res-form label{font-size:0.82rem; font-weight:600; color:var(--ink-soft);}
.res-form input, .res-form textarea{
  font-family:var(--body); font-size:0.95rem; color:var(--ink); background:var(--bg-card);
  border:1px solid var(--line); border-radius:4px; padding:11px 14px; width:100%; resize:vertical;
}
.res-form input:focus, .res-form textarea:focus{outline:2px solid var(--rust); outline-offset:1px;}
.res-form__honeypot{position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden;}
.res-form .btn{margin-top:6px;}
.res-form__status{font-size:0.9rem; font-weight:500; margin-top:14px; min-height:1.4em;}
.res-form__status.is-success{color:var(--moss);}
.res-form__status.is-error{color:var(--rust-deep);}
@media (max-width:560px){.res-form__row{grid-template-columns:1fr;} .res-form{padding:26px;}}

/* RECHTSTEXT-SEITEN (Impressum etc.) */
.legal{padding:90px 0 110px;}
.legal__head{max-width:760px; margin:0 auto 40px; padding:0 32px;}
.legal__head h1{font-family:var(--display); font-weight:600; font-size:clamp(2rem,3.6vw,2.7rem); margin:14px 0 0;}
.legal__body{max-width:760px; margin:0 auto; padding:0 32px;}
.legal__body h2{font-family:var(--display); font-weight:600; font-size:1.4rem; margin:38px 0 14px;}
.legal__body h2:first-child{margin-top:0;}
.legal__body p{color:var(--ink-soft); margin-bottom:14px;}
.legal__body address{color:var(--ink-soft); font-style:normal; margin-bottom:14px;}
.legal__body a{color:var(--rust-deep); text-decoration:underline;}

/* FOOTER */
.footer{background:var(--ink); color:#F1E9DB; padding:70px 0 30px;}
.footer__inner{max-width:1200px; margin:0 auto; padding:0 32px; display:grid; grid-template-columns:1.3fr 1fr 1fr; gap:48px;}
.footer__logo{font-family:var(--display); font-weight:600; font-size:1.7rem; margin-bottom:14px;}
.footer__tagline{opacity:.65; font-size:0.92rem; max-width:32ch;}
.footer h4{font-weight:600; text-transform:uppercase; letter-spacing:.1em; font-size:0.74rem; color:#E9C9B4; margin-bottom:16px;}
.footer ul li{margin-bottom:10px; font-size:0.92rem; opacity:.82;}
.footer__contact-item{display:flex; align-items:center; gap:9px;}
.footer__contact-icon{width:15px; height:15px; flex-shrink:0; opacity:.85;}
.footer__social{display:flex; gap:14px; margin-top:18px;}
.footer__social a{width:36px; height:36px; border:1px solid rgba(241,233,219,.3); border-radius:50%; display:flex; align-items:center; justify-content:center;}
.footer__social svg{width:16px; height:16px;}
.footer__bottom{max-width:1200px; margin:50px auto 0; padding:24px 32px 0; border-top:1px solid rgba(241,233,219,.15); font-size:0.78rem; opacity:.5; display:flex; gap:16px; flex-wrap:wrap; justify-content:space-between;}
.footer__bottom a{opacity:.85;}
.footer__bottom a:hover{opacity:1; text-decoration:underline;}
@media (max-width:760px){.footer__inner{grid-template-columns:1fr; gap:36px;}}
