:root{
  --cream:#FAF7F2; --ink:#1C1B19; --gold:#C9A04F; --gold-2:#E6C67A; --forest:#2F3E34; --slate:#6B7280;
}
html{scroll-behavior:smooth}
body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,sans-serif;color:var(--ink);background:var(--cream)}
.title-font{font-family:"Playfair Display",serif;letter-spacing:.2px}

/* Background */
.page-bg:before{content:"";position:fixed;inset:0;z-index:-2;background:
  radial-gradient(1200px 700px at 80% -10%, rgba(201,160,79,.20), transparent 60%),
  radial-gradient(900px 600px at 10% 10%, rgba(47,62,52,.20), transparent 55%),
  linear-gradient(180deg,#fff 0%,var(--cream) 65%,#fff 100%)}
.page-bg:after{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;background:
  radial-gradient(60% 60% at 50% 40%, rgba(0,0,0,.06), transparent 60%),
  repeating-linear-gradient(0deg, rgba(0,0,0,.02) 0 1px, transparent 1px 2px);mix-blend-mode:multiply}

#site-header{
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000; /* higher than hero/art */
}

/* Gold accents */
.gold{background:linear-gradient(90deg,var(--gold),var(--gold-2));-webkit-background-clip:text;background-clip:text;color:transparent}
.section-underline{height:4px;width:140px;border-radius:999px;background:linear-gradient(90deg,var(--gold),var(--gold-2))}
.shine{position:relative;overflow:hidden}
.shine:after{content:"";position:absolute;inset:0;transform:translateX(-120%);background:linear-gradient(75deg,transparent 20%,rgba(255,255,255,.25) 45%,transparent 70%);animation:shine 3.5s ease-in-out infinite}
@keyframes shine{0%{transform:translateX(-120%)}60%,100%{transform:translateX(120%)}}

/* Glass + edge */
.glass{background:rgba(255,255,255,.65);backdrop-filter:blur(10px)}
.card-edge{position:relative;border-radius:18px}
.card-edge:before{content:"";position:absolute;inset:0;border-radius:18px;padding:1px;background:linear-gradient(120deg,rgba(201,160,79,.05),rgba(255,255,255,0) 40%,rgba(201,160,79,.35));-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}

/* Hero */
.hero{min-height:68vh;display:grid;place-items:center;position:relative;overflow:hidden;background:
  radial-gradient(1200px 600px at 100% 0%, rgba(201,160,79,.18), transparent 60%),
  radial-gradient(1200px 700px at 0% 0%, rgba(47,62,52,.18), transparent 60%)}
.hero-watermark{position:absolute;right:-3%;top:-6%;width:min(42vw,640px);opacity:.06;pointer-events:none}
@media (max-width:640px){.hero-watermark{width:min(70vw,480px);top:-8%;right:-8%;opacity:.07}}
.hero-interior{
  position:absolute;left:8%;top:8%;
  width:min(78vw,1200px);max-width:1200px;
  opacity:.22;pointer-events:none;mix-blend-mode:multiply;
  filter:grayscale(10%) contrast(96%) saturate(92%);
  -webkit-mask-image:linear-gradient(90deg,rgba(0,0,0,.95) 0%,rgba(0,0,0,.85) 35%,rgba(0,0,0,.55) 58%,rgba(0,0,0,.15) 78%,rgba(0,0,0,0) 92%);
          mask-image:linear-gradient(90deg,rgba(0,0,0,.95) 0%,rgba(0,0,0,.85) 35%,rgba(0,0,0,.55) 58%,rgba(0,0,0,.15) 78%,rgba(0,0,0,0) 92%);
}
@media (max-width:900px){.hero-interior{left:4%;top:10%;width:min(88vw,1100px);opacity:.20}}

/* Pill */
.pill{
  display:inline-flex;align-items:center;justify-content:center;
  font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.12em;
  padding:6px 10px;border-radius:9999px;color:#5B3B00;
  background:linear-gradient(180deg,#FFE9B7,#FBD88E);border:1px solid #E9C77A;
  line-height:1;
}

/* Chips (section links) */
.chips{display:flex;gap:3.25rem;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding:.25rem;width:max-content;margin:0 auto;justify-content:center}
.chip{padding:.4rem .2rem;font-weight:700;font-size:.98rem;position:relative;color:#1f2937;border-bottom:2px solid transparent;transition:color .2s ease,border-color .2s ease}
.chip:hover{color:var(--gold-2);border-color:var(--gold-2)}
.chip.active{color:var(--gold);border-color:var(--gold)}
.chips-inline-wrap{ position: sticky; top: var(--headerH,72px); z-index: 25; }
.chips--docked{gap:3.6rem}
.chips--docked .chip{font-size:.9rem}
#chipsDock{display:none}
body.chips-docked #chipsDock{display:flex}
body.chips-docked #sectionChipsInline .chips{opacity:0;pointer-events:none}
body.chips-docked #sectionChipsInline{height:0;padding:0;border:0;margin:0}

/* Menu rows */
.menu-item{display:flex;align-items:baseline;gap:.35rem}
.menu-item .name{font-weight:500;letter-spacing:.2px}
.menu-item .meta{color:#6B7280;font-size:.88rem;font-weight:500;margin-left:.25rem;white-space:nowrap}
.menu-item .fill{flex:1 1 auto;height:1px;align-self:center;margin:0 .5rem;background-image:radial-gradient(currentColor 1px,transparent 1px);background-size:7px 1px;background-repeat:repeat-x;opacity:.25}
.menu-item .price{font-weight:600;color:var(--forest);white-space:nowrap}
.menu-item .price .sep{color:#9CA3AF;font-weight:600;padding:0 .3rem}
@media (max-width:640px){.menu-item .fill{margin:0 .35rem;background-size:6px 1px}}
.menu-desc{margin-top:.20rem;color:#6b7280;font-size:.86rem;line-height:1.35}

/* Section titles */
.section-title{font-family:"Playfair Display",serif;font-weight:900;font-size:clamp(1.6rem,1.2rem + 1vw,2.05rem);line-height:1.15;letter-spacing:-0.01em}

/* Space between menu sections */
#menu-dynamic section + section{ margin-top: 4.5rem; }

/* Buttons */
.btn-glass{
  display:inline-flex;align-items:center;gap:.5rem;border-radius:14px;padding:.65rem 1rem;font-weight:800;
  color:var(--forest);
  background:linear-gradient(180deg, rgba(250,247,242,.65), rgba(250,247,242,.35));
  border:1px solid rgba(201,160,79,.25);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.4), 0 12px 28px rgba(28,27,25,.12), 0 0 0 2px rgba(201,160,79,.08);
  backdrop-filter:blur(8px);
  transition:transform .15s ease, color .15s ease, border-color .15s ease, background .15s ease, box-shadow .15s ease;
}
.btn-glass:hover{
  transform:translateY(-1px);color:#8A6A2E;border-color:rgba(201,160,79,.45);
  background:linear-gradient(180deg, rgba(250,247,242,.85), rgba(250,247,242,.55));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.5), 0 10px 30px rgba(28,27,25,.08);
}

/* Footer (3 columns: locations | art | hours) */
.footer-wrap{border-top:1px solid rgba(255,255,255,.7)}
.footer-inner{max-width:72rem;margin:0 auto;padding:3rem 1.5rem}
.footer-card{position:relative; overflow:hidden; border-radius:18px}

/* Grid */
.footer-grid{display:grid;grid-template-columns:1fr;gap:28px}
@media (min-width:1024px){
  .footer-grid{grid-template-columns:1.05fr 1.2fr 1fr;column-gap:48px}
  .footer-left{padding-left:10px}
}
.space-y-8 > * + *{margin-top:2rem}

.footer-col h3{font-family:"Playfair Display",serif;font-weight:900;font-size:1.2rem;margin:0}
.footer-col small{color:#6B7280}
.phone{color:#1f2937;font-weight:800;font-size:.98rem}
.phone a{color:inherit;text-decoration:none}
.phone a:hover{text-decoration:underline}

/* Socials — larger, balanced */
.social-row{display:flex;gap:.7rem;justify-content:flex-start;margin-top:.8rem}
.social-btn{height:46px;width:46px;border-radius:9999px;display:grid;place-items:center;
  background:linear-gradient(180deg,#FFF,#F7F3EA);border:1px solid #fff;box-shadow:0 8px 22px rgba(28,27,25,.08)}
.social-btn svg{width:22px;height:22px}

/* Hours */
.hours-title{font-family:"Playfair Display",serif;font-weight:900;font-size:1.35rem;margin:0 0 .6rem 0}
.hours{display:grid;gap:.4rem}
.hour-item{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.6rem;padding:.18rem 0;border-bottom:1px dashed rgba(0,0,0,.08)}
.hour-item:last-child{border-bottom:none}
.hour-day,.hour-time{font-size:.95rem}
.hour-day{font-weight:600;color:#1f2937}
.hour-time{font-weight:800;color:#1f2937}
.hour-dots{height:2px;background:repeating-linear-gradient(90deg, rgba(0,0,0,.18) 0 4px, transparent 4px 10px);opacity:.35;align-self:center}

/* Footer polish — gold hairline */
.footer-card::before{
  content:""; position:absolute; left:0; right:0; top:0; height:2px;
  background:linear-gradient(90deg,var(--gold),var(--gold-2));
  opacity:.55; pointer-events:none;
}

/* Inline icons */
.inline-ico{display:inline-block;width:16px;height:16px;margin-right:6px;vertical-align:-2px;color:var(--gold)}
.addr,.phone{display:block}

/* Center bison head art (desktop only) */
.footer-art{display:none; position:relative; min-height:100%}
@media (min-width:1024px){
  .footer-art{display:block}
  .footer-art::before{
    content:""; position:absolute; inset:-10px;
    background:url("./bison-head.svg") no-repeat center/contain;
    opacity:.065; filter:grayscale(100%) contrast(95%); mix-blend-mode:multiply; pointer-events:none;
  }
}

/* ===== Mobile-only: chips swap + FAB contact (clean, single block) ===== */
@media (hover: none), (pointer: coarse), (max-width: 900px){

  /* Default (not docked): inline chips below header; header chips hidden */
  #chipsDock{ display: none; }
  .chips-inline-wrap{
    position: sticky;
    top: var(--headerH,72px);
    z-index: 25;
  }

  /* When docked: show header chips, hide inline chips */
  body.chips-docked #chipsDock{ display: block; }
  body.chips-docked .chips-inline-wrap{ display: none; }

  /* Header chips style on phones */
  body.chips-docked #chipsDock .chips{
    display:flex;
    gap:1rem;
    padding:.45rem .5rem;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    width:100%;
  }

  /* FAB that JS clone mounts into <body> while docked */
  .fab-contact{
    position: fixed;
    right: max(14px, env(safe-area-inset-right));
    bottom: max(14px, env(safe-area-inset-bottom));
    z-index: 4000;
    transform: none;
    pointer-events: auto;
    box-shadow: 0 10px 28px rgba(0,0,0,.18),
                0 0 0 1px rgba(255,255,255,.6) inset;
  }
  /* If you prefer bottom-center:
  .fab-contact{ left:50%; transform:translateX(-50%); right:auto; }
  */

  /* Keep content clear of the FAB */
  body.chips-docked{
    padding-bottom: calc(76px + env(safe-area-inset-bottom));
  }
}

/* Respect notches for the fixed header */
@supports (padding-top: env(safe-area-inset-top)){
  #site-header{ padding-top: env(safe-area-inset-top); }
}

/* Mobile: keep docked chips clear of the logo (only while docked) */
@media (hover: none), (pointer: coarse), (max-width: 900px){
  /* give the chips rail a left inset so it doesn’t sit under the logo */
  body.chips-docked #chipsDock .chips{
    padding-left: clamp(56px, 14vw, 92px); /* tweak if needed: 56–92px */
  }
}

/* ===== Featured boxes for "Най-популярни" ===== */
.featured-grid{
  display:grid;
  gap: 22px;
  grid-template-columns: 1fr;
}
@media (min-width: 640px){
  .featured-grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px){
  .featured-grid{ grid-template-columns: repeat(3, 1fr); }
}

.featured-card{
  border-radius: 18px;
  padding: 16px 18px;
  background: rgba(255,255,255,.78);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(201,160,79,.18);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.45),
    0 22px 40px rgba(28,27,25,.10),
    0 0 0 2px rgba(201,160,79,.06);
}

.fc-title{
  font-family:"Playfair Display",serif;
  font-weight:900;
  font-size: clamp(1.05rem, .95rem + .4vw, 1.25rem);
  line-height:1.2;
  margin: 0 0 .35rem 0;
  letter-spacing:-.01em;
}

.fc-desc{
  color:#6b7280;
  font-size:.95rem;
  line-height:1.45;
  margin:.1rem 0 .8rem 0;
}

.fc-meta{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  column-gap:.6rem;
}

.fc-size{
  color:#6b7280;
  font-weight:600;
  font-size:.92rem;
}

.fc-price{
  justify-self:end;
  font-weight:800;
  color:var(--forest, #2F3E34);
  white-space:nowrap;
}

/* keeps section spacing consistent with other blocks */
#menu-dynamic section + section{ margin-top: 4.5rem; }

/* Mobile: keep docked chips clear of the logo */
@media (hover: none), (pointer: coarse), (max-width: 900px){
  body.chips-docked #chipsDock .chips{
    padding-left: clamp(72px, 18vw, 120px);
  }
}

/* Extra breathing room after the "Най-популярни" card grid */
.featured-grid{
  margin-bottom: clamp(2.2rem, 3vw, 3.25rem);
}

/* === Mobile: gently zoom + recenter the interior photo so it covers the whole top === */
@media (max-width: 640px){
  .hero-interior{
    left: 50%;
    top: 6%;                         /* a touch higher so more image shows */
    width: 130vw;                    /* wider canvas to avoid side gaps */
    max-width: none;
    transform: translateX(-50%) scale(1.12);  /* <— the zoom */
    transform-origin: 50% 18%;       /* anchor the zoom near the top */
    opacity: .22;                    /* keep current mood */
    /* keep your vertical fade but push it lower so zoom still blends nicely */
    -webkit-mask-image: linear-gradient(180deg,
      rgba(0,0,0,1) 0%,
      rgba(0,0,0,1) 70%,
      rgba(0,0,0,.55) 86%,
      rgba(0,0,0,0) 100%);
            mask-image: linear-gradient(180deg,
      rgba(0,0,0,1) 0%,
      rgba(0,0,0,1) 70%,
      rgba(0,0,0,.55) 86%,
      rgba(0,0,0,0) 100%);
  }
}

@media (max-width: 480px) {
  .chips { gap: 1rem; }  /* tighter only on phones */
}


/* ===== Gigs (Участия) — collapsible panel ===== */
.gigs{
  margin-top: 0.9rem;
}
.gigs-inner{
  border-radius: 18px;
  padding: 14px 14px 12px;
}
.gigs-grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
@media (min-width:640px){
  .gigs-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); gap: 14px; }
}
@media (min-width:1024px){
  .gigs-grid{ grid-template-columns: repeat(3, minmax(0,1fr)); gap: 16px; }
}

.gig{
  display: grid;
  grid-template-rows: auto auto auto;
  gap: 8px;
  border-radius: 14px;
  padding: 10px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(201,160,79,.18);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.45),
    0 14px 30px rgba(28,27,25,.08),
    0 0 0 2px rgba(201,160,79,.05);
}

.gig-name{
  font-family:"Playfair Display",serif;
  font-weight:900;
  font-size: clamp(1.05rem, .95rem + .3vw, 1.2rem);
  line-height: 1.2;
  letter-spacing:-.01em;
}

.gig-meta{
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-weight:700;
  color: var(--forest);
  font-size: .98rem;
}

/* subtle divider when panel opens below hero */
.gigs .gigs-inner::before{
  content:"";
  display:block;
  height:2px;
  width:120px;
  margin: 4px auto 12px;
  border-radius:999px;
  background: linear-gradient(90deg,var(--gold),var(--gold-2));
  opacity:.7;
}

/* helper: hide/show with class to avoid layout jumps */
.hidden[hidden]{ display:none !important; }

/* Make gig images 1:1 aspect ratio */
.gig img {
  width: 100%;
  height: auto;             /* ensure no leftover fixed height */
  aspect-ratio: 4 / 3;   
  object-fit: cover;     /* crop & fill, keeps center focus */
  border-radius: 0.5rem; /* optional, matches other rounded styles */
}

.gig{ display:flex; flex-direction:column; }
.gig .gig-meta{ margin-top:auto; }

/* MOBILE: clear visual break before the second location */
@media (max-width: 1023px) {
  /* Case A: both locations are inside .footer-left as siblings */
  .footer-left .footer-col + .footer-col,
  /* Case B: locations are separate grid items; the second is the last .footer-col */
  .footer-grid > .footer-col:last-child {
    border-top: 1px solid rgba(0,0,0,.16);
    margin-top: 1.75rem;
    padding-top: 1.75rem;
  }
}

/* Mobile: when the section chips are docked in the header,
   hide the logo block and center the links so everything fits. */
@media (max-width: 1023px) {
  /* Hide the left logo chunk only while the chips are in the header */
  body.chips-docked #site-header .glass .flex > div:first-child {
    display: none;
  }

  /* Make sure the chips are centered inside the header nav area */
  body.chips-docked #site-header #chipsDock {
    justify-content: center !important;
  }
}

/* Mobile: center the docked chips in the header bar (logo hidden) */
@media (max-width: 1023px) {
  body.chips-docked #chipsDock {
    display: flex;              /* ensure it's flex on all devices */
    justify-content: center;    /* center the rail in the header */
  }
  body.chips-docked #chipsDock .chips {
    padding-left: 0 !important; /* override the earlier “logo offset” */
    margin-left: auto;          /* center the chips block */
    margin-right: auto;
    justify-content: center;
  }
}

/* ===== Location cards (grouped actions) ===== */
.loc-card { display: flex; flex-direction: column; }
.loc-head .title-font { font-size: clamp(1.2rem, 1.05rem + .6vw, 1.5rem); }
.loc-sub a { text-decoration: none; }
.loc-sub a:hover { text-decoration: underline; }

/* Segmented control (two joined buttons) */
.loc-seg {
  display: inline-flex;
  border-radius: 12px;
  border: 1px solid rgba(201,160,79,.28);
  background: linear-gradient(180deg, rgba(250,247,242,.75), rgba(250,247,242,.45));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.45);
  overflow: hidden;
}
.loc-seg .seg-btn{
  appearance:none; border:0; background:transparent; cursor:pointer;
  padding:.5rem .9rem; font-weight:800; font-size:.95rem; color:var(--forest);
  transition: background .15s ease, color .15s ease;
}
.loc-seg .seg-btn + .seg-btn{ border-left:1px solid rgba(201,160,79,.22); }
.loc-seg .seg-btn.is-active{
  background: linear-gradient(180deg, rgba(255,255,255,.9), rgba(250,247,242,.7));
  color:#8A6A2E;
  box-shadow: inset 0 -2px 0 var(--gold);
}

/* About pane layout */
.about-grid{
  display:grid; gap:10px; grid-template-columns: 1fr 1fr;
}
.about-grid img{
  width:100%; height:auto; border-radius:12px; object-fit:cover; aspect-ratio: 4/3;
  border:1px solid rgba(201,160,79,.18);
  box-shadow: 0 8px 20px rgba(28,27,25,.06);
}
.about-copy{
  margin-top:.6rem; color:#6b7280; font-size:.98rem; line-height:1.5;
}

@media (max-width: 640px){
  .about-grid{ grid-template-columns: 1fr; }
}

/* Optional: subtle divider line atop content, matching gigs panel vibe */
.loc-content::before{
  content:""; display:block; height:2px; width:120px; margin: 4px auto 12px;
  border-radius:999px; background: linear-gradient(90deg,var(--gold),var(--gold-2)); opacity:.7;
}

/* Mobile accordion spacing between the two cards */
@media (max-width:1023px){
  .loc-cards { gap: 16px; }
}

/* Separate action buttons per location card */
.loc-actions{
  display:flex;
  gap:.5rem;
  flex-wrap:wrap;
  justify-content:center;   /* center them */
}
}
.loc-actions .btn-glass{
  padding:.55rem .9rem;   /* a hair smaller than hero buttons */
}

@media (min-width: 768px) {
  .loc-cards {
    grid-template-columns: 1fr !important; /* override md:grid-cols-2 */
    max-width: 64rem;                       /* nice readable width */
    margin-left: auto;
    margin-right: auto;
  }
}

.loc-card .loc-content { margin-top: .6rem; }

/* Language switcher: bigger, classier */
.lang-switch {
  font: 800 12px/1 Inter, system-ui, sans-serif;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 8px 12px;
  border-radius: 9999px;
  color: #5B3B00;
  background: linear-gradient(180deg,#FFE9B7,#FBD88E);
  border: 1px solid #E9C77A;
  box-shadow: 0 8px 18px rgba(0,0,0,.06), inset 0 1px 0 rgba(255,255,255,.55);
}
.lang-switch .lang-btn{
  background: transparent;
  border: 0;
  padding: 0;
  margin: 0;
  font: inherit;
  color: inherit;
  cursor: pointer;
}
.lang-switch .lang-btn.is-active { color: #7A5A1C; }
.lang-switch span { margin: 0 .4rem; opacity: .6; }

/* Scale up on bigger screens */
@media (min-width: 900px){
  .lang-switch { font-size: 13.5px; padding: 9px 14px; }
}