/*
Theme Name: Exclusive Treasure
Theme URI: https://exclusivetreasure.com
Author: Exclusive Treasure
Author URI: https://exclusivetreasure.com
Description: A premium WooCommerce theme for Exclusive Treasure — custom printed gifts, mouse pads, t-shirts & mugs. Fully responsive, SEO-friendly, and WooCommerce ready.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: exclusive-treasure
Tags: woocommerce, e-commerce, custom-logo, custom-menu, featured-images, full-width-template, theme-options, two-columns, left-sidebar, right-sidebar, blog, custom-background, custom-colors, flexible-header, footer-widgets, post-formats, sticky-post, threaded-comments, translation-ready
*/

/* ============================================================
   CSS CUSTOM PROPERTIES
   ============================================================ */
:root {
  --et-gold:        #C9A84C;
  --et-gold-light:  #E8C97A;
  --et-gold-pale:   #F5EDD6;
  --et-ink:         #1A1108;
  --et-cream:       #FAF6EE;
  --et-warm-white:  #FFFDF8;
  --et-charcoal:    #2C2416;
  --et-muted:       #8B7355;
  --et-border:      rgba(201,168,76,0.22);
  --et-shadow:      0 8px 40px rgba(26,17,8,0.10);
  --et-radius:      6px;
  --et-radius-sm:   3px;
  --et-font-head:   'Playfair Display', Georgia, serif;
  --et-font-body:   'DM Sans', system-ui, sans-serif;
  --et-font-italic: 'Cormorant Garamond', Georgia, serif;
  --et-transition:  0.25s ease;
  --et-container:   1340px;
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: var(--et-font-body);
  background: var(--et-warm-white);
  color: var(--et-ink);
  line-height: 1.65;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
img, svg { max-width: 100%; height: auto; display: block; }
a { color: var(--et-gold); text-decoration: none; transition: color var(--et-transition); }
a:hover { color: var(--et-gold-light); }
ul, ol { list-style: none; }
button { cursor: pointer; font-family: inherit; border: none; background: none; }
input, textarea, select { font-family: inherit; }
h1,h2,h3,h4,h5,h6 {
  font-family: var(--et-font-head);
  color: var(--et-ink);
  line-height: 1.1;
  letter-spacing: -0.02em;
}

/* ============================================================
   LAYOUT UTILITIES
   ============================================================ */
.et-container {
  max-width: var(--et-container);
  margin-left: auto;
  margin-right: auto;
  padding-left: 40px;
  padding-right: 40px;
}
.et-section { padding: 100px 0; }
.et-section--sm { padding: 60px 0; }
.et-section--dark { background: var(--et-ink); }
.et-section--cream { background: var(--et-cream); }
.et-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.et-grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.et-grid-4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 24px; }

/* ============================================================
   SECTION HEADER
   ============================================================ */
.et-section-header { text-align: center; margin-bottom: 64px; }
.et-eyebrow {
  display: flex; align-items: center; justify-content: center; gap: 12px;
  font-size: 11px; letter-spacing: 0.25em; color: var(--et-gold);
  font-weight: 600; text-transform: uppercase; margin-bottom: 16px;
}
.et-eyebrow::before, .et-eyebrow::after {
  content: ''; width: 28px; height: 1px; background: var(--et-gold);
}
.et-eyebrow--left { justify-content: flex-start; }
.et-eyebrow--left::before { display: none; }
.et-section-title {
  font-size: clamp(36px, 4vw, 54px);
  font-weight: 800; color: var(--et-ink);
}
.et-section-title em {
  font-style: italic; color: var(--et-gold);
  font-family: var(--et-font-italic); font-size: 1.1em;
}
.et-section-sub {
  margin-top: 16px; font-size: 16px; color: var(--et-muted);
  line-height: 1.7; max-width: 560px; margin-inline: auto; font-weight: 300;
}

/* ============================================================
   BUTTONS
   ============================================================ */
.et-btn,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button {
  display: inline-block; padding: 14px 36px;
  font-size: 13.5px; font-weight: 700; letter-spacing: 0.06em;
  text-transform: uppercase; border-radius: var(--et-radius-sm);
  transition: all var(--et-transition); text-align: center; border: 2px solid transparent;
}
.et-btn--primary,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt {
  background: var(--et-gold); color: var(--et-ink); border-color: var(--et-gold);
}
.et-btn--primary:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover { background: var(--et-gold-light); color: var(--et-ink); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(201,168,76,.35); }
.et-btn--dark { background: var(--et-ink); color: var(--et-gold-light); border-color: var(--et-ink); }
.et-btn--dark:hover { background: var(--et-charcoal); color: var(--et-gold-light); }
.et-btn--outline { background: transparent; color: var(--et-ink); border: 2px solid var(--et-ink); }
.et-btn--outline:hover { background: var(--et-ink); color: var(--et-warm-white); }
.et-btn--outline-light { background: transparent; color: var(--et-warm-white); border: 2px solid rgba(250,246,238,.3); }
.et-btn--outline-light:hover { border-color: var(--et-gold); color: var(--et-gold); }

/* ============================================================
   ANNOUNCEMENT BAR
   ============================================================ */
.et-announcement-bar {
  background: var(--et-ink); color: var(--et-gold-light);
  text-align: center; padding: 10px 20px;
  font-size: 13px; letter-spacing: 0.06em; font-weight: 500;
}
.et-announcement-bar a { color: var(--et-gold); text-decoration: underline; }
.et-announcement-bar .dismiss {
  position: absolute; right: 20px; top: 50%; transform: translateY(-50%);
  background: none; border: none; color: var(--et-gold); font-size: 16px; cursor: pointer;
}

/* ============================================================
   HEADER
   ============================================================ */
#masthead {
  position: sticky; top: 0; z-index: 999;
  background: var(--et-warm-white);
  border-bottom: 1px solid var(--et-border);
  transition: box-shadow var(--et-transition);
}
#masthead.scrolled { box-shadow: 0 4px 24px rgba(26,17,8,.10); }
.et-header-inner {
  display: flex; align-items: center; justify-content: space-between;
  height: 76px; gap: 32px;
}
/* Logo */
.et-logo { display: flex; align-items: center; gap: 0; flex-shrink: 0; }
.et-logo img { max-height: 48px; width: auto; }
.et-logo-text {
  font-family: var(--et-font-head); font-size: 22px; font-weight: 800;
  color: var(--et-ink); letter-spacing: -0.01em;
}
.et-logo-text span { color: var(--et-gold); }
/* Primary Nav */
#primary-navigation { display: flex; align-items: center; }
#primary-navigation .nav-menu { display: flex; align-items: center; gap: 0; }
#primary-navigation .nav-menu li a {
  font-size: 13.5px; font-weight: 500; color: var(--et-charcoal);
  padding: 8px 16px; display: block; position: relative; letter-spacing: 0.03em;
  transition: color var(--et-transition);
}
#primary-navigation .nav-menu li a::after {
  content: ''; position: absolute; bottom: 2px; left: 16px; right: 16px;
  height: 1.5px; background: var(--et-gold); transform: scaleX(0);
  transition: transform 0.25s ease;
}
#primary-navigation .nav-menu li a:hover { color: var(--et-gold); }
#primary-navigation .nav-menu li a:hover::after { transform: scaleX(1); }
#primary-navigation .nav-menu li.menu-item-highlight > a {
  background: var(--et-gold); color: var(--et-ink); border-radius: 4px; font-weight: 600;
}
#primary-navigation .nav-menu li.menu-item-highlight > a::after { display: none; }
/* Dropdown */
#primary-navigation .nav-menu li { position: relative; }
#primary-navigation .nav-menu li .sub-menu {
  position: absolute; top: 100%; left: 0; min-width: 220px;
  background: #fff; border: 1px solid var(--et-border);
  border-radius: var(--et-radius); box-shadow: var(--et-shadow);
  opacity: 0; visibility: hidden; transform: translateY(8px);
  transition: all 0.25s ease; z-index: 100; padding: 8px 0;
}
#primary-navigation .nav-menu li:hover .sub-menu { opacity: 1; visibility: visible; transform: translateY(0); }
#primary-navigation .nav-menu li .sub-menu li a { font-size: 13px; color: var(--et-charcoal); padding: 9px 18px; }
#primary-navigation .nav-menu li .sub-menu li a:hover { color: var(--et-gold); }
/* Header Actions */
.et-header-actions { display: flex; align-items: center; gap: 16px; flex-shrink: 0; }
.et-cart-link {
  display: flex; align-items: center; gap: 8px;
  background: var(--et-ink); color: var(--et-gold-light);
  padding: 9px 20px; border-radius: var(--et-radius-sm);
  font-size: 13.5px; font-weight: 600; letter-spacing: 0.03em;
  transition: background var(--et-transition);
}
.et-cart-link:hover { background: var(--et-charcoal); color: var(--et-gold-light); }
.et-cart-count {
  background: var(--et-gold); color: var(--et-ink); border-radius: 50%;
  width: 18px; height: 18px; font-size: 11px; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
}
.et-search-toggle {
  background: none; border: none; font-size: 18px; cursor: pointer;
  color: var(--et-charcoal); padding: 6px; transition: color var(--et-transition);
}
.et-search-toggle:hover { color: var(--et-gold); }
/* Hamburger */
.et-menu-toggle {
  display: none; flex-direction: column; gap: 5px; cursor: pointer;
  padding: 4px; background: none; border: none;
}
.et-menu-toggle span { display: block; width: 24px; height: 2px; background: var(--et-ink); transition: all 0.3s; }
.et-menu-toggle.active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.et-menu-toggle.active span:nth-child(2) { opacity: 0; }
.et-menu-toggle.active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ============================================================
   HERO (home banner - via custom template)
   ============================================================ */
.et-hero {
  min-height: 88vh; display: grid; grid-template-columns: 1fr 1fr;
  position: relative; overflow: hidden;
}
.et-hero__left {
  background: var(--et-ink); display: flex; flex-direction: column;
  justify-content: center; padding: 80px 60px 80px 80px;
  position: relative; z-index: 2;
}
.et-hero__left::after {
  content: ''; position: absolute; right: -60px; top: 0; bottom: 0;
  width: 120px; background: var(--et-ink);
  clip-path: polygon(0 0, 0 100%, 100% 100%); z-index: 3;
}
.et-hero__eyebrow {
  font-size: 11px; letter-spacing: 0.25em; color: var(--et-gold);
  font-weight: 600; text-transform: uppercase; margin-bottom: 24px;
  display: flex; align-items: center; gap: 12px;
}
.et-hero__eyebrow::before { content: ''; width: 32px; height: 1px; background: var(--et-gold); }
.et-hero h1 {
  font-family: var(--et-font-head); font-size: clamp(48px,5.5vw,76px);
  font-weight: 800; color: var(--et-warm-white); line-height: 1.08;
  letter-spacing: -0.02em; margin-bottom: 0;
}
.et-hero h1 em {
  font-style: italic; color: var(--et-gold-light); font-weight: 400;
  font-family: var(--et-font-italic); font-size: 1.15em;
}
.et-hero__sub {
  margin-top: 28px; font-size: 16px; color: rgba(250,246,238,0.72);
  line-height: 1.7; max-width: 420px; font-weight: 300;
}
.et-hero__actions { margin-top: 44px; display: flex; gap: 16px; flex-wrap: wrap; }
.et-hero__stats {
  margin-top: 56px; display: flex; gap: 36px;
  padding-top: 36px; border-top: 1px solid rgba(250,246,238,0.12);
}
.et-stat__num {
  font-family: var(--et-font-head); font-size: 32px; font-weight: 800;
  color: var(--et-gold-light); line-height: 1;
}
.et-stat__label {
  font-size: 11px; color: rgba(250,246,238,0.5);
  letter-spacing: 0.06em; margin-top: 4px; text-transform: uppercase;
}
.et-hero__right { position: relative; overflow: hidden; background: var(--et-cream); }
.et-hero__grid { display: grid; grid-template-columns:1fr 1fr; grid-template-rows:1fr 1fr; height:100%; gap:3px; }
.et-hero__img-cell { position: relative; overflow: hidden; background: #e8dfc9; }
.et-hero__img-cell img { width:100%; height:100%; object-fit:cover; transition: transform 0.6s ease; }
.et-hero__img-cell:hover img { transform: scale(1.06); }
.et-hero__img-overlay {
  position: absolute; bottom:0; left:0; right:0;
  background: linear-gradient(to top, rgba(26,17,8,0.8) 0%, transparent 100%);
  padding: 20px 16px 14px;
}
.et-hero__img-label { color: var(--et-gold-light); font-size:12px; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; }
.et-hero__img-cell--wide { grid-column: span 2; }

/* ============================================================
   CATEGORY CARDS
   ============================================================ */
.et-cat-card {
  position: relative; border-radius: var(--et-radius);
  overflow: hidden; aspect-ratio: 4/5; cursor: pointer; background: #d8cdb8;
}
.et-cat-card img { width:100%; height:100%; object-fit:cover; transition: transform 0.6s ease; }
.et-cat-card:hover img { transform: scale(1.08); }
.et-cat-card__overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(26,17,8,0.85) 0%, rgba(26,17,8,0.2) 50%, transparent 100%);
  display: flex; flex-direction: column; justify-content: flex-end; padding: 36px 32px;
  transition: background 0.3s;
}
.et-cat-card:hover .et-cat-card__overlay { background: linear-gradient(to top, rgba(26,17,8,0.92) 0%, rgba(26,17,8,0.3) 50%, transparent 100%); }
.et-cat-card__tag { font-size:10px; letter-spacing:0.18em; color:var(--et-gold-light); font-weight:600; text-transform:uppercase; margin-bottom:8px; }
.et-cat-card__name { font-family:var(--et-font-head); font-size:28px; font-weight:700; color:#fff; margin-bottom:10px; }
.et-cat-card__desc { font-size:13.5px; color:rgba(255,255,255,0.72); line-height:1.6; margin-bottom:20px; max-width:260px; }
.et-cat-card__btn {
  display: inline-flex; align-items: center; gap:8px;
  background: var(--et-gold); color: var(--et-ink);
  padding: 10px 22px; font-size:12.5px; font-weight:700;
  letter-spacing:0.06em; text-transform:uppercase; border-radius:var(--et-radius-sm);
  transform: translateY(8px); opacity:0; transition: all 0.3s ease; width:fit-content;
}
.et-cat-card:hover .et-cat-card__btn { transform: translateY(0); opacity:1; }

/* ============================================================
   PRODUCT CARDS (WooCommerce override + custom)
   ============================================================ */
.woocommerce ul.products { display: grid; grid-template-columns: repeat(4,1fr); gap: 24px; margin: 0; padding: 0; }
.woocommerce ul.products li.product,
.et-product-card {
  background: #fff; border-radius: var(--et-radius);
  border: 1px solid rgba(201,168,76,0.15); overflow: hidden;
  transition: all 0.3s ease; position: relative; margin: 0;
}
.woocommerce ul.products li.product:hover,
.et-product-card:hover { transform: translateY(-6px); box-shadow: 0 20px 48px rgba(26,17,8,0.12); border-color: var(--et-gold); }
.woocommerce ul.products li.product a img,
.et-product-card__img-wrap img { width:100%; aspect-ratio:1; object-fit:cover; transition: transform 0.5s ease; }
.woocommerce ul.products li.product:hover a img,
.et-product-card:hover .et-product-card__img-wrap img { transform: scale(1.08); }
.woocommerce ul.products li.product a img { border-radius: 0; }
.et-product-card__img-wrap { position: relative; overflow: hidden; aspect-ratio:1; background:var(--et-cream); }
/* Badges */
.et-badge { position:absolute; top:12px; left:12px; font-size:11px; font-weight:700; padding:4px 10px; border-radius:var(--et-radius-sm); letter-spacing:0.05em; text-transform:uppercase; }
.et-badge--sale { background:#E8434A; color:#fff; }
.et-badge--new { background:var(--et-gold); color:var(--et-ink); }
.woocommerce ul.products li.product .onsale { background:#E8434A; border-radius: var(--et-radius-sm); font-size:11px; top:12px; left:12px; min-height:auto; min-width:auto; padding:4px 10px; line-height:1.4; }
/* Product actions overlay */
.et-product-actions {
  position:absolute; top:12px; right:12px;
  display:flex; flex-direction:column; gap:8px;
  opacity:0; transform:translateX(8px); transition:all 0.3s;
}
.et-product-card:hover .et-product-actions,
.woocommerce ul.products li.product:hover .et-product-actions { opacity:1; transform:translateX(0); }
.et-action-btn {
  width:36px; height:36px; background:#fff; border:none; border-radius:50%;
  display:flex; align-items:center; justify-content:center; cursor:pointer;
  font-size:15px; box-shadow:0 2px 8px rgba(0,0,0,.1); transition:background 0.2s;
}
.et-action-btn:hover { background:var(--et-gold); }
/* Product body */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.et-product-card__name {
  font-family:var(--et-font-head); font-size:15px; font-weight:700; color:var(--et-ink);
  line-height:1.3; padding:20px 20px 0; margin:0;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.et-product-card__cat { font-size:10.5px; color:var(--et-gold); font-weight:600; letter-spacing:0.1em; text-transform:uppercase; padding:20px 20px 0; }
.woocommerce ul.products li.product .price,
.et-product-card__price { display:flex; align-items:baseline; gap:8px; padding:10px 20px 0; flex-wrap:wrap; }
.woocommerce ul.products li.product .price,
.et-product-card__price .amount { font-size:18px; font-weight:700; color:var(--et-ink); }
.woocommerce ul.products li.product .price del,
.et-product-card__price .was { font-size:14px; color:var(--et-muted); text-decoration:line-through; font-weight:400; }
.woocommerce ul.products li.product .price ins { text-decoration:none; font-weight:700; }
.et-product-card__save { font-size:11px; background:#E8F5E9; color:#2E7D32; padding:2px 8px; border-radius:12px; font-weight:600; }
.woocommerce ul.products li.product .button,
.et-product-card__add-btn {
  display:block; width:calc(100% - 40px); margin:16px 20px 20px;
  background:var(--et-ink); color:var(--et-gold-light);
  border:none; padding:12px; font-size:13px; font-weight:600;
  letter-spacing:0.05em; cursor:pointer; border-radius:var(--et-radius-sm);
  transition:all 0.25s; font-family:var(--et-font-body); text-align:center;
}
.woocommerce ul.products li.product .button:hover,
.et-product-card__add-btn:hover { background:var(--et-gold); color:var(--et-ink); }

/* ============================================================
   USP BAND
   ============================================================ */
.et-usp-band { background: var(--et-ink); padding: 60px 0; }
.et-usp-grid { display:grid; grid-template-columns:repeat(4,1fr); background:rgba(201,168,76,0.2); gap:1px; }
.et-usp-item { background:var(--et-ink); padding:44px 36px; text-align:center; transition:background 0.3s; }
.et-usp-item:hover { background:rgba(201,168,76,0.08); }
.et-usp-icon { font-size:36px; margin-bottom:16px; display:block; }
.et-usp-title { font-family:var(--et-font-head); font-size:18px; font-weight:700; color:var(--et-gold-light); margin-bottom:10px; }
.et-usp-desc { font-size:13.5px; color:rgba(250,246,238,0.6); line-height:1.65; font-weight:300; }

/* ============================================================
   BULK SECTION
   ============================================================ */
.et-bulk__img-wrap { position:relative; border-radius:var(--et-radius); overflow:hidden; }
.et-bulk__img-wrap img { width:100%; height:480px; object-fit:cover; }
.et-bulk__badge { position:absolute; bottom:28px; left:28px; background:var(--et-gold); color:var(--et-ink); padding:14px 24px; border-radius:4px; font-weight:700; font-size:15px; }
.et-bulk__points { display:flex; flex-direction:column; gap:20px; margin:36px 0; }
.et-bulk__point { display:flex; gap:20px; align-items:flex-start; padding:20px 24px; background:#fff; border-radius:var(--et-radius); border:1px solid var(--et-border); transition:border-color 0.2s; }
.et-bulk__point:hover { border-color:var(--et-gold); }
.et-bulk__point-icon { font-size:24px; flex-shrink:0; width:44px; height:44px; background:var(--et-gold-pale); border-radius:50%; display:flex; align-items:center; justify-content:center; }
.et-bulk__point-text h4 { font-size:15px; font-weight:700; color:var(--et-ink); margin-bottom:4px; }
.et-bulk__point-text p { font-size:13.5px; color:var(--et-muted); line-height:1.6; font-weight:300; }

/* ============================================================
   INDUSTRIES
   ============================================================ */
.et-ind-card { border:1px solid var(--et-border); border-radius:var(--et-radius); padding:32px 24px; text-align:center; transition:all 0.3s; cursor:pointer; background:#fff; }
.et-ind-card:hover { border-color:var(--et-gold); background:var(--et-gold-pale); transform:translateY(-4px); box-shadow:var(--et-shadow); }
.et-ind-icon { font-size:40px; margin-bottom:16px; display:block; }
.et-ind-name { font-family:var(--et-font-head); font-size:18px; font-weight:700; color:var(--et-ink); margin-bottom:8px; }
.et-ind-desc { font-size:13px; color:var(--et-muted); line-height:1.6; }

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.et-testi-card { background:rgba(250,246,238,0.05); border:1px solid rgba(201,168,76,0.2); border-radius:var(--et-radius); padding:36px; transition:all 0.3s; }
.et-testi-card:hover { background:rgba(201,168,76,0.08); border-color:rgba(201,168,76,0.5); transform:translateY(-4px); }
.et-testi-stars { color:var(--et-gold); font-size:16px; letter-spacing:2px; margin-bottom:20px; }
.et-testi-text { font-size:18px; color:rgba(250,246,238,0.82); line-height:1.75; font-weight:300; font-style:italic; margin-bottom:28px; font-family:var(--et-font-italic); }
.et-testi-author { display:flex; align-items:center; gap:14px; }
.et-testi-avatar { width:44px; height:44px; background:var(--et-gold); border-radius:50%; display:flex; align-items:center; justify-content:center; font-weight:700; color:var(--et-ink); font-size:16px; }
.et-testi-name { font-weight:600; color:var(--et-gold-light); font-size:14px; }
.et-testi-role { font-size:12.5px; color:rgba(250,246,238,0.45); margin-top:2px; }

/* ============================================================
   GALLERY
   ============================================================ */
.et-gallery-grid { display:grid; grid-template-columns:repeat(6,1fr); grid-template-rows:220px 220px; gap:12px; }
.et-gallery-cell { overflow:hidden; border-radius:var(--et-radius); cursor:pointer; background:#d8cdb8; }
.et-gallery-cell:nth-child(1) { grid-column:span 2; grid-row:span 2; }
.et-gallery-cell:nth-child(4) { grid-column:span 2; }
.et-gallery-cell img { width:100%; height:100%; object-fit:cover; transition:transform 0.5s ease; }
.et-gallery-cell:hover img { transform:scale(1.1); }

/* ============================================================
   CTA SECTION
   ============================================================ */
.et-cta-section { background:linear-gradient(135deg, var(--et-gold) 0%, #B8912A 100%); padding:80px 0; text-align:center; }
.et-cta-eyebrow { font-size:11px; letter-spacing:0.25em; color:rgba(26,17,8,0.7); font-weight:600; text-transform:uppercase; margin-bottom:20px; }
.et-cta-title { font-family:var(--et-font-head); font-size:clamp(32px,4vw,52px); font-weight:800; color:var(--et-ink); line-height:1.1; margin-bottom:20px; }
.et-cta-sub { font-size:16px; color:rgba(26,17,8,0.75); line-height:1.65; margin-bottom:40px; font-weight:300; }
.et-cta-actions { display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }

/* ============================================================
   WOOCOMMERCE - Single Product
   ============================================================ */
.woocommerce div.product div.images .woocommerce-product-gallery { border-radius:var(--et-radius); overflow:hidden; }
.woocommerce div.product .product_title { font-family:var(--et-font-head); font-size:36px; font-weight:800; }
.woocommerce div.product p.price { font-size:28px; color:var(--et-gold); font-weight:700; }
.woocommerce div.product p.price del { font-size:18px; color:var(--et-muted); }
.woocommerce div.product .woocommerce-product-details__short-description { font-size:15px; color:var(--et-muted); line-height:1.7; margin:16px 0; }
.woocommerce form.cart .qty { border:1px solid var(--et-border); border-radius:var(--et-radius-sm); padding:10px 14px; font-size:16px; width:70px; }
.woocommerce #respond input#submit,
.woocommerce a.button, .woocommerce button.button,
.woocommerce input.button { border-radius:var(--et-radius-sm); }
.woocommerce div.product .product_meta span { font-size:13px; }
.woocommerce .woocommerce-tabs ul.tabs li a { font-family:var(--et-font-head); font-weight:600; }
.woocommerce .woocommerce-tabs ul.tabs li.active a { color:var(--et-gold); }

/* Cart & Checkout */
.woocommerce-cart table.cart td.actions .coupon .input-text { border:1px solid var(--et-border); border-radius:var(--et-radius-sm); padding:10px 14px; }
.woocommerce #payment { border-radius:var(--et-radius); }
.woocommerce #payment div.payment_box { border-radius:var(--et-radius-sm); }

/* ============================================================
   SIDEBAR
   ============================================================ */
.widget-area { padding-left: 40px; }
.widget { margin-bottom: 40px; }
.widget-title { font-family:var(--et-font-head); font-size:20px; font-weight:700; color:var(--et-ink); margin-bottom:20px; padding-bottom:12px; border-bottom:2px solid var(--et-gold); }
.widget ul li { padding:8px 0; border-bottom:1px solid var(--et-border); font-size:14px; }
.widget ul li a { color:var(--et-charcoal); }
.widget ul li a:hover { color:var(--et-gold); }
.woocommerce .widget_price_filter .ui-slider .ui-slider-range { background:var(--et-gold); }
.woocommerce .widget_price_filter .ui-slider .ui-slider-handle { background:var(--et-gold); border-color:var(--et-gold); }

/* ============================================================
   BLOG
   ============================================================ */
.et-blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:32px; }
.et-post-card { background:#fff; border-radius:var(--et-radius); overflow:hidden; border:1px solid var(--et-border); transition:all 0.3s; }
.et-post-card:hover { transform:translateY(-4px); box-shadow:var(--et-shadow); border-color:var(--et-gold); }
.et-post-card__img { aspect-ratio:16/9; overflow:hidden; }
.et-post-card__img img { width:100%; height:100%; object-fit:cover; transition:transform 0.5s; }
.et-post-card:hover .et-post-card__img img { transform:scale(1.06); }
.et-post-card__body { padding:28px; }
.et-post-card__meta { font-size:11.5px; color:var(--et-muted); letter-spacing:0.06em; text-transform:uppercase; margin-bottom:12px; }
.et-post-card__title { font-family:var(--et-font-head); font-size:20px; font-weight:700; margin-bottom:12px; line-height:1.3; }
.et-post-card__title a { color:var(--et-ink); }
.et-post-card__title a:hover { color:var(--et-gold); }
.et-post-card__excerpt { font-size:14px; color:var(--et-muted); line-height:1.7; margin-bottom:20px; font-weight:300; }
.et-post-card__read-more { font-size:13px; font-weight:700; color:var(--et-gold); letter-spacing:0.06em; text-transform:uppercase; }

/* ============================================================
   FOOTER
   ============================================================ */
#colophon { background:#0F0A04; padding:80px 0 0; color:rgba(250,246,238,0.65); }
.et-footer-inner { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:60px; padding-bottom:60px; }
.et-footer-brand .et-logo-text { display:block; margin-bottom:20px; font-size:24px; }
.et-footer-brand p { font-size:14px; line-height:1.7; font-weight:300; max-width:300px; margin-bottom:28px; }
.et-footer-social { display:flex; gap:12px; }
.et-social-link { width:38px; height:38px; border:1px solid rgba(201,168,76,0.3); border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--et-gold-light); font-size:14px; transition:all 0.2s; }
.et-social-link:hover { background:var(--et-gold); color:var(--et-ink); border-color:var(--et-gold); }
.et-footer-col h5 { font-size:12px; letter-spacing:0.15em; color:var(--et-gold); font-weight:600; text-transform:uppercase; margin-bottom:20px; }
.et-footer-col ul { display:flex; flex-direction:column; gap:10px; }
.et-footer-col ul li a { font-size:14px; color:rgba(250,246,238,0.6); transition:color 0.2s; font-weight:300; }
.et-footer-col ul li a:hover { color:var(--et-gold-light); }
.et-footer-contact p { font-size:14px; color:rgba(250,246,238,0.65); line-height:1.8; font-weight:300; }
.et-footer-contact strong { color:var(--et-gold-light); font-weight:600; }
.et-footer-bottom-bar { border-top:1px solid rgba(201,168,76,0.15); padding:28px 0; display:flex; align-items:center; justify-content:space-between; font-size:12.5px; color:rgba(250,246,238,0.35); }
.et-footer-bottom-links { display:flex; gap:20px; }
.et-footer-bottom-links a { color:rgba(201,168,76,0.6); }
.et-footer-bottom-links a:hover { color:var(--et-gold); }

/* ============================================================
   SEARCH OVERLAY
   ============================================================ */
.et-search-overlay { position:fixed; inset:0; background:rgba(26,17,8,0.95); z-index:9999; display:flex; align-items:center; justify-content:center; opacity:0; pointer-events:none; transition:opacity 0.3s; }
.et-search-overlay.active { opacity:1; pointer-events:all; }
.et-search-overlay form { width:90%; max-width:600px; position:relative; }
.et-search-overlay input[type=search] { width:100%; padding:20px 60px 20px 24px; font-size:20px; background:rgba(255,255,255,0.1); border:1px solid rgba(201,168,76,0.4); border-radius:var(--et-radius); color:#fff; font-family:var(--et-font-body); outline:none; }
.et-search-overlay input[type=search]::placeholder { color:rgba(255,255,255,0.4); }
.et-search-overlay .et-search-close { position:absolute; top:50%; right:0; transform:translateY(-50%); background:none; border:none; color:#fff; font-size:28px; cursor:pointer; padding:12px 20px; }

/* ============================================================
   MOBILE MENU
   ============================================================ */
.et-mobile-nav {
  display:none; position:fixed; inset:0; background:var(--et-ink); z-index:998;
  flex-direction:column; padding:100px 40px 40px; overflow-y:auto;
}
.et-mobile-nav.active { display:flex; }
.et-mobile-nav .nav-menu { flex-direction:column; gap:0; }
.et-mobile-nav .nav-menu li a { font-size:24px; font-family:var(--et-font-head); font-weight:700; color:var(--et-warm-white); padding:14px 0; display:block; border-bottom:1px solid rgba(201,168,76,0.15); }
.et-mobile-nav .nav-menu li a:hover { color:var(--et-gold); }
.et-mobile-nav .sub-menu { padding-left:20px; }
.et-mobile-nav .sub-menu li a { font-size:16px; font-family:var(--et-font-body); }

/* ============================================================
   ANIMATIONS
   ============================================================ */
@keyframes et-fadeInUp { from { opacity:0; transform:translateY(32px); } to { opacity:1; transform:translateY(0); } }
.et-fade-in-up { opacity:0; transform:translateY(24px); transition:opacity 0.5s ease, transform 0.5s ease; }
.et-fade-in-up.visible { opacity:1; transform:translateY(0); }
.et-hero__left > * { animation:et-fadeInUp 0.7s ease backwards; }
.et-hero__eyebrow { animation-delay:0.1s; }
.et-hero h1 { animation-delay:0.25s; }
.et-hero__sub { animation-delay:0.38s; }
.et-hero__actions { animation-delay:0.5s; }
.et-hero__stats { animation-delay:0.62s; }

/* ============================================================
   TOAST NOTIFICATION
   ============================================================ */
.et-toast {
  position:fixed; bottom:32px; left:50%; transform:translateX(-50%) translateY(20px);
  background:var(--et-ink); color:var(--et-gold-light); padding:14px 28px;
  border-radius:var(--et-radius); font-size:14px; font-weight:600; letter-spacing:0.04em;
  z-index:9998; opacity:0; pointer-events:none; transition:all 0.3s;
  border-left:4px solid var(--et-gold); box-shadow:0 8px 32px rgba(0,0,0,0.25);
}
.et-toast.show { opacity:1; transform:translateX(-50%) translateY(0); }

/* ============================================================
   PAGE / CONTENT
   ============================================================ */
.et-page-hero { background:var(--et-cream); padding:80px 0; text-align:center; border-bottom:1px solid var(--et-border); }
.et-page-hero h1 { font-size:clamp(36px,5vw,64px); }
.et-breadcrumb { font-size:13px; color:var(--et-muted); margin-top:12px; }
.et-breadcrumb a { color:var(--et-gold); }
.et-content-area { padding:80px 0; }
.et-main-with-sidebar { display:grid; grid-template-columns:1fr 300px; gap:60px; }

/* ============================================================
   FORMS (contact, etc.)
   ============================================================ */
.et-form input, .et-form textarea, .et-form select {
  width:100%; padding:14px 18px; border:1px solid var(--et-border);
  border-radius:var(--et-radius-sm); font-size:15px; font-family:var(--et-font-body);
  background:#fff; color:var(--et-ink); transition:border-color var(--et-transition);
  outline:none;
}
.et-form input:focus, .et-form textarea:focus { border-color:var(--et-gold); box-shadow:0 0 0 3px rgba(201,168,76,0.15); }
.et-form label { font-size:13px; font-weight:600; color:var(--et-charcoal); margin-bottom:6px; display:block; letter-spacing:0.04em; text-transform:uppercase; }
.et-form-group { margin-bottom:24px; }
.et-form-row { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.woocommerce-input-wrapper input, .woocommerce-input-wrapper textarea { width:100%; }

/* ============================================================
   PAGINATION
   ============================================================ */
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span { border-color:var(--et-border); color:var(--et-ink); border-radius:var(--et-radius-sm); }
.woocommerce nav.woocommerce-pagination ul li a:hover,
.woocommerce nav.woocommerce-pagination ul li span.current { background:var(--et-gold); border-color:var(--et-gold); color:var(--et-ink); }
.navigation.pagination .nav-links { display:flex; gap:8px; justify-content:center; flex-wrap:wrap; }
.navigation.pagination .page-numbers { padding:10px 16px; border:1px solid var(--et-border); border-radius:var(--et-radius-sm); color:var(--et-ink); font-size:14px; font-weight:600; }
.navigation.pagination .page-numbers.current { background:var(--et-gold); border-color:var(--et-gold); color:var(--et-ink); }
.navigation.pagination .page-numbers:hover { border-color:var(--et-gold); color:var(--et-gold); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1100px) {
  .woocommerce ul.products { grid-template-columns:repeat(3,1fr); }
  .et-grid-4 { grid-template-columns:repeat(2,1fr); }
  .et-usp-grid { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:900px) {
  .et-hero { grid-template-columns:1fr; min-height:auto; }
  .et-hero__right { height:360px; }
  .et-hero__left { padding:60px 40px; }
  .et-hero__left::after { display:none; }
  .et-grid-3 { grid-template-columns:1fr; }
  .et-grid-2 { grid-template-columns:1fr; gap:40px; }
  .et-footer-inner { grid-template-columns:1fr 1fr; }
  .et-main-with-sidebar { grid-template-columns:1fr; }
  .widget-area { padding-left:0; padding-top:40px; }
}
@media (max-width:768px) {
  #primary-navigation { display:none; }
  .et-menu-toggle { display:flex; }
  .woocommerce ul.products { grid-template-columns:repeat(2,1fr); }
  .et-gallery-grid { grid-template-columns:repeat(3,1fr); grid-template-rows:auto; }
  .et-gallery-cell:nth-child(1), .et-gallery-cell:nth-child(4) { grid-column:span 1; grid-row:span 1; }
  .et-blog-grid { grid-template-columns:1fr; }
  .et-footer-inner { grid-template-columns:1fr; gap:40px; }
  .et-footer-bottom-bar { flex-direction:column; gap:12px; text-align:center; }
  .et-container { padding-left:20px; padding-right:20px; }
  .et-section { padding:60px 0; }
  .et-form-row { grid-template-columns:1fr; }
}
@media (max-width:480px) {
  .woocommerce ul.products { grid-template-columns:1fr; }
  .et-hero h1 { font-size:38px; }
  .et-hero__stats { flex-wrap:wrap; gap:24px; }
  .et-usp-grid { grid-template-columns:1fr; }
}
