/* Global */

:root {
  --cl-accent: #f15a24;
  --cl-gray: #e5e5e5;
  --cl-dark: #222222;
  --cl-body: #555555;
  --cl-bg: #ffffff;
  --cl-footer-bg: #111111;
}

html, body {
  height: 100%;
}

body {
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--cl-body);
  background-color: var(--cl-bg);
}

/* Typography helpers */

.tracking-wide {
  letter-spacing: 0.12em;
  font-size: 0.9rem;
  text-transform: uppercase;
}

/* Navbar */

.site-header .navbar-brand {
  font-size: 1rem;
}

.site-header .nav-link {
  font-size: 0.9rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

/* Hero */

.hero {
  min-height: 70vh;
  background-color: var(--cl-gray);
  padding-top: 6rem;
  padding-bottom: 6rem;
}

.hero h1 {
  letter-spacing: 0.04em;
}

/* Featured workshop */

.hero-image img {
  object-fit: cover;
}

/* Accent button */

.btn-accent {
  background-color: var(--cl-accent);
  border-color: var(--cl-accent);
  color: #ffffff;
}

.btn-accent:hover,
.btn-accent:focus {
  background-color: #d64f20;
  border-color: #d64f20;
  color: #ffffff;
}

/* Newsletter */

.newsletter {
  background-color: #fafafa;
}

.newsletter-form .form-control {
  border-radius: 999px;
  padding-inline: 1.25rem;
}

/* Location / map */

.location-strip {
  background-color: var(--cl-gray);
}

.location-strip .location-card {
  background-color: #ffffff;
}

/* Map placeholder */

.map-placeholder img {
  display: block;
  max-height: 360px;
  object-fit: cover;
}

/* Footer */

.site-footer {
  background-color: var(--cl-footer-bg);
  color: #ffffff;
}

.site-footer .footer-link {
  color: #f1f1f1;
  text-decoration: none;
}

.site-footer .footer-link:hover {
  color: var(--cl-accent);
}

/* Back-to-top */

.back-to-top {
  position: fixed;
  right: 1.5rem;
  bottom: 1.5rem;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  padding: 0;
  font-size: 1.4rem;
  line-height: 1;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.25s ease, visibility 0.25s ease, transform 0.25s ease;
  transform: translateY(8px);
  z-index: 1040;
}

.back-to-top.show {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

/* Responsive tweaks */

@media (max-width: 767.98px) {
  .hero {
    min-height: 60vh;
    padding-top: 5rem;
    padding-bottom: 4rem;
  }
}
/* ====== Base (совместно с главной) ====== */
:root {
  --cl-accent: #f15a24;
  --cl-gray: #e5e5e5;
  --cl-dark: #222;
  --cl-body: #555;
  --cl-footer-bg: #111;
}

body { font-family: system-ui, -apple-system, "Segoe UI", sans-serif; color: var(--cl-body); }

.btn-accent { background-color: var(--cl-accent); border-color: var(--cl-accent); color:#fff; }
.btn-accent:hover { background-color:#d64f20; border-color:#d64f20; color:#fff; }

.footer-link { color:#f1f1f1; text-decoration:none; }
.footer-link:hover { color:var(--cl-accent); }

/* ====== Post ====== */
.post-title { letter-spacing: .02em; }
.post-meta { letter-spacing: .02em; }

.gallery-grid img { display:block; width:100%; height:100%; object-fit:cover; }

.widget { background:#fff; }
.widget .h6 { letter-spacing: .08em; }

/* ====== Footer ====== */
.site-footer { background: var(--cl-footer-bg); }

/* ====== Back to top ====== */
.back-to-top {
  position: fixed; right: 1rem; bottom: 1rem;
  width: 44px; height: 44px; border-radius: 50%;
  padding: 0; font-size: 1.4rem; line-height: 1;
  opacity: 0; visibility: hidden; transform: translateY(8px);
  transition: opacity .25s ease, visibility .25s ease, transform .25s ease;
  z-index: 1040;
}
.back-to-top.show { opacity:1; visibility:visible; transform: translateY(0); }

/* ====== Responsive ====== */
@media (max-width: 767.98px){
  .post-title { font-size: 1.625rem; }
}
.footer-social i.bi {
  font-size: 1.2rem;
  vertical-align: middle;
}
