/* =========================================================================
   A Time for Karma — Child Theme
   v0.4.0 — Phase 1 visual system port from claude-design/karma-v1
   ========================================================================= */

:root {
  /* This is a light design — opt out of browser/OS auto-darkening so
     dark-mode phones render it as intended instead of inverting it. */
  color-scheme: light;

  /* Surfaces */
  --karma-bg: #FBF8F3;
  --karma-bg-warm: #F7F1EA;
  --karma-lavender-wash: #F2EAF5;
  --karma-lavender-soft: #E8DCEF;
  --karma-lavender-mid: #D4BFE0;

  /* Amethyst */
  --karma-amethyst: #7B5BA6;
  --karma-amethyst-deep: #4F3878;
  --karma-amethyst-light: #B8A4D4;

  /* Teal */
  --karma-teal: #3FA4A0;
  --karma-teal-deep: #2C7E7B;
  --karma-teal-light: #5BB5B0;

  /* Ink */
  --karma-ink: #1F1A2E;
  --karma-ink-mid: #4A4258;
  --karma-ink-soft: #7C748D;
  --karma-ink-faint: #B5AEC2;

  /* Accents */
  --karma-cream: #FFFCF5;   /* near-white: used as light text on dark panels */
  --karma-surface: #FFFCF5; /* card surface: same in light, flips dark in dark mode */
  --karma-gold: #C9A961;

  /* Borders */
  --karma-border: rgba(31, 26, 46, 0.12);
  --karma-border-soft: rgba(31, 26, 46, 0.08);
  --karma-border-strong: rgba(31, 26, 46, 0.22);

  /* Radii */
  --karma-radius-sm: 6px;
  --karma-radius: 12px;
  --karma-radius-lg: 20px;
  --karma-radius-xl: 28px;

  /* Shadows (amethyst-tinted) */
  --karma-shadow-sm: 0 1px 2px rgba(31, 26, 46, 0.06), 0 2px 8px rgba(123, 91, 166, 0.04);
  --karma-shadow: 0 4px 16px rgba(31, 26, 46, 0.06), 0 12px 40px rgba(123, 91, 166, 0.08);
  --karma-shadow-lg: 0 8px 24px rgba(31, 26, 46, 0.08), 0 24px 60px rgba(123, 91, 166, 0.12);

  /* Fonts */
  --karma-font-display: 'Cinzel', 'Crimson Pro', Georgia, serif;
  --karma-font-serif: 'Crimson Pro', Georgia, serif;
  --karma-font-body: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --karma-font-mono: 'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, monospace;

  /* Layout */
  --karma-shell: min(1440px, calc(100% - 80px));

  /* Mystical intensity — controls celestial decoration opacity site-wide */
  --mystic: 0.85;
}

/* =========================================================================
   Reset & globals
   ========================================================================= */

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  background: var(--karma-bg);
  color: var(--karma-ink);
  font-family: var(--karma-font-body);
  font-size: 15px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body.karma-search-is-open,
body.karma-menu-is-open {
  overflow: hidden;
}

a {
  color: var(--karma-amethyst-deep);
  text-underline-offset: 0.2em;
}

a:hover,
a:focus {
  color: var(--karma-teal-deep);
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--karma-font-display);
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.05;
  color: var(--karma-ink);
}

/* Hide Astra/Elementor wrappers on pages we render ourselves */
body.home .site-content > .ast-container { display: none; }

/* Astra applies `padding: 0 50px` on body to create page gutters.
   Strip it on home + woo so section backgrounds (hero gradient,
   dark visit band, finder, etc.) span the full viewport. */
body.home,
body.woocommerce,
body.woocommerce-page {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

body.home .site-content,
body.home .site,
body.woocommerce .site-content {
  max-width: none !important;
  width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.site-header,
.main-header-bar,
.ast-primary-header-bar,
.elementor-location-header,
.elementor-location-footer,
#ast-scroll-top,
.ast-scroll-top-icon,
#colophon {
  display: none !important;
}

.ast-separate-container .ast-woocommerce-container,
.ast-separate-container .ast-article-single,
.ast-separate-container .ast-article-post,
.site-content .ast-container {
  background: transparent;
}

body:not(.home).ast-separate-container #primary {
  margin-top: clamp(2rem, 4vw, 3.6rem);
  margin-bottom: clamp(2rem, 4vw, 3.6rem);
}

/* =========================================================================
   Utilities
   ========================================================================= */

.karma-shell {
  width: var(--karma-shell);
  margin: 0 auto;
}

/* Italic accent word — used inside Cinzel headlines */
.k-italic {
  font-family: var(--karma-font-serif);
  font-style: italic;
  font-weight: 500;
  color: var(--karma-amethyst-deep);
  letter-spacing: -0.005em;
}

/* Eyebrow — serif italic, uppercase, wide tracking, with constellation flanks */
.karma-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin: 0 0 24px;
  color: var(--karma-amethyst);
  font-family: var(--karma-font-serif);
  font-style: italic;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.karma-eyebrow::before,
.karma-eyebrow::after {
  content: "";
  display: inline-block;
  width: 36px;
  height: 10px;
  flex: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 36 10'><polyline points='0,5 8,2 16,7 24,3 32,6 36,5' fill='none' stroke='%237B5BA6' stroke-width='0.6' stroke-linecap='round'/><circle cx='8' cy='2' r='1.4' fill='%237B5BA6'/><circle cx='16' cy='7' r='1.6' fill='%234F3878'/><circle cx='24' cy='3' r='1.4' fill='%237B5BA6'/><circle cx='32' cy='6' r='1.4' fill='%234F3878'/></svg>");
  background-repeat: no-repeat;
  background-position: center;
  opacity: calc(var(--mystic) * 1.2 + 0.2);
}

/* Inverted eyebrow on dark surfaces */
.karma-eyebrow--light {
  color: var(--karma-amethyst-light);
}

.karma-eyebrow--light::before,
.karma-eyebrow--light::after {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 36 10'><polyline points='0,5 8,2 16,7 24,3 32,6 36,5' fill='none' stroke='%23B8A4D4' stroke-width='0.6' stroke-linecap='round'/><circle cx='8' cy='2' r='1.4' fill='%23B8A4D4'/><circle cx='16' cy='7' r='1.6' fill='%23D7C8E8'/><circle cx='24' cy='3' r='1.4' fill='%23B8A4D4'/><circle cx='32' cy='6' r='1.4' fill='%23D7C8E8'/></svg>");
}

/* Mono micro-label */
.karma-mono-label {
  margin: 0 0 8px;
  color: var(--karma-ink-soft);
  font-family: var(--karma-font-body);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.20em;
  text-transform: uppercase;
}

/* Star field — celestial scatter behind hero, finder, footer */
.k-star-field {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    radial-gradient(circle, rgba(79, 56, 120, 0.85) 0 1.4px, transparent 2px),
    radial-gradient(circle, rgba(123, 91, 166, 0.75) 0 1.2px, transparent 1.8px),
    radial-gradient(circle, rgba(184, 164, 212, 0.85) 0 1px, transparent 1.6px),
    radial-gradient(circle, rgba(201, 169, 97, 0.85) 0 1.4px, transparent 2.2px),
    radial-gradient(circle, rgba(91, 181, 176, 0.65) 0 0.9px, transparent 1.5px),
    radial-gradient(circle, rgba(79, 56, 120, 0.45) 0 0.7px, transparent 1.2px);
  background-size:
    140px 140px,
    200px 200px,
    260px 260px,
    320px 320px,
    180px 180px,
    90px 90px;
  background-position:
    12% 22%,
    62% 14%,
    36% 68%,
    78% 44%,
    8% 84%,
    52% 92%;
  opacity: calc(var(--mystic) * 0.95 + 0.05);
}

/* Once JS scatters individual dots, drop the tiled gradient so the grid
   pattern doesn't show through underneath the real stars. */
.k-star-field--scattered {
  background-image: none;
}

.k-star {
  position: absolute;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  will-change: opacity;
  animation: k-twinkle 4s ease-in-out infinite;
}

@keyframes k-twinkle {
  0%,
  100% {
    opacity: 0.35;
  }
  50% {
    opacity: 1;
  }
}

@media (prefers-reduced-motion: reduce) {
  .k-star {
    animation: none;
  }
}

.k-star-field--dark {
  background-image:
    radial-gradient(circle, rgba(255, 252, 245, 0.85) 0 1.2px, transparent 1.8px),
    radial-gradient(circle, rgba(184, 164, 212, 0.75) 0 1px, transparent 1.6px),
    radial-gradient(circle, rgba(201, 169, 97, 0.95) 0 1.4px, transparent 2.2px),
    radial-gradient(circle, rgba(91, 181, 176, 0.65) 0 0.9px, transparent 1.5px),
    radial-gradient(circle, rgba(255, 252, 245, 0.45) 0 0.7px, transparent 1.2px),
    radial-gradient(circle, rgba(255, 252, 245, 0.55) 0 0.6px, transparent 1px);
}

/* Soft glow aura */
.k-aura {
  position: absolute;
  border-radius: 50%;
  filter: blur(60px);
  pointer-events: none;
  opacity: calc(var(--mystic) * 0.9);
}

/* Sparkle dot (4-point star sized via font-size) */
.k-sparkle {
  display: inline-block;
  width: 1em;
  height: 1em;
  vertical-align: -0.1em;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'><path d='M6 0 L6.8 5.2 L12 6 L6.8 6.8 L6 12 L5.2 6.8 L0 6 L5.2 5.2 Z' fill='%23C9A961'/></svg>");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

.k-sparkle--amethyst {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'><path d='M6 0 L6.8 5.2 L12 6 L6.8 6.8 L6 12 L5.2 6.8 L0 6 L5.2 5.2 Z' fill='%237B5BA6'/></svg>");
}

/* Action row */
.karma-action-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

/* =========================================================================
   Buttons
   ========================================================================= */

.karma-button,
.elementor-button,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce-page a.button,
.woocommerce-page button.button,
.woocommerce-page input.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 48px;
  padding: 12px 22px;
  border-radius: 999px !important;
  background: var(--karma-teal) !important;
  border: 1px solid var(--karma-teal-deep) !important;
  color: #fff !important;
  font-family: var(--karma-font-body) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  letter-spacing: 0.02em !important;
  line-height: 1.1 !important;
  text-decoration: none !important;
  cursor: pointer;
  box-shadow: 0 1px 2px rgba(31, 26, 46, 0.10), 0 4px 14px rgba(63, 164, 160, 0.18) !important;
  transition: transform 120ms ease, background 120ms ease, border-color 120ms ease, color 120ms ease, box-shadow 120ms ease;
}

.karma-button:hover,
.karma-button:focus,
.elementor-button:hover,
.elementor-button:focus,
.woocommerce a.button:hover,
.woocommerce a.button:focus,
.woocommerce button.button:hover,
.woocommerce button.button:focus,
.woocommerce input.button:hover,
.woocommerce input.button:focus {
  transform: translateY(-1px);
  background: var(--karma-teal-deep) !important;
  border-color: var(--karma-teal-deep) !important;
  color: #fff !important;
}

.karma-button--secondary {
  background: var(--karma-amethyst) !important;
  border-color: var(--karma-amethyst-deep) !important;
}

.karma-button--secondary:hover,
.karma-button--secondary:focus {
  background: var(--karma-amethyst-deep) !important;
  border-color: var(--karma-amethyst-deep) !important;
}

.karma-button--outline {
  background: transparent !important;
  border-color: var(--karma-amethyst) !important;
  color: var(--karma-amethyst-deep) !important;
  box-shadow: none !important;
}

.karma-button--outline:hover,
.karma-button--outline:focus {
  background: var(--karma-amethyst-deep) !important;
  border-color: var(--karma-amethyst-deep) !important;
  color: #fff !important;
}

.karma-button--ghost {
  background: transparent !important;
  border-color: var(--karma-lavender-mid) !important;
  color: var(--karma-ink) !important;
  box-shadow: none !important;
}

.karma-button--ghost:hover,
.karma-button--ghost:focus {
  background: var(--karma-lavender-wash) !important;
  border-color: var(--karma-amethyst) !important;
  color: var(--karma-amethyst-deep) !important;
}

.karma-button--lg {
  min-height: 54px;
  padding: 16px 28px;
  font-size: 15px !important;
}

.karma-button--ghost-light {
  background: rgba(255, 252, 245, 0.06) !important;
  border-color: rgba(255, 252, 245, 0.30) !important;
  color: var(--karma-cream) !important;
}

.karma-button--ghost-light:hover,
.karma-button--ghost-light:focus {
  background: rgba(255, 252, 245, 0.14) !important;
  color: #fff !important;
}

/* Inline arrow on buttons (set with span text or use SVG bg) */
.karma-button .karma-arrow {
  display: inline-block;
  width: 14px;
  height: 14px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'><line x1='5' y1='12' x2='19' y2='12'/><polyline points='12 5 19 12 12 19'/></svg>");
  background-size: contain;
  background-repeat: no-repeat;
}

.karma-button--outline .karma-arrow,
.karma-button--ghost .karma-arrow {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%234F3878' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'><line x1='5' y1='12' x2='19' y2='12'/><polyline points='12 5 19 12 12 19'/></svg>");
}

/* =========================================================================
   Header
   ========================================================================= */

.karma-site-header {
  position: sticky;
  top: 0;
  z-index: 900;
  background: rgba(251, 248, 243, 0.94);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

body.admin-bar .karma-site-header { top: 32px; }

.karma-announcement {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  min-height: 36px;
  padding: 8px 16px;
  background: var(--karma-amethyst-deep);
  color: var(--karma-cream);
  font-family: var(--karma-font-body);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1.35;
  text-align: center;
}

.karma-announcement .k-sparkle {
  width: 10px;
  height: 10px;
  flex: none;
}

.karma-announcement a {
  color: var(--karma-cream);
  font-weight: 600;
  text-decoration: none;
}

.karma-announcement a:hover,
.karma-announcement a:focus {
  color: #fff;
  text-decoration: underline;
}

.karma-header-main {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 24px;
  width: var(--karma-shell);
  min-height: 76px;
  margin: 0 auto;
  padding: 14px 0;
}

.karma-header-meta {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  justify-self: center;
  gap: 4px;
  color: var(--karma-ink-mid);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.02em;
  text-align: center;
}

.karma-header-meta span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.karma-header-meta svg {
  width: 13px;
  height: 13px;
  flex: none;
}

.karma-logo {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  justify-self: start;
}

.karma-logo img {
  display: block;
  width: auto;
  max-width: 320px;
  max-height: 96px;
  object-fit: contain;
  /* Tint transparent PNG logo to amethyst-deep */
  filter: brightness(0) saturate(100%) invert(20%) sepia(28%) saturate(1500%) hue-rotate(238deg) brightness(75%) contrast(95%);
}

.karma-header-actions {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 4px;
}

.karma-icon-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  padding: 0;
  border: 1px solid transparent;
  border-radius: 999px;
  background: transparent;
  color: var(--karma-ink);
  font-size: 0;
  text-decoration: none;
  cursor: pointer;
  transition: background 120ms ease, border-color 120ms ease, color 120ms ease;
}

.karma-icon-button svg {
  width: 20px;
  height: 20px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.4;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.karma-icon-button:hover,
.karma-icon-button:focus {
  background: var(--karma-lavender-wash);
  color: var(--karma-amethyst-deep);
}

/* Menu hamburger inherits .karma-icon-button styling (hover, focus, etc.) */
.karma-menu-button {
  display: none; /* shown via mobile media query */
}

/* Nav strip */
.karma-nav-strip {
  border-top: 1px solid var(--karma-lavender-soft);
  border-bottom: 1px solid var(--karma-lavender-soft);
  background: rgba(251, 248, 243, 0.6);
}

.karma-desktop-nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 48px;
  width: var(--karma-shell);
  margin: 0 auto;
}

.karma-desktop-nav a {
  display: inline-block;
  padding: 16px 0;
  border-bottom: 2px solid transparent;
  color: var(--karma-ink);
  font-family: var(--karma-font-body);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.16em;
  line-height: 1.2;
  text-transform: uppercase;
  text-decoration: none;
  transition: color 120ms ease, border-color 120ms ease;
}

.karma-desktop-nav a:hover,
.karma-desktop-nav a:focus,
.karma-desktop-nav a[aria-current="page"] {
  color: var(--karma-amethyst-deep);
  border-color: var(--karma-teal);
}

/* Mobile drawer */
.karma-mobile-drawer {
  border-top: 1px solid var(--karma-lavender-soft);
  background: var(--karma-surface);
}

.karma-mobile-drawer nav {
  display: grid;
  gap: 0;
  width: var(--karma-shell);
  margin: 0 auto;
  padding: 12px 0 20px;
}

.karma-mobile-drawer a {
  display: block;
  padding: 14px 0;
  border-bottom: 1px solid var(--karma-lavender-soft);
  color: var(--karma-ink);
  font-family: var(--karma-font-serif);
  font-style: italic;
  font-size: 19px;
  font-weight: 500;
  text-decoration: none;
}

.karma-mobile-drawer a:hover,
.karma-mobile-drawer a:focus {
  color: var(--karma-amethyst-deep);
}

/* =========================================================================
   Homepage shell
   ========================================================================= */

.karma-home {
  background: var(--karma-bg);
  color: var(--karma-ink);
  overflow: hidden;
}

/* =========================================================================
   Hero
   ========================================================================= */

.karma-hero {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  padding: clamp(36px, 5vw, 68px) 0 clamp(56px, 7vw, 96px);
  text-align: center;
  background-color: var(--karma-lavender-soft);
  /* Legibility scrim (lavender wash, lighter behind centred text) layered over
     the generated celestial backdrop. First declaration is the jpg fallback;
     the second upgrades to webp via image-set where supported. */
  background-image:
    radial-gradient(ellipse 72% 64% at 50% 42%, rgba(242, 234, 245, 0.62), rgba(242, 234, 245, 0.18) 62%, transparent 80%),
    linear-gradient(180deg, rgba(242, 234, 245, 0.30) 0%, rgba(232, 220, 239, 0.08) 40%, rgba(232, 220, 239, 0.48) 100%),
    url("../img/hero-bg.jpg");
  background-image:
    radial-gradient(ellipse 72% 64% at 50% 42%, rgba(242, 234, 245, 0.62), rgba(242, 234, 245, 0.18) 62%, transparent 80%),
    linear-gradient(180deg, rgba(242, 234, 245, 0.30) 0%, rgba(232, 220, 239, 0.08) 40%, rgba(232, 220, 239, 0.48) 100%),
    image-set(
      url("../img/hero-bg.webp") type("image/webp"),
      url("../img/hero-bg.jpg") type("image/jpeg")
    );
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.karma-hero__stars {
  z-index: -1;
  /* The generated backdrop already carries most of the celestial detail, so the
     scattered JS stars sit on top only as a subtle, sparkling accent. */
  opacity: 0.5;
  /* additional dense star layers on top of the base utility */
  background-image:
    radial-gradient(circle, rgba(79, 56, 120, 0.95) 0 1.6px, transparent 2.4px),
    radial-gradient(circle, rgba(123, 91, 166, 0.85) 0 1.4px, transparent 2px),
    radial-gradient(circle, rgba(184, 164, 212, 0.85) 0 1.1px, transparent 1.7px),
    radial-gradient(circle, rgba(201, 169, 97, 1) 0 1.5px, transparent 2.3px),
    radial-gradient(circle, rgba(91, 181, 176, 0.7) 0 1px, transparent 1.6px),
    radial-gradient(circle, rgba(79, 56, 120, 0.55) 0 0.8px, transparent 1.3px);
  background-size:
    160px 160px,
    220px 220px,
    280px 280px,
    340px 340px,
    180px 180px,
    100px 100px;
  background-position:
    8% 18%,
    64% 22%,
    32% 64%,
    78% 38%,
    14% 86%,
    50% 50%;
}

.karma-hero__inner {
  width: var(--karma-shell);
  max-width: 880px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.karma-hero__copy h1 {
  margin: 0 0 22px;
  font-family: var(--karma-font-display);
  font-size: clamp(44px, 8vw, 84px);
  font-weight: 500;
  letter-spacing: -0.005em;
  line-height: 1.05;
  color: var(--karma-ink);
}

.karma-hero__copy p:not(.karma-eyebrow) {
  max-width: 620px;
  margin: 0 auto 32px;
  color: var(--karma-ink-mid);
  font-family: var(--karma-font-serif);
  font-style: italic;
  font-size: clamp(18px, 2vw, 22px);
  font-weight: 400;
  line-height: 1.55;
}

.karma-action-row--center {
  justify-content: center;
}

/* Hero actions: inline search bar + visit button, kept on one line. */
.karma-hero__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 12px;
}

.karma-hero-search {
  display: flex;
  align-items: center;
  gap: 8px;
  width: min(420px, 100%);
  min-height: 52px;
  padding: 5px 5px 5px 18px;
  background: var(--karma-surface);
  border: 1px solid var(--karma-lavender-mid);
  border-radius: 999px;
  box-shadow: 0 1px 2px rgba(31, 26, 46, 0.08), 0 6px 18px rgba(79, 56, 120, 0.10);
}

.karma-hero-search:focus-within {
  border-color: var(--karma-amethyst);
  box-shadow: 0 0 0 3px rgba(123, 91, 166, 0.18);
}

.karma-hero-search__icon {
  display: inline-flex;
  flex: none;
  color: var(--karma-ink-soft);
}

.karma-hero-search__icon svg {
  width: 18px;
  height: 18px;
}

.karma-hero-search input[type="search"] {
  flex: 1 1 auto;
  min-width: 0;
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
  font-family: var(--karma-font-body);
  font-size: 15px;
  color: var(--karma-ink);
  outline: none;
}

.karma-hero-search input[type="search"]::placeholder {
  color: var(--karma-ink-soft);
  opacity: 1;
}

.karma-hero-search__submit {
  flex: none;
  min-height: 42px;
  padding: 0 20px;
  border: 0;
  border-radius: 999px;
  background: var(--karma-teal);
  color: #fff;
  font-family: var(--karma-font-body);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.02em;
  cursor: pointer;
  transition: background 120ms ease;
}

.karma-hero-search__submit:hover,
.karma-hero-search__submit:focus {
  background: var(--karma-teal-deep);
}

/* Hero side panel — the original theme had a 2-col layout with a side panel.
   In the new design, the hero is centered. Repurpose the panel as a row of
   moon-phase glyphs below CTAs (more on-spec). */
.karma-hero__panel {
  display: none;
}

.karma-hero__moon-row {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 14px;
  margin-top: 36px;
  opacity: 0.7;
}

.karma-hero__moon-row svg {
  width: 18px;
  height: 18px;
}

/* =========================================================================
   Priority cards (3-card band)
   ========================================================================= */

.karma-priorities {
  position: relative;
  padding: clamp(28px, 4vw, 48px) 0 clamp(32px, 5vw, 56px);
  background: var(--karma-bg);
}

.karma-priorities__grid {
  display: grid;
  grid-template-columns: 1fr 1.1fr 1fr;
  gap: 24px;
}

.karma-priority-card {
  position: relative;
  display: flex;
  flex-direction: column;
  padding: 44px 36px 40px;
  border: 1px solid var(--karma-lavender-soft);
  border-radius: var(--karma-radius-lg);
  background: var(--karma-lavender-wash);
  color: var(--karma-ink);
  text-decoration: none;
  overflow: hidden;
  transition: transform 200ms ease, box-shadow 200ms ease, border-color 200ms ease;
}

.karma-priority-card:hover,
.karma-priority-card:focus {
  transform: translateY(-4px);
  box-shadow: var(--karma-shadow-lg);
  border-color: rgba(123, 91, 166, 0.30);
}

.karma-priority-card__moon {
  position: absolute;
  top: 24px;
  right: 24px;
  width: 42px;
  height: 42px;
  opacity: 0.5;
}

.karma-priority-card > span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 18px;
  color: var(--karma-amethyst);
  font-family: var(--karma-font-serif);
  font-style: italic;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.karma-priority-card > span .k-sparkle {
  width: 10px;
  height: 10px;
}

.karma-priority-card h2 {
  margin: 0 0 20px;
  font-family: var(--karma-font-serif);
  font-style: italic;
  font-size: clamp(28px, 3.2vw, 38px);
  font-weight: 500;
  line-height: 1.05;
  color: var(--karma-ink);
}

.karma-priority-card p {
  margin: 0 0 32px;
  color: var(--karma-ink-mid);
  font-size: 15px;
  line-height: 1.6;
}

.karma-priority-card::after {
  content: "Explore →";
  display: inline-block;
  margin-top: auto;
  padding-bottom: 4px;
  border-bottom: 1px solid currentColor;
  color: var(--karma-amethyst-deep);
  font-family: var(--karma-font-body);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  align-self: flex-start;
}

/* Featured middle card — dark amethyst with sun-rays */
.karma-priority-card--featured {
  background: var(--karma-amethyst-deep);
  border-color: var(--karma-amethyst-deep);
  color: var(--karma-cream);
}

.karma-priority-card--featured h2,
.karma-priority-card--featured p {
  color: var(--karma-cream);
}

.karma-priority-card--featured p { opacity: 0.9; }

.karma-priority-card--featured > span {
  color: var(--karma-amethyst-light);
}

.karma-priority-card--shop > span {
  color: rgba(255, 252, 245, 0.85);
}

.karma-priority-card--featured::after {
  color: var(--karma-cream);
}

.karma-priority-card--featured .karma-priority-card__moon {
  opacity: 0.7;
}

.karma-priority-card--featured .karma-priority-card__rays {
  position: absolute;
  top: -40px;
  right: -40px;
  width: 220px;
  height: 220px;
  opacity: 0.25;
  pointer-events: none;
}

/* Right card — teal */
.karma-priority-card--shop {
  background: var(--karma-teal-deep);
  border-color: var(--karma-teal-deep);
  color: var(--karma-cream);
}

.karma-priority-card--shop h2,
.karma-priority-card--shop p { color: var(--karma-cream); }
.karma-priority-card--shop p { opacity: 0.9; }
.karma-priority-card--shop::after { color: var(--karma-cream); }

/* =========================================================================
   Section base
   ========================================================================= */

.karma-section {
  padding: clamp(36px, 6vw, 72px) 0;
}

.karma-section__intro {
  max-width: 720px;
  margin: 0 0 36px;
}

.karma-section__intro--center {
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

.karma-section__intro h2 {
  margin: 0 0 16px;
  font-family: var(--karma-font-display);
  font-size: clamp(32px, 5vw, 56px);
  font-weight: 500;
  line-height: 1.05;
  color: var(--karma-ink);
}

.karma-section__intro p:not(.karma-eyebrow) {
  margin: 0;
  color: var(--karma-ink-mid);
  font-family: var(--karma-font-serif);
  font-style: italic;
  font-size: 19px;
  line-height: 1.55;
}

/* =========================================================================
   Categories
   ========================================================================= */

.karma-categories {
  background: var(--karma-bg);
}

.karma-category-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}

.karma-category-card {
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 180px;
  padding: 28px;
  border: 1px solid var(--karma-lavender-soft);
  border-radius: var(--karma-radius);
  background: var(--karma-lavender-wash);
  color: var(--karma-ink);
  text-decoration: none;
  overflow: hidden;
  transition: transform 200ms ease, background 200ms ease, border-color 200ms ease;
}

.karma-category-card:hover,
.karma-category-card:focus {
  transform: translateY(-2px);
  background: var(--karma-lavender-soft);
  border-color: var(--karma-lavender-mid);
}

.karma-category-card span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  margin: 0 0 18px;
  border-radius: 50%;
  background: rgba(255, 252, 245, 0.7);
  color: var(--karma-amethyst-deep);
}

.karma-category-card span svg {
  width: 22px;
  height: 22px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.karma-category-card h3 {
  margin: 0 0 8px;
  font-family: var(--karma-font-serif);
  font-style: italic;
  font-size: 22px;
  font-weight: 500;
  line-height: 1.2;
  color: var(--karma-ink);
}

.karma-category-card p {
  margin: 0;
  color: var(--karma-ink-soft);
  font-size: 13px;
  line-height: 1.5;
}

.karma-category-card::after {
  content: "";
  position: absolute;
  top: 24px;
  right: 24px;
  width: 16px;
  height: 16px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%234F3878' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'><line x1='5' y1='12' x2='19' y2='12'/><polyline points='12 5 19 12 12 19'/></svg>");
  background-repeat: no-repeat;
  background-size: contain;
  opacity: 0.4;
  transition: opacity 200ms ease, transform 200ms ease;
}

.karma-category-card:hover::after,
.karma-category-card:focus::after {
  opacity: 0.8;
  transform: translateX(2px);
}

/* =========================================================================
   Find Your Tool (finder)
   ========================================================================= */

.karma-finder {
  position: relative;
  margin: clamp(20px, 4vw, 48px) 0;
  padding: clamp(40px, 6vw, 72px) clamp(28px, 5vw, 60px);
  border-radius: var(--karma-radius-xl);
  background: var(--karma-amethyst-deep);
  color: var(--karma-cream);
  overflow: hidden;
  isolation: isolate;
}

.karma-finder::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background-image:
    radial-gradient(circle, rgba(255, 252, 245, 0.55) 0 1px, transparent 1.5px),
    radial-gradient(circle, rgba(184, 164, 212, 0.65) 0 1px, transparent 1.5px),
    radial-gradient(circle, rgba(201, 169, 97, 0.7) 0 1.2px, transparent 2px),
    radial-gradient(circle, rgba(91, 181, 176, 0.55) 0 0.8px, transparent 1.4px);
  background-size: 200px 200px, 260px 260px, 340px 340px, 160px 160px;
  background-position: 12% 22%, 68% 14%, 28% 78%, 84% 64%;
  opacity: calc(var(--mystic) * 0.85 + 0.1);
  pointer-events: none;
}

.karma-finder .karma-section__intro {
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

.karma-finder .karma-section__intro h2 {
  font-size: clamp(32px, 5.5vw, 64px);
  color: var(--karma-cream);
}

.karma-finder .karma-section__intro h2 .k-italic {
  color: var(--karma-teal-light);
}

.karma-finder .karma-section__intro p:not(.karma-eyebrow) {
  color: rgba(255, 252, 245, 0.85);
}

.karma-finder__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(280px, 1fr);
  gap: 24px;
  margin-top: 40px;
}

.karma-finder__steps {
  display: grid;
  gap: 16px;
}

.karma-finder__step {
  padding: 28px;
  border: 1px solid rgba(255, 252, 245, 0.14);
  border-radius: var(--karma-radius-lg);
  background: rgba(255, 252, 245, 0.06);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.karma-finder__step h3 {
  margin: 0 0 18px;
  font-family: var(--karma-font-serif);
  font-style: italic;
  font-size: 24px;
  font-weight: 500;
  line-height: 1.2;
  color: var(--karma-cream);
}

.karma-finder__label {
  margin: 0 0 8px;
  color: var(--karma-amethyst-light);
  font-family: var(--karma-font-body);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.20em;
  text-transform: uppercase;
}

.karma-choice-group {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.karma-choice-group--wrap {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.karma-choice-group button {
  min-height: 44px;
  padding: 12px 16px;
  border: 1px solid rgba(255, 252, 245, 0.20);
  border-radius: 999px;
  background: rgba(255, 252, 245, 0.06);
  color: var(--karma-cream);
  font-family: var(--karma-font-body);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.02em;
  line-height: 1.2;
  cursor: pointer;
  transition: background 120ms ease, border-color 120ms ease, color 120ms ease;
}

.karma-choice-group button:hover,
.karma-choice-group button:focus {
  border-color: var(--karma-teal-light);
  background: rgba(91, 181, 176, 0.18);
}

.karma-choice-group button[aria-pressed="true"] {
  background: var(--karma-teal);
  border-color: var(--karma-teal-light);
  color: #fff;
}

.karma-finder__result {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 32px 28px;
  border: 1px solid rgba(255, 252, 245, 0.14);
  border-radius: var(--karma-radius-lg);
  background: rgba(255, 252, 245, 0.06);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.karma-finder__result h3 {
  margin: 0 0 12px;
  font-family: var(--karma-font-serif);
  font-style: italic;
  font-size: 24px;
  font-weight: 500;
  line-height: 1.2;
  color: var(--karma-cream);
}

.karma-finder__result p:not(.karma-finder__label) {
  margin: 0 0 24px;
  color: rgba(255, 252, 245, 0.78);
  font-size: 14px;
  line-height: 1.6;
}

.karma-finder__links {
  display: grid;
  gap: 8px;
}

.karma-finder__links a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  min-height: 44px;
  padding: 10px 18px;
  border: 1px solid rgba(255, 252, 245, 0.20);
  border-radius: 999px;
  background: rgba(255, 252, 245, 0.04);
  color: var(--karma-cream);
  font-family: var(--karma-font-body);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-decoration: none;
  transition: background 120ms ease, border-color 120ms ease;
}

.karma-finder__links a:hover,
.karma-finder__links a:focus {
  background: rgba(91, 181, 176, 0.16);
  border-color: var(--karma-teal-light);
}

.karma-finder__links a::after {
  content: "→";
  color: var(--karma-teal-light);
  font-size: 14px;
}

/* Finder result — live product tiles (shown after the format step) */
.karma-finder__products[hidden],
.karma-finder__actions[hidden] {
  display: none;
}

.karma-finder__products {
  margin-top: 18px;
}

.karma-finder__products-label {
  margin: 0 0 10px;
  color: var(--karma-amethyst-light);
  font-family: var(--karma-font-body);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.karma-finder__products-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.karma-finder-tile {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border: 1px solid rgba(255, 252, 245, 0.16);
  border-radius: var(--karma-radius);
  background: rgba(255, 252, 245, 0.95);
  color: var(--karma-ink);
  text-decoration: none;
  transition: transform 160ms ease, box-shadow 160ms ease;
}

.karma-finder-tile:hover,
.karma-finder-tile:focus {
  transform: translateY(-2px);
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.28);
}

.karma-finder-tile__media {
  display: block;
  aspect-ratio: 1 / 1;
  background:
    radial-gradient(circle at 70% 28%, rgba(123, 91, 166, 0.18), transparent 60%),
    linear-gradient(160deg, var(--karma-lavender-wash) 0%, var(--karma-lavender-soft) 100%);
}

.karma-finder-tile__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.karma-finder-tile__name {
  padding: 10px 12px 0;
  color: var(--karma-ink);
  font-family: var(--karma-font-serif);
  font-style: italic;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.2;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.karma-finder-tile__price {
  padding: 4px 12px 12px;
  color: var(--karma-teal-deep);
  font-family: var(--karma-font-body);
  font-size: 12px;
  font-weight: 600;
}

.karma-finder__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin-top: 18px;
}

.karma-finder__viewall {
  flex: 1 1 auto;
}

.karma-finder__reset {
  flex: none;
  min-height: 44px;
  padding: 0 18px;
  border: 1px solid rgba(255, 252, 245, 0.3);
  border-radius: 999px;
  background: transparent;
  color: var(--karma-cream);
  font-family: var(--karma-font-body);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: background 120ms ease, border-color 120ms ease;
}

.karma-finder__reset:hover,
.karma-finder__reset:focus {
  background: rgba(255, 252, 245, 0.12);
  border-color: rgba(255, 252, 245, 0.55);
}

/* =========================================================================
   Visit band
   ========================================================================= */

.karma-visit-band {
  position: relative;
  background:
    radial-gradient(ellipse 60% 50% at 12% 30%, rgba(123, 91, 166, 0.30), transparent 70%),
    radial-gradient(ellipse 70% 60% at 90% 80%, rgba(79, 56, 120, 0.25), transparent 70%),
    linear-gradient(135deg, var(--karma-lavender-soft) 0%, var(--karma-lavender-mid) 100%);
  overflow: hidden;
  isolation: isolate;
}

.karma-visit-band::before {
  content: "";
  position: absolute;
  top: -140px;
  right: -120px;
  width: 460px;
  height: 460px;
  z-index: -1;
  background: radial-gradient(circle at 50% 50%, rgba(79, 56, 120, 0.35) 0%, transparent 60%);
  pointer-events: none;
}

.karma-visit-band::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background-image:
    radial-gradient(circle, rgba(79, 56, 120, 0.85) 0 1.4px, transparent 2px),
    radial-gradient(circle, rgba(123, 91, 166, 0.7) 0 1.1px, transparent 1.7px),
    radial-gradient(circle, rgba(201, 169, 97, 0.95) 0 1.4px, transparent 2.2px),
    radial-gradient(circle, rgba(255, 252, 245, 0.55) 0 0.8px, transparent 1.3px);
  background-size: 160px 160px, 220px 220px, 320px 320px, 100px 100px;
  background-position: 12% 28%, 64% 18%, 32% 70%, 82% 56%;
  opacity: calc(var(--mystic) * 0.85);
  pointer-events: none;
}

.karma-visit-band__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

/* Mobile-only line break to keep "Rockville Centre" on its own line. */
.karma-br-mobile {
  display: none;
}

.karma-visit-band h2 {
  margin: 0 0 16px;
  max-width: 760px;
  font-family: var(--karma-font-display);
  font-size: clamp(32px, 5vw, 56px);
  line-height: 1.05;
  text-wrap: balance;
}

.karma-visit-band p {
  margin: 0 0 24px;
  max-width: 620px;
  color: var(--karma-ink-mid);
  font-family: var(--karma-font-serif);
  font-style: italic;
  font-size: 19px;
  line-height: 1.55;
  text-wrap: balance;
}

.karma-visit-band__facts {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 36px;
  margin: 8px 0 36px;
  max-width: 820px;
  width: 100%;
  text-align: center;
}

.karma-visit-band__facts > div { margin: 0; }

.karma-visit-band__facts dt {
  margin: 0 0 10px;
  color: var(--karma-amethyst-deep);
  font-family: var(--karma-font-body);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

.karma-visit-band__facts dd {
  margin: 0;
  color: var(--karma-ink);
  font-family: var(--karma-font-serif);
  font-size: 21px;
  font-weight: 600;
  line-height: 1.4;
}

.karma-visit-band__facts dd a {
  color: var(--karma-ink);
  text-decoration: none;
  border-bottom: 1px solid currentColor;
}

.karma-visit-band__facts dd a:hover,
.karma-visit-band__facts dd a:focus {
  color: var(--karma-amethyst-deep);
}

.karma-visit-band__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  justify-content: center;
}

/* =========================================================================
   Classes & circles strip (WooCommerce-backed)
   ========================================================================= */

.karma-classes {
  background: var(--karma-bg);
}

.karma-classes__head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  margin: 0 0 36px;
}

.karma-classes__head h2 {
  margin: 0;
  font-family: var(--karma-font-display);
  font-size: clamp(30px, 4.5vw, 48px);
  line-height: 1.05;
}

.karma-classes__all {
  flex: none;
  padding-bottom: 4px;
  border-bottom: 1px solid currentColor;
  color: var(--karma-teal-deep);
  font-family: var(--karma-font-body);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-decoration: none;
  white-space: nowrap;
}

.karma-classes__all:hover,
.karma-classes__all:focus {
  color: var(--karma-amethyst-deep);
}

.karma-classes__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.karma-class-card {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border: 1px solid var(--karma-lavender-soft);
  border-radius: var(--karma-radius-lg);
  background: var(--karma-surface);
  box-shadow: var(--karma-shadow-sm);
  color: var(--karma-ink);
  text-decoration: none;
  transition: transform 200ms ease, box-shadow 200ms ease, border-color 200ms ease;
}

.karma-class-card:hover,
.karma-class-card:focus {
  transform: translateY(-3px);
  box-shadow: var(--karma-shadow);
  border-color: var(--karma-lavender-mid);
}

.karma-class-card__media {
  position: relative;
  display: block;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background:
    radial-gradient(circle at 72% 28%, rgba(123, 91, 166, 0.18), transparent 60%),
    linear-gradient(160deg, var(--karma-lavender-wash) 0%, var(--karma-lavender-soft) 100%);
}

.karma-class-card__media .karma-class-card__img,
.karma-class-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.karma-class-card__media .karma-class-card__moon {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: auto;
  height: auto;
  color: var(--karma-amethyst);
  opacity: 0.7;
}

.karma-class-card__body {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  padding: 22px 24px 24px;
}

.karma-class-card__title {
  display: block;
  font-family: var(--karma-font-serif);
  font-style: italic;
  font-size: 22px;
  font-weight: 500;
  line-height: 1.2;
  color: var(--karma-ink);
}

.karma-class-card__when {
  display: block;
  margin-top: 8px;
  color: var(--karma-ink-soft);
  font-family: var(--karma-font-body);
  font-size: 13px;
  letter-spacing: 0.01em;
}

.karma-class-card__foot {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  margin-top: auto;
  padding-top: 20px;
}

.karma-class-card__price {
  color: var(--karma-teal-deep);
  font-family: var(--karma-font-serif);
  font-style: italic;
  font-size: 20px;
  font-weight: 500;
}

.karma-class-card__price .amount,
.karma-class-card__price bdi {
  font-style: italic;
}

.karma-class-card__cta {
  color: var(--karma-amethyst-deep);
  font-family: var(--karma-font-body);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.10em;
  text-transform: uppercase;
}

/* Empty state when no classes are in stock */
.karma-classes__empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 14px;
  padding: clamp(40px, 6vw, 72px) 24px;
  border: 1px solid var(--karma-lavender-soft);
  border-radius: var(--karma-radius-xl);
  background:
    radial-gradient(circle at 50% 0%, rgba(123, 91, 166, 0.10), transparent 60%),
    var(--karma-surface);
}

.karma-classes__empty .karma-class-card__moon {
  width: 48px;
  height: 48px;
  color: var(--karma-amethyst);
  opacity: 0.7;
}

.karma-classes__empty h3 {
  margin: 0;
  font-family: var(--karma-font-serif);
  font-style: italic;
  font-size: 26px;
  font-weight: 500;
  color: var(--karma-ink);
}

.karma-classes__empty p {
  margin: 0;
  max-width: 440px;
  color: var(--karma-ink-mid);
  font-size: 15px;
  line-height: 1.6;
}

.karma-classes__empty .karma-button {
  margin-top: 6px;
}

/* =========================================================================
   Spiritual Guidance (counselor grid)
   ========================================================================= */

.karma-guidance {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background: linear-gradient(180deg, var(--karma-lavender-wash) 0%, var(--karma-bg) 100%);
}

.karma-guidance__stars {
  z-index: -1;
  opacity: calc(var(--mystic) * 0.5);
}

.karma-guidance__grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 20px;
}

.karma-guide-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 0 1 232px;
  padding: 32px 24px 28px;
  border: 1px solid var(--karma-lavender-soft);
  border-radius: var(--karma-radius-lg);
  background: var(--karma-surface);
  box-shadow: var(--karma-shadow-sm);
  text-align: center;
  transition: transform 200ms ease, box-shadow 200ms ease, border-color 200ms ease;
}

.karma-guide-card:hover,
.karma-guide-card:focus-within {
  transform: translateY(-3px);
  box-shadow: var(--karma-shadow);
  border-color: var(--karma-lavender-mid);
}

.karma-guide-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  margin: 0 0 18px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 30%, rgba(255, 252, 245, 0.9), transparent 70%),
    var(--karma-lavender-wash);
  color: var(--karma-amethyst-deep);
}

.karma-guide-card__icon svg {
  width: 24px;
  height: 24px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.karma-guide-card__name {
  margin: 0 0 6px;
  font-family: var(--karma-font-serif);
  font-style: italic;
  font-size: 23px;
  font-weight: 500;
  line-height: 1.15;
  color: var(--karma-ink);
}

.karma-guide-card__role {
  margin: 0 0 14px;
  color: var(--karma-amethyst);
  font-family: var(--karma-font-body);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  line-height: 1.4;
}

.karma-guide-card__focus {
  margin: 0 0 16px;
  color: var(--karma-ink-mid);
  font-size: 13px;
  line-height: 1.55;
}

.karma-guide-card__days {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  margin: auto 0 0;
  padding: 7px 14px;
  border-radius: 999px;
  background: var(--karma-lavender-wash);
  color: var(--karma-teal-deep);
  font-family: var(--karma-font-body);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
}

.karma-guide-card__days .k-sparkle {
  width: 9px;
  height: 9px;
}

.karma-guidance__cta {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  margin-top: 40px;
  text-align: center;
}

.karma-guidance__note {
  margin: 0;
  color: var(--karma-ink-soft);
  font-family: var(--karma-font-serif);
  font-style: italic;
  font-size: 15px;
  line-height: 1.5;
}

/* =========================================================================
   Search overlay
   ========================================================================= */

.karma-search-overlay {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: grid;
  place-items: start center;
  padding: 80px 16px 16px;
}

.karma-search-overlay[hidden] { display: none; }

.karma-search-overlay__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(31, 26, 46, 0.6);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.karma-search-overlay__panel {
  position: relative;
  width: min(720px, 100%);
  padding: 28px;
  border: 1px solid var(--karma-lavender-soft);
  border-radius: var(--karma-radius-xl);
  background: var(--karma-bg);
  box-shadow: var(--karma-shadow-lg);
}

.karma-search-overlay__panel h2 {
  margin: 0 0 24px;
  font-family: var(--karma-font-display);
  font-size: clamp(28px, 4.5vw, 44px);
  font-weight: 500;
  line-height: 1.05;
}

.karma-search-overlay__close {
  position: absolute;
  right: 18px;
  top: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  padding: 0 14px;
  border: 1px solid var(--karma-lavender-mid);
  border-radius: 999px;
  background: transparent;
  color: var(--karma-ink-soft);
  font-family: var(--karma-font-body);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  cursor: pointer;
}

.karma-search-overlay__close:hover,
.karma-search-overlay__close:focus {
  border-color: var(--karma-amethyst);
  color: var(--karma-amethyst-deep);
}

.karma-search-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  margin-bottom: 24px;
}

.karma-search-form input[type="search"] {
  min-height: 52px;
  padding: 0 20px;
  border: 1px solid var(--karma-lavender-mid);
  border-radius: 999px;
  background: var(--karma-surface);
  color: var(--karma-ink);
  font-family: var(--karma-font-serif);
  font-style: italic;
  font-size: 18px;
}

.karma-search-form input[type="search"]:focus {
  border-color: var(--karma-amethyst);
  outline: 2px solid rgba(123, 91, 166, 0.2);
  outline-offset: 2px;
}

.karma-search-form button {
  min-height: 52px;
  padding: 0 24px;
  border: 1px solid var(--karma-teal-deep);
  border-radius: 999px;
  background: var(--karma-teal);
  color: #fff;
  font-family: var(--karma-font-body);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.02em;
  cursor: pointer;
}

.karma-search-overlay__quick-links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.karma-search-overlay__quick-links a {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 0 16px;
  border: 1px solid var(--karma-lavender-soft);
  border-radius: 999px;
  background: var(--karma-lavender-wash);
  color: var(--karma-amethyst-deep);
  font-family: var(--karma-font-serif);
  font-style: italic;
  font-size: 14px;
  font-weight: 500;
  text-decoration: none;
  transition: background 120ms ease, border-color 120ms ease;
}

.karma-search-overlay__quick-links a:hover,
.karma-search-overlay__quick-links a:focus {
  background: var(--karma-lavender-soft);
  border-color: var(--karma-amethyst);
}

/* =========================================================================
   Shop intro & WooCommerce
   ========================================================================= */

.karma-shop-intro {
  position: relative;
  margin: 0 0 28px;
  padding: clamp(36px, 5vw, 56px);
  border: 1px solid var(--karma-lavender-soft);
  border-radius: var(--karma-radius-xl);
  background: linear-gradient(180deg, var(--karma-bg) 0%, var(--karma-lavender-wash) 100%);
  overflow: hidden;
  isolation: isolate;
}

.karma-shop-intro::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background-image:
    radial-gradient(circle, rgba(123, 91, 166, 0.45) 0 1px, transparent 1.5px),
    radial-gradient(circle, rgba(201, 169, 97, 0.55) 0 1.2px, transparent 2px);
  background-size: 200px 200px, 280px 280px;
  background-position: 14% 28%, 78% 18%;
  opacity: calc(var(--mystic) * 0.7 + 0.1);
  pointer-events: none;
}

.karma-shop-intro h1 {
  max-width: 720px;
  margin: 0 0 16px;
  color: var(--karma-ink);
  font-family: var(--karma-font-display);
  font-size: clamp(32px, 5vw, 56px);
  font-weight: 500;
  line-height: 1.05;
}

.karma-shop-intro p:not(.karma-eyebrow) {
  max-width: 620px;
  margin: 0 0 24px;
  color: var(--karma-ink-mid);
  font-family: var(--karma-font-serif);
  font-style: italic;
  font-size: 19px;
  line-height: 1.55;
}

.karma-shop-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  width: 100%;
  margin: 0 0 24px;
  padding: 0 0 18px;
  border-bottom: 1px solid var(--karma-lavender-soft);
}

.karma-shop-chips a {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 0 16px;
  border: 1px solid var(--karma-lavender-mid);
  border-radius: 999px;
  background: transparent;
  color: var(--karma-ink);
  font-family: var(--karma-font-body);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.02em;
  text-decoration: none;
  transition: background 120ms ease, border-color 120ms ease, color 120ms ease;
}

.karma-shop-chips a:hover,
.karma-shop-chips a:focus {
  background: var(--karma-amethyst-deep);
  border-color: var(--karma-amethyst-deep);
  color: var(--karma-cream);
}

/* Slim header for search results — keeps matches near the top */
.karma-shop-intro--slim {
  margin: 0 0 18px;
  padding: clamp(18px, 3vw, 26px) clamp(20px, 3vw, 32px);
}

.karma-shop-intro--slim .karma-eyebrow {
  margin-bottom: 8px;
}

.karma-shop-intro--slim h1 {
  margin: 0;
  font-size: clamp(24px, 4vw, 36px);
}

/* Hide Astra's shop filter toggle: the shop sidebar has no filter widgets,
   so the off-canvas panel it opens is empty. */
.astra-shop-filter-button,
.ast-woocommerce-mobile-template .astra-shop-filter-button {
  display: none !important;
}

/* WooCommerce shop loop */
.ast-woocommerce-container .ast-woocommerce-container-header,
.woocommerce-products-header {
  display: none;
}

.woocommerce ul.products {
  display: grid;
  gap: clamp(16px, 2vw, 24px);
  margin: 0 0 32px;
  padding: 0;
  list-style: none;
}

.woocommerce ul.products::before,
.woocommerce ul.products::after {
  display: none;
}

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden;
  border: 1px solid var(--karma-lavender-soft);
  border-radius: var(--karma-radius);
  background: var(--karma-surface);
  box-shadow: var(--karma-shadow-sm);
  transition: transform 200ms ease, box-shadow 200ms ease, border-color 200ms ease;
}

.woocommerce ul.products li.product:hover,
.woocommerce ul.products li.product:focus-within {
  transform: translateY(-2px);
  border-color: var(--karma-lavender-mid);
  box-shadow: var(--karma-shadow);
}

.woocommerce ul.products li.product a img {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  background: var(--karma-lavender-wash);
}

.woocommerce ul.products li.product .astra-shop-summary-wrap,
.woocommerce ul.products li.product > a + .price,
.woocommerce ul.products li.product > .button {
  padding-left: 18px;
  padding-right: 18px;
}

.woocommerce ul.products li.product .astra-shop-summary-wrap {
  padding-top: 18px;
  padding-bottom: 8px;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
  color: var(--karma-ink);
  font-family: var(--karma-font-serif);
  font-style: italic;
  font-size: 20px;
  font-weight: 500;
  line-height: 1.25;
}

.woocommerce ul.products li.product .price {
  color: var(--karma-teal-deep) !important;
  font-family: var(--karma-font-body);
  font-size: 14px;
  font-weight: 600;
}

.woocommerce ul.products li.product .button {
  display: block;
  width: calc(100% - 36px);
  margin: 16px 18px 18px !important;
  text-align: center;
}

/* =========================================================================
   Category cards (.product-category) — image-led, sibling of class cards
   ========================================================================= */

.woocommerce ul.products li.product-category {
  position: relative;
}

.woocommerce ul.products li.product-category > a {
  display: block !important;
  text-decoration: none;
}

/* Square media well behind the image (also shows for the celestial placeholder).
   Astra sets an explicit img height that beats aspect-ratio, so force a square
   with height:auto + aspect-ratio !important, scoped to category cards. */
.woocommerce ul.products li.product-category > a > img {
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 1 / 1 !important;
  margin: 0 !important;
  object-fit: cover;
  background:
    radial-gradient(circle at 72% 26%, rgba(123, 91, 166, 0.18), transparent 60%),
    linear-gradient(160deg, var(--karma-lavender-wash) 0%, var(--karma-lavender-soft) 100%);
}

/* Replace WooCommerce's grey placeholder with a calm celestial tile.
   object-position pushes the grey graphic out of view; the element's own
   background (gradient + moon) stays visible. */
.woocommerce ul.products li.product-category > a > img[src*="woocommerce-placeholder"] {
  object-position: -9999px 0;
  background-image:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='56' height='56' viewBox='0 0 18 18'><circle cx='9' cy='9' r='7' fill='%237B5BA6' opacity='0.55'/></svg>"),
    radial-gradient(circle at 50% 40%, rgba(255, 252, 245, 0.55), transparent 60%),
    linear-gradient(160deg, var(--karma-lavender-wash) 0%, var(--karma-lavender-soft) 100%);
  background-repeat: no-repeat;
  background-position: center 38%, center, center;
  background-size: 56px 56px, cover, cover;
}

/* Override Astra's absolute "white plate" overlay → normal flow below image */
.woocommerce ul.products li.product-category h2.woocommerce-loop-category__title {
  position: static !important;
  inset: auto !important;
  width: auto !important;
  background: transparent !important;
  margin: 0;
  padding: 18px 18px 4px;
  color: var(--karma-ink);
  font-family: var(--karma-font-serif);
  font-style: italic;
  font-size: 20px;
  font-weight: 500;
  line-height: 1.2;
  text-transform: none;
  letter-spacing: 0;
  text-align: left;
}

.woocommerce ul.products li.product-category mark.count {
  display: block;
  padding: 0 18px 18px;
  background: transparent;
  color: var(--karma-ink-soft);
  font-family: var(--karma-font-body);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-align: left;
}

/* Arrow corner on the image, matching the homepage category grid */
.woocommerce ul.products li.product-category > a::after {
  content: "";
  position: absolute;
  top: 14px;
  right: 14px;
  width: 30px;
  height: 30px;
  display: flex;
  border-radius: 50%;
  background:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%234F3878' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'><line x1='5' y1='12' x2='19' y2='12'/><polyline points='12 5 19 12 12 19'/></svg>") center / 15px no-repeat,
    rgba(255, 252, 245, 0.92);
  box-shadow: var(--karma-shadow-sm);
  opacity: 0;
  transform: translateY(-4px);
  transition: opacity 200ms ease, transform 200ms ease;
}

.woocommerce ul.products li.product-category:hover > a::after,
.woocommerce ul.products li.product-category:focus-within > a::after {
  opacity: 1;
  transform: translateY(0);
}

/* =========================================================================
   Shop archive chrome — ordering row, result count, breadcrumb, pagination
   ========================================================================= */

.woocommerce .woocommerce-result-count,
.woocommerce .woocommerce-ordering {
  color: var(--karma-ink-soft);
  font-family: var(--karma-font-body);
  font-size: 13px;
}

.woocommerce .woocommerce-result-count {
  margin: 0 0 18px;
  letter-spacing: 0.01em;
}

.woocommerce .woocommerce-ordering select {
  min-height: 42px;
  padding: 0 16px;
  border: 1px solid var(--karma-lavender-mid);
  border-radius: 999px;
  background: var(--karma-surface);
  color: var(--karma-ink);
  font-family: var(--karma-font-body);
  font-size: 13px;
}

.woocommerce .woocommerce-ordering select:focus {
  border-color: var(--karma-amethyst);
  outline: 2px solid rgba(123, 91, 166, 0.18);
  outline-offset: 2px;
}

/* Breadcrumb */
.woocommerce .woocommerce-breadcrumb {
  margin: 0 0 18px;
  color: var(--karma-ink-soft);
  font-family: var(--karma-font-body);
  font-size: 12px;
  letter-spacing: 0.04em;
}

.woocommerce .woocommerce-breadcrumb a {
  color: var(--karma-amethyst-deep);
  text-decoration: none;
}

.woocommerce .woocommerce-breadcrumb a:hover,
.woocommerce .woocommerce-breadcrumb a:focus {
  color: var(--karma-teal-deep);
  text-decoration: underline;
}

/* Pagination */
.woocommerce nav.woocommerce-pagination {
  margin-top: 8px;
  text-align: center;
}

.woocommerce nav.woocommerce-pagination ul {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 8px;
  border: 0;
}

.woocommerce nav.woocommerce-pagination ul li {
  border: 0;
  margin: 0;
  overflow: visible;
}

.woocommerce nav.woocommerce-pagination ul li a.page-numbers,
.woocommerce nav.woocommerce-pagination ul li span.page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 42px;
  min-height: 42px;
  padding: 0 12px;
  border: 1px solid var(--karma-lavender-mid);
  border-radius: 999px;
  background: var(--karma-surface);
  color: var(--karma-ink);
  font-family: var(--karma-font-body);
  font-size: 13px;
  font-weight: 600;
  line-height: 1;
  transition: background 120ms ease, border-color 120ms ease, color 120ms ease;
}

.woocommerce nav.woocommerce-pagination ul li a.page-numbers:hover,
.woocommerce nav.woocommerce-pagination ul li a.page-numbers:focus {
  border-color: var(--karma-amethyst);
  color: var(--karma-amethyst-deep);
}

.woocommerce nav.woocommerce-pagination ul li span.page-numbers.current {
  background: var(--karma-amethyst-deep);
  border-color: var(--karma-amethyst-deep);
  color: var(--karma-cream);
}

/* WooCommerce product detail */
.woocommerce div.product div.summary {
  padding: clamp(24px, 3vw, 40px);
  border: 1px solid var(--karma-lavender-soft);
  border-radius: var(--karma-radius-lg);
  background: var(--karma-surface);
  box-shadow: var(--karma-shadow-sm);
}

.woocommerce div.product .product_title {
  color: var(--karma-ink);
  font-family: var(--karma-font-display);
  font-size: clamp(32px, 5vw, 52px);
  font-weight: 500;
  line-height: 1.05;
}

.woocommerce div.product p.price,
.woocommerce div.product span.price {
  color: var(--karma-teal-deep);
  font-family: var(--karma-font-body);
  font-size: 22px;
  font-weight: 600;
}

.woocommerce div.product form.cart .button {
  min-width: min(100%, 220px);
}

.woocommerce div.product .woocommerce-tabs ul.tabs {
  margin: 0 0 24px;
  padding: 0;
  border-bottom: 1px solid var(--karma-lavender-soft);
}

.woocommerce div.product .woocommerce-tabs ul.tabs::before {
  border-bottom-color: var(--karma-lavender-soft) !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
  margin: 0 4px -1px 0 !important;
  padding: 0 !important;
  border: 1px solid transparent !important;
  border-bottom: none !important;
  border-radius: var(--karma-radius) var(--karma-radius) 0 0;
  background: transparent !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  display: block;
  padding: 12px 18px !important;
  color: var(--karma-ink-soft);
  font-family: var(--karma-font-body);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: none;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active {
  border-color: var(--karma-lavender-soft) !important;
  background: var(--karma-surface) !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
  color: var(--karma-amethyst-deep);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after {
  display: none !important;
}

.woocommerce div.product .woocommerce-tabs .panel {
  padding: 0;
  background: transparent;
  border: none;
  box-shadow: none;
  color: var(--karma-ink-mid);
}

/* Product image gallery — give a soft placeholder background while loading */
.woocommerce div.product div.images,
.woocommerce div.product div.images .woocommerce-product-gallery,
.woocommerce div.product div.images .woocommerce-product-gallery__wrapper {
  border-radius: var(--karma-radius);
}

.woocommerce div.product div.images .woocommerce-product-gallery__image {
  background: var(--karma-lavender-wash);
  border-radius: var(--karma-radius);
  overflow: hidden;
}

.woocommerce div.product div.images img {
  border-radius: var(--karma-radius);
}

/* Quantity controls */
.woocommerce .quantity .qty {
  min-height: 44px;
  padding: 0 12px;
  border: 1px solid var(--karma-lavender-mid);
  border-radius: 999px;
  background: var(--karma-surface);
  color: var(--karma-ink);
  font-family: var(--karma-font-body);
  font-size: 14px;
}

/* Astra renders server-side quantity placeholders (.ast-qty-placeholder) that
   its JS is meant to replace with the labelled .minus/.plus buttons — but both
   linger here, giving a doubled +/-. Hide the leftover placeholders so a single
   functional minus/input/plus remains. */
.woocommerce .quantity a.ast-qty-placeholder {
  display: none !important;
}

/* =========================================================================
   Footer
   ========================================================================= */

.karma-site-footer {
  position: relative;
  padding: clamp(60px, 8vw, 96px) 0 32px;
  background: var(--karma-amethyst-deep);
  color: var(--karma-cream);
  overflow: hidden;
  isolation: isolate;
}

.karma-site-footer::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background-image:
    radial-gradient(circle, rgba(255, 252, 245, 0.45) 0 1px, transparent 1.5px),
    radial-gradient(circle, rgba(201, 169, 97, 0.55) 0 1.2px, transparent 2px);
  background-size: 220px 220px, 320px 320px;
  background-position: 12% 28%, 76% 18%;
  opacity: calc(var(--mystic) * 0.6 + 0.1);
  pointer-events: none;
}

.karma-site-footer__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) repeat(3, minmax(0, 1fr));
  gap: clamp(32px, 4vw, 60px);
  margin-bottom: 60px;
}

.karma-footer-brand {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.karma-footer-logo {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  margin: 0 0 24px;
  color: var(--karma-cream);
  text-decoration: none;
  line-height: 1;
}

.karma-footer-logo .karma-footer-logo__est {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 10px;
  color: var(--karma-amethyst-light);
  font-family: var(--karma-font-serif);
  font-style: italic;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.karma-footer-logo .karma-footer-logo__top {
  font-family: var(--karma-font-display);
  font-size: 22px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.karma-footer-logo .karma-footer-logo__bottom {
  margin-top: -2px;
  color: var(--karma-cream);
  font-family: var(--karma-font-serif);
  font-style: italic;
  font-size: 38px;
  font-weight: 500;
  letter-spacing: 0.01em;
}

.karma-site-footer p {
  max-width: 320px;
  margin: 0;
  color: rgba(255, 252, 245, 0.78);
  font-family: var(--karma-font-serif);
  font-style: italic;
  font-size: 15px;
  line-height: 1.55;
}

.karma-footer-address {
  margin: 18px 0 0;
  max-width: 320px;
  color: rgba(255, 252, 245, 0.85);
  font-family: var(--karma-font-serif);
  font-size: 14px;
  font-style: normal;
  line-height: 1.6;
}

.karma-footer-address a {
  color: rgba(255, 252, 245, 0.95);
  text-decoration: none;
  border-bottom: 1px solid rgba(255, 252, 245, 0.4);
}

.karma-footer-address a:hover,
.karma-footer-address a:focus {
  color: #fff;
  border-bottom-color: #fff;
}

.karma-site-footer h2 {
  display: none; /* legacy lead — replaced by stacked logo */
}

.karma-site-footer h3 {
  margin: 0 0 16px;
  color: var(--karma-amethyst-light);
  font-family: var(--karma-font-body);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.20em;
  text-transform: uppercase;
}

.karma-site-footer nav {
  display: grid;
  align-content: start;
  gap: 12px;
}

.karma-site-footer a {
  color: rgba(255, 252, 245, 0.85);
  font-family: var(--karma-font-serif);
  font-size: 16px;
  text-decoration: none;
  transition: color 120ms ease;
}

.karma-site-footer a:hover,
.karma-site-footer a:focus {
  color: #fff;
}

.karma-site-footer__bottom {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px;
  margin-top: clamp(32px, 4vw, 48px);
  padding-top: 24px;
  border-top: 1px solid rgba(255, 252, 245, 0.15);
  color: rgba(255, 252, 245, 0.7);
  font-family: var(--karma-font-body);
  font-size: 12px;
  text-align: center;
}

.karma-site-footer__moons {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 14px;
  color: var(--karma-amethyst-light);
}

.karma-site-footer__moons svg {
  width: 16px;
  height: 16px;
}

/* =========================================================================
   Responsive
   ========================================================================= */

@media (max-width: 1080px) {
  :root {
    --karma-shell: min(100% - 48px, 1280px);
  }

  .karma-header-meta {
    display: none;
  }

  .karma-header-main {
    grid-template-columns: 1fr auto;
  }

  .karma-desktop-nav {
    display: none;
  }

  .karma-nav-strip {
    display: none;
  }

  .karma-menu-button {
    display: inline-flex;
  }

  .karma-priorities__grid {
    grid-template-columns: 1fr;
  }

  .karma-category-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .karma-finder__grid {
    grid-template-columns: 1fr;
  }

  .karma-classes__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .karma-site-footer__grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 768px) {
  :root {
    --karma-shell: min(100% - 32px, 1280px);
  }

  body.admin-bar .karma-site-header { top: 46px; }

  .karma-announcement {
    gap: 8px;
    padding: 7px 14px;
    font-size: 11px;
    letter-spacing: 0.04em;
    line-height: 1.3;
  }

  .karma-header-main {
    min-height: 72px;
    gap: 12px;
    padding: 10px 0;
  }

  .karma-logo img {
    max-width: 230px;
    max-height: 74px;
  }

  .karma-header-actions .karma-icon-button:not([data-karma-search-open]):not([data-karma-menu-toggle]):not([href*="cart"]) {
    display: none;
  }

  .karma-hero {
    padding: 28px 0 44px;
  }

  .karma-finder {
    padding: 32px 22px;
    margin: 16px 0;
  }

  .karma-finder__step {
    padding: 22px;
  }

  .karma-section__intro {
    margin: 0 0 24px;
  }

  .karma-priority-card {
    padding: 28px 24px 24px;
  }

  .karma-priority-card p {
    margin-bottom: 22px;
  }

  .karma-choice-group,
  .karma-choice-group--wrap {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .karma-category-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .karma-classes__grid {
    grid-template-columns: 1fr;
  }

  .karma-classes__head {
    flex-direction: column;
    align-items: flex-start;
    gap: 14px;
  }

  .karma-section__intro h2 {
    font-size: clamp(28px, 7vw, 36px);
  }

  .karma-priority-card h2 {
    font-size: 26px;
    margin-bottom: 14px;
  }

  .karma-visit-band__inner {
    gap: 24px;
  }

  .karma-visit-band__facts {
    grid-template-columns: 1fr;
    gap: 18px;
    margin-bottom: 24px;
  }

  .woocommerce ul.products {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .karma-site-footer__grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .karma-site-footer__bottom {
    flex-direction: column;
    align-items: center;
  }

  .karma-br-mobile {
    display: inline;
  }
}

@media (max-width: 480px) {
  body.admin-bar .karma-site-header { top: 0; }

  .karma-guide-card {
    flex: 1 1 100%;
    max-width: 340px;
  }

  .karma-hero__copy h1 {
    font-size: clamp(32px, 9vw, 42px);
    letter-spacing: -0.01em;
    margin-bottom: 16px;
  }

  .karma-hero__copy p:not(.karma-eyebrow) {
    margin-bottom: 22px;
  }

  .karma-hero__moon-row {
    margin-top: 24px;
  }

  .karma-action-row,
  .karma-button {
    width: 100%;
  }

  .karma-action-row { flex-direction: column; }

  .karma-search-form {
    grid-template-columns: 1fr;
  }

  .karma-priorities__grid {
    grid-template-columns: 1fr;
  }

  .karma-category-grid {
    /* Keep 2-col through small mobile so 9 categories aren't a long stack */
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }

  .karma-category-card {
    min-height: 150px;
    padding: 18px;
  }

  .karma-category-card span {
    width: 32px;
    height: 32px;
    margin-bottom: 12px;
  }

  .karma-category-card span svg {
    width: 18px;
    height: 18px;
  }

  .karma-category-card h3 {
    font-size: 17px;
  }

  .karma-category-card p {
    display: none; /* tighten on small mobile */
  }

  .karma-category-card::after {
    top: 18px;
    right: 18px;
    width: 14px;
    height: 14px;
  }

  .woocommerce ul.products {
    grid-template-columns: 1fr;
  }

  .karma-search-overlay {
    padding: 40px 12px 12px;
  }

  .karma-search-overlay__panel {
    max-height: calc(100vh - 60px);
    overflow: auto;
  }
}

@media (min-width: 922px) {
  .woocommerce ul.products.columns-3,
  .woocommerce-page ul.products.columns-3,
  .woocommerce ul.products.columns-4,
  .woocommerce-page ul.products.columns-4 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

/* =========================================================================
   Dark mode (prefers-color-scheme: dark)
   Shipping real dark styles makes browsers use these instead of
   algorithmically force-darkening the light design. Token-driven: most of
   the UI recolours via the :root overrides; the rest are targeted fixes for
   panels that are dark by design and must not invert.
   ========================================================================= */
@media (prefers-color-scheme: dark) {
  :root {
    color-scheme: dark;

    /* Surfaces → deep amethyst-blacks */
    --karma-bg: #14101F;
    --karma-bg-warm: #1A1430;
    --karma-lavender-wash: #221A38;
    --karma-lavender-soft: #2C2147;
    --karma-lavender-mid: #3F2F5C;
    --karma-surface: #1C1638;

    /* Amethyst — mid stays saturated (buttons/eyebrows), deep lightens (text) */
    --karma-amethyst: #8E6FB8;
    --karma-amethyst-deep: #C9B6E6;
    --karma-amethyst-light: #B8A4D4;

    /* Teal — mid stays saturated (buttons), deep lightens (price/accents) */
    --karma-teal: #3FA4A0;
    --karma-teal-deep: #6FC6C1;
    --karma-teal-light: #5BB5B0;

    /* Ink → light */
    --karma-ink: #F2EAF5;
    --karma-ink-mid: #C7BDD6;
    --karma-ink-soft: #9D93B0;
    --karma-ink-faint: #5C5470;

    /* Cream stays light — it's the light text colour on dark panels */
    --karma-cream: #F4ECF8;
    --karma-gold: #D4B872;

    /* Borders → light hairlines on dark */
    --karma-border: rgba(242, 234, 245, 0.12);
    --karma-border-soft: rgba(242, 234, 245, 0.07);
    --karma-border-strong: rgba(242, 234, 245, 0.24);

    /* Shadows → black */
    --karma-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.4), 0 2px 8px rgba(0, 0, 0, 0.3);
    --karma-shadow: 0 4px 16px rgba(0, 0, 0, 0.5), 0 12px 40px rgba(0, 0, 0, 0.4);
    --karma-shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.6), 0 24px 60px rgba(0, 0, 0, 0.5);
  }

  /* Astra forces a white <body>/content background via the customizer; beat it
     so inner pages (shop/product) don't show white gutters around the content. */
  body,
  .site,
  .ast-separate-container,
  .ast-separate-container .ast-article-single,
  .ast-separate-container .ast-woocommerce-container {
    background-color: var(--karma-bg) !important;
  }

  /* Sticky header / nav — dark translucent instead of cream */
  .karma-site-header { background: rgba(20, 16, 31, 0.92); }
  .karma-nav-strip { background: rgba(20, 16, 31, 0.5); }

  /* Logo — light tint on the dark header */
  .karma-logo img {
    filter: brightness(0) invert(1);
    opacity: 0.92;
  }

  /* Hero — dark scrim over the cloud photo so it reads dark; text stays light */
  .karma-hero {
    background-color: var(--karma-bg);
    background-image:
      radial-gradient(ellipse 72% 64% at 50% 42%, rgba(20, 16, 31, 0.5), rgba(20, 16, 31, 0.72) 62%, rgba(20, 16, 31, 0.92) 90%),
      url("../img/hero-bg.jpg");
    background-image:
      radial-gradient(ellipse 72% 64% at 50% 42%, rgba(20, 16, 31, 0.5), rgba(20, 16, 31, 0.72) 62%, rgba(20, 16, 31, 0.92) 90%),
      image-set(
        url("../img/hero-bg.webp") type("image/webp"),
        url("../img/hero-bg.jpg") type("image/jpeg")
      );
  }

  /* Panels that are dark by design must STAY dark — their token background
     would otherwise flip light. Light text + glass overlays already read on
     a dark surface. */
  .karma-announcement { background: #241B3F; }
  .karma-finder { background: #201A3A; }
  .karma-site-footer { background: #1A1535; }
  .karma-priority-card--featured { background: #241B3F; border-color: #241B3F; }
  .karma-priority-card--shop { background: #143230; border-color: #143230; }

  /* Icon discs that were near-white circles → subtle light on dark */
  .karma-category-card span,
  .karma-guide-card__icon {
    background: rgba(242, 234, 245, 0.08);
  }

  /* Hover states that filled with a now-light accent would put light text on
     a light fill — keep them saturated so the label stays readable. */
  .karma-shop-chips a:hover,
  .karma-shop-chips a:focus,
  .karma-search-overlay__quick-links a:hover,
  .karma-search-overlay__quick-links a:focus {
    background: var(--karma-amethyst);
    border-color: var(--karma-amethyst);
    color: #fff;
  }

  .karma-button--outline:hover,
  .karma-button--outline:focus {
    background: var(--karma-amethyst) !important;
    border-color: var(--karma-amethyst) !important;
  }
}
