/* components.css — yeniden kullanılabilir bileşenler.
   (Ürün kartı/grid bileşenleri 2. adımda eklenecek.) */

/* ============================ Butonlar ============================ */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  min-height: var(--tap-min); padding: var(--space-2) var(--space-4);
  font-family: var(--font-display); font-weight: var(--fw-medium); font-size: var(--fs-400);
  border-radius: var(--radius-pill); border: 1px solid transparent;
  text-align: center; transition: background-color .15s, color .15s, border-color .15s;
}
.btn:hover { text-decoration: none; }
.btn--primary { background: var(--color-primary); color: var(--color-on-primary); }
.btn--primary:hover { background: var(--color-primary-dark); }
.btn--outline { background: transparent; color: var(--color-text); border-color: var(--color-border); }
.btn--outline:hover { border-color: var(--color-primary); color: var(--color-primary-dark); }
.btn--block { width: 100%; }
/* Canlı site buton varyantları: banner üstü açık buton + koyu CTA */
.btn--light { background: rgba(255, 255, 255, .9); color: var(--color-text); }
.btn--light:hover { background: var(--color-primary); color: var(--color-on-primary); }
.btn--dark { background: var(--color-text); color: var(--color-on-primary); }
.btn--dark:hover { background: var(--color-primary); }

/* ============================ Kart ============================ */
.card { background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-4); }
@media (min-width: 768px) { .card { padding: var(--space-5); } }

/* ============================ Rozet ============================ */
.badge {
  display: inline-block; padding: var(--space-1) var(--space-2);
  font-size: var(--fs-300); font-weight: var(--fw-semibold); line-height: 1;
  border-radius: var(--radius-pill); background: var(--color-surface); color: var(--color-muted);
}
.badge--sale { background: var(--color-sale); color: var(--color-on-primary); }

/* ============================ Üst şerit (top bar) ============================ */
/* Canlı site: açık gri zemin (#F4F4F4), koyu metin. */
.topbar { background: var(--color-surface); color: var(--color-muted); font-size: 0.875rem; border-bottom: 1px solid var(--color-border); }
.topbar__inner { display: flex; align-items: center; gap: var(--space-3); min-height: 40px; }
.topbar__contact { display: inline-flex; align-items: center; gap: 6px; color: #777777; font-weight: var(--fw-semibold); flex: 0 0 auto; }
.topbar__contact i { font-size: 1.45em; line-height: 1; color: var(--color-primary); }
.topbar__contact:hover { color: var(--color-primary); text-decoration: none; }
.topbar__promo { margin: 0 auto; text-align: center; color: var(--color-muted); }
.topbar__promo a { color: var(--color-muted); }
.topbar__promo strong, .topbar__promo b { color: var(--color-text); font-weight: var(--fw-semibold); } /* "30% İndirim!!!" vurgusu */
/* Canlı site: İletişim mobilde gizli (elementor-hidden-mobile); yalnızca duyuru ortada kalır.
   Mobilde üst bar fontu biraz küçülür. */
@media (max-width: 767px) {
  .topbar__contact { display: none; }
  .topbar { font-size: 0.75rem; }              /* 14px → 12px */
  .topbar__promo strong, .topbar__promo b { font-size: 0.8125rem; }
  /* Mobilde favori + telefon ikonu gizli (özgüllük .header__actions ile artırıldı) */
  .header__actions .header__action--fav,
  .header__actions .header__action--phone { display: none; }
}

/* ============================ Header ============================ */
.site-header { border-bottom: 1px solid var(--color-border); position: sticky; top: 0; z-index: 30; background: var(--color-bg); }
.header__inner {
  display: flex; align-items: center; gap: var(--space-2);
  min-height: 64px; padding-block: var(--space-2);
}
.header__logo {
  font-family: var(--font-display); font-weight: var(--fw-semibold);
  font-size: var(--fs-500); color: var(--color-text);
  flex: 0 0 auto; white-space: nowrap;
}
/* Logo görseli: yüksekliğe göre ölçeklenir, oran korunur (110x35 native) */
.header__logo img { display: block; height: 34px; width: auto; }
/* Mobilde canlı siteyle aynı: 89px genişlik (oran korunur). */
@media (max-width: 767px) { .header__logo img { width: 89px; height: auto; } }
@media (min-width: 768px) { .header__logo img { height: 38px; } }
.header__logo:hover { text-decoration: none; }
.header__search { flex: 1 1 auto; display: none; position: relative; max-width: 788px; } /* mobilde gizli; lg+ grid ortasında 788px */
.header__search input {
  width: 100%; min-height: 56px; padding: var(--space-2) 58px var(--space-2) var(--space-4);
  border: 1px solid var(--color-border); border-radius: var(--radius-pill); background: var(--color-bg);
  font-size: 1rem; font-weight: var(--fw-medium); color: #555; /* 16px/500 — gerçek arama */
}
.header__search input::placeholder { color: #555; font-weight: var(--fw-medium); }
.header__search input:focus { outline: none; border-color: var(--color-primary); }
/* Canlı site: sağda mavi daire içinde beyaz büyüteç */
.header__search-btn {
  position: absolute; right: 6px; top: 50%; transform: translateY(-50%);
  width: 42px; height: 42px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: var(--color-primary); color: #fff;
  transition: background-color .2s;
}
.header__search-btn:hover { background: var(--color-primary-dark); color: #fff; }
.header__search-btn svg { width: 19px; height: 19px; }
.header__search-btn i { font-size: 19px; line-height: 1; }
.header__actions { display: flex; align-items: center; gap: var(--space-1); margin-left: auto; }
.header__action--phone { display: none; } /* mobilde gizli */

/* Sepet aksiyonu: ikon SOLDA, yanında (md+) "Sepetim / ₺tutar" (canlı site gibi).
   .header__action.header__cart ile özgüllüğü artırıp column yönünü row'a çeviriyoruz. */
.header__action.header__cart { flex-direction: row; align-items: center; gap: 0.75rem; padding-inline: var(--space-2); }
.header__cart-icon { position: relative; display: inline-flex; }
.header__cart-icon svg { width: 22px; height: 22px; }
/* Sepet sayacı: küçük koyu rozet, ikonun üst-sağ KÖŞESİNDE (dışa taşar), ikonu kapatmaz.
   Özgüllük .header__cart ... ile artırıldı (aksi halde .header__action .count eziyordu). */
.header__cart .header__cart-icon .count {
  top: -6px; right: -7px;
  min-width: 16px; height: 16px; padding: 0 3px;
  font-size: 10px; line-height: 16px;
}
.header__cart-icon .count.count--dark { background: var(--color-text); color: #fff; } /* gerçek sepet rozeti koyu #222529 */
.header__cart-text { display: none; flex-direction: column; line-height: 1.15; text-align: left; }
.header__cart-label { font-size: var(--fs-300); font-weight: 700; color: var(--color-text); white-space: nowrap; } /* gerçek: 13px/700 koyu */
.header__cart-total { font-size: var(--fs-400); font-weight: var(--fw-semibold); color: var(--color-text); white-space: nowrap; }
.header__action {
  display: inline-flex; flex-direction: column; align-items: center; justify-content: center;
  min-width: var(--tap-min); min-height: var(--tap-min); padding: var(--space-1);
  color: var(--color-text); font-size: var(--fs-300); position: relative;
}
.header__action:hover { color: var(--color-primary-dark); text-decoration: none; }
.header__action .count {
  position: absolute; top: 2px; right: 2px;
  min-width: 18px; height: 18px; padding: 0 4px;
  background: var(--color-primary); color: var(--color-on-primary);
  font-size: 11px; font-weight: var(--fw-semibold); line-height: 18px;
  border-radius: var(--radius-pill); text-align: center;
}
.header__action svg { width: 22px; height: 22px; }
/* Porto ikon fontu (i) — SVG yerine glyph boyutları */
.header__action > i { font-size: 22px; line-height: 1; }
.header__search-btn i { font-size: 19px; line-height: 1; }
.header__cart-icon i { font-size: 22px; line-height: 1; }
.nav-toggle i { font-size: 24px; line-height: 1; }
.header__label { display: none; } /* etiket md+ üstünde görünür */

/* Hamburger (mobil) */
.nav-toggle { display: inline-flex; }
@media (min-width: 1024px) { .nav-toggle { display: none; } }

/* ============================ Nav (masaüstü) ============================ */
.main-nav { display: none; border-top: 1px solid var(--color-border); background: var(--color-bg); }
@media (min-width: 1024px) { .main-nav { display: block; } }
.main-nav__bar { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); }
.main-nav__list { display: flex; gap: var(--space-5); }
.main-nav__item { position: relative; }
.main-nav__link {
  display: inline-flex; align-items: center; gap: var(--space-2); min-height: var(--tap-min);
  font-family: var(--font-display); font-weight: var(--fw-medium);
  font-size: var(--fs-500); color: var(--color-text); /* 18px — gerçek nav */
  text-transform: capitalize; letter-spacing: -0.035em;
}
.main-nav__link:hover { color: var(--color-primary); text-decoration: none; }
.main-nav__icon { width: 32px; height: 32px; object-fit: contain; flex: 0 0 auto; }
/* Sağda kargo rozeti — canlı site: iki tonlu kapsül.
   Mavi ikon segmenti (beyaz ikon, sol yuvarlak) + açık mavi #E7EEF6 metin
   segmenti (koyu yazı, sağ yuvarlak). Değerler canlı CSS'ten birebir. */
.main-nav__shipping { display: inline-flex; align-items: stretch; flex: 0 0 auto; }
.main-nav__shipping:hover { text-decoration: none; }
.main-nav__shipping-icon {
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--color-primary); color: #fff;
  padding: 0.3rem 0.65rem 0.02rem 0.5rem;
  border-radius: 1.25rem 0 0 1.25rem;
}
.main-nav__shipping-icon i { font-size: 1.4375rem; line-height: 1; }
.main-nav__shipping-text {
  display: inline-flex; align-items: center;
  background: var(--color-surface-tint); color: var(--color-text);
  padding: 0.65rem 0.7rem 0.65rem 0.55rem; border-radius: 0 1.25rem 1.25rem 0;
  font-size: 0.75rem; font-weight: var(--fw-semibold); letter-spacing: -0.025em; line-height: 1.2;
}
/* Dropdown — hover/focus ile aç (JS'siz çalışır) */
.main-nav__dropdown {
  position: absolute; top: 100%; left: 0; min-width: 220px;
  background: var(--color-bg); border: 1px solid var(--color-border);
  border-radius: var(--radius); box-shadow: var(--shadow);
  padding: var(--space-2); display: none; z-index: 40;
}
.main-nav__item:hover .main-nav__dropdown,
.main-nav__item:focus-within .main-nav__dropdown { display: block; }
.main-nav__dropdown a {
  display: block; padding: var(--space-2) var(--space-3); color: var(--color-text); border-radius: var(--radius);
}
.main-nav__dropdown a:hover { background: var(--color-surface); color: var(--color-primary-dark); text-decoration: none; }

/* ============================ Mobil çekmece menü (iki sekme — canlı site) ============================ */
.mobile-menu {
  position: fixed; inset: 0 0 0 auto; width: min(86vw, 340px);
  background: #212529; color: rgba(255, 255, 255, .75); box-shadow: var(--shadow); z-index: 60;
  transform: translateX(100%); transition: transform .2s ease;
  display: flex; flex-direction: column; overflow-y: auto;
}
.mobile-menu[aria-hidden="false"] { transform: translateX(0); }
.mobile-menu__close { position: absolute; top: .5rem; right: .5rem; color: #fff; line-height: 0; padding: .4rem; z-index: 2; }
.mobile-menu__close svg { width: 22px; height: 22px; }

/* Sekmeler (Kategoriler / Menü) */
.mobile-menu__tabs { display: flex; border-bottom: 1px solid rgba(255, 255, 255, .12); margin: 1.6rem var(--space-3) 0; }
.mobile-menu__tab {
  flex: 1; padding: .7rem 0; background: none; border-bottom: 2px solid transparent;
  color: rgba(255, 255, 255, .7); font-family: var(--font-display); font-weight: var(--fw-medium);
}
.mobile-menu__tab.is-active { color: #fff; border-bottom-color: var(--color-primary); }

/* Paneller */
.mobile-menu__pane { display: none; padding: var(--space-2) 0; }
.mobile-menu__pane.is-active { display: block; }

/* Mobil arama */
.mobile-menu__search { padding: var(--space-2) var(--space-3); }
.mobile-menu__search input {
  width: 100%; min-height: var(--tap-min); padding: var(--space-2) var(--space-3);
  border: 1px solid rgba(255, 255, 255, .15); border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, .06); color: #fff;
}
.mobile-menu__search input::placeholder { color: rgba(255, 255, 255, .5); }

/* Akordeon menü */
.accordion-menu { list-style: none; padding: 0; margin: 0; }
.accordion-menu > li { position: relative; border-bottom: 1px solid rgba(255, 255, 255, .08); }
.accordion-menu > li > a {
  display: flex; align-items: center; gap: .6rem; min-height: var(--tap-min);
  padding: .7rem var(--space-3); color: rgba(255, 255, 255, .85); font-weight: var(--fw-medium);
}
.accordion-menu > li > a:hover { color: #fff; text-decoration: none; }
.accordion-menu__icon { width: 22px; height: 22px; object-fit: contain; flex: 0 0 auto; }
.accordion-menu__arrow { position: absolute; top: 0; right: 0; width: 48px; height: 48px; background: none; }
.accordion-menu__arrow::before {
  content: ""; position: absolute; top: 50%; left: 50%; width: 8px; height: 8px;
  border-right: 2px solid rgba(255, 255, 255, .6); border-bottom: 2px solid rgba(255, 255, 255, .6);
  transform: translate(-50%, -60%) rotate(45deg); transition: transform .2s;
}
.accordion-menu__arrow[aria-expanded="true"]::before { transform: translate(-50%, -40%) rotate(225deg); }
.accordion-menu .sub-menu { list-style: none; padding: 0; margin: 0; background: rgba(0, 0, 0, .25); display: none; }
.accordion-menu .sub-menu.is-open { display: block; }
.accordion-menu .sub-menu a {
  display: block; min-height: 40px; padding: .55rem var(--space-3) .55rem 2.4rem; color: rgba(255, 255, 255, .65);
}
.accordion-menu .sub-menu a:hover { background: rgba(255, 255, 255, .06); color: #fff; text-decoration: none; }
.menu-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,.4); z-index: 50;
  opacity: 0; visibility: hidden; transition: opacity .2s;
}
.menu-overlay[data-open="true"] { opacity: 1; visibility: visible; }

/* ============================ Footer ============================ */
/* Canlı site: marka mavisi zemin, beyaz metinler, Instagram karesi. */
.site-footer { background: var(--color-primary); color: rgba(255, 255, 255, .7); margin-top: var(--space-6); }
.footer__grid { display: grid; gap: var(--space-5); grid-template-columns: 1fr; padding-block: var(--space-6) var(--space-5); }
@media (min-width: 768px) { .footer__grid { grid-template-columns: 1.2fr 1fr 1fr 1.3fr; } }
.footer__title { font-size: var(--fs-400); font-weight: var(--fw-semibold); margin-bottom: var(--space-3); color: #fff; }
.footer__logo { display: inline-block; margin-bottom: var(--space-2); }
.footer__logo img { display: block; height: 35px; width: auto; }
.footer__about { max-width: 240px; line-height: 1.7; }
.footer__links a { display: block; padding: var(--space-1) 0; color: rgba(255, 255, 255, .7); min-height: 32px; }
.footer__links a:hover { color: #fff; text-decoration: none; }
.footer__insta { display: grid; grid-template-columns: repeat(4, minmax(0, 82px)); gap: 4px; margin-bottom: var(--space-3); }
.footer__insta img { width: 100%; height: auto; border-radius: 4px; display: block; }
.footer__insta-handle {
  display: inline-flex; align-items: center; gap: var(--space-2);
  color: #fff; font-family: var(--font-display); font-weight: var(--fw-medium);
}
.footer__insta-handle i { font-size: 22px; line-height: 1; }
.footer__insta-handle:hover { opacity: .85; text-decoration: none; }
.footer__phone { margin-top: var(--space-2); }
.footer__phone a { color: rgba(255, 255, 255, .85); }
.footer__bottom { border-top: 1px solid rgba(255, 255, 255, .15); font-size: var(--fs-300); color: rgba(255, 255, 255, .8); }
.footer__bottom-inner { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); padding-block: var(--space-3); flex-wrap: wrap; }
.footer__payments { display: flex; gap: 4px; }
.footer__payment {
  background: #fff; color: var(--color-text); border-radius: 4px;
  font-size: .6875rem; font-weight: 700; font-style: italic;
  padding: .35em .7em; letter-spacing: .02em;
}
@media (max-width: 575px) { .footer__bottom-inner { justify-content: center; text-align: center; } }

/* Tablet+: geniş arama, telefon ikonu ve sepet tutarı görünür */
@media (min-width: 768px) {
  .header__inner { gap: var(--space-4); }
  .header__logo { font-size: var(--fs-600); }
  .header__search { display: block; }
  .header__action--phone { display: inline-flex; }
  .header__cart-text { display: flex; }
}
/* Masaüstü: 3 kolon grid → arama container'ın TAM ortasında (gerçek site gibi) */
@media (min-width: 1024px) {
  .header__inner {
    display: grid;
    /* aksiyon sütunu içeriğe göre boyutlanır (auto) → "Sepetim ₺X" asla kırpılmaz */
    grid-template-columns: 1fr minmax(0, 720px) auto;
    align-items: center; gap: var(--space-4);
  }
  .header__search { max-width: none; width: 100%; }
  .header__actions { justify-self: end; margin-left: 0; }
}

/* ============================ Bölüm başlığı ============================ */
.section-header { display: flex; align-items: baseline; justify-content: space-between; gap: var(--space-3); margin-bottom: var(--space-4); }
.section-header__title { position: relative; }
.section-header__link { font-size: var(--fs-400); color: var(--color-accent); white-space: nowrap; }

/* ============================ Ürün kartı ============================ */
/* Canlı site düzeni: 0.7rem radius, ortalı gövde, hover'da aksiyon daireleri. */
.product-card {
  position: relative; display: flex; flex-direction: column;
  background: var(--color-bg); border: 1px solid var(--color-border);
  border-radius: 0.7rem; overflow: hidden; transition: box-shadow .15s;
}
.product-card:hover { box-shadow: var(--shadow); }
.product-card__media-wrap { position: relative; }
.product-card__badge {
  position: absolute; top: 1em; left: 1em; z-index: 2;
  border-radius: 10px; font-size: .6875rem; padding: .2em 1em;
}
.product-card__media { display: block; aspect-ratio: 1/1; background: #fff; }
.product-card__media img { width: 100%; height: 100%; object-fit: contain; }
.product-card__placeholder { display: flex; align-items: center; justify-content: center; height: 100%; font-size: 3rem; }

/* Aksiyon daireleri: görsel ortasında, hover/odakta görünür; mobilde hep açık */
.product-card__actions {
  position: absolute; inset-inline: var(--space-3); top: 50%; transform: translateY(-50%);
  display: flex; justify-content: center; align-items: center; gap: 10px;
  opacity: 0; transition: opacity .25s; z-index: 2;
}
.product-card:hover .product-card__actions,
.product-card:focus-within .product-card__actions { opacity: 1; }
@media (max-width: 575px) { .product-card__actions { opacity: 1; } }
.product-card__action,
.product-card__actions .product-card__fav {
  position: static; width: 2.5rem; height: 2.5rem; flex: 0 0 auto;
  display: inline-flex; align-items: center; justify-content: center;
  background: #fff; border: 1px solid var(--color-border); border-radius: 50%;
  color: var(--color-text);
  transition: background-color .2s, color .2s, border-color .2s;
}
.product-card__action:hover,
.product-card__actions .product-card__fav:hover {
  background: var(--color-primary); border-color: var(--color-primary); color: #fff;
}
.product-card__action svg { width: 18px; height: 18px; }
.product-card__addform { display: inline-flex; }

/* Favori butonu (ürün detayda da kullanılır — varsayılan konumu korunur) */
.product-card__fav {
  position: absolute; top: var(--space-1); right: var(--space-1); z-index: 2;
  color: var(--color-muted); background: rgba(255,255,255,.85); border-radius: var(--radius-pill);
}
.product-card__fav svg { width: 20px; height: 20px; }
.product-card__fav:hover, .product-card__fav[aria-pressed="true"] { color: var(--color-primary); }

.product-card__body {
  display: flex; flex-direction: column; gap: 2px;
  padding: 12px var(--space-3) var(--space-4); flex: 1 1 auto; text-align: center;
}
.product-card__cat {
  font-size: .625rem; color: #999; text-transform: uppercase; line-height: 1.9;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.product-card__title {
  font-size: .9375rem; font-weight: var(--fw-medium); line-height: 1.35;
  letter-spacing: -0.025em; min-height: 2.7em;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.product-card__title a { color: var(--color-text); }
.product-card__title a:hover { color: var(--color-primary-dark); text-decoration: none; }
.product-card__price { display: flex; align-items: baseline; justify-content: center; gap: var(--space-2); margin-top: auto; padding-top: var(--space-1); }
.product-card__price-old { color: var(--color-muted); text-decoration: line-through; font-size: var(--fs-300); }
.product-card__price-now { color: #444; font-family: var(--font-display); font-weight: var(--fw-semibold); font-size: var(--fs-500); letter-spacing: -0.05em; }

/* ============================ Sayfalama ============================ */
.pagination { display: flex; align-items: center; justify-content: center; gap: var(--space-3); margin-top: var(--space-5); }
.pagination__link { display: inline-flex; align-items: center; min-height: var(--tap-min); padding: var(--space-2) var(--space-4); border: 1px solid var(--color-border); border-radius: var(--radius-pill); color: var(--color-text); }
.pagination__link:hover { border-color: var(--color-primary); color: var(--color-primary-dark); text-decoration: none; }
.pagination__status { color: var(--color-muted); font-size: var(--fs-300); }

/* ============================ Flash mesajları ============================ */
.messages { list-style: none; padding: 0; display: flex; flex-direction: column; gap: var(--space-2); }
.message { padding: var(--space-2) var(--space-3); border-radius: var(--radius); font-size: var(--fs-400); border: 1px solid var(--color-border); }
.message--success { background: #eaf6ea; border-color: var(--color-sale); color: #2c6e2c; }
.message--error { background: #fde8e8; border-color: #e05656; color: #a12727; }
.message--info, .message--warning { background: var(--color-surface-tint); color: var(--color-text); }

/* ============================ Sepet bildirimi (toast) ============================ */
.cart-toast {
  position: fixed; right: var(--space-3); bottom: var(--space-3); z-index: 80;
  background: var(--color-primary); color: var(--color-on-primary);
  padding: var(--space-2) var(--space-4); border-radius: var(--radius); box-shadow: var(--shadow);
  font-size: var(--fs-400);
}
.cart-toast[hidden] { display: none; }

/* Ürün şeritleri — canlı site gibi kaydırmalı carousel (2 → 2.5 → 3.5 → 4.5 kart) */
.product-strip {
  display: flex; gap: var(--space-3);
  overflow-x: auto; scroll-snap-type: x mandatory;
  scrollbar-width: none; -webkit-overflow-scrolling: touch;
  padding-bottom: 4px;
}
.product-strip::-webkit-scrollbar { display: none; }
.product-strip > * { flex: 0 0 calc((100% - 1rem) / 2); scroll-snap-align: start; }
@media (min-width: 576px) { .product-strip > * { flex-basis: calc((100% - 1.5rem) / 2.5); } }
@media (min-width: 768px) { .product-strip > * { flex-basis: calc((100% - 2.5rem) / 3.5); } }
@media (min-width: 1024px) { .product-strip > * { flex-basis: calc((100% - 3.5rem) / 4.5); } }

/* Carousel okları */
.carousel { position: relative; }
.carousel__btn {
  position: absolute; top: 50%; transform: translateY(-50%); z-index: 5;
  width: 2.5rem; height: 2.5rem; border-radius: 50%;
  background: #fff; border: 1px solid var(--color-border); color: var(--color-text);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.4rem; line-height: 1; box-shadow: var(--shadow-sm);
  transition: background-color .2s, color .2s, border-color .2s;
}
.carousel__btn:hover { background: var(--color-primary); border-color: var(--color-primary); color: #fff; }
.carousel__btn--prev { left: -12px; }
.carousel__btn--next { right: -12px; }
.no-js .carousel__btn { display: none; }
