/*
Theme Name: Patch
Theme URI: https://cabbagepatchbar.com
Author: Sopotnick's Cabbage Patch Bar
Author URI: https://cabbagepatchbar.com
Description: A custom WordPress theme built for Sopotnick's Cabbage Patch Bar. Elementor-compatible, WooCommerce-ready, zero bloat.
Version: 1.0.1
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: Private
Text Domain: patch
Tags: elementor, woocommerce, custom
*/

/* ============================================================
   GLOBAL DESIGN TOKENS
   Change a value here → updates the entire site
   ============================================================ */

:root {
  /* --- Brand Colors --- */
  --patch-bg:           #0d1f0f;   /* Dark forest green — main background */
  --patch-bg-deep:      #091508;   /* Deeper green — section alternates */
  --patch-bg-deepest:   #060e05;   /* Darkest — footer background */
  --patch-accent:       #c8911a;   /* Gold / amber — primary accent */
  --patch-accent-hover: #ffd700;   /* Yellow — hover state */
  --patch-green-link:   #4aaa4a;   /* Green — links */
  --patch-text:         #ffffff;   /* White — body text */
  --patch-text-muted:   #f0e8d0;   /* Parchment — secondary text */
  --patch-border:       rgba(200, 145, 26, 0.2); /* Gold border */

  /* --- Typography --- */
  --patch-font-heading: 'Alfa Slab One', serif;
  --patch-font-body:    'Libre Baskerville', Georgia, serif;

  /* --- Spacing --- */
  --patch-section-padding: 5rem 2rem;
  --patch-max-width: 1200px;

  /* --- Transitions --- */
  --patch-transition: 0.2s ease;
}

/* ============================================================
   GLOBAL RESETS & BASE
   ============================================================ */

*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  font-size: 16px;
}

body {
  background-color: var(--patch-bg);
  color: var(--patch-text);
  font-family: var(--patch-font-body);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
}

/* ============================================================
   TYPOGRAPHY
   ============================================================ */

h1, h2, h3, h4, h5, h6 {
  font-family: var(--patch-font-heading);
  color: var(--patch-text);
  line-height: 1.15;
  margin-bottom: 1rem;
}

h1 { font-size: clamp(2.2rem, 5vw, 4rem); }
h2 { font-size: clamp(1.8rem, 4vw, 3rem); }
h3 { font-size: clamp(1.3rem, 3vw, 2rem); }
h4 { font-size: 1.2rem; }
h5 { font-size: 1rem; }
h6 { font-size: 0.875rem; }

p {
  font-size: 0.95rem;
  line-height: 1.9;
  color: var(--patch-text);
  margin-bottom: 1.2rem;
}

a {
  color: var(--patch-green-link);
  text-decoration: none;
  transition: color var(--patch-transition);
}

a:hover {
  color: var(--patch-accent-hover);
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

/* ============================================================
   LAYOUT HELPERS
   ============================================================ */

.patch-container {
  max-width: var(--patch-max-width);
  margin: 0 auto;
  padding: 0 2rem;
}

.patch-section {
  padding: var(--patch-section-padding);
}

.patch-section--deep {
  background: var(--patch-bg-deep);
}

.patch-section--deepest {
  background: var(--patch-bg-deepest);
}

/* ============================================================
   BUTTONS
   ============================================================ */

.patch-btn,
.elementor-button,
button[type="submit"],
input[type="submit"] {
  font-family: var(--patch-font-heading);
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  display: inline-block;
  padding: 0.9rem 2.2rem;
  cursor: pointer;
  transition: background var(--patch-transition), color var(--patch-transition), transform var(--patch-transition);
  border: none;
}

.patch-btn--primary {
  background: var(--patch-accent);
  color: var(--patch-bg-deepest);
}

.patch-btn--primary:hover {
  background: var(--patch-accent-hover);
  color: var(--patch-bg-deepest);
  transform: translateY(-1px);
}

.patch-btn--outline {
  background: transparent;
  color: var(--patch-accent);
  border: 1px solid var(--patch-accent);
}

.patch-btn--outline:hover {
  color: var(--patch-accent-hover);
  border-color: var(--patch-accent-hover);
  transform: translateY(-1px);
}

/* ============================================================
   DIVIDER
   ============================================================ */

.cpb-divider {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin: 1.5rem 0 2rem;
}

.cpb-divider-line {
  flex: 1;
  height: 1px;
  background: linear-gradient(to right, var(--patch-accent), transparent);
}

.cpb-divider-ornament {
  color: var(--patch-accent);
  font-size: 0.75rem;
  opacity: 0.55;
}

/* ============================================================
   SECTION LABELS
   ============================================================ */

.patch-section-label {
  font-family: var(--patch-font-heading);
  font-size: 0.65rem;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: var(--patch-accent);
  margin-bottom: 0.8rem;
  display: flex;
  align-items: center;
  gap: 0.7rem;
}

.patch-section-label::before {
  content: '◆';
  font-size: 0.42rem;
}

/* ============================================================
   HEADER
   ============================================================ */

.patch-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 9999;
  height: 70px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 2.5rem;
  background: linear-gradient(to bottom, rgba(6,14,5,0.97), rgba(6,14,5,0.88));
  border-bottom: 1px solid var(--patch-border);
  transition: background var(--patch-transition);
}

.patch-header.scrolled {
  background: rgba(6,14,5,0.99);
}

.patch-header__logo img {
  height: 54px;
  width: auto;
}

.patch-header__nav ul {
  display: flex;
  gap: 2.5rem;
  list-style: none;
}

.patch-header__nav a {
  font-family: var(--patch-font-heading);
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--patch-text-muted);
  opacity: 0.75;
  transition: opacity var(--patch-transition), color var(--patch-transition);
}

.patch-header__nav a:hover {
  opacity: 1;
  color: var(--patch-accent-hover);
}

/* ============================================================
   FOOTER
   ============================================================ */

.patch-footer {
  background: var(--patch-bg-deepest);
  border-top: 3px solid var(--patch-accent);
}

.patch-footer__bottom {
  padding: 1.5rem 2rem;
  text-align: center;
  font-family: var(--patch-font-heading);
  font-size: 0.6rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--patch-text);
  opacity: 0.5;
  border-top: 1px solid var(--patch-border);
}

/* ============================================================
   WOOCOMMERCE OVERRIDES
   ============================================================ */

/* Reset WooCommerce defaults to match theme */
.woocommerce,
.woocommerce-page {
  background: var(--patch-bg);
  color: var(--patch-text);
}

/* Buttons */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
  font-family: var(--patch-font-heading);
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  background: var(--patch-accent);
  color: var(--patch-bg-deepest);
  border: none;
  border-radius: 0;
  padding: 0.85rem 2rem;
  transition: background var(--patch-transition), transform var(--patch-transition);
}

.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover {
  background: var(--patch-accent-hover);
  color: var(--patch-bg-deepest);
  transform: translateY(-1px);
}

/* Product cards */
.woocommerce ul.products li.product {
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--patch-border);
  padding: 1.5rem;
  transition: border-color var(--patch-transition), background var(--patch-transition);
}

.woocommerce ul.products li.product:hover {
  border-color: var(--patch-accent);
  background: rgba(200,145,26,0.04);
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--patch-font-heading);
  color: var(--patch-text);
  font-size: 1rem;
}

.woocommerce ul.products li.product .price {
  color: var(--patch-accent);
  font-family: var(--patch-font-heading);
}

/* Cart & Checkout tables */
.woocommerce table.shop_table {
  border: 1px solid var(--patch-border);
  background: rgba(255,255,255,0.02);
  color: var(--patch-text);
}

.woocommerce table.shop_table th {
  font-family: var(--patch-font-heading);
  font-size: 0.72rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--patch-accent);
  border-bottom: 1px solid var(--patch-border);
  padding: 1rem;
}

.woocommerce table.shop_table td {
  border-bottom: 1px solid var(--patch-border);
  padding: 1rem;
  color: var(--patch-text-muted);
}

/* Form fields */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea {
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--patch-border);
  color: var(--patch-text);
  border-radius: 0;
  padding: 0.75rem 1rem;
  width: 100%;
  font-family: var(--patch-font-body);
  transition: border-color var(--patch-transition);
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus {
  border-color: var(--patch-accent);
  outline: none;
}

/* Sale badge */
.woocommerce span.onsale {
  background: var(--patch-accent);
  color: var(--patch-bg-deepest);
  font-family: var(--patch-font-heading);
  border-radius: 0;
  font-size: 0.65rem;
  letter-spacing: 0.1em;
}

/* Notices */
.woocommerce-message,
.woocommerce-info {
  border-top-color: var(--patch-accent);
  background: rgba(200,145,26,0.08);
  color: var(--patch-text);
}

/* ============================================================
   ELEMENTOR COMPATIBILITY
   ============================================================ */

/* Push content below fixed header */
.elementor-section,
#page,
.site {
  padding-top: 70px;
}

/* Make Elementor respect our CSS variables */
.elementor-widget-heading .elementor-heading-title {
  font-family: var(--patch-font-heading);
}

.elementor-widget-text-editor {
  font-family: var(--patch-font-body);
  color: var(--patch-text-muted);
}

/* ============================================================
   UTILITY CLASSES
   ============================================================ */

.text-accent  { color: var(--patch-accent); }
.text-muted   { color: var(--patch-text-muted);  }
.text-center  { text-align: center; }
.text-upper   { text-transform: uppercase; letter-spacing: 0.15em; }
.bg-deep      { background: var(--patch-bg-deep); }
.bg-deepest   { background: var(--patch-bg-deepest); }
.border-gold  { border: 1px solid var(--patch-border); }

/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 1024px) {
  :root { --patch-section-padding: 4rem 1.5rem; }
}

@media (max-width: 768px) {
  :root { --patch-section-padding: 3rem 1.2rem; }
  .patch-header { padding: 0 1.2rem; }
  .patch-header__nav { display: none; } /* Elementor mobile menu takes over */
}
