/* ============ BRANCH PAGE (moscow.html / chelny.html) ============ */
:root {
  --gold: #B8945F; --gold-deep: #8B6F2C; --gold-light: #D9BD83;
  --ink: #1A1A1A; --ink-warm: #2B241B; --gray: #5A5046;
  --ivory: #FAF7F0; --cream: #F1EADB; --line: #E5DDC9;
  --tg: #229ED9;
}
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 140px; -webkit-text-size-adjust: 100%; }
body {
  font-family: 'Inter', sans-serif; font-size: 18px; line-height: 1.6;
  color: var(--ink); background: var(--ivory); -webkit-font-smoothing: antialiased;
}
h1, h2, h3, h4 {
  font-family: 'Fraunces', Georgia, serif;
  font-weight: 600; line-height: 1.1; letter-spacing: -0.015em;
}
img { display: block; max-width: 100%; }
.bcontainer { max-width: 1100px; margin: 0 auto; padding: 0 24px; }

/* NAV */
.bnav { padding: 16px 0; border-bottom: 1px solid var(--line); background: var(--ivory); position: sticky; top: 0; z-index: 100; }
.bnav-inner { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.bnav-logo { font-family: 'Fraunces', serif; font-weight: 600; font-size: 22px; color: var(--ink); text-decoration: none; }
.bnav-logo span { color: var(--gold-deep); }
.bnav-back { font-size: 14px; color: var(--gray); text-decoration: none; border-bottom: 1px solid transparent; }
.bnav-back:hover { color: var(--ink); border-bottom-color: var(--gold); }
.bnav-cta {
  background: var(--ink); color: var(--gold-light); padding: 10px 22px;
  border-radius: 999px; text-decoration: none; font-size: 14px;
  font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em;
}
.bnav-cta:hover { background: var(--gold-deep); color: #fff; }

/* HERO + DECORATIVE WORDMARK (в стиле premium-журналов) */
.bhero { padding: 80px 0 64px; position: relative; overflow: hidden; }
.bhero-wordmark {
  position: absolute; right: -2vw; bottom: -0.15em; pointer-events: none;
  font-family: 'Fraunces', Georgia, serif;
  font-weight: 400; font-style: italic;
  font-size: clamp(120px, 16vw, 260px); line-height: 1;
  color: var(--gold-deep); opacity: 0.07;
  letter-spacing: -0.04em;
  white-space: nowrap;
  user-select: none;
}
.bhero .bcontainer { position: relative; z-index: 1; }
@media (max-width: 768px) {
  .bhero-wordmark { font-size: clamp(96px, 22vw, 160px); opacity: 0.06; right: -4vw; }
}
.bhero-eyebrow { font-size: 13px; font-weight: 600; color: var(--gold-deep); text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 20px; }
.bhero-h1 { font-size: clamp(36px, 5vw, 60px); margin-bottom: 24px; max-width: 880px; }
.bhero-h1 em { font-style: italic; color: var(--gold-deep); }
.bhero-sub { font-size: 20px; color: var(--gray); max-width: 680px; margin-bottom: 36px; }
.bhero-cta-row { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 14px; }
.bhero-cta-note { font-size: 14px; color: var(--gray); }

/* BUTTONS */
.bbtn {
  display: inline-flex; align-items: center; justify-content: center;
  min-height: 56px; padding: 18px 36px; border-radius: 999px;
  text-decoration: none; font-weight: 600; font-size: 16px;
  letter-spacing: 0.02em; transition: all 0.2s ease;
}
.bbtn-primary {
  background: linear-gradient(135deg, var(--gold-light) 0%, var(--gold) 60%, var(--gold-deep) 100%);
  color: var(--ink);
  box-shadow: 0 8px 24px rgba(184,148,95,0.32), 0 2px 6px rgba(0,0,0,0.06);
}
.bbtn-primary:hover { transform: translateY(-1px); box-shadow: 0 12px 32px rgba(184,148,95,0.4); }
.bbtn-tg { background: var(--tg); color: #fff; }
.bbtn-tg:hover { background: #1a8ec3; }

/* UPCOMING */
.bupcoming { padding: 48px 0; background: var(--cream); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.bupcoming-head { display: flex; align-items: baseline; justify-content: space-between; gap: 24px; flex-wrap: wrap; margin-bottom: 28px; }
.bupcoming-head h2 { font-size: 32px; }
.bupcoming-tg { font-size: 14px; color: var(--gold-deep); text-decoration: none; border-bottom: 1px solid var(--gold); padding-bottom: 2px; }
.bupcoming-tg:hover { color: var(--ink); border-bottom-color: var(--ink); }
.bupcoming-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 16px; }
.bupcoming-card { background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 24px; display: flex; flex-direction: column; gap: 6px; }
.bupcoming-date { font-family: 'Fraunces', serif; font-weight: 600; font-size: 28px; color: var(--ink); }
.bupcoming-note { font-size: 15px; color: var(--gray); }
.bupcoming-empty { color: var(--gray); font-size: 16px; padding: 24px 28px; background: #fff; border: 1px dashed var(--line); border-radius: 14px; }
.bupcoming-empty a { color: var(--gold-deep); border-bottom: 1px solid var(--gold); }

/* INFO */
.binfo { padding: 72px 0; }
.binfo-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start; }
.binfo h2 { font-size: 32px; margin-bottom: 20px; }
.binfo p, .binfo li { font-size: 17px; line-height: 1.65; color: var(--ink-warm); }
.binfo ul { list-style: none; padding: 0; }
.binfo ul li { padding: 8px 0 8px 28px; position: relative; }
.blist-do li::before { content: ""; position: absolute; left: 0; top: 14px; width: 16px; height: 16px; border-radius: 50%; background: var(--gold); }
.blist-no li { color: var(--gray); }
.blist-no li::before { content: "—"; position: absolute; left: 0; top: 8px; color: var(--line); font-size: 18px; }
.binfo-address { background: var(--cream); padding: 24px 28px; border-radius: 14px; margin-top: 24px; font-size: 16px; line-height: 1.55; }
.binfo-address strong { color: var(--ink); }
.binfo-link-row { margin-top: 16px; color: var(--gray); font-size: 15px; }
.binfo-link-row a { color: var(--gold-deep); border-bottom: 1px solid var(--gold); text-decoration: none; }

/* REVIEWS */
.breviews { padding: 72px 0; background: #fff; border-top: 1px solid var(--line); }
.breviews-head { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; flex-wrap: wrap; margin-bottom: 32px; }
.breviews-head h2 { font-size: 32px; }
.breviews-rating { font-size: 16px; color: var(--gray); }
.breviews-rating strong { color: var(--ink); font-weight: 600; }
.breviews-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 18px; }
.breview-card { background: var(--ivory); border: 1px solid var(--line); border-radius: 16px; padding: 26px 24px; display: flex; flex-direction: column; gap: 12px; }
.breview-stars { color: var(--gold); font-size: 14px; letter-spacing: 2px; }
.breview-text { font-size: 15px; line-height: 1.6; color: var(--ink-warm); display: -webkit-box; -webkit-line-clamp: 7; -webkit-box-orient: vertical; overflow: hidden; }
.breview-meta { font-size: 13px; color: var(--gray); margin-top: auto; padding-top: 8px; border-top: 1px solid var(--line); }
.breview-meta strong { color: var(--ink); font-weight: 600; }
.breview-source { display: inline-block; margin-left: 8px; padding: 2px 8px; background: #fff; border: 1px solid var(--line); border-radius: 999px; font-size: 11px; text-transform: uppercase; letter-spacing: 0.05em; color: var(--gold-deep); }
.breviews-all { margin-top: 28px; display: flex; align-items: center; justify-content: flex-end; flex-wrap: wrap; gap: 8px 12px; font-size: 14px; color: var(--gray); }
.breviews-all a { color: var(--gold-deep); border-bottom: 1px solid var(--gold); text-decoration: none; padding-bottom: 1px; transition: all 0.2s; }
.breviews-all a:hover { color: var(--ink); border-bottom-color: var(--ink); }
.breviews-all-main { font-weight: 600; font-size: 15px; }
.breviews-all-sep { color: var(--gray); font-style: italic; margin-left: 8px; }
.breviews-all-dot { color: var(--line); }
@media (max-width: 600px) { .breviews-all { justify-content: flex-start; } .breviews-all-sep { margin-left: 0; width: 100%; } }

/* PROMOS */
.bpromos { padding: 72px 0; background: var(--ivory); border-top: 1px solid var(--line); }
.bpromos h2 { font-size: 32px; margin-bottom: 20px; }
.bpromo-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 16px; }
.bpromo-card { background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 24px; display: flex; flex-direction: column; gap: 8px; }
.bpromo-card-badge { display: inline-block; padding: 4px 10px; background: var(--gold); color: #fff; font-size: 12px; font-weight: 600; border-radius: 999px; align-self: flex-start; text-transform: uppercase; letter-spacing: 0.05em; }
.bpromo-card h3 { font-size: 22px; }
.bpromo-card .bprice { display: flex; gap: 10px; align-items: baseline; margin-top: 4px; }
.bprice-new { font-family: 'Fraunces', serif; font-weight: 600; font-size: 28px; color: var(--ink); }
.bprice-old { font-size: 16px; color: var(--gray); text-decoration: line-through; }
.bpromos { background: linear-gradient(180deg, var(--ivory) 0%, var(--cream) 100%); }
.bpromos-head { margin-bottom: 32px; }
.bpromos-sub { font-size: 17px; color: var(--gray); max-width: 640px; margin-top: 8px; }
.bpromo-empty { padding: 40px 32px; background: #fff; border: 1px solid var(--line); border-radius: 18px; color: var(--ink-warm); text-align: center; }
.bpromo-empty-icon { font-family: 'Fraunces', serif; font-size: 56px; color: var(--gold); line-height: 1; margin-bottom: 8px; }
.bpromo-empty h3 { font-family: 'Fraunces', serif; font-size: 24px; font-weight: 600; margin-bottom: 8px; color: var(--ink); }
.bpromo-empty p { font-size: 16px; color: var(--gray); margin-bottom: 18px; max-width: 480px; margin-left: auto; margin-right: auto; }
.bpromo-empty a { color: var(--gold-deep); border-bottom: 1px solid var(--gold); text-decoration: none; }

/* SUBSCRIBE */
.bsubscribe { padding: 88px 0; background: linear-gradient(180deg, var(--cream) 0%, #fff 100%); border-top: 1px solid var(--line); }
.bsubscribe-box { max-width: 720px; margin: 0 auto; text-align: center; }
.bsubscribe h2 { font-size: 36px; margin-bottom: 16px; }
.bsubscribe-lead { font-size: 18px; color: var(--gray); margin-bottom: 32px; }
.bsubscribe-cta {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 20px 40px; background: var(--tg); color: #fff;
  border-radius: 999px; text-decoration: none; font-size: 18px;
  font-weight: 600; box-shadow: 0 12px 32px rgba(34,158,217,0.32); transition: all 0.2s;
}
.bsubscribe-cta:hover { transform: translateY(-1px); box-shadow: 0 16px 40px rgba(34,158,217,0.4); }
.bsubscribe-cta svg { width: 24px; height: 24px; }
.bsubscribe-handle { display: block; margin-top: 16px; font-size: 14px; color: var(--gray); }
.bsubscribe-alt { margin-top: 36px; font-size: 15px; color: var(--gray); }
.bsubscribe-alt a { color: var(--gold-deep); border-bottom: 1px solid var(--gold); text-decoration: none; padding-bottom: 1px; }
.bsubscribe-alt a:hover { color: var(--ink); }

/* FOOTER */
.bfooter { background: var(--ink-warm); color: rgba(255,255,255,0.7); padding: 48px 0 32px; }
.bfooter a { color: var(--gold-light); text-decoration: none; }
.bfooter a:hover { color: #fff; }
.bfooter-inner { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 20px; font-size: 14px; }

/* FOOTER LICENSE (унифицировано с index/catalog/promo) */
.footer-license {
  border-top: 1px solid rgba(255,255,255,0.1);
  margin-bottom: 24px;
  padding: 24px 0;
  display: flex;
  align-items: flex-start;
  gap: 16px;
  color: rgba(255,255,255,0.78);
}
.footer-license-icon { flex-shrink: 0; width: 28px; height: 28px; color: var(--gold-light); }
.footer-license-text { font-size: 14px; line-height: 1.55; }
.footer-license-text strong { color: #FFFFFF; font-weight: 600; }

/* STICKY MOBILE CTA (унифицировано с index.html) */
.mobile-cta {
  display: none;
  position: fixed;
  left: 10px; right: 10px;
  bottom: calc(8px + env(safe-area-inset-bottom, 0px));
  z-index: 95;
  flex-direction: column; gap: 6px;
  background: rgba(255,255,255,0.96);
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  border: 1px solid var(--line);
  border-radius: 18px; padding: 8px;
  box-shadow: 0 18px 40px rgba(0,0,0,0.18);
}
.mcta-main {
  display: flex; align-items: center; justify-content: center;
  min-height: 56px;
  background: linear-gradient(135deg, #2b2519, #1a1612);
  color: #d9bd83;
  border-radius: 12px;
  font-weight: 600; letter-spacing: 0.05em;
  text-transform: uppercase; font-size: 14px;
  text-decoration: none; transition: transform 0.2s;
}
.mcta-main:active { transform: scale(0.98); }
.mcta-row { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; }
.mcta-mini {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 4px; min-height: 56px; padding: 8px 6px;
  border-radius: 12px; background: #f6f0e6; color: #1c1b17;
  font-size: 14px; font-weight: 600; letter-spacing: 0.02em;
  text-decoration: none; transition: transform 0.2s, background 0.2s;
}
.mcta-mini:active { transform: scale(0.95); background: #efe5cf; }
.mcta-mini img { width: 22px; height: 22px; border-radius: 4px; }

@media (max-width: 900px) {
  .mobile-cta { display: flex; }
  body { padding-bottom: calc(140px + env(safe-area-inset-bottom, 0px)); }
}
@media (min-width: 901px) {
  .mobile-cta { display: none !important; }
}
@media (max-width: 600px) {
  .footer-license { flex-direction: column; align-items: center; text-align: center; gap: 12px; }
}

@media (max-width: 768px) {
  .binfo-grid { grid-template-columns: 1fr; gap: 32px; }
}
@media (max-width: 600px) {
  .bhero { padding: 56px 0 40px; }
  .bupcoming, .bpromos, .binfo, .bsubscribe { padding: 56px 0; }
  .bsubscribe h2 { font-size: 28px; }
}
