/* RDR2 Modern — clean, cinematic, western-inspired theme overrides */

:root {
  --font-heading: 'Cinzel', serif;
  --font-body: 'Inter', ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, 'Apple Color Emoji', 'Segoe UI Emoji';

  /* Accent / texture tokens (safe defaults) */
  --color-accent: var(--color-accent, #c7a36b); /* brass/gold */
  --noise-opacity: 0.08;
  --hero-overlay: linear-gradient(180deg, rgb(0 0 0 / 0.45) 0%, rgb(0 0 0 / 0.65) 60%, rgb(0 0 0 / 0.85) 100%);
  --page-transition-duration: 250ms;
}

html, body {
  font-family: var(--font-body);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Background hero treatment */
body::before {
  background: var(--bg-image, none) center/cover no-repeat;
  mask-image: none;
}

/* Add a noise overlay for depth */
body::after {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: var(--noise-opacity);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140' viewBox='0 0 140 140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='140' height='140' filter='url(%23n)' opacity='0.6'/%3E%3C/svg%3E");
}

/* Hero header */
.site-header.rdr2-hero {
  position: relative;
}

.site-header.rdr2-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: -1;
  background: var(--hero-overlay);
}

/* Hero image layer (below overlay) */
.site-header.rdr2-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: -2;
  background-image: var(--hero-image, var(--bg-image));
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  filter: saturate(0.95) contrast(1.05);
}

.site-header .site-title {
  font-family: var(--font-heading);
  font-weight: 900;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  text-shadow: 0 4px 20px rgb(0 0 0 / 0.45);
}

.site-header .site-title a { color: #fff; }

.site-header .site-title img { filter: drop-shadow(0 8px 18px rgb(0 0 0 / 0.45)); }

.site-header .site-tagline {
  margin: 8px auto 0;
  max-width: 60ch;
  color: var(--color-text-secondary);
  text-align: center;
  font-size: clamp(14px, 2vw, 18px);
}

.site-header .btn-cta {
  margin: 16px auto 0;
  padding-inline: 22px;
  height: 48px;
  line-height: 48px;
  border: 1px solid color-mix(in srgb, var(--color-accent) 70%, #fff 0%);
  background: linear-gradient(180deg, color-mix(in srgb, var(--color-primary) 90%, #000 10%), color-mix(in srgb, var(--color-primary-hover) 90%, #000 10%));
  box-shadow: 0 10px 24px -10px color-mix(in srgb, var(--color-primary) 65%, #000 35%);
}

.site-header .brand-badge {
  position: absolute;
  top: var(--widget-padding);
  left: var(--content-padding);
  width: 72px;
  height: 72px;
  object-fit: contain;
  opacity: 0.9;
  filter: drop-shadow(0 8px 18px rgb(0 0 0 / 0.5));
}

@media (width <= 960px) {
  .site-header .brand-badge { width: 56px; height: 56px; }
}

/* Buttons */
.btn-primary,
.btn-secondary,
.btn-tertiary {
  border-radius: 8px;
  letter-spacing: 0.02em;
}

.btn-primary {
  --btn-color-text: #fff;
  --btn-color-bg: var(--color-primary);
  --btn-color-bg-hover: color-mix(in srgb, var(--color-primary-hover) 80%, #fff 0%);
  border: 1px solid color-mix(in srgb, var(--color-accent) 60%, #fff 0%);
  box-shadow: inset 0 0 0 1px rgb(255 255 255 / 0.05), 0 8px 24px -10px color-mix(in srgb, var(--color-primary) 60%, #000 40%);
}

.btn-secondary {
  --btn-color-text: #fff;
  --btn-color-bg: #232323;
  --btn-color-bg-hover: #2b2b2b;
  border: 1px solid rgb(255 255 255 / 0.06);
}

.btn-tertiary {
  --btn-color-text: var(--color-text);
  --btn-color-bg: transparent;
  --btn-color-bg-hover: rgb(255 255 255 / 0.06);
  border: 1px solid transparent;
}

/* Navigation */
.navigation-horizontal .menu {
  background: rgb(from var(--color-brighter-bg) r g b/0.7);
  backdrop-filter: blur(12px);
  border: 1px solid rgb(255 255 255 / 0.06);
  border-radius: 12px;
}

.navigation-horizontal > ul > li > a {
  padding: 10px 14px;
  border-radius: 8px;
}

.navigation-horizontal a:hover,
.navigation-horizontal a.link-active {
  color: var(--color-accent);
}

.navigation-horizontal li li a.link-active,
.navigation-horizontal li li a:hover {
  color: var(--color-bg);
}

/* Cards */
.widget,
.store-product,
.category-description,
.store-text,
.store-product-full {
  background: linear-gradient(180deg, rgb(from var(--color-brighter-bg) r g b / 0.75), rgb(from var(--color-brighter-bg) r g b / 0.65));
  border: 1px solid rgb(255 255 255 / 0.06);
  border-radius: 14px;
  box-shadow: 0 10px 30px -16px rgb(0 0 0 / 0.5);
}

.store-products-images .store-product .image-link,
.store-products-list .store-product .image-link {
  border-radius: 10px;
  overflow: hidden;
}

.store-product .image {
  border-radius: 10px;
  filter: saturate(0.9) contrast(1.02);
  transition: transform 0.25s ease, filter 0.25s ease;
}

.store-product:hover .image { transform: scale(1.02); filter: saturate(1) contrast(1.05); }

.store-product .product-title { font-family: var(--font-heading); letter-spacing: 0.01em; }

.store-product .price strong { color: var(--color-accent); }

/* Sale banner */
.site-sale-banner {
  border: 1px solid rgb(255 255 255 / 0.06);
  border-radius: 10px;
  background-image: linear-gradient(90deg, color-mix(in srgb, var(--color-primary) 70%, #000 30%), color-mix(in srgb, var(--color-primary-hover) 70%, #000 30%));
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* Sidebar and widgets */
.widget-title {
  font-family: var(--font-heading);
  letter-spacing: 0.02em;
}

.widget-recent .username { color: #fff; }
.widget .link-text { color: var(--color-accent); }
.widget .link-text:hover { color: color-mix(in srgb, var(--color-accent) 80%, #fff 0%); }

/* Quantity fields */
.quantity-field {
  border-radius: 8px;
  border: 1px solid rgb(255 255 255 / 0.07);
}

.quantity-field .adjust::before {
  background-color: var(--color-text);
}

/* Basket */
.basket .basket-header { border-block: 1px solid rgb(255 255 255 / 0.06); }
.basket .basket-second-header { border-bottom: 1px solid rgb(255 255 255 / 0.06); }

/* Footer */
.site-footer { background: linear-gradient(180deg, #0b0b0b, #090909); }
.site-footer-inner .copyright { color: rgb(200 200 200 / 0.7); }

/* Home category tiles */
.site-home-categories .category {
  background: linear-gradient(180deg, rgb(from var(--color-brighter-bg) r g b / 0.75), rgb(from var(--color-brighter-bg) r g b / 0.6));
  border: 1px solid rgb(255 255 255 / 0.06);
  border-radius: 12px;
}

.site-home-categories .category img {
  border-radius: 8px;
  filter: sepia(0.1) contrast(1.02);
}

/* Price badge */
.product-actions .price strong {
  position: relative;
}

.product-actions .price strong::after {
  content: '';
  position: absolute;
  inset: auto 0 -2px 0;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--color-accent), color-mix(in srgb, var(--color-primary) 60%, #fff 0%), var(--color-accent));
  opacity: 0.35;
}

/* Toast */
.toast {
  border: 1px solid rgb(255 255 255 / 0.08);
  background: linear-gradient(180deg, #171717, #141414);
}

/* Checkout button prominence */
.basket .checkout {
  height: 54px;
  font-size: 18px;
}

/* Links */
.link-text { color: var(--color-accent); }
.link-text:hover { color: color-mix(in srgb, var(--color-accent) 80%, #fff 0%); }
