/**
 * Locations page styling (public marketing).
 * Scope: only `.gsts-locations-page` wrapper and its descendants.
 * Tokens align with `gsts-marketing-design-system.css` so the page matches
 * the rest of the brochure shell (About / FAQ / Kontakt).
 */

body.gsts-marketing-shell .gsts-locations-page {
  --gsts-loc-bg-card: var(--gsts-mkt-bg-card, #fffefb);
  --gsts-loc-bg-muted: var(--gsts-mkt-bg-muted, #f4ece4);
  --gsts-loc-border: var(--gsts-mkt-border, rgba(20, 31, 51, 0.10));
  --gsts-loc-radius: var(--gsts-mkt-radius, 16px);
  --gsts-loc-radius-sm: var(--gsts-mkt-radius-sm, 12px);
  --gsts-loc-shadow: var(--gsts-mkt-shadow, 0 14px 42px rgba(20, 31, 51, 0.08), 0 4px 12px rgba(20, 31, 51, 0.04));
  --gsts-loc-navy: var(--gsts-mkt-navy, #141f33);
  --gsts-loc-navy-soft: var(--gsts-mkt-navy-soft, #2a3548);
  --gsts-loc-muted: var(--gsts-mkt-muted, #5c6578);
  --gsts-loc-orange: var(--gsts-mkt-orange, #c67a1c);
  --gsts-loc-orange-deep: var(--gsts-mkt-orange-deep, #a45f0f);
  --gsts-loc-success: #2f7d3a;
}

body.gsts-marketing-shell .gsts-locations-page__title {
  font-weight: 800;
  letter-spacing: -0.022em;
  color: var(--gsts-loc-navy);
  font-size: clamp(1.6rem, 2.2vw, 2.05rem);
  margin-block-end: 1.25rem;
}

body.gsts-marketing-shell .gsts-locations-page__row {
  --bs-gutter-x: clamp(1.1rem, 2.6vw, 1.75rem);
  --bs-gutter-y: 1.2rem;
  align-items: flex-start;
}

@media (min-width: 992px) {
  body.gsts-marketing-shell .gsts-locations-page__sidebar {
    position: sticky;
    top: calc(var(--gsts-mkt-header-content-max, 0px) * 0 + 96px);
  }
}

body.gsts-marketing-shell .gsts-locations-panel {
  background: linear-gradient(165deg, var(--gsts-loc-bg-card) 0%, var(--gsts-loc-bg-muted) 100%);
  border: 1px solid var(--gsts-loc-border);
  border-radius: var(--gsts-loc-radius-sm);
  padding: 1rem 1.1rem;
  margin-bottom: 0.85rem;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
}

body.gsts-marketing-shell .gsts-locations-panel:last-child {
  margin-bottom: 0;
}

body.gsts-marketing-shell .gsts-locations-current h5 {
  font-size: 0.98rem;
  color: var(--gsts-loc-navy);
}

body.gsts-marketing-shell .gsts-locations-change {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--gsts-loc-orange-deep);
  text-decoration: none;
  border-bottom: 1px solid rgba(198, 122, 28, 0.35);
  cursor: pointer;
  white-space: nowrap;
}

body.gsts-marketing-shell .gsts-locations-change:hover,
body.gsts-marketing-shell .gsts-locations-change:focus-visible {
  color: #8d5610;
  border-bottom-color: rgba(198, 122, 28, 0.7);
}

body.gsts-marketing-shell .gsts-locations-page .accordion-button {
  font-size: 0.92rem;
  letter-spacing: 0.012em;
  color: var(--gsts-loc-navy);
}

body.gsts-marketing-shell .gsts-locations-page .form-check {
  padding-block: 0.35rem;
}

body.gsts-marketing-shell .gsts-locations-page .form-check-label {
  font-size: 0.92rem;
  color: var(--gsts-loc-navy-soft);
  cursor: pointer;
}

body.gsts-marketing-shell .gsts-locations-page .form-check-input:checked {
  background-color: var(--gsts-loc-orange);
  border-color: var(--gsts-loc-orange-deep);
}

body.gsts-marketing-shell .gsts-locations-page .form-check-input:focus {
  border-color: rgba(198, 122, 28, 0.55);
  box-shadow: 0 0 0 0.18rem rgba(198, 122, 28, 0.22);
}

body.gsts-marketing-shell .gsts-locations-search.input-group {
  background: var(--gsts-loc-bg-card);
  border: 1px solid var(--gsts-loc-border);
  border-radius: 999px;
  padding: 0.18rem 0.18rem 0.18rem 1.1rem;
  align-items: center;
  box-shadow: 0 6px 18px rgba(20, 31, 51, 0.06);
}

body.gsts-marketing-shell .gsts-locations-search.input-group .form-control {
  background: transparent;
  border: 0;
  box-shadow: none;
  font-size: 0.97rem;
  min-height: 44px;
  padding-block: 0;
}

body.gsts-marketing-shell .gsts-locations-search.input-group .form-control:focus {
  box-shadow: none;
}

body.gsts-marketing-shell .gsts-locations-search__btn {
  border: 0;
  border-radius: 999px;
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  background: var(--gsts-mkt-gradient-cta, linear-gradient(135deg, #dc8b22 0%, #c97416 52%, #b8660f 100%));
  box-shadow: 0 4px 12px rgba(184, 108, 28, 0.22);
}

body.gsts-marketing-shell .gsts-locations-search__btn:hover,
body.gsts-marketing-shell .gsts-locations-search__btn:focus-visible {
  background: var(--gsts-mkt-gradient-cta-hover, linear-gradient(135deg, #e3982e 0%, #d3821a 52%, #c46f12 100%));
  color: #fff;
}

body.gsts-marketing-shell .gsts-locations-results {
  display: flex;
  flex-direction: column;
  gap: 0.95rem;
}

body.gsts-marketing-shell .gsts-locations-results > .gsts-location-card {
  margin-bottom: 0;
}

body.gsts-marketing-shell .gsts-location-card {
  display: block;
  background: var(--gsts-loc-bg-card);
  border: 1px solid var(--gsts-loc-border);
  border-radius: var(--gsts-loc-radius);
  padding: 1.1rem 1.2rem;
  color: var(--gsts-loc-navy);
  text-decoration: none;
  transition: border-color 0.16s ease, box-shadow 0.16s ease, transform 0.16s ease;
  box-shadow: 0 4px 14px rgba(20, 31, 51, 0.05);
}

body.gsts-marketing-shell .gsts-location-card:hover,
body.gsts-marketing-shell .gsts-location-card:focus-visible {
  border-color: rgba(198, 122, 28, 0.35);
  box-shadow: 0 12px 28px rgba(20, 31, 51, 0.10), 0 2px 6px rgba(184, 108, 28, 0.08);
  transform: translateY(-1px);
  color: var(--gsts-loc-navy);
}

body.gsts-marketing-shell .gsts-location-card .boxes {
  gap: 1.15rem;
  align-items: center;
}

body.gsts-marketing-shell .gsts-location-card__thumb {
  flex: 0 0 auto;
}

body.gsts-marketing-shell .gsts-location-card__media-img {
  display: block;
  width: 96px;
  height: 80px;
  max-width: 96px;
  max-height: 80px;
  object-fit: cover;
  border-radius: var(--gsts-loc-radius-sm);
  background: var(--gsts-loc-bg-muted);
  border: 1px solid var(--gsts-loc-border);
}

body.gsts-marketing-shell .gsts-location-card__title {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--gsts-loc-navy);
  letter-spacing: -0.01em;
}

body.gsts-marketing-shell .gsts-location-card__meta {
  color: var(--gsts-loc-muted);
  font-size: 0.82rem;
}

body.gsts-marketing-shell .gsts-location-card__address {
  color: var(--gsts-loc-navy-soft);
  font-size: 0.9rem;
  line-height: 1.5;
}

body.gsts-marketing-shell .gsts-location-card__aside {
  border-inline-start: 1px solid var(--gsts-loc-border);
  padding-inline-start: 1rem;
}

@media (max-width: 767.98px) {
  body.gsts-marketing-shell .gsts-location-card__aside {
    border-inline-start: 0;
    padding-inline-start: 0;
    border-block-start: 1px solid var(--gsts-loc-border);
    padding-block-start: 0.85rem;
    margin-block-start: 0.6rem;
  }
}

body.gsts-marketing-shell .gsts-location-card__status {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--gsts-loc-muted);
}

body.gsts-marketing-shell .gsts-location-card__status--open {
  display: inline-flex;
  align-items: center;
  padding: 0.18rem 0.55rem;
  border-radius: 999px;
  background: rgba(47, 125, 58, 0.12);
  color: var(--gsts-loc-success);
  font-weight: 700;
  font-size: 0.78rem;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

body.gsts-marketing-shell .gsts-location-card__services {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  font-size: 0.84rem;
  color: var(--gsts-loc-navy-soft);
}

body.gsts-marketing-shell .gsts-location-card__services > div {
  line-height: 1.4;
}

body.gsts-marketing-shell .gsts-locations-page .pagination-bar {
  margin-top: 1.4rem;
}

body.gsts-marketing-shell .gsts-locations-page .panel.panel-local {
  background: var(--gsts-loc-bg-card);
  border: 1px solid var(--gsts-loc-border);
  border-radius: var(--gsts-loc-radius-sm);
  padding: 1.5rem;
  text-align: center;
  color: var(--gsts-loc-muted);
}
