/* ============================================
   CasiOAK Custom - Luxury Artisan Dark Theme v2.0
   Based on: IA方案-v2.0 Russian Aesthetic Spec
   Bronze Gold (#C8A84E) + Deep Blue-Black (#0f0f1a)
   Brutalism accents + Cool Industrial tones
   ============================================ */

/* === Google Fonts === */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Playfair+Display:wght@600;700;800&display=swap');

/* === GLOBAL COLOR SYSTEM === */
:root {
  /* Backgrounds — deep blue-black, warm undertone */
  --cc-bg-primary:    #0f0f1a;
  --cc-bg-surface:    #181825;
  --cc-bg-elevated:   #1e1e2e;
  --cc-bg-card:       #1a1a28;

  /* Accent — Bronze Gold */
  --cc-accent:        #C8A84E;
  --cc-accent-light:  #D4BC6E;
  --cc-accent-dark:   #A88A3A;
  --cc-accent-glow:   rgba(200, 168, 78, 0.15);

  /* Text — warm white + cool grays (Russian IA spec) */
  --cc-text-primary:  #F5F0E8;
  --cc-text-secondary:#C0C0C0;
  --cc-text-muted:    #8A8A8A;
  --cc-text-inverse:  #0f0f1a;

  /* Borders — Brutalist subtle */
  --cc-border:        #2A2A3A;
  --cc-border-accent: #3A3A4A;
  --cc-border-gold:   rgba(200, 168, 78, 0.3);

  /* Legacy aliases */
  --cc-black:         #0a0a0a;
  --cc-white:         #F5F0E8;
  --cc-gray-100:      #1a1a28;
  --cc-gray-200:      #2A2A3A;
  --cc-gray-300:      #3A3A4A;
  --cc-gray-400:      #6A6A7A;
  --cc-gray-500:      #8A8A8A;
  --cc-gray-600:      #C0C0C0;
  --cc-gray-700:      #2A2A3A;
  --cc-gray-800:      #1a1a28;
  --cc-gray-900:      #0f0f1a;

  --cc-font-heading:  'Playfair Display', 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --cc-font-body:     'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}

/* === BASE RESET === */
body {
  font-family: var(--cc-font-body) !important;
  color: var(--cc-text-primary) !important;
  background-color: var(--cc-bg-primary) !important;
  font-size: 16px !important;
  line-height: 1.65 !important;
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--cc-font-heading) !important;
  font-weight: 700 !important;
  line-height: 1.25 !important;
  color: var(--cc-text-primary) !important;
  letter-spacing: 0.02em;
}

h1 { font-size: 2.75rem !important; }
h2 { font-size: 2rem !important; letter-spacing: 0.04em; text-transform: uppercase; }
h3 { font-size: 1.5rem !important; }
h4 { font-size: 1.25rem !important; }

a {
  color: var(--cc-text-primary) !important;
  text-decoration: none !important;
  transition: color 0.25s ease !important;
}
a:hover { color: var(--cc-accent) !important; }

/* === HEADER === */
.site-header {
  background-color: var(--cc-bg-surface) !important;
  color: var(--cc-text-primary) !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 1000 !important;
  border-bottom: 2px solid var(--cc-accent) !important;
}
.main-header-bar { background-color: var(--cc-bg-surface) !important; }
.ast-site-identity { color: var(--cc-text-primary) !important; }
.site-title a, .site-title a:hover {
  color: var(--cc-accent) !important;
  font-weight: 800 !important;
  font-size: 1.2rem !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
}

/* === NAVIGATION === */
.main-navigation .menu-item > a {
  color: var(--cc-text-secondary) !important;
  font-weight: 600 !important;
  font-size: 0.8rem !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  padding: 1rem 1.2rem !important;
  transition: color 0.2s !important;
}
.main-navigation .menu-item > a:hover { color: var(--cc-accent) !important; }
.main-navigation .current-menu-item > a { color: var(--cc-accent) !important; }
.ast-header-cart .astra-cart-icon { color: var(--cc-text-primary) !important; }

/* === BUTTONS — Bronze Gold System === */
.cc-btn-primary,
.wp-block-button__link,
.ast-button,
.button.alt {
  background-color: var(--cc-accent) !important;
  color: var(--cc-text-inverse) !important;
  border: 2px solid var(--cc-accent) !important;
  padding: 14px 36px !important;
  font-size: 0.8rem !important;
  font-weight: 700 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: all 0.25s ease !important;
  border-radius: 4px !important;
  display: inline-block !important;
}
.cc-btn-primary:hover,
.wp-block-button__link:hover,
.ast-button:hover,
.button.alt:hover {
  background-color: var(--cc-accent-light) !important;
  border-color: var(--cc-accent-light) !important;
  color: var(--cc-text-inverse) !important;
  transform: translateY(-1px);
  box-shadow: 0 4px 16px var(--cc-accent-glow);
}

.cc-btn-secondary {
  background-color: transparent !important;
  color: var(--cc-accent) !important;
  border: 2px solid var(--cc-accent) !important;
  padding: 14px 36px !important;
  font-size: 0.8rem !important;
  font-weight: 700 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: all 0.25s ease !important;
  border-radius: 4px !important;
}
.cc-btn-secondary:hover {
  background-color: var(--cc-accent) !important;
  color: var(--cc-text-inverse) !important;
}

/* === PRODUCT CARDS === */
ul.products li.product {
  text-align: center !important;
  margin-bottom: 2rem !important;
  background: var(--cc-bg-card) !important;
  border: 1px solid var(--cc-border) !important;
  border-radius: 4px !important;
  padding: 0 !important;
  overflow: hidden !important;
  transition: border-color 0.3s ease, transform 0.3s ease !important;
}
ul.products li.product:hover {
  border-color: var(--cc-accent) !important;
  transform: translateY(-2px);
}

ul.products li.product .woocommerce-loop-product__title {
  font-size: 0.95rem !important;
  font-weight: 600 !important;
  color: var(--cc-text-primary) !important;
  margin: 1rem 1rem 0.5rem !important;
  letter-spacing: 0.3px !important;
}

ul.products li.product .price {
  color: var(--cc-accent) !important;
  font-weight: 700 !important;
  font-size: 1.1rem !important;
}

ul.products li.product .button,
ul.products li.product .add_to_cart_button {
  background-color: var(--cc-accent) !important;
  color: var(--cc-text-inverse) !important;
  border: none !important;
  font-weight: 700 !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  border-radius: 4px !important;
  font-size: 0.75rem !important;
}
ul.products li.product .button:hover {
  background-color: var(--cc-accent-light) !important;
}

/* === WOOCOMMERCE GLOBAL === */
.woocommerce, .woocommerce-page {
  background-color: var(--cc-bg-primary) !important;
  color: var(--cc-text-primary) !important;
}
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  color: var(--cc-accent) !important;
  font-weight: 700 !important;
}

/* === SHOP PAGE === */
.ast-woocommerce-container {
  background-color: var(--cc-bg-primary) !important;
}

/* === BLOG & PAGES === */
.ast-container, .site-content {
  background-color: var(--cc-bg-primary) !important;
}

article.post, article.page {
  background-color: var(--cc-bg-surface) !important;
  border: 1px solid var(--cc-border) !important;
  border-radius: 4px !important;
  padding: 2rem !important;
}

.entry-title, .entry-title a {
  color: var(--cc-text-primary) !important;
}

.entry-content {
  color: var(--cc-text-secondary) !important;
}

.entry-content h1, .entry-content h2, .entry-content h3 {
  color: var(--cc-text-primary) !important;
}

.entry-content a {
  color: var(--cc-accent) !important;
  text-decoration: underline !important;
}

/* === BRUTALIST ACCENTS === */
/* Thick accent side borders for blockquotes */
blockquote {
  border-left: 4px solid var(--cc-accent) !important;
  background: var(--cc-bg-surface) !important;
  color: var(--cc-text-secondary) !important;
  padding: 1.5rem 2rem !important;
  margin: 2rem 0 !important;
  border-radius: 0 4px 4px 0 !important;
}

/* Gold horizontal rules */
hr, .wp-block-separator {
  border: none !important;
  border-top: 2px solid var(--cc-border-gold) !important;
  margin: 3rem 0 !important;
}

/* === WIDGETS & SIDEBAR === */
.widget {
  background: var(--cc-bg-surface) !important;
  border: 1px solid var(--cc-border) !important;
  border-radius: 4px !important;
  padding: 1.5rem !important;
  margin-bottom: 1.5rem !important;
}

.widget-title {
  color: var(--cc-accent) !important;
  font-weight: 700 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  font-size: 0.9rem !important;
}

/* === FOOTER === */
.site-footer {
  background-color: var(--cc-bg-surface) !important;
  color: var(--cc-text-secondary) !important;
  border-top: 2px solid var(--cc-accent) !important;
}
.site-footer a {
  color: var(--cc-text-secondary) !important;
}
.site-footer a:hover {
  color: var(--cc-accent) !important;
}

/* === FORMS === */
input, textarea, select {
  background-color: var(--cc-bg-elevated) !important;
  color: var(--cc-text-primary) !important;
  border: 2px solid var(--cc-border) !important;
  border-radius: 4px !important;
  padding: 12px 16px !important;
  transition: border-color 0.2s !important;
}
input:focus, textarea:focus, select:focus {
  border-color: var(--cc-accent) !important;
  outline: none !important;
}

/* === TABLES === */
table {
  border-collapse: collapse !important;
}
table th {
  background: var(--cc-bg-surface) !important;
  color: var(--cc-accent) !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
  padding: 12px 16px !important;
}
table td {
  border-bottom: 1px solid var(--cc-border) !important;
  padding: 12px 16px !important;
}

/* === MOBILE TWEAKS === */
@media (max-width: 768px) {
  h1 { font-size: 2rem !important; }
  h2 { font-size: 1.5rem !important; }
  body { font-size: 15px !important; }
  article.post, article.page { padding: 1.25rem !important; }
}


/* ============================================
   HOMEPAGE DARK THEME OVERRIDES
   Force dark theme on all homepage sections
   ============================================ */

/* Collection section */
.collection-section,
.featured-collection,
section[id="popular"],
section[id="customize"] {
  background: var(--cc-bg-primary) !important;
}

/* Product cards */
.product-card {
  background: var(--cc-bg-card) !important;
  border-color: var(--cc-border) !important;
}
.product-card-img {
  background: var(--cc-bg-primary) !important;
}
.product-card-name {
  color: var(--cc-text-primary) !important;
}
.price-current {
  color: var(--cc-accent) !important;
}

/* Tab buttons */
.tab-btn {
  background: var(--cc-bg-surface) !important;
  color: var(--cc-text-secondary) !important;
  border-color: var(--cc-border) !important;
}
.tab-btn.active,
.tab-btn:hover {
  background: var(--cc-accent) !important;
  color: var(--cc-text-inverse) !important;
  border-color: var(--cc-accent) !important;
}

/* View all button */
.btn-view-all {
  border-color: var(--cc-accent) !important;
  color: var(--cc-accent) !important;
}
.btn-view-all:hover {
  background: var(--cc-accent) !important;
  color: var(--cc-text-inverse) !important;
}

/* Trust strip */
.trust-strip {
  background: var(--cc-bg-surface) !important;
}

/* Section titles */
.section-title {
  color: var(--cc-accent) !important;
}

/* Ann bar */
.ann-bar { background: #000 !important; }

/* Circle menu */
.circle-menu-section {
  background: var(--cc-bg-primary) !important;
  border-color: var(--cc-border) !important;
}
.circle-item {
  color: var(--cc-text-primary) !important;
}

/* Configurator cards */
a[href*="configurator"],
a[href*="popular"] {
  background: var(--cc-bg-surface) !important;
}

/* Any remaining white backgrounds in sections */
section,
.section-inner,
[class*="section"] {
  background-color: inherit;
}

/* Override all #fff backgrounds in homepage context */
.home .product-card-img,
.home .tab-content {
  background: var(--cc-bg-primary) !important;
}

/* Reviews section */
.home blockquote,
.home .review-item {
  background: var(--cc-bg-surface) !important;
  color: var(--cc-text-secondary) !important;
}


/* === HERO TRUST ICONS — Replace emoji with SVG === */
.hero-trust-item .trust-icon {
  display: inline-block;
  vertical-align: middle;
  margin-right: 6px;
}

/* === FEATURE CARDS — Mobile compression === */
@media (max-width: 768px) {
  /* Compact feature section on mobile */
  .craft-section,
  [class*="craft"],
  .why-choose-section,
  section:has(.craft-card) {
    padding: 24px 16px !important;
  }
  
  /* Horizontal icon row instead of tall cards */
  .craft-cards,
  .feature-cards,
  .why-choose-grid {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    justify-content: center !important;
  }
  
  .craft-card,
  .feature-card,
  .why-choose-item {
    flex: 1 1 100px !important;
    max-width: 120px !important;
    padding: 12px 8px !important;
    text-align: center !important;
  }
  
  .craft-card .card-icon,
  .feature-card .card-icon {
    font-size: 24px !important;
    margin-bottom: 6px !important;
  }
  
  .craft-card .card-icon svg,
  .feature-card .card-icon svg {
    width: 24px !important;
    height: 24px !important;
  }
  
  .craft-card h3,
  .feature-card h3 {
    font-size: 11px !important;
    margin-bottom: 2px !important;
  }
  
  .craft-card p,
  .feature-card p {
    display: none !important;
  }
  
  .craft-card a,
  .feature-card a {
    font-size: 10px !important;
  }
}

/* === CIRCLE MENU — Keep compact on mobile === */
@media (max-width: 768px) {
  .circle-menu-track {
    gap: 2px !important;
  }
  .circle-item {
    width: 64px !important;
  }
}

/* === PERF FIX: CLS + font-display (2026-05-19) === */

/* Fix product image layout shift */
.woocommerce ul.products li.product img,
.woocommerce-product-gallery__image img,
.wp-post-image {
    aspect-ratio: 1 / 1;
    object-fit: cover;
}

/* Reserve space for share/viral box */
.viral-share-box,
.share-buttons-container {
    min-height: 60px;
}

/* font-display: swap to prevent FOIT */
@font-face {
    font-display: swap;
}

/* WooCommerce gallery fix */
.woocommerce-product-gallery {
    min-height: 400px;
}

.woocommerce-product-gallery__wrapper {
    position: relative;
}
