/* ==========================================================
   DeMa Steinmetzbedarf · Stone Theme 2026 · Ultra Enterprise
   ========================================================== */

/* ── Design Tokens ──────────────────────────────────────── */
:root {
  --sw-black:        #111111;
  --sw-charcoal:     #1E1E1E;
  --sw-dark:         #2D2D2D;
  --sw-gold:         #C49A2A;
  --sw-gold-light:   #E8C96A;
  --sw-stone:        #C8A96E;
  --sw-stone-soft:   #E6D8C4;
  --sw-stone-pale:   #F4EEE6;
  --sw-bg:           #F8F5F1;
  --sw-surface:      #FFFFFF;
  --sw-border:       #E2DAD0;
  --sw-text:         #1A1A1A;
  --sw-text-mid:     #4A4540;
  --sw-text-muted:   #857D74;
  --sw-white:        #FFFFFF;
  --sw-radius:       8px;
  --sw-radius-lg:    14px;
  --sw-shadow-sm:    0 1px 3px rgba(0,0,0,.08);
  --sw-shadow:       0 4px 14px rgba(0,0,0,.1);
  --sw-shadow-lg:    0 10px 36px rgba(0,0,0,.15);
  --sw-ease:         180ms ease;
}

/* ── Base ───────────────────────────────────────────────── */
body {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  color: var(--sw-text);
  background: var(--sw-bg);
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; }

/* ── sw-header sticky wrapper ───────────────────────────── */
.sw-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  box-shadow: 0 2px 20px rgba(0,0,0,.4);
}

/* ── Hero Band ─────────────────────────────────────────── */
.sw-hero-band {
  /* responsive background: cover on desktop, contain on mobile */
  background-size: cover;
  background-position: left center;
  background-repeat: no-repeat;
  min-height: 160px;
  position: relative;
  display: flex;
  align-items: center;
}
/* subtle dark gradient so text is legible on bright background */
.sw-hero-band::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    rgba(0,0,0,.55) 0%,
    rgba(0,0,0,.20) 45%,
    rgba(0,0,0,.10) 100%
  );
  pointer-events: none;
  z-index: 0;
}
.sw-hero-band .container-fluid {
  position: relative;
  z-index: 1;
  width: 100%;
}

/* ── Hero row ── */
.sw-hero-row {
  min-height: 140px;
  padding: 16px 0;
}

/* ── Logo ───────────────────────────────────────────────── */
.sw-hero-logo {
  display: flex;
  align-items: center;
}
.sw-logo-link {
  display: inline-block;
  line-height: 0;
}
.sw-logo-img {
  height: clamp(80px, 11vw, 140px);
  width: auto;
  object-fit: contain;
  display: block;
  filter: drop-shadow(0 3px 10px rgba(0,0,0,.7));
}

/* ── Right actions (security + cart) ────────────────────── */
.sw-hero-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}
.sw-hero-actions a,
.sw-hero-actions button:not(.btn-close) {
  color: rgba(255,255,255,.92) !important;
  font-size: 0.9rem !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  transition: color var(--sw-ease) !important;
  white-space: nowrap;
}
.sw-hero-actions a:hover { color: var(--sw-gold-light) !important; }

/* user icon SVG */
.sw-hero-actions svg,
.sw-hero-actions [class*="bi-"] {
  color: rgba(255,255,255,.8) !important;
  fill: rgba(255,255,255,.8) !important;
  width: 22px; height: 22px;
}

/* login/register links */
.sw-hero-actions .col-auto,
.sw-hero-actions > div {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
}

/* cart button style */
.sw-hero-actions [data-test-cart-button],
.sw-hero-actions [data-bs-target="#offcanvasCart"],
.sw-hero-actions button.btn {
  background: rgba(255,255,255,.15) !important;
  border: 1.5px solid rgba(255,255,255,.35) !important;
  color: rgba(255,255,255,.92) !important;
  border-radius: var(--sw-radius) !important;
  padding: 8px 18px !important;
  font-weight: 600 !important;
  backdrop-filter: blur(6px);
  transition: background var(--sw-ease) !important;
}
.sw-hero-actions [data-bs-target="#offcanvasCart"]:hover { background: rgba(255,255,255,.28) !important; }

/* ── Navbar strip (dark, below hero band) ────────────────── */
.sw-header .w-100.border-bottom,
.sw-header .border-bottom.w-100,
.sw-header > nav,
.sw-header div[class*="bg-"] ~ .w-100 {
  background: var(--sw-charcoal) !important;
  border-top: 1px solid rgba(255,255,255,.1) !important;
  border-bottom: none !important;
}
.sw-header .navbar,
.sw-header nav[role="navigation"] {
  background: var(--sw-charcoal) !important;
  padding: 0 !important;
}
.sw-header .navbar-nav { gap: 0 !important; }
.sw-header .navbar-nav a,
.sw-header .nav-link {
  color: rgba(255,255,255,.78) !important;
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  padding: 11px 18px !important;
  transition: color var(--sw-ease), background var(--sw-ease) !important;
  white-space: nowrap;
  text-decoration: none !important;
}
.sw-header .navbar-nav a:hover,
.sw-header .nav-link:hover {
  color: var(--sw-gold-light) !important;
  background: rgba(255,255,255,.07) !important;
}
.sw-header .navbar-toggler {
  border-color: rgba(255,255,255,.3) !important;
}
.sw-header .navbar-toggler-icon {
  filter: invert(1) !important;
}
/* Offcanvas nav on mobile */
.sw-header .offcanvas {
  background: var(--sw-charcoal) !important;
}
.sw-header .offcanvas .nav-link {
  color: rgba(255,255,255,.78) !important;
  padding: 14px 20px !important;
}

/* ── Main content ───────────────────────────────────────── */
.sw-main { min-height: 60vh; padding-top: 36px; padding-bottom: 60px; }

/* ── Typography ─────────────────────────────────────────── */
h1, h2, h3, h4 { font-weight: 700; letter-spacing: -.02em; color: var(--sw-text); line-height: 1.2; }
h1 { font-size: clamp(1.75rem, 3vw, 2.5rem); margin-bottom: .5em; }
h2 { font-size: clamp(1.375rem, 2.4vw, 1.875rem); margin-bottom: .45em; }
h3 { font-size: 1.25rem; margin-bottom: .4em; }

/* ── Breadcrumb ─────────────────────────────────────────── */
ol.breadcrumb, .breadcrumb { background: transparent !important; padding: 14px 0 !important; font-size: .8125rem; }
.breadcrumb-item { color: var(--sw-text-muted); }
.breadcrumb-item a { color: var(--sw-text-muted); text-decoration: none; }
.breadcrumb-item a:hover { color: var(--sw-gold); }
.breadcrumb-item + .breadcrumb-item::before { content: "›"; color: #ccc; }

/* ── Product Cards ──────────────────────────────────────── */
.card {
  background: var(--sw-surface) !important;
  border: 1px solid var(--sw-border) !important;
  border-radius: var(--sw-radius-lg) !important;
  box-shadow: var(--sw-shadow-sm) !important;
  overflow: hidden;
  transition: box-shadow var(--sw-ease), transform var(--sw-ease) !important;
}
.card:hover { box-shadow: var(--sw-shadow-lg) !important; transform: translateY(-3px); }
.card-img-top { aspect-ratio: 4/3; object-fit: cover; width: 100%; }
.card-body { padding: 18px !important; }
.card-title { font-size: .9375rem !important; font-weight: 600 !important; margin-bottom: 6px !important; }
.card-footer { background: var(--sw-stone-pale) !important; border-top: 1px solid var(--sw-border) !important; padding: 12px 18px !important; }
.price, [data-test-product-price] { font-size: 1.125rem !important; font-weight: 700 !important; color: var(--sw-dark) !important; }

/* ── Buttons ─────────────────────────────────────────────── */
.btn { border-radius: var(--sw-radius) !important; font-weight: 600 !important; }
.btn-primary, button[type="submit"], input[type="submit"] {
  background: var(--sw-charcoal) !important;
  border-color: var(--sw-charcoal) !important;
  color: var(--sw-white) !important;
}
.btn-primary:hover { background: var(--sw-black) !important; border-color: var(--sw-black) !important; }
.btn-outline-primary { color: var(--sw-charcoal) !important; border-color: var(--sw-border) !important; background: transparent !important; }
.btn-outline-primary:hover { background: var(--sw-charcoal) !important; color: var(--sw-white) !important; }

/* ── Forms ───────────────────────────────────────────────── */
.form-control:focus, input:focus, select:focus, textarea:focus {
  border-color: var(--sw-gold) !important;
  box-shadow: 0 0 0 3px rgba(196,154,42,.18) !important;
  outline: none !important;
}

/* ── Alerts ──────────────────────────────────────────────── */
.alert-success { background: #EEFBF4 !important; border-color: #7DD4AC !important; color: #1A4A32 !important; }
.alert-warning { background: #FFFAEB !important; border-color: #F5CC5A !important; color: #5C3E09 !important; }
.alert-danger  { background: #FFF2F2 !important; border-color: #FAA0A0 !important; color: #7F1D1D !important; }
.alert-info    { background: #EEF5FF !important; border-color: #93C5FD !important; color: #1E3A6E !important; }

/* ── Tables ──────────────────────────────────────────────── */
.table th { background: var(--sw-stone-pale) !important; font-size: .75rem !important; font-weight: 700 !important; letter-spacing: .06em; text-transform: uppercase; padding: 12px 16px !important; border-bottom: 2px solid var(--sw-border) !important; }
.table td { padding: 13px 16px !important; border-bottom: 1px solid var(--sw-border) !important; vertical-align: middle !important; }
.table-hover tbody tr:hover td { background: var(--sw-bg) !important; }

/* ── Pagination ──────────────────────────────────────────── */
.page-link { color: var(--sw-text) !important; border-color: var(--sw-border) !important; }
.page-item.active .page-link { background: var(--sw-charcoal) !important; border-color: var(--sw-charcoal) !important; color: var(--sw-white) !important; }

/* ── Footer ──────────────────────────────────────────────── */
footer, .sw-page > footer {
  background: var(--sw-charcoal) !important;
  color: rgba(255,255,255,.75) !important;
  padding: 56px 0 28px !important;
  margin-top: 72px !important;
}
footer a { color: var(--sw-stone-soft) !important; text-decoration: none !important; transition: color var(--sw-ease) !important; }
footer a:hover { color: var(--sw-gold-light) !important; }
footer h5 { color: var(--sw-white) !important; font-weight: 700 !important; margin-bottom: 18px !important; text-transform: uppercase !important; letter-spacing: .07em; }
footer p, footer span { color: rgba(255,255,255,.5) !important; font-size: .8125rem !important; }
footer img[alt="PayPal"], footer img[alt="Adyen"], footer img[alt="Mollie"] {
  filter: brightness(0) invert(.45) !important; height: 22px !important; width: auto !important;
}
.footer-copy { border-top: 1px solid rgba(255,255,255,.1) !important; margin-top: 40px !important; padding-top: 20px !important; }

/* ── Offcanvas Cart ──────────────────────────────────────── */
.offcanvas:not(.sw-header .offcanvas) { background: var(--sw-surface) !important; }

/* ── RESPONSIVE ─────────────────────────────────────────── */

/* Tablet ≤ 991px */
@media (max-width: 991.98px) {
  .sw-hero-band {
    background-size: cover;
    background-position: center center;
    min-height: 130px;
  }
  .sw-hero-row { min-height: 110px; padding: 12px 0; }
  .sw-logo-img { height: clamp(60px, 12vw, 100px); }
}

/* Mobile ≤ 767px */
@media (max-width: 767.98px) {
  .sw-hero-band {
    /* On mobile show background centered and scaled to fit height */
    background-size: cover;
    background-position: center center;
    min-height: 100px;
  }
  .sw-hero-row { min-height: 84px; padding: 10px 0; gap: 8px; }
  .sw-logo-img { height: clamp(50px, 14vw, 76px); }
  .sw-hero-actions { gap: 6px !important; }
  .sw-hero-actions a { font-size: .78rem !important; }
  .sw-hero-actions [data-bs-target="#offcanvasCart"] { padding: 6px 12px !important; font-size: .78rem !important; }
}

/* Small mobile ≤ 479px */
@media (max-width: 479px) {
  .sw-hero-band { min-height: 80px; }
  .sw-hero-row { min-height: 70px; }
  .sw-logo-img { height: 48px; }
  .sw-hero-actions a { font-size: .72rem !important; }
}

/* ── Utility ─────────────────────────────────────────────── */
.text-gold  { color: var(--sw-gold) !important; }
.text-stone { color: var(--sw-stone) !important; }
.bg-stone-pale { background: var(--sw-stone-pale) !important; }
