/*
Theme Name:   Rivet & Weld
Theme URI:    https://rivetandweld.com
Description:  Rivet & Weld custom child theme for Kadence
Author:       Rivet & Weld
Template:     kadence
Version:      1.0.0
*/

/* ============================================================
   GOOGLE FONTS
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Barlow+Condensed:wght@300;400;600;700;800&family=Crimson+Pro:ital,wght@0,400;0,600;1,400&family=Special+Elite&display=swap');

/* ============================================================
   BRAND TOKENS
   ============================================================ */
:root {
  /* Colors */
  --rw-black:       #141210;
  --rw-charcoal:    #1E1B17;
  --rw-charcoal-lt: #2A2520;
  --rw-cream:       #F0E4C4;
  --rw-cream-dim:   #C9B98A;
  --rw-rust:        #C4501A;
  --rw-rust-dark:   #8C3610;
  --rw-rust-hover:  #D96020;
  --rw-brass:       #C9A535;
  --rw-leather:     #7A5C3A;
  --rw-olive:       #3D4A32;
  --rw-rule:        rgba(240, 228, 196, 0.12);
  --rw-rule-strong: rgba(240, 228, 196, 0.25);

  /* Typography */
  --font-display:  'Bebas Neue', sans-serif;
  --font-ui:       'Barlow Condensed', sans-serif;
  --font-body:     'Crimson Pro', Georgia, serif;
  --font-detail:   'Special Elite', monospace;

  /* Spacing */
  --rw-gap:     24px;
  --rw-section: 80px;
}

/* ============================================================
   BASE
   ============================================================ */
*, *::before, *::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  background-color: var(--rw-black);
  color: var(--rw-cream);
  font-family: var(--font-body);
  font-size: 18px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}

/* Grain overlay */
body::after {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9998;
  opacity: 0.035;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 200px 200px;
}

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.04em;
  color: var(--rw-cream);
  text-transform: uppercase;
}

h1 { font-size: clamp(52px, 7vw, 96px); }
h2 { font-size: clamp(36px, 5vw, 64px); }
h3 { font-size: clamp(26px, 3.5vw, 44px); }
h4 { font-size: clamp(20px, 2.5vw, 32px); }
h5 { font-size: 22px; font-family: var(--font-ui); font-weight: 700; letter-spacing: 0.12em; }
h6 { font-size: 14px; font-family: var(--font-detail); letter-spacing: 0.2em; color: var(--rw-rust); }

p {
  color: var(--rw-cream-dim);
  margin-bottom: 1.2em;
}

a {
  color: var(--rw-cream);
  text-decoration: none;
  transition: color 0.2s;
}

a:hover {
  color: var(--rw-rust);
}

strong, b {
  font-weight: 600;
  color: var(--rw-cream);
}

em, i {
  font-style: italic;
  color: var(--rw-cream-dim);
}

small {
  font-family: var(--font-detail);
  font-size: 11px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--rw-leather);
}

blockquote {
  border-left: 3px solid var(--rw-rust);
  padding: 12px 24px;
  margin: 24px 0;
  background: var(--rw-charcoal);
  font-family: var(--font-display);
  font-size: clamp(20px, 3vw, 32px);
  letter-spacing: 0.05em;
  color: var(--rw-cream);
}

hr {
  border: none;
  border-top: 1px solid var(--rw-rule);
  margin: 40px 0;
}

/* ============================================================
   SITE LAYOUT
   ============================================================ */
.site {
  background: var(--rw-black);
}

.container,
.wp-block-group__inner-container {
  max-width: 1280px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 24px;
  padding-right: 24px;
}

/* ============================================================
   HEADER
   ============================================================ */
#masthead,
.site-header,
.kadence-header {
  background-color: var(--rw-black) !important;
  border-bottom: 1px solid var(--rw-rule) !important;
  position: sticky;
  top: 0;
  z-index: 1000;
}

/* Logo */
.site-branding .site-title,
.kadence-header .site-title {
  font-family: var(--font-display) !important;
  font-size: 28px !important;
  letter-spacing: 0.08em !important;
  color: var(--rw-cream) !important;
  text-transform: uppercase !important;
}

.site-branding .site-title a,
.kadence-header .site-title a {
  color: var(--rw-cream) !important;
}

/* Primary Navigation */
#primary-navigation a,
.kadence-header nav a,
.main-navigation a {
  font-family: var(--font-ui) !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: var(--rw-cream-dim) !important;
  transition: color 0.2s !important;
  padding: 8px 14px !important;
}

#primary-navigation a:hover,
.main-navigation a:hover,
.main-navigation .current-menu-item > a {
  color: var(--rw-rust) !important;
}

/* Dropdown menus */
.main-navigation .sub-menu,
.kadence-header .sub-menu {
  background: var(--rw-charcoal) !important;
  border: 1px solid var(--rw-rule) !important;
  border-top: 2px solid var(--rw-rust) !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.6) !important;
}

.main-navigation .sub-menu a {
  border-bottom: 1px solid var(--rw-rule) !important;
  padding: 10px 20px !important;
}

/* Cart icon in header */
.header-cart-link,
.kadence-header .header-cart-button {
  color: var(--rw-cream) !important;
  font-family: var(--font-ui) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em !important;
}

.header-cart-total {
  background: var(--rw-rust) !important;
  color: var(--rw-cream) !important;
  font-family: var(--font-detail) !important;
}

/* ============================================================
   BUTTONS
   ============================================================ */
.wp-block-button__link,
button,
input[type="submit"],
input[type="button"],
.button,
.btn {
  font-family: var(--font-ui) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0.22em !important;
  text-transform: uppercase !important;
  border-radius: 0 !important;
  transition: all 0.2s !important;
  cursor: pointer !important;
}

/* Primary button */
.wp-block-button__link,
.button,
.btn,
button[type="submit"],
input[type="submit"] {
  background: var(--rw-rust) !important;
  color: var(--rw-cream) !important;
  border: 2px solid var(--rw-rust) !important;
  padding: 14px 28px !important;
}

.wp-block-button__link:hover,
.button:hover,
.btn:hover,
button[type="submit"]:hover,
input[type="submit"]:hover {
  background: transparent !important;
  color: var(--rw-rust) !important;
  border-color: var(--rw-rust) !important;
}

/* Ghost / secondary button */
.wp-block-button.is-style-outline .wp-block-button__link,
.button.secondary,
.btn-outline {
  background: transparent !important;
  color: var(--rw-cream) !important;
  border: 2px solid var(--rw-cream) !important;
}

.wp-block-button.is-style-outline .wp-block-button__link:hover {
  background: var(--rw-cream) !important;
  color: var(--rw-black) !important;
}

/* ============================================================
   FORMS
   ============================================================ */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
input[type="tel"],
input[type="number"],
select,
textarea {
  background: var(--rw-charcoal) !important;
  border: 1px solid var(--rw-rule-strong) !important;
  color: var(--rw-cream) !important;
  font-family: var(--font-ui) !important;
  font-size: 14px !important;
  letter-spacing: 0.06em !important;
  border-radius: 0 !important;
  padding: 12px 16px !important;
  transition: border-color 0.2s !important;
}

input:focus,
select:focus,
textarea:focus {
  outline: none !important;
  border-color: var(--rw-rust) !important;
}

input::placeholder,
textarea::placeholder {
  color: var(--rw-leather) !important;
  font-family: var(--font-detail) !important;
  font-size: 12px !important;
  letter-spacing: 0.12em !important;
}

label {
  font-family: var(--font-ui) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: var(--rw-cream-dim) !important;
  display: block;
  margin-bottom: 6px;
}

/* ============================================================
   SECTION / BLOCK DEFAULTS
   ============================================================ */
.wp-block-group,
.wp-block-cover,
section {
  background-color: var(--rw-black);
}

/* Section label style (eyebrow text) */
.section-label {
  font-family: var(--font-detail);
  font-size: 11px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--rw-rust);
  display: block;
  margin-bottom: 10px;
}

/* Divider line with diamond */
.rw-divider {
  display: flex;
  align-items: center;
  gap: 16px;
  margin: 40px 0;
  color: var(--rw-leather);
}

.rw-divider::before,
.rw-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--rw-rule);
}

/* ============================================================
   WOOCOMMERCE — SHOP / ARCHIVE
   ============================================================ */
.woocommerce,
.woocommerce-page {
  background: var(--rw-black) !important;
}

/* Product grid */
.woocommerce ul.products {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)) !important;
  gap: 2px !important;
  margin: 0 !important;
}

/* Product card */
.woocommerce ul.products li.product {
  background: var(--rw-charcoal) !important;
  border: 1px solid var(--rw-rule) !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow: hidden !important;
  transition: border-color 0.25s, transform 0.25s !important;
  position: relative !important;
}

.woocommerce ul.products li.product:hover {
  border-color: var(--rw-rust) !important;
  transform: translateY(-2px) !important;
}

/* Product image */
.woocommerce ul.products li.product .woocommerce-loop-product__link img {
  display: block !important;
  width: 100% !important;
  aspect-ratio: 1 / 1 !important;
  object-fit: cover !important;
  transition: transform 0.4s !important;
}

.woocommerce ul.products li.product:hover img {
  transform: scale(1.04) !important;
}

/* Product info area */
.woocommerce ul.products li.product .woocommerce-loop-product__link,
.woocommerce ul.products li.product > a:not(.add_to_cart_button) {
  display: block !important;
}

/* Product title */
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--font-ui) !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: var(--rw-cream) !important;
  padding: 16px 16px 4px !important;
  margin: 0 !important;
}

/* Product price */
.woocommerce ul.products li.product .price {
  font-family: var(--font-detail) !important;
  font-size: 14px !important;
  letter-spacing: 0.08em !important;
  color: var(--rw-brass) !important;
  padding: 0 16px 14px !important;
  display: block !important;
}

.woocommerce ul.products li.product .price del {
  color: var(--rw-leather) !important;
  opacity: 0.7 !important;
}

/* Add to cart button on product card */
.woocommerce ul.products li.product .button.add_to_cart_button {
  display: block !important;
  width: calc(100% - 0px) !important;
  margin: 0 !important;
  padding: 12px !important;
  text-align: center !important;
  font-size: 11px !important;
  letter-spacing: 0.22em !important;
  background: transparent !important;
  border: none !important;
  border-top: 1px solid var(--rw-rule) !important;
  color: var(--rw-cream-dim) !important;
  transition: all 0.2s !important;
}

.woocommerce ul.products li.product .button.add_to_cart_button:hover {
  background: var(--rw-rust) !important;
  color: var(--rw-cream) !important;
  border-top-color: var(--rw-rust) !important;
}

/* Sale badge */
.woocommerce ul.products li.product .onsale,
.woocommerce span.onsale {
  background: var(--rw-rust) !important;
  color: var(--rw-cream) !important;
  font-family: var(--font-detail) !important;
  font-size: 10px !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
  border-radius: 0 !important;
  padding: 4px 10px !important;
  top: 12px !important;
  left: 12px !important;
  right: auto !important;
  min-height: auto !important;
  min-width: auto !important;
  line-height: 1.4 !important;
}

/* ============================================================
   WOOCOMMERCE — SINGLE PRODUCT
   ============================================================ */
.single-product .woocommerce-product-gallery {
  background: var(--rw-charcoal) !important;
}

.single-product .product_title {
  font-family: var(--font-display) !important;
  font-size: clamp(32px, 5vw, 64px) !important;
  letter-spacing: 0.04em !important;
  color: var(--rw-cream) !important;
  text-transform: uppercase !important;
  line-height: 1 !important;
  margin-bottom: 12px !important;
}

.single-product .price {
  font-family: var(--font-detail) !important;
  font-size: 20px !important;
  color: var(--rw-brass) !important;
  letter-spacing: 0.08em !important;
}

.single-product .woocommerce-product-details__short-description {
  font-family: var(--font-body) !important;
  font-size: 17px !important;
  color: var(--rw-cream-dim) !important;
  border-top: 1px solid var(--rw-rule) !important;
  border-bottom: 1px solid var(--rw-rule) !important;
  padding: 20px 0 !important;
  margin: 20px 0 !important;
}

.single-product .single_add_to_cart_button {
  background: var(--rw-rust) !important;
  color: var(--rw-cream) !important;
  border: 2px solid var(--rw-rust) !important;
  font-family: var(--font-ui) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0.22em !important;
  text-transform: uppercase !important;
  border-radius: 0 !important;
  padding: 16px 36px !important;
  transition: all 0.2s !important;
}

.single-product .single_add_to_cart_button:hover {
  background: transparent !important;
  color: var(--rw-rust) !important;
}

/* Variation selects / swatches */
.woocommerce .variations td.value select {
  background: var(--rw-charcoal) !important;
  border: 1px solid var(--rw-rule-strong) !important;
  color: var(--rw-cream) !important;
  font-family: var(--font-ui) !important;
  font-size: 13px !important;
  letter-spacing: 0.1em !important;
  border-radius: 0 !important;
}

/* Tabs */
.single-product .woocommerce-tabs ul.tabs {
  border-bottom: 1px solid var(--rw-rule) !important;
  background: none !important;
  padding: 0 !important;
}

.single-product .woocommerce-tabs ul.tabs li {
  background: transparent !important;
  border: none !important;
  border-bottom: 3px solid transparent !important;
  border-radius: 0 !important;
}

.single-product .woocommerce-tabs ul.tabs li.active {
  border-bottom-color: var(--rw-rust) !important;
}

.single-product .woocommerce-tabs ul.tabs li a {
  font-family: var(--font-ui) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
  color: var(--rw-cream-dim) !important;
}

.single-product .woocommerce-tabs ul.tabs li.active a {
  color: var(--rw-cream) !important;
}

.single-product .woocommerce-tabs .panel {
  background: var(--rw-charcoal) !important;
  border: 1px solid var(--rw-rule) !important;
  padding: 32px !important;
  border-top: none !important;
}

/* ============================================================
   WOOCOMMERCE — CART & CHECKOUT
   ============================================================ */
.woocommerce-cart table.cart,
.woocommerce-checkout .woocommerce {
  background: var(--rw-charcoal) !important;
  border: 1px solid var(--rw-rule) !important;
}

.woocommerce table.shop_table {
  border-collapse: collapse !important;
  border: 1px solid var(--rw-rule) !important;
}

.woocommerce table.shop_table th {
  font-family: var(--font-ui) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
  color: var(--rw-cream-dim) !important;
  background: var(--rw-charcoal-lt) !important;
  border-bottom: 1px solid var(--rw-rule) !important;
  padding: 14px 16px !important;
}

.woocommerce table.shop_table td {
  border-bottom: 1px solid var(--rw-rule) !important;
  padding: 16px !important;
  color: var(--rw-cream) !important;
  vertical-align: middle !important;
}

.woocommerce .cart-subtotal th,
.woocommerce .order-total th {
  font-family: var(--font-ui) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
}

.woocommerce .order-total .amount {
  color: var(--rw-brass) !important;
  font-family: var(--font-detail) !important;
  font-size: 22px !important;
}

/* ============================================================
   WOOCOMMERCE — NOTICES
   ============================================================ */
.woocommerce-message,
.woocommerce-info {
  background: var(--rw-charcoal) !important;
  border-top: 3px solid var(--rw-rust) !important;
  color: var(--rw-cream) !important;
  font-family: var(--font-ui) !important;
  font-size: 14px !important;
  letter-spacing: 0.06em !important;
}

.woocommerce-error {
  background: var(--rw-rust-dark) !important;
  border: 1px solid var(--rw-rust) !important;
  color: var(--rw-cream) !important;
}

/* ============================================================
   FOOTER
   ============================================================ */
#colophon,
.site-footer,
.kadence-footer {
  background-color: var(--rw-charcoal) !important;
  border-top: 1px solid var(--rw-rule) !important;
  padding: 60px 0 32px !important;
}

.site-footer .widget-title,
.kadence-footer .widget-title {
  font-family: var(--font-ui) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.28em !important;
  text-transform: uppercase !important;
  color: var(--rw-cream-dim) !important;
  margin-bottom: 16px !important;
}

.site-footer ul li a,
.kadence-footer ul li a {
  font-family: var(--font-ui) !important;
  font-size: 13px !important;
  letter-spacing: 0.1em !important;
  color: var(--rw-leather) !important;
}

.site-footer ul li a:hover,
.kadence-footer ul li a:hover {
  color: var(--rw-rust) !important;
}

.site-info,
.footer-credit {
  font-family: var(--font-detail) !important;
  font-size: 11px !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: var(--rw-leather) !important;
  border-top: 1px solid var(--rw-rule) !important;
  padding-top: 24px !important;
  margin-top: 40px !important;
  text-align: center !important;
}

/* ============================================================
   UTILITY CLASSES
   ============================================================ */
.text-rust    { color: var(--rw-rust) !important; }
.text-brass   { color: var(--rw-brass) !important; }
.text-cream   { color: var(--rw-cream) !important; }
.text-dim     { color: var(--rw-cream-dim) !important; }
.text-leather { color: var(--rw-leather) !important; }
.text-olive   { color: var(--rw-olive) !important; }

.bg-black     { background-color: var(--rw-black) !important; }
.bg-charcoal  { background-color: var(--rw-charcoal) !important; }
.bg-rust      { background-color: var(--rw-rust) !important; }
.bg-olive     { background-color: var(--rw-olive) !important; }

.font-display { font-family: var(--font-display) !important; }
.font-ui      { font-family: var(--font-ui) !important; }
.font-body    { font-family: var(--font-body) !important; }
.font-detail  { font-family: var(--font-detail) !important; }

.border-rule  { border: 1px solid var(--rw-rule) !important; }
.border-rust  { border: 1px solid var(--rw-rust) !important; }

.uppercase    { text-transform: uppercase !important; }
.tracked-wide { letter-spacing: 0.2em !important; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 768px) {
  body { font-size: 16px; }

  .woocommerce ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 1px !important;
  }

  #masthead,
  .site-header {
    padding: 12px 0 !important;
  }
}

@media (max-width: 480px) {
  .woocommerce ul.products {
    grid-template-columns: 1fr !important;
  }
}
