/*
Theme Name: AHA Avada Child
Template: Avada
Version: 1.1
Description: Avada child theme with the AHA Herbal design system. Used by custom page templates (aha-home, aha-inner, aha-contact, aha-woocommerce) and WooCommerce overrides (product, cart, checkout, thank-you).
*/

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400&family=Jost:wght@300;400;500&display=swap');

/* ============================================================
   AHA HERBAL — DESIGN TOKENS
   ============================================================ */

:root {
  --aha-ink: #1a1714;
  --aha-ink-soft: #4a4640;
  --aha-ink-muted: #8a8078;

  --aha-paper: #f7f4ef;
  --aha-paper-warm: #ede8e0;
  --aha-paper-dark: #e0d9cf;

  --aha-gold: #b8935a;
  --aha-gold-light: #d4aa72;
  --aha-gold-pale: #f0e4cc;

  /* Brand logo green — the olive/chartreuse from the AHA seal mark.
     Used sparingly: the logo itself, and small accents directly
     associated with it. NOT a section background color — it is too
     bright for large dark fills. For dark sections use --aha-green-deep. */
  --aha-olive: #7da100;

  --aha-red: #8b2e1a;
  --aha-green-deep: #1e3a2a;

  --aha-serif: "Cormorant Garamond", Georgia, serif;
  --aha-sans: "Jost", Arial, sans-serif;

  --aha-section-y: clamp(4rem, 7vw, 7rem);
  --aha-container-x: clamp(1.5rem, 5vw, 5rem);
  --aha-max-width: 1180px;
}

/* ============================================================
   AHA PAGE WRAPPER
   The aha-page class is added (via functions.php) to any page
   using an AHA template, plus all WooCommerce single product,
   cart, checkout, and order-received pages.
   ============================================================ */

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

body.aha-page {
  font-family: var(--aha-sans);
  background: var(--aha-paper);
  color: var(--aha-ink);
  font-weight: 300;
  line-height: 1.6;
  overflow-x: hidden;
  margin: 0;
}

/* Hide Avada chrome on AHA pages */
body.aha-page #wrapper_blank,
body.aha-page .fusion-page-title-bar,
body.aha-page #sliders-container,
body.aha-page .avada-page-titlebar-wrapper,
body.aha-page .fusion-header-wrapper,
body.aha-page .fusion-footer-wrapper,
body.aha-page .fusion-footer,
body.aha-page #side-header {
  display: none !important;
}
body.aha-page #main { padding: 0 !important; background: transparent !important; }
body.aha-page #wrapper { padding: 0 !important; margin: 0 !important; }
body.aha-page #main > .fusion-row { max-width: 100% !important; padding: 0 !important; margin: 0 !important; }

/* WooCommerce-specific overrides */
body.aha-product-page .woocommerce-notices-wrapper,
body.aha-cart-page .woocommerce-notices-wrapper,
body.aha-checkout-page .woocommerce-notices-wrapper,
body.aha-thankyou-page .woocommerce-notices-wrapper {
  max-width: 1200px;
  margin: 1rem auto;
  padding: 0 2.5rem;
}
body.aha-product-page .woocommerce-breadcrumb,
body.aha-cart-page .woocommerce-breadcrumb,
body.aha-checkout-page .woocommerce-breadcrumb,
body.aha-thankyou-page .woocommerce-breadcrumb { display: none !important; }
body.aha-product-page div.product { display: block !important; }

html { scroll-behavior: smooth; }

/* Wrapper used by aha-woocommerce.php */
.aha-woo-wrap { background: var(--aha-paper); }

/* ============================================================
   TYPOGRAPHY HELPERS (your originals — preserved)
   ============================================================ */

.aha-serif { font-family: var(--aha-serif); }
.aha-sans  { font-family: var(--aha-sans); }

.aha-section {
  padding: var(--aha-section-y) var(--aha-container-x);
  background: var(--aha-paper);
  color: var(--aha-ink);
}
.aha-section-warm { background: var(--aha-paper-warm); }
.aha-section-dark { background: var(--aha-green-deep); color: var(--aha-paper); }
.aha-container { max-width: var(--aha-max-width); margin: 0 auto; }

.aha-eyebrow {
  font-family: var(--aha-sans);
  font-size: 0.68rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--aha-gold);
  font-weight: 400;
  margin-bottom: 1.25rem;
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.aha-eyebrow::before {
  content: "";
  width: 1.5rem;
  height: 1px;
  background: var(--aha-gold);
  display: block;
}
/* Centered variant (used in section headers) */
.aha-eyebrow-center {
  justify-content: center;
  display: inline-flex;
  margin-left: auto;
  margin-right: auto;
}
.aha-eyebrow-center::after {
  content: "";
  width: 1.5rem;
  height: 1px;
  background: var(--aha-gold);
  display: block;
}

.aha-title {
  font-family: var(--aha-serif);
  font-size: clamp(2.3rem, 4.5vw, 5rem);
  font-weight: 300;
  line-height: 1.05;
  letter-spacing: -0.01em;
  color: var(--aha-ink);
}
.aha-title em,
.aha-section .aha-title em {
  color: var(--aha-gold) !important;
  font-style: italic !important;
}
.aha-section-dark .aha-title { color: var(--aha-paper); }

.aha-body {
  font-family: var(--aha-sans);
  font-size: 1rem;
  font-weight: 300;
  line-height: 1.75;
  color: var(--aha-ink-soft);
}
.aha-section-dark .aha-body { color: rgba(247, 244, 239, 0.75); }

/* Section title variants used in templates */
.aha-section-eyebrow {
  font-size: .67rem; letter-spacing: .22em; text-transform: uppercase;
  color: var(--aha-gold); font-weight: 400; margin-bottom: 1.25rem;
  display: flex; align-items: center; gap: .75rem;
}
.aha-section-eyebrow::before {
  content: ''; width: 1.5rem; height: 1px;
  background: var(--aha-gold); display: block;
}
.aha-section-title {
  font-family: var(--aha-serif);
  font-size: clamp(2.2rem, 3.5vw, 3.2rem);
  font-weight: 300;
  line-height: 1.1;
  color: var(--aha-ink);
  margin-bottom: 1.5rem;
  letter-spacing: -.01em;
}
.aha-section-title em { font-style: italic; color: var(--aha-gold); }
.aha-section-body {
  font-size: .95rem;
  color: var(--aha-ink-soft);
  line-height: 1.85;
  margin-bottom: 2rem;
  font-weight: 300;
}

/* ============================================================
   BUTTONS (your originals + variations used in templates)
   ============================================================ */

.aha-btn {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 1rem 2.25rem !important;
  text-decoration: none !important;
  font-family: var(--aha-sans) !important;
  font-size: 0.72rem !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  font-weight: 400;
  line-height: 1;
  border-radius: 0 !important;
  cursor: pointer;
  transition: background 0.25s ease, color 0.25s ease, border-color 0.25s ease, transform 0.15s ease;
}
.aha-btn:hover { transform: translateY(-1px); }

.aha-btn-primary,
.aha-section a.aha-btn-primary,
.aha-section a.aha-btn-primary:visited {
  background: var(--aha-green-deep) !important;
  color: var(--aha-paper) !important;
  border: 1px solid var(--aha-green-deep) !important;
}
.aha-btn-primary:hover {
  background: var(--aha-gold) !important;
  color: var(--aha-ink) !important;
  border-color: var(--aha-gold) !important;
}

.aha-btn-secondary,
.aha-section a.aha-btn-secondary,
.aha-section a.aha-btn-secondary:visited {
  background: transparent !important;
  color: var(--aha-ink) !important;
  border: 1px solid rgba(26,23,20,0.25) !important;
}
.aha-btn-secondary:hover {
  color: var(--aha-gold) !important;
  border-color: var(--aha-gold) !important;
}

/* Light button — used on dark backgrounds */
.aha-btn-light {
  background: var(--aha-paper) !important;
  color: var(--aha-ink) !important;
  border: 1px solid var(--aha-paper) !important;
}
.aha-btn-light:hover {
  background: var(--aha-gold) !important;
  color: var(--aha-ink) !important;
  border-color: var(--aha-gold) !important;
}

/* Outline variant used in cart/checkout */
.aha-btn-outline {
  background: transparent;
  color: var(--aha-ink);
  padding: .85rem 1.5rem;
  font-family: var(--aha-sans);
  font-size: .7rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  font-weight: 400;
  border: 1px solid rgba(26,23,20,0.3);
  cursor: pointer;
  border-radius: 0;
  transition: all .2s;
  text-decoration: none;
  display: inline-block;
}
.aha-btn-outline:hover { border-color: var(--aha-gold); color: var(--aha-gold); }

/* ============================================================
   CARDS (your original)
   ============================================================ */

.aha-card {
  background: var(--aha-paper);
  border: 1px solid rgba(184, 147, 90, 0.22);
  padding: clamp(1.5rem, 3vw, 2.5rem);
}
.aha-card-title {
  font-family: var(--aha-serif);
  font-size: 1.4rem;
  font-weight: 400;
  color: var(--aha-ink);
  line-height: 1.2;
}

/* ============================================================
   NAV (shared header)
   ============================================================ */

.aha-nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 9999;
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.25rem 2.5rem;
  background: rgba(247,244,239,0.92);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(184,147,90,0.2);
  transition: all 0.3s ease;
}
.aha-nav-logo {
  font-family: var(--aha-serif);
  font-size: 1.3rem; font-weight: 500;
  letter-spacing: .12em;
  color: var(--aha-ink); text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: .6rem;
}
.aha-nav-logo .aha-seal {
  width: 38px;
  height: 38px;
  display: block;
  flex-shrink: 0;
}
.aha-nav-logo .aha-nav-logo-text { font-style: normal; }
.aha-nav-logo em { color: var(--aha-gold); font-style: normal; }
.aha-nav-links {
  display: flex; gap: 2.5rem; list-style: none;
  align-items: center; margin: 0; padding: 0;
}
.aha-nav-links a {
  font-size: .75rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--aha-ink-soft); text-decoration: none; font-weight: 400;
  transition: color .2s;
}
.aha-nav-links a:hover,
.aha-nav-links a.current { color: var(--aha-gold); }
.aha-nav-cta {
  background: var(--aha-ink) !important;
  color: var(--aha-paper) !important;
  padding: .55rem 1.4rem !important;
  border-radius: 0 !important;
  font-size: .72rem !important;
  letter-spacing: .16em !important;
  transition: background .2s !important;
}
.aha-nav-cta:hover {
  background: var(--aha-gold) !important;
  color: var(--aha-ink) !important;
}
.aha-nav-cart {
  font-size: .72rem; letter-spacing: .12em; text-transform: uppercase;
  color: var(--aha-ink-soft); text-decoration: none;
  display: flex; align-items: center; gap: .35rem;
}
.aha-nav-cart .count {
  background: var(--aha-gold); color: var(--aha-paper);
  min-width: 18px; height: 18px; padding: 0 5px;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: .65rem; border-radius: 50%;
}

/* Products dropdown */
.aha-nav-dropdown { position: relative; }
.aha-nav-dropdown-toggle {
  display: inline-flex !important;
  align-items: center;
  gap: .3rem;
  cursor: pointer;
}
.aha-nav-caret {
  font-size: .55rem;
  transition: transform .2s ease;
  display: inline-block;
  margin-top: 2px;
}
.aha-nav-dropdown:hover .aha-nav-caret,
.aha-nav-dropdown.is-open .aha-nav-caret { transform: rotate(180deg); }

.aha-nav-submenu {
  position: absolute;
  top: 100%;
  left: -1rem;
  min-width: 280px;
  background: var(--aha-paper);
  border: 1px solid rgba(184,147,90,0.2);
  margin: 0;
  padding: .75rem 0;
  list-style: none;
  box-shadow: 0 12px 32px rgba(26,23,20,0.08);
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: opacity .2s ease, transform .2s ease, visibility .2s;
  z-index: 100;
}
.aha-nav-dropdown:hover .aha-nav-submenu,
.aha-nav-dropdown.is-open .aha-nav-submenu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.aha-nav-submenu li { margin: 0; }
.aha-nav-submenu a {
  display: block !important;
  padding: .9rem 1.25rem !important;
  text-transform: none !important;
  letter-spacing: normal !important;
  font-size: .9rem !important;
  text-decoration: none;
  transition: background .15s ease, color .15s ease;
}
.aha-nav-submenu a:hover {
  background: var(--aha-paper-warm);
  color: var(--aha-ink) !important;
}
.aha-submenu-name {
  font-family: var(--aha-serif);
  font-size: 1.1rem;
  font-weight: 400;
  color: var(--aha-ink);
  display: block;
  line-height: 1.2;
}
.aha-submenu-sub {
  font-size: .68rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--aha-ink-muted);
  display: block;
  margin-top: .2rem;
}
.aha-submenu-divider {
  height: 1px;
  background: var(--aha-paper-dark);
  margin: .5rem 1.25rem;
}
.aha-submenu-all {
  font-family: var(--aha-sans) !important;
  font-size: .7rem !important;
  letter-spacing: .14em !important;
  text-transform: uppercase !important;
  color: var(--aha-gold) !important;
  padding: .75rem 1.25rem !important;
}
.aha-submenu-all:hover { color: var(--aha-ink) !important; }

/* Page wrap below fixed nav */
.aha-page-wrap { padding-top: 80px; min-height: calc(100vh - 80px); }

/* ============================================================
   INNER PAGE HERO (centered title + eyebrow)
   ============================================================ */

.aha-page-hero {
  padding: 6rem 2rem 4rem;
  background: var(--aha-paper);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.aha-page-hero::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 50% 70% at 50% 60%, rgba(184,147,90,0.06) 0%, transparent 70%);
  pointer-events: none;
}
.aha-page-hero .eyebrow {
  font-size: .72rem; letter-spacing: .22em; text-transform: uppercase;
  color: var(--aha-gold); font-weight: 400; margin-bottom: 1.25rem;
  display: inline-flex; align-items: center; gap: .75rem;
  position: relative; z-index: 1;
}
.aha-page-hero .eyebrow::before,
.aha-page-hero .eyebrow::after {
  content: ''; display: block; width: 2rem; height: 1px; background: var(--aha-gold);
}
.aha-page-hero h1 {
  font-family: var(--aha-serif);
  font-size: clamp(2.6rem, 5vw, 4.2rem);
  font-weight: 300; line-height: 1.1;
  color: var(--aha-ink); margin-bottom: 1.25rem;
  letter-spacing: -.01em; position: relative; z-index: 1;
}
.aha-page-hero h1 em { font-style: italic; color: var(--aha-gold); }
.aha-page-hero .lede {
  max-width: 600px; margin: 0 auto;
  font-size: 1.05rem; color: var(--aha-ink-soft);
  line-height: 1.75; font-weight: 300;
  position: relative; z-index: 1;
}

/* ============================================================
   LONG-FORM CONTENT (inner pages — About, Learn, Legal)
   ============================================================ */

.aha-content {
  max-width: 760px;
  margin: 0 auto;
  padding: 4rem 2rem 6rem;
  font-size: 1rem; line-height: 1.85;
  color: var(--aha-ink-soft); font-weight: 300;
}
.aha-content h2 {
  font-family: var(--aha-serif);
  font-size: clamp(1.8rem, 2.5vw, 2.4rem);
  font-weight: 400; color: var(--aha-ink);
  margin: 3rem 0 1rem;
  line-height: 1.2; letter-spacing: -.01em;
}
.aha-content h2 em { font-style: italic; color: var(--aha-gold); }
.aha-content h3 {
  font-family: var(--aha-serif); font-size: 1.4rem; font-weight: 400;
  color: var(--aha-ink); margin: 2rem 0 .75rem;
}
.aha-content p { margin-bottom: 1.25rem; }
.aha-content a {
  color: var(--aha-gold); text-decoration: underline; text-underline-offset: 3px;
}
.aha-content a:hover { color: var(--aha-ink); }
.aha-content ul, .aha-content ol { margin: 0 0 1.5rem 1.5rem; }
.aha-content li { margin-bottom: .5rem; }
.aha-content blockquote {
  border-left: 2px solid var(--aha-gold);
  padding-left: 1.5rem; margin: 2rem 0;
  font-family: var(--aha-serif); font-style: italic; font-size: 1.15rem;
  color: var(--aha-ink); line-height: 1.6;
}
.aha-content img { max-width: 100%; height: auto; margin: 2rem 0; }
.aha-content hr {
  border: none; height: 1px;
  background: var(--aha-paper-dark); margin: 3rem 0;
}

/* ============================================================
   FADE-IN ANIMATION (used across all pages)
   ============================================================ */

.fade-in {
  opacity: 0; transform: translateY(24px);
  transition: opacity .7s ease, transform .7s ease;
}
.fade-in.visible { opacity: 1; transform: none; }

/* ============================================================
   FOOTER (shared)
   ============================================================ */

.aha-footer {
  background: var(--aha-ink); color: rgba(247,244,239,0.7);
  padding: 4rem 5rem 2rem;
}
.aha-footer-grid {
  display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 3rem;
  margin-bottom: 3rem;
}
.aha-footer-brand .footer-logo {
  font-family: var(--aha-serif); font-size: 1.4rem; font-weight: 500;
  color: var(--aha-paper); letter-spacing: .1em;
  display: inline-flex; align-items: center; gap: .65rem;
  margin-bottom: 1rem;
}
.aha-footer-brand .footer-logo .aha-seal {
  width: 42px;
  height: 42px;
  display: block;
  flex-shrink: 0;
}
.aha-footer-brand .footer-logo .footer-logo-text { font-style: normal; }
.aha-footer-brand .footer-logo em { color: var(--aha-gold-light); font-style: normal; }
.aha-footer-brand p { font-size: .83rem; line-height: 1.7; max-width: 260px; margin: 0; }
.aha-footer-col h4 {
  font-size: .65rem; letter-spacing: .2em; text-transform: uppercase;
  color: var(--aha-gold-light); margin: 0 0 1rem; font-weight: 400;
}
.aha-footer-col ul { list-style: none; margin: 0; padding: 0; }
.aha-footer-col ul li { margin-bottom: .5rem; }
.aha-footer-col ul li a {
  font-size: .83rem; color: rgba(247,244,239,0.6); text-decoration: none;
  transition: color .2s;
}
.aha-footer-col ul li a:hover { color: var(--aha-gold-light); }
.aha-footer-bottom {
  border-top: 1px solid rgba(247,244,239,0.1);
  padding-top: 1.5rem;
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 1rem;
}
.aha-footer-bottom p { font-size: .72rem; color: rgba(247,244,239,0.35); margin: 0; }
.aha-footer-disclaimer {
  font-size: .65rem; color: rgba(247,244,239,0.25);
  max-width: 700px; line-height: 1.5; text-align: right;
}

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

@media (max-width: 900px) {
  .aha-nav { padding: 1rem 1.5rem; }
  .aha-nav-links { gap: 1.5rem; }
  .aha-page-hero { padding: 4rem 1.5rem 3rem; }
  .aha-content { padding: 3rem 1.5rem 5rem; }
  .aha-footer { padding: 3rem 2rem 2rem; }
  .aha-footer-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 800px) {
  .aha-section { padding: 4rem 1.5rem; }
  .aha-title { font-size: clamp(2.2rem, 12vw, 3.4rem); }
  .aha-btn { width: 100%; }
}

@media (max-width: 600px) {
  .aha-nav-links { gap: 1rem; }
  .aha-nav-links li.hide-mobile { display: none; }
  .aha-footer-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   ABOUT PAGE — aha-about.php template
   Scoped under .aha-about so these rules only affect that page.
   ============================================================ */

.aha-about .aha-text-center { text-align: center; }
.aha-about .aha-max-prose { max-width: 640px; margin-left: auto; margin-right: auto; }

/* Shared figure styling */
.aha-about .aha-figure { margin: 0; position: relative; }
.aha-about .aha-figure img {
  width: 100%; height: auto; display: block;
  filter: drop-shadow(0 16px 40px rgba(26,23,20,0.10));
}
.aha-about .aha-figure figcaption {
  font-size: .72rem; letter-spacing: .08em; text-transform: uppercase;
  color: var(--aha-ink-muted); margin-top: 1rem;
  text-align: center; font-weight: 400; line-height: 1.5;
}

/* POSITIONING STATEMENT */
.aha-about-positioning {
  background: var(--aha-paper);
  padding: 5rem 2rem 4rem;
  text-align: center;
  border-bottom: 1px solid var(--aha-paper-dark);
}
.aha-about-positioning-inner { max-width: 760px; margin: 0 auto; }
.aha-positioning-eyebrow {
  font-size: .7rem; letter-spacing: .22em; text-transform: uppercase;
  color: var(--aha-gold); font-weight: 400; margin-bottom: 1.75rem;
  display: inline-flex; align-items: center; gap: .75rem;
}
.aha-positioning-eyebrow::before,
.aha-positioning-eyebrow::after {
  content: ''; display: block; width: 2rem; height: 1px; background: var(--aha-gold);
}
.aha-positioning-line {
  font-family: var(--aha-serif);
  font-size: clamp(2rem, 3.5vw, 3rem);
  font-weight: 300; line-height: 1.25;
  color: var(--aha-ink); letter-spacing: -.01em;
  margin-bottom: 1.75rem;
}
.aha-positioning-line em { font-style: italic; color: var(--aha-gold); }
.aha-positioning-body {
  font-size: 1rem; color: var(--aha-ink-soft);
  line-height: 1.85; font-weight: 300;
  max-width: 540px; margin: 0 auto;
}

/* ORIGIN */
.aha-about-origin {
  background: var(--aha-paper-warm);
  padding: 6rem 2rem;
}
.aha-about-origin-inner {
  max-width: 1100px; margin: 0 auto;
  display: grid; grid-template-columns: 1.3fr 1fr;
  gap: 4rem; align-items: center;
}
.aha-about-origin-text .aha-section-body strong {
  color: var(--aha-ink); font-weight: 500;
}
.aha-about-origin-text .aha-section-body em {
  color: var(--aha-gold); font-style: italic;
}
.aha-about-portrait-inline {
  display: inline-flex; flex-direction: column; gap: .35rem;
  padding: 1.5rem 2rem; margin-top: 2rem;
  border-left: 1px solid var(--aha-gold);
  background: rgba(247,244,239,0.6);
}
.aha-about-portrait-inline .dates {
  font-size: .68rem; letter-spacing: .22em; text-transform: uppercase;
  color: var(--aha-gold); font-weight: 400;
}
.aha-about-portrait-inline .char {
  font-family: var(--aha-serif); font-size: 2.5rem;
  color: var(--aha-ink); font-weight: 300;
  line-height: 1; letter-spacing: .05em;
}
.aha-about-portrait-inline .role {
  font-size: .85rem; color: var(--aha-ink-muted);
  line-height: 1.5; margin-top: .25rem;
}
.aha-about-portrait-inline .role em {
  font-style: italic; color: var(--aha-ink);
}
.aha-about-origin-image .aha-figure img {
  background: var(--aha-paper); padding: 1rem;
}

/* PULL QUOTE */
.aha-about-pullquote {
  background: var(--aha-paper);
  padding: 5rem 2rem;
  text-align: center;
}
.aha-about-pullquote blockquote {
  font-family: var(--aha-serif);
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  font-weight: 300; line-height: 1.4;
  color: var(--aha-ink);
  max-width: 780px; margin: 0 auto;
  padding: 0; border: none; position: relative;
}
.aha-about-pullquote blockquote::before,
.aha-about-pullquote blockquote::after {
  content: ''; display: block; width: 3rem; height: 1px;
  background: var(--aha-gold); margin: 0 auto 2rem;
}
.aha-about-pullquote blockquote::after { margin: 2rem auto 0; }
.aha-about-pullquote blockquote em { font-style: italic; color: var(--aha-gold); }

/* ARCHIVE */
.aha-about-archive {
  background: var(--aha-paper-warm);
  padding: 6rem 2rem;
}
.aha-about-archive-inner { max-width: 1100px; margin: 0 auto; }
.aha-about-archive .aha-eyebrow-center,
.aha-about-translation .aha-eyebrow-center {
  justify-content: center; display: inline-flex; align-items: center;
}
.aha-about-archive .aha-section-eyebrow::after,
.aha-about-translation .aha-section-eyebrow::after {
  content: ''; width: 1.5rem; height: 1px;
  background: var(--aha-gold); display: block;
}
.aha-about-archive .aha-section-eyebrow,
.aha-about-translation .aha-section-eyebrow { margin-bottom: 1.25rem; }
.aha-about-archive .aha-section-title { margin-bottom: 1.5rem; }
.aha-archive-stats {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 0; margin: 3rem 0;
  border: 1px solid var(--aha-paper-dark);
  background: var(--aha-paper);
}
.aha-archive-stat {
  padding: 2.5rem 1.5rem; text-align: center;
  border-right: 1px solid var(--aha-paper-dark);
}
.aha-archive-stat:last-child { border-right: none; }
.aha-archive-stat .num {
  font-family: var(--aha-serif);
  font-size: clamp(2.5rem, 4vw, 3.5rem);
  font-weight: 300; color: var(--aha-ink);
  line-height: 1; display: block;
  margin-bottom: .75rem; letter-spacing: -.01em;
}
.aha-archive-stat .label {
  font-size: .7rem; letter-spacing: .2em; text-transform: uppercase;
  color: var(--aha-gold); display: block;
  margin-bottom: .5rem; font-weight: 400;
}
.aha-archive-stat .sub {
  font-size: .85rem; color: var(--aha-ink-muted);
  display: block; line-height: 1.5; font-weight: 300;
}
.aha-archive-footnote { margin-top: 2rem; }
.aha-archive-footnote em { color: var(--aha-gold); font-style: italic; }

/* TRANSLATION */
.aha-about-translation {
  background: var(--aha-paper);
  padding: 6rem 2rem;
}
.aha-about-translation-inner { max-width: 1100px; margin: 0 auto; }
.aha-translation-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem; margin-top: 3rem;
}
.aha-translation-card {
  background: var(--aha-paper-warm);
  padding: 2.5rem 2rem;
  position: relative; overflow: hidden;
  transition: transform .25s ease, border-color .25s ease;
  border: 1px solid transparent;
}
.aha-translation-card:hover {
  transform: translateY(-3px);
  border-color: var(--aha-gold);
}
.aha-translation-card .numeral {
  font-family: var(--aha-serif); font-size: 3rem;
  color: var(--aha-gold); font-weight: 300;
  line-height: 1; display: block;
  margin-bottom: 1rem; letter-spacing: .05em;
}
.aha-translation-card h3 {
  font-family: var(--aha-serif); font-size: 1.6rem;
  font-weight: 400; color: var(--aha-ink);
  margin-bottom: 1rem; line-height: 1.2;
}
.aha-translation-card p {
  font-size: .92rem; color: var(--aha-ink-soft);
  line-height: 1.7; font-weight: 300; margin: 0;
}

/* FORGED IN HISTORY */
.aha-about-forged {
  background: var(--aha-paper-warm);
  padding: 6rem 2rem;
}
.aha-about-forged-inner {
  max-width: 1100px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 1.2fr;
  gap: 4rem; align-items: center;
}
.aha-about-forged-image .aha-figure img {
  background: var(--aha-paper);
}

/* CLOSING — dark with product backdrop */
.aha-about-closing {
  background-color: var(--aha-green-deep);
  background-image: url('https://i0.wp.com/ahaherbal.com/wp-content/uploads/2026/02/Shield-All-Water-shot.png?fit=1024%2C1024&ssl=1');
  background-repeat: no-repeat;
  background-position: right -6% center;
  background-size: 46% auto;
  color: var(--aha-paper);
  padding: 6rem 2rem;
  text-align: center;
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.aha-about-closing::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    var(--aha-green-deep) 30%,
    rgba(30,58,42,0.86) 60%,
    rgba(30,58,42,0.78) 100%
  );
  z-index: 0;
  pointer-events: none;
}
.aha-about-closing::before {
  content: '蘭茂';
  position: absolute;
  font-family: var(--aha-serif);
  font-size: 22rem;
  color: rgba(212,170,114,0.07);
  line-height: 1;
  left: -5%; top: 50%;
  transform: translateY(-50%);
  pointer-events: none; user-select: none;
  letter-spacing: .1em;
  z-index: 1;
}
.aha-about-closing-inner {
  max-width: 760px; margin: 0 auto;
  position: relative; z-index: 2;
}
.aha-closing-eyebrow {
  font-size: .7rem; letter-spacing: .22em; text-transform: uppercase;
  color: var(--aha-gold-light); font-weight: 400; margin-bottom: 1.75rem;
  display: inline-flex; align-items: center; gap: .75rem;
}
.aha-closing-eyebrow::before,
.aha-closing-eyebrow::after {
  content: ''; display: block; width: 2rem; height: 1px;
  background: var(--aha-gold-light);
}
.aha-closing-statement {
  font-family: var(--aha-serif);
  font-size: clamp(2rem, 4vw, 3.2rem);
  font-weight: 300; line-height: 1.25;
  color: var(--aha-paper); margin-bottom: 1.5rem;
  letter-spacing: -.01em;
}
.aha-closing-statement em {
  font-style: italic; color: var(--aha-gold-light);
}
.aha-closing-body {
  font-size: 1.05rem;
  color: rgba(247,244,239,0.75);
  font-weight: 300; line-height: 1.7;
  max-width: 520px; margin: 0 auto 2.5rem;
}
.aha-closing-cta-row {
  display: inline-flex; gap: 1rem;
  flex-wrap: wrap; justify-content: center;
}
.aha-btn-on-dark {
  color: var(--aha-paper) !important;
  border-color: rgba(247,244,239,0.3) !important;
}
.aha-btn-on-dark:hover {
  color: var(--aha-gold-light) !important;
  border-color: var(--aha-gold-light) !important;
}

/* ABOUT — RESPONSIVE */
@media (max-width: 900px) {
  .aha-about-positioning { padding: 4rem 1.5rem 3rem; }
  .aha-about-origin,
  .aha-about-archive,
  .aha-about-translation,
  .aha-about-forged,
  .aha-about-closing { padding: 4rem 1.5rem; }
  .aha-about-origin-inner,
  .aha-about-forged-inner {
    grid-template-columns: 1fr;
    gap: 3rem;
  }
  .aha-about-forged-inner .aha-about-forged-image { order: -1; }
  .aha-archive-stats { grid-template-columns: 1fr; }
  .aha-archive-stat {
    border-right: none;
    border-bottom: 1px solid var(--aha-paper-dark);
  }
  .aha-archive-stat:last-child { border-bottom: none; }
  .aha-translation-grid { grid-template-columns: 1fr; }
  .aha-about-pullquote { padding: 4rem 1.5rem; }
  .aha-about-closing {
    background-position: right -30% center;
    background-size: 80% auto;
  }
  .aha-about-closing::after {
    background: rgba(30,58,42,0.88);
  }
  .aha-about-portrait-inline {
    width: 100%;
    box-sizing: border-box;
  }
}

/* ============================================================
   SINGLE PRODUCT PAGE — content-single-product.php
   Long-scroll narrative PDP. All selectors prefixed .aha-pdp-*.
   Buy box selectors also target WooCommerce's standard summary
   output classes (.summary form.cart, .summary .price, etc.)
   so the gallery, add-to-cart form, variations, and subscriptions
   render correctly inside our shell.
   ============================================================ */

.aha-pdp {
  font-family: var(--aha-sans);
  color: var(--aha-ink);
  background: var(--aha-paper);
  width: 100%;
  overflow: hidden;
}
.aha-pdp * { box-sizing: border-box; }

/* ---- HERO ---- */
.aha-pdp-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 620px;
  background: var(--aha-paper);
}
.aha-pdp-visual {
  background: linear-gradient(135deg, var(--aha-paper-warm), var(--aha-paper-dark));
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(3rem, 6vw, 5rem);
  overflow: hidden;
}
.aha-pdp[data-product-slug="shield-her"] .aha-pdp-visual {
  background: linear-gradient(135deg, #f0e8dc, #e4d5c4);
}
.aha-pdp-char-bg {
  position: absolute;
  right: 5%; top: 50%; transform: translateY(-50%);
  font-family: var(--aha-serif);
  font-size: clamp(12rem, 22vw, 22rem);
  color: rgba(184,147,90,0.10);
  line-height: 1;
  pointer-events: none;
  user-select: none;
  writing-mode: vertical-rl;
  z-index: 0;
}

/* WooCommerce gallery rendered inside .aha-pdp-visual */
.aha-pdp-visual .woocommerce-product-gallery {
  position: relative; z-index: 2;
  width: min(390px, 78%) !important;
  max-width: 100%;
  margin: 0 !important;
}
.aha-pdp-visual .woocommerce-product-gallery__wrapper { margin: 0 !important; }
.aha-pdp-visual .woocommerce-product-gallery__image img {
  filter: drop-shadow(0 24px 64px rgba(26,23,20,0.14));
  max-width: 100%; height: auto;
}
.aha-pdp-visual .flex-control-thumbs {
  display: flex !important; gap: .5rem;
  margin-top: 1.5rem !important;
  padding: 0 !important; list-style: none;
  justify-content: center;
}
.aha-pdp-visual .flex-control-thumbs li { width: 56px !important; margin: 0 !important; }
.aha-pdp-visual .flex-control-thumbs img {
  border: 1px solid transparent;
  background: var(--aha-paper);
  padding: 4px; cursor: pointer; opacity: .6;
  transition: opacity .2s, border-color .2s;
}
.aha-pdp-visual .flex-control-thumbs img:hover,
.aha-pdp-visual .flex-control-thumbs img.flex-active {
  opacity: 1; border-color: var(--aha-gold);
}
.aha-pdp-visual .woocommerce-product-gallery__trigger {
  position: absolute; top: 1.5rem; right: 1.5rem;
  background: var(--aha-paper); color: var(--aha-ink);
  font-size: .68rem; letter-spacing: .12em; text-transform: uppercase;
  padding: .4rem .7rem; text-decoration: none; z-index: 3;
  border: 1px solid var(--aha-paper-dark);
  transition: border-color .2s, color .2s;
}
.aha-pdp-visual .woocommerce-product-gallery__trigger:hover {
  border-color: var(--aha-gold); color: var(--aha-gold);
}

/* ---- BUY BOX ---- */
.aha-pdp-summary {
  padding: clamp(3rem, 6vw, 5rem);
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: var(--aha-paper);
  scroll-margin-top: 100px;
}
.aha-pdp-eyebrow {
  font-size: .66rem;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--aha-gold);
  margin-bottom: 1.1rem;
  font-weight: 400;
}

/* WC product title — restyled */
.aha-pdp-summary .product_title,
.aha-pdp-summary h1.entry-title {
  font-family: var(--aha-serif) !important;
  font-size: clamp(3rem, 5vw, 5rem) !important;
  font-weight: 300 !important;
  line-height: .95 !important;
  letter-spacing: -.02em !important;
  color: var(--aha-ink) !important;
  margin: 0 0 1.25rem !important;
}

/* WC rating */
.aha-pdp-summary .woocommerce-product-rating {
  margin: 0 0 1rem !important;
  display: flex; align-items: center; gap: .5rem;
}
.aha-pdp-summary .woocommerce-product-rating .star-rating { color: var(--aha-gold) !important; }
.aha-pdp-summary .woocommerce-product-rating .woocommerce-review-link {
  font-size: .8rem; color: var(--aha-ink-muted); text-decoration: none;
}

/* WC price */
.aha-pdp-summary .price {
  font-family: var(--aha-serif) !important;
  font-size: 2.35rem !important;
  font-weight: 400 !important;
  color: var(--aha-ink) !important;
  margin: 0 0 .25rem !important;
  display: block !important;
}
.aha-pdp-summary .price .woocommerce-Price-currencySymbol {
  font-size: .7em; vertical-align: top; margin-right: .1em;
}
.aha-pdp-summary .price del {
  color: var(--aha-ink-muted) !important;
  font-size: 1.5rem !important; margin-right: .5rem !important;
}
.aha-pdp-summary .price ins {
  text-decoration: none !important; color: var(--aha-ink) !important; background: none !important;
}

/* Per-day chip + supply label injected by functions.php — restyled to sit
   between price and short description, with a top border. */
.aha-pdp-summary .aha-pdp-price-meta {
  display: flex; align-items: baseline; gap: .9rem;
  flex-wrap: wrap;
  padding-top: 1.25rem;
  border-top: 1px solid var(--aha-paper-dark);
  margin: 1.5rem 0 1.5rem;
}
.aha-pdp-summary .aha-pdp-perday {
  font-size: .72rem; letter-spacing: .1em; text-transform: uppercase;
  color: var(--aha-gold); background: var(--aha-gold-pale);
  padding: .35rem .65rem;
}
.aha-pdp-summary .aha-pdp-perday .woocommerce-Price-amount {
  color: var(--aha-gold) !important;
}
.aha-pdp-summary .aha-pdp-supply {
  font-size: .68rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--aha-ink-muted); margin-left: auto;
}

/* WC short description */
.aha-pdp-summary .woocommerce-product-details__short-description {
  max-width: 430px;
  color: var(--aha-ink-soft);
  font-size: 1rem; line-height: 1.85;
  font-weight: 300;
  margin: 0 0 1.75rem;
}

/* WC add-to-cart form */
.aha-pdp-summary form.cart {
  display: flex; gap: .75rem;
  align-items: stretch;
  margin: 0 0 1.25rem !important;
  flex-wrap: wrap;
}
.aha-pdp-summary form.cart .quantity { margin: 0 !important; }
.aha-pdp-summary form.cart .quantity input.qty {
  width: 64px; min-height: 56px;
  padding: 1rem .5rem;
  border: 1px solid var(--aha-paper-dark);
  background: var(--aha-paper);
  color: var(--aha-ink);
  font-family: var(--aha-sans); font-size: 1rem;
  text-align: center; outline: none;
  border-radius: 0;
  transition: border-color .2s;
  -moz-appearance: textfield;
}
.aha-pdp-summary form.cart .quantity input.qty:focus { border-color: var(--aha-gold); }
.aha-pdp-summary form.cart .quantity input.qty::-webkit-outer-spin-button,
.aha-pdp-summary form.cart .quantity input.qty::-webkit-inner-spin-button {
  -webkit-appearance: none; margin: 0;
}
.aha-pdp-summary form.cart button.single_add_to_cart_button,
.aha-pdp-summary form.cart button.button {
  flex: 1; min-width: 200px; min-height: 56px;
  background: var(--aha-ink) !important;
  color: var(--aha-paper) !important;
  border: 1px solid var(--aha-ink) !important;
  border-radius: 0 !important;
  padding: 1rem 2rem !important;
  font-family: var(--aha-sans) !important;
  font-size: .72rem !important;
  letter-spacing: .18em !important;
  text-transform: uppercase !important;
  font-weight: 400 !important;
  cursor: pointer;
  transition: background .2s, transform .15s !important;
  line-height: 1.2;
}
.aha-pdp-summary form.cart button.single_add_to_cart_button:hover,
.aha-pdp-summary form.cart button.button:hover {
  background: var(--aha-green-deep) !important;
  border-color: var(--aha-green-deep) !important;
  transform: translateY(-1px);
}

/* WC variations */
.aha-pdp-summary .variations { margin-bottom: 1.5rem !important; }
.aha-pdp-summary .variations th {
  font-size: .68rem !important;
  letter-spacing: .14em !important;
  text-transform: uppercase !important;
  color: var(--aha-ink-muted) !important;
  font-weight: 400 !important;
  padding: .5rem 1rem .5rem 0 !important;
  background: none !important;
}
.aha-pdp-summary .variations select {
  padding: .75rem 1rem !important;
  border: 1px solid var(--aha-paper-dark) !important;
  background: var(--aha-paper) !important;
  font-family: var(--aha-sans) !important;
  font-size: .9rem !important;
  color: var(--aha-ink) !important;
  border-radius: 0 !important;
}

/* WC product meta */
.aha-pdp-summary .product_meta {
  font-size: .68rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--aha-ink-muted);
  padding-top: 1rem;
  margin-top: 1rem;
}
.aha-pdp-summary .product_meta > span { display: block; margin-bottom: .35rem; }
.aha-pdp-summary .product_meta a {
  color: var(--aha-ink-soft); text-decoration: none;
  border-bottom: 1px solid var(--aha-gold-light);
}
.aha-pdp-summary .product_meta a:hover { color: var(--aha-gold); }

/* Subscriptions badge (only renders if WC Subscriptions installed) */
.aha-pdp-subscribe-badge {
  border: 1px solid rgba(26,23,20,0.25);
  padding: .85rem 1rem;
  text-align: center;
  font-size: .7rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--aha-ink);
  margin-bottom: 1.5rem;
}

/* Mini trust grid below the form */
.aha-pdp-trust-mini {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .65rem .9rem;
  padding-top: 1.2rem;
  border-top: 1px solid var(--aha-paper-dark);
}
.aha-pdp-trust-mini span {
  font-size: .68rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--aha-ink-soft);
}
.aha-pdp-trust-mini span::before {
  content: "✓";
  color: var(--aha-olive);
  margin-right: .35rem;
}

/* WooCommerce notices */
.aha-pdp .woocommerce-message,
.aha-pdp .woocommerce-info,
.aha-pdp .woocommerce-error {
  background: var(--aha-paper-warm) !important;
  border: none !important;
  border-left: 3px solid var(--aha-gold) !important;
  color: var(--aha-ink) !important;
  font-family: var(--aha-sans) !important;
  font-size: .9rem !important;
  padding: 1rem 1.25rem !important;
  border-radius: 0 !important;
}
.aha-pdp .woocommerce-message .button,
.aha-pdp .woocommerce-info .button {
  background: var(--aha-ink) !important;
  color: var(--aha-paper) !important;
  padding: .5rem 1rem !important;
  font-size: .7rem !important;
  letter-spacing: .14em !important;
  text-transform: uppercase !important;
  border-radius: 0 !important;
}

/* ---- TRUST STRIP ---- */
.aha-pdp-strip {
  background: var(--aha-green-deep);
  color: var(--aha-paper);
  padding: 1rem 2rem;
  display: flex;
  justify-content: center;
  gap: 2.5rem;
  flex-wrap: wrap;
}
.aha-pdp-strip span {
  font-size: .68rem;
  letter-spacing: .15em;
  text-transform: uppercase;
}
.aha-pdp-strip span::before {
  content: "◈";
  color: var(--aha-gold-light);
  margin-right: .55rem;
}

/* ---- GENERIC SECTIONS ---- */
.aha-pdp-section {
  padding: clamp(4rem, 7vw, 7rem) clamp(1.5rem, 5vw, 5rem);
}
.aha-pdp-section-inner {
  max-width: 980px;
  margin: 0 auto;
}
.aha-pdp-section-warm { background: var(--aha-paper-warm); }
.aha-pdp-section-dark { background: var(--aha-green-deep); color: var(--aha-paper); }

.aha-pdp-tag {
  display: inline-block;
  font-size: .62rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--aha-gold);
  border: 1px solid rgba(184,147,90,0.35);
  padding: .35rem .7rem;
  margin-bottom: 1rem;
}
.aha-pdp-section-title {
  font-family: var(--aha-serif);
  font-size: clamp(2rem, 4vw, 3.2rem);
  font-weight: 300;
  line-height: 1.12;
  color: var(--aha-ink);
  margin: 0 0 1.5rem;
}
.aha-pdp-section-title em {
  color: var(--aha-gold);
  font-style: italic;
}
.aha-pdp-section-dark .aha-pdp-section-title { color: var(--aha-paper); }
.aha-pdp-section-dark .aha-pdp-section-title em,
.aha-pdp-section-dark .aha-pdp-tag {
  color: var(--aha-gold-light);
}
.aha-pdp-copy {
  font-size: 1rem;
  line-height: 1.9;
  color: var(--aha-ink-soft);
  font-weight: 300;
}
.aha-pdp-section-dark .aha-pdp-copy {
  color: rgba(247,244,239,0.75);
}

/* ---- INTRODUCTION ---- */
.aha-pdp-intro-grid {
  display: grid;
  grid-template-columns: .9fr 2fr;
  gap: clamp(2rem, 5vw, 5rem);
}
.aha-pdp-pull {
  font-family: var(--aha-serif);
  font-size: clamp(1.7rem, 3vw, 2.4rem);
  font-weight: 300;
  line-height: 1.35;
  color: var(--aha-ink);
  margin: 0 0 1.75rem;
}
.aha-pdp-pull em { font-style: italic; color: var(--aha-gold); }

/* ---- RITUAL CARDS ---- */
.aha-pdp-ritual-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: rgba(247,244,239,0.18);
  margin-top: 2.5rem;
}
.aha-pdp-ritual-card {
  background: var(--aha-green-deep);
  padding: 2rem;
}
.aha-pdp-ritual-num {
  font-family: var(--aha-serif);
  color: var(--aha-gold-light);
  font-size: .85rem;
  margin-bottom: 1rem;
}
.aha-pdp-ritual-card h3 {
  font-family: var(--aha-serif);
  color: var(--aha-paper);
  font-size: 1.35rem;
  font-weight: 300;
  margin: 0 0 .75rem;
}
.aha-pdp-ritual-card p {
  color: rgba(247,244,239,0.7);
  font-size: .9rem;
  line-height: 1.75;
  margin: 0;
}

/* ---- BENEFITS ---- */
.aha-pdp-benefits { display: grid; gap: 0; margin-top: 2rem; }
.aha-pdp-benefit {
  display: grid;
  grid-template-columns: 70px 1fr;
  gap: 2rem;
  padding: 1.75rem 0;
  border-bottom: 1px solid var(--aha-paper-dark);
}
.aha-pdp-benefit:last-child { border-bottom: none; }
.aha-pdp-benefit-num {
  font-family: var(--aha-serif);
  font-size: 2.4rem;
  color: var(--aha-paper-dark);
  line-height: 1;
}
.aha-pdp-benefit h3 {
  font-family: var(--aha-serif);
  font-size: 1.45rem;
  color: var(--aha-ink);
  font-weight: 400;
  margin: 0 0 .5rem;
}
.aha-pdp-benefit p {
  margin: 0;
  color: var(--aha-ink-soft);
  line-height: 1.8;
}

/* ---- BOTANICAL ---- */
.aha-pdp-botanical-list { margin-top: 2rem; }
.aha-pdp-botanical-item {
  display: grid;
  grid-template-columns: 70px 1fr 1.2fr;
  gap: 2rem;
  padding: 1.5rem 0;
  border-bottom: 1px solid var(--aha-paper-dark);
  align-items: start;
}
.aha-pdp-botanical-item:last-child { border-bottom: none; }
.aha-pdp-botanical-num {
  font-family: var(--aha-serif);
  color: var(--aha-olive);
  font-size: .9rem;
}
.aha-pdp-botanical-name {
  font-family: var(--aha-serif);
  font-size: 1.25rem;
  font-style: italic;
  color: var(--aha-ink);
  margin-bottom: .25rem;
}
.aha-pdp-botanical-common {
  font-size: .68rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--aha-olive);
}
.aha-pdp-botanical-desc {
  color: var(--aha-ink-soft);
  line-height: 1.75;
  font-size: .95rem;
}

/* ---- PURITY ---- */
.aha-pdp-purity-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
}
.aha-pdp-badges { display: grid; gap: .85rem; }
.aha-pdp-badge {
  border: 1px solid var(--aha-paper-dark);
  background: var(--aha-paper);
  padding: 1rem 1.25rem;
  font-size: .72rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--aha-ink-soft);
}
.aha-pdp-badge::before {
  content: "✓";
  color: var(--aha-olive);
  margin-right: .6rem;
}

/* ---- LINEAGE ---- */
.aha-pdp-lineage { position: relative; overflow: hidden; }
.aha-pdp-lineage::before {
  content: "蘭茂";
  position: absolute;
  right: -2%;
  top: 50%;
  transform: translateY(-50%);
  font-family: var(--aha-serif);
  font-size: clamp(8rem, 18vw, 18rem);
  color: rgba(212,170,114,0.06);
  line-height: 1;
  pointer-events: none;
}
.aha-pdp-lineage-grid {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1.3fr .8fr;
  gap: clamp(2rem, 5vw, 5rem);
}
.aha-pdp-stats { display: grid; gap: 1.35rem; }
.aha-pdp-stat {
  border-left: 1px solid rgba(247,244,239,0.22);
  padding-left: 1rem;
}
.aha-pdp-stat strong {
  display: block;
  font-family: var(--aha-serif);
  font-size: 2.2rem;
  font-weight: 300;
  color: var(--aha-gold-light);
}
.aha-pdp-stat span {
  display: block;
  font-size: .72rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(247,244,239,0.62);
}

/* ---- MID-PAGE CTA ---- */
.aha-pdp-midcta {
  background: var(--aha-green-deep);
  color: var(--aha-paper);
}
.aha-pdp-midcta-inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 2.25rem clamp(1.5rem, 5vw, 5rem);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  flex-wrap: wrap;
}
.aha-pdp-midcta-eyebrow {
  font-size: .65rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--aha-gold-light);
  margin: 0 0 .35rem;
}
.aha-pdp-midcta-title {
  font-family: var(--aha-serif);
  font-size: clamp(1.25rem, 2vw, 1.6rem);
  font-weight: 300;
  line-height: 1.25;
  color: var(--aha-paper);
  margin: 0;
}

/* ---- TESTIMONIALS ---- */
.aha-pdp-testimonials {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
  margin-top: 2.5rem;
}
.aha-pdp-testimonial {
  padding: 2rem;
  border: 0.5px solid var(--aha-paper-dark);
  position: relative;
  background: var(--aha-paper);
}
.aha-pdp-testimonial::before {
  content: '\201C';
  font-family: var(--aha-serif);
  font-size: 5rem;
  color: var(--aha-gold-pale, #f0e4cc);
  position: absolute;
  top: -.5rem;
  left: 1rem;
  line-height: 1;
  pointer-events: none;
  z-index: 0;
}
.aha-pdp-testimonial-text {
  font-family: var(--aha-serif);
  font-size: 1rem;
  font-weight: 300;
  font-style: italic;
  line-height: 1.7;
  color: var(--aha-ink-soft, #4a4640);
  position: relative;
  z-index: 1;
  margin-bottom: 1.25rem;
}
.aha-pdp-testimonial-author {
  display: flex;
  align-items: center;
  gap: .75rem;
}
.aha-pdp-author-avatar {
  width: 36px;
  height: 36px;
  background: var(--aha-paper-warm);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--aha-serif);
  font-size: .85rem;
  color: var(--aha-gold);
  flex-shrink: 0;
}
.aha-pdp-author-info .aha-pdp-author-name {
  font-size: .78rem;
  font-weight: 500;
  color: var(--aha-ink);
  display: block;
}
.aha-pdp-author-info .aha-pdp-author-detail {
  font-size: .7rem;
  color: var(--aha-ink-muted);
  display: block;
}
.aha-pdp-verified-badge {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  font-size: .6rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--aha-green-deep, #1e3a2a);
  margin-top: .25rem;
  background: rgba(30,58,42,0.08);
  padding: .2rem .5rem;
}

/* ---- WOOCOMMERCE TABS ---- */
.aha-pdp-tabs { background: var(--aha-paper-warm); }
.aha-pdp-tabs .woocommerce-tabs {
  max-width: 900px;
  margin: 0 auto;
}
.aha-pdp-tabs ul.tabs {
  display: flex !important;
  list-style: none !important;
  border-bottom: 1px solid var(--aha-paper-dark) !important;
  padding: 0 !important;
  margin: 0 0 2rem !important;
  gap: 2rem !important;
  background: none !important;
}
.aha-pdp-tabs ul.tabs::before,
.aha-pdp-tabs ul.tabs::after { display: none !important; }
.aha-pdp-tabs ul.tabs li {
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 0 !important; margin: 0 !important;
  list-style: none !important;
}
.aha-pdp-tabs ul.tabs li a {
  display: block !important;
  padding: 1rem 0 !important;
  font-family: var(--aha-sans) !important;
  font-size: .72rem !important;
  letter-spacing: .18em !important;
  text-transform: uppercase !important;
  font-weight: 400 !important;
  color: var(--aha-ink-muted) !important;
  text-decoration: none !important;
  border-bottom: 2px solid transparent !important;
  margin-bottom: -1px !important;
  transition: color .2s, border-color .2s !important;
}
.aha-pdp-tabs ul.tabs li.active a,
.aha-pdp-tabs ul.tabs li a:hover {
  color: var(--aha-ink) !important;
  border-bottom-color: var(--aha-gold) !important;
}
.aha-pdp-tabs .panel,
.aha-pdp-tabs .woocommerce-Tabs-panel {
  padding: 1.5rem 0 !important;
  font-size: 1rem; line-height: 1.85;
  color: var(--aha-ink-soft); font-weight: 300;
}
.aha-pdp-tabs .panel h2,
.aha-pdp-tabs .panel h3 {
  font-family: var(--aha-serif) !important;
  color: var(--aha-ink) !important;
  font-weight: 400 !important;
}

/* ---- CLOSING ---- */
.aha-pdp-closing {
  background: var(--aha-green-deep);
  color: var(--aha-paper);
  text-align: center;
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.aha-pdp-closing-char {
  position: absolute;
  left: -2%; top: 50%; transform: translateY(-50%);
  font-family: var(--aha-serif);
  font-size: clamp(10rem, 20vw, 20rem);
  color: rgba(212,170,114,0.06);
  line-height: 1;
  pointer-events: none; user-select: none;
  z-index: 0;
}
.aha-pdp-closing .aha-pdp-section-inner {
  position: relative;
  z-index: 1;
  max-width: 680px;
}
.aha-pdp-closing-cta-row {
  display: inline-flex;
  gap: 1rem;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 1.5rem;
}

/* ---- RELATED PRODUCTS ---- */
.aha-pdp-related {
  background: var(--aha-paper-warm);
  padding: clamp(3rem, 5vw, 5rem) clamp(1.5rem, 5vw, 5rem);
}
.aha-pdp-related .related.products,
.aha-pdp-related .upsells.products {
  max-width: 1100px;
  margin: 0 auto;
}
.aha-pdp-related .related.products > h2,
.aha-pdp-related .upsells.products > h2 {
  font-family: var(--aha-serif) !important;
  font-size: clamp(1.8rem, 3vw, 2.4rem) !important;
  font-weight: 300 !important;
  color: var(--aha-ink) !important;
  text-align: center !important;
  margin-bottom: 2.5rem !important;
}
.aha-pdp-related ul.products {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)) !important;
  gap: 2rem !important;
  list-style: none !important;
  margin: 0 !important; padding: 0 !important;
}
.aha-pdp-related ul.products li.product {
  background: var(--aha-paper);
  padding: 1.5rem !important;
  margin: 0 !important; width: 100% !important;
  text-align: center;
  list-style: none !important;
  border: 1px solid var(--aha-paper-dark);
  transition: transform .3s ease;
}
.aha-pdp-related ul.products li.product:hover { transform: translateY(-4px); }
.aha-pdp-related ul.products li.product img {
  margin: 0 auto 1rem !important;
  max-width: 180px; height: auto;
}
.aha-pdp-related ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--aha-serif) !important;
  font-size: 1.4rem !important;
  font-weight: 400 !important;
  color: var(--aha-ink) !important;
}
.aha-pdp-related ul.products li.product .price {
  font-family: var(--aha-serif) !important;
  font-size: 1.4rem !important;
  color: var(--aha-gold) !important;
}
.aha-pdp-related ul.products li.product .button {
  background: var(--aha-ink) !important;
  color: var(--aha-paper) !important;
  padding: .75rem 1.5rem !important;
  font-size: .68rem !important;
  letter-spacing: .16em !important;
  text-transform: uppercase !important;
  border-radius: 0 !important;
  margin-top: .5rem !important;
}
.aha-pdp-related ul.products li.product .button:hover {
  background: var(--aha-gold) !important;
  color: var(--aha-ink) !important;
}

/* ---- PRODUCT PAGE RESPONSIVE ---- */
@media (max-width: 980px) {
  .aha-pdp-hero,
  .aha-pdp-intro-grid,
  .aha-pdp-purity-grid,
  .aha-pdp-lineage-grid {
    grid-template-columns: 1fr;
  }
  .aha-pdp-ritual-grid,
  .aha-pdp-testimonials {
    grid-template-columns: 1fr 1fr;
  }
  .aha-pdp-summary { padding: 3rem 1.5rem; }
}
@media (max-width: 640px) {
  .aha-pdp-hero { min-height: auto; }
  .aha-pdp-visual { min-height: 420px; }
  .aha-pdp-ritual-grid,
  .aha-pdp-testimonials,
  .aha-pdp-botanical-item {
    grid-template-columns: 1fr;
  }
  .aha-pdp-benefit {
    grid-template-columns: 1fr;
    gap: .5rem;
  }
  .aha-pdp-summary form.cart { flex-direction: column; }
  .aha-pdp-summary form.cart .quantity input.qty { width: 100%; }
  .aha-pdp-summary form.cart button.single_add_to_cart_button { width: 100%; }
  .aha-pdp-trust-mini { grid-template-columns: 1fr; }
  .aha-pdp-midcta-inner { flex-direction: column; align-items: flex-start; }
  .aha-pdp-midcta a { width: 100%; }
}

/* ============================================================
   CART PAGE — woocommerce/cart/cart.php
   Two-column: line items left, sticky order summary right.
   Targets WooCommerce's collaterals/totals output so coupons,
   shipping calculator, taxes, and the proceed button all keep working.
   ============================================================ */

.aha-cart {
  background: var(--aha-paper);
  padding: clamp(3rem, 6vw, 5rem) clamp(1.5rem, 5vw, 5rem) clamp(4rem, 7vw, 7rem);
}
.aha-cart-inner { max-width: 1180px; margin: 0 auto; }

/* Header */
.aha-cart-head { text-align: center; margin-bottom: clamp(2.5rem, 5vw, 4rem); }
.aha-cart-eyebrow {
  display: inline-block;
  font-size: .66rem; letter-spacing: .24em; text-transform: uppercase;
  color: var(--aha-gold); margin-bottom: 1rem; font-weight: 400;
}
.aha-cart-title {
  font-family: var(--aha-serif);
  font-size: clamp(2.4rem, 5vw, 4rem);
  font-weight: 300; line-height: 1; letter-spacing: -.02em;
  color: var(--aha-ink); margin: 0 0 .75rem;
}
.aha-cart-title em { font-style: italic; color: var(--aha-gold); }
.aha-cart-sub {
  font-size: .95rem; color: var(--aha-ink-soft);
  font-weight: 300; margin: 0;
}

/* Grid */
.aha-cart-grid {
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: clamp(2rem, 4vw, 4rem);
  align-items: start;
}

/* ---- LINE ITEMS ---- */
.aha-cart-items { min-width: 0; }
.aha-cart-item {
  display: grid;
  grid-template-columns: 96px 1fr auto;
  gap: 1.5rem;
  padding: 1.75rem 0;
  border-bottom: 1px solid var(--aha-paper-dark);
  align-items: start;
}
.aha-cart-item:first-child { border-top: 1px solid var(--aha-paper-dark); }

.aha-cart-item-thumb {
  width: 96px; height: 96px;
  background: var(--aha-paper-warm);
  overflow: hidden;
}
.aha-cart-item-thumb a,
.aha-cart-item-thumb img {
  display: block; width: 100%; height: 100%;
  object-fit: cover;
}

.aha-cart-item-detail {
  display: flex; flex-direction: column; gap: .65rem;
  min-width: 0;
}
.aha-cart-item-name { line-height: 1.3; }
.aha-cart-item-name a,
.aha-cart-item-name {
  font-family: var(--aha-serif);
  font-size: 1.3rem; font-weight: 400;
  color: var(--aha-ink); text-decoration: none;
}
.aha-cart-item-name a:hover { color: var(--aha-gold); }
.aha-cart-item-name dl {
  margin: .4rem 0 0; font-size: .8rem;
  color: var(--aha-ink-muted); font-family: var(--aha-sans);
}
.aha-cart-item-name dl dt,
.aha-cart-item-name dl dd { display: inline; margin: 0; }
.aha-cart-item-name .backorder_notification {
  font-size: .78rem; color: var(--aha-red);
  font-family: var(--aha-sans); margin: .35rem 0 0;
}

.aha-cart-item-unit {
  font-size: .85rem; color: var(--aha-ink-muted);
  font-family: var(--aha-sans);
}
.aha-cart-item-unit-label {
  font-size: .65rem; letter-spacing: .12em;
  text-transform: uppercase; margin-left: .25rem;
}

.aha-cart-item-controls {
  display: flex; align-items: center; gap: 1.25rem;
  margin-top: .25rem;
}
.aha-cart-item-qty .quantity { margin: 0 !important; }
.aha-cart-item-qty input.qty {
  width: 70px; height: 44px;
  padding: .5rem;
  border: 1px solid var(--aha-paper-dark);
  background: var(--aha-paper);
  color: var(--aha-ink);
  font-family: var(--aha-sans); font-size: .95rem;
  text-align: center; border-radius: 0;
  outline: none; transition: border-color .2s;
  -moz-appearance: textfield;
}
.aha-cart-item-qty input.qty:focus { border-color: var(--aha-gold); }
.aha-cart-item-qty input.qty::-webkit-outer-spin-button,
.aha-cart-item-qty input.qty::-webkit-inner-spin-button {
  -webkit-appearance: none; margin: 0;
}
.aha-cart-item-remove {
  font-size: .68rem; letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--aha-ink-muted) !important;
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: color .2s, border-color .2s;
}
.aha-cart-item-remove:hover {
  color: var(--aha-red) !important;
  border-bottom-color: var(--aha-red);
}

.aha-cart-item-line {
  font-family: var(--aha-serif);
  font-size: 1.3rem; font-weight: 400;
  color: var(--aha-ink);
  text-align: right; white-space: nowrap;
}

/* Toolbar (coupon + update) */
.aha-cart-toolbar {
  display: flex; flex-wrap: wrap;
  gap: 1rem; align-items: center;
  padding: 1.75rem 0;
  border-bottom: 1px solid var(--aha-paper-dark);
}
.aha-cart-coupon {
  display: flex; gap: .5rem; flex: 1; min-width: 260px;
}
.aha-cart-coupon-input {
  flex: 1; min-width: 0;
  padding: .85rem 1rem;
  border: 1px solid var(--aha-paper-dark);
  background: var(--aha-paper);
  color: var(--aha-ink);
  font-family: var(--aha-sans); font-size: .9rem;
  border-radius: 0; outline: none;
  transition: border-color .2s;
}
.aha-cart-coupon-input:focus { border-color: var(--aha-gold); }
.aha-cart-coupon .aha-btn { flex-shrink: 0; }
.aha-cart-update {
  margin-left: auto;
  background: transparent;
  color: var(--aha-ink-soft);
  border: none;
  font-family: var(--aha-sans);
  font-size: .68rem; letter-spacing: .14em;
  text-transform: uppercase;
  cursor: pointer;
  padding: .85rem 0;
  border-bottom: 1px solid var(--aha-paper-dark);
  transition: color .2s, border-color .2s;
}
.aha-cart-update:hover {
  color: var(--aha-gold);
  border-bottom-color: var(--aha-gold);
}

.aha-cart-continue {
  display: inline-block;
  margin-top: 1.75rem;
  font-size: .8rem; letter-spacing: .04em;
  color: var(--aha-ink-soft);
  text-decoration: none;
  font-family: var(--aha-sans);
  transition: color .2s;
}
.aha-cart-continue:hover { color: var(--aha-gold); }

/* ---- SUMMARY PANEL (right, sticky) ---- */
.aha-cart-summary { min-width: 0; }
.aha-cart-summary-inner {
  position: sticky;
  top: 110px;
  background: var(--aha-paper-warm);
  border: 1px solid var(--aha-paper-dark);
  padding: clamp(1.75rem, 3vw, 2.5rem);
}
.aha-cart-summary-title {
  font-family: var(--aha-serif);
  font-size: 1.5rem; font-weight: 400;
  color: var(--aha-ink);
  margin: 0 0 1.5rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--aha-paper-dark);
}

/* WooCommerce cart-totals — restyle the default markup */
.aha-cart-collaterals .cart_totals h2 {
  position: absolute !important;
  width: 1px; height: 1px;
  overflow: hidden; clip: rect(0 0 0 0);
}
.aha-cart-collaterals .shop_table {
  width: 100%; border: none !important;
  border-collapse: collapse; margin: 0 0 1.5rem;
}
.aha-cart-collaterals .shop_table th,
.aha-cart-collaterals .shop_table td {
  border: none !important;
  padding: .85rem 0 !important;
  background: transparent !important;
  font-family: var(--aha-sans);
  font-size: .92rem;
  color: var(--aha-ink-soft);
  text-align: left;
  vertical-align: top;
}
.aha-cart-collaterals .shop_table th {
  font-size: .68rem; letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--aha-ink-muted);
  font-weight: 400;
  width: 42%;
}
.aha-cart-collaterals .shop_table td { text-align: right; color: var(--aha-ink); }
.aha-cart-collaterals .shop_table tr {
  border-bottom: 1px solid rgba(184,147,90,0.2);
}
.aha-cart-collaterals .shop_table tr:last-child { border-bottom: none; }

.aha-cart-collaterals .cart-subtotal td,
.aha-cart-collaterals .order-total td {
  font-family: var(--aha-serif);
}
.aha-cart-collaterals .order-total th,
.aha-cart-collaterals .order-total td {
  padding-top: 1.25rem !important;
  font-size: 1rem;
}
.aha-cart-collaterals .order-total td strong {
  font-family: var(--aha-serif);
  font-size: 1.6rem; font-weight: 400;
  color: var(--aha-ink);
}
.aha-cart-collaterals .order-total .woocommerce-Price-amount {
  color: var(--aha-gold);
}

/* Shipping calculator inside totals */
.aha-cart-collaterals .shipping-calculator-button {
  color: var(--aha-gold) !important;
  text-decoration: none;
  border-bottom: 1px solid var(--aha-gold-light);
  font-size: .85rem;
}
.aha-cart-collaterals .shipping-calculator-form {
  margin-top: 1rem;
}
.aha-cart-collaterals .shipping-calculator-form p { margin-bottom: .65rem; }
.aha-cart-collaterals .shipping-calculator-form input,
.aha-cart-collaterals .shipping-calculator-form select,
.aha-cart-collaterals .shipping-calculator-form .select2-selection {
  width: 100% !important;
  padding: .7rem .85rem !important;
  border: 1px solid var(--aha-paper-dark) !important;
  background: var(--aha-paper) !important;
  color: var(--aha-ink) !important;
  font-family: var(--aha-sans) !important;
  font-size: .85rem !important;
  border-radius: 0 !important;
  height: auto !important;
}
.aha-cart-collaterals .shipping-calculator-form button {
  background: var(--aha-ink) !important;
  color: var(--aha-paper) !important;
  border: none !important;
  padding: .7rem 1.25rem !important;
  font-family: var(--aha-sans) !important;
  font-size: .68rem !important;
  letter-spacing: .14em !important;
  text-transform: uppercase !important;
  border-radius: 0 !important;
  cursor: pointer;
}
.aha-cart-collaterals ul#shipping_method {
  list-style: none; margin: 0; padding: 0;
}
.aha-cart-collaterals ul#shipping_method li {
  padding: .35rem 0; font-size: .88rem;
}
.aha-cart-collaterals .woocommerce-shipping-destination {
  font-size: .8rem; color: var(--aha-ink-muted);
  margin-top: .5rem;
}

/* Proceed-to-checkout button */
.aha-cart-collaterals .wc-proceed-to-checkout {
  padding: 0; margin-top: 1.5rem;
}
.aha-cart-collaterals .wc-proceed-to-checkout a.checkout-button {
  display: block !important;
  width: 100%;
  text-align: center;
  background: var(--aha-ink) !important;
  color: var(--aha-paper) !important;
  border: 1px solid var(--aha-ink) !important;
  border-radius: 0 !important;
  padding: 1.1rem 2rem !important;
  font-family: var(--aha-sans) !important;
  font-size: .74rem !important;
  letter-spacing: .18em !important;
  text-transform: uppercase !important;
  font-weight: 400 !important;
  text-decoration: none !important;
  transition: background .2s, border-color .2s, transform .15s !important;
}
.aha-cart-collaterals .wc-proceed-to-checkout a.checkout-button:hover {
  background: var(--aha-green-deep) !important;
  border-color: var(--aha-green-deep) !important;
  transform: translateY(-1px);
}

/* Cross-sells, if any, render below the panel */
.aha-cart-collaterals .cross-sells { margin-top: 2rem; }
.aha-cart-collaterals .cross-sells h2 {
  font-family: var(--aha-serif) !important;
  font-size: 1.2rem !important;
  font-weight: 400 !important;
  color: var(--aha-ink) !important;
  position: static !important;
  width: auto !important; height: auto !important;
  clip: auto !important;
  margin: 0 0 1rem !important;
}
.aha-cart-collaterals .cross-sells ul.products {
  display: grid; gap: 1rem;
  list-style: none; margin: 0; padding: 0;
}
.aha-cart-collaterals .cross-sells ul.products li.product {
  width: 100% !important; margin: 0 !important;
  background: var(--aha-paper);
  border: 1px solid var(--aha-paper-dark);
  padding: 1rem !important;
  text-align: center;
}
.aha-cart-collaterals .cross-sells ul.products li.product .button {
  background: var(--aha-ink) !important;
  color: var(--aha-paper) !important;
  font-size: .65rem !important;
  letter-spacing: .14em !important;
  text-transform: uppercase !important;
  border-radius: 0 !important;
  margin-top: .5rem !important;
}

/* Trust block */
.aha-cart-trust {
  margin-top: 1.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--aha-paper-dark);
  display: flex; flex-direction: column; gap: .6rem;
}
.aha-cart-trust-item {
  display: flex; align-items: center; gap: .55rem;
  font-size: .8rem; color: var(--aha-ink-soft);
  font-weight: 300;
}
.aha-cart-trust-item span {
  color: var(--aha-gold); font-size: 1rem; flex-shrink: 0;
}

/* WooCommerce notices on cart */
.aha-cart .woocommerce-message,
.aha-cart .woocommerce-info,
.aha-cart .woocommerce-error {
  background: var(--aha-paper-warm) !important;
  border: none !important;
  border-left: 3px solid var(--aha-gold) !important;
  color: var(--aha-ink) !important;
  font-family: var(--aha-sans) !important;
  font-size: .9rem !important;
  padding: 1rem 1.25rem !important;
  border-radius: 0 !important;
  margin-bottom: 1.5rem;
  list-style: none;
}
.aha-cart .woocommerce-message .button,
.aha-cart .woocommerce-info .button {
  background: var(--aha-ink) !important;
  color: var(--aha-paper) !important;
  padding: .5rem 1rem !important;
  font-size: .68rem !important;
  letter-spacing: .14em !important;
  text-transform: uppercase !important;
  border-radius: 0 !important;
}

/* ---- CART RESPONSIVE ---- */
@media (max-width: 980px) {
  .aha-cart-grid { grid-template-columns: 1fr; }
  .aha-cart-summary-inner { position: static; }
}
@media (max-width: 600px) {
  .aha-cart-item {
    grid-template-columns: 72px 1fr;
    grid-template-areas:
      "thumb detail"
      "line  line";
    gap: 1rem;
  }
  .aha-cart-item-thumb { grid-area: thumb; width: 72px; height: 72px; }
  .aha-cart-item-detail { grid-area: detail; }
  .aha-cart-item-line {
    grid-area: line; text-align: left;
    padding-top: .5rem;
    border-top: 1px solid var(--aha-paper-dark);
  }
  .aha-cart-item-line::before {
    content: "Subtotal: ";
    font-family: var(--aha-sans);
    font-size: .68rem; letter-spacing: .12em;
    text-transform: uppercase; color: var(--aha-ink-muted);
  }
  .aha-cart-toolbar { flex-direction: column; align-items: stretch; }
  .aha-cart-coupon { min-width: 0; }
  .aha-cart-update { margin-left: 0; text-align: center; }
}

/* ============================================================
   EMPTY CART — woocommerce/cart/cart-empty.php
   ============================================================ */
    .aha-empty-cart {
        background: var(--aha-paper);
        padding: 5rem 2rem 6rem;
        text-align: center;
        min-height: calc(100vh - 80px - 200px);
        display: flex;
        align-items: center;
        justify-content: center;
    }
    .aha-empty-cart-inner {
        max-width: 720px;
        margin: 0 auto;
        position: relative;
    }
    .aha-empty-cart-char {
        font-family: var(--aha-serif);
        font-size: 12rem;
        color: rgba(184,147,90,0.08);
        line-height: 1;
        margin-bottom: -3rem;
        user-select: none;
    }
    .aha-empty-cart-eyebrow {
        font-size: .7rem;
        letter-spacing: .22em;
        text-transform: uppercase;
        color: var(--aha-gold);
        font-weight: 400;
        margin-bottom: 1rem;
        position: relative;
    }
    .aha-empty-cart-title {
        font-family: var(--aha-serif);
        font-size: clamp(2.2rem, 4vw, 3rem);
        font-weight: 300;
        line-height: 1.1;
        color: var(--aha-ink);
        margin-bottom: 1.5rem;
        letter-spacing: -.01em;
    }
    .aha-empty-cart-title em {
        font-style: italic;
        color: var(--aha-gold);
    }
    .aha-empty-cart-body {
        font-size: 1rem;
        color: var(--aha-ink-soft);
        line-height: 1.75;
        max-width: 480px;
        margin: 0 auto 2.5rem;
        font-weight: 300;
    }

    .aha-empty-cart-products {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 1.5rem;
        max-width: 560px;
        margin: 0 auto;
    }
    .aha-empty-product-card {
        background: var(--aha-paper-warm);
        padding: 2rem 1.5rem;
        text-decoration: none;
        text-align: center;
        position: relative;
        overflow: hidden;
        transition: transform .25s, background .25s;
        border: 0.5px solid var(--aha-paper-dark);
    }
    .aha-empty-product-card:hover { transform: translateY(-4px); background: var(--aha-paper); }
    .aha-empty-product-card-her { background: linear-gradient(135deg, #f0e8dc 0%, #e4d5c4 100%); }
    .aha-empty-product-char {
        position: absolute;
        font-family: var(--aha-serif);
        font-size: 8rem;
        color: rgba(184,147,90,0.12);
        right: -.5rem;
        top: -1rem;
        line-height: 1;
        pointer-events: none;
        user-select: none;
    }
    .aha-empty-product-card .name {
        font-family: var(--aha-serif);
        font-size: 1.4rem;
        font-weight: 400;
        color: var(--aha-ink);
        display: block;
        position: relative;
        z-index: 1;
        margin-bottom: .25rem;
    }
    .aha-empty-product-card .sub {
        font-size: .7rem;
        letter-spacing: .15em;
        text-transform: uppercase;
        color: var(--aha-ink-muted);
        display: block;
        position: relative;
        z-index: 1;
        margin-bottom: 1rem;
    }
    .aha-empty-product-card .price {
        font-family: var(--aha-serif);
        font-size: 1.5rem;
        font-weight: 500;
        color: var(--aha-gold);
        display: block;
        position: relative;
        z-index: 1;
    }

    @media (max-width: 600px) {
        .aha-empty-cart-char { font-size: 8rem; margin-bottom: -2rem; }
        .aha-empty-cart-products { grid-template-columns: 1fr; }
    }

/* ============================================================
   CART — AVADA OVERRIDE LAYER
   Avada loads its own minified WooCommerce stylesheet that targets
   the same elements as our cart CSS and wins on load order. These
   rules are scoped under body.aha-cart-page (confirmed present in
   the DOM) to raise specificity above Avada's .woocommerce-cart
   selectors WITHOUT a blanket !important sweep. This is the layer
   that actually makes the redesign visible on an Avada build.
   ============================================================ */

/* Kill Avada's WooCommerce page chrome on the cart */
body.aha-cart-page .fusion-page-title-bar,
body.aha-cart-page .avada-page-titlebar-wrapper,
body.aha-cart-page .fusion-breadcrumbs,
body.aha-cart-page .woocommerce-breadcrumb,
body.aha-cart-page .fusion-sidebar,
body.aha-cart-page #sidebar {
  display: none !important;
}

/* Let our section span full width — Avada constrains .woocommerce */
body.aha-cart-page .woocommerce,
body.aha-cart-page .woocommerce-cart-form,
body.aha-cart-page #content,
body.aha-cart-page .post-content {
  max-width: none !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
}

body.aha-cart-page .aha-cart { background: var(--aha-paper); }

/* Re-assert the two-column grid above Avada's table reset */
body.aha-cart-page .aha-cart-grid {
  display: grid !important;
  grid-template-columns: 1fr 380px !important;
  gap: clamp(2rem, 4vw, 4rem) !important;
  align-items: start !important;
}
@media (max-width: 980px) {
  body.aha-cart-page .aha-cart-grid { grid-template-columns: 1fr !important; }
}

/* Line-item card — beat Avada's .cart_item table styling */
body.aha-cart-page .aha-cart-item {
  display: grid !important;
  grid-template-columns: 96px 1fr auto !important;
  gap: 1.5rem !important;
  padding: 1.75rem 0 !important;
  border: none !important;
  border-bottom: 1px solid var(--aha-paper-dark) !important;
  background: transparent !important;
  align-items: start !important;
}
body.aha-cart-page .aha-cart-item:first-child {
  border-top: 1px solid var(--aha-paper-dark) !important;
}
body.aha-cart-page .aha-cart-item td,
body.aha-cart-page .aha-cart-item::before,
body.aha-cart-page .aha-cart-item::after {
  display: revert;
  content: none;
}
body.aha-cart-page .aha-cart-item-thumb {
  width: 96px !important; height: 96px !important;
  background: var(--aha-paper-warm) !important;
}
body.aha-cart-page .aha-cart-item-thumb img {
  width: 100% !important; height: 100% !important;
  object-fit: cover !important; margin: 0 !important;
}
body.aha-cart-page .aha-cart-item-name,
body.aha-cart-page .aha-cart-item-name a {
  font-family: var(--aha-serif) !important;
  font-size: 1.3rem !important; font-weight: 400 !important;
  color: var(--aha-ink) !important; text-decoration: none !important;
}
body.aha-cart-page .aha-cart-item-line {
  font-family: var(--aha-serif) !important;
  font-size: 1.3rem !important; color: var(--aha-ink) !important;
  text-align: right !important;
}

/* Summary panel — beat Avada's .cart-collaterals / .cart_totals */
body.aha-cart-page .aha-cart-summary { width: auto !important; float: none !important; }
body.aha-cart-page .aha-cart-summary-inner {
  position: sticky !important; top: 110px !important;
  background: var(--aha-paper-warm) !important;
  border: 1px solid var(--aha-paper-dark) !important;
  padding: clamp(1.75rem, 3vw, 2.5rem) !important;
  width: auto !important;
}
@media (max-width: 980px) {
  body.aha-cart-page .aha-cart-summary-inner { position: static !important; }
}
body.aha-cart-page .aha-cart-summary-title {
  font-family: var(--aha-serif) !important;
  font-size: 1.5rem !important; font-weight: 400 !important;
  color: var(--aha-ink) !important;
  margin: 0 0 1.5rem !important;
  padding-bottom: 1rem !important;
  border-bottom: 1px solid var(--aha-paper-dark) !important;
}

/* Hide WooCommerce's own "Cart totals" H2 (we use our own title) */
body.aha-cart-page .cart_totals > h2 {
  position: absolute !important;
  width: 1px !important; height: 1px !important;
  overflow: hidden !important; clip: rect(0 0 0 0) !important;
}

/* Totals table — strip Avada's table borders/striping */
body.aha-cart-page .aha-cart-collaterals,
body.aha-cart-page .aha-cart-collaterals .cart_totals {
  width: 100% !important; float: none !important;
}
body.aha-cart-page .aha-cart-collaterals table.shop_table,
body.aha-cart-page .aha-cart-collaterals table.shop_table tbody,
body.aha-cart-page .aha-cart-collaterals table.shop_table tr,
body.aha-cart-page .aha-cart-collaterals table.shop_table th,
body.aha-cart-page .aha-cart-collaterals table.shop_table td {
  border: none !important;
  background: transparent !important;
}
body.aha-cart-page .aha-cart-collaterals table.shop_table {
  width: 100% !important; margin: 0 0 1.5rem !important;
}
body.aha-cart-page .aha-cart-collaterals table.shop_table tr {
  border-bottom: 1px solid rgba(184,147,90,0.2) !important;
}
body.aha-cart-page .aha-cart-collaterals table.shop_table tr:last-child {
  border-bottom: none !important;
}
body.aha-cart-page .aha-cart-collaterals th {
  font-family: var(--aha-sans) !important;
  font-size: .68rem !important; letter-spacing: .12em !important;
  text-transform: uppercase !important; color: var(--aha-ink-muted) !important;
  font-weight: 400 !important; text-align: left !important;
  padding: .85rem 0 !important;
}
body.aha-cart-page .aha-cart-collaterals td {
  font-family: var(--aha-sans) !important;
  color: var(--aha-ink) !important; text-align: right !important;
  padding: .85rem 0 !important;
}
body.aha-cart-page .aha-cart-collaterals .order-total td strong,
body.aha-cart-page .aha-cart-collaterals .order-total td .woocommerce-Price-amount {
  font-family: var(--aha-serif) !important;
  font-size: 1.6rem !important; font-weight: 400 !important;
  color: var(--aha-gold) !important;
}

/* Proceed-to-checkout — beat Avada's button skin */
body.aha-cart-page .aha-cart-collaterals .wc-proceed-to-checkout a.checkout-button,
body.aha-cart-page a.checkout-button.button.alt {
  display: block !important;
  width: 100% !important;
  text-align: center !important;
  background: var(--aha-ink) !important;
  background-image: none !important;
  color: var(--aha-paper) !important;
  border: 1px solid var(--aha-ink) !important;
  border-radius: 0 !important;
  padding: 1.1rem 2rem !important;
  font-family: var(--aha-sans) !important;
  font-size: .74rem !important;
  letter-spacing: .18em !important;
  text-transform: uppercase !important;
  font-weight: 400 !important;
  text-shadow: none !important;
  box-shadow: none !important;
  margin-top: 1.5rem !important;
}
body.aha-cart-page .aha-cart-collaterals .wc-proceed-to-checkout a.checkout-button:hover,
body.aha-cart-page a.checkout-button.button.alt:hover {
  background: var(--aha-green-deep) !important;
  border-color: var(--aha-green-deep) !important;
  color: var(--aha-paper) !important;
}

/* Coupon + update toolbar — neutralize Avada input/button skin */
body.aha-cart-page .aha-cart-coupon-input {
  padding: .85rem 1rem !important;
  border: 1px solid var(--aha-paper-dark) !important;
  background: var(--aha-paper) !important;
  color: var(--aha-ink) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}
body.aha-cart-page .aha-cart-update {
  background: transparent !important;
  border: none !important;
  border-bottom: 1px solid var(--aha-paper-dark) !important;
  color: var(--aha-ink-soft) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  text-shadow: none !important;
  font-family: var(--aha-sans) !important;
  letter-spacing: .14em !important;
  text-transform: uppercase !important;
}

/* Quantity field — strip Avada number-input chrome */
body.aha-cart-page .aha-cart-item-qty input.qty {
  width: 70px !important; height: 44px !important;
  border: 1px solid var(--aha-paper-dark) !important;
  background: var(--aha-paper) !important;
  color: var(--aha-ink) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

/* Notices */
body.aha-cart-page .woocommerce-message,
body.aha-cart-page .woocommerce-info,
body.aha-cart-page .woocommerce-error {
  background: var(--aha-paper-warm) !important;
  border: none !important;
  border-left: 3px solid var(--aha-gold) !important;
  color: var(--aha-ink) !important;
  border-radius: 0 !important;
}

/* ============================================================
   CART — POST-SHORTCODE FIXES
   After converting the Cart page from the WooCommerce block to the
   [woocommerce_cart] shortcode, three issues remained:
   1. Summary column crushed (WC block CSS still constraining widths)
   2. Redundant "You Have N Items In Your Cart" WC heading
   3. Tax/coupon text wrapping one word per line (symptom of #1)
   ============================================================ */

/* Force the two-column grid to actually hold its track widths.
   WooCommerce block CSS sets min-width/flex on descendants that
   collapse our right column — pin both columns explicitly. */
body.aha-cart-page .aha-cart-grid {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 360px !important;
  gap: clamp(2rem, 4vw, 4rem) !important;
  align-items: start !important;
}
body.aha-cart-page .aha-cart-items { min-width: 0 !important; }
body.aha-cart-page .aha-cart-summary {
  width: 360px !important;
  max-width: 360px !important;
  min-width: 360px !important;
}
body.aha-cart-page .aha-cart-summary-inner {
  width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
}
@media (max-width: 980px) {
  body.aha-cart-page .aha-cart-grid {
    grid-template-columns: 1fr !important;
  }
  body.aha-cart-page .aha-cart-summary,
  body.aha-cart-page .aha-cart-summary-inner {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }
}

/* Suppress WooCommerce's redundant cart heading.
   We already have the "The Cart / N formulas" branded header.
   WC outputs an <h1>/<h2> like "You Have 2 Items In Your Cart"
   via the page title or a cart notice — hide the common variants. */
body.aha-cart-page .aha-cart .entry-title,
body.aha-cart-page .aha-cart > h1:first-child,
body.aha-cart-page .aha-cart-items > h1,
body.aha-cart-page .aha-cart-items > h2:first-child {
  display: none !important;
}

/* Totals table: never let label/value cells wrap to one-word-per-line.
   The crushed column made "LOS ANGELES COUNTY ... TAX" stack vertically. */
body.aha-cart-page .aha-cart-collaterals table.shop_table th,
body.aha-cart-page .aha-cart-collaterals table.shop_table td {
  word-break: normal !important;
  overflow-wrap: anywhere !important;
  hyphens: none !important;
  white-space: normal !important;
  vertical-align: top !important;
}
body.aha-cart-page .aha-cart-collaterals table.shop_table th {
  width: 55% !important;
  padding-right: .75rem !important;
  line-height: 1.45 !important;
}
body.aha-cart-page .aha-cart-collaterals table.shop_table td {
  width: 45% !important;
  white-space: nowrap !important;
}

/* Shipping address line inside totals — keep readable, not stacked */
body.aha-cart-page .aha-cart-collaterals .woocommerce-shipping-destination {
  font-size: .78rem !important;
  line-height: 1.5 !important;
  color: var(--aha-ink-muted) !important;
  white-space: normal !important;
}

/* If WC still injects its own coupon form into the panel, hide it —
   the active coupon field is in the left toolbar (.aha-cart-coupon). */
body.aha-cart-page .aha-cart-summary .coupon,
body.aha-cart-page .aha-cart-summary form.woocommerce-form-coupon,
body.aha-cart-page .aha-cart-summary .wc-block-components-totals-coupon,
body.aha-cart-page .aha-cart-summary .cart_totals ~ .cross-sells {
  display: none !important;
}

/* Proceed button: ensure full width within the (now correctly sized) panel */
body.aha-cart-page .aha-cart-collaterals .wc-proceed-to-checkout {
  width: 100% !important;
  padding: 0 !important;
  margin-top: 1.5rem !important;
}

/* ============================================================
   CART — TOTALS TABLE WIDTH (decisive fix)
   The summary text was stacking one-word-per-line because the
   totals TABLE element itself wasn't expanding to its container —
   WooCommerce block CSS gives it a tiny intrinsic width. Earlier
   rules styled the cells but never forced the table to 100%.
   This targets the table element with full specificity + the
   shipping address paragraph that was also collapsing.
   ============================================================ */

body.aha-cart-page .aha-cart-summary .aha-cart-collaterals table,
body.aha-cart-page .aha-cart-summary table.shop_table,
body.aha-cart-page .aha-cart-summary table.cart_totals,
body.aha-cart-page .aha-cart-collaterals .cart_totals table {
  width: 100% !important;
  min-width: 100% !important;
  max-width: 100% !important;
  table-layout: auto !important;
  border-collapse: collapse !important;
  display: table !important;
  margin: 0 0 1.25rem !important;
}
body.aha-cart-page .aha-cart-summary .aha-cart-collaterals table tbody,
body.aha-cart-page .aha-cart-summary table.shop_table tbody {
  display: table-row-group !important;
  width: 100% !important;
}
body.aha-cart-page .aha-cart-summary .aha-cart-collaterals table tr,
body.aha-cart-page .aha-cart-summary table.shop_table tr {
  display: table-row !important;
  width: 100% !important;
}
body.aha-cart-page .aha-cart-summary .aha-cart-collaterals table th,
body.aha-cart-page .aha-cart-summary .aha-cart-collaterals table td {
  display: table-cell !important;
  white-space: normal !important;
  word-break: keep-all !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
  font-family: var(--aha-sans) !important;
  vertical-align: top !important;
  padding: .8rem 0 !important;
}
body.aha-cart-page .aha-cart-summary .aha-cart-collaterals table th {
  width: 58% !important;
  text-align: left !important;
  font-size: .66rem !important;
  letter-spacing: .1em !important;
  text-transform: uppercase !important;
  color: var(--aha-ink-muted) !important;
  font-weight: 400 !important;
  line-height: 1.5 !important;
  padding-right: .85rem !important;
}
body.aha-cart-page .aha-cart-summary .aha-cart-collaterals table td {
  width: 42% !important;
  text-align: right !important;
  color: var(--aha-ink) !important;
  font-size: .9rem !important;
  white-space: nowrap !important;
}
/* order-total row: bigger, serif, gold amount */
body.aha-cart-page .aha-cart-summary .aha-cart-collaterals .order-total th,
body.aha-cart-page .aha-cart-summary .aha-cart-collaterals .order-total td {
  padding-top: 1.1rem !important;
  border-top: 1px solid var(--aha-paper-dark) !important;
}
body.aha-cart-page .aha-cart-summary .aha-cart-collaterals .order-total td strong,
body.aha-cart-page .aha-cart-summary .aha-cart-collaterals .order-total .woocommerce-Price-amount {
  font-family: var(--aha-serif) !important;
  font-size: 1.5rem !important;
  font-weight: 400 !important;
  color: var(--aha-gold) !important;
  white-space: nowrap !important;
}
/* shipping destination line — was collapsing into a vertical strip */
body.aha-cart-page .aha-cart-summary .woocommerce-shipping-destination,
body.aha-cart-page .aha-cart-summary .shipping-calculator-button {
  display: block !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: break-word !important;
  font-size: .76rem !important;
  line-height: 1.5 !important;
  color: var(--aha-ink-muted) !important;
  text-align: left !important;
}
/* the shipping row's value cell holds the address — let it wrap normally */
body.aha-cart-page .aha-cart-summary .aha-cart-collaterals tr.shipping td {
  white-space: normal !important;
  text-align: right !important;
  font-size: .82rem !important;
  line-height: 1.5 !important;
}

/* ============================================================
   CART — AVADA INJECTED-DIV FIX (root cause)
   Inspector revealed Avada injects <div class="woocommerce-content-box
   full-width clearfix"> as a child of the cart form, BETWEEN the form
   open and .aha-cart-items. Our grid expects exactly two children
   (.aha-cart-items + .aha-cart-summary); the injected third child
   scrambled the track assignment, collapsing the summary column to
   ~200px. THIS is why the totals text stacked — not block CSS, not
   specificity. Neutralize the injected div and pin the grid to its
   real children explicitly.
   ============================================================ */

/* Remove Avada's injected wrapper from layout flow entirely */
body.aha-cart-page .woocommerce-cart-form > .woocommerce-content-box,
body.aha-cart-page form.woocommerce-cart-form > .woocommerce-content-box,
body.aha-cart-page .aha-cart-grid > .woocommerce-content-box {
  display: none !important;
}

/* Re-establish the grid targeting ONLY the two real children by class,
   regardless of any extra siblings Avada injects. Use explicit grid
   areas so injected elements can't shift the layout. */
body.aha-cart-page .aha-cart-grid {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 360px !important;
  grid-template-areas: "items summary" !important;
  gap: clamp(2rem, 4vw, 4rem) !important;
  align-items: start !important;
  max-width: 1180px !important;
  margin: 0 auto !important;
  width: 100% !important;
}
body.aha-cart-page .aha-cart-grid > .aha-cart-items {
  grid-area: items !important;
  min-width: 0 !important;
  width: auto !important;
  max-width: none !important;
  float: none !important;
}
body.aha-cart-page .aha-cart-grid > .aha-cart-summary {
  grid-area: summary !important;
  width: 360px !important;
  min-width: 360px !important;
  max-width: 360px !important;
  float: none !important;
}
/* Any other direct child Avada injects: keep it out of the grid flow */
body.aha-cart-page .aha-cart-grid > *:not(.aha-cart-items):not(.aha-cart-summary) {
  display: none !important;
}

/* Now that the column is a true 360px, the totals table fills it.
   Reassert table fill (container is finally wide enough to matter). */
body.aha-cart-page .aha-cart-summary .cart_totals,
body.aha-cart-page .aha-cart-summary .aha-cart-collaterals,
body.aha-cart-page .aha-cart-summary table.shop_table {
  width: 100% !important;
  min-width: 0 !important;
  max-width: 100% !important;
  float: none !important;
}
body.aha-cart-page .aha-cart-summary table.shop_table {
  table-layout: fixed !important;
}
body.aha-cart-page .aha-cart-summary table.shop_table th {
  width: 60% !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: anywhere !important;
  font-size: .64rem !important;
  line-height: 1.5 !important;
  letter-spacing: .08em !important;
}
body.aha-cart-page .aha-cart-summary table.shop_table td {
  width: 40% !important;
  white-space: nowrap !important;
  text-align: right !important;
}

/* Mobile: single column, summary full width */
@media (max-width: 980px) {
  body.aha-cart-page .aha-cart-grid {
    grid-template-columns: 1fr !important;
    grid-template-areas: "items" "summary" !important;
  }
  body.aha-cart-page .aha-cart-grid > .aha-cart-summary {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
  }
}
/* ==========================================================================
   APPEND THIS BLOCK to your existing avada-child-theme/style.css
   (at the very end of the file).

   Do NOT replace the entire file â€” just append.

   Scopes:
     body.aha-learn-page        â†’ the Learn hub
     body.aha-learn-post--essay â†’ editorial essays
     body.aha-learn-post--qa    â†’ AHA Learn Q&A explainers
   ========================================================================== */


/* ==========================================================================
   LEARN HUB
   ========================================================================== */

body.aha-learn-page {
  background: var(--aha-paper);
}

body.aha-learn-page .aha-learn-wrap {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 1.5rem 4rem;
}

/* ----- Hero ----- */
body.aha-learn-page .aha-learn-hero {
  text-align: center;
  padding: 4rem 1rem 3rem;
  max-width: 720px;
  margin: 0 auto;
}

body.aha-learn-page .aha-learn-hero__eyebrow {
  font-family: var(--aha-sans);
  font-size: .68rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--aha-gold);
  margin-bottom: 1.1rem;
  font-weight: 400;
}

body.aha-learn-page .aha-learn-hero__title {
  font-family: var(--aha-serif);
  font-weight: 300;
  font-size: clamp(2.2rem, 4.5vw, 3.6rem);
  line-height: 1.05;
  color: var(--aha-ink);
  margin: 0 0 1.25rem;
  letter-spacing: -.01em;
}

body.aha-learn-page .aha-learn-hero__title em {
  font-style: italic;
  color: var(--aha-gold);
}

body.aha-learn-page .aha-learn-hero__subtitle {
  font-family: var(--aha-sans);
  font-weight: 300;
  font-size: clamp(.95rem, 1.4vw, 1.05rem);
  line-height: 1.6;
  color: var(--aha-ink-soft);
  margin: 0;
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
}

/* ----- Section blocks ----- */
body.aha-learn-page .aha-learn-section {
  padding: 4rem 0 3rem;
  border-top: 1px solid rgba(184, 147, 90, .18);
  margin-top: 2.5rem;
}

body.aha-learn-page .aha-learn-section:first-of-type {
  margin-top: 1.5rem;
}

body.aha-learn-page .aha-learn-section__header {
  text-align: center;
  margin-bottom: 3rem;
}

body.aha-learn-page .aha-learn-section__numeral {
  font-family: var(--aha-sans);
  font-size: .62rem;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--aha-gold);
  margin-bottom: .5rem;
}

body.aha-learn-page .aha-learn-section__label {
  font-family: var(--aha-serif);
  font-style: italic;
  font-weight: 400;
  font-size: 1.15rem;
  color: var(--aha-ink-muted);
  letter-spacing: .04em;
  margin: 0;
}

body.aha-learn-page .aha-learn-section__essays {
  display: flex;
  flex-direction: column;
  gap: 4rem;
}

/* ----- Essay cards (image-left / image-right alternation) ----- */
body.aha-learn-page .aha-essay {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: center;
}

body.aha-learn-page .aha-essay--image-right {
  grid-template-areas: "body image";
}

body.aha-learn-page .aha-essay--image-right .aha-essay__body {
  grid-area: body;
}

body.aha-learn-page .aha-essay--image-right .aha-essay__image {
  grid-area: image;
}

body.aha-learn-page .aha-essay__image {
  display: block;
  aspect-ratio: 4 / 3;
  background: var(--aha-paper-warm);
  overflow: hidden;
  transition: transform .35s ease;
}

body.aha-learn-page .aha-essay__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .8s ease;
}

body.aha-learn-page .aha-essay__image:hover img {
  transform: scale(1.03);
}

body.aha-learn-page .aha-essay__image-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--aha-gold);
  font-family: var(--aha-serif);
  font-size: 2rem;
}

body.aha-learn-page .aha-essay__eyebrow {
  font-family: var(--aha-sans);
  font-size: .6rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--aha-gold);
  margin-bottom: .85rem;
  font-weight: 400;
}

body.aha-learn-page .aha-essay__title {
  font-family: var(--aha-serif);
  font-weight: 400;
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  line-height: 1.1;
  margin: 0 0 1rem;
  letter-spacing: -.005em;
}

body.aha-learn-page .aha-essay__title a {
  color: var(--aha-ink);
  text-decoration: none;
  transition: color .2s ease;
}

body.aha-learn-page .aha-essay__title a:hover {
  color: var(--aha-gold);
}

body.aha-learn-page .aha-essay__excerpt {
  font-family: var(--aha-sans);
  font-weight: 300;
  font-size: .9rem;
  line-height: 1.65;
  color: var(--aha-ink-soft);
  margin: 0 0 1.5rem;
}

body.aha-learn-page .aha-essay__cta {
  display: inline-block;
  font-family: var(--aha-sans);
  font-size: .6rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--aha-ink);
  text-decoration: none;
  padding-bottom: 3px;
  border-bottom: 1px solid var(--aha-gold);
  transition: color .2s ease, border-color .2s ease;
}

body.aha-learn-page .aha-essay__cta:hover {
  color: var(--aha-gold);
  border-color: var(--aha-ink);
}

body.aha-learn-page .aha-essay__cta span {
  margin-left: .35rem;
  transition: transform .2s ease;
  display: inline-block;
}

body.aha-learn-page .aha-essay__cta:hover span {
  transform: translateX(3px);
}

/* ----- AHA Learn Q&A section ----- */
body.aha-learn-page .aha-learn-qa {
  margin-top: 4rem;
  padding: 4rem 2rem;
  background: var(--aha-paper-warm);
  border-top: 1px solid rgba(184, 147, 90, .18);
}

body.aha-learn-page .aha-learn-qa__header {
  text-align: center;
  margin-bottom: 3rem;
}

body.aha-learn-page .aha-learn-qa__eyebrow {
  font-family: var(--aha-sans);
  font-size: .65rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--aha-gold);
  margin-bottom: .75rem;
  font-weight: 400;
}

body.aha-learn-page .aha-learn-qa__title {
  font-family: var(--aha-serif);
  font-weight: 300;
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  line-height: 1.15;
  color: var(--aha-ink);
  margin: 0 0 .75rem;
}

body.aha-learn-page .aha-learn-qa__title em {
  font-style: italic;
  color: var(--aha-gold);
}

body.aha-learn-page .aha-learn-qa__subtitle {
  font-family: var(--aha-serif);
  font-style: italic;
  font-size: 1rem;
  color: var(--aha-ink-soft);
  margin: 0;
}

body.aha-learn-page .aha-learn-qa__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  max-width: 1080px;
  margin: 0 auto;
}

body.aha-learn-page .aha-learn-qa__card {
  display: block;
  padding: 2rem 1.75rem;
  background: var(--aha-paper);
  border: 1px solid var(--aha-paper-dark);
  text-decoration: none;
  color: inherit;
  transition: border-color .25s ease, transform .25s ease;
}

body.aha-learn-page .aha-learn-qa__card:hover {
  border-color: var(--aha-gold);
  transform: translateY(-2px);
}

body.aha-learn-page .aha-learn-qa__card-eyebrow {
  font-family: var(--aha-sans);
  font-size: .58rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--aha-gold);
  margin-bottom: .75rem;
  font-weight: 400;
}

body.aha-learn-page .aha-learn-qa__card-title {
  font-family: var(--aha-serif);
  font-weight: 400;
  font-size: 1.2rem;
  line-height: 1.2;
  color: var(--aha-ink);
  margin: 0 0 .85rem;
}

body.aha-learn-page .aha-learn-qa__card-excerpt {
  font-family: var(--aha-sans);
  font-weight: 300;
  font-size: .8rem;
  line-height: 1.6;
  color: var(--aha-ink-soft);
  margin: 0;
}

/* ----- Learn hub responsive ----- */
@media (max-width: 768px) {
  body.aha-learn-page .aha-essay {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }
  body.aha-learn-page .aha-essay--image-right {
    grid-template-areas: "image" "body";
  }
  body.aha-learn-page .aha-learn-qa__grid {
    grid-template-columns: 1fr;
  }
  body.aha-learn-page .aha-learn-hero {
    padding: 2.5rem 1rem 2rem;
  }
  body.aha-learn-page .aha-learn-section {
    padding: 2.5rem 0 2rem;
  }
}


/* ==========================================================================
   SINGLE POST â€” SHARED (both essay and Q&A)
   ========================================================================== */

body.aha-learn-post {
  background: var(--aha-paper);
}

body.aha-learn-post .aha-learn-post-wrap {
  max-width: 820px;
  margin: 0 auto;
  padding: 0 1.5rem 5rem;
}

/* Breadcrumb */
body.aha-learn-post .aha-post-breadcrumb {
  font-family: var(--aha-sans);
  font-size: .58rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--aha-ink-muted);
  padding: 1.75rem 0 .75rem;
}

body.aha-learn-post .aha-post-breadcrumb a {
  color: var(--aha-gold);
  text-decoration: none;
  transition: color .2s ease;
}

body.aha-learn-post .aha-post-breadcrumb a:hover {
  color: var(--aha-ink);
}

body.aha-learn-post .aha-post-breadcrumb__sep {
  color: var(--aha-paper-dark);
  margin: 0 .5rem;
}

/* Hero block */
body.aha-learn-post .aha-post-hero {
  padding: .5rem 0 2.5rem;
  text-align: center;
}

body.aha-learn-post .aha-post-hero__eyebrow {
  font-family: var(--aha-sans);
  font-size: .62rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--aha-gold);
  margin-bottom: 1rem;
  font-weight: 400;
}

body.aha-learn-post .aha-post-hero__title {
  font-family: var(--aha-serif);
  font-weight: 300;
  font-size: clamp(2rem, 4.5vw, 3.4rem);
  line-height: 1.05;
  color: var(--aha-ink);
  margin: 0 0 1.25rem;
  letter-spacing: -.01em;
}

body.aha-learn-post .aha-post-hero__title em {
  font-style: italic;
  color: var(--aha-gold);
}

body.aha-learn-post .aha-post-hero__subtitle {
  font-family: var(--aha-serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1rem, 1.6vw, 1.2rem);
  line-height: 1.35;
  color: var(--aha-ink-soft);
  margin: 0 auto 1.5rem;
  max-width: 600px;
}

body.aha-learn-post .aha-post-hero__meta {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1rem;
  font-family: var(--aha-sans);
  font-size: .6rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--aha-ink-muted);
  padding-top: 1.25rem;
  border-top: 1px solid rgba(184, 147, 90, .2);
  max-width: 420px;
  margin: 0 auto;
}

body.aha-learn-post .aha-post-hero__meta-sep {
  color: var(--aha-gold);
}

/* Featured image */
body.aha-learn-post .aha-post-featured {
  margin: 0 0 2.5rem;
}

body.aha-learn-post .aha-post-featured img {
  width: 100%;
  height: auto;
  display: block;
}

/* Body â€” shared base typography */
body.aha-learn-post .aha-post-body {
  max-width: 660px;
  margin: 0 auto;
  font-family: var(--aha-sans);
  font-weight: 300;
  font-size: 1rem;
  line-height: 1.75;
  color: var(--aha-ink);
}

body.aha-learn-post .aha-post-body p {
  margin: 0 0 1.5rem;
}

body.aha-learn-post .aha-post-body a {
  color: var(--aha-gold);
  text-decoration: none;
  border-bottom: 1px solid rgba(184, 147, 90, .4);
  transition: border-color .2s ease;
}

body.aha-learn-post .aha-post-body a:hover {
  border-color: var(--aha-gold);
}

body.aha-learn-post .aha-post-body em,
body.aha-learn-post .aha-post-body i {
  font-style: italic;
  color: var(--aha-ink-soft);
}

body.aha-learn-post .aha-post-body strong,
body.aha-learn-post .aha-post-body b {
  font-weight: 500;
  color: var(--aha-ink);
}

body.aha-learn-post .aha-post-body ul,
body.aha-learn-post .aha-post-body ol {
  margin: 0 0 1.5rem;
  padding-left: 1.5rem;
}

body.aha-learn-post .aha-post-body li {
  margin-bottom: .5rem;
}

body.aha-learn-post .aha-post-body img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 2rem auto;
}

body.aha-learn-post .aha-post-body blockquote {
  border-left: 3px solid var(--aha-gold);
  padding: .5rem 0 .5rem 1.5rem;
  margin: 2rem 0;
  font-family: var(--aha-serif);
  font-style: italic;
  font-size: 1.3rem;
  line-height: 1.4;
  color: var(--aha-ink);
}

body.aha-learn-post .aha-post-body blockquote p {
  margin: 0;
}

/* CTA block */
body.aha-learn-post .aha-post-cta {
  margin-top: 4rem;
  padding: 3rem 2rem;
  background: var(--aha-paper-warm);
  border-top: 1px solid rgba(184, 147, 90, .2);
  text-align: center;
}

body.aha-learn-post .aha-post-cta__eyebrow {
  font-family: var(--aha-sans);
  font-size: .6rem;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--aha-gold);
  margin-bottom: 1rem;
  font-weight: 400;
}

body.aha-learn-post .aha-post-cta__title {
  font-family: var(--aha-serif);
  font-weight: 300;
  font-size: 1.8rem;
  line-height: 1.15;
  color: var(--aha-ink);
  margin: 0 0 1rem;
}

body.aha-learn-post .aha-post-cta__title em {
  font-style: italic;
  color: var(--aha-gold);
}

body.aha-learn-post .aha-post-cta__sub {
  font-family: var(--aha-sans);
  font-weight: 300;
  font-size: .85rem;
  line-height: 1.55;
  color: var(--aha-ink-soft);
  margin: 0 auto 1.75rem;
  max-width: 400px;
}

body.aha-learn-post .aha-post-cta__button {
  display: inline-block;
  background: var(--aha-ink);
  color: var(--aha-paper);
  padding: .95rem 2.25rem;
  font-family: var(--aha-sans);
  font-size: .65rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  text-decoration: none;
  border: 1px solid var(--aha-ink);
  transition: background .25s ease, color .25s ease;
}

body.aha-learn-post .aha-post-cta__button:hover {
  background: var(--aha-green-deep);
  border-color: var(--aha-green-deep);
}

/* Related posts */
body.aha-learn-post .aha-post-related {
  margin-top: 3rem;
  padding: 3rem 0 0;
  border-top: 1px solid rgba(184, 147, 90, .18);
}

body.aha-learn-post .aha-post-related__header {
  text-align: center;
  margin-bottom: 2.5rem;
}

body.aha-learn-post .aha-post-related__eyebrow {
  font-family: var(--aha-sans);
  font-size: .6rem;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--aha-gold);
  margin-bottom: .5rem;
  font-weight: 400;
}

body.aha-learn-post .aha-post-related__title {
  font-family: var(--aha-serif);
  font-weight: 300;
  font-size: 1.5rem;
  color: var(--aha-ink);
  margin: 0;
}

body.aha-learn-post .aha-post-related__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
}

body.aha-learn-post .aha-post-related__card {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
  text-decoration: none;
  color: inherit;
  padding: 1rem;
  border: 1px solid transparent;
  transition: border-color .25s ease;
}

body.aha-learn-post .aha-post-related__card:hover {
  border-color: var(--aha-gold);
}

body.aha-learn-post .aha-post-related__card-img {
  width: 80px;
  height: 80px;
  background: var(--aha-paper-warm);
  flex-shrink: 0;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--aha-gold);
  font-family: var(--aha-serif);
}

body.aha-learn-post .aha-post-related__card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

body.aha-learn-post .aha-post-related__card-eyebrow {
  font-family: var(--aha-sans);
  font-size: .55rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--aha-gold);
  margin-bottom: .3rem;
}

body.aha-learn-post .aha-post-related__card-title {
  font-family: var(--aha-serif);
  font-weight: 400;
  font-size: 1rem;
  line-height: 1.2;
  color: var(--aha-ink);
  margin: 0;
}

body.aha-learn-post .aha-post-related__card-excerpt {
  font-family: var(--aha-sans);
  font-weight: 300;
  font-size: .75rem;
  line-height: 1.5;
  color: var(--aha-ink-soft);
  margin: .4rem 0 0;
}


/* ==========================================================================
   ESSAY POST â€” drop cap + styled section headers (h4 â†’ era markers)
   ========================================================================== */

/* Drop cap on the FIRST paragraph of essay body */
body.aha-learn-post--essay .aha-post-body--essay > p:first-of-type::first-letter {
  font-family: var(--aha-serif);
  font-weight: 400;
  font-size: 3.4rem;
  line-height: .85;
  float: left;
  padding: .3rem .55rem 0 0;
  color: var(--aha-gold);
}

/* Era markers â€” H4s in the body get the editorial section-break treatment */
body.aha-learn-post--essay .aha-post-body--essay h4 {
  font-family: var(--aha-sans);
  font-size: .62rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--aha-gold);
  text-align: center;
  font-weight: 400;
  margin: 3rem 0 1.5rem;
  position: relative;
  padding: 0 1rem;
}

/* Decorative horizontal lines either side of the h4 */
body.aha-learn-post--essay .aha-post-body--essay h4::before,
body.aha-learn-post--essay .aha-post-body--essay h4::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 25%;
  height: 1px;
  background: rgba(184, 147, 90, .3);
}

body.aha-learn-post--essay .aha-post-body--essay h4::before {
  left: 0;
}

body.aha-learn-post--essay .aha-post-body--essay h4::after {
  right: 0;
}

/* H2 / H3 in essays â€” serif headlines (used for "Architecture of You" etc.) */
body.aha-learn-post--essay .aha-post-body--essay h2,
body.aha-learn-post--essay .aha-post-body--essay h3 {
  font-family: var(--aha-serif);
  font-weight: 400;
  color: var(--aha-ink);
  text-align: center;
  margin: 2rem 0 1.25rem;
  line-height: 1.2;
}

body.aha-learn-post--essay .aha-post-body--essay h2 {
  font-size: 2rem;
}

body.aha-learn-post--essay .aha-post-body--essay h3 {
  font-size: 1.5rem;
}


/* ==========================================================================
   Q&A POST â€” cleaner FAQ-style body, no drop cap, no era markers
   ========================================================================== */

/* Center-narrow body width */
body.aha-learn-post--qa .aha-post-body--qa {
  max-width: 640px;
}

/* H3 in Q&A â€” section labels in serif */
body.aha-learn-post--qa .aha-post-body--qa h3 {
  font-family: var(--aha-serif);
  font-weight: 400;
  font-size: 1.5rem;
  color: var(--aha-ink);
  margin: 2.5rem 0 1rem;
  line-height: 1.2;
}

/* H4 in Q&A â€” smaller serif subhead (NOT era markers like essays) */
body.aha-learn-post--qa .aha-post-body--qa h4 {
  font-family: var(--aha-serif);
  font-weight: 400;
  font-size: 1.2rem;
  color: var(--aha-ink);
  margin: 2rem 0 .85rem;
  line-height: 1.25;
}

/* The Q&A posts use bold paragraphs as inline section labels â€” give them
   a little more typographic weight and gold accent */
body.aha-learn-post--qa .aha-post-body--qa p strong:first-child:only-child {
  display: block;
  font-family: var(--aha-sans);
  font-size: .68rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--aha-gold);
  font-weight: 500;
  margin: 2rem 0 .5rem;
}

/* Q&A Q&A pairs â€” bold question followed by paragraph answer */
body.aha-learn-post--qa .aha-post-body--qa p strong:first-child {
  display: inline-block;
  font-family: var(--aha-sans);
  font-weight: 500;
  color: var(--aha-ink);
}

/* Q&A CTA gets a smaller, less hero-ish treatment */
body.aha-learn-post--qa .aha-post-cta--qa {
  padding: 2.5rem 2rem;
}

body.aha-learn-post--qa .aha-post-cta--qa .aha-post-cta__title {
  font-size: 1.5rem;
}

/* Q&A featured image â€” smaller / contained, since these are shorter posts */
body.aha-learn-post--qa .aha-post-featured--qa {
  max-width: 540px;
  margin: 0 auto 2.5rem;
}

/* Q&A related cards â€” text-only, no thumbnails */
body.aha-learn-post--qa .aha-post-related__card--qa {
  padding: 1.5rem;
  background: var(--aha-paper-warm);
  border: 1px solid var(--aha-paper-dark);
}

body.aha-learn-post--qa .aha-post-related__card--qa:hover {
  background: var(--aha-paper);
}


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

@media (max-width: 640px) {
  body.aha-learn-post .aha-post-hero__title {
    font-size: 2rem;
  }
  body.aha-learn-post .aha-post-related__grid {
    grid-template-columns: 1fr;
  }
  body.aha-learn-post .aha-post-hero__meta {
    flex-wrap: wrap;
    font-size: .55rem;
  }
  body.aha-learn-post--essay .aha-post-body--essay > p:first-of-type::first-letter {
    font-size: 2.8rem;
  }
  body.aha-learn-post .aha-post-cta {
    padding: 2rem 1.5rem;
  }
}

/* ==========================================================================
   APPEND THIS BLOCK to your existing avada-child-theme/style.css
   (at the very end of the file).

   Do NOT replace the entire file â€” just append.

   Scopes:
     body.aha-account-page        â†’ all My Account pages
     .aha-nav-account             â†’ the header nav link (any page)
   ========================================================================== */


/* ==========================================================================
   HEADER ACCOUNT LINK (renders on every page via header-aha.php)
   ========================================================================== */

.aha-nav-links .aha-nav-account-wrap {
  list-style: none;
}

.aha-nav-account {
  font-family: var(--aha-sans);
  font-size: .75rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--aha-ink-soft);
  text-decoration: none;
  font-weight: 400;
  transition: color .2s ease, border-color .2s ease;
  padding-bottom: 2px;
  border-bottom: 1px solid transparent;
}

.aha-nav-account:hover {
  color: var(--aha-gold);
}

.aha-nav-account.is-active {
  color: var(--aha-gold);
  border-bottom-color: var(--aha-gold);
}


/* ==========================================================================
   MY ACCOUNT â€” PAGE SHELL
   ========================================================================== */

body.aha-account-page {
  background: var(--aha-paper);
}

body.aha-account-page .aha-account-wrap {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 1.5rem 4rem;
}


/* ==========================================================================
   HERO (logged-in + logged-out variants)
   ========================================================================== */

body.aha-account-page .aha-account-hero {
  text-align: center;
  padding: 3.5rem 1rem 2.5rem;
  border-bottom: 1px solid rgba(184, 147, 90, .15);
  margin-bottom: 2.5rem;
}

body.aha-account-page .aha-account-hero__eyebrow {
  font-family: var(--aha-sans);
  font-size: .62rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--aha-gold);
  margin-bottom: .85rem;
  font-weight: 400;
}

body.aha-account-page .aha-account-hero__title {
  font-family: var(--aha-serif);
  font-weight: 300;
  font-size: clamp(2.2rem, 4.5vw, 3.4rem);
  line-height: 1;
  color: var(--aha-ink);
  margin: 0 0 .85rem;
  letter-spacing: -.01em;
}

body.aha-account-page .aha-account-hero__title em {
  font-style: italic;
  color: var(--aha-gold);
}

body.aha-account-page .aha-account-hero__sub {
  font-family: var(--aha-sans);
  font-weight: 300;
  font-size: .9rem;
  color: var(--aha-ink-soft);
  margin: 0;
}


/* ==========================================================================
   LOGGED-OUT: LOGIN + REGISTER TWO-COLUMN LAYOUT
   ========================================================================== */

body.aha-account-page .aha-account-loggedout {
  max-width: 880px;
  margin: 0 auto;
}

body.aha-account-page .aha-account-auth__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  background: var(--aha-paper);
  border: 1px solid var(--aha-paper-dark);
}

body.aha-account-page .aha-account-auth__panel {
  padding: 2.75rem 2.25rem;
}

body.aha-account-page .aha-account-auth__panel--login {
  border-right: 1px solid var(--aha-paper-dark);
}

body.aha-account-page .aha-account-auth__eyebrow {
  font-family: var(--aha-sans);
  font-size: .6rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--aha-gold);
  margin-bottom: .65rem;
  text-align: center;
  font-weight: 400;
}

body.aha-account-page .aha-account-auth__title {
  font-family: var(--aha-serif);
  font-weight: 400;
  font-size: 1.5rem;
  color: var(--aha-ink);
  margin: 0 0 1.75rem;
  text-align: center;
  line-height: 1.2;
}

body.aha-account-page .aha-account-auth__title em {
  font-style: italic;
  color: var(--aha-gold);
}


/* ==========================================================================
   FORM FIELDS â€” shared across login, register, lost password
   ========================================================================== */

body.aha-account-page .aha-form-field {
  margin-bottom: 1.1rem;
}

body.aha-account-page .aha-form-field label {
  display: block;
  font-family: var(--aha-sans);
  font-size: .6rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--aha-ink-muted);
  margin-bottom: .4rem;
  font-weight: 400;
}

body.aha-account-page .aha-form-field label .required {
  color: var(--aha-gold);
  margin-left: 2px;
}

body.aha-account-page .aha-form-field input[type="text"],
body.aha-account-page .aha-form-field input[type="email"],
body.aha-account-page .aha-form-field input[type="password"],
body.aha-account-page .aha-form-field input[type="tel"],
body.aha-account-page .aha-account-form input.input-text,
body.aha-account-page .aha-account-form input[type="text"],
body.aha-account-page .aha-account-form input[type="email"],
body.aha-account-page .aha-account-form input[type="password"] {
  width: 100%;
  height: 42px;
  padding: .6rem .85rem;
  border: 1px solid var(--aha-paper-dark);
  background: var(--aha-paper);
  color: var(--aha-ink);
  font-family: var(--aha-sans);
  font-size: .9rem;
  border-radius: 0;
  outline: none;
  box-shadow: none;
  transition: border-color .2s ease;
}

body.aha-account-page .aha-form-field input:focus,
body.aha-account-page .aha-account-form input:focus {
  border-color: var(--aha-gold);
  outline: none;
  box-shadow: none;
}


/* ==========================================================================
   CHECKBOX (Remember me)
   ========================================================================== */

body.aha-account-page .aha-form-row--remember {
  margin-bottom: 1.4rem;
}

body.aha-account-page .aha-checkbox {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-family: var(--aha-sans);
  font-size: .72rem;
  color: var(--aha-ink-soft);
  cursor: pointer;
}

body.aha-account-page .aha-checkbox input[type="checkbox"] {
  width: 14px;
  height: 14px;
  accent-color: var(--aha-gold);
  margin: 0;
  flex-shrink: 0;
}


/* ==========================================================================
   BUTTONS â€” Sign In (primary/ink) and Create Account (secondary/green)
   ========================================================================== */

body.aha-account-page .aha-form-row {
  margin-bottom: 1rem;
}

body.aha-account-page .aha-btn-account {
  display: block;
  width: 100%;
  text-align: center;
  padding: .95rem 1.5rem;
  font-family: var(--aha-sans);
  font-size: .65rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  font-weight: 400;
  text-decoration: none;
  border-radius: 0;
  cursor: pointer;
  transition: background .2s ease, border-color .2s ease, transform .15s ease;
  border: 1px solid;
}

body.aha-account-page .aha-btn-account--primary {
  background: var(--aha-ink);
  color: var(--aha-paper);
  border-color: var(--aha-ink);
}

body.aha-account-page .aha-btn-account--primary:hover {
  background: var(--aha-green-deep);
  border-color: var(--aha-green-deep);
  color: var(--aha-paper);
  transform: translateY(-1px);
}

body.aha-account-page .aha-btn-account--secondary {
  background: var(--aha-green-deep);
  color: var(--aha-paper);
  border-color: var(--aha-green-deep);
}

body.aha-account-page .aha-btn-account--secondary:hover {
  background: var(--aha-gold);
  border-color: var(--aha-gold);
  color: var(--aha-ink);
  transform: translateY(-1px);
}


/* ==========================================================================
   LOGIN PANEL â€” utility links
   ========================================================================== */

body.aha-account-page .aha-form-row--lost {
  text-align: center;
  margin-top: 1rem;
  margin-bottom: 0;
}

body.aha-account-page .aha-account-auth__lost {
  font-family: var(--aha-sans);
  font-size: .7rem;
  color: var(--aha-gold);
  text-decoration: none;
  border-bottom: 1px solid rgba(184, 147, 90, .4);
  padding-bottom: 1px;
  transition: color .2s ease;
}

body.aha-account-page .aha-account-auth__lost:hover {
  color: var(--aha-ink);
}


/* ==========================================================================
   REGISTER PANEL â€” terms + reassurance
   ========================================================================== */

body.aha-account-page .aha-account-auth__terms {
  font-family: var(--aha-sans);
  font-size: .66rem;
  color: var(--aha-ink-muted);
  line-height: 1.5;
  margin: 0 0 1.4rem;
}

body.aha-account-page .aha-account-auth__terms a {
  color: var(--aha-gold);
  text-decoration: none;
  border-bottom: 1px solid rgba(184, 147, 90, .35);
}

body.aha-account-page .aha-account-auth__terms a:hover {
  color: var(--aha-ink);
}

body.aha-account-page .aha-account-auth__autopass {
  font-family: var(--aha-sans);
  font-size: .78rem;
  color: var(--aha-ink-soft);
  background: var(--aha-paper-warm);
  border-left: 2px solid var(--aha-gold);
  padding: .75rem .85rem;
  margin: 0 0 1.4rem;
  line-height: 1.5;
}

body.aha-account-page .aha-account-auth__reassure {
  text-align: center;
  font-family: var(--aha-sans);
  font-size: .68rem;
  color: var(--aha-ink-muted);
  line-height: 1.5;
  margin: 1rem 0 0;
}


/* ==========================================================================
   LOST PASSWORD VIEW
   ========================================================================== */

body.aha-account-page .aha-account-auth--lost-password {
  max-width: 460px;
  margin: 0 auto;
}

body.aha-account-page .aha-account-auth__lost-panel {
  background: var(--aha-paper);
  border: 1px solid var(--aha-paper-dark);
  padding: 2.75rem 2.25rem;
}

body.aha-account-page .aha-account-auth__lost-intro {
  font-family: var(--aha-sans);
  font-size: .85rem;
  color: var(--aha-ink-soft);
  line-height: 1.65;
  margin: 0 0 1.75rem;
  text-align: center;
}

body.aha-account-page .aha-account-auth__lost-back {
  text-align: center;
  margin: 1.5rem 0 0;
  font-family: var(--aha-sans);
  font-size: .75rem;
}

body.aha-account-page .aha-account-auth__lost-back a {
  color: var(--aha-ink-soft);
  text-decoration: none;
  transition: color .2s ease;
}

body.aha-account-page .aha-account-auth__lost-back a:hover {
  color: var(--aha-gold);
}


/* ==========================================================================
   LOGGED-IN: SIDEBAR + CONTENT LAYOUT
   ========================================================================== */

body.aha-account-page .aha-account-layout {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 0;
  background: var(--aha-paper);
  border: 1px solid var(--aha-paper-dark);
  align-items: stretch;
}


/* ==========================================================================
   SIDEBAR NAVIGATION
   ========================================================================== */

body.aha-account-page .aha-account-sidebar {
  background: var(--aha-paper-warm);
  border-right: 1px solid var(--aha-paper-dark);
}

body.aha-account-page .aha-account-nav {
  padding: 1.5rem 0;
}

body.aha-account-page .aha-account-nav__eyebrow {
  font-family: var(--aha-sans);
  font-size: .58rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--aha-gold);
  padding: 0 1.5rem .75rem;
  font-weight: 400;
}

body.aha-account-page .aha-account-nav__list {
  list-style: none;
  margin: 0;
  padding: 0;
}

body.aha-account-page .aha-account-nav__item {
  margin: 0;
  padding: 0;
}

body.aha-account-page .aha-account-nav__link {
  display: block;
  padding: .85rem 1.5rem;
  font-family: var(--aha-sans);
  font-size: .78rem;
  color: var(--aha-ink-soft);
  text-decoration: none;
  border-left: 2px solid transparent;
  transition: color .2s ease, background .2s ease, border-color .2s ease;
}

body.aha-account-page .aha-account-nav__link:hover {
  color: var(--aha-ink);
  background: rgba(247, 244, 239, .5);
}

/* Active state â€” WC adds .is-active class to current endpoint */
body.aha-account-page .aha-account-nav__item.is-active .aha-account-nav__link,
body.aha-account-page .woocommerce-MyAccount-navigation-link.is-active .aha-account-nav__link {
  color: var(--aha-ink);
  background: var(--aha-paper);
  border-left-color: var(--aha-gold);
}

/* Logout link â€” visually separated with divider */
body.aha-account-page .aha-account-nav__item.woocommerce-MyAccount-navigation-link--customer-logout {
  border-top: 1px solid rgba(184, 147, 90, .18);
  margin-top: .85rem;
  padding-top: .85rem;
}

body.aha-account-page .aha-account-nav__link--logout {
  color: var(--aha-ink-muted);
  font-size: .72rem;
}


/* ==========================================================================
   CONTENT AREA
   ========================================================================== */

body.aha-account-page .aha-account-content {
  padding: 2rem;
  min-width: 0;
}


/* ==========================================================================
   DASHBOARD
   ========================================================================== */

body.aha-account-page .aha-dashboard__cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
  margin-bottom: 1.75rem;
}

body.aha-account-page .aha-dashboard__card {
  background: var(--aha-paper-warm);
  padding: 1.5rem 1.25rem;
  border: 1px solid var(--aha-paper-dark);
}

body.aha-account-page .aha-dashboard__card-eyebrow {
  font-family: var(--aha-sans);
  font-size: .58rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--aha-gold);
  margin-bottom: .55rem;
  font-weight: 400;
}

body.aha-account-page .aha-dashboard__card-title {
  font-family: var(--aha-serif);
  font-weight: 400;
  font-size: 1.05rem;
  color: var(--aha-ink);
  margin: 0 0 .3rem;
  line-height: 1.2;
}

body.aha-account-page .aha-dashboard__card-title--empty {
  color: var(--aha-ink-soft);
}

body.aha-account-page .aha-dashboard__card-title em {
  font-style: italic;
  color: var(--aha-gold);
}

body.aha-account-page .aha-dashboard__card-sep {
  color: var(--aha-gold);
  margin: 0 .3rem;
}

body.aha-account-page .aha-dashboard__card-item {
  font-style: italic;
  color: var(--aha-ink-soft);
}

body.aha-account-page .aha-dashboard__card-extra {
  font-size: .7rem;
  color: var(--aha-ink-muted);
  margin-left: .3rem;
}

body.aha-account-page .aha-dashboard__card-meta {
  font-family: var(--aha-sans);
  font-size: .7rem;
  color: var(--aha-ink-soft);
  margin: 0 0 .85rem;
}

body.aha-account-page .aha-dashboard__card-cta {
  display: inline-block;
  font-family: var(--aha-sans);
  font-size: .58rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--aha-ink);
  text-decoration: none;
  border-bottom: 1px solid var(--aha-gold);
  padding-bottom: 1px;
  transition: color .2s ease, border-color .2s ease;
}

body.aha-account-page .aha-dashboard__card-cta:hover {
  color: var(--aha-gold);
  border-color: var(--aha-ink);
}


/* Continue the practice nudge block */
body.aha-account-page .aha-dashboard__nudge {
  background: var(--aha-paper);
  border: 1px solid var(--aha-paper-dark);
  padding: 1.75rem 1.5rem;
}

body.aha-account-page .aha-dashboard__nudge-eyebrow {
  font-family: var(--aha-sans);
  font-size: .6rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--aha-gold);
  margin-bottom: .65rem;
  font-weight: 400;
}

body.aha-account-page .aha-dashboard__nudge-title {
  font-family: var(--aha-serif);
  font-weight: 400;
  font-size: 1.3rem;
  color: var(--aha-ink);
  margin: 0 0 .5rem;
  line-height: 1.2;
}

body.aha-account-page .aha-dashboard__nudge-title em {
  font-style: italic;
  color: var(--aha-gold);
}

body.aha-account-page .aha-dashboard__nudge-body {
  font-family: var(--aha-sans);
  font-weight: 300;
  font-size: .82rem;
  color: var(--aha-ink-soft);
  line-height: 1.6;
  margin: 0 0 1.25rem;
}

body.aha-account-page .aha-dashboard__nudge-cta {
  display: inline-block;
  background: var(--aha-ink);
  color: var(--aha-paper);
  padding: .7rem 1.5rem;
  font-family: var(--aha-sans);
  font-size: .6rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  text-decoration: none;
  border: 1px solid var(--aha-ink);
  transition: background .2s ease, border-color .2s ease;
}

body.aha-account-page .aha-dashboard__nudge-cta:hover {
  background: var(--aha-green-deep);
  border-color: var(--aha-green-deep);
}


/* ==========================================================================
   WOOCOMMERCE NOTICES (errors, info messages)
   ========================================================================== */

body.aha-account-page .woocommerce-message,
body.aha-account-page .woocommerce-info,
body.aha-account-page .woocommerce-error,
body.aha-account-page .woocommerce-notices-wrapper > * {
  background: var(--aha-paper-warm) !important;
  border: none !important;
  border-left: 3px solid var(--aha-gold) !important;
  color: var(--aha-ink) !important;
  font-family: var(--aha-sans) !important;
  font-size: .88rem !important;
  padding: 1rem 1.25rem !important;
  border-radius: 0 !important;
  margin-bottom: 1.5rem;
  list-style: none;
}

body.aha-account-page .woocommerce-error {
  border-left-color: var(--aha-red) !important;
}


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

@media (max-width: 768px) {
  body.aha-account-page .aha-account-auth__grid {
    grid-template-columns: 1fr;
  }
  body.aha-account-page .aha-account-auth__panel--login {
    border-right: none;
    border-bottom: 1px solid var(--aha-paper-dark);
  }
  body.aha-account-page .aha-account-layout {
    grid-template-columns: 1fr;
  }
  body.aha-account-page .aha-account-sidebar {
    border-right: none;
    border-bottom: 1px solid var(--aha-paper-dark);
  }
  body.aha-account-page .aha-dashboard__cards {
    grid-template-columns: 1fr;
  }
  body.aha-account-page .aha-account-hero {
    padding: 2.5rem 1rem 2rem;
  }
  body.aha-account-page .aha-account-content {
    padding: 1.5rem;
  }
}

/* ==========================================================================
   APPEND THIS BLOCK to your existing avada-child-theme/style.css
   (at the very end of the file, AFTER the Phase 1 account block).

   Do NOT replace the entire file â€” just append.

   Scopes:
     body.aha-account-page   â†’ all My Account pages
   ========================================================================== */


/* ==========================================================================
   SHARED SECTION HEADER (used by edit-account, my-address, etc.)
   ========================================================================== */

body.aha-account-page .aha-account-edit__header,
body.aha-account-page .aha-account-edit-address__header,
body.aha-account-page .aha-account-addresses__header,
body.aha-account-page .aha-account-orders__header,
body.aha-account-page .aha-view-order__header {
  margin-bottom: 2rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid rgba(184, 147, 90, .18);
}

body.aha-account-page .aha-account-edit__eyebrow,
body.aha-account-page .aha-account-edit-address__eyebrow,
body.aha-account-page .aha-account-addresses__eyebrow,
body.aha-account-page .aha-account-orders__eyebrow,
body.aha-account-page .aha-view-order__eyebrow {
  font-family: var(--aha-sans);
  font-size: .62rem;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--aha-gold);
  margin-bottom: .6rem;
  font-weight: 400;
}

body.aha-account-page .aha-account-edit__title,
body.aha-account-page .aha-account-edit-address__title,
body.aha-account-page .aha-account-addresses__title,
body.aha-account-page .aha-account-orders__title,
body.aha-account-page .aha-view-order__title {
  font-family: var(--aha-serif);
  font-weight: 300;
  font-size: 1.85rem;
  color: var(--aha-ink);
  margin: 0 0 .5rem;
  line-height: 1.15;
  letter-spacing: -.005em;
}

body.aha-account-page .aha-account-edit__title em,
body.aha-account-page .aha-account-edit-address__title em,
body.aha-account-page .aha-account-addresses__title em,
body.aha-account-page .aha-account-orders__title em,
body.aha-account-page .aha-view-order__title em {
  font-style: italic;
  color: var(--aha-gold);
}

body.aha-account-page .aha-account-edit__sub,
body.aha-account-page .aha-account-edit-address__sub,
body.aha-account-page .aha-account-addresses__sub {
  font-family: var(--aha-sans);
  font-weight: 300;
  font-size: .85rem;
  color: var(--aha-ink-soft);
  margin: 0;
  line-height: 1.55;
}


/* ==========================================================================
   EDIT ACCOUNT FORM â€” name, email, password
   ========================================================================== */

/* Two-column row for first/last name */
body.aha-account-page .aha-form-row-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

body.aha-account-page .aha-form-row-grid .aha-form-field {
  margin-bottom: 1.1rem;
}

/* Field hint text (e.g. "This will be how your name is displayed") */
body.aha-account-page .aha-form-hint {
  display: block;
  font-family: var(--aha-serif);
  font-style: italic;
  font-size: .78rem;
  color: var(--aha-ink-muted);
  margin-top: .35rem;
  line-height: 1.5;
}

/* Password change fieldset */
body.aha-account-page .aha-form-fieldset {
  border: 1px solid var(--aha-paper-dark);
  background: var(--aha-paper-warm);
  padding: 1.5rem 1.5rem 1rem;
  margin: 1.75rem 0;
}

body.aha-account-page .aha-form-legend {
  font-family: var(--aha-sans);
  font-size: .6rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--aha-gold);
  font-weight: 400;
  padding: 0 .5rem;
  margin-left: -.5rem;
}

body.aha-account-page .aha-form-fieldset-hint {
  font-family: var(--aha-sans);
  font-size: .8rem;
  color: var(--aha-ink-soft);
  margin: 0 0 1rem;
  font-style: italic;
}

/* Form action row (Save Changes button) */
body.aha-account-page .aha-form-row--actions {
  margin-top: 1.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--aha-paper-dark);
}

/* Make Save button inline rather than full-width when alone */
body.aha-account-page .aha-form-row--actions .aha-btn-account {
  display: inline-block;
  width: auto;
  min-width: 200px;
}


/* ==========================================================================
   MY ADDRESS OVERVIEW (two cards)
   ========================================================================== */

body.aha-account-page .aha-account-addresses__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
}

body.aha-account-page .aha-account-addresses__grid--single {
  grid-template-columns: 1fr;
  max-width: 480px;
}

body.aha-account-page .aha-address-card {
  background: var(--aha-paper-warm);
  border: 1px solid var(--aha-paper-dark);
  padding: 1.5rem 1.5rem 1.25rem;
  display: flex;
  flex-direction: column;
  min-height: 200px;
}

body.aha-account-page .aha-address-card__eyebrow {
  font-family: var(--aha-sans);
  font-size: .58rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--aha-gold);
  margin-bottom: .85rem;
  font-weight: 400;
}

body.aha-account-page .aha-address-card__body {
  font-family: var(--aha-serif);
  font-weight: 400;
  font-size: 1rem;
  line-height: 1.55;
  color: var(--aha-ink);
  font-style: normal;
  margin: 0 0 1.25rem;
  flex: 1;
}

body.aha-account-page .aha-address-card__empty {
  flex: 1;
  margin: 0 0 1.25rem;
}

body.aha-account-page .aha-address-card__empty p {
  font-family: var(--aha-sans);
  font-weight: 300;
  font-style: italic;
  font-size: .9rem;
  color: var(--aha-ink-muted);
  margin: 0;
  line-height: 1.5;
}

body.aha-account-page .aha-address-card__footer {
  border-top: 1px solid rgba(184, 147, 90, .2);
  padding-top: 1rem;
}

body.aha-account-page .aha-address-card__cta {
  display: inline-block;
  font-family: var(--aha-sans);
  font-size: .58rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--aha-ink);
  text-decoration: none;
  border-bottom: 1px solid var(--aha-gold);
  padding-bottom: 1px;
  transition: color .2s ease, border-color .2s ease;
}

body.aha-account-page .aha-address-card__cta:hover {
  color: var(--aha-gold);
  border-color: var(--aha-ink);
}


/* ==========================================================================
   EDIT ADDRESS FORM â€” country/state dropdowns + all standard fields
   ========================================================================== */

body.aha-account-page .aha-address-fields {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem 1.25rem;
}

/* Full-width fields */
body.aha-account-page .aha-address-field-wrap--billing_address_1,
body.aha-account-page .aha-address-field-wrap--billing_address_2,
body.aha-account-page .aha-address-field-wrap--shipping_address_1,
body.aha-account-page .aha-address-field-wrap--shipping_address_2,
body.aha-account-page .aha-address-field-wrap--billing_country,
body.aha-account-page .aha-address-field-wrap--shipping_country {
  grid-column: 1 / -1;
}

/* WC form field wrapper â€” strip default <p> margin */
body.aha-account-page .aha-address-field-wrap .form-row,
body.aha-account-page .aha-address-field-wrap p.form-row {
  margin: 0 0 .25rem;
  padding: 0;
}

/* WC labels â€” restyle to match our form pattern */
body.aha-account-page .aha-address-field-wrap label {
  display: block;
  font-family: var(--aha-sans);
  font-size: .6rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--aha-ink-muted);
  margin-bottom: .4rem;
  font-weight: 400;
}

body.aha-account-page .aha-address-field-wrap label .required,
body.aha-account-page .aha-address-field-wrap label abbr.required {
  color: var(--aha-gold);
  border: none;
  text-decoration: none;
}

body.aha-account-page .aha-address-field-wrap label .optional {
  color: var(--aha-ink-muted);
  font-style: italic;
}

/* WC text inputs â€” restyle to match our form pattern */
body.aha-account-page .aha-address-field-wrap input[type="text"],
body.aha-account-page .aha-address-field-wrap input[type="email"],
body.aha-account-page .aha-address-field-wrap input[type="tel"],
body.aha-account-page .aha-address-field-wrap input.input-text {
  width: 100% !important;
  height: 42px !important;
  padding: .6rem .85rem !important;
  border: 1px solid var(--aha-paper-dark) !important;
  background: var(--aha-paper) !important;
  color: var(--aha-ink) !important;
  font-family: var(--aha-sans) !important;
  font-size: .9rem !important;
  border-radius: 0 !important;
  outline: none;
  box-shadow: none !important;
  transition: border-color .2s ease;
}

body.aha-account-page .aha-address-field-wrap input:focus {
  border-color: var(--aha-gold) !important;
}

/* Native select fallback (before select2 enhances) */
body.aha-account-page .aha-address-field-wrap select {
  width: 100% !important;
  height: 42px !important;
  padding: .6rem .85rem !important;
  border: 1px solid var(--aha-paper-dark) !important;
  background: var(--aha-paper) !important;
  color: var(--aha-ink) !important;
  font-family: var(--aha-sans) !important;
  font-size: .9rem !important;
  border-radius: 0 !important;
  outline: none;
  appearance: none;
  -webkit-appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, var(--aha-gold) 50%),
                    linear-gradient(135deg, var(--aha-gold) 50%, transparent 50%);
  background-position: calc(100% - 1.2rem) center, calc(100% - .8rem) center;
  background-size: .4rem .4rem;
  background-repeat: no-repeat;
  padding-right: 2.5rem !important;
}

/* select2 enhanced dropdown â€” Country/State selectors */
body.aha-account-page .aha-address-field-wrap .select2-container {
  width: 100% !important;
}

body.aha-account-page .aha-address-field-wrap .select2-container--default .select2-selection--single {
  width: 100% !important;
  height: 42px !important;
  padding: 0 !important;
  border: 1px solid var(--aha-paper-dark) !important;
  background: var(--aha-paper) !important;
  border-radius: 0 !important;
  outline: none;
  box-shadow: none !important;
}

body.aha-account-page .aha-address-field-wrap .select2-container--default .select2-selection--single .select2-selection__rendered {
  line-height: 42px !important;
  padding: 0 2.5rem 0 .85rem !important;
  color: var(--aha-ink) !important;
  font-family: var(--aha-sans) !important;
  font-size: .9rem !important;
}

body.aha-account-page .aha-address-field-wrap .select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 42px !important;
  right: .8rem !important;
}

body.aha-account-page .aha-address-field-wrap .select2-container--default.select2-container--focus .select2-selection--single,
body.aha-account-page .aha-address-field-wrap .select2-container--default.select2-container--open .select2-selection--single {
  border-color: var(--aha-gold) !important;
}

/* select2 dropdown panel (renders outside our form, scoped via body) */
body.aha-account-page .select2-dropdown {
  border: 1px solid var(--aha-paper-dark) !important;
  background: var(--aha-paper) !important;
  border-radius: 0 !important;
}

body.aha-account-page .select2-container--default .select2-results__option--highlighted[aria-selected],
body.aha-account-page .select2-container--default .select2-results__option--highlighted.select2-results__option--selectable {
  background: var(--aha-gold-pale) !important;
  color: var(--aha-ink) !important;
}

body.aha-account-page .select2-container--default .select2-search--dropdown .select2-search__field {
  border: 1px solid var(--aha-paper-dark) !important;
  font-family: var(--aha-sans) !important;
  font-size: .85rem !important;
  padding: .5rem .75rem !important;
}


/* ==========================================================================
   ORDERS TABLE
   ========================================================================== */

body.aha-account-page .aha-account-orders__table-wrap {
  overflow-x: auto;
}

body.aha-account-page .aha-orders-table {
  width: 100%;
  border-collapse: collapse;
  border: none;
}

body.aha-account-page .aha-orders-table th,
body.aha-account-page .aha-orders-table td {
  padding: 1rem .85rem;
  text-align: left;
  border: none;
  background: transparent;
  font-family: var(--aha-sans);
}

body.aha-account-page .aha-orders-table thead tr {
  border-bottom: 1px solid var(--aha-paper-dark);
}

body.aha-account-page .aha-orders-table__head {
  font-family: var(--aha-sans) !important;
  font-size: .6rem !important;
  letter-spacing: .14em !important;
  text-transform: uppercase !important;
  color: var(--aha-ink-muted) !important;
  font-weight: 400 !important;
  padding-top: 0 !important;
}

body.aha-account-page .aha-orders-table tbody tr {
  border-bottom: 1px solid rgba(184, 147, 90, .15);
  transition: background .15s ease;
}

body.aha-account-page .aha-orders-table tbody tr:hover {
  background: var(--aha-paper-warm);
}

body.aha-account-page .aha-orders-table tbody tr:last-child {
  border-bottom: 1px solid var(--aha-paper-dark);
}

body.aha-account-page .aha-orders-table__num {
  font-family: var(--aha-serif);
  font-size: 1.05rem;
  font-weight: 400;
  color: var(--aha-ink);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color .2s ease;
}

body.aha-account-page .aha-orders-table__num:hover {
  border-bottom-color: var(--aha-gold);
}

body.aha-account-page .aha-orders-table__date {
  font-size: .85rem;
  color: var(--aha-ink-soft);
}

body.aha-account-page .aha-orders-table__status {
  display: inline-block;
  font-family: var(--aha-sans);
  font-size: .58rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: .35rem .65rem;
  border-radius: 0;
  background: var(--aha-paper-warm);
  color: var(--aha-ink-soft);
  border: 1px solid rgba(184, 147, 90, .25);
}

body.aha-account-page .aha-orders-table__status--completed,
body.aha-account-page .aha-orders-table__status--delivered {
  background: rgba(125, 161, 0, .12);
  color: var(--aha-green-deep);
  border-color: rgba(125, 161, 0, .35);
}

body.aha-account-page .aha-orders-table__status--processing,
body.aha-account-page .aha-orders-table__status--on-hold {
  background: var(--aha-gold-pale);
  color: var(--aha-gold);
  border-color: rgba(184, 147, 90, .4);
}

body.aha-account-page .aha-orders-table__status--cancelled,
body.aha-account-page .aha-orders-table__status--refunded,
body.aha-account-page .aha-orders-table__status--failed {
  background: rgba(139, 46, 26, .08);
  color: var(--aha-red);
  border-color: rgba(139, 46, 26, .25);
}

body.aha-account-page .aha-orders-table__total {
  font-family: var(--aha-serif);
  font-size: 1rem;
  color: var(--aha-ink);
}

body.aha-account-page .aha-orders-table__actions {
  display: flex;
  gap: .5rem;
  flex-wrap: wrap;
  justify-content: flex-end;
}

body.aha-account-page .aha-orders-action {
  display: inline-block;
  font-family: var(--aha-sans);
  font-size: .58rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: .55rem 1rem;
  text-decoration: none;
  background: var(--aha-ink) !important;
  color: var(--aha-paper) !important;
  border: 1px solid var(--aha-ink);
  border-radius: 0;
  transition: background .2s ease, color .2s ease;
}

body.aha-account-page .aha-orders-action:hover {
  background: var(--aha-green-deep) !important;
  border-color: var(--aha-green-deep);
}

body.aha-account-page .aha-orders-action--pay,
body.aha-account-page .aha-orders-action--cancel {
  background: var(--aha-paper) !important;
  color: var(--aha-ink) !important;
  border-color: var(--aha-paper-dark);
}

body.aha-account-page .aha-orders-action--pay:hover,
body.aha-account-page .aha-orders-action--cancel:hover {
  border-color: var(--aha-gold);
  color: var(--aha-gold) !important;
}

/* Orders pagination */
body.aha-account-page .aha-orders-pagination {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 1.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--aha-paper-dark);
}

body.aha-account-page .aha-orders-pagination__btn {
  font-family: var(--aha-sans);
  font-size: .6rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--aha-ink);
  text-decoration: none;
  padding: .55rem 1rem;
  border: 1px solid var(--aha-paper-dark);
  background: var(--aha-paper);
  transition: border-color .2s ease, color .2s ease;
}

body.aha-account-page .aha-orders-pagination__btn:hover {
  border-color: var(--aha-gold);
  color: var(--aha-gold);
}

body.aha-account-page .aha-orders-pagination__btn--prev {
  margin-right: auto;
}

body.aha-account-page .aha-orders-pagination__btn--next {
  margin-left: auto;
}

/* Empty state */
body.aha-account-page .aha-account-orders__empty {
  text-align: center;
  padding: 3rem 1.5rem;
  background: var(--aha-paper-warm);
  border: 1px solid var(--aha-paper-dark);
}

body.aha-account-page .aha-account-orders__empty-eyebrow {
  font-family: var(--aha-sans);
  font-size: .6rem;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--aha-gold);
  margin-bottom: .85rem;
  font-weight: 400;
}

body.aha-account-page .aha-account-orders__empty-title {
  font-family: var(--aha-serif);
  font-weight: 300;
  font-size: 1.6rem;
  color: var(--aha-ink);
  margin: 0 0 .85rem;
  line-height: 1.2;
}

body.aha-account-page .aha-account-orders__empty-title em {
  font-style: italic;
  color: var(--aha-gold);
}

body.aha-account-page .aha-account-orders__empty-body {
  font-family: var(--aha-sans);
  font-weight: 300;
  font-size: .9rem;
  color: var(--aha-ink-soft);
  margin: 0 0 1.5rem;
  line-height: 1.55;
}

body.aha-account-page .aha-btn-account--inline {
  display: inline-block !important;
  width: auto !important;
  min-width: 200px;
}


/* ==========================================================================
   VIEW ORDER â€” single order detail
   ========================================================================== */

body.aha-account-page .aha-view-order__meta {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
  margin-top: 1rem;
}

body.aha-account-page .aha-view-order__status {
  display: inline-block;
  font-family: var(--aha-sans);
  font-size: .58rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: .4rem .75rem;
  background: var(--aha-paper-warm);
  color: var(--aha-ink-soft);
  border: 1px solid rgba(184, 147, 90, .25);
}

body.aha-account-page .aha-view-order__status--completed,
body.aha-account-page .aha-view-order__status--delivered {
  background: rgba(125, 161, 0, .12);
  color: var(--aha-green-deep);
  border-color: rgba(125, 161, 0, .35);
}

body.aha-account-page .aha-view-order__status--processing {
  background: var(--aha-gold-pale);
  color: var(--aha-gold);
  border-color: rgba(184, 147, 90, .4);
}

body.aha-account-page .aha-view-order__pay-cta {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  font-family: var(--aha-sans);
  font-size: .65rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  background: var(--aha-ink);
  color: var(--aha-paper);
  padding: .65rem 1.25rem;
  text-decoration: none;
  border: 1px solid var(--aha-ink);
  transition: background .2s ease;
}

body.aha-account-page .aha-view-order__pay-cta:hover {
  background: var(--aha-green-deep);
  border-color: var(--aha-green-deep);
  color: var(--aha-paper);
}

/* Customer notes section */
body.aha-account-page .aha-view-order__notes {
  margin: 2rem 0;
  padding: 1.5rem;
  background: var(--aha-paper-warm);
  border: 1px solid var(--aha-paper-dark);
}

body.aha-account-page .aha-view-order__section-title {
  font-family: var(--aha-sans);
  font-size: .6rem;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--aha-gold);
  font-weight: 400;
  margin: 0 0 1rem;
}

body.aha-account-page .aha-view-order__notes-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

body.aha-account-page .aha-view-order__note {
  padding: 1rem 0;
  border-bottom: 1px solid rgba(184, 147, 90, .15);
}

body.aha-account-page .aha-view-order__note:first-child {
  padding-top: 0;
}

body.aha-account-page .aha-view-order__note:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

body.aha-account-page .aha-view-order__note-date {
  font-family: var(--aha-sans);
  font-size: .68rem;
  color: var(--aha-ink-muted);
  margin-bottom: .35rem;
}

body.aha-account-page .aha-view-order__note-body {
  font-family: var(--aha-sans);
  font-weight: 300;
  font-size: .9rem;
  line-height: 1.55;
  color: var(--aha-ink);
}

body.aha-account-page .aha-view-order__note-body p {
  margin: 0 0 .5rem;
}

body.aha-account-page .aha-view-order__note-body p:last-child {
  margin-bottom: 0;
}

/* Restyle WC's default order details table that renders inside .aha-view-order__details */
body.aha-account-page .aha-view-order__details {
  margin-top: 1rem;
}

body.aha-account-page .aha-view-order__details h2,
body.aha-account-page .aha-view-order__details h3 {
  font-family: var(--aha-serif) !important;
  font-weight: 400 !important;
  font-size: 1.25rem !important;
  color: var(--aha-ink) !important;
  margin: 1.75rem 0 1rem !important;
  letter-spacing: -.005em;
}

/* WC items table inside view-order */
body.aha-account-page .aha-view-order__details .woocommerce-table--order-details,
body.aha-account-page .aha-view-order__details table.shop_table {
  width: 100% !important;
  border-collapse: collapse !important;
  border: none !important;
  margin: 0 0 1.5rem;
  background: transparent !important;
}

body.aha-account-page .aha-view-order__details table.shop_table thead {
  border-bottom: 1px solid var(--aha-paper-dark) !important;
}

body.aha-account-page .aha-view-order__details table.shop_table th,
body.aha-account-page .aha-view-order__details table.shop_table td {
  border: none !important;
  background: transparent !important;
  padding: .85rem .5rem !important;
  font-family: var(--aha-sans) !important;
}

body.aha-account-page .aha-view-order__details table.shop_table thead th {
  font-size: .6rem !important;
  letter-spacing: .14em !important;
  text-transform: uppercase !important;
  color: var(--aha-ink-muted) !important;
  font-weight: 400 !important;
  text-align: left;
}

body.aha-account-page .aha-view-order__details table.shop_table tbody tr {
  border-bottom: 1px solid rgba(184, 147, 90, .15) !important;
}

body.aha-account-page .aha-view-order__details table.shop_table tfoot tr {
  border-top: 1px solid var(--aha-paper-dark) !important;
}

body.aha-account-page .aha-view-order__details table.shop_table tfoot th {
  font-family: var(--aha-sans) !important;
  font-size: .68rem !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
  color: var(--aha-ink-muted) !important;
  font-weight: 400 !important;
  padding: .65rem .5rem !important;
}

body.aha-account-page .aha-view-order__details table.shop_table tfoot td {
  font-family: var(--aha-sans) !important;
  color: var(--aha-ink) !important;
  text-align: right !important;
}

/* Order total row */
body.aha-account-page .aha-view-order__details .order_total td,
body.aha-account-page .aha-view-order__details .order_total .woocommerce-Price-amount {
  font-family: var(--aha-serif) !important;
  font-size: 1.3rem !important;
  font-weight: 400 !important;
  color: var(--aha-gold) !important;
}

/* Item names (product titles) in the order details table */
body.aha-account-page .aha-view-order__details .product-name {
  font-family: var(--aha-serif) !important;
  font-weight: 400 !important;
  color: var(--aha-ink) !important;
}

body.aha-account-page .aha-view-order__details .product-name a {
  color: var(--aha-ink) !important;
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color .2s ease;
}

body.aha-account-page .aha-view-order__details .product-name a:hover {
  border-bottom-color: var(--aha-gold);
}

/* Customer details block â€” billing + shipping addresses side by side */
body.aha-account-page .aha-view-order__details .woocommerce-customer-details {
  margin-top: 2rem;
}

body.aha-account-page .aha-view-order__details .woocommerce-customer-details address {
  background: var(--aha-paper-warm);
  border: 1px solid var(--aha-paper-dark);
  padding: 1.25rem 1.5rem;
  font-family: var(--aha-serif);
  font-weight: 400;
  font-size: 1rem;
  line-height: 1.55;
  color: var(--aha-ink);
  font-style: normal;
  margin: 0;
}

body.aha-account-page .aha-view-order__details .woocommerce-customer-details .col2-set {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 1.25rem !important;
  margin: 0 !important;
}

body.aha-account-page .aha-view-order__details .woocommerce-customer-details .col-1,
body.aha-account-page .aha-view-order__details .woocommerce-customer-details .col-2 {
  width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
  float: none !important;
}


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

@media (max-width: 768px) {
  body.aha-account-page .aha-form-row-grid,
  body.aha-account-page .aha-account-addresses__grid,
  body.aha-account-page .aha-address-fields {
    grid-template-columns: 1fr;
  }
  body.aha-account-page .aha-view-order__details .woocommerce-customer-details .col2-set {
    grid-template-columns: 1fr !important;
  }
  body.aha-account-page .aha-orders-table__actions {
    justify-content: flex-start;
  }
}

@media (max-width: 600px) {
  /* Responsive order table - WC has its own responsive class system but
     we add ours to ensure clean stacking on narrow viewports */
  body.aha-account-page .aha-orders-table thead {
    display: none;
  }
  body.aha-account-page .aha-orders-table,
  body.aha-account-page .aha-orders-table tbody,
  body.aha-account-page .aha-orders-table tr,
  body.aha-account-page .aha-orders-table td {
    display: block;
    width: 100%;
  }
  body.aha-account-page .aha-orders-table tbody tr {
    margin-bottom: 1rem;
    padding: 1rem;
    background: var(--aha-paper-warm);
    border: 1px solid var(--aha-paper-dark) !important;
  }
  body.aha-account-page .aha-orders-table__cell {
    padding: .35rem 0 !important;
  }
  body.aha-account-page .aha-orders-table__cell::before {
    content: attr(data-title) ": ";
    font-family: var(--aha-sans);
    font-size: .58rem;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--aha-ink-muted);
    display: inline-block;
    margin-right: .5rem;
  }
}

/* ==========================================================================
   APPEND THIS BLOCK to your existing avada-child-theme/style.css
   (at the very end).
   ========================================================================== */


/* ==========================================================================
   AHA SIGNUP — SHARED
   ========================================================================== */

.aha-signup {
  font-family: var(--aha-sans);
}


/* ==========================================================================
   INLINE EDITORIAL BLOCK
   ========================================================================== */

.aha-signup--inline {
  background: var(--aha-paper);
  border: 1px solid var(--aha-paper-dark);
  padding: clamp(2.5rem, 5vw, 3.5rem) clamp(1.5rem, 4vw, 3rem);
  position: relative;
  overflow: hidden;
  margin: 3rem 0;
}

.aha-signup--inline .aha-signup__form-state,
.aha-signup--inline .aha-signup__confirm-state {
  position: relative;
  z-index: 1;
}

.aha-signup__bg-char {
  position: absolute;
  left: -2%;
  top: 50%;
  transform: translateY(-50%);
  font-family: var(--aha-serif);
  font-size: 14rem;
  color: rgba(212, 170, 114, .07);
  line-height: 1;
  pointer-events: none;
  user-select: none;
  letter-spacing: .1em;
  z-index: 0;
}

.aha-signup__inner {
  text-align: center;
  max-width: 560px;
  margin: 0 auto;
}

.aha-signup__eyebrow {
  font-family: var(--aha-sans);
  font-size: .62rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--aha-gold);
  margin-bottom: 1rem;
  font-weight: 400;
}

.aha-signup__title {
  font-family: var(--aha-serif);
  font-weight: 300;
  font-size: clamp(1.7rem, 3.5vw, 2.1rem);
  line-height: 1.1;
  color: var(--aha-ink);
  margin: 0 0 1rem;
  letter-spacing: -.01em;
}

.aha-signup__title em {
  font-style: italic;
  color: var(--aha-gold);
}

.aha-signup__lead {
  font-family: var(--aha-sans);
  font-weight: 300;
  font-size: .95rem;
  line-height: 1.65;
  color: var(--aha-ink-soft);
  margin: 0 0 2rem;
}

.aha-signup__lead strong {
  font-weight: 500;
  color: var(--aha-ink);
}

/* Form */
.aha-signup__form {
  display: grid;
  grid-template-columns: 1fr 1.4fr auto;
  gap: .5rem;
  max-width: 560px;
  margin: 0 auto 1rem;
}

.aha-signup__input {
  height: 46px;
  padding: .75rem 1rem;
  border: 1px solid var(--aha-paper-dark);
  background: var(--aha-paper);
  color: var(--aha-ink);
  font-family: var(--aha-sans);
  font-size: .9rem;
  border-radius: 0;
  outline: none;
  box-shadow: none;
  transition: border-color .2s ease;
}

.aha-signup__input:focus {
  border-color: var(--aha-gold);
  outline: none;
}

.aha-signup__submit {
  background: var(--aha-ink);
  color: var(--aha-paper);
  padding: 0 1.5rem;
  font-family: var(--aha-sans);
  font-size: .62rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  border: 1px solid var(--aha-ink);
  border-radius: 0;
  cursor: pointer;
  white-space: nowrap;
  transition: background .2s ease, border-color .2s ease;
  height: 46px;
  min-width: 90px;
  position: relative;
}

.aha-signup__submit:hover:not(:disabled) {
  background: var(--aha-green-deep);
  border-color: var(--aha-green-deep);
}

.aha-signup__submit:disabled {
  opacity: .7;
  cursor: wait;
}

.aha-signup__submit-loading {
  display: none;
}

.aha-signup__submit.is-loading .aha-signup__submit-label {
  visibility: hidden;
}

.aha-signup__submit.is-loading .aha-signup__submit-loading {
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 1rem;
  letter-spacing: .15em;
}

.aha-signup__fine {
  font-family: var(--aha-serif);
  font-style: italic;
  font-size: .78rem;
  color: var(--aha-ink-muted);
  margin: 0;
}

.aha-signup__error {
  margin-top: 1rem;
  font-family: var(--aha-sans);
  font-size: .78rem;
  color: var(--aha-red);
  min-height: 1rem;
}

.aha-signup__error:empty {
  display: none;
}

/* Inline responsive */
@media (max-width: 600px) {
  .aha-signup__form {
    grid-template-columns: 1fr;
  }
  .aha-signup__submit {
    width: 100%;
  }
  .aha-signup__bg-char {
    font-size: 9rem;
  }
}


/* ==========================================================================
   CONFIRMATION STATE (inline)
   ========================================================================== */

.aha-signup--inline.is-confirmed,
.aha-signup--inline:has(.aha-signup__confirm-state:not([hidden])) {
  border-color: var(--aha-gold);
}

.aha-signup__welcome-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-family: var(--aha-sans);
  font-size: .62rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--aha-olive);
  margin-bottom: 1rem;
  font-weight: 400;
}

.aha-signup__welcome-line {
  display: inline-block;
  width: 1.5rem;
  height: 1px;
  background: var(--aha-olive);
}

.aha-signup__confirm-lead {
  font-family: var(--aha-sans);
  font-weight: 300;
  font-size: .95rem;
  line-height: 1.65;
  color: var(--aha-ink-soft);
  margin: 0 0 1.75rem;
}

.aha-signup__code-callout {
  background: var(--aha-paper-warm);
  border: 1px dashed var(--aha-gold);
  padding: 1rem 1.75rem;
  display: inline-block;
  margin: 0 auto 1.5rem;
}

.aha-signup__code {
  font-family: var(--aha-serif);
  font-weight: 400;
  font-size: clamp(1.7rem, 3vw, 2.2rem);
  line-height: 1;
  color: var(--aha-ink);
  letter-spacing: .15em;
  display: inline-block;
  user-select: all;
}

.aha-signup__confirm-fine {
  font-family: var(--aha-serif);
  font-style: italic;
  font-size: .85rem;
  color: var(--aha-ink-soft);
  margin: 0 0 2rem;
  line-height: 1.55;
}

.aha-signup__confirm-cta {
  display: inline-block;
  background: var(--aha-ink);
  color: var(--aha-paper);
  padding: .85rem 2.25rem;
  font-family: var(--aha-sans);
  font-size: .62rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  text-decoration: none;
  border: 1px solid var(--aha-ink);
  transition: background .2s ease, border-color .2s ease;
}

.aha-signup__confirm-cta:hover {
  background: var(--aha-green-deep);
  border-color: var(--aha-green-deep);
  color: var(--aha-paper);
}


/* ==========================================================================
   FOOTER COMPACT FORM
   ========================================================================== */

.aha-signup--footer {
  border-top: 1px solid rgba(212, 170, 114, .2);
  padding-top: 1.1rem;
  margin-bottom: 1rem;
}

.aha-signup-footer__eyebrow {
  font-family: var(--aha-sans);
  font-size: .58rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--aha-gold-light);
  font-weight: 400;
  margin-bottom: .75rem;
}

.aha-signup-footer__eyebrow--welcome {
  color: var(--aha-olive);
}

.aha-signup-footer__lead {
  font-family: var(--aha-sans);
  font-weight: 300;
  font-size: .78rem;
  line-height: 1.55;
  color: rgba(247, 244, 239, .6);
  margin: 0 0 1rem;
  max-width: 240px;
}

.aha-signup-footer__form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .4rem;
  max-width: 260px;
}

.aha-signup-footer__input {
  height: 36px !important;
  padding: .5rem .75rem !important;
  border: 1px solid rgba(247, 244, 239, .15) !important;
  background: rgba(247, 244, 239, .05) !important;
  color: var(--aha-paper) !important;
  font-family: var(--aha-sans) !important;
  font-size: .78rem !important;
  border-radius: 0 !important;
  outline: none !important;
  box-shadow: none !important;
  transition: border-color .2s ease;
  -webkit-appearance: none;
}

.aha-signup-footer__input::placeholder {
  color: rgba(247, 244, 239, .4) !important;
  opacity: 1 !important; /* Firefox reduces opacity by default */
}

.aha-signup-footer__input:focus {
  border-color: var(--aha-gold-light) !important;
  outline: none !important;
  background: rgba(247, 244, 239, .08) !important;
}

.aha-signup-footer__submit {
  grid-column: 1 / -1;
  background: transparent;
  color: var(--aha-gold-light);
  padding: .5rem;
  font-family: var(--aha-sans);
  font-size: .55rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  border: 1px solid var(--aha-gold-light);
  border-radius: 0;
  cursor: pointer;
  transition: background .2s ease, color .2s ease;
  height: 36px;
  position: relative;
}

.aha-signup-footer__submit:hover:not(:disabled) {
  background: var(--aha-gold-light);
  color: var(--aha-ink);
}

.aha-signup-footer__submit:disabled {
  opacity: .7;
  cursor: wait;
}

.aha-signup-footer__submit.is-loading .aha-signup__submit-label {
  visibility: hidden;
}

.aha-signup-footer__submit.is-loading .aha-signup__submit-loading {
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: .9rem;
  letter-spacing: .15em;
}

.aha-signup-footer__error {
  margin-top: .75rem;
  font-family: var(--aha-sans);
  font-size: .72rem;
  color: var(--aha-gold-light);
  min-height: 1rem;
}

.aha-signup-footer__error:empty {
  display: none;
}

/* Footer confirmation state */
.aha-signup-footer__confirm-lead {
  font-family: var(--aha-sans);
  font-weight: 300;
  font-size: .78rem;
  line-height: 1.55;
  color: rgba(247, 244, 239, .6);
  margin: 0 0 .65rem;
}

.aha-signup-footer__confirm-lead em {
  font-style: italic;
  color: var(--aha-gold-light);
}

.aha-signup-footer__code {
  font-family: var(--aha-serif);
  font-weight: 400;
  font-size: 1.2rem;
  color: var(--aha-paper);
  letter-spacing: .12em;
  background: rgba(247, 244, 239, .05);
  border: 1px dashed var(--aha-gold-light);
  padding: .55rem .85rem;
  display: inline-block;
  user-select: all;
  margin: 0 0 .75rem;
}

.aha-signup-footer__confirm-fine {
  font-family: var(--aha-serif);
  font-style: italic;
  font-size: .72rem;
  color: rgba(247, 244, 239, .45);
  margin: 0;
}

/* ==========================================================================
   APPEND THIS BLOCK to your existing avada-child-theme/style.css
   (at the very end).
   ========================================================================== */


/* ==========================================================================
   AHA CONTACT PAGE
   ========================================================================== */

body.aha-contact-page .aha-contact-wrap {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1.5rem;
}


/* ============ HERO ============ */

body.aha-contact-page .aha-contact-hero {
  padding: 5rem 1rem 3rem;
  text-align: center;
  max-width: 760px;
  margin: 0 auto;
}

body.aha-contact-page .aha-contact-hero__eyebrow {
  font-family: var(--aha-sans);
  font-size: .7rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--aha-gold);
  font-weight: 400;
  margin-bottom: 1.25rem;
}

body.aha-contact-page .aha-contact-hero__title {
  font-family: var(--aha-serif);
  font-weight: 300;
  font-size: clamp(2.2rem, 5vw, 3.2rem);
  color: var(--aha-ink);
  margin: 0 0 1.5rem;
  line-height: 1.1;
  letter-spacing: -.015em;
}

body.aha-contact-page .aha-contact-hero__title em {
  font-style: italic;
  color: var(--aha-gold);
}

body.aha-contact-page .aha-contact-hero__lede {
  font-family: var(--aha-sans);
  font-weight: 300;
  font-size: 1.05rem;
  color: var(--aha-ink-soft);
  line-height: 1.65;
  margin: 0 auto;
  max-width: 540px;
}

body.aha-contact-page .aha-contact-hero__divider {
  width: 540px;
  max-width: 100%;
  height: 1px;
  background: var(--aha-paper-dark);
  margin: 0 auto 4rem;
}


/* ============ TWO-COLUMN GRID ============ */

body.aha-contact-page .aha-contact-grid {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 5rem;
  padding: 0 0 6rem;
  max-width: 1100px;
  margin: 0 auto;
  align-items: start;
}


/* ============ LEFT COLUMN: INFO ============ */

body.aha-contact-page .aha-contact-info__eyebrow {
  font-family: var(--aha-sans);
  font-size: .62rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--aha-gold);
  font-weight: 400;
  margin-bottom: 1rem;
}

body.aha-contact-page .aha-contact-info__title {
  font-family: var(--aha-serif);
  font-weight: 300;
  font-size: 1.85rem;
  color: var(--aha-ink);
  margin: 0 0 1.5rem;
  line-height: 1.15;
  letter-spacing: -.005em;
}

body.aha-contact-page .aha-contact-info__title em {
  font-style: italic;
  color: var(--aha-gold);
}

body.aha-contact-page .aha-contact-info__intro {
  font-family: var(--aha-sans);
  font-weight: 300;
  font-size: .95rem;
  color: var(--aha-ink-soft);
  line-height: 1.65;
  margin: 0 0 2.5rem;
}

body.aha-contact-page .aha-contact-info__block {
  margin-bottom: 1.75rem;
}

body.aha-contact-page .aha-contact-info__label {
  font-family: var(--aha-sans);
  font-size: .58rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--aha-ink-muted);
  font-weight: 400;
  margin-bottom: .45rem;
}

body.aha-contact-page .aha-contact-info__link {
  display: inline-block;
  font-family: var(--aha-serif);
  font-size: 1.05rem;
  color: var(--aha-ink);
  text-decoration: none;
  border-bottom: 1px solid var(--aha-gold);
  padding-bottom: 1px;
  transition: color .2s ease, border-color .2s ease;
}

body.aha-contact-page .aha-contact-info__link:hover {
  color: var(--aha-gold);
  border-color: var(--aha-ink);
}

body.aha-contact-page .aha-contact-info__desc {
  font-family: var(--aha-serif);
  font-style: italic;
  font-size: .85rem;
  color: var(--aha-ink-muted);
  margin: .4rem 0 0;
  line-height: 1.5;
}


/* ============ RIGHT COLUMN: FORM CARD ============ */

body.aha-contact-page .aha-contact-form-card {
  background: var(--aha-paper-warm);
  border: 1px solid var(--aha-paper-dark);
  padding: 2.75rem 2.5rem;
}

body.aha-contact-page .aha-contact-form-card__eyebrow {
  font-family: var(--aha-sans);
  font-size: .62rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--aha-gold);
  font-weight: 400;
  margin-bottom: .85rem;
}

body.aha-contact-page .aha-contact-form-card__title {
  font-family: var(--aha-serif);
  font-weight: 400;
  font-size: 1.5rem;
  color: var(--aha-ink);
  margin: 0 0 1rem;
  line-height: 1.2;
}

body.aha-contact-page .aha-contact-form-card__intro {
  font-family: var(--aha-sans);
  font-weight: 300;
  font-size: .88rem;
  color: var(--aha-ink-soft);
  line-height: 1.6;
  margin: 0 0 2rem;
}


/* ==========================================================================
   AVADA FORMS OVERRIDES (scoped to Contact page only)
   --------------------------------------------------------------------------
   Avada's form classes confirmed from inspector:
     .fusion-form-form-wrapper   — form wrapper
     .fusion-form-field          — each field block
     .fusion-form-text-field     — text input wrapper
     .fusion-form-email-field    — email input wrapper
     .fusion-form-textarea-field — textarea wrapper
     .fusion-form-submit-field   — submit button wrapper
     .fusion-form-input          — actual input element
     .fusion-form-label          — labels above fields

   We use high-specificity selectors + !important sparingly because Avada
   ships heavy default styling via CSS custom properties (--awb-*) that we
   need to override for brand consistency.
   ========================================================================== */

/* Form wrapper */
body.aha-contact-page .aha-contact-form-card .fusion-form-form-wrapper {
  margin: 0 !important;
  padding: 0 !important;
}

/* Labels (Avada uses .fusion-form-label or label inside .fusion-form-field) */
body.aha-contact-page .aha-contact-form-card .fusion-form-field label,
body.aha-contact-page .aha-contact-form-card .fusion-form-label {
  display: block !important;
  font-family: var(--aha-sans) !important;
  font-size: .6rem !important;
  letter-spacing: .18em !important;
  text-transform: uppercase !important;
  color: var(--aha-ink-muted) !important;
  font-weight: 400 !important;
  margin-bottom: .45rem !important;
}

/* Required asterisk styling */
body.aha-contact-page .aha-contact-form-card .fusion-form-field label .required,
body.aha-contact-page .aha-contact-form-card .fusion-form-field label .fusion-form-label-required {
  color: var(--aha-gold) !important;
}

/* All text-like inputs */
body.aha-contact-page .aha-contact-form-card .fusion-form-field input[type="text"],
body.aha-contact-page .aha-contact-form-card .fusion-form-field input[type="email"],
body.aha-contact-page .aha-contact-form-card .fusion-form-field input[type="tel"],
body.aha-contact-page .aha-contact-form-card .fusion-form-field input[type="url"],
body.aha-contact-page .aha-contact-form-card .fusion-form-field input[type="number"],
body.aha-contact-page .aha-contact-form-card .fusion-form-field input.fusion-form-input,
body.aha-contact-page .aha-contact-form-card .fusion-form-field textarea,
body.aha-contact-page .aha-contact-form-card .fusion-form-field select {
  width: 100% !important;
  height: 44px !important;
  padding: .65rem .85rem !important;
  border: 1px solid var(--aha-paper-dark) !important;
  background: var(--aha-paper) !important;
  color: var(--aha-ink) !important;
  font-family: var(--aha-sans) !important;
  font-size: .9rem !important;
  font-weight: 300 !important;
  border-radius: 0 !important;
  outline: none !important;
  box-shadow: none !important;
  box-sizing: border-box !important;
  transition: border-color .2s ease !important;
  margin-bottom: 1rem !important;
}

/* Textarea overrides height */
body.aha-contact-page .aha-contact-form-card .fusion-form-field textarea {
  height: auto !important;
  min-height: 120px !important;
  resize: vertical !important;
  line-height: 1.55 !important;
  padding: .75rem .85rem !important;
}

/* Focus state */
body.aha-contact-page .aha-contact-form-card .fusion-form-field input:focus,
body.aha-contact-page .aha-contact-form-card .fusion-form-field textarea:focus,
body.aha-contact-page .aha-contact-form-card .fusion-form-field select:focus {
  border-color: var(--aha-gold) !important;
  outline: none !important;
}

/* Placeholder text */
body.aha-contact-page .aha-contact-form-card .fusion-form-field input::placeholder,
body.aha-contact-page .aha-contact-form-card .fusion-form-field textarea::placeholder {
  color: var(--aha-ink-muted) !important;
  opacity: .7;
  font-style: normal;
}

/* Field wrapper spacing — strip Avada's default margins */
body.aha-contact-page .aha-contact-form-card .fusion-form-field {
  margin-bottom: 0 !important;
  padding: 0 !important;
}

/* Submit button — the most stubborn Avada override */
body.aha-contact-page .aha-contact-form-card .fusion-form-submit-field button,
body.aha-contact-page .aha-contact-form-card .fusion-form-submit-field input[type="submit"],
body.aha-contact-page .aha-contact-form-card .fusion-form-submit-field .fusion-button,
body.aha-contact-page .aha-contact-form-card button.fusion-button[type="submit"] {
  display: inline-block !important;
  background: var(--aha-ink) !important;
  background-color: var(--aha-ink) !important;
  color: var(--aha-paper) !important;
  padding: .95rem 2.5rem !important;
  font-family: var(--aha-sans) !important;
  font-size: .65rem !important;
  letter-spacing: .22em !important;
  text-transform: uppercase !important;
  font-weight: 400 !important;
  border: 1px solid var(--aha-ink) !important;
  border-radius: 0 !important;
  cursor: pointer !important;
  margin-top: .5rem !important;
  transition: background .2s ease, border-color .2s ease !important;
  box-shadow: none !important;
  text-shadow: none !important;
  height: auto !important;
  line-height: 1 !important;
}

body.aha-contact-page .aha-contact-form-card .fusion-form-submit-field button:hover,
body.aha-contact-page .aha-contact-form-card .fusion-form-submit-field input[type="submit"]:hover,
body.aha-contact-page .aha-contact-form-card .fusion-form-submit-field .fusion-button:hover {
  background: var(--aha-green-deep) !important;
  background-color: var(--aha-green-deep) !important;
  border-color: var(--aha-green-deep) !important;
  color: var(--aha-paper) !important;
}

/* Form submission notices (success/error messages from Avada) */
body.aha-contact-page .aha-contact-form-card .form-submission-notices,
body.aha-contact-page .aha-contact-form-card .fusion-notices {
  margin: 1rem 0 !important;
  padding: 1rem !important;
  font-family: var(--aha-sans) !important;
  font-size: .85rem !important;
  border-radius: 0 !important;
}


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

@media (max-width: 900px) {
  body.aha-contact-page .aha-contact-grid {
    grid-template-columns: 1fr;
    gap: 3rem;
    padding-bottom: 4rem;
  }
  body.aha-contact-page .aha-contact-form-card {
    padding: 2rem 1.5rem;
  }
  body.aha-contact-page .aha-contact-hero {
    padding: 3.5rem 1rem 2rem;
  }
  body.aha-contact-page .aha-contact-hero__divider {
    margin-bottom: 2.5rem;
  }
}

@media (max-width: 600px) {
  body.aha-contact-page .aha-contact-form-card {
    padding: 1.5rem 1.25rem;
  }
}
