/* ============================================================
   Vaishnavi Gaushala — Global Styles
   Loaded on every page AFTER tokens.css and Bootstrap.
   ============================================================ */

/* ---------- Reset (modern, minimal) ---------- */
*,
*::before,
*::after { box-sizing: border-box; }

html, body, h1, h2, h3, h4, h5, h6, p, ul, ol, figure, blockquote, dl, dd {
  margin: 0;
}

ul[role="list"],
ol[role="list"] { list-style: none; padding: 0; }

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
          text-size-adjust: 100%;
}

body {
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  color: var(--color-ink);
  background-color: var(--color-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  min-height: 100vh;
  overflow-x: hidden;
}

img,
picture,
svg,
video { display: block; max-width: 100%; height: auto; }

input, button, textarea, select { font: inherit; color: inherit; }

button { background: none; border: none; padding: 0; cursor: pointer; }

a {
  color: var(--color-primary);
  text-decoration: none;
  transition: color var(--dur-fast) var(--ease-out);
}
a:hover { color: var(--color-primary-deep); }

::selection {
  background: var(--color-primary);
  color: var(--color-bg);
}

/* ---------- Typography helpers ---------- */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  font-weight: 600;
  line-height: var(--lh-heading);
  color: var(--color-ink);
  letter-spacing: var(--tracking-tight);
}

h1 { font-size: var(--fs-h1); }
h2 { font-size: var(--fs-h2); }
h3 { font-size: var(--fs-h3); }

.display {
  font-family: var(--font-display);
  font-size: var(--fs-display);
  line-height: var(--lh-display);
  font-weight: 700;
  letter-spacing: var(--tracking-tight);
}

.text-deva {
  font-family: var(--font-deva);
  color: var(--color-primary);
}

.eyebrow {
  display: inline-block;
  font-family: var(--font-body);
  font-size: var(--fs-tiny);
  font-weight: 600;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-gold-deep);
}

.text-muted-soft { color: var(--color-ink-soft); }
.text-primary-maroon { color: var(--color-primary); }

.price,
.tabular { font-variant-numeric: tabular-nums; }

/* ---------- Layout helpers ---------- */
.container-vai {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--sp-4);
}

@media (min-width: 768px) {
  .container-vai { padding-inline: var(--sp-6); }
}

.section {
  padding-block: clamp(var(--sp-7), 8vw, var(--sp-9));
}

.section--alt { background-color: var(--color-bg-alt); }

.section--maroon {
  background-color: var(--color-primary);
  color: var(--color-bg);
}
.section--maroon h1,
.section--maroon h2,
.section--maroon h3 { color: var(--color-bg); }

/* ---------- Buttons ---------- */
.btn-vaishnavi-primary,
.btn-vaishnavi-ghost,
.btn-vaishnavi-gold {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  padding: 14px 28px;
  min-height: 48px;
  font-family: var(--font-body);
  font-size: var(--fs-body);
  font-weight: 600;
  letter-spacing: 0.02em;
  border-radius: var(--r-pill);
  border: 1.5px solid transparent;
  cursor: pointer;
  text-decoration: none;
  transition:
    background-color var(--dur-base) var(--ease-out),
    color var(--dur-base) var(--ease-out),
    border-color var(--dur-base) var(--ease-out),
    transform var(--dur-fast) var(--ease-out),
    box-shadow var(--dur-base) var(--ease-out);
  white-space: nowrap;
}

.btn-vaishnavi-primary {
  background-color: var(--color-primary);
  color: var(--color-bg);
}
.btn-vaishnavi-primary:hover,
.btn-vaishnavi-primary:focus-visible {
  background-color: var(--color-primary-deep);
  color: var(--color-bg);
  box-shadow: var(--shadow-2);
}
.btn-vaishnavi-primary:active { transform: translateY(1px); }

.btn-vaishnavi-ghost {
  background-color: transparent;
  color: var(--color-primary);
  border-color: var(--color-primary);
}
.btn-vaishnavi-ghost:hover,
.btn-vaishnavi-ghost:focus-visible {
  background-color: var(--color-primary);
  color: var(--color-bg);
}

.btn-vaishnavi-gold {
  background-color: var(--color-gold);
  color: var(--color-ink);
}
.btn-vaishnavi-gold:hover,
.btn-vaishnavi-gold:focus-visible {
  background-color: var(--color-gold-deep);
  color: var(--color-bg);
}

.btn-sm {
  padding: 10px 20px;
  min-height: 40px;
  font-size: var(--fs-small);
}

.btn-icon {
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--r-pill);
  background-color: var(--color-surface);
  color: var(--color-primary);
  border: 1px solid var(--color-line);
  transition: all var(--dur-base) var(--ease-out);
}
.btn-icon:hover {
  background-color: var(--color-primary);
  color: var(--color-bg);
  border-color: var(--color-primary);
}

/* ---------- Forms ---------- */
.form-control-vai {
  width: 100%;
  min-height: 48px;
  padding: 12px 16px;
  background-color: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--r-md);
  color: var(--color-ink);
  font-family: var(--font-body);
  font-size: var(--fs-body);
  transition: border-color var(--dur-fast) var(--ease-out),
              box-shadow var(--dur-fast) var(--ease-out);
}
.form-control-vai::placeholder { color: var(--color-muted); }
.form-control-vai:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(var(--rgb-primary), 0.12);
}

.form-label-vai {
  display: block;
  margin-bottom: var(--sp-2);
  font-size: var(--fs-small);
  font-weight: 600;
  color: var(--color-ink-soft);
}

/* ---------- Focus ring (keyboard-only) ---------- */
:focus-visible {
  outline: 2px solid var(--color-gold);
  outline-offset: 3px;
  border-radius: 2px;
}

/* ---------- Dividers & ornaments ---------- */
.divider-gold {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-3);
  margin-block: var(--sp-4);
  color: var(--color-gold); /* default; pseudo-elements & inline SVG inherit */
}
.divider-gold::before,
.divider-gold::after {
  content: "";
  flex: 0 1 80px;
  height: 1px;
  background-color: currentColor;
}
.divider-gold svg,
.divider-gold .icon-lotus { width: 24px; height: 24px; flex-shrink: 0; }

/* Mask-image helper so currentColor tints an external SVG.
   Strokes/fills in the source become the silhouette; CSS color fills it. */
.icon-lotus,
.icon-lotus-lg {
  display: inline-block;
  background-color: currentColor;
  -webkit-mask: url("../svg/lotus-dot.1ea2f4b84b2e.svg") center / contain no-repeat;
          mask: url("../svg/lotus-dot.1ea2f4b84b2e.svg") center / contain no-repeat;
}
.icon-lotus    { width: 20px; height: 20px; }
.icon-lotus-lg { width: 40px; height: 40px; }

/* ---------- Section heading composite ---------- */
.section-heading {
  text-align: center;
  margin-bottom: var(--sp-7);
}
.section-heading .eyebrow { margin-bottom: var(--sp-3); }
.section-heading h2 { margin-bottom: var(--sp-3); }
.section-heading p {
  max-width: 60ch;
  margin-inline: auto;
  color: var(--color-ink-soft);
}

/* ---------- Card base ---------- */
.card-vai {
  background-color: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--r-lg);
  overflow: hidden;
  transition: box-shadow var(--dur-base) var(--ease-out),
              transform var(--dur-base) var(--ease-out);
}
.card-vai:hover {
  box-shadow: var(--shadow-2);
  transform: translateY(-2px);
}

/* ---------- Badges / pills ---------- */
.badge-vai {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  font-size: var(--fs-tiny);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border-radius: var(--r-pill);
  background-color: var(--color-bg-alt);
  color: var(--color-ink-soft);
}
.badge-vai--sale   { background-color: var(--color-accent-red); color: #fff; }
.badge-vai--new    { background-color: var(--color-primary); color: #fff; }
.badge-vai--stock  { background-color: rgba(92, 138, 74, 0.15); color: var(--color-success); }
.badge-vai--gold   { background-color: var(--color-gold); color: var(--color-ink); }

/* ---------- Bootstrap overrides ---------- */
.btn-primary,
.btn-primary:hover,
.btn-primary:focus { /* prevent stock-blue leaks */
  background-color: var(--color-primary);
  border-color: var(--color-primary);
}

/* ---------- Loading splash ---------- */
.splash {
  position: fixed;
  inset: 0;
  background-color: var(--color-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: var(--z-overlay);
  pointer-events: none;
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* ---------- Accessibility utility ---------- */
.visually-hidden {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0, 0, 0, 0);
  white-space: nowrap; border: 0;
}

/* ---------- Display utility (toggled by JS) ---------- */
.is-hidden { display: none !important; }
.mt-section { margin-top: var(--sp-5); }
