/* ==========================================================================
   STUDIO BESPOKE — "Warm Minimalist Sovereign" design system for Flatsome
   --------------------------------------------------------------------------
   Source: Google Stitch design (DESIGN.md)
   Strategy: Override Flatsome / WooCommerce styles using design tokens below.
   All "white" = cream, all "black" = espresso brown (warm cohesive palette).
   ========================================================================== */

/* ---------- 1. DESIGN TOKENS (CSS variables) ---------- */
:root {
  /* Surfaces */
  --sb-bg:                 #fcf9f4; /* Sovereign Cream — main background */
  --sb-surface:            #fcf9f4;
  --sb-surface-low:        #f6f3ee; /* oat / inset containers */
  --sb-surface-container:  #f0ede9;
  --sb-surface-high:       #ebe8e3;
  --sb-surface-dim:        #dcdad5;

  /* Brand colors */
  --sb-primary:            #4a3728; /* espresso brown — text + primary actions */
  --sb-primary-deep:       #322214;
  --sb-on-primary:         #fcf9f4; /* cream text on brown */
  --sb-secondary:          #7e7576; /* muted stone — borders / secondary text */
  --sb-muted-stone:        #d2c4bb; /* sandstone border */
  --sb-ink:                #1c1b1b; /* near-black ink (warm) */
  --sb-accent-gold:        #c5a028; /* gold accent (badges, hovers) */
  --sb-error:              #ba1a1a;

  /* Typography */
  --sb-font-display: "Chivo", system-ui, sans-serif;
  --sb-font-body:    "Hanken Grotesk", system-ui, sans-serif;

  /* Spacing / shape */
  --sb-radius:       0.25rem; /* 4px base */
  --sb-radius-lg:    0.75rem; /* 12px cards */
  --sb-container:    1440px;
  --sb-shadow-soft:  0 20px 40px rgba(74, 55, 40, 0.06);
}

/* ---------- 2. GLOBAL BASE ---------- */
body,
body.woocommerce,
.page-wrapper {
  background-color: var(--sb-bg);
  color: var(--sb-ink);
  font-family: var(--sb-font-body);
  font-weight: 400;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4, h5,
.heading-font,
.entry-title {
  font-family: var(--sb-font-display);
  color: var(--sb-primary);
  letter-spacing: -0.01em;
}

h1 { font-weight: 900; letter-spacing: -0.03em; }
h2, h3 { font-weight: 700; }

a { color: var(--sb-primary); }
a:hover { color: var(--sb-accent-gold); }

/* Container width to match design (1440 max, generous margins) */
.container,
.container-width,
.row {
  max-width: var(--sb-container);
}

/* "Label" overline style helper (uppercase + tracking) */
.sb-label {
  font-family: var(--sb-font-body);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--sb-secondary);
}

/* ---------- 3. HEADER / NAV ---------- */
#header,
.header-wrapper,
#masthead {
  background-color: rgba(252, 249, 244, 0.9) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--sb-muted-stone);
}

#header.sb-scrolled,
.stuck #header .header-wrapper {
  box-shadow: 0 4px 30px rgba(74, 55, 40, 0.05);
}

/* Logo (text logo) styled like the design */
.header-main .logo a,
.logo a {
  font-family: var(--sb-font-display) !important;
  font-weight: 900;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: var(--sb-ink) !important;
}

/* Nav links: uppercase, tracked, secondary -> primary on hover */
.header-nav.nav > li > a,
.nav-line > li > a,
ul.nav > li > a {
  font-family: var(--sb-font-body);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--sb-secondary);
}
.header-nav.nav > li > a:hover,
.nav > li.active > a,
.nav > li.current-menu-item > a {
  color: var(--sb-primary);
}

/* Cart badge → gold like the design */
.header-cart .cart-icon strong,
li.cart-item .cart-icon strong {
  background-color: var(--sb-accent-gold) !important;
  border-color: var(--sb-accent-gold) !important;
  color: #fff !important;
}
.header-cart .cart-icon strong:after {
  border-color: var(--sb-accent-gold) !important;
}

/* ---------- 4. BUTTONS ---------- */
.button,
button,
input[type="submit"],
.woocommerce a.button,
.woocommerce button.button,
.woocommerce .button.alt,
.woocommerce #respond input#submit {
  font-family: var(--sb-font-body) !important;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-radius: var(--sb-radius) !important;
  background-color: var(--sb-primary);
  color: var(--sb-on-primary);
  border: 1px solid var(--sb-primary);
  padding: 0.95em 2.2em;
  transition: opacity .25s ease, background-color .25s ease, color .25s ease;
}
.button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce .button.alt:hover {
  opacity: 0.85;
  background-color: var(--sb-primary-deep);
  color: var(--sb-on-primary);
}

/* Secondary / outline button */
.button.is-outline,
.button.secondary.is-outline,
.woocommerce a.button.is-outline {
  background: transparent;
  color: var(--sb-primary);
  border: 1px solid var(--sb-muted-stone);
}
.button.is-outline:hover {
  background: var(--sb-primary);
  color: var(--sb-on-primary);
  border-color: var(--sb-primary);
}

/* Avoid pill buttons (design = structured) */
.button { border-radius: var(--sb-radius) !important; }

/* ---------- 5. WOOCOMMERCE — SHOP / ARCHIVE ---------- */
.woocommerce ul.products li.product .price,
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  color: var(--sb-secondary);
  font-family: var(--sb-font-body);
  font-weight: 400;
}

.woocommerce ul.products li.product h2,
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--sb-font-display);
  font-weight: 700;
  text-transform: uppercase;
  font-size: 18px;
  letter-spacing: -0.01em;
  color: var(--sb-primary);
}

/* Product cards: no harsh border, soft inset surface */
.woocommerce ul.products li.product .box-image,
.woocommerce ul.products li.product img {
  background-color: var(--sb-surface-low);
  border-radius: var(--sb-radius);
}

/* Sale flash → gold instead of default */
.woocommerce span.onsale,
.badge-inner.on-sale {
  background-color: var(--sb-accent-gold) !important;
  color: #fff !important;
  border-radius: var(--sb-radius);
  font-family: var(--sb-font-body);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* Result count / ordering */
.woocommerce .woocommerce-result-count,
.woocommerce .woocommerce-ordering select {
  font-family: var(--sb-font-body);
  color: var(--sb-secondary);
}

/* ---------- 6. WOOCOMMERCE — SINGLE PRODUCT ---------- */
.woocommerce div.product .product_title,
.single-product .product-title {
  font-family: var(--sb-font-display);
  font-weight: 700;
  text-transform: uppercase;
  color: var(--sb-ink);
}

.woocommerce div.product p.price,
.woocommerce div.product span.price {
  font-size: 20px;
  color: var(--sb-secondary);
}

/* Gallery image surfaces */
.woocommerce-product-gallery,
.woocommerce div.product div.images img {
  background-color: var(--sb-surface-low);
  border-radius: var(--sb-radius);
}

/* Variation swatches / select */
.woocommerce div.product form.cart .variations td,
.woocommerce div.product form.cart .variations th {
  font-family: var(--sb-font-body);
  letter-spacing: 0.04em;
}

/* Tabs */
.woocommerce-tabs ul.tabs li a {
  font-family: var(--sb-font-body);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 13px;
  color: var(--sb-secondary);
}
.woocommerce-tabs ul.tabs li.active a {
  color: var(--sb-primary);
}

/* Quantity box */
.quantity .qty {
  border: 1px solid var(--sb-muted-stone);
  background: var(--sb-surface-low);
  border-radius: var(--sb-radius);
  color: var(--sb-primary);
}

/* ---------- 7. WOOCOMMERCE — CART / CHECKOUT ---------- */
.woocommerce-cart table.cart,
.woocommerce table.shop_table {
  border-color: var(--sb-muted-stone);
  background: transparent;
}
.woocommerce table.shop_table th {
  font-family: var(--sb-font-body);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 12px;
  color: var(--sb-primary);
}
.woocommerce table.shop_table td {
  border-top: 1px solid rgba(210, 196, 187, 0.5);
}

.cart_totals h2,
.woocommerce .cart-collaterals h2 {
  font-family: var(--sb-font-display);
  text-transform: uppercase;
}

/* Order summary box → inset surface, soft */
.cart-collaterals .cart_totals,
.woocommerce-checkout #order_review {
  background-color: var(--sb-surface-low);
  border-radius: var(--sb-radius-lg);
  padding: 2rem;
  box-shadow: var(--sb-shadow-soft);
  border: none;
}

/* Inputs: subtle fill, bottom border emphasis */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
input[type="text"], input[type="email"],
input[type="tel"], input[type="password"],
select, textarea {
  background-color: var(--sb-surface-low) !important;
  border: 1px solid var(--sb-muted-stone) !important;
  border-radius: var(--sb-radius) !important;
  color: var(--sb-primary) !important;
}
input:focus, textarea:focus, select:focus {
  border-color: var(--sb-primary) !important;
  box-shadow: none !important;
}

/* ---------- 8. FOOTER ---------- */
.footer-wrapper,
#footer {
  background-color: var(--sb-bg);
  border-top: 1px solid var(--sb-muted-stone);
  color: var(--sb-secondary);
}
#footer a { color: var(--sb-secondary); }
#footer a:hover { color: var(--sb-accent-gold); }
#footer h3, #footer h5 {
  font-family: var(--sb-font-body);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 12px;
  font-weight: 700;
  color: var(--sb-primary);
}
.absolute-footer {
  background-color: var(--sb-bg) !important;
  color: var(--sb-secondary);
}

/* ==========================================================================
   9. CUSTOM HTML BLOCKS (for UX Builder "HTML" element)
   Classes prefixed with .sb- so they don't collide with Flatsome/Woo.
   ========================================================================== */

.sb-section { max-width: var(--sb-container); margin: 0 auto; padding: 6rem 1rem; }
@media (min-width: 768px) { .sb-section { padding: 8rem 4rem; } }

/* Hero */
.sb-hero {
  position: relative;
  min-height: 80vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: var(--sb-surface-dim);
}
.sb-hero__bg {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  filter: grayscale(100%) brightness(0.9);
}
.sb-hero.sb-animate .sb-hero__bg { animation: sb-kenburns 20s ease-out forwards; }
@keyframes sb-kenburns { 0% { transform: scale(1);} 100% { transform: scale(1.15);} }
.sb-hero__inner {
  position: relative; z-index: 2;
  max-width: var(--sb-container);
  margin: 0 auto;
  width: 100%;
  padding: 2rem 1rem;
  color: var(--sb-on-primary);
}
@media (min-width: 768px) { .sb-hero__inner { padding: 2rem 4rem; } }
.sb-hero__title {
  font-family: var(--sb-font-display);
  font-weight: 900;
  font-size: clamp(40px, 7vw, 72px);
  line-height: 1.05;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  color: var(--sb-on-primary);
  margin: 0 0 1.5rem;
  max-width: 16ch;
}
.sb-hero__text {
  font-size: 18px; max-width: 36ch; margin: 0 0 2.5rem;
  color: rgba(252, 249, 244, 0.9);
}
.sb-btn-row { display: flex; flex-wrap: wrap; gap: 1rem; }
.sb-btn {
  display: inline-block;
  font-family: var(--sb-font-body);
  font-size: 14px; font-weight: 600;
  letter-spacing: 0.1em; text-transform: uppercase;
  padding: 1.1rem 3rem;
  border-radius: var(--sb-radius);
  text-decoration: none;
  transition: opacity .25s ease, background .25s ease, color .25s ease;
}
.sb-btn--solid { background: var(--sb-primary); color: var(--sb-on-primary); }
.sb-btn--solid:hover { opacity: 0.85; color: var(--sb-on-primary); }
.sb-btn--ghost { border: 1px solid var(--sb-on-primary); color: var(--sb-on-primary); }
.sb-btn--ghost:hover { background: var(--sb-on-primary); color: var(--sb-primary); }

/* Section heading row */
.sb-head-row {
  display: flex; flex-wrap: wrap; gap: 1rem;
  justify-content: space-between; align-items: baseline;
  margin-bottom: 4rem;
}
.sb-head-row h2 {
  font-family: var(--sb-font-display);
  font-weight: 700; font-size: clamp(28px, 4vw, 40px);
  text-transform: uppercase; color: var(--sb-primary); margin: 0;
}
.sb-link-underline {
  font-family: var(--sb-font-body);
  font-size: 12px; font-weight: 700; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--sb-primary);
  border-bottom: 1px solid var(--sb-primary);
  padding-bottom: 4px; text-decoration: none;
}
.sb-link-underline:hover { color: var(--sb-accent-gold); border-color: var(--sb-accent-gold); }

/* Featured grid */
.sb-grid { display: grid; grid-template-columns: repeat(1, 1fr); gap: 24px; }
@media (min-width: 768px) { .sb-grid { grid-template-columns: repeat(12, 1fr); } }
.sb-col-8 { grid-column: span 12; }
.sb-col-4 { grid-column: span 12; }
@media (min-width: 768px) {
  .sb-col-8 { grid-column: span 8; }
  .sb-col-4 { grid-column: span 4; }
}
.sb-card { cursor: pointer; }
.sb-card__img { overflow: hidden; background: var(--sb-surface-low); margin-bottom: 1.5rem; }
.sb-card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform 1s ease; display: block; }
.sb-card:hover .sb-card__img img { transform: scale(1.1); }
.sb-card h3 {
  font-family: var(--sb-font-display); font-weight: 700;
  text-transform: uppercase; color: var(--sb-primary); margin: 0;
  font-size: clamp(20px, 2.5vw, 32px);
}
.sb-ratio-16-9 { aspect-ratio: 16 / 9; }
.sb-ratio-3-4 { aspect-ratio: 3 / 4; }

/* Studio standard / features */
.sb-features { display: grid; grid-template-columns: 1fr; gap: 3rem; }
@media (min-width: 768px) { .sb-features { grid-template-columns: repeat(3, 1fr); } }
.sb-feature__icon {
  width: 64px; height: 64px; display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--sb-muted-stone); color: var(--sb-primary);
  margin-bottom: 2rem; transition: transform .5s ease;
}
.sb-feature:hover .sb-feature__icon { transform: scale(1.1); }
.sb-feature h4 {
  font-family: var(--sb-font-display); text-transform: uppercase;
  font-size: 24px; color: var(--sb-primary); margin: 0 0 1rem;
}
.sb-feature p { color: var(--sb-secondary); }
.sb-bg-low { background: var(--sb-surface-low); }

/* Testimonial */
.sb-testimonial { background: var(--sb-primary); color: var(--sb-on-primary); }
.sb-testimonial blockquote {
  font-family: var(--sb-font-display);
  font-size: clamp(24px, 4vw, 40px); line-height: 1.2;
  font-style: italic; text-transform: uppercase;
  max-width: 50ch; margin: 0 0 3rem; border: none; padding: 0;
}
.sb-quote-mark { font-size: 4rem; color: var(--sb-accent-gold); opacity: 0.5; }
.sb-cite {
  font-family: var(--sb-font-body); font-size: 12px; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase; font-style: normal;
}
.sb-test-nav { display: flex; gap: 1rem; margin-top: 4rem; }
.sb-test-nav button {
  width: 48px; height: 48px; background: transparent;
  border: 1px solid rgba(252,249,244,0.3); color: var(--sb-on-primary);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: all .25s ease; border-radius: var(--sb-radius);
}
.sb-test-nav button:hover { border-color: var(--sb-on-primary); background: rgba(252,249,244,0.1); }
#sb-testimonial-container { transition: opacity .4s ease, transform .4s ease; }

/* ---------- 10. SCROLL REVEAL ANIMATION ---------- */
.sb-reveal {
  opacity: 0; transform: translateY(30px);
  transition: opacity 1s cubic-bezier(0.22,1,0.36,1), transform 1s cubic-bezier(0.22,1,0.36,1);
  will-change: opacity, transform;
}
.sb-reveal.sb-active { opacity: 1; transform: translateY(0); }

/* Reduce motion for accessibility */
@media (prefers-reduced-motion: reduce) {
  .sb-reveal { opacity: 1; transform: none; transition: none; }
  .sb-hero.sb-animate .sb-hero__bg { animation: none; }
}
