* { box-sizing: border-box; }
body { margin: 0; font-family: Arial, sans-serif; color: #222; background: #f7f7f7; }
a { color: inherit; text-decoration: none; }
.container { width: min(1180px, 92%); margin: 0 auto; }
.muted { color: #666; font-size: 12px; }
.mt-12 { margin-top: 12px; }

.topbar { background: #ddd; font-size: 13px; }
.topbar__inner { display: flex; gap: 12px; padding: 8px 0; align-items: center; }

.header { background: #fff; border-bottom: 1px solid #ddd; position: sticky; top: 0; z-index: 2; }
.header__inner { display: grid; grid-template-columns: 220px 160px 1fr 140px; gap: 16px; align-items: center; padding: 14px 0; }
.logo { font-weight: 700; font-size: 14px; }
.search input { width: 100%; padding: 8px 10px; border: 1px solid #ccc; }
.nav { display: flex; gap: 14px; flex-wrap: wrap; font-size: 14px; }
.btn { display: inline-block; padding: 10px 14px; border: 1px solid #111; background: #fff; text-align: center; }
.btn-dark { background: #1e1e1e; color: #fff; }
.main { padding: 28px 0 60px; min-height: 60vh; }

h1 { font-family: Georgia, serif; font-size: 56px; margin: 0 0 18px; line-height: 1; }
h2 { font-family: Georgia, serif; font-size: 44px; margin: 36px 0 14px; }
h3 { margin: 0 0 10px; font-size: 21px; }
p { line-height: 1.5; }

.icon-btn { border: 1px solid #cfcfcf; background: #fff; width: 38px; height: 38px; display: grid; place-items: center; cursor: pointer; }
.icon-btn:active { transform: translateY(1px); }

.breadcrumb { color: #777; font-size: 13px; margin-bottom: 14px; }
.section { margin-top: 30px; }
.row { display: flex; gap: 24px; flex-wrap: wrap; }
.col { flex: 1; min-width: 280px; }
.placeholder { background: #e6e6e6; border: 1px solid #d4d4d4; min-height: 220px; }
.placeholder--sm { min-height: 120px; }
.placeholder--lg { min-height: 360px; }

.hero.section { margin-top: 8px; }
.slider { border: 1px solid #ddd; background: #fff; padding: 16px; }
.slider__viewport { overflow: hidden; }
.slider__track { display: flex; gap: 18px; }
.slide { min-width: 100%; display: grid; grid-template-columns: 1.15fr .85fr; gap: 18px; align-items: center; }
.slide__content { padding: 8px 6px; }
.slider__controls { display: flex; justify-content: flex-end; align-items: center; gap: 12px; margin-top: 12px; }
.dots { display: flex; gap: 8px; align-items: center; }
.dot { width: 8px; height: 8px; border-radius: 99px; background: #cfcfcf; display: inline-block; }
.dot.active { background: #222; }

.cards-2, .cards-3, .cards-4 { display: grid; gap: 16px; }
.cards-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.cards-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.cards-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }

.card { border: 1px solid #ddd; background: #fff; padding: 12px; }
.card h4 { margin: 8px 0 6px; font-size: 19px; font-family: Georgia, serif; }
.card .meta { color: #666; font-size: 12px; margin-bottom: 6px; }
.list { display: grid; gap: 10px; }
.list-item { border: 1px solid #ddd; padding: 10px; background: #fff; display: flex; justify-content: space-between; gap: 12px; }
.chip { display: inline-flex; border: 1px solid #ccc; padding: 5px 8px; font-size: 12px; margin-right: 6px; margin-bottom: 6px; background: #fff; }
.toolbar { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; margin-bottom: 16px; }
.toolbar select, .toolbar input { padding: 8px; border: 1px solid #ccc; background: #fff; }
.filters { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }

.calendar { display: flex; gap: 10px; align-items: center; flex: 1; min-width: 280px; }
.calendar__strip { display: grid; grid-auto-flow: column; grid-auto-columns: 54px; gap: 8px; overflow: hidden; }
.cal-day { border: 1px solid #ddd; background: #fff; padding: 6px 0; text-align: center; display: block; }
.cal-day__num { font-weight: 700; }
.cal-day__dow { font-size: 11px; color: #666; margin-top: 2px; }
.cal-day.active { background: #222; color: #fff; border-color: #222; }
.cal-day.active .cal-day__dow { color: #ddd; }

.pagination { display: flex; gap: 8px; margin-top: 20px; }
.page { border: 1px solid #ccc; width: 36px; height: 36px; display: grid; place-items: center; background: #fff; }
.page.active { background: #222; color: #fff; border-color: #222; }

.two-col { display: grid; gap: 26px; grid-template-columns: 1.1fr .9fr; }
.stats { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; margin: 20px 0; }
.stat { border: 1px solid #ddd; background: #fff; padding: 12px; }
.stat b { display: block; font-size: 30px; font-family: Georgia, serif; margin-bottom: 6px; }

.faq details { border-top: 1px solid #ddd; padding: 12px 0; }
.faq summary { cursor: pointer; font-weight: 600; }

.footer { background: #d7d7d7; margin-top: 60px; padding: 26px 0 14px; }
.footer__grid { display: grid; grid-template-columns: 1.1fr 1fr 1fr; gap: 24px; }
.footer h4 { margin: 0 0 10px; font-size: 16px; }
.footer a { display: block; margin-bottom: 8px; }
.logo-box { width: 120px; height: 84px; border: 1px solid #999; display: grid; place-items: center; background: #eee; }
.socials { display: flex; gap: 6px; margin-top: 8px; }
.socials span { width: 22px; height: 22px; background: #c1c1c1; display: inline-block; }
.promo { border: 1px solid #555; padding: 12px; background: #efefef; margin-top: 10px; }
.footer__bottom { border-top: 1px solid #bdbdbd; margin-top: 16px; padding-top: 12px; display: flex; justify-content: space-between; gap: 16px; font-size: 12px; }
.footer__bottom > div { display: flex; gap: 14px; flex-wrap: wrap; }

.sidebar-layout { display: grid; grid-template-columns: 280px 1fr; gap: 18px; }
.sidebar { background: #fff; border: 1px solid #ddd; padding: 12px; }
.sidebar h4 { margin: 10px 0; font-size: 16px; }
.check-list { display: grid; gap: 8px; font-size: 14px; }
.range { width: 100%; }

@media (max-width: 1024px) {
  .header__inner { grid-template-columns: 1fr; }
  .cards-4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .cards-3 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .two-col, .sidebar-layout { grid-template-columns: 1fr; }
  .slide { grid-template-columns: 1fr; }
  h1 { font-size: 44px; }
}

@media (max-width: 640px) {
  .cards-2, .cards-3, .cards-4 { grid-template-columns: 1fr; }
  .stats { grid-template-columns: 1fr; }
  h1 { font-size: 36px; }
}
