/* ================================================================
   BARKOT JEANS — Ana Stylesheet  v2.0
   Geliştirici : Senior E-Commerce Frontend Developer
   Tasarım     : Minimalist · Mobile-First · Yüksek Dönüşüm
   Font        : Montserrat (başlık) + Poppins (gövde)
   Palet       : #111 (siyah) · #FFF (beyaz) · #F8F9FA (açık gri)
                 #E63329 (kırmızı/aksan) · #25D366 (WA yeşili)
   ================================================================ */

/* ── 0. DESIGN TOKENS ───────────────────────────────────────── */
:root {
  /* Renkler */
  --bj-black       : #111111;
  --bj-white       : #FFFFFF;
  --bj-light       : #F8F9FA;
  --bj-mid         : #E9ECEF;
  --bj-muted       : #888888;
  --bj-border      : #E5E5E5;
  --bj-red         : #E63329;   /* Duyuru bandı & vurgu */
  --bj-red-dark    : #C0271E;
  --bj-wa          : #25D366;   /* WhatsApp yeşili */
  --bj-wa-dark     : #128C7E;

  /* Tipografi */
  --ff-head  : 'Montserrat', sans-serif;
  --ff-body  : 'Poppins', sans-serif;

  /* Boyutlar */
  --ann-h          : 36px;
  --header-topbar  : 72px;
  --header-navbar  : 44px;
  --header-total   : calc(var(--ann-h) + var(--header-topbar) + var(--header-navbar));

  --radius-xs  : 2px;
  --radius-sm  : 4px;
  --radius-md  : 8px;
  --radius-lg  : 16px;
  --radius-pill: 50px;

  /* Gölgeler */
  --shadow-sm  : 0 2px 8px  rgba(17,17,17,.07);
  --shadow-md  : 0 6px 24px rgba(17,17,17,.10);
  --shadow-lg  : 0 16px 48px rgba(17,17,17,.14);

  /* Geçişler */
  --tr-fast : .16s ease;
  --tr-med  : .28s cubic-bezier(.4,0,.2,1);
  --tr-slow : .42s cubic-bezier(.4,0,.2,1);
}

/* ── 1. GLOBAL RESET ────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  font-family: var(--ff-body);
  font-size: 15px;
  line-height: 1.65;
  color: var(--bj-black);
  background: var(--bj-white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

body.bj-body--noscroll { overflow: hidden; }

a { color: inherit; text-decoration: none; transition: opacity var(--tr-fast); }
a:hover { opacity: .72; }
img { display: block; max-width: 100%; height: auto; }
ul, ol { list-style: none; }
address { font-style: normal; }

/* ── 2. TİPOGRAFİ ───────────────────────────────────────────── */
h1,h2,h3,h4,h5,h6 {
  font-family: var(--ff-head);
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: -.02em;
}

.bj-section-title {
  font-family: var(--ff-head);
  font-size: clamp(1.15rem, 2.5vw, 1.75rem);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .05em;
}

/* ================================================================
   3. DUYURU BANDI (Announcement Bar)
   ================================================================ */
.bj-ann-bar {
  width: 100%;
  height: var(--ann-h);
  background-color: var(--bj-red);
  color: var(--bj-white);
  overflow: hidden;
  position: relative;
  z-index: 1100;
  flex-shrink: 0;
}

.bj-ann-bar__inner {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  padding: 0 1rem;
  gap: 1rem;
  position: relative;
}

.bj-ann-bar__side {
  flex-shrink: 0;
  font-family: var(--ff-head);
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  opacity: .85;
}

.bj-ann-bar__messages {
  display: flex;
  align-items: center;
  gap: .75rem;
  overflow: hidden;
}

.bj-ann-bar__msg {
  font-family: var(--ff-head);
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  white-space: nowrap;
}

.bj-ann-bar__sep {
  opacity: .45;
  font-size: .75rem;
}

.bj-ann-bar__close {
  position: absolute;
  right: .5rem;
  top: 50%;
  transform: translateY(-50%);
  width: 28px;
  height: 28px;
  border: none;
  background: rgba(255,255,255,.15);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 1rem;
  line-height: 1;
  transition: background var(--tr-fast);
}
.bj-ann-bar__close:hover { background: rgba(255,255,255,.3); }

@media (max-width: 767px) {
  .bj-ann-bar__sep,
  .bj-ann-bar__msg:not(:first-child) { display: none; }
  .bj-ann-bar__msg { font-size: .65rem; }
}

/* ================================================================
   4. HEADER
   ================================================================ */
.bj-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: var(--bj-white);
  border-bottom: 1px solid var(--bj-border);
  transition: box-shadow var(--tr-med), background var(--tr-med);
}

.bj-header.is-sticky {
  background: rgba(255,255,255,.88);
  backdrop-filter: blur(18px) saturate(180%);
  -webkit-backdrop-filter: blur(18px) saturate(180%);
  box-shadow: 0 2px 20px rgba(17,17,17,.07);
  border-color: transparent;
}

.bj-header__topbar {
  height: var(--header-topbar);
  display: flex;
  align-items: center;
}

.bj-header__row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 1.25rem;
  height: 100%;
}

.bj-header__cell--brand {
  display: flex;
  align-items: center;
  gap: .5rem;
  flex-shrink: 0;
}

.bj-header__cell--search { width: 100%; }

.bj-header__cell--actions {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-shrink: 0;
}

/* ── Logo ── */
.bj-logo {
  display: inline-flex;
  align-items: baseline;
  gap: 2px;
  line-height: 1;
}

.bj-logo__brand {
  font-family: var(--ff-head);
  font-weight: 900;
  font-size: 1.3rem;
  letter-spacing: .1em;
  color: var(--bj-black);
  text-transform: uppercase;
  transition: opacity var(--tr-fast);
}

.bj-logo__sub {
  font-family: var(--ff-head);
  font-weight: 300;
  font-size: .8rem;
  letter-spacing: .22em;
  color: var(--bj-black);
  text-transform: uppercase;
  opacity: .5;
  transition: opacity var(--tr-fast);
}

.bj-logo:hover { opacity: 1; }
.bj-logo:hover .bj-logo__brand { opacity: .7; }

/* ── Arama Çubuğu ── */
.bj-searchbar {
  display: flex;
  align-items: center;
  border: 1.5px solid var(--bj-border);
  border-radius: var(--radius-pill);
  background: var(--bj-light);
  overflow: hidden;
  transition: border-color var(--tr-fast), box-shadow var(--tr-fast), background var(--tr-fast);
  height: 44px;
}

.bj-searchbar:focus-within {
  border-color: var(--bj-black);
  background: var(--bj-white);
  box-shadow: 0 0 0 3px rgba(17,17,17,.06);
}

.bj-searchbar__icon {
  flex-shrink: 0;
  padding: 0 .75rem 0 1rem;
  font-size: 1rem;
  color: var(--bj-muted);
  pointer-events: none;
}

.bj-searchbar__field {
  flex: 1;
  border: none;
  background: transparent;
  font-family: var(--ff-body);
  font-size: .875rem;
  color: var(--bj-black);
  outline: none;
  min-width: 0;
}

.bj-searchbar__field::placeholder { color: var(--bj-muted); }

.bj-searchbar__submit {
  flex-shrink: 0;
  height: 100%;
  padding: 0 1.25rem;
  border: none;
  border-left: 1.5px solid var(--bj-border);
  background: var(--bj-black);
  color: var(--bj-white);
  font-family: var(--ff-head);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background var(--tr-fast);
}

.bj-searchbar__submit:hover { background: #2a2a2a; }

/* ── Aksiyon Butonları ── */
.bj-action-item {
  display: flex;
  align-items: center;
}

.bj-action-btn {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  height: 40px;
  padding: 0 .6rem;
  border: none;
  background: transparent;
  color: var(--bj-black);
  font-family: var(--ff-body);
  font-size: .8rem;
  font-weight: 500;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: background var(--tr-fast);
  white-space: nowrap;
}

.bj-action-btn:hover { background: var(--bj-light); opacity: 1; }
.bj-action-btn i { font-size: 1.15rem; }
.bj-action-btn__label { font-size: .75rem; font-weight: 600; }
.bj-action-btn--icon-only { padding: 0 .5rem; }

/* ── Popover Dropdown ── */
.bj-popover {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  min-width: 210px;
  background: var(--bj-white);
  border: 1px solid var(--bj-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
  padding: .5rem 0;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition: opacity var(--tr-med), transform var(--tr-med), visibility var(--tr-med);
  z-index: 1200;
}

.bj-popover.open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.bj-popover__greeting {
  display: flex;
  align-items: center;
  gap: .5rem;
  padding: .6rem 1rem;
  font-family: var(--ff-head);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--bj-muted);
  border-bottom: 1px solid var(--bj-border);
  margin-bottom: .35rem;
}

.bj-popover__item {
  display: flex;
  align-items: center;
  gap: .6rem;
  padding: .5rem 1rem;
  font-size: .85rem;
  font-weight: 400;
  color: var(--bj-black);
  transition: background var(--tr-fast), padding-left var(--tr-fast);
}

.bj-popover__item:hover {
  background: var(--bj-light);
  padding-left: 1.25rem;
  opacity: 1;
}

.bj-popover__item--danger { color: var(--bj-red); }

.bj-popover__divider {
  height: 1px;
  background: var(--bj-border);
  margin: .35rem 0;
}

/* ── Hamburger ── */
.bj-hamburger {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 40px;
  height: 40px;
  border: none;
  background: transparent;
  cursor: pointer;
  border-radius: var(--radius-sm);
  transition: background var(--tr-fast);
  padding: 8px;
}

.bj-hamburger:hover { background: var(--bj-light); }

.bj-hamburger__line {
  display: block;
  height: 1.5px;
  background: var(--bj-black);
  border-radius: 2px;
  transition: transform var(--tr-med), width var(--tr-med), opacity var(--tr-fast);
  width: 22px;
}

.bj-hamburger__line:nth-child(2) { width: 15px; align-self: flex-start; }

body:has(.bj-mobile-menu.is-open) .bj-hamburger__line:nth-child(1) {
  transform: translateY(6.5px) rotate(45deg);
  width: 22px;
}
body:has(.bj-mobile-menu.is-open) .bj-hamburger__line:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}
body:has(.bj-mobile-menu.is-open) .bj-hamburger__line:nth-child(3) {
  transform: translateY(-6.5px) rotate(-45deg);
  width: 22px;
}

/* ── Navigasyon (Desktop) ── */
.bj-header__navbar {
  border-top: 1px solid var(--bj-border);
  height: var(--header-navbar);
  display: flex;
  align-items: center;
}

.bj-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  list-style: none;
}

.bj-nav__item { position: relative; }

.bj-nav__link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: .5rem .85rem;
  font-family: var(--ff-head);
  font-size: .73rem;
  font-weight: 600;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--bj-black);
  border-radius: var(--radius-sm);
  white-space: nowrap;
  transition: background var(--tr-fast), color var(--tr-fast);
  height: var(--header-navbar);
}

.bj-nav__link:hover {
  background: var(--bj-light);
  color: var(--bj-black);
  opacity: 1;
}

.bj-nav__link--cats {
  color: var(--bj-black);
  border: 1.5px solid var(--bj-border);
  border-radius: var(--radius-sm);
  margin-right: .5rem;
  height: 32px;
  font-size: .7rem;
}

.bj-nav__link--cats:hover {
  background: var(--bj-black);
  color: var(--bj-white);
  border-color: var(--bj-black);
  opacity: 1;
}

.bj-nav__link--fire { color: var(--bj-red); }

.bj-nav__caret {
  font-size: .6rem;
  transition: transform var(--tr-fast);
}

.bj-nav__item.has-sub:hover .bj-nav__caret { transform: rotate(180deg); }

.bj-nav__sub {
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 200px;
  background: var(--bj-white);
  border: 1px solid var(--bj-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
  padding: .5rem 0;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-6px);
  transition: opacity var(--tr-med), transform var(--tr-med), visibility var(--tr-med);
  z-index: 1100;
}

.bj-nav__item.has-sub:hover .bj-nav__sub {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.bj-nav__sub-link {
  display: block;
  padding: .5rem 1.25rem;
  font-size: .85rem;
  color: var(--bj-black);
  transition: background var(--tr-fast), padding-left var(--tr-fast);
}

.bj-nav__sub-link:hover {
  background: var(--bj-light);
  padding-left: 1.5rem;
  opacity: 1;
}

#bjMain { min-height: 60vh; }

/* ================================================================
   5. MOBİL MENÜ
   ================================================================ */
.bj-mobile-menu {
  position: fixed;
  inset: 0;
  z-index: 2000;
  pointer-events: none;
  visibility: hidden;
  transition: visibility 0s .42s;
}

.bj-mobile-menu.is-open {
  pointer-events: all;
  visibility: visible;
  transition: visibility 0s 0s;
}

.bj-mm-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(17,17,17,.55);
  opacity: 0;
  transition: opacity var(--tr-med);
  cursor: pointer;
}

.bj-mobile-menu.is-open .bj-mm-backdrop { opacity: 1; }

.bj-mm-panel {
  position: absolute;
  inset: 0 auto 0 0;
  width: min(340px, 88vw);
  background: var(--bj-white);
  display: flex;
  flex-direction: column;
  transform: translateX(-100%);
  transition: transform var(--tr-slow);
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
}

.bj-mobile-menu.is-open .bj-mm-panel { transform: translateX(0); }

.bj-mm-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 1rem;
  height: 60px;
  border-bottom: 1px solid var(--bj-border);
  flex-shrink: 0;
}

.bj-mm-close {
  width: 38px;
  height: 38px;
  border: none;
  background: var(--bj-light);
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-size: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background var(--tr-fast);
}
.bj-mm-close:hover { background: var(--bj-mid); }

.bj-mm-search {
  padding: .75rem 1rem;
  border-bottom: 1px solid var(--bj-border);
  flex-shrink: 0;
}

.bj-mm-search__wrap {
  display: flex;
  align-items: center;
  gap: .5rem;
  background: var(--bj-light);
  border: 1.5px solid var(--bj-border);
  border-radius: var(--radius-pill);
  padding: 0 1rem;
  height: 40px;
}

.bj-mm-search__wrap i { color: var(--bj-muted); }

.bj-mm-search__wrap input {
  flex: 1;
  border: none;
  background: transparent;
  font-size: .85rem;
  font-family: var(--ff-body);
  outline: none;
  color: var(--bj-black);
}

.bj-mm-list { flex: 1; padding: .5rem 0; }

.bj-mm-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .8rem 1.25rem;
  font-family: var(--ff-head);
  font-size: .8rem;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--bj-black);
  border: none;
  background: transparent;
  width: 100%;
  text-align: left;
  cursor: pointer;
  transition: background var(--tr-fast);
}

.bj-mm-link:hover { background: var(--bj-light); opacity: 1; }
.bj-mm-link--campaign { color: var(--bj-red); }

.bj-mm-sub { display: none; background: var(--bj-light); }
.bj-mm-item--has-sub.is-open .bj-mm-sub { display: block; }

.bj-mm-sub-link {
  display: block;
  padding: .6rem 2rem;
  font-size: .82rem;
  color: var(--bj-black);
  opacity: .7;
  transition: opacity var(--tr-fast), padding-left var(--tr-fast);
}

.bj-mm-sub-link:hover { opacity: 1; padding-left: 2.25rem; }

.bj-mm-footer {
  border-top: 1px solid var(--bj-border);
  padding: .75rem 1rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .5rem;
  flex-shrink: 0;
}

.bj-mm-footer-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: .65rem .5rem;
  background: var(--bj-light);
  border-radius: var(--radius-md);
  font-family: var(--ff-body);
  font-size: .78rem;
  font-weight: 500;
  color: var(--bj-black);
  transition: background var(--tr-fast);
  text-align: center;
}

.bj-mm-footer-btn:hover { background: var(--bj-mid); opacity: 1; }

.bj-mm-footer-btn--wa {
  grid-column: 1 / -1;
  background: var(--bj-wa);
  color: #fff;
}

.bj-mm-footer-btn--wa:hover { background: var(--bj-wa-dark); color: #fff; }

/* ================================================================
   6. ALERT ŞERİTLERİ
   ================================================================ */
.bj-alert {
  padding: .8rem 0;
  font-size: .875rem;
  font-weight: 500;
}

.bj-alert .container-xxl {
  display: flex;
  align-items: center;
  gap: .6rem;
}

.bj-alert--ok   { background: #ECFDF5; color: #065F46; border-bottom: 1px solid #A7F3D0; }
.bj-alert--warn { background: #FFF7ED; color: #92400E; border-bottom: 1px solid #FDE68A; }

.bj-alert__x {
  margin-left: auto;
  border: none;
  background: transparent;
  cursor: pointer;
  font-size: 1.1rem;
  opacity: .5;
  transition: opacity var(--tr-fast);
}
.bj-alert__x:hover { opacity: 1; }

/* ================================================================
   7. HERO GRİD — 4'lü Kategori Kartları
   ================================================================ */
.bj-hero-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 4px;
  width: 100%;
  padding: 0;
  margin: 0;
}

.bj-hero-card {
  position: relative;
  overflow: hidden;
  cursor: pointer;
  background: var(--bj-light);
  aspect-ratio: 3 / 4;
}

.bj-hero-card--large { aspect-ratio: 3 / 5; }

.bj-hero-card__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  transition: transform var(--tr-slow);
  will-change: transform;
}

.bj-hero-card:hover .bj-hero-card__img { transform: scale(1.06); }

.bj-hero-card__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(0,0,0,.78) 0%,
    rgba(0,0,0,.30) 35%,
    rgba(0,0,0,.0)  65%
  );
  transition: opacity var(--tr-med);
}

.bj-hero-card:hover .bj-hero-card__overlay {
  background: linear-gradient(
    to top,
    rgba(0,0,0,.88) 0%,
    rgba(0,0,0,.35) 40%,
    rgba(0,0,0,.0)  70%
  );
}

.bj-hero-card__body {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 1.5rem 1.25rem 1.25rem;
  text-align: center;
  z-index: 2;
  transform: translateY(6px);
  transition: transform var(--tr-med);
}

.bj-hero-card:hover .bj-hero-card__body { transform: translateY(0); }

.bj-hero-card__title {
  display: block;
  font-family: var(--ff-head);
  font-weight: 900;
  font-size: clamp(1rem, 2vw, 1.6rem);
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--bj-white);
  line-height: 1.15;
  margin-bottom: .4rem;
  text-shadow: 0 2px 12px rgba(0,0,0,.4);
}

.bj-hero-card__cta {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: var(--ff-body);
  font-size: .78rem;
  font-weight: 300;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.75);
  border-bottom: 1px solid rgba(255,255,255,.3);
  padding-bottom: 1px;
  transition: color var(--tr-fast), border-color var(--tr-fast), gap var(--tr-fast);
}

.bj-hero-card:hover .bj-hero-card__cta {
  color: var(--bj-white);
  border-color: rgba(255,255,255,.7);
  gap: 9px;
}

@media (max-width: 991px) {
  .bj-hero-grid { grid-template-columns: repeat(2, 1fr); gap: 3px; }
}

@media (max-width: 480px) {
  .bj-hero-grid { grid-template-columns: repeat(2, 1fr); gap: 2px; }
  .bj-hero-card__title { font-size: .95rem; }
  .bj-hero-card__cta   { font-size: .7rem; }
}

/* ================================================================
   8. ÜRÜN KARTLARI (Product Grid)
   ================================================================ */
.bj-product-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  padding: 12px 0;
}

@media (min-width: 768px)  { .bj-product-grid { grid-template-columns: repeat(3,1fr); gap: 16px; } }
@media (min-width: 992px)  { .bj-product-grid { grid-template-columns: repeat(4,1fr); gap: 20px; } }
@media (min-width: 1400px) { .bj-product-grid { grid-template-columns: repeat(5,1fr); } }

.bj-product-card {
  background: var(--bj-white);
  border: none;
  border-radius: var(--radius-md);
  overflow: hidden;
  cursor: pointer;
  transition: box-shadow var(--tr-med), transform var(--tr-med);
}

.bj-product-card:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-3px);
}

.bj-product-card__thumb {
  position: relative;
  width: 100%;
  padding-top: 133%;
  overflow: hidden;
  background: var(--bj-light);
}

.bj-product-card__img {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: top center;
  transition: transform var(--tr-slow);
}

.bj-product-card:hover .bj-product-card__img { transform: scale(1.04); }

.bj-product-card__tags {
  position: absolute;
  top: 8px; left: 8px;
  z-index: 2;
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.bj-tag {
  display: inline-flex;
  padding: 2px 7px;
  font-family: var(--ff-head);
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  border-radius: 2px;
  line-height: 1.5;
}

.bj-tag--new   { background: var(--bj-black); color: #fff; }
.bj-tag--sale  { background: var(--bj-red);   color: #fff; }

.bj-product-card__wish {
  position: absolute;
  top: 8px; right: 8px;
  z-index: 3;
  width: 32px; height: 32px;
  border-radius: 50%;
  background: rgba(255,255,255,.85);
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .9rem;
  color: var(--bj-black);
  opacity: 0;
  transform: translateX(4px);
  transition: opacity var(--tr-med), transform var(--tr-med), background var(--tr-fast), color var(--tr-fast);
  backdrop-filter: blur(4px);
}

.bj-product-card:hover .bj-product-card__wish {
  opacity: 1;
  transform: translateX(0);
}

.bj-product-card__wish:hover { background: var(--bj-black); color: var(--bj-white); }

.bj-product-card__info { padding: .65rem .5rem .9rem; }

.bj-product-card__name {
  font-family: var(--ff-body);
  font-size: .85rem;
  font-weight: 500;
  color: var(--bj-black);
  line-height: 1.4;
  margin-bottom: .35rem;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.bj-product-card__prices {
  display: flex;
  align-items: baseline;
  gap: 6px;
  margin-bottom: .65rem;
}

.bj-price {
  font-family: var(--ff-head);
  font-size: .95rem;
  font-weight: 700;
  color: var(--bj-black);
}

.bj-price--old {
  font-size: .8rem;
  font-weight: 400;
  color: var(--bj-muted);
  text-decoration: line-through;
}

.bj-price--sale { color: var(--bj-red); }

.bj-btn-add {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  width: 100%;
  height: 38px;
  border: 1.5px solid var(--bj-black);
  border-radius: var(--radius-xs);
  background: transparent;
  color: var(--bj-black);
  font-family: var(--ff-head);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  cursor: pointer;
  overflow: hidden;
  position: relative;
  transition: color var(--tr-fast);
}

.bj-btn-add::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--bj-black);
  transform: translateY(101%);
  transition: transform var(--tr-med);
  z-index: 0;
}

.bj-btn-add:hover::before { transform: translateY(0); }

.bj-btn-add span, .bj-btn-add i {
  position: relative;
  z-index: 1;
  transition: color var(--tr-fast);
}

.bj-btn-add:hover span,
.bj-btn-add:hover i { color: var(--bj-white); }

.product-layout { padding: 6px; }
@media (min-width: 768px) { .product-layout { padding: 10px; } }

/* ================================================================
   9. GENEL BUTONLAR
   ================================================================ */
.bj-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  height: 48px;
  padding: 0 2rem;
  border-radius: var(--radius-xs);
  font-family: var(--ff-head);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  cursor: pointer;
  border: 1.5px solid transparent;
  transition: background var(--tr-fast), color var(--tr-fast), box-shadow var(--tr-fast), transform var(--tr-fast);
  white-space: nowrap;
  text-decoration: none;
}

.bj-btn:active { transform: scale(.97); }

.bj-btn--primary {
  background: var(--bj-black);
  color: var(--bj-white);
  border-color: var(--bj-black);
}

.bj-btn--primary:hover {
  background: #2a2a2a;
  box-shadow: 0 4px 16px rgba(17,17,17,.2);
  color: var(--bj-white);
  opacity: 1;
}

.bj-btn--ghost {
  background: transparent;
  color: var(--bj-black);
  border-color: var(--bj-black);
}

.bj-btn--ghost:hover {
  background: var(--bj-black);
  color: var(--bj-white);
  opacity: 1;
}

.bj-btn--sm { height: 38px; padding: 0 1.25rem; font-size: .7rem; }

/* ================================================================
   10. FOOTER
   ================================================================ */
.bj-footer {
  background: var(--bj-black);
  color: rgba(255,255,255,.8);
  margin-top: 5rem;
}

.bj-footer__main {
  padding: 4rem 0 3rem;
  border-bottom: 1px solid rgba(255,255,255,.07);
}

.bj-footer__logo { display: inline-flex; margin-bottom: 1.1rem; }

.bj-footer__logo .bj-logo__brand,
.bj-footer__logo .bj-logo__sub { color: var(--bj-white); }

.bj-footer__tagline {
  font-size: .85rem;
  line-height: 1.7;
  color: rgba(255,255,255,.45);
  margin-bottom: 1.25rem;
}

.bj-footer__socials { display: flex; gap: 8px; }

.bj-footer__social {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.15);
  color: rgba(255,255,255,.6);
  font-size: 1rem;
  transition: background var(--tr-fast), border-color var(--tr-fast), color var(--tr-fast);
}

.bj-footer__social:hover {
  background: var(--bj-white);
  border-color: var(--bj-white);
  color: var(--bj-black);
  opacity: 1;
}

.bj-footer__head {
  font-family: var(--ff-head);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--bj-white);
  margin-bottom: 1.1rem;
}

.bj-footer__links { display: flex; flex-direction: column; gap: .55rem; }

.bj-footer__link {
  font-size: .83rem;
  font-weight: 400;
  color: rgba(255,255,255,.5);
  transition: color var(--tr-fast);
}

.bj-footer__link:hover { color: var(--bj-white); opacity: 1; }
.bj-footer__link--dim  { color: rgba(255,255,255,.25); }

.bj-footer__contact { display: flex; flex-direction: column; gap: .9rem; }

.bj-footer__contact > li {
  display: flex;
  align-items: flex-start;
  gap: .6rem;
}

.bj-footer__contact i {
  flex-shrink: 0;
  font-size: .85rem;
  color: rgba(255,255,255,.35);
  margin-top: 3px;
}

.bj-footer__contact address {
  font-size: .83rem;
  color: rgba(255,255,255,.5);
  line-height: 1.6;
}

.bj-footer__pay-strip {
  padding: 1rem 0;
  border-bottom: 1px solid rgba(255,255,255,.06);
}

.bj-footer__pay-row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .75rem;
}

.bj-footer__pay-label {
  font-family: var(--ff-head);
  font-size: .65rem;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(255,255,255,.28);
  white-space: nowrap;
}

.bj-footer__pay-badges { display: flex; flex-wrap: wrap; gap: 5px; }

.bj-pay-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 8px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius-xs);
  font-size: .7rem;
  color: rgba(255,255,255,.5);
}

.bj-footer__bottom { padding: 1.1rem 0; }

.bj-footer__bottom-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: .4rem;
}

.bj-footer__bottom-row p {
  font-size: .78rem;
  color: rgba(255,255,255,.28);
}

.bj-footer__bottom-row strong { color: rgba(255,255,255,.5); }

/* ================================================================
   11. WHATSAPP FAB
   ================================================================ */
.bj-wa-fab {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 9999;
  width: 58px;
  height: 58px;
  border-radius: 50%;
  background: var(--bj-wa);
  color: var(--bj-white);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 20px rgba(37,211,102,.45);
  text-decoration: none;
  animation: bj-wa-breathe 3.5s ease-in-out infinite;
  transition: transform var(--tr-fast), background var(--tr-fast), box-shadow var(--tr-fast);
}

.bj-wa-fab:hover {
  background: var(--bj-wa-dark);
  transform: scale(1.1);
  box-shadow: 0 8px 28px rgba(18,140,126,.55);
  opacity: 1;
  animation-play-state: paused;
}

.bj-wa-fab:hover .bj-wa-fab__tip {
  opacity: 1;
  transform: translateY(-50%) translateX(0);
  pointer-events: all;
}

.bj-wa-fab__pulse {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: var(--bj-wa);
}

.bj-wa-fab__pulse--1 { animation: bj-wa-pulse 2.4s ease-out infinite; }
.bj-wa-fab__pulse--2 { animation: bj-wa-pulse 2.4s ease-out .85s infinite; }

.bj-wa-fab__svg { position: relative; z-index: 2; }

.bj-wa-fab__tip {
  position: absolute;
  right: calc(100% + 12px);
  top: 50%;
  transform: translateY(-50%) translateX(6px);
  background: var(--bj-black);
  color: var(--bj-white);
  font-family: var(--ff-body);
  font-size: .75rem;
  font-weight: 500;
  white-space: nowrap;
  padding: 6px 12px;
  border-radius: var(--radius-pill);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--tr-fast), transform var(--tr-fast);
}

.bj-wa-fab__tip::after {
  content: '';
  position: absolute;
  right: -5px;
  top: 50%;
  transform: translateY(-50%);
  border-width: 5px 0 5px 6px;
  border-style: solid;
  border-color: transparent transparent transparent var(--bj-black);
}

@keyframes bj-wa-breathe {
  0%, 100% { transform: scale(1); }
  50%       { transform: scale(1.055); }
}

@keyframes bj-wa-pulse {
  0%   { transform: scale(1);   opacity: .75; }
  100% { transform: scale(2.3); opacity: 0; }
}

@media (max-width: 767px) {
  .bj-wa-fab { width: 52px; height: 52px; bottom: 16px; right: 16px; }
}

/* ================================================================
   12. BÖLÜM DÜZENİ & YARDIMCI SINIFLAR
   ================================================================ */
.bj-section { padding: 3.5rem 0; }
@media (min-width: 992px) { .bj-section { padding: 5rem 0; } }

.bj-section__hd {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
  margin-bottom: 1.75rem;
}

.bj-underline {
  display: block;
  width: 32px;
  height: 2px;
  background: var(--bj-black);
  margin-top: .5rem;
}

.bj-link-all {
  font-family: var(--ff-head);
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: var(--bj-black);
  display: inline-flex;
  align-items: center;
  gap: 4px;
  border-bottom: 1.5px solid var(--bj-black);
  padding-bottom: 1px;
  transition: gap var(--tr-fast), opacity var(--tr-fast);
}

.bj-link-all:hover { gap: 9px; opacity: .65; }

hr.bj-hr { border: none; border-top: 1px solid var(--bj-border); margin: 2rem 0; }

/* ================================================================
   13. YAZICI & ERİŞİLEBİLİRLİK
   ================================================================ */
@media print {
  .bj-header, .bj-ann-bar, .bj-wa-fab, .bj-mobile-menu, .bj-footer__socials { display: none !important; }
  #bjMain { padding-top: 0 !important; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
}
