.htg-slider-block { position: relative; background: var(--htg-sand, #f5f1ea); overflow: hidden; }
.htg-slider { position: relative; width: 100%; }
.htg-slider__viewport { overflow: hidden; }
.htg-slider__track { display: flex; transition: transform .45s ease; will-change: transform; }
.htg-slider__slide { flex: 0 0 100%; min-width: 100%; position: relative; }
.htg-slider__media { width: 100%; height: auto; aspect-ratio: 1320 / 600; background: #ddd; }
.htg-slider__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.htg-slider__content { position: absolute; inset: 0; display: flex; align-items: center; padding: clamp(24px, 6vw, 88px) max(18px, calc((100vw - var(--htg-max, 1320px)) / 2)); color: #fff; background: linear-gradient(90deg, rgba(23,22,59,.78), rgba(23,22,59,.42) 46%, rgba(23,22,59,.08)); }
.htg-slider__box { max-width: 700px; }
.htg-slider__eyebrow { font-family: var(--htg-head-font); font-size: clamp(20px, 2.2vw, 32px); line-height: 1; color: #fff; text-transform: uppercase; margin: 0 0 .4em; }
.htg-slider__title { font-family: var(--htg-head-font); font-size: clamp(42px, 7vw, 104px); line-height: .92; margin: 0 0 .2em; color: #fff; }
.htg-slider__text { font-size: clamp(17px, 1.5vw, 21px); line-height: 1.55; max-width: 620px; margin: 0 0 1.4em; color: #fff; }
.htg-slider__button { display: inline-flex; padding: .85em 1.25em; background: var(--htg-orange); color: #fff; text-decoration: none; font-family: var(--htg-head-font); font-size: 22px; line-height: 1; text-transform: uppercase; border: 1px solid var(--htg-orange); }
.htg-slider__button:hover { background: #fff; color: var(--htg-blue); border-color: #fff; }
.htg-slider__controls { position: absolute; z-index: 4; right: max(18px, calc((100vw - var(--htg-max, 1320px)) / 2)); bottom: clamp(18px, 3vw, 34px); display: flex; gap: 10px; }
.htg-slider__control { width: 46px; height: 46px; border: 1px solid rgba(255,255,255,.65); background: rgba(23,22,59,.35); color: #fff; font-size: 28px; line-height: 1; cursor: pointer; }
.htg-slider__control:hover, .htg-slider__control:focus { background: var(--htg-orange); border-color: var(--htg-orange); }
.htg-slider__dots { position: absolute; left: max(18px, calc((100vw - var(--htg-max, 1320px)) / 2)); bottom: clamp(22px, 3vw, 40px); display: flex; gap: 9px; z-index: 4; }
.htg-slider__dot { width: 9px; height: 9px; border: 1px solid #fff; background: transparent; padding: 0; border-radius: 999px; cursor: pointer; }
.htg-slider__dot.is-active { background: #fff; }

@media (max-width: 760px) {
  .htg-slider__media { aspect-ratio: 4 / 5; }
  .htg-slider__content { position: relative; background: var(--htg-blue); padding: 32px 18px 72px; }
  .htg-slider__controls { right: 18px; bottom: 18px; }
  .htg-slider__dots { left: 18px; bottom: 36px; }
}
