/* ===== Café Niki — Styles (aus der Original-HTML rekonstruiert) ===== */
*{margin:0;padding:0;box-sizing:border-box}

:root{
  --paper:#FBF7F0;
  --cream:#F3EBDE;
  --sand:#EADFCD;
  --taupe:#CDBEA6;
  --espresso:#322B22;
  --ink:#463E32;
  --muted:#8C8071;
  --brass:#9A7B4F;
  --brass-soft:#B89A6E;
  --line:#DDD0BC;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Jost',-apple-system,sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
}

html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  font-weight:300;
  -webkit-font-smoothing:antialiased;
  letter-spacing:.01em;
  overflow-x:hidden;
}

/* subtle paper grain */
body::before{
  content:'';
  position:fixed;inset:0;
  pointer-events:none;z-index:1;
  opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.eyebrow{
  font-size:11px;
  font-weight:400;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--brass);
}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.logo-link{display:flex;align-items:center;line-height:0}
.logo-img{
  height:52px;width:auto;display:block;transition:height .4s var(--ease);
  filter:brightness(.18) sepia(1);
}
header.scrolled .logo-img{height:42px}
.hero-logo{
  width:clamp(230px,32vw,340px);height:auto;display:block;margin-bottom:18px;
  filter:brightness(.18) sepia(1);
}
.foot-logo{
  width:150px;height:auto;display:block;margin-bottom:18px;
  filter:brightness(.97) sepia(.55) saturate(.7);
}

/* ===== HEADER ===== */
header{
  position:fixed;top:0;left:0;right:0;
  z-index:50;
  padding:22px clamp(20px,5vw,64px);
  display:flex;align-items:center;justify-content:space-between;
  transition:background .4s var(--ease),padding .4s var(--ease),border-color .4s var(--ease);
  border-bottom:1px solid transparent;
}
header.scrolled{
  background:rgba(251,247,240,.86);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  padding-top:14px;padding-bottom:14px;
  border-bottom:1px solid var(--line);
}
.wordmark{
  font-family:var(--serif);
  font-size:26px;
  font-weight:600;
  letter-spacing:.02em;
  color:var(--espresso);
  text-decoration:none;
  display:flex;align-items:baseline;gap:.6em;
  line-height:1;
}
nav{display:flex;align-items:center;gap:clamp(20px,3vw,44px)}
nav a{
  font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink);text-decoration:none;font-weight:400;
  position:relative;transition:color .3s var(--ease);
}
nav a:not(.nav-cta)::after{
  content:'';position:absolute;left:0;bottom:-5px;height:1px;width:0;
  background:var(--brass);transition:width .4s var(--ease);
}
nav a:not(.nav-cta):hover::after{width:100%}
nav a:hover{color:var(--brass)}
.nav-cta{
  border:1px solid var(--espresso);
  padding:9px 20px;border-radius:999px;
  transition:all .35s var(--ease);
}
.nav-cta:hover{background:var(--espresso);color:var(--paper)!important}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;color:var(--espresso);padding:4px}
@media(max-width:860px){
  nav{
    position:fixed;inset:0;background:var(--paper);
    flex-direction:column;justify-content:center;gap:30px;
    transform:translateX(100%);transition:transform .5s var(--ease);
    z-index:60;
  }
  nav.open{transform:translateX(0)}
  nav a{font-size:18px;letter-spacing:.18em}
  .nav-toggle{display:block;z-index:70;position:relative}
}

/* ===== HERO ===== */
.hero{
  min-height:100vh;min-height:100svh;
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  text-align:center;
  padding:140px clamp(20px,5vw,64px) 80px;
  position:relative;
}
.hero-sub{
  max-width:440px;
  font-size:clamp(15px,2vw,17px);
  color:var(--muted);
  margin-bottom:42px;
  line-height:1.8;
}
.hero-loc{
  display:flex;align-items:center;gap:14px;
  margin-bottom:46px;
}
.hero-loc span{
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--muted);
}
.hero-loc .dot{width:3px;height:3px;border-radius:50%;background:var(--taupe)}
.hero-cta{display:flex;gap:18px;flex-wrap:wrap;justify-content:center}
.scroll-hint{
  position:absolute;bottom:34px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:10px;
  color:var(--muted);
}
.scroll-hint span{font-size:10px;letter-spacing:.26em;text-transform:uppercase}
.scroll-line{width:1px;height:40px;background:linear-gradient(var(--taupe),transparent);
  animation:scrollPulse 2.4s var(--ease) infinite}
@keyframes scrollPulse{0%,100%{opacity:.3;transform:scaleY(.7)}50%{opacity:1;transform:scaleY(1)}}

/* ===== BUTTONS ===== */
.btn{
  font-family:var(--sans);font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  font-weight:400;cursor:pointer;text-decoration:none;
  display:inline-flex;align-items:center;gap:10px;
  padding:15px 30px;border-radius:999px;
  transition:all .4s var(--ease);border:1px solid transparent;
}
.btn-primary{background:var(--espresso);color:var(--paper)}
.btn-primary:hover{background:var(--brass);transform:translateY(-2px);box-shadow:0 14px 30px -12px rgba(154,123,79,.6)}
.btn-ghost{background:transparent;color:var(--espresso);border-color:var(--taupe)}
.btn-ghost:hover{border-color:var(--espresso);background:var(--cream)}
.btn svg{transition:transform .4s var(--ease)}
.btn:hover svg{transform:translateX(4px)}

/* ===== SECTIONS ===== */
section{position:relative;z-index:2}
.wrap{max-width:1180px;margin:0 auto;padding:clamp(80px,12vw,140px) clamp(20px,5vw,64px)}
.sec-head{margin-bottom:64px}
.sec-head.center{text-align:center}
.sec-head .eyebrow{display:block;margin-bottom:18px}
.sec-title{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(38px,6vw,68px);line-height:1.02;
  letter-spacing:-.01em;color:var(--espresso);
}
.sec-title em{font-style:italic;color:var(--brass)}

/* ===== ABOUT ===== */
.about{background:var(--cream)}
.about-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(40px,7vw,96px);align-items:center}
.about-copy p{color:var(--muted);font-size:16.5px;line-height:1.95;margin-bottom:22px;max-width:46ch}
.about-copy p.lead{
  font-family:var(--serif);font-size:clamp(22px,3vw,28px);font-style:italic;
  color:var(--ink);line-height:1.5;margin-bottom:30px;
}
.about-img-frame{position:relative}
.about-img-frame img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:6px;display:block}
.about-img-frame::after{
  content:'';position:absolute;inset:-14px;border:1px solid var(--taupe);
  border-radius:6px;pointer-events:none;z-index:-1;
}
.img-ph{
  width:100%;aspect-ratio:4/5;display:block;
  background:var(--sand);border-radius:6px;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-style:italic;font-size:22px;
  color:var(--brass);opacity:.5;
}
.values{
  display:grid;grid-template-columns:repeat(2,1fr);gap:2px;
  margin-top:96px;background:var(--line);border:1px solid var(--line);border-radius:8px;overflow:hidden;
}
.value{background:var(--cream);padding:38px 32px;transition:background .4s var(--ease)}
.value:hover{background:var(--paper)}
.value .ic{color:var(--brass);margin-bottom:20px}
.value h3{font-family:var(--serif);font-size:23px;font-weight:600;color:var(--espresso);margin-bottom:8px}
.value p{font-size:14.5px;color:var(--muted);line-height:1.7}
@media(max-width:780px){
  .about-grid{grid-template-columns:1fr;gap:48px}
  .values{grid-template-columns:1fr;margin-top:64px}
}

/* ===== MENU ===== */
.menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}

.menu-card{
  background:var(--cream);border-radius:16px;border:1px solid var(--line);
  display:flex;flex-direction:column;overflow:hidden;
  transition:box-shadow .4s var(--ease);
}
.menu-card:hover{box-shadow:0 20px 60px -20px rgba(50,43,34,.12)}

.menu-card-hd{
  padding:36px 36px 28px;
  border-bottom:1px solid var(--line);
  position:relative;
}
.menu-cat-label{
  font-size:10px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--brass);font-weight:400;display:block;margin-bottom:10px;
}
.menu-cat-title{
  font-family:var(--serif);font-size:clamp(36px,4vw,48px);
  font-weight:500;line-height:1;color:var(--espresso);
  margin:0;
}
.menu-cat-icon{
  position:absolute;top:36px;right:36px;
  color:var(--taupe);opacity:.7;
}

.menu-items{list-style:none;padding:0 36px 36px;margin:0;flex:1}

.m-item{
  display:flex;align-items:flex-start;justify-content:space-between;
  gap:16px;padding:18px 0;
}
.m-item + .m-item{border-top:1px solid rgba(205,190,166,.28)}

.m-body{display:flex;flex-direction:column;gap:4px}
.m-name{font-size:15px;color:var(--ink);font-weight:400;line-height:1.3}
.m-note{font-size:11.5px;color:var(--muted);font-weight:300;letter-spacing:.02em}
.m-price{
  font-family:var(--serif);font-size:22px;font-style:italic;
  color:var(--brass);flex-shrink:0;line-height:1.2;
}

@media(max-width:900px){.menu-grid{grid-template-columns:1fr 1fr}}
@media(max-width:580px){.menu-grid{grid-template-columns:1fr}}

/* ===== GALLERY / INSTAGRAM ===== */
.gallery{background:var(--espresso);color:var(--paper)}
.gallery .eyebrow{color:var(--brass-soft)}
.gallery .sec-title{color:var(--paper)}
.gallery .sec-title em{color:var(--brass-soft)}

.ig-intro{margin-bottom:36px}
.ig-account-badge{
  display:inline-flex;align-items:center;gap:12px;
  background:rgba(255,255,255,.06);border:1px solid rgba(205,190,166,.3);
  border-radius:50px;padding:10px 22px 10px 16px;
  color:var(--paper);text-decoration:none;
  font-size:15px;font-weight:500;letter-spacing:.02em;
  transition:border-color .25s var(--ease),background .25s var(--ease);
}
.ig-account-badge:hover{border-color:rgba(184,154,110,.6);background:rgba(255,255,255,.1)}
.ig-icon{width:20px;height:20px;color:var(--brass-soft);flex-shrink:0}
.ig-handle{color:var(--brass-soft)}
.ig-follow-arrow{color:rgba(251,247,240,.5);font-size:17px;margin-left:2px}
.ig-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.ig-post{border-radius:14px;overflow:hidden;box-shadow:0 16px 40px rgba(0,0,0,.35),0 0 0 1px rgba(205,190,166,.12)}
.ig-post .instagram-media{border-radius:14px!important;min-width:0!important}
.ig-cta{margin-top:44px;text-align:center}
.ig-btn{color:var(--paper)!important;border-color:rgba(205,190,166,.5)!important}
.ig-btn:hover{background:var(--paper)!important;color:var(--espresso)!important}

@keyframes ig-shimmer{0%{background-position:-400px 0}100%{background-position:400px 0}}
.ig-skeleton{border-radius:14px;overflow:hidden;background:rgba(255,255,255,.05);border:1px solid rgba(205,190,166,.1)}
.ig-sk-img{
  width:100%;aspect-ratio:1;
  background:linear-gradient(90deg,rgba(205,190,166,.04) 25%,rgba(205,190,166,.12) 50%,rgba(205,190,166,.04) 75%);
  background-size:800px 100%;
  animation:ig-shimmer 1.8s ease-in-out infinite;
}
.ig-sk-footer{display:flex;align-items:center;gap:10px;padding:13px 15px;color:rgba(184,154,110,.55);font-size:13px;font-weight:500;letter-spacing:.02em}
.ig-sk-footer svg{width:17px;height:17px;flex-shrink:0}

@media(max-width:860px){.ig-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.ig-grid{grid-template-columns:1fr}}

/* ===== BOOKING ===== */
.booking{background:var(--cream)}
.book-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(48px,7vw,110px);align-items:start}
.book-aside .sec-title{margin-bottom:26px}
.book-aside > p{color:var(--muted);font-size:16px;line-height:1.9;margin-bottom:34px;max-width:34ch}
.book-meta{display:flex;flex-direction:column;gap:22px}
.book-meta .bm{display:flex;gap:16px;align-items:flex-start}
.book-meta .ic{color:var(--brass);flex-shrink:0;margin-top:3px}
.book-meta h4{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink);margin-bottom:3px}
.book-meta p{font-size:15px;color:var(--muted);margin:0;line-height:1.6}
.form{background:var(--paper);padding:clamp(32px,5vw,52px);border-radius:10px;border:1px solid var(--line)}
.fg{margin-bottom:30px}
.fg label{display:block;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:12px}
.fg input,.fg select{
  width:100%;padding:10px 2px;border:none;border-bottom:1px solid var(--taupe);
  background:transparent;font-family:var(--sans);font-size:16px;color:var(--ink);
  font-weight:300;transition:border-color .35s var(--ease);border-radius:0;
}
.fg input:focus,.fg select:focus{outline:none;border-bottom-color:var(--brass)}
.fg input::placeholder{color:var(--taupe)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.guest-pick{display:flex;gap:10px;flex-wrap:wrap}
.guest-pick button{
  font-family:var(--sans);flex:1;min-width:46px;padding:12px 0;border:1px solid var(--taupe);
  background:transparent;border-radius:6px;cursor:pointer;font-size:14px;color:var(--ink);
  transition:all .3s var(--ease);
}
.guest-pick button:hover{border-color:var(--brass)}
.guest-pick button.active{background:var(--espresso);color:var(--paper);border-color:var(--espresso)}
.form-submit{
  width:100%;margin-top:8px;padding:17px;border:none;border-radius:999px;
  background:var(--espresso);color:var(--paper);cursor:pointer;
  font-family:var(--sans);font-size:12px;letter-spacing:.2em;text-transform:uppercase;
  transition:all .4s var(--ease);display:flex;align-items:center;justify-content:center;gap:10px;
}
.form-submit:hover{background:var(--brass)}
.f-msg{margin-top:22px;padding:16px 20px;border-radius:8px;font-size:14px;text-align:center;line-height:1.5}
.f-msg.ok{background:var(--sand);color:var(--ink)}
.f-msg.err{background:#f0e0db;color:#8a4a3a}
@media(max-width:820px){.book-grid{grid-template-columns:1fr;gap:48px}}
@media(max-width:480px){.frow{grid-template-columns:1fr}}

/* ===== CONTACT ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:stretch}
.contact-info{display:flex;flex-direction:column;gap:36px}
.ci{display:flex;gap:18px;align-items:flex-start}
.ci .ic{color:var(--brass);flex-shrink:0;margin-top:2px}
.ci h4{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink);margin-bottom:7px}
.ci p,.ci a{font-size:15.5px;color:var(--muted);line-height:1.7;text-decoration:none}
.ci a:hover{color:var(--brass)}
.socials{display:flex;gap:12px;margin-top:4px}
.socials a{
  width:44px;height:44px;border-radius:50%;border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;color:var(--ink);
  transition:all .4s var(--ease);
}
.socials a:hover{background:var(--espresso);color:var(--paper);border-color:var(--espresso);transform:translateY(-3px)}
.map{border-radius:10px;overflow:hidden;min-height:380px;border:1px solid var(--line);position:relative;background:var(--cream)}
.map iframe{width:100%;height:100%;min-height:380px;border:0;filter:grayscale(.4) sepia(.12) contrast(.96)}
@media(max-width:780px){.contact-grid{grid-template-columns:1fr;gap:48px}.map{min-height:300px}}

/* ===== FOOTER ===== */
footer{background:var(--espresso);color:var(--paper);position:relative;z-index:2}
.foot-wrap{max-width:1180px;margin:0 auto;padding:72px clamp(20px,5vw,64px) 40px}
.foot-top{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:40px;padding-bottom:54px;border-bottom:1px solid rgba(255,255,255,.12)}
.foot-brand .wordmark{color:var(--paper);font-size:34px;margin-bottom:16px}
.foot-brand p{color:var(--brass-soft);font-size:14px;max-width:30ch;line-height:1.7}
.foot-nav{display:flex;gap:clamp(40px,7vw,90px);flex-wrap:wrap}
.foot-col h5{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--brass-soft);margin-bottom:18px}
.foot-col a{display:block;color:rgba(251,247,240,.78);text-decoration:none;font-size:14.5px;margin-bottom:11px;transition:color .3s var(--ease)}
.foot-col a:hover{color:var(--paper)}
.foot-bot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:30px;font-size:12.5px;color:rgba(251,247,240,.5);letter-spacing:.04em}
.foot-bot a{color:inherit;text-decoration:none}.foot-bot a:hover{color:var(--paper)}

/* ===== REVEAL ===== */
.reveal{opacity:0;transform:translateY(26px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}.scroll-line{animation:none}}
