/* ============================================================
   KISKOPÁR BISZTRÓ — kiskopar.hu
   Visual system carried over from the printed menu:
   navy / gold / cream · Jost (display caps) · Archivo (body)
   · Great Vibes (script accent) · ornamental gold rules.
   ============================================================ */

:root{
  --navy:#16243f;
  --navy-2:#1d3252;
  --navy-deep:#0f1c30;
  --gold:#bf9b30;
  --gold-soft:#cdb068;
  --gold-bright:#d8bd74;
  --cream:#faf6ec;
  --cream-deep:#f1e8d4;
  --cream-card:#fffdf7;
  --slate:#8a8f98;
  --light:#fbf8f1;

  --ink-72: rgba(22,39,63,.72);
  --ink-55: rgba(22,39,63,.55);
  --ink-38: rgba(22,39,63,.38);
  --ink-22: rgba(22,39,63,.22);
  --ink-12: rgba(22,39,63,.12);

  --cream-72: rgba(251,248,241,.72);
  --cream-45: rgba(251,248,241,.45);
  --cream-18: rgba(251,248,241,.16);

  --ff-display:"Jost", system-ui, sans-serif;
  --ff-body:"Archivo", system-ui, sans-serif;
  --ff-script:"Great Vibes", cursive;

  --maxw: 1180px;
  --gut: clamp(20px, 5vw, 64px);
  --nav-h: 76px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; scroll-padding-top:var(--nav-h); }
/* verrou anti-débordement horizontal (iframe héro surdimensionnée + quirk iOS Safari) */
html, body{ max-width:100%; overflow-x:hidden; }
body{
  margin:0; padding:0;
  background:var(--cream);
  color:var(--navy);
  font-family:var(--ff-body);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0 0 0 0); border:0; }

/* ---------- shared type helpers ---------- */
.eyebrow{
  font-family:var(--ff-display); font-weight:600;
  letter-spacing:.34em; text-transform:uppercase;
  font-size:12px; color:var(--gold);
  display:inline-flex; align-items:center; gap:14px;
}
.eyebrow::before{ content:""; width:30px; height:1px; background:var(--gold); }
.eyebrow.center{ justify-content:center; }
.eyebrow.center::after{ content:""; width:30px; height:1px; background:var(--gold); }

.section-title{
  font-family:var(--ff-display); font-weight:300;
  letter-spacing:.12em; text-transform:uppercase;
  font-size:clamp(30px, 4.4vw, 50px); line-height:1.04;
  margin:.4em 0 0; color:var(--navy);
}
.lead{
  font-size:clamp(17px,1.6vw,19px); line-height:1.7;
  color:var(--ink-72); max-width:62ch; text-wrap:pretty;
}
.script{ font-family:var(--ff-script); color:var(--gold); }

/* image-slot empty-state theming (shadow parts) */
image-slot::part(frame){ background:#e7dcc4; }
image-slot::part(empty){ color:rgba(22,39,63,.48); }
.hero__bg image-slot::part(frame),
.contact__map image-slot::part(frame),
.ecard__media image-slot::part(frame){ background:#142239; }
.hero__bg image-slot::part(empty),
.contact__map image-slot::part(empty),
.ecard__media image-slot::part(empty){ color:rgba(251,248,241,.5); }

/* gold diamond rule (echo of the printed menu) */
.diamond-rule{
  display:flex; align-items:center; justify-content:center; gap:0;
  width:120px; height:14px; margin:0 auto; position:relative;
}
.diamond-rule::before{ content:""; flex:1; height:1px; background:linear-gradient(90deg,transparent,var(--gold)); }
.diamond-rule::after{ content:""; flex:1; height:1px; background:linear-gradient(90deg,var(--gold),transparent); }
.diamond-rule i{ width:7px; height:7px; background:var(--gold); transform:rotate(45deg); flex:none; margin:0 7px; }

.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--ff-display); font-weight:600;
  letter-spacing:.16em; text-transform:uppercase; font-size:12.5px;
  padding:15px 28px; border-radius:2px; cursor:pointer;
  border:1px solid transparent; transition:all .18s ease; white-space:nowrap;
}
.btn-gold{ background:var(--gold); color:var(--navy); }
.btn-gold:hover{ background:var(--gold-bright); transform:translateY(-1px); }
.btn-ghost{ background:transparent; color:var(--cream); border-color:var(--cream-45); }
.btn-ghost:hover{ border-color:var(--cream); background:var(--cream-18); }
.btn-navy{ background:var(--navy); color:var(--cream); }
.btn-navy:hover{ background:var(--navy-deep); transform:translateY(-1px); }
.btn-outline{ background:transparent; color:var(--navy); border-color:var(--ink-22); }
.btn-outline:hover{ border-color:var(--gold); color:var(--gold); }

.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 var(--gut); }
section{ scroll-margin-top:var(--nav-h); }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:100; height:var(--nav-h);
  display:flex; align-items:center;
  padding:0 var(--gut);
  transition:background .3s ease, box-shadow .3s ease, height .3s ease;
}
.nav.solid{
  background:rgba(16,29,49,.94);
  -webkit-backdrop-filter:blur(10px); backdrop-filter:blur(10px);
  box-shadow:0 1px 0 var(--cream-18), 0 10px 30px rgba(0,0,0,.18);
}
.nav__logo{ display:flex; align-items:center; gap:0; flex:none; margin-right:auto; }
.nav__logo img{ height:38px; width:auto; }

/* ---------- animated brand logo (original artwork) ---------- */
.klogo-wrap{ position:relative; display:block; line-height:0; }
.klogo-wrap img{
  height:44px; width:auto; display:block;
  opacity:0; transform:translateY(4px);
  animation:klogo-in 1.2s cubic-bezier(.3,0,.2,1) .15s forwards;
}
.klogo-shine{
  position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(110deg, rgba(231,201,130,0) 38%, rgba(231,201,130,.95) 50%, rgba(231,201,130,0) 62%);
  background-size:260% 100%; background-position:130% 0;
  -webkit-mask-image:url("assets/kiskopar-logo-cream.png");
  mask-image:url("assets/kiskopar-logo-cream.png");
  -webkit-mask-size:contain; mask-size:contain;
  -webkit-mask-repeat:no-repeat; mask-repeat:no-repeat;
  -webkit-mask-position:center; mask-position:center;
  animation:klogo-shine 8s ease-in-out 1.6s infinite;
}
.nav__logo:hover .klogo-wrap img{ filter:drop-shadow(0 0 5px rgba(231,201,130,.45)); transition:filter .4s ease; }
@keyframes klogo-in{ to{ opacity:1; transform:translateY(0); } }
@keyframes klogo-shine{
  0%{ background-position:130% 0; }
  14%{ background-position:-30% 0; }
  100%{ background-position:-30% 0; }
}
@media (prefers-reduced-motion: reduce){
  .klogo-wrap img{ animation:none; opacity:1; transform:none; }
  .klogo-shine{ animation:none; display:none; }
}
  .klogo__name, .klogo__sub{ animation:none; opacity:1; transform:none; }
  .klogo__peaks{ animation:none; }
}
.nav__links{ display:flex; align-items:center; gap:34px; }
.nav__links a{
  font-family:var(--ff-display); font-weight:500;
  letter-spacing:.14em; text-transform:uppercase; font-size:12.5px;
  color:var(--cream-72); padding:6px 0; position:relative; transition:color .15s ease;
}
.nav__links a::after{
  content:""; position:absolute; left:0; right:0; bottom:-2px; height:1px;
  background:var(--gold); transform:scaleX(0); transform-origin:left; transition:transform .22s ease;
}
.nav__links a:hover{ color:var(--cream); }
.nav__links a:hover::after{ transform:scaleX(1); }
.nav__right{ display:flex; align-items:center; gap:18px; margin-left:36px; }
.nav__social{ display:flex; align-items:center; gap:12px; }
.nav__social a{ color:var(--cream-72); display:grid; place-items:center; transition:color .15s ease, transform .15s ease; }
.nav__social a:hover{ color:var(--gold); transform:translateY(-1px); }
.nav__social svg{ width:19px; height:19px; }
.nav__cta{ padding:11px 20px; font-size:11.5px; }
.nav__burger{
  display:none; width:42px; height:42px; border:none; background:transparent; cursor:pointer;
  flex-direction:column; justify-content:center; gap:5px; align-items:flex-end; padding:0;
}
.nav__burger span{ display:block; height:2px; background:var(--cream); border-radius:2px; transition:.25s ease; }
.nav__burger span:nth-child(1){ width:24px; }
.nav__burger span:nth-child(2){ width:18px; }
.nav__burger span:nth-child(3){ width:24px; }
.nav.open .nav__burger span:nth-child(1){ transform:translateY(7px) rotate(45deg); width:24px; }
.nav.open .nav__burger span:nth-child(2){ opacity:0; }
.nav.open .nav__burger span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); width:24px; }

/* mobile drawer */
.drawer{
  position:fixed; inset:var(--nav-h) 0 0 0; z-index:90;
  background:var(--navy-deep);
  display:flex; flex-direction:column; padding:28px var(--gut) 40px;
  transform:translateY(-12px); opacity:0; pointer-events:none; transition:.28s ease;
}
.drawer.open{ transform:none; opacity:1; pointer-events:auto; }
.drawer a{
  font-family:var(--ff-display); font-weight:500; letter-spacing:.12em; text-transform:uppercase;
  font-size:18px; color:var(--cream); padding:18px 0; border-bottom:1px solid var(--cream-18);
}
.drawer .btn{
  margin-top:26px; max-width:100%; box-sizing:border-box;
  white-space:normal; text-align:center; line-height:1.5;
  font-size:13.5px; letter-spacing:.1em; padding:14px 16px;
  overflow-wrap:break-word;
}
.drawer__social{ display:flex; gap:22px; margin-top:auto; padding-top:28px; }
.drawer__social a{ color:var(--cream-72); border:none; padding:0; }
.drawer__social svg{ width:22px; height:22px; }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; min-height:100svh; display:flex; align-items:center; isolation:isolate; }
.hero__bg{ position:absolute; inset:0; z-index:-2; overflow:hidden; background:#0e1a2c; }
.hero__bg image-slot{ width:100%; height:100%; --slot-bg:#16273f; }
.hero__poster{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
#heroVideo{
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%) scale(1.55);
  width:100vw; height:56.25vw; min-height:100%; min-width:177.78svh;
  border:0; pointer-events:none; opacity:0; transition:opacity 1s ease;
}
.hero__bg.playing #heroVideo{ opacity:1; }
.hero::after{
  content:""; position:absolute; inset:0; z-index:-1;
  background:
    linear-gradient(180deg, rgba(16,29,49,.62) 0%, rgba(16,29,49,.30) 38%, rgba(16,29,49,.72) 100%),
    linear-gradient(90deg, rgba(16,29,49,.55), transparent 60%);
}
.hero__inner{ max-width:var(--maxw); margin:0 auto; padding:calc(var(--nav-h) + 40px) var(--gut) 80px; width:100%; }
.hero__peaks{ width:60px; height:auto; margin-bottom:26px; }
.hero__word{
  font-family:var(--ff-display); font-weight:300;
  letter-spacing:.2em; text-transform:uppercase;
  font-size:clamp(44px, 9vw, 104px); line-height:.92; color:var(--light);
  margin:0; text-shadow:0 2px 30px rgba(0,0,0,.3);
}
.hero__sub{
  display:flex; align-items:center; gap:16px; margin-top:18px;
  font-family:var(--ff-display); font-weight:600; letter-spacing:.42em;
  text-transform:uppercase; font-size:clamp(12px,1.5vw,15px); color:var(--gold-soft);
}
.hero__sub .ln{ width:48px; height:1px; background:var(--gold); }
.hero__tag{
  margin:30px 0 0; max-width:34ch;
  font-size:clamp(18px,2vw,22px); line-height:1.55; color:var(--cream);
  text-wrap:pretty; font-weight:400;
}
.hero__tag b{ color:var(--gold-bright); font-weight:500; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:16px; margin-top:38px; }
.hero__meta{
  display:flex; flex-wrap:wrap; align-items:center; gap:14px 26px; margin-top:44px;
  padding-top:26px; border-top:1px solid var(--cream-18);
}
.hero__status{
  display:inline-flex; align-items:center; gap:10px; white-space:nowrap;
  font-family:var(--ff-display); font-weight:500; letter-spacing:.04em; font-size:14px; color:var(--cream);
}
.hero__status .dot{ width:9px; height:9px; border-radius:50%; flex:none; }
.hero__status .dot.open{ background:#7fbf6a; box-shadow:0 0 0 4px rgba(127,191,106,.22); }
.hero__status .dot.closed{ background:var(--slate); box-shadow:0 0 0 4px rgba(138,143,152,.2); }
.hero__status b{ color:var(--gold-bright); font-weight:600; }
.hero__loc{
  display:inline-flex; align-items:center; gap:9px;
  font-size:13.5px; color:var(--cream-72); letter-spacing:.02em;
}
.hero__loc svg{ width:16px; height:16px; color:var(--gold-soft); flex:none; }
.hero__scroll{
  position:absolute; left:50%; bottom:26px; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:8px; z-index:1;
  font-family:var(--ff-display); letter-spacing:.24em; text-transform:uppercase; font-size:10px; color:var(--cream-72);
}
.hero__scroll .mouse{ width:1px; height:30px; background:linear-gradient(var(--gold-soft),transparent); animation:scrolldot 2.2s ease-in-out infinite; }
@keyframes scrolldot{ 0%{transform:scaleY(0);transform-origin:top;} 45%{transform:scaleY(1);transform-origin:top;} 55%{transform:scaleY(1);transform-origin:bottom;} 100%{transform:scaleY(0);transform-origin:bottom;} }

/* ============================================================
   INTRO STRIP
   ============================================================ */
.intro{ background:var(--cream); padding:clamp(70px,9vw,120px) 0; }
.intro__grid{ display:grid; grid-template-columns:1.15fr 1fr; gap:clamp(40px,6vw,90px); align-items:center; }
.intro__title{
  font-family:var(--ff-display); font-weight:300; letter-spacing:.04em;
  font-size:clamp(28px,3.6vw,42px); line-height:1.18; margin:.4em 0 0; color:var(--navy);
}
.intro__title b{ color:var(--gold); font-weight:400; }
.intro p{ color:var(--ink-72); margin:22px 0 0; max-width:54ch; text-wrap:pretty; }
.intro__features{ display:flex; gap:0; margin-top:36px; border-top:1px solid var(--ink-12); }
.feat{ flex:1; padding:22px 18px 0; border-right:1px solid var(--ink-12); }
.feat:last-child{ border-right:none; }
.feat .ico{ color:var(--gold); margin-bottom:10px; }
.feat .ico svg{ width:26px; height:26px; }
.feat h4{ font-family:var(--ff-display); font-weight:600; letter-spacing:.1em; text-transform:uppercase; font-size:13px; margin:0 0 4px; }
.feat p{ margin:0; font-size:13.5px; color:var(--ink-55); }
.intro__media{ position:relative; }
.intro__media .stack{ display:grid; grid-template-columns:1fr 1fr; grid-template-rows:auto auto; gap:14px; }
.intro__media image-slot{ width:100%; }
.intro__media .tall{ grid-row:span 2; height:100%; min-height:340px; }
.intro__media .short{ height:172px; }
.intro__badge{
  position:absolute; bottom:-26px; left:-26px; z-index:2;
  background:var(--navy); color:var(--cream); padding:18px 22px; border-radius:2px;
  box-shadow:0 16px 40px rgba(16,29,49,.28);
  display:flex; align-items:center; gap:14px;
}
.intro__badge .n{ font-family:var(--ff-display); font-weight:300; font-size:34px; line-height:1; color:var(--gold-bright); }
.intro__badge .t{ font-family:var(--ff-display); font-weight:500; letter-spacing:.08em; text-transform:uppercase; font-size:11px; line-height:1.35; color:var(--cream-72); }

/* ============================================================
   MENU
   ============================================================ */
.menu{ background:var(--navy); color:var(--cream); padding:clamp(74px,9vw,128px) 0; position:relative; }
.menu .eyebrow{ color:var(--gold-soft); }
.menu .eyebrow::before, .menu .eyebrow.center::after{ background:var(--gold-soft); }
.menu .section-title{ color:var(--light); }
.menu__head{ text-align:center; margin-bottom:14px; }
.menu__note{ text-align:center; color:var(--cream-72); font-size:15px; margin:14px auto 0; max-width:48ch; }
.menu__switch{ display:flex; justify-content:center; margin:40px auto 0; }
.menu__switch button{
  font-family:var(--ff-display); font-weight:600; letter-spacing:.14em; text-transform:uppercase; font-size:13px;
  color:var(--cream-72); background:transparent; border:1px solid var(--cream-18);
  padding:12px 36px; cursor:pointer; transition:.16s ease;
}
.menu__switch button:first-child{ border-radius:999px 0 0 999px; border-right:none; }
.menu__switch button:last-child{ border-radius:0 999px 999px 0; }
.menu__switch button:hover{ color:var(--cream); border-color:var(--gold-soft); }
.menu__switch button.active{ color:var(--navy); background:var(--gold-soft); border-color:var(--gold-soft); }

.menu__cats{
  display:flex; flex-wrap:wrap; justify-content:center; gap:10px;
  margin:30px auto 56px; max-width:880px;
}
.menu__cats button{
  font-family:var(--ff-display); font-weight:500; letter-spacing:.1em; text-transform:uppercase; font-size:11.5px;
  color:var(--cream-72); background:transparent; border:1px solid var(--cream-18);
  border-radius:999px; padding:9px 17px; cursor:pointer; transition:.16s ease;
}
.menu__cats button:hover{ color:var(--cream); border-color:var(--gold-soft); }
.menu__cats button.active{ color:var(--navy); background:var(--gold-soft); border-color:var(--gold-soft); }

.menu__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,5vw,72px); }
.menu__col{ display:flex; flex-direction:column; gap:40px; }
.mcat{ scroll-margin-top:calc(var(--nav-h) + 20px); }
.mcat__head{ display:flex; align-items:center; gap:12px; margin-bottom:20px; }
.mcat__head .ico{ width:26px; height:26px; flex:none; color:var(--gold-soft); }
.mcat__head .ico svg{ width:100%; height:100%; }
.mcat__head h3{
  font-family:var(--ff-display); font-weight:600; letter-spacing:.13em; text-transform:uppercase;
  font-size:16px; margin:0; color:var(--light); white-space:nowrap;
}
.mcat__head .line{ flex:1; height:1px; background:linear-gradient(90deg,var(--gold-soft),rgba(205,176,104,.18)); position:relative; }
.mcat__head .line::after{ content:""; position:absolute; right:0; top:50%; transform:translateY(-50%); width:5px;height:5px;border-radius:50%;background:var(--gold-soft); }

.mitem{ padding:13px 0; border-bottom:1px dotted var(--cream-18); }
.mitem:last-child{ border-bottom:none; }
.mitem__row{ display:flex; align-items:baseline; gap:14px; }
.mitem__name{ font-weight:600; font-size:16px; color:var(--light); flex:1; line-height:1.3; }
.mitem__dots{ flex:1; border-bottom:1px dotted var(--cream-18); transform:translateY(-4px); min-width:14px; }
.mitem__price{ font-family:var(--ff-display); font-weight:500; font-size:16px; color:var(--gold-bright); white-space:nowrap; }
.mitem__desc{ margin:5px 0 0; font-size:13.5px; line-height:1.45; color:var(--cream-72); max-width:46ch; text-wrap:pretty; }
.tag-new{
  display:inline-block; vertical-align:middle; margin-left:9px; transform:translateY(-1px);
  font-family:var(--ff-display); font-size:9px; font-weight:600; letter-spacing:.16em; text-transform:uppercase;
  color:var(--gold-bright); border:1px solid var(--gold-soft); border-radius:2px; padding:2px 6px;
}
.tag-star{ color:var(--gold-bright); margin-left:7px; font-size:13px; }
.menu__legend{
  display:flex; flex-wrap:wrap; justify-content:center; gap:26px; margin-top:58px;
  padding-top:30px; border-top:1px solid var(--cream-18); text-align:center;
}
.menu__legend span{ font-family:var(--ff-display); font-size:11.5px; font-weight:500; letter-spacing:.1em; text-transform:uppercase; color:var(--cream-72); }
.menu__legend b{ color:var(--gold-bright); }
.menu__sync{
  display:inline-flex; align-items:center; gap:8px; margin:0 auto;
  font-size:11.5px; color:var(--cream-45); letter-spacing:.04em;
}
.menu__sync svg{ width:13px; height:13px; }

/* ============================================================
   EVENTS
   ============================================================ */
.events{ background:var(--cream-deep); padding:clamp(74px,9vw,128px) 0; }
.events__head{ display:flex; align-items:flex-end; justify-content:space-between; gap:30px; flex-wrap:wrap; margin-bottom:48px; }
.events__head .lead{ margin-top:14px; }
.events__sync{ display:inline-flex; align-items:center; gap:8px; font-size:12px; color:var(--ink-55); letter-spacing:.03em; }
.events__sync svg{ width:14px; height:14px; color:var(--gold); }
.events__sync b{ color:var(--navy); font-weight:600; }
.events__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.ecard{
  background:var(--cream-card); border:1px solid var(--ink-12); border-radius:3px; overflow:hidden;
  display:flex; flex-direction:column; transition:transform .2s ease, box-shadow .2s ease;
}
.ecard:hover{ transform:translateY(-4px); box-shadow:0 22px 50px rgba(16,29,49,.13); }
.ecard__media{ position:relative; background:#142239; }
.ecard__media image-slot{ width:100%; height:188px; --slot-bg:#e7dcc3; }
.ecard__date{
  position:absolute; top:14px; left:14px; background:var(--navy); color:var(--cream);
  text-align:center; padding:8px 12px 7px; border-radius:2px; line-height:1; min-width:54px;
}
.ecard__date .d{ font-family:var(--ff-display); font-weight:300; font-size:24px; }
.ecard__date .m{ font-family:var(--ff-display); font-weight:600; letter-spacing:.16em; text-transform:uppercase; font-size:10px; color:var(--gold-bright); margin-top:3px; }
.ecard__body{ padding:22px 22px 24px; display:flex; flex-direction:column; flex:1; }
.ecard__kind{ font-family:var(--ff-display); font-weight:600; letter-spacing:.16em; text-transform:uppercase; font-size:10.5px; color:var(--gold); margin-bottom:9px; }
.ecard__title{ font-family:var(--ff-display); font-weight:500; font-size:21px; line-height:1.2; margin:0 0 8px; color:var(--navy); }
.ecard__meta{ font-size:13px; color:var(--ink-55); display:flex; align-items:center; gap:7px; margin-bottom:12px; }
.ecard__meta svg{ width:14px; height:14px; color:var(--gold); flex:none; }
.ecard__desc{ font-size:14px; color:var(--ink-72); line-height:1.5; margin:0 0 16px; text-wrap:pretty; }
.ecard__src{ margin-top:auto; display:inline-flex; align-items:center; gap:7px; font-family:var(--ff-display); font-weight:500; letter-spacing:.1em; text-transform:uppercase; font-size:10px; color:var(--ink-55); padding-top:14px; border-top:1px solid var(--ink-12); }
.ecard__src svg{ width:13px; height:13px; color:#3b5998; flex:none; }
.events__foot{ display:flex; justify-content:center; margin-top:46px; }

/* live facebook page plugin (events tab) + branded fallback */
.fb-live{
  display:grid; grid-template-columns:minmax(0,500px) 1fr; gap:clamp(34px,5vw,64px);
  align-items:start; margin-top:54px; padding-top:46px; border-top:1px solid var(--ink-12);
}
.fb-live__frame{
  background:var(--cream); border:1px solid var(--ink-12); border-radius:6px; overflow:hidden;
  box-shadow:0 18px 44px rgba(16,29,49,.10);
}
.fb-live__bar{
  display:flex; align-items:center; justify-content:space-between;
  padding:13px 16px; border-bottom:1px solid var(--ink-12); background:rgba(22,36,63,.02);
}
.fb-live__brand{ display:inline-flex; align-items:center; gap:9px; font-family:var(--ff-display); font-weight:600; font-size:13px; letter-spacing:.04em; color:var(--navy); }
.fb-live__brand svg{ width:18px; height:18px; }
.fb-live__dot{ display:inline-flex; align-items:center; gap:7px; font-family:var(--ff-display); font-weight:600; letter-spacing:.14em; text-transform:uppercase; font-size:9.5px; color:#1877f2; }
.fb-live__dot::before{ content:""; width:7px; height:7px; border-radius:50%; background:#1877f2; box-shadow:0 0 0 3px rgba(24,119,242,.18); animation:fbpulse 1.8s ease-in-out infinite; }
@keyframes fbpulse{ 0%,100%{ opacity:1; } 50%{ opacity:.4; } }
.fb-live__plugin{ padding:12px; min-height:200px; position:relative; overflow:hidden; }
.fb-live__plugin .fb-page{ width:100%; }
.fb-live__plugin .fb-page span,
.fb-live__plugin .fb-page iframe{ width:100% !important; }

.fb-fallback__cards{ display:flex; flex-direction:column; gap:0; }
.fb-fallback .ecard{ flex-direction:row; background:transparent; border:none; border-radius:0; box-shadow:none; border-bottom:1px solid var(--ink-12); }
.fb-fallback .ecard:last-child{ border-bottom:none; }
.fb-fallback .ecard:hover{ transform:none; box-shadow:none; }
.fb-fallback .ecard__media{ display:none; }
.fb-fallback .ecard__body{ padding:15px 8px; }
.fb-fallback .ecard__src{ display:none; }
.fb-fallback .ecard__desc{ display:none; }
.fb-fallback .ecard__title{ font-size:17px; margin-bottom:5px; }
.fb-fallback .ecard__kind{ margin-bottom:5px; }
.fb-fallback__note{ margin:14px 6px 4px; font-size:12px; color:var(--ink-55); line-height:1.5; text-wrap:pretty; }

.fb-live__aside{ padding-top:6px; }
.fb-live__aside .eyebrow{ margin-bottom:6px; }
.fb-live__aside h3{ font-family:var(--ff-display); font-weight:300; letter-spacing:.02em; font-size:clamp(24px,3vw,34px); line-height:1.16; margin:.3em 0 0; color:var(--navy); }
.fb-live__aside p{ color:var(--ink-72); margin:16px 0 24px; max-width:42ch; text-wrap:pretty; }
.fb-live__aside b{ color:var(--navy); font-weight:600; }
.fb-live__steps{ list-style:none; margin:0 0 28px; padding:0; display:flex; flex-direction:column; gap:14px; }
.fb-live__steps li{ display:flex; align-items:center; gap:14px; font-size:15px; color:var(--navy); }
.fb-live__steps span{
  width:30px; height:30px; flex:none; border-radius:50%; display:grid; place-items:center;
  font-family:var(--ff-display); font-weight:600; font-size:13px; color:var(--gold);
  border:1px solid var(--gold-soft); background:rgba(191,155,48,.06);
}

/* ============================================================
   ABOUT
   ============================================================ */
.about{ background:var(--cream); padding:clamp(74px,9vw,128px) 0; }
.about__grid{ display:grid; grid-template-columns:1fr 1.05fr; gap:clamp(40px,6vw,84px); align-items:center; }
.about__media{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.about__media image-slot{ width:100%; --slot-bg:#e7dcc3; }
.about__media .a{ height:300px; grid-row:span 2; }
.about__media .b{ height:143px; }
.about__media.solo{ display:block; }
.media-solo{ width:100%; height:clamp(360px,46vw,520px); }
.about p{ color:var(--ink-72); margin:20px 0 0; text-wrap:pretty; }
.about p:first-of-type{ font-size:19px; color:var(--navy); line-height:1.6; }
.about__sign{ margin-top:26px; }
.about__sign .script{ font-size:34px; line-height:1; }

/* ============================================================
   CONTACT
   ============================================================ */
.contact{ background:var(--navy); color:var(--cream); padding:clamp(74px,9vw,128px) 0; }
.contact .eyebrow{ color:var(--gold-soft); }
.contact .eyebrow::before, .contact .eyebrow.center::after{ background:var(--gold-soft); }
.contact .section-title{ color:var(--light); }
.contact__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,80px); margin-top:54px; }

.cblock{ margin-bottom:34px; }
.cblock__h{ display:flex; align-items:center; gap:11px; margin-bottom:18px; }
.cblock__h .ico{ width:22px; height:22px; color:var(--gold-soft); flex:none; }
.cblock__h h3{ font-family:var(--ff-display); font-weight:600; letter-spacing:.13em; text-transform:uppercase; font-size:14px; margin:0; color:var(--light); }
.cblock__h .line{ flex:1; height:1px; background:linear-gradient(90deg,var(--gold-soft),rgba(205,176,104,.16)); }

.hours{ width:100%; border-collapse:collapse; }
.hours th{
  font-family:var(--ff-display); font-weight:600; letter-spacing:.12em; text-transform:uppercase; font-size:11px;
  color:var(--gold-soft); text-align:right; padding:0 0 12px; }
.hours th:first-child{ text-align:left; }
.hours td{ padding:9px 0; border-bottom:1px dotted var(--cream-18); font-size:14.5px; }
.hours tr:last-child td{ border-bottom:none; }
.hours .day{ font-weight:600; color:var(--light); }
.hours .t{ text-align:right; color:var(--cream); font-variant-numeric:tabular-nums; }
.hours .closed{ color:var(--cream-45); font-style:italic; }
.hours tr.today td{ }
.hours tr.today .day::after{
  content:"MA"; margin-left:9px; font-family:var(--ff-display); font-size:9px; font-weight:600; letter-spacing:.14em;
  color:var(--navy); background:var(--gold-soft); padding:2px 6px; border-radius:2px; vertical-align:middle;
}
.hours__sync{ display:inline-flex; align-items:center; gap:7px; margin-top:14px; font-size:11px; color:var(--cream-45); letter-spacing:.03em; }
.hours__sync svg{ width:12px; height:12px; }

.cinfo{ list-style:none; margin:0; padding:0; }
.cinfo li{ display:flex; gap:15px; padding:15px 0; border-bottom:1px dotted var(--cream-18); align-items:flex-start; }
.cinfo li:last-child{ border-bottom:none; }
.cinfo .ico{ width:20px; height:20px; color:var(--gold-soft); flex:none; margin-top:3px; }
.cinfo .lbl{ font-family:var(--ff-display); font-weight:600; letter-spacing:.12em; text-transform:uppercase; font-size:10.5px; color:var(--gold-soft); display:block; margin-bottom:3px; }
.cinfo .val{ color:var(--light); font-size:15.5px; }
.cinfo a.val:hover{ color:var(--gold-bright); }

.contact__map{ margin-top:22px; border:1px solid var(--cream-18); border-radius:3px; overflow:hidden; background:#142239; }
.contact__map image-slot{ width:100%; height:220px; --slot-bg:#1d3252; }
.map-frame{ display:block; width:100%; height:300px; border:0; filter:grayscale(.25) contrast(.95); }
.map-cta{ display:flex; align-items:center; justify-content:space-between; padding:13px 16px; background:rgba(251,248,241,.05); }
.map-cta span{ font-size:13px; color:var(--cream-72); }
.map-cta a{ font-family:var(--ff-display); font-weight:600; letter-spacing:.1em; text-transform:uppercase; font-size:11px; color:var(--gold-bright); display:inline-flex; align-items:center; gap:6px; }
.map-cta svg{ width:13px; height:13px; }

/* form */
.cform{ display:grid; gap:18px; }
.field{ display:flex; flex-direction:column; gap:7px; }
.field label{ font-family:var(--ff-display); font-weight:600; letter-spacing:.1em; text-transform:uppercase; font-size:10.5px; color:var(--gold-soft); }
.field input, .field textarea{
  font-family:var(--ff-body); font-size:15px; color:var(--light);
  background:rgba(251,248,241,.05); border:1px solid var(--cream-18); border-radius:2px;
  padding:13px 15px; transition:border-color .16s ease, background .16s ease;
}
.field input::placeholder, .field textarea::placeholder{ color:var(--cream-45); }
.field input:focus, .field textarea:focus{ outline:none; border-color:var(--gold-soft); background:rgba(251,248,241,.08); }
.field textarea{ resize:vertical; min-height:120px; }
.field.row2{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.cform__submit{ display:flex; align-items:center; gap:18px; margin-top:6px; flex-wrap:wrap; }
.cform__note{ font-size:12px; color:var(--cream-45); max-width:34ch; }
.form-ok{
  display:none; align-items:center; gap:10px; padding:14px 16px; border-radius:2px;
  background:rgba(127,191,106,.12); border:1px solid rgba(127,191,106,.4); color:#bfe3b1; font-size:14px;
}
.form-ok.show{ display:flex; }
.form-ok svg{ width:18px; height:18px; flex:none; }
.form-err{ background:rgba(214,108,108,.12); border-color:rgba(214,108,108,.4); color:#e8b3b3; }
.hp-field{ position:absolute; left:-9999px; width:1px; height:1px; opacity:0; }

.contact__reserve{
  grid-column:1/-1; margin-top:18px; padding:30px clamp(24px,4vw,48px);
  background:linear-gradient(120deg, rgba(191,154,51,.14), rgba(191,154,51,.04));
  border:1px solid var(--cream-18); border-radius:3px;
  display:flex; flex-direction:column; gap:0;
}
.contact__reserve-main{ display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.contact__reserve .t h3{ font-family:var(--ff-display); font-weight:300; font-size:clamp(22px,2.6vw,30px); margin:0 0 6px; color:var(--light); letter-spacing:.03em; }
.contact__reserve .t p{ margin:0; color:var(--cream-72); font-size:14.5px; }
.contact__reserve .t b{ color:var(--gold-bright); }
.reserve-feszek{
  display:flex; align-items:center; gap:16px;
  margin-top:24px; padding-top:22px; border-top:1px solid var(--cream-18);
}
.reserve-feszek__mark{ height:30px; width:auto; flex:none; filter:brightness(0) invert(1) opacity(.8); }
.reserve-feszek p{ margin:0; flex:1; font-size:13px; line-height:1.5; color:var(--cream-72); text-wrap:pretty; }
.reserve-feszek p b{ color:var(--gold-bright); font-weight:600; }
.reserve-feszek__cta{
  flex:none; display:inline-flex; align-items:center; gap:7px;
  font-family:var(--ff-display); font-weight:600; letter-spacing:.1em; text-transform:uppercase; font-size:10.5px;
  color:var(--cream); padding:8px 14px; border:1px solid var(--cream-18); border-radius:2px; transition:all .16s ease;
}
.reserve-feszek__cta svg{ width:13px; height:13px; }
.reserve-feszek__cta:hover{ border-color:var(--gold-soft); color:var(--gold-bright); }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--navy-deep); color:var(--cream-72); padding:64px 0 30px; }
.footer__grid{ display:grid; grid-template-columns:1.4fr .8fr 1.2fr 1fr; gap:42px; }
.nl-form{ display:flex; gap:8px; margin-top:14px; }
.nl-form input{
  flex:1; min-width:0; background:rgba(250,244,232,.06); border:1px solid var(--cream-18);
  border-radius:2px; padding:10px 12px; color:var(--cream); font-family:inherit; font-size:13.5px;
}
.nl-form input::placeholder{ color:var(--cream-72); opacity:.7; }
.nl-form input:focus{ outline:none; border-color:var(--gold-soft); }
.nl-form .btn{ padding:10px 16px; font-size:11px; white-space:nowrap; }
.nl-note{ font-size:11.5px !important; color:var(--cream-72); margin-top:10px !important; }
.footer__nl .nl-note a{ display:inline; padding:0; text-decoration:underline; color:var(--cream-72); }
.footer__nl .nl-note a:hover{ color:var(--gold-soft); }
.footer__logo img{ height:42px; margin-bottom:18px; }
.footer__grid p{ font-size:13.5px; line-height:1.7; margin:0; }
.footer h5{ font-family:var(--ff-display); font-weight:600; letter-spacing:.16em; text-transform:uppercase; font-size:11px; color:var(--gold-soft); margin:0 0 16px; }
.footer__col a{ display:block; font-size:13.5px; padding:5px 0; color:var(--cream-72); transition:color .15s ease; }
.footer__col a:hover{ color:var(--gold-bright); }
.footer__social{ display:flex; gap:14px; margin-top:6px; }
.footer__social a{ color:var(--cream-72); display:grid; place-items:center; transition:color .15s; }
.footer__social a:hover{ color:var(--gold-bright); }
.footer__social svg{ width:20px; height:20px; }
.footer__bar{
  display:flex; align-items:center; justify-content:space-between; gap:18px; flex-wrap:wrap;
  margin-top:48px; padding-top:24px; border-top:1px solid var(--cream-18);
  font-size:12px; color:var(--cream-45);
}
.footer__bar a:hover{ color:var(--gold-bright); }
.footer__peak{ display:flex; align-items:center; gap:9px; }
.footer__peak svg{ width:22px; height:auto; color:var(--slate); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1000px){
  .nav__links, .nav__social{ display:none; }
  .nav__burger{ display:flex; }
  .nav__right{ margin-left:0; gap:12px; }
  .intro__grid, .about__grid, .contact__grid{ grid-template-columns:1fr; }
  .menu__grid{ gap:38px; }
  .events__grid{ grid-template-columns:repeat(2,1fr); }
  .fb-live{ grid-template-columns:1fr; gap:36px; }
  .fb-live__frame{ max-width:500px; }
  .footer__grid{ grid-template-columns:1fr 1fr; }
  .about__media .a{ height:260px; }
}
@media (max-width:680px){
  body{ font-size:16px; }
  :root{ --nav-h:66px; }
  .nav__cta{ display:none; }
  .menu__grid{ grid-template-columns:1fr; }
  .events__grid{ grid-template-columns:1fr; }
  .field.row2{ grid-template-columns:1fr; }
  .intro__features{ flex-wrap:wrap; }
  .feat{ flex:1 1 45%; border-right:none; border-bottom:1px solid var(--ink-12); padding-bottom:18px; }
  .footer__grid{ grid-template-columns:1fr; gap:34px; }
  .intro__badge{ left:50%; transform:translateX(-50%); bottom:-22px; }
  .contact__reserve-main{ flex-direction:column; align-items:flex-start; }
  .hero__cta .btn{ flex:1 1 auto; }
  .reserve-feszek{ flex-direction:column; align-items:flex-start; gap:12px; text-align:left; }
}