/* ============================================================
   Beethoven — Ungarisches Pub & Restaurant
   Editorial-Bistro Design System (vanilla, no build)
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400;1,500&family=Karla:wght@300;400;500;600;700&display=swap');

:root{
  /* — Brand colour tokens — */
  --cream:        #F6F1E7;   /* warm paper background */
  --cream-deep:   #EFE7D6;   /* slightly deeper panel */
  --ink:          #1C1A16;   /* near-black, warm */
  --ink-soft:     #4A463E;   /* secondary text */
  --green:        #1F3D2B;   /* brand deep forest green (logo) */
  --green-700:    #2C5238;
  --green-300:    #6E8F77;
  --gold:         #A9803F;   /* elegant gold */
  --gold-soft:    #D9C089;   /* light gold / hover ring */
  --paprika:      #B2331E;   /* Hungarian paprika red accent */
  --paprika-700:  #8E2615;
  --line:         #DCD2BF;   /* hairline on cream */
  --line-strong:  #C7BBA1;
  --white:        #FFFFFF;

  /* — Semantic — */
  --bg:           var(--cream);
  --fg:           var(--ink);
  --muted:        var(--ink-soft);
  --surface:      #FBF8F1;

  /* — Type scale — */
  --f-display: clamp(2.8rem, 7vw, 6rem);
  --f-h1:      clamp(2.2rem, 5vw, 3.6rem);
  --f-h2:      clamp(1.7rem, 3.4vw, 2.6rem);
  --f-h3:      clamp(1.25rem, 2vw, 1.6rem);
  --f-body:    1.05rem;

  --maxw: 1180px;
  --radius: 4px;
  --shadow-sm: 0 2px 10px rgba(28,26,22,.06);
  --shadow-md: 0 14px 40px rgba(28,26,22,.14);
  --shadow-lg: 0 30px 70px rgba(28,26,22,.22);
  --ease: cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--fg);
  font-family:'Karla',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-size:var(--f-body);line-height:1.65;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;font-weight:700;line-height:1.08;margin:0;letter-spacing:-.01em}
p{margin:0 0 1em}

.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(20px,5vw,48px)}
.eyebrow{
  font-family:'Karla',sans-serif;text-transform:uppercase;letter-spacing:.28em;
  font-size:.72rem;font-weight:700;color:var(--gold);margin:0 0 .9rem
}
.eyebrow.on-dark{color:var(--gold-soft)}
.section{padding:clamp(64px,9vw,120px) 0}
.section--tight{padding:clamp(44px,6vw,72px) 0}
.lead{font-size:clamp(1.1rem,1.6vw,1.3rem);color:var(--muted);max-width:60ch}
.center{text-align:center}
.center .lead{margin-inline:auto}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55em;cursor:pointer;
  font-family:'Karla',sans-serif;font-weight:700;font-size:.95rem;
  letter-spacing:.02em;padding:.85em 1.6em;border-radius:var(--radius);
  border:1.5px solid transparent;transition:transform .2s var(--ease),background .2s,box-shadow .2s,color .2s;
  text-decoration:none;line-height:1;
}
.btn svg{width:1.05em;height:1.05em}
.btn-primary{background:var(--paprika);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--paprika-700);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-green{background:var(--green);color:#fff}
.btn-green:hover{background:var(--green-700);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-ghost{background:transparent;border-color:var(--line-strong);color:var(--ink)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px)}
.btn-ghost.on-dark{color:#fff;border-color:rgba(255,255,255,.5)}
.btn-ghost.on-dark:hover{color:var(--gold-soft);border-color:var(--gold-soft)}

/* ---------- Header / Nav ---------- */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(246,241,231,.82);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);transition:box-shadow .3s
}
.site-header.scrolled{box-shadow:var(--shadow-sm)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;min-height:74px}
.brand{display:flex;align-items:center;gap:.7rem;font-family:'Playfair Display',serif;font-weight:700;font-size:1.25rem}
.brand img{height:42px;width:auto}
.brand .brand-sub{display:block;font-family:'Karla',sans-serif;font-weight:600;font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-top:2px}
.nav-links{display:flex;align-items:center;gap:.3rem;list-style:none;margin:0;padding:0}
.nav-links a{
  font-weight:600;font-size:.95rem;padding:.5em .85em;border-radius:var(--radius);
  color:var(--ink-soft);transition:color .2s,background .2s;position:relative
}
.nav-links a:hover{color:var(--ink)}
.nav-links a.active{color:var(--green)}
.nav-links a.active::after{content:"";position:absolute;left:.85em;right:.85em;bottom:.25em;height:2px;background:var(--paprika)}
.nav-cta{margin-left:.4rem}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:.4rem;color:var(--ink)}
.nav-toggle svg{width:28px;height:28px}

@media(max-width:880px){
  .nav-toggle{display:block}
  .nav-links{
    position:fixed;inset:74px 0 auto 0;flex-direction:column;align-items:stretch;
    background:var(--cream);border-bottom:1px solid var(--line);gap:0;padding:.5rem 0;
    transform:translateY(-130%);transition:transform .35s var(--ease);box-shadow:var(--shadow-md)
  }
  .nav-links.open{transform:translateY(0)}
  .nav-links a{padding:.9em clamp(20px,5vw,48px);border-radius:0}
  .nav-links a.active::after{display:none}
  .nav-links a.active{background:var(--cream-deep)}
  .nav-cta{margin:.6rem clamp(20px,5vw,48px)}
}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:clamp(560px,86vh,820px);display:flex;align-items:flex-end;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 40%}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,28,20,.36) 0%,rgba(20,24,18,.12) 38%,rgba(18,20,14,.72) 100%)
}
.hero-inner{position:relative;z-index:2;padding-bottom:clamp(44px,7vw,90px);color:#fff;max-width:880px}
.hero h1{font-size:var(--f-display);color:#fff;font-weight:800;text-shadow:0 2px 30px rgba(0,0,0,.35)}
.hero .hero-tag{font-style:italic;font-weight:500}
.hero-sub{font-size:clamp(1.05rem,1.6vw,1.3rem);max-width:48ch;margin:1rem 0 1.8rem;color:rgba(255,255,255,.92)}
.hero-actions{display:flex;flex-wrap:wrap;gap:.9rem}
.hero-badge{
  position:absolute;top:clamp(20px,4vw,40px);right:clamp(20px,5vw,48px);z-index:2;
  display:flex;align-items:center;gap:.55rem;background:rgba(246,241,231,.92);
  padding:.6rem 1rem;border-radius:40px;box-shadow:var(--shadow-md);font-weight:700;font-size:.9rem
}
.hero-badge .stars{color:var(--gold);letter-spacing:1px}
.hero-strip{
  position:relative;z-index:2;background:var(--green);color:#fff;
}
.hero-strip .wrap{display:flex;flex-wrap:wrap;gap:1.4rem 2.4rem;justify-content:center;padding-block:.95rem;font-size:.92rem}
.hero-strip span{display:inline-flex;align-items:center;gap:.5rem;letter-spacing:.02em}
.hero-strip svg{width:1.05em;height:1.05em;color:var(--gold-soft)}

/* ---------- Section heading block ---------- */
.head{max-width:62ch;margin-bottom:clamp(28px,4vw,52px)}
.head.center{margin-inline:auto}
.head h2{font-size:var(--f-h2)}
.head p{margin-top:.8rem}
.rule{width:64px;height:3px;background:var(--paprika);margin:0 0 1.2rem;border-radius:2px}
.head.center .rule{margin-inline:auto}

/* ---------- Editorial split ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,72px);align-items:center}
.split.reverse .split-media{order:2}
.split-media{position:relative}
.split-media img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow-md)}
.split-media .tag-float{
  position:absolute;left:-14px;bottom:24px;background:var(--paprika);color:#fff;
  font-family:'Playfair Display',serif;font-style:italic;font-size:1.05rem;padding:.55rem 1.1rem;
  border-radius:var(--radius);box-shadow:var(--shadow-md)
}
@media(max-width:820px){
  .split{grid-template-columns:1fr;gap:28px}
  .split.reverse .split-media{order:0}
}

/* ---------- Feature dish cards (bento) ---------- */
.dish-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2.4vw,26px)}
.dish-card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .28s var(--ease),box-shadow .28s,border-color .28s;cursor:pointer
}
.dish-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:var(--gold-soft)}
.dish-card .ph{aspect-ratio:4/3;overflow:hidden}
.dish-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.dish-card:hover .ph img{transform:scale(1.06)}
.dish-card .body{padding:1.1rem 1.2rem 1.3rem}
.dish-card h3{font-size:1.25rem;display:flex;justify-content:space-between;align-items:baseline;gap:1rem}
.dish-card .price{font-family:'Karla',sans-serif;font-weight:700;color:var(--paprika);font-size:1.05rem;font-variant-numeric:tabular-nums;white-space:nowrap}
.dish-card p{font-size:.92rem;color:var(--muted);margin:.5rem 0 0}
@media(max-width:820px){.dish-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.dish-grid{grid-template-columns:1fr}}

/* ---------- Menu (typographic) ---------- */
.menu-panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(24px,4vw,48px);box-shadow:var(--shadow-sm)}
.menu-cat{margin-bottom:2.6rem}
.menu-cat:last-child{margin-bottom:0}
.menu-cat > h3{
  font-size:1.5rem;color:var(--green);display:flex;align-items:center;gap:1rem;margin-bottom:1.3rem
}
.menu-cat > h3::after{content:"";flex:1;height:1px;background:var(--line-strong)}
.m-item{padding:.6rem 0;border-bottom:1px dashed var(--line)}
.m-item:last-child{border-bottom:0}
.m-head{display:flex;align-items:baseline;gap:.6rem;font-weight:700;font-size:1.08rem}
.m-name{color:var(--ink)}
.m-dots{flex:1;border-bottom:1.5px dotted var(--line-strong);transform:translateY(-4px);min-width:18px}
.m-price{font-variant-numeric:tabular-nums;color:var(--paprika);white-space:nowrap}
.m-desc{font-size:.92rem;color:var(--muted);margin:.25rem 0 0;max-width:62ch}
.m-allerg{font-size:.74rem;letter-spacing:.06em;color:var(--green-300);font-weight:600;text-transform:uppercase;margin-left:.4rem}
.m-veg{display:inline-block;font-size:.66rem;font-weight:700;letter-spacing:.08em;color:var(--green-700);border:1px solid var(--green-300);border-radius:20px;padding:.05em .5em;margin-left:.4rem;vertical-align:middle}

/* lunch / seasonal callouts */
.callout{
  background:linear-gradient(160deg,var(--green) 0%,var(--green-700) 100%);color:#fff;
  border-radius:var(--radius);padding:clamp(24px,4vw,40px);box-shadow:var(--shadow-md)
}
.callout .eyebrow{color:var(--gold-soft)}
.callout h3{color:#fff;font-size:1.7rem}
.callout .price-row{display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;margin:1rem 0 1.4rem;font-weight:700}
.callout .price-row b{color:var(--gold-soft);font-variant-numeric:tabular-nums}
.callout ul{list-style:none;margin:0;padding:0;columns:2;column-gap:2rem}
.callout li{padding:.3rem 0;border-bottom:1px solid rgba(255,255,255,.14);break-inside:avoid;font-size:.95rem}
.callout li small{display:block;color:rgba(255,255,255,.7);font-size:.78rem}
@media(max-width:640px){.callout ul{columns:1}}

.menu-tabs{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem;justify-content:center}
.menu-tabs button{
  font-family:'Karla',sans-serif;font-weight:700;font-size:.92rem;cursor:pointer;
  padding:.6em 1.2em;border-radius:30px;border:1.5px solid var(--line-strong);background:transparent;color:var(--ink-soft);
  transition:all .2s
}
.menu-tabs button:hover{border-color:var(--gold);color:var(--ink)}
.menu-tabs button.active{background:var(--green);color:#fff;border-color:var(--green)}
.tabpane{display:none}
.tabpane.active{display:block;animation:fadeUp .4s var(--ease)}

/* ---------- Reviews marquee ---------- */
.reviews{background:var(--green);color:#fff;overflow:hidden}
.marquee-mask{position:relative;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee{display:flex;gap:1.4rem;width:max-content;animation:marquee 46s linear infinite}
.marquee-mask:has(.review-card:hover) .marquee{animation-play-state:paused}
.review-card{
  width:340px;flex:0 0 340px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);
  border-radius:var(--radius);padding:1.4rem 1.5rem;transition:border-color .2s,box-shadow .2s,background .2s
}
.review-card:hover{border-color:var(--gold-soft);box-shadow:0 0 0 2px var(--gold-soft);background:rgba(255,255,255,.1)}
.review-card .stars{color:var(--gold-soft);letter-spacing:2px;margin-bottom:.6rem}
.review-card p{font-family:'Playfair Display',serif;font-style:italic;font-size:1.05rem;line-height:1.5;margin:0 0 .9rem}
.review-card .who{font-size:.85rem;color:rgba(255,255,255,.78);font-weight:600}
.review-card .who span{color:var(--gold-soft)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(calc(-50% - .7rem))}}

/* ---------- Gallery / lightbox ---------- */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.gallery .g-item{position:relative;overflow:hidden;border-radius:var(--radius);cursor:pointer;aspect-ratio:1;background:var(--cream-deep)}
.gallery .g-item.tall{grid-row:span 2;aspect-ratio:auto}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.gallery .g-item:hover img{transform:scale(1.07)}
.gallery .g-item::after{content:"";position:absolute;inset:0;background:rgba(31,61,43,0);transition:background .3s}
.gallery .g-item:hover::after{background:rgba(31,61,43,.18)}
@media(max-width:720px){.gallery{grid-template-columns:repeat(2,1fr)}.gallery .g-item.tall{grid-row:span 1}}

.lightbox{position:fixed;inset:0;z-index:1000;background:rgba(14,16,12,.92);display:none;align-items:center;justify-content:center;padding:24px}
.lightbox.open{display:flex;animation:fadeUp .25s ease}
.lightbox img{max-width:92vw;max-height:86vh;border-radius:var(--radius);box-shadow:var(--shadow-lg)}
.lightbox .lb-close{position:absolute;top:20px;right:24px;background:none;border:0;color:#fff;cursor:pointer}
.lightbox .lb-close svg{width:34px;height:34px}
.lightbox .lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.1);border:0;color:#fff;cursor:pointer;border-radius:50%;width:52px;height:52px;display:flex;align-items:center;justify-content:center;transition:background .2s}
.lightbox .lb-nav:hover{background:rgba(255,255,255,.22)}
.lightbox .lb-prev{left:18px}.lightbox .lb-next{right:18px}
.lightbox .lb-nav svg{width:26px;height:26px}

/* ---------- Info / stats strip ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;text-align:center}
.stats .stat{padding:1rem}
.stats .num{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,2.8rem);color:var(--green);font-weight:700;line-height:1}
.stats .lbl{font-size:.82rem;text-transform:uppercase;letter-spacing:.16em;color:var(--muted);margin-top:.5rem}
@media(max-width:680px){.stats{grid-template-columns:1fr 1fr}}

/* ---------- Reservation ---------- */
.reserve-band{background:var(--ink);color:#fff;position:relative;overflow:hidden}
.reserve-band .wrap{position:relative;z-index:2}
.reserve-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:center}
.reserve-grid>*{min-width:0}
@media(max-width:860px){.reserve-grid{grid-template-columns:1fr}}
.reserve-band h2{color:#fff;font-size:var(--f-h2)}
.reserve-band .eyebrow{color:var(--gold-soft)}
.form-card{background:var(--surface);color:var(--ink);border-radius:var(--radius);padding:clamp(22px,3.5vw,36px);box-shadow:var(--shadow-lg);max-width:100%}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-row>*{min-width:0}
@media(max-width:540px){.form-row{grid-template-columns:1fr}}
.field{margin-bottom:1rem;display:flex;flex-direction:column}
.field.full{grid-column:1/-1}
.field label{font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft);margin-bottom:.4rem}
.field input,.field select,.field textarea{
  font-family:'Karla',sans-serif;font-size:1rem;padding:.75em .85em;border:1.5px solid var(--line-strong);
  border-radius:var(--radius);background:#fff;color:var(--ink);transition:border-color .2s,box-shadow .2s;min-height:46px
}
.field textarea{min-height:90px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(31,61,43,.14)}
.form-note{font-size:.84rem;color:var(--muted);margin-top:.4rem}
.contact-list{list-style:none;margin:1.4rem 0 0;padding:0}
.contact-list li{display:flex;gap:.9rem;align-items:flex-start;padding:.7rem 0;border-bottom:1px solid rgba(255,255,255,.14)}
.contact-list svg{width:1.3rem;height:1.3rem;color:var(--gold-soft);flex:0 0 auto;margin-top:2px}
.contact-list a{border-bottom:1px solid transparent}
.contact-list a:hover{border-color:var(--gold-soft)}

/* ---------- Map ---------- */
.map-card{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md);border:1px solid var(--line)}
.map-card iframe{width:100%;height:100%;min-height:380px;border:0;display:block}

/* ---------- Footer ---------- */
.site-footer{background:#161510;color:#cfc7b6;font-size:.92rem}
.site-footer .wrap{padding-block:clamp(48px,7vw,80px)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.4rem}
.site-footer h4{color:#fff;font-family:'Karla',sans-serif;font-size:.8rem;text-transform:uppercase;letter-spacing:.16em;margin:0 0 1rem}
.site-footer .brand-foot{display:flex;align-items:center;gap:.7rem;margin-bottom:1rem}
.site-footer .brand-foot img{height:54px}
.site-footer ul{list-style:none;margin:0;padding:0}
.site-footer li{margin-bottom:.5rem}
.site-footer a:hover{color:var(--gold-soft)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:2.4rem;padding-top:1.4rem;display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;justify-content:space-between;color:#8d8676;font-size:.82rem}
.foot-bottom a{text-decoration:underline}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr;gap:1.8rem}}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}

/* small helpers */
.muted{color:var(--muted)}
.tabular{font-variant-numeric:tabular-nums}
.badge-pill{display:inline-flex;align-items:center;gap:.4rem;background:var(--cream-deep);border:1px solid var(--line);border-radius:30px;padding:.35rem .9rem;font-size:.84rem;font-weight:600}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,3vw,36px)}
@media(max-width:760px){.grid-2{grid-template-columns:1fr}}
