/* ==========================================================================
   HERBALISSA UTILITIES
   Surface classes, layout helpers, and design system building blocks
   ========================================================================== */

/* ------------------------------------------------------------------
   SURFACES — "Stacked fine papers" tonal hierarchy
   Use these instead of borders to create visual separation
   ------------------------------------------------------------------ */

.surface                  { background-color: var(--color-surface); }
.surface-bright           { background-color: var(--color-surface-bright); }
.surface-dim              { background-color: var(--color-surface-dim); }
.surface-container-lowest { background-color: var(--color-surface-container-lowest); }
.surface-container-low    { background-color: var(--color-surface-container-low); }
.surface-container        { background-color: var(--color-surface-container); }
.surface-container-high   { background-color: var(--color-surface-container-high); }
.surface-container-highest{ background-color: var(--color-surface-container-highest); }
.surface-inverse          { background-color: var(--color-inverse-surface); color: var(--color-inverse-on-surface); }
.surface-primary          { background-color: var(--color-primary); color: var(--color-on-primary); }


/* ------------------------------------------------------------------
   GLASSMORPHISM — Floating elements
   ------------------------------------------------------------------ */

.glass {
  background-color: var(--glass-bg);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
}

.glass-heavy {
  background-color: var(--glass-bg);
  backdrop-filter: blur(var(--glass-blur-heavy));
  -webkit-backdrop-filter: blur(var(--glass-blur-heavy));
}


/* ------------------------------------------------------------------
   LAYOUT
   ------------------------------------------------------------------ */

.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--gutter);
}

.container-narrow {
  max-width: var(--container-narrow);
  margin-inline: auto;
  padding-inline: var(--gutter);
}

.container-wide {
  max-width: var(--container-wide);
  margin-inline: auto;
  padding-inline: var(--gutter);
}

.section {
  padding-block: var(--space-section);
}

/* Pages using .site-main: first child gets margin to clear fixed header.
   Hero and blog post hero overlap UNDER the header intentionally. */
.site-main > :first-child {
  margin-top: var(--header-offset);
}

.site-main > .c-hero:first-child,
.site-main > .sp-hero:first-child {
  margin-top: var(--space-2);
}

/* Pages where <main> IS the page wrapper (no .site-main parent).
   These handle their own internal layout, so use padding-top.
   Just clear the fixed header + a small breathing pad — these pages
   already add their own .section padding internally. */
main.cart-page,
main.checkout-page,
main.thankyou-page,
main.wc-main,
main.error404-page,
main.search-page,
main.blog-page,
main.shop-page {
  padding-top: calc(var(--header-offset) + var(--space-4));
}

.section-hero {
  padding-block: var(--space-section-hero);
}


/* ------------------------------------------------------------------
   GRID
   ------------------------------------------------------------------ */

.grid {
  display: grid;
  gap: var(--gutter);
}

.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 1024px) {
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 640px) {
  .grid-2,
  .grid-3,
  .grid-4 { grid-template-columns: 1fr; }
}


/* ------------------------------------------------------------------
   FLEX HELPERS
   ------------------------------------------------------------------ */

.flex         { display: flex; }
.flex-col     { flex-direction: column; }
.flex-wrap    { flex-wrap: wrap; }
.items-center { align-items: center; }
.items-start  { align-items: flex-start; }
.items-end    { align-items: flex-end; }
.justify-between { justify-content: space-between; }
.justify-center  { justify-content: center; }
.gap-2  { gap: var(--space-2); }
.gap-3  { gap: var(--space-3); }
.gap-4  { gap: var(--space-4); }
.gap-6  { gap: var(--space-6); }
.gap-8  { gap: var(--space-8); }


/* ------------------------------------------------------------------
   RADIUS — "Organic" vibe, no sharp corners
   ------------------------------------------------------------------ */

.rounded-sm   { border-radius: var(--radius-sm); }
.rounded-md   { border-radius: var(--radius-md); }
.rounded-lg   { border-radius: var(--radius-lg); }
.rounded-xl   { border-radius: var(--radius-xl); }
.rounded-full { border-radius: var(--radius-full); }


/* ------------------------------------------------------------------
   ELEVATION
   ------------------------------------------------------------------ */

.shadow-ambient { box-shadow: var(--shadow-ambient); }
.shadow-low     { box-shadow: var(--shadow-low); }
.shadow-medium  { box-shadow: var(--shadow-medium); }
.ghost-border   { outline: var(--ghost-border); }


/* ------------------------------------------------------------------
   BUTTONS — Per design system spec
   ------------------------------------------------------------------ */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-6);
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: var(--text-body-md);
  font-weight: 600;
  line-height: 1;
  text-decoration: none;
  cursor: pointer;
  transition:
    background-color var(--duration-normal) var(--ease-default),
    color var(--duration-normal) var(--ease-default),
    transform var(--duration-fast) var(--ease-default);
  white-space: nowrap;
}

.btn:active {
  transform: scale(0.98);
}

.btn:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

/* Primary — gradient from primary to primary-container */
.btn-primary {
  background: linear-gradient(135deg, var(--color-primary), var(--color-primary-container));
  color: var(--color-on-primary);
}

.btn-primary:hover {
  background: linear-gradient(135deg, var(--color-primary-container), var(--color-primary));
}

/* Secondary — surface-container-highest, no border */
.btn-secondary {
  background-color: var(--color-surface-container-highest);
  color: var(--color-primary);
}

.btn-secondary:hover {
  background-color: var(--color-surface-container-high);
}

/* Tertiary — text only, underline on hover */
.btn-tertiary {
  background: none;
  color: var(--color-primary);
  padding-inline: 0;
  position: relative;
}

.btn-tertiary::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: var(--color-primary);
  transform: scaleX(0);
  transform-origin: right;
  transition: transform var(--duration-normal) var(--ease-default);
}

.btn-tertiary:hover::after {
  transform: scaleX(1);
  transform-origin: left;
}


/* ------------------------------------------------------------------
   HERB CHIP — Signature component for ingredient tags
   ------------------------------------------------------------------ */

.herb-chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-1) var(--space-3);
  background-color: var(--color-secondary-container);
  color: var(--color-on-secondary-container);
  border-radius: var(--radius-full);
  font-family: var(--font-body);
  font-size: var(--text-label-md);
  line-height: var(--text-label-md-lh);
  letter-spacing: var(--text-label-md-tracking);
  font-weight: var(--text-label-md-weight);
  text-transform: uppercase;
  white-space: nowrap;
}


/* ------------------------------------------------------------------
   INPUT FIELDS — Minimalist, bottom-border only
   ------------------------------------------------------------------ */

.input-field {
  position: relative;
}

.input-field input,
.input-field textarea,
.input-field select {
  width: 100%;
  padding: var(--space-3) 0;
  background: transparent;
  border: none;
  border-bottom: 1px solid rgba(118, 120, 107, 0.3); /* outline @ 30% */
  font-family: var(--font-body);
  font-size: var(--text-body-lg);
  color: var(--color-on-surface);
  transition: border-color var(--duration-normal) var(--ease-default);
  outline: none;
}

.input-field input:focus,
.input-field textarea:focus,
.input-field select:focus {
  border-bottom-color: var(--color-primary);
}

.input-field input:focus-visible,
.input-field textarea:focus-visible,
.input-field select:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

.input-field label {
  position: absolute;
  top: var(--space-3);
  left: 0;
  font-size: var(--text-body-lg);
  color: var(--color-on-surface-variant);
  pointer-events: none;
  transition:
    top var(--duration-normal) var(--ease-default),
    font-size var(--duration-normal) var(--ease-default);
}

.input-field input:focus ~ label,
.input-field input:not(:placeholder-shown) ~ label,
.input-field textarea:focus ~ label,
.input-field textarea:not(:placeholder-shown) ~ label {
  top: calc(-1 * var(--space-4));
  font-size: var(--text-label-sm);
  letter-spacing: var(--text-label-sm-tracking);
  color: var(--color-primary);
}


/* ------------------------------------------------------------------
   PAPER GRAIN — Subtle artisanal texture overlay
   Applied to body or section backgrounds
   ------------------------------------------------------------------ */

.grain::after {
  content: '';
  position: fixed;
  inset: 0;
  opacity: 0.025;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 9999;
}


/* ------------------------------------------------------------------
   BOTANICAL ACCENTS — Decorative plant images on sections
   Add [data-botanical="name"] to a section for a subtle accent.
   Position with [data-botanical-pos="left|right"] (default: right).
   ------------------------------------------------------------------ */

[data-botanical] {
  position: relative;
  overflow: hidden;
}

[data-botanical]::after {
  content: '';
  position: absolute;
  width: clamp(300px, 40vw, 600px);
  height: clamp(300px, 40vw, 600px);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  pointer-events: none;
  opacity: 0.2;
  z-index: 1;
}

/* Positioning — default right */
[data-botanical]::after,
[data-botanical][data-botanical-pos="right"]::after {
  right: -2%;
  top: 50%;
  transform: translateY(-50%);
}

[data-botanical][data-botanical-pos="left"]::after {
  left: -2%;
  right: auto;
  top: 50%;
  transform: translateY(-50%) scaleX(-1);
}

/* Plant variants */
[data-botanical="chamomile"]::after { background-image: url('../../images/botanicals/chamomile.avif'); }
[data-botanical="lavender"]::after  { background-image: url('../../images/botanicals/lavender.avif'); }
[data-botanical="echinacea"]::after { background-image: url('../../images/botanicals/echinacea.avif'); }
[data-botanical="nettle"]::after    { background-image: url('../../images/botanicals/nettle.avif'); }

/* Pass overflow/position to the inner section so the botanical renders through it */
[data-botanical] > section {
  overflow: hidden;
}

/* Ensure containers stay above the botanical accent */
[data-botanical] .container {
  position: relative;
  z-index: 2;
}

@media (max-width: 768px) {
  [data-botanical]::after {
    opacity: 0.12;
    width: clamp(200px, 50vw, 350px);
    height: clamp(200px, 50vw, 350px);
  }
}

@media (prefers-reduced-motion: reduce) {
  [data-botanical]::after {
    opacity: 0.1;
  }
}

/* ------------------------------------------------------------------
   VISUALLY HIDDEN — Accessibility
   ------------------------------------------------------------------ */

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ------------------------------------------------------------------
   SKIP LINK — keyboard users jump past the header
   ------------------------------------------------------------------ */

.skip-link {
  position: absolute;
  left: var(--space-4);
  top: -64px;
  z-index: var(--z-toast);
  padding: var(--space-3) var(--space-5);
  background-color: var(--color-primary);
  color: var(--color-on-primary);
  font-family: var(--font-body);
  font-weight: 600;
  font-size: var(--text-body-md);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: top var(--duration-fast) var(--ease-default);
}

.skip-link:focus {
  top: var(--space-4);
  outline: 3px solid var(--color-secondary-container);
  outline-offset: 2px;
}
