/* ==========================================================
   innermetaphysics — Full-Width Responsive Design
   Palette: Saffron #E8751A + Charcoal #1A1A1A
   Fonts:   Cormorant Garamond (headings) + Inter (body)
   ========================================================== */

:root {
  --font-heading:  'Cormorant Garamond', serif;
  --font-body:     'Inter', sans-serif;
  --saffron:       #E8751A;
  --saffron-light: #F4A44A;
  --saffron-pale:  #FDF3E8;
  --saffron-dark:  #C45F0A;
  --black:         #0D0D0D;
  --charcoal:      #1A1A1A;
  --ink:           #2E2E2E;
  --muted:         #6B6B6B;
  --light:         #A8A8A8;
  --rule:          #E4E4DF;
  --bg:            #FAFAF8;
  --white:         #FFFFFF;
  --radius:        12px;
  --radius-lg:     20px;
  --shadow-sm:     0 2px 8px rgba(0,0,0,.06);
  --shadow-md:     0 8px 30px rgba(0,0,0,.08);
  --shadow-lg:     0 20px 60px rgba(0,0,0,.10);
}

/* ── Reset ───────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: var(--font-body);
  font-weight: 400;
  color: var(--ink);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }

/* ── Typography ──────────────────────────── */
h1, h2, h3, h4 {
  font-family: var(--font-heading);
  font-weight: 500;
  line-height: 1.08;
  color: var(--black);
}
h1 { font-size: clamp(2.8rem, 6vw, 5rem); font-weight: 400; letter-spacing: -.02em; }
h1 em, h2 em { font-style: italic; color: var(--saffron); }
h2 { font-size: clamp(2rem, 4vw, 3rem); }
h3 { font-size: clamp(1.15rem, 2vw, 1.45rem); font-weight: 500; }
p  { font-size: .93rem; line-height: 1.72; color: var(--muted); }
.lead { font-size: 1.08rem; line-height: 1.75; color: var(--ink); }

/* ── Container ───────────────────────────── */
.container {
  width: 100%;
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 clamp(20px, 3vw, 48px);
}
.container-narrow { max-width: 860px; }

/* ── Eyebrow label ───────────────────────── */
.eyebrow {
  display: block;
  font-size: .7rem; font-weight: 600;
  letter-spacing: .26em; text-transform: uppercase;
  color: var(--saffron);
  margin-bottom: 14px;
}

/* ── Buttons ─────────────────────────────── */
.button {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 13px 28px;
  font-family: var(--font-body);
  font-size: .78rem; font-weight: 600;
  letter-spacing: .12em; text-transform: uppercase;
  border-radius: 4px; cursor: pointer;
  transition: background .2s, color .2s, border-color .2s, transform .15s;
  border: 1.5px solid transparent;
}
.button:active { transform: scale(.97); }
.button-primary { background: var(--saffron); color: var(--white); border-color: var(--saffron); }
.button-primary:hover { background: var(--saffron-dark); border-color: var(--saffron-dark); }
.button-secondary { background: transparent; color: var(--black); border-color: var(--black); }
.button-secondary:hover { background: var(--black); color: var(--white); }
.button-secondary-light { background: rgba(255,255,255,.15); color: #fff; border-color: rgba(255,255,255,.4); }
.button-secondary-light:hover { background: rgba(255,255,255,.25); }
.button-outline-saffron { background: transparent; color: var(--saffron); border-color: var(--saffron); }
.button-outline-saffron:hover { background: var(--saffron); color: var(--white); }
.full-width { width: 100%; justify-content: center; }

/* ── Section ─────────────────────────────── */
.section { padding: clamp(56px, 8vw, 100px) 0; }
.section + .section { border-top: 1px solid var(--rule); }
.section-heading { text-align: center; max-width: 600px; margin: 0 auto 48px; }
.section-heading h2 { margin-top: 8px; }

/* ══════════════════════════════════════════════
   HEADER — sticky, full-width, responsive
   ══════════════════════════════════════════════ */
.site-header {
  position: sticky; top: 0; z-index: 200;
  background: rgba(255,255,255,.97);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--rule);
}
.header-inner {
  display: flex; align-items: center; gap: 24px;
  max-width: 1440px; margin: 0 auto;
  padding: 0 clamp(16px, 3vw, 48px);
  height: 64px;
}
.brand {
  font-family: var(--font-body);
  font-size: .82rem; font-weight: 700;
  letter-spacing: .22em; text-transform: uppercase;
  color: var(--black); white-space: nowrap; flex-shrink: 0;
}
.brand span { color: var(--saffron); }

/* ── Nav list ──────────────────────────── */
.site-nav { flex: 1; display: flex; justify-content: center; }
.nav-list {
  list-style: none; display: flex; gap: 6px;
  align-items: center; padding: 0; margin: 0;
}
.nav-item > a {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 8px 14px;
  font-size: .78rem; font-weight: 600;
  letter-spacing: .12em; text-transform: uppercase;
  color: var(--muted); transition: color .18s;
  white-space: nowrap;
}
.nav-item > a:hover,
.nav-item > a.active { color: var(--black); }
.nav-item > a i { font-size: .85rem; }
.dd-arrow { margin-left: 2px; transition: transform .2s; }

/* ── Dropdown ──────────────────────────── */
.has-dropdown { position: relative; }
.dropdown-menu {
  position: absolute; top: calc(100% + 8px); left: 0;
  min-width: 230px; padding: 8px 0;
  background: var(--white);
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  box-shadow: var(--shadow-md);
  opacity: 0; visibility: hidden;
  transform: translateY(6px);
  transition: opacity .18s, transform .18s, visibility .18s;
  z-index: 300;
  list-style: none;
}
.has-dropdown:hover > .dropdown-menu,
.has-dropdown:focus-within > .dropdown-menu {
  opacity: 1; visibility: visible; transform: translateY(0);
}
.has-dropdown:hover .dd-arrow { transform: rotate(180deg); }
.dropdown-menu li a {
  display: block; padding: .75rem 1.2rem;
  font-size: .9rem; font-weight: 500;
  color: var(--ink); text-transform: none;
  letter-spacing: 0; transition: background .15s;
}
.dropdown-menu li a:hover { background: var(--saffron-pale); color: var(--saffron); }

/* ── Header actions (search + auth) ────── */
.header-actions {
  display: flex; align-items: center; gap: 16px; flex-shrink: 0;
}
.header-search {
  display: flex; align-items: center;
  border: 1px solid var(--rule); border-radius: 999px;
  overflow: hidden; background: var(--white);
  height: 40px;
}
.header-search input {
  border: none; outline: none; padding: 0 14px;
  font-size: .85rem; font-family: var(--font-body);
  color: var(--ink); background: transparent;
  width: 160px; transition: width .25s;
}
.header-search input:focus { width: 220px; }
.header-search input::placeholder { color: var(--light); }
.header-search button {
  border: none; background: var(--saffron); color: #fff;
  width: 40px; height: 40px; display: flex;
  align-items: center; justify-content: center;
  cursor: pointer; transition: background .2s;
}
.header-search button:hover { background: var(--saffron-dark); }

.nav-auth { display: flex; align-items: center; gap: 12px; }
.nav-auth-link {
  font-size: .78rem; font-weight: 500;
  letter-spacing: .06em; color: var(--muted);
  transition: color .18s; white-space: nowrap;
  max-width: 140px; overflow: hidden; text-overflow: ellipsis;
}
.nav-auth-link:hover { color: var(--black); }
.nav-cta {
  display: inline-block; padding: 8px 18px;
  font-size: .72rem; font-weight: 600;
  letter-spacing: .1em; text-transform: uppercase;
  background: var(--saffron); color: var(--white);
  border-radius: 4px; transition: background .18s;
  white-space: nowrap;
}
.nav-cta:hover { background: var(--saffron-dark); }

/* ── Mobile toggle ────────────────────── */
.mobile-toggle {
  display: none; flex-direction: column; gap: 5px;
  background: none; border: none; cursor: pointer; padding: 6px;
}

/* ── Mobile search icon (hidden on desktop) ── */
.header-search-mobile {
  display: none; align-items: center; justify-content: center;
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--saffron-pale); color: var(--saffron);
  font-size: 1rem; transition: background .2s, color .2s;
}
.header-search-mobile:hover { background: var(--saffron); color: #fff; }

/* ── Dashboard link emphasis ─────────── */
.nav-dashboard-link {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--saffron-pale); padding: 6px 14px;
  border-radius: 999px; color: var(--saffron) !important;
  font-weight: 600 !important; transition: background .18s;
}
.nav-dashboard-link:hover { background: var(--saffron); color: #fff !important; }

/* ── Profile completion banner ───────── */
.profile-complete-banner {
  background: var(--saffron-pale); border-bottom: 1px solid rgba(232,117,26,.2);
  padding: 10px 0; font-size: .88rem; color: var(--saffron-dark);
}
.profile-complete-banner i { margin-right: 6px; }
.mobile-toggle span {
  display: block; width: 22px; height: 2px;
  background: var(--black); transition: .3s;
}
.mobile-toggle.active span:nth-child(1) { transform: rotate(45deg) translate(5px, 5px); }
.mobile-toggle.active span:nth-child(2) { opacity: 0; }
.mobile-toggle.active span:nth-child(3) { transform: rotate(-45deg) translate(5px, -5px); }

/* ══════════════════════════════════════════════
   HERO — home page
   ══════════════════════════════════════════════ */

/* ── Dark centered hero (inner pages — kundali, matchmaking, etc.) ────────── */
.mm-hero {
  background: var(--black);
  color: #fff;
  padding: 4rem 1.5rem 5.5rem;
  text-align: center;
}
.mm-heading {
  font-family: var(--font-heading);
  font-size: clamp(2.5rem, 6vw, 4rem);
  font-weight: 600;
  margin: .5rem 0 1rem;
  line-height: 1.1;
  color: #fff;
}
.mm-heading em { color: var(--saffron); font-style: italic; }
.mm-sub {
  max-width: 520px;
  margin: 0 auto;
  opacity: .75;
  font-size: 1rem;
  line-height: 1.7;
}

/* ── Compact page hero (inner pages) ──────────── */
.page-hero {
  background: radial-gradient(circle at 15% 60%, rgba(232,117,26,.08), transparent 40%),
              linear-gradient(180deg, #FEF9F3 0%, #F5F1EA 100%);
  border-bottom: 1px solid var(--rule);
  padding: clamp(2.5rem, 5vw, 3.5rem) clamp(1.5rem, 5vw, 5rem);
}
.page-hero-content { max-width: 680px; }
.page-hero-content h1 { margin: .35rem 0 .75rem; }
.page-hero-content h1 em { display: block; font-style: italic; color: var(--saffron); }
.page-hero-summary {
  font-size: 1rem; line-height: 1.7; color: var(--muted);
  max-width: 52ch; margin: 0;
}

.hero {
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  min-height: 92vh;
  background: radial-gradient(circle at 20% 30%, rgba(232,117,26,.1), transparent 32%),
              linear-gradient(180deg, #FEF9F3 0%, #F5F1EA 100%);
  overflow: hidden;
}
.hero-content {
  display: flex; flex-direction: column; justify-content: center;
  padding: clamp(60px, 6vw, 100px) clamp(32px, 5vw, 80px);
  max-width: 720px;
}
.hero-content h1 { margin: 0 0 20px; max-width: 14ch; }
.hero-content h1 em { display: block; font-style: italic; color: var(--saffron); }

.hero-summary {
  font-size: 1rem; line-height: 1.7; color: var(--muted);
  max-width: 40ch; margin-bottom: 32px;
}
.hero-actions { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 24px; }

.hero-stamps { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 36px; }
.hero-stamp {
  display: inline-flex; align-items: center; justify-content: center;
  padding: .6rem 1rem; border-radius: 999px;
  background: rgba(232,117,26,.1); color: var(--saffron);
  font-size: .72rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .12em;
}

.hero-stats {
  display: flex; gap: 32px; padding-top: 28px;
  border-top: 1px solid var(--rule);
}
.hero-stats div { display: flex; flex-direction: column; gap: 4px; }
.hero-stats strong {
  font-family: var(--font-heading);
  font-size: 2rem; font-weight: 500; color: var(--black); line-height: 1;
}
.hero-stats span {
  font-size: .7rem; letter-spacing: .1em;
  text-transform: uppercase; color: var(--light);
}

/* hero image panel */
.hero-image-panel {
  position: relative; overflow: hidden;
  background: linear-gradient(160deg, #2A1A0E 0%, #4A2C10 40%, #1A1200 100%);
}
.hero-image-panel::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(circle at 50% 40%, rgba(232,117,26,.3) 0%, transparent 55%),
              radial-gradient(circle at 30% 70%, rgba(244,164,74,.12) 0%, transparent 40%);
}
.hero-image-panel::after {
  content: "✦ ASTRO INTELLIGENCE ✦";
  position: absolute; bottom: 40px; right: 40px;
  font-size: .6rem; letter-spacing: .3em; text-transform: uppercase;
  color: rgba(255,255,255,.35); writing-mode: vertical-rl; transform: rotate(180deg);
}
.hero-glyph {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  font-size: clamp(8rem, 18vw, 16rem);
  line-height: 1; opacity: .16;
  color: var(--saffron-light); user-select: none;
}

/* ══════════════════════════════════════════════
   SERVICE / PRODUCT PAGE
   ══════════════════════════════════════════════ */

/* ── Service Hero ──────────────────────── */
.service-hero,
.services-index-hero {
  position: relative;
  min-height: 520px; display: flex; align-items: center;
  background: var(--charcoal) center / cover no-repeat;
  overflow: hidden;
}
.service-hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(10,10,10,.45), rgba(10,10,10,.72));
}
.service-hero .container,
.services-index-hero .container { position: relative; z-index: 2; }

.service-hero-content {
  max-width: 720px;
  padding: clamp(48px, 5vw, 80px) 0;
  color: var(--white);
}
.hero-badge {
  display: inline-block;
  padding: 6px 16px; border-radius: 999px;
  background: rgba(232,117,26,.2); color: var(--saffron-light);
  font-size: .7rem; font-weight: 700;
  letter-spacing: .15em; text-transform: uppercase;
  margin-bottom: 20px;
}
.service-hero-content h1 { color: #fff; margin-bottom: 16px; }
.hero-tagline { font-size: 1.1rem; color: rgba(255,255,255,.82); max-width: 50ch; margin-bottom: 24px; }
.hero-price {
  font-family: var(--font-heading);
  font-size: 2.2rem; font-weight: 500; color: var(--saffron-light);
  margin-bottom: 28px;
}
.hero-cta-row { display: flex; gap: 14px; flex-wrap: wrap; }

/* ── Service About grid ────────────────── */
.service-about-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: clamp(32px, 4vw, 64px);
  align-items: start;
}
.service-about-main .eyebrow { margin-bottom: 10px; }
.service-about-main h2 { margin-bottom: 20px; }
.service-about-main .lead { margin-bottom: 24px; }
.rich-text { font-size: .95rem; line-height: 1.8; color: var(--ink); }
.rich-text p { color: var(--ink); margin-bottom: 1rem; }
.rich-text h3 { margin: 2rem 0 .75rem; }
.rich-text ul, .rich-text ol { margin: 1rem 0; padding-left: 1.5rem; }
.rich-text li { margin-bottom: .5rem; color: var(--ink); }

/* ── Sidebar card ──────────────────────── */
.service-sidebar { position: sticky; top: 96px; }
.service-card {
  background: var(--white);
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  padding: 2rem;
  box-shadow: var(--shadow-md);
}
.service-card-price {
  font-family: var(--font-heading);
  font-size: 2.4rem; font-weight: 500;
  color: var(--saffron); margin-bottom: 16px;
}
.service-card-meta {
  list-style: none; padding: 0;
  display: grid; gap: 10px; margin-bottom: 24px;
}
.service-card-meta li {
  display: flex; justify-content: space-between;
  font-size: .9rem; padding-bottom: 10px;
  border-bottom: 1px solid var(--rule); color: var(--ink);
}
.service-card-meta li strong { color: var(--muted); font-weight: 600; font-size: .8rem; text-transform: uppercase; letter-spacing: .06em; }

/* ── Features grid ─────────────────────── */
.service-features { background: var(--saffron-pale); }
.features-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 24px;
}
.feature-item {
  background: var(--white); border-radius: var(--radius-lg);
  padding: 2rem; box-shadow: var(--shadow-sm);
  transition: transform .2s, box-shadow .2s;
}
.feature-item:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.feature-icon {
  width: 52px; height: 52px; border-radius: 50%;
  background: var(--saffron-pale); color: var(--saffron);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.3rem; margin-bottom: 16px;
}
.feature-icon span {
  font-family: var(--font-heading);
  font-size: 1.5rem; font-weight: 600;
}
.feature-item h3 { margin-bottom: 10px; }
.feature-item p { font-size: .88rem; }

/* ── FAQ accordion ─────────────────────── */
.service-faq { background: var(--white); }
.faq-list { display: grid; gap: 0; }
.faq-item {
  border-bottom: 1px solid var(--rule);
}
.faq-question {
  display: flex; align-items: center; justify-content: space-between;
  padding: 22px 0; cursor: pointer;
  font-size: 1.05rem; font-weight: 600; color: var(--black);
  list-style: none;
}
.faq-question::-webkit-details-marker { display: none; }
.faq-question::after {
  content: "+"; font-size: 1.4rem; font-weight: 300;
  color: var(--saffron); transition: transform .2s;
}
.faq-item[open] .faq-question::after { content: "−"; }
.faq-answer { padding: 0 0 22px; }
.faq-answer p { font-size: .93rem; color: var(--ink); }

/* ── Testimonials grid ─────────────────── */
.testimonials-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 24px;
}
.testimonial-card {
  background: var(--white); border: 1px solid var(--rule);
  border-radius: var(--radius-lg); padding: 2rem;
  box-shadow: var(--shadow-sm); margin: 0;
}
.testimonial-card p {
  font-size: 1rem; font-style: italic;
  color: var(--ink); line-height: 1.7; margin-bottom: 16px;
}
.testimonial-card footer strong {
  display: block; font-size: .88rem; color: var(--black); font-style: normal;
}
.testimonial-card footer span {
  font-size: .78rem; color: var(--muted); font-style: normal;
}

/* ── Contact split ─────────────────────── */
.service-contact { background: var(--bg); }
.contact-split {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: clamp(32px, 4vw, 64px);
  align-items: start;
}
.contact-info-side h2 { margin: 10px 0 16px; }
.contact-info-side p { max-width: 42ch; margin-bottom: 24px; }
.contact-highlights {
  list-style: none; padding: 0;
  display: flex; flex-direction: column; gap: 10px;
}
.contact-highlights li { font-size: .9rem; color: var(--ink); }

.contact-form-side {
  background: var(--white);
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  padding: 2rem; box-shadow: var(--shadow-md);
}
.contact-form { display: grid; gap: 1rem; }
.field { display: flex; flex-direction: column; gap: .4rem; }
.field label {
  font-size: .88rem; font-weight: 600; color: var(--black);
}
.field input,
.field textarea,
.field select {
  width: 100%; min-height: 48px;
  padding: .85rem 1rem;
  font-family: var(--font-body); font-size: .93rem;
  color: var(--ink); border: 1px solid var(--rule);
  border-radius: var(--radius); background: var(--white);
  transition: border-color .18s, box-shadow .18s;
}
.field textarea { min-height: 120px; resize: vertical; }
.field input:focus,
.field textarea:focus,
.field select:focus {
  outline: none; border-color: var(--saffron);
  box-shadow: 0 0 0 3px rgba(232,117,26,.12);
}
.field .errorlist { margin: 0; padding: 0; color: #B00020; font-size: .85rem; list-style: none; }

/* ── Services grid (index & related) ───── */
.services-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 24px;
}
.service-grid-card {
  display: flex; flex-direction: column;
  background: var(--white);
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: transform .22s, box-shadow .22s;
}
.service-grid-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); }
.service-grid-img {
  width: 100%; height: 220px; overflow: hidden;
  background: var(--saffron-pale);
}
.service-grid-img img { width: 100%; height: 100%; object-fit: cover; }
.service-grid-img-placeholder {
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, #2A1A0E, #4A2C10);
}
.service-grid-img-placeholder span {
  font-size: .75rem; font-weight: 700; letter-spacing: .2em;
  text-transform: uppercase; color: var(--saffron-light);
}
.service-grid-body { padding: 1.5rem; flex: 1; display: flex; flex-direction: column; }
.service-grid-type {
  font-size: .68rem; font-weight: 700;
  letter-spacing: .16em; text-transform: uppercase;
  color: var(--saffron); margin-bottom: 8px;
}
.service-grid-body h3 { margin-bottom: 8px; font-size: 1.25rem; }
.service-grid-body p { flex: 1; font-size: .88rem; margin-bottom: 12px; }
.service-grid-price {
  font-family: var(--font-heading);
  font-size: 1.4rem; font-weight: 500; color: var(--saffron);
}

/* ══════════════════════════════════════════════
   HOMEPAGE SECTIONS
   ══════════════════════════════════════════════ */

/* ── Feature cards grid ──────────────────── */
.card-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px; background: var(--rule); border: 1px solid var(--rule);
}
.feature-card {
  background: var(--white);
  padding: 32px 28px 36px;
  transition: background .2s;
}
.feature-card:hover { background: var(--saffron-pale); }
.feature-card > span {
  display: block; font-size: .68rem; font-weight: 700;
  letter-spacing: .22em; text-transform: uppercase;
  color: var(--saffron); margin-bottom: 18px;
}
.feature-card h3 { font-size: 1.45rem; margin-bottom: 12px; }
.feature-card p { font-size: .85rem; }
.feature-card-img {
  width: 100%; aspect-ratio: 4 / 5;
  background: var(--saffron-pale); margin-bottom: 18px;
  overflow: hidden; position: relative;
}
.feature-card-img::after {
  content: attr(data-label);
  position: absolute; top: 10px; left: 10px;
  background: var(--saffron); color: #fff;
  font-size: .6rem; font-weight: 700;
  letter-spacing: .14em; text-transform: uppercase;
  padding: 4px 10px;
}
.card-grid-footer { text-align: center; padding: 40px 0 0; }

/* ── Highlight strip ─────────────────────── */
.highlight-strip { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 28px; }
.highlight-strip span {
  padding: 6px 14px; font-size: .72rem; font-weight: 600;
  letter-spacing: .12em; text-transform: uppercase;
  border: 1px solid var(--rule); color: var(--muted);
  background: var(--white); transition: border-color .18s, color .18s;
}
.highlight-strip span:hover { border-color: var(--saffron); color: var(--saffron); }

/* ── Split section ───────────────────────── */
.split-section {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 6vw, 90px); align-items: center;
}
.split-image-placeholder {
  width: 100%; aspect-ratio: 4/5; position: relative;
  background: linear-gradient(160deg, #2A1A0E 0%, #5A3218 60%, #2E1A08 100%);
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.split-image-placeholder::before {
  content: ""; inset: 0; position: absolute;
  background: radial-gradient(circle at 50% 50%, rgba(232,117,26,.25) 0%, transparent 60%);
}
.split-image-glyph {
  font-size: 6rem; opacity: .22; color: var(--saffron-light);
  position: relative; z-index: 1;
}
.split-image-badge {
  position: absolute; bottom: 28px; right: -16px;
  background: var(--white); border: 1px solid var(--rule);
  padding: 14px 18px; text-align: center; min-width: 90px;
}
.split-image-badge strong {
  display: block; font-family: var(--font-heading);
  font-size: 2rem; font-weight: 500; color: var(--saffron); line-height: 1;
}
.split-image-badge span {
  font-size: .65rem; letter-spacing: .14em;
  text-transform: uppercase; color: var(--muted);
}
.split-copy { padding: 20px 0; }
.split-copy h2 { margin: 8px 0 20px; }
.split-copy p { max-width: 44ch; margin-bottom: 16px; }
.split-features {
  display: flex; gap: 32px; margin: 28px 0 32px;
  padding-top: 28px; border-top: 1px solid var(--rule);
}
.split-feature-item { display: flex; flex-direction: column; gap: 6px; }
.split-feature-icon { font-size: 1.25rem; color: var(--saffron); }
.split-feature-item strong { font-size: .78rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--black); }
.split-feature-item span { font-size: .72rem; color: var(--light); }

.bullet-list {
  list-style: none; padding: 0;
  display: flex; flex-direction: column; gap: 10px; margin-bottom: 28px;
}

/* ── Page layout utilities ───────────────────────────── */
.section-heading {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 32px;
}
.section-heading .eyebrow {
  font-size: .75rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--saffron);
}
.section-heading h2 {
  font-family: var(--font-heading);
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1.05;
  margin: 0;
}

.page-card {
  background: var(--white);
  border-radius: 24px;
  box-shadow: 0 20px 50px rgba(0,0,0,.08);
  padding: 2.5rem;
  margin: 0 auto;
  max-width: 740px;
}

.page-form .form-field,
.k-field {
  display: flex;
  flex-direction: column;
  gap: .5rem;
  margin-bottom: 1.25rem;
}

.page-form label,
.k-field label {
  font-size: .82rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--black);
}

.page-form input,
.page-form select,
.page-form textarea,
.k-field input,
.k-field select,
.k-field textarea {
  width: 100%;
  padding: .9rem 1rem;
  border: 1.5px solid var(--rule);
  border-radius: 12px;
  font-family: var(--font-body);
  font-size: .95rem;
  color: var(--ink);
  background: #fafafa;
  outline: none;
  transition: border-color .2s, background .2s;
}

.page-form input:focus,
.page-form select:focus,
.page-form textarea:focus,
.k-field input:focus,
.k-field select:focus,
.k-field textarea:focus {
  border-color: var(--saffron);
  background: #fff;
}

.page-form .field-errors,
.page-form .k-error,
.k-field .k-error {
  color: #dc2626;
  font-size: .85rem;
}

.page-form .form-actions {
  display: flex;
  justify-content: flex-start;
  gap: 1rem;
  flex-wrap: wrap;
  margin-top: 1.5rem;
}

.page-form .button-primary,
.page-form .button-secondary {
  min-width: 180px;
}

.k-alert {
  margin: 1.5rem auto;
  max-width: 740px;
  border-radius: 16px;
  padding: 1rem 1.25rem;
}
.k-alert-info { background: #eff6ff; border: 1px solid #bfdbfe; color: #1d4ed8; }
.k-alert-warning { background: #fffbeb; border: 1px solid #fde68a; color: #92400e; }
.k-alert-success { background: #f0fdf4; border: 1px solid #bbf7d0; color: #166534; }
.k-alert-error { background: #fef2f2; border: 1px solid #fecaca; color: #991b1b; }

/* ── Prose content (terms, privacy, etc.) ── */
.prose-content { font-size: 1rem; color: var(--ink); line-height: 1.8; }
.prose-content section { margin-bottom: 2.5rem; }
.prose-content h2 { font-family: var(--font-heading); font-size: 1.5rem; font-weight: 600; color: var(--black); margin: 0 0 .75rem; }
.prose-content p { margin: 0 0 .85rem; }
.prose-content ul, .prose-content ol { padding-left: 1.5rem; margin-bottom: .85rem; }
.prose-content li { margin-bottom: .35rem; }
.k-divider { border-top: 1px solid var(--rule); margin: 2rem 0; }
.k-city-wrap { position: relative; }
.k-suggestions { position: absolute; top: 100%; left: 0; right: 0; background: #fff; border: 1.5px solid var(--rule); border-radius: 12px; box-shadow: 0 8px 24px rgba(0,0,0,.1); z-index: 100; display: none; max-height: 220px; overflow-y: auto; }
.k-sug-item { padding: .6rem .85rem; font-size: .95rem; cursor: pointer; color: var(--ink); border-bottom: 1px solid #f0f0ee; }
.k-sug-item:last-child { border-bottom: none; }
.k-sug-item:hover { background: var(--saffron-pale); }

@media(max-width:900px){
  .split-section { grid-template-columns: 1fr; }
}
.bullet-list li {
  display: flex; align-items: flex-start; gap: 12px;
  font-size: .88rem; color: var(--muted); line-height: 1.6;
}
.bullet-list li::before { content: "—"; color: var(--saffron); flex-shrink: 0; font-weight: 700; }

/* ── Collections ─────────────────────────── */
.collection-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px;
}
.collection-card {
  position: relative; overflow: hidden; aspect-ratio: 3/4; cursor: pointer; border-radius: var(--radius);
}
.collection-card-bg {
  position: absolute; inset: 0; transition: transform .5s;
}
.collection-card:hover .collection-card-bg { transform: scale(1.04); }
.collection-card-light .collection-card-bg { background: linear-gradient(180deg, #3D1F08, #7A3C10 40%, #3D1F08); }
.collection-card-dark .collection-card-bg  { background: linear-gradient(180deg, #0F0F0F, #2A1A0E 50%, #0F0F0F); }
.collection-card-mid .collection-card-bg   { background: linear-gradient(180deg, #1E1510, #4A3020 50%, #1E1510); }
.collection-card::before {
  content: ""; position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(0deg, rgba(0,0,0,.7) 0%, rgba(0,0,0,.1) 60%, transparent);
}
.collection-card::after {
  content: ""; position: absolute; inset: 0; z-index: 1;
  background: radial-gradient(circle at 50% 30%, rgba(232,117,26,.2) 0%, transparent 60%);
}
.collection-card-body {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 28px 24px; z-index: 2;
}
.collection-card-body > span {
  display: block; font-size: .65rem; font-weight: 700;
  letter-spacing: .28em; text-transform: uppercase;
  color: var(--saffron-light); margin-bottom: 8px;
}
.collection-card-body > strong {
  display: block; font-family: var(--font-heading);
  font-size: 1.55rem; font-weight: 500; color: var(--white); line-height: 1.15;
}

/* ── Report banner ───────────────────────── */
.report-banner {
  display: grid; grid-template-columns: 1fr auto;
  align-items: center; gap: 32px; padding: 40px 44px;
  background: var(--saffron-pale);
  border: 1px solid rgba(232,117,26,.2);
  border-radius: var(--radius);
}
.report-banner h3 {
  font-size: clamp(1.3rem, 2.5vw, 1.8rem); font-weight: 500;
  color: var(--black); margin-bottom: 8px;
}

/* ── Membership (dark) section ───────────── */
.membership-section {
  display: grid; grid-template-columns: 1fr 1fr;
  min-height: 520px; background: var(--charcoal);
}
.membership-content {
  display: flex; flex-direction: column; justify-content: center;
  padding: clamp(40px, 7vw, 80px);
}
.membership-content .eyebrow { color: var(--saffron-light); }
.membership-content h2 { color: var(--white); margin: 12px 0 20px; }
.membership-content h2 em { color: var(--saffron); }
.membership-content p { color: rgba(255,255,255,.55); max-width: 40ch; margin-bottom: 28px; }
.membership-list {
  list-style: none; padding: 0;
  display: flex; flex-direction: column; gap: 10px; margin-bottom: 36px;
}
.membership-list li {
  display: flex; align-items: center; gap: 10px;
  font-size: .88rem; color: rgba(255,255,255,.7);
}
.membership-list li::before { content: "✓"; color: var(--saffron); font-weight: 700; flex-shrink: 0; }
.membership-image {
  position: relative; overflow: hidden;
  background: linear-gradient(160deg, #1A0E05, #3D1F08 60%, #1A0E05);
}
.membership-image::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(circle at 50% 40%, rgba(232,117,26,.3) 0%, transparent 60%);
}
.membership-image-glyph {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  font-size: clamp(6rem, 14vw, 12rem); opacity: .15; color: var(--saffron-light); user-select: none;
}
.membership-badge {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2);
  backdrop-filter: blur(8px); padding: 20px 28px; text-align: center; min-width: 130px;
}
.membership-badge span {
  display: block; font-size: .65rem; font-weight: 700;
  letter-spacing: .22em; text-transform: uppercase;
  color: var(--saffron-light); margin-bottom: 8px;
}
.membership-badge strong {
  font-family: var(--font-heading);
  font-size: 1.4rem; font-weight: 500; color: var(--white);
}

/* ── Subscribe section ───────────────────── */
.subscribe-section { padding: clamp(56px, 8vw, 88px) 0; text-align: center; }
.subscribe-section h2 { margin-bottom: 12px; }
.subscribe-section p { max-width: 44ch; margin: 0 auto 28px; }
.subscribe-form {
  display: flex; max-width: 480px; margin: 0 auto; border: 1px solid var(--rule);
  border-radius: var(--radius); overflow: hidden;
}
.subscribe-form input {
  flex: 1; padding: 14px 20px; font-size: .88rem;
  font-family: var(--font-body); border: none; outline: none;
  background: var(--white); color: var(--ink);
}
.subscribe-form input::placeholder { color: var(--light); }
.subscribe-form button {
  padding: 14px 24px; background: var(--black); color: var(--white);
  font-size: .72rem; font-weight: 700; letter-spacing: .14em;
  text-transform: uppercase; border: none; cursor: pointer;
  font-family: var(--font-body); transition: background .18s; white-space: nowrap;
}
.subscribe-form button:hover { background: var(--saffron); }

/* ── Subcard grid (tags) ─────────────────── */
.subcard-grid {
  display: flex; gap: 10px; flex-wrap: wrap;
  padding-top: 28px; border-top: 1px solid var(--rule); margin-top: 28px;
}
.subcard {
  padding: 8px 16px; font-size: .72rem; font-weight: 600;
  letter-spacing: .12em; text-transform: uppercase;
  border: 1px solid var(--rule); color: var(--muted);
  background: var(--white); transition: .18s; cursor: pointer;
  border-radius: 4px;
}
.subcard:hover { border-color: var(--saffron); color: var(--saffron); background: var(--saffron-pale); }

/* ══════════════════════════════════════════════
   SHOP / PRODUCT PAGES (inline styles override)
   ══════════════════════════════════════════════ */
.product-detail-page { background: var(--bg); min-height: 100vh; }
.product-detail-hero {
  position: relative; min-height: 400px;
  display: flex; align-items: center;
  background: var(--charcoal) center / cover no-repeat;
}
.product-detail-hero::before {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(10,10,10,.35), rgba(10,10,10,.68));
}
.page-hero {
  position: relative;
  min-height: 520px;
  display: flex;
  align-items: center;
  background: var(--charcoal) center / cover no-repeat;
  overflow: hidden;
}
.page-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(10,10,10,.35), rgba(10,10,10,.72));
}
.page-hero-inner,
.product-hero-inner {
  position: relative; z-index: 1;
  max-width: 760px; padding: clamp(40px, 4vw, 72px) clamp(20px, 3vw, 48px);
  color: var(--white);
}
.page-hero-inner h1,
.product-hero-inner h1 {
  font-size: clamp(2.6rem, 5vw, 4.5rem); line-height: 1.04; margin-bottom: 12px;
}
.product-hero-inner .section-label,
.page-hero-inner .eyebrow {
  color: rgba(255,255,255,.82); letter-spacing: .2em;
  text-transform: uppercase; font-size: .78rem; margin-bottom: 12px;
}
.page-hero-inner p,
.product-hero-inner p { max-width: 46ch; color: rgba(255,255,255,.9); }

/* ── Product detail grid ─────────────────── */
.product-detail-grid {
  display: grid; grid-template-columns: 1.6fr 1fr; gap: 1.5rem;
}
.product-detail-main {
  background: var(--white); border-radius: var(--radius-lg);
  overflow: hidden; box-shadow: var(--shadow-md);
}
.detail-image { width: 100%; height: 420px; object-fit: cover; }
.product-gallery { display: grid; gap: 1rem; }
.product-body { padding: 1.75rem; }
.product-body h2 { margin-top: 0; }
.product-specs {
  display: grid; grid-template-columns: 120px 1fr;
  gap: .85rem; font-size: .95rem; color: var(--muted);
}
.product-specs dt { font-weight: 700; color: var(--black); }
.product-detail-sidebar { display: flex; flex-direction: column; gap: 1rem; }

.product-card {
  background: var(--white); border: 1px solid var(--rule);
  border-radius: var(--radius-lg); padding: 1.5rem;
  box-shadow: var(--shadow-md); position: sticky; top: 96px;
}
.product-price-large {
  font-family: var(--font-heading);
  font-size: 2.4rem; font-weight: 500; color: var(--saffron);
}
.product-stock { font-size: .88rem; color: green; margin-bottom: 16px; }
.product-qty {
  width: 100%; padding: .7rem; border: 1px solid var(--rule);
  border-radius: var(--radius); font-size: .95rem; margin-bottom: .5rem;
}
.product-login-prompt { text-align: center; }
.product-login-prompt p { margin-bottom: 16px; }
.product-login-prompt .button { margin-bottom: 8px; }

/* ══════════════════════════════════════════════
   CONTACT PAGE
   ══════════════════════════════════════════════ */
.contact-page { padding: 3.5rem 0 5rem; background: var(--bg); }
.contact-grid {
  display: grid; grid-template-columns: minmax(240px, 1fr) minmax(340px, 1.25fr);
  gap: 2rem; align-items: start;
}
.contact-panel,
.contact-card {
  background: var(--white); border: 1px solid var(--rule);
  border-radius: var(--radius-lg); padding: 2rem; box-shadow: var(--shadow-md);
}
.contact-panel h1 { margin: 0; font-size: clamp(2.1rem, 4vw, 3.2rem); line-height: 1.05; }
.contact-panel-meta { display: grid; gap: 1rem; margin-top: 1.5rem; }
.contact-panel-meta strong {
  display: block; margin-bottom: .4rem; font-size: .78rem;
  letter-spacing: .18em; text-transform: uppercase; color: var(--saffron);
}
.contact-panel-meta a { border-bottom: 1px dotted var(--saffron); }
.contact-card-header h2 { margin: 0 0 .75rem; font-size: clamp(1.85rem, 3vw, 2.3rem); }

/* ══════════════════════════════════════════════
   FOOTER
   ══════════════════════════════════════════════ */
.site-footer {
  padding: clamp(48px, 6vw, 80px) 0 32px;
  border-top: 1px solid var(--rule); background: var(--bg);
}
.footer-grid {
  display: grid; grid-template-columns: 1.6fr 1fr 1fr;
  gap: 48px; margin-bottom: 48px;
}
.footer-brand {
  font-family: var(--font-body); font-size: .82rem;
  font-weight: 700; letter-spacing: .22em; text-transform: uppercase;
  color: var(--black); margin-bottom: 14px;
}
.footer-brand span { color: var(--saffron); }
.site-footer p { font-size: .85rem; color: var(--muted); max-width: 30ch; line-height: 1.65; }
.footer-links-col h4 {
  font-family: var(--font-body); font-size: .68rem; font-weight: 700;
  letter-spacing: .2em; text-transform: uppercase; color: var(--black); margin-bottom: 16px;
}
.footer-links-col a { display: block; font-size: .88rem; color: var(--muted); margin-bottom: 10px; transition: color .15s; }
.footer-links-col a:hover { color: var(--saffron); }
.footer-base {
  padding-top: 24px; border-top: 1px solid var(--rule);
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
}
.footer-base p { font-size: .75rem; color: var(--light); margin: 0; }
.footer-base a { color: var(--muted); }
.footer-base a:hover { color: var(--saffron); }

/* ── Footer currency switcher ────────── */
.footer-currency {
  display: flex; align-items: center; gap: 6px;
}
.footer-currency label { color: var(--muted); font-size: .88rem; }
.footer-currency select {
  padding: 4px 8px; border: 1px solid var(--rule); border-radius: 6px;
  font-family: var(--font-body); font-size: .8rem; color: var(--ink);
  background: var(--white); cursor: pointer;
}

/* ══════════════════════════════════════════════
   SHOP PAGE (overrides for product_list.html)
   ══════════════════════════════════════════════ */

/* ── Search results cards ────────────── */
.search-cards { display: grid; gap: 12px; }
.search-card {
  display: flex; align-items: center; gap: 16px;
  background: var(--white); border: 1px solid var(--rule);
  border-radius: var(--radius); padding: 16px 20px;
  transition: border-color .18s, box-shadow .18s;
  text-decoration: none; color: inherit;
}
.search-card:hover { border-color: var(--saffron); box-shadow: var(--shadow-sm); }
.search-card-icon {
  width: 48px; height: 48px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%; background: var(--saffron-pale); color: var(--saffron);
  font-size: 1.1rem;
}
.search-card-body { flex: 1; min-width: 0; }
.search-card-body h3 { font-size: 1.1rem; margin-bottom: 4px; }
.search-card-body p { font-size: .85rem; color: var(--muted); margin: 0; }
.search-card-arrow { color: var(--light); transition: color .18s; }
.search-card:hover .search-card-arrow { color: var(--saffron); }

.search-product-card {
  display: flex; flex-direction: column;
  background: var(--white); border: 1px solid var(--rule);
  border-radius: var(--radius-lg); overflow: hidden;
  transition: transform .22s, box-shadow .22s;
  text-decoration: none; color: inherit;
}
.search-product-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.search-product-img { width: 100%; height: 180px; overflow: hidden; background: var(--saffron-pale); }
.search-product-img img { width: 100%; height: 100%; object-fit: cover; }
.search-product-placeholder {
  display: flex; align-items: center; justify-content: center;
  width: 100%; height: 100%;
  background: linear-gradient(135deg, #2A1A0E, #4A2C10);
  color: var(--saffron-light); font-size: 2.5rem;
}
.search-product-body { padding: 1.25rem; flex: 1; display: flex; flex-direction: column; }
.search-product-type {
  font-size: .68rem; font-weight: 700;
  letter-spacing: .16em; text-transform: uppercase;
  color: var(--saffron); margin-bottom: 6px;
}
.search-product-body h3 { font-size: 1.12rem; margin-bottom: 6px; }
.search-product-body p { font-size: .85rem; color: var(--muted); flex: 1; margin: 0 0 10px; }
.search-product-price {
  font-family: var(--font-heading);
  font-size: 1.3rem; font-weight: 500; color: var(--saffron);
}

.shop-page { background: var(--bg); min-height: 100vh; }
.shop-hero {
  position: relative; background: var(--charcoal); color: #fff;
  padding: 3.5rem 1.5rem; text-align: center;
}
.shop-hero h1 { font-family: var(--font-heading); font-size: clamp(2.2rem, 4.5vw, 3rem); font-weight: 700; font-style: normal; margin: .75rem 0; letter-spacing: -.02em; }
.product-toolbar { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; margin-bottom: 1.5rem; }
.product-filters { display: flex; flex-wrap: wrap; gap: .6rem; }
.filter-pill {
  padding: .55rem 1rem; border-radius: 999px;
  border: 1px solid var(--rule); color: var(--ink);
  font-size: .88rem; transition: .18s;
}
.filter-pill:hover { border-color: var(--saffron); color: var(--saffron); }
.filter-pill.active { background: var(--charcoal); color: #fff; border-color: var(--charcoal); }
.product-grid {
  display: grid; grid-template-columns: repeat(3, minmax(240px, 1fr)); gap: 24px;
}

/* ══════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════ */
@media (max-width: 1100px) {
  .header-search input { width: 130px; }
  .header-search input:focus { width: 170px; }
}

@media (max-width: 960px) {
  .mobile-toggle { display: flex; }
  .site-nav {
    position: fixed; top: 64px; left: 0; right: 0;
    background: var(--white); border-bottom: 1px solid var(--rule);
    box-shadow: var(--shadow-md);
    max-height: 0; overflow: hidden;
    transition: max-height .35s ease;
    z-index: 199;
  }
  .site-nav.open { max-height: 80vh; overflow-y: auto; }
  .nav-list {
    flex-direction: column; align-items: stretch;
    padding: 16px 0; gap: 0;
  }
  .nav-item > a {
    padding: 14px clamp(20px, 4vw, 40px); font-size: .85rem;
    border-bottom: 1px solid var(--rule);
  }
  .has-dropdown .dropdown-menu {
    position: static; opacity: 1; visibility: visible;
    transform: none; box-shadow: none; border: none;
    border-radius: 0; padding: 0; min-width: auto;
    background: var(--saffron-pale);
  }
  .dropdown-menu li a { padding: 12px clamp(32px, 6vw, 56px); }
  .header-actions { gap: 10px; }
  .header-search { display: none; }
  .header-search-mobile { display: flex; }

  .hero { grid-template-columns: 1fr; min-height: auto; }
  .hero-image-panel { display: none; }
  .service-about-grid { grid-template-columns: 1fr; }
  .contact-split { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; }
  .split-section { grid-template-columns: 1fr; }
  .split-image-placeholder { display: none; }
  .membership-section { grid-template-columns: 1fr; }
  .membership-image { display: none; }
  .product-detail-grid { grid-template-columns: 1fr; }
  .product-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
  .card-grid { grid-template-columns: repeat(2, 1fr); }
  .collection-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; gap: 32px; }
  .features-grid { grid-template-columns: 1fr; }
  .testimonials-grid { grid-template-columns: 1fr; }
  .services-grid { grid-template-columns: 1fr; }
  .report-banner { grid-template-columns: 1fr; text-align: center; }
}

@media (max-width: 560px) {
  .card-grid { grid-template-columns: 1fr; }
  .product-grid { grid-template-columns: 1fr; }
  .hero-stats { gap: 20px; flex-wrap: wrap; }
  .footer-base { flex-direction: column; text-align: center; }
  .nav-auth { gap: 8px; }
  .nav-auth-link { max-width: 100px; }
}

/* ===== DASHBOARD ===== */
/* hide site footer on dashboard page */
.dashboard-page .site-footer{display:none;}
.dashboard-page main{padding:0;margin:0;}

.dash-wrap{display:flex;min-height:calc(100vh - 64px);background:#f8f9fa;margin:0;width:100%;box-sizing:border-box;font-family:var(--font-body);}
.dash-wrap.sidebar-open .dash-main{margin-left:240px;width:calc(100% - 240px);transition:margin-left .25s ease,width .25s ease;}
.dash-sidebar{width:240px;background:#2b2b2b;color:#ccc;display:flex;flex-direction:column;position:fixed;top:64px;left:-240px;bottom:0;overflow-y:auto;z-index:300;flex-shrink:0;font-family:var(--font-body);box-shadow:2px 0 8px rgba(0,0,0,.12);transition:left .25s ease;}
.dash-sidebar.open{left:0;}
.dash-sidebar-head{display:flex;align-items:center;gap:.7rem;padding:1.2rem 1rem .8rem;border-bottom:1px solid rgba(255,255,255,.08);}
.dash-avatar{width:38px;height:38px;border-radius:50%;background:#E8751A;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;color:#fff;text-transform:uppercase;flex-shrink:0;}
.dash-user-name{font-weight:600;font-size:.85rem;color:#eee;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px;}
.dash-user-email{font-size:.7rem;color:#888;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px;}
.dash-nav{flex:1;padding:.4rem 0;overflow-y:auto;}
.dash-nav-label{display:block;font-size:.6rem;text-transform:uppercase;color:#666;letter-spacing:.08rem;padding:.9rem 1rem .25rem;font-weight:700;}
.dash-nav-item{display:flex;align-items:center;gap:.6rem;padding:.45rem 1rem;color:#999;text-decoration:none;font-size:.82rem;font-weight:500;border-left:3px solid transparent;transition:all .15s;line-height:1.3;}
.dash-nav-item:hover{background:rgba(255,255,255,.05);color:#ddd;}
.dash-nav-item.active{background:rgba(232,117,26,.1);color:#E8751A;border-left-color:#E8751A;font-weight:600;}
.dash-nav-item i{width:16px;text-align:center;font-size:.8rem;color:#777;}
.dash-nav-item.active i{color:#E8751A;}
.dash-nav-item:hover i{color:#bbb;}
.dash-sidebar-foot{padding:.8rem 1rem;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:.4rem;}
.dash-currency-pill{display:inline-flex;align-items:center;gap:.4rem;background:rgba(255,255,255,.08);color:#aaa;padding:.25rem .7rem;border-radius:20px;font-size:.72rem;width:fit-content;}
.dash-main{flex:1;padding:1.5rem 2rem 2rem;overflow-y:auto;min-width:0;width:100%;font-family:var(--font-body);padding-top:3.5rem;transition:margin-left .25s ease,width .25s ease;}
.dash-menu-toggle{display:flex;align-items:center;justify-content:center;position:fixed;top:80px;left:12px;z-index:301;background:#2b2b2b;color:#fff;border:none;border-radius:8px;width:38px;height:38px;font-size:1rem;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.15);transition:left .25s ease;}
.dash-menu-toggle.sidebar-open{left:252px;}
/* backdrop overlay when sidebar is open */
.dash-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.3);z-index:250;}
.dash-overlay.active{display:block;}

/* stat cards */
.dash-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem;}
.dash-stat-card{background:#fff;border-radius:10px;padding:1rem;box-shadow:0 1px 3px rgba(0,0,0,.06);display:flex;align-items:center;gap:.8rem;}
.dash-stat-icon{font-size:1.4rem;width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:#f9fafb;flex-shrink:0;}
.dash-stat-label{font-size:.72rem;color:#888;text-transform:uppercase;letter-spacing:.04rem;}
.dash-stat-val{font-size:1.6rem;font-weight:700;color:#1A1A1A;line-height:1.2;}

/* active block */
.dash-active-block{display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,#fff5eb,#fef3c7);border:1px solid rgba(232,117,26,.2);border-radius:12px;padding:1rem 1.2rem;margin-bottom:1.5rem;gap:1rem;flex-wrap:wrap;}
.dash-active-left{display:flex;align-items:center;gap:.8rem;}
.dash-active-icon{width:44px;height:44px;border-radius:50%;background:#E8751A;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.2rem;flex-shrink:0;}
.dash-active-left span{display:block;font-size:.82rem;color:#666;margin-top:.1rem;}
.dash-active-actions{display:flex;gap:.5rem;flex-wrap:wrap;}

/* cards */
.dash-card{background:#fff;border-radius:12px;padding:1.2rem;box-shadow:0 1px 4px rgba(0,0,0,.06);margin-bottom:1rem;}
.dash-card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:.8rem;}
.dash-card-head h3{font-size:1rem;font-weight:600;display:flex;align-items:center;gap:.5rem;margin:0;font-family:var(--font-body);}
.dash-link{font-size:.82rem;color:#E8751A;text-decoration:none;font-weight:500;}
.dash-link:hover{text-decoration:underline;}

/* list items */
.dash-list-item{display:flex;justify-content:space-between;align-items:center;padding:.8rem 0;border-bottom:1px solid #f0f0f0;}
.dash-list-item:last-child{border-bottom:none;}
.dash-list-sub{font-size:.78rem;color:#888;margin-top:.15rem;}

/* badges */
.dash-badge{display:inline-block;font-size:.68rem;font-weight:600;text-transform:uppercase;padding:.15rem .5rem;border-radius:20px;margin-left:.4rem;}
.dash-badge-green{background:#d1fae5;color:#065f46;}
.dash-badge-yellow{background:#fef3c7;color:#92400e;}
.dash-badge-red{background:#fee2e2;color:#991b1b;}
.dash-badge-grey{background:#f3f4f6;color:#6b7280;}

/* buttons */
.btn-sm{display:inline-block;padding:.4rem 1rem;border-radius:8px;font-size:.82rem;font-weight:600;cursor:pointer;text-decoration:none;border:none;transition:all .2s;}
.btn-primary{background:#E8751A;color:#fff;}
.btn-primary:hover{background:#d35400;color:#fff;}
.btn-outline{background:transparent;border:1.5px solid #E8751A;color:#E8751A;}
.btn-outline:hover{background:#E8751A;color:#fff;}

/* two col */
.dash-two-col{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem;}

/* quick grid */
.dash-quick-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.6rem;}
.dash-quick-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.8rem .5rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;font-size:.78rem;color:#444;text-decoration:none;transition:all .2s;}
.dash-quick-btn i{font-size:1.1rem;color:#E8751A;margin-bottom:.3rem;}
.dash-quick-btn:hover{border-color:#E8751A;background:#fff5eb;color:#E8751A;}

/* chart grid */
.dash-chart-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;}
.chart-card-meta{display:grid;gap:.35rem;font-size:.82rem;color:#666;}
.chart-card-meta i{width:14px;color:#999;margin-right:.3rem;font-size:.75rem;}

/* empty states */
.dash-empty{font-size:.85rem;color:#888;padding:.5rem 0;}
.dash-empty a{color:#E8751A;font-weight:600;}
.dash-empty-state{text-align:center;padding:3rem 1rem;}
.dash-empty-state h3{margin:.8rem 0 .3rem;color:#1A1A1A;font-family:var(--font-body);}
.dash-empty-state p{color:#888;margin-bottom:1rem;font-size:.9rem;}

/* sections toggle */
.dash-section{display:none;}
.dash-section.active{display:block;}
.dash-section-title{font-family:var(--font-heading);font-size:1.6rem;font-weight:700;color:#1A1A1A;margin-bottom:1.2rem;}
.dash-wrap h3,.dash-wrap h4{font-family:var(--font-body);}
.dash-wrap .dash-section-title{font-family:var(--font-heading);}

/* rasi grid - South Indian style */
.rasi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;background:#e5e7eb;border-radius:8px;overflow:hidden;}
.rasi-cell{background:#fff;padding:.5rem;min-height:70px;display:flex;flex-direction:column;gap:.15rem;}
.rasi-center{background:#fafafa;}
.rasi-sign{font-size:.65rem;font-weight:700;color:#E8751A;text-transform:uppercase;}
.rasi-planet{font-size:.65rem;color:#444;white-space:nowrap;}

/* dasha timeline */
.dash-timeline{display:flex;flex-direction:column;gap:0;padding-left:1rem;border-left:3px solid #E8751A;}
.dash-timeline-item{display:flex;align-items:flex-start;gap:.7rem;padding:.6rem 0;position:relative;}
.dash-timeline-dot{width:10px;height:10px;border-radius:50%;background:#E8751A;flex-shrink:0;margin-top:5px;position:relative;left:-1.35rem;}
.dash-timeline-item strong{font-size:.9rem;}

/* divisional tabs */
.dash-div-tabs{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:1rem;}
.dash-div-tab{padding:.35rem .8rem;border-radius:20px;font-size:.78rem;border:1.5px solid #e5e7eb;background:#fff;cursor:pointer;font-weight:500;transition:all .2s;}
.dash-div-tab.active{background:#E8751A;color:#fff;border-color:#E8751A;}
.dash-div-table{overflow-x:auto;}
.dash-div-table table{width:100%;border-collapse:collapse;font-size:.82rem;}
.dash-div-table th{text-align:left;padding:.5rem;background:#f9fafb;font-weight:600;color:#444;border-bottom:2px solid #e5e7eb;}
.dash-div-table td{padding:.5rem;border-bottom:1px solid #f0f0f0;}

/* panchanga grid */
.dash-panch-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.8rem;}
.dash-panch-item{text-align:center;padding:.8rem;background:#f9fafb;border-radius:10px;}
.dash-panch-label{font-size:.7rem;text-transform:uppercase;color:#888;letter-spacing:.05rem;margin-bottom:.3rem;}
.dash-panch-val{font-weight:600;font-size:.95rem;color:#1A1A1A;}

/* responsive */
@media(max-width:900px){
  .dash-two-col{grid-template-columns:1fr;}
}
@media(max-width:768px){
  .dash-sidebar{top:64px;}
  .dash-main{padding:1rem;padding-top:3.5rem;}
  .dash-stats{grid-template-columns:1fr 1fr;}
  .dash-quick-grid{grid-template-columns:repeat(2,1fr);}
  .dash-menu-toggle{top:72px;left:8px;}
}
@media(max-width:480px){
  .dash-stats{grid-template-columns:1fr;}
  .dash-quick-grid{grid-template-columns:1fr 1fr;}
}

/* panchanga full table */
.panch-planet-table{width:100%;border-collapse:collapse;font-size:.82rem;font-family:var(--font-body);}
.panch-planet-table th{text-align:left;padding:.55rem .6rem;background:#f9fafb;font-weight:600;color:#444;border-bottom:2px solid #e5e7eb;white-space:nowrap;}
.panch-planet-table td{padding:.45rem .6rem;border-bottom:1px solid #f0f0f0;white-space:nowrap;}
.panch-planet-table tr:hover td{background:#fefce8;}
.panch-location-bar{display:flex;align-items:center;gap:.8rem;flex-wrap:wrap;margin-bottom:1rem;padding:.8rem 1rem;background:#fff;border-radius:10px;box-shadow:0 1px 3px rgba(0,0,0,.06);}
.panch-location-bar input{flex:1;min-width:200px;padding:.45rem .8rem;border:1.5px solid #e5e7eb;border-radius:8px;font-size:.85rem;font-family:var(--font-body);outline:none;transition:border-color .2s;}
.panch-location-bar input:focus{border-color:#E8751A;}
.panch-location-bar button{padding:.45rem 1rem;background:#E8751A;color:#fff;border:none;border-radius:8px;font-size:.82rem;font-weight:600;cursor:pointer;font-family:var(--font-body);}
.panch-location-bar button:hover{background:#d35400;}
.panch-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.8rem;margin-bottom:1.2rem;}
.panch-info-card{text-align:center;padding:.8rem;background:#f9fafb;border-radius:10px;border:1px solid #f0f0f0;}
.panch-info-card .pi-label{font-size:.68rem;text-transform:uppercase;color:#888;letter-spacing:.05rem;margin-bottom:.25rem;}
.panch-info-card .pi-value{font-weight:600;font-size:.95rem;color:#1A1A1A;}

/* print button */
.dash-print-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .9rem;background:#fff;border:1.5px solid #e5e7eb;border-radius:8px;font-size:.78rem;font-weight:500;color:#444;cursor:pointer;transition:all .2s;font-family:var(--font-body);}
.dash-print-btn:hover{border-color:#E8751A;color:#E8751A;}
@media print{
  .site-header,.dash-sidebar,.dash-menu-toggle,.wa-float,.dash-print-btn,.btn-sm,.dash-quick-grid,.dash-sidebar-foot{display:none!important;}
  .dash-main{margin-left:0!important;max-width:100%!important;padding:0!important;}
  .dash-section{display:block!important;}
  .dash-card{box-shadow:none!important;break-inside:avoid;}
  body{background:#fff!important;}
  .dash-wrap{background:#fff!important;}
}

/* ═══════════════════════════════════════════
   SECTION-LABEL (alias for .eyebrow, used in
   shop hero / checkout / orders / cart)
   ═══════════════════════════════════════════ */
.section-label {
  display: block;
  font-size: .7rem; font-weight: 600;
  letter-spacing: .26em; text-transform: uppercase;
  color: rgba(255,255,255,.82);
  margin-bottom: 10px;
}
/* inside non-dark contexts fall back to saffron */
.container > .section-label,
.contact-panel > .section-label { color: var(--saffron); }

/* ═══════════════════════════════════════════
   NEWS / ARTICLES
   ═══════════════════════════════════════════ */
.news-hero {
  padding: clamp(48px, 6vw, 80px) 0 clamp(32px, 4vw, 56px);
  background: radial-gradient(circle at 20% 40%, rgba(232,117,26,.07), transparent 38%),
              linear-gradient(180deg, #FEF9F3 0%, #F5F1EA 100%);
}
.article-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 24px;
  margin-top: 2rem;
}
.article-card {
  background: var(--white);
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  padding: 1.75rem;
  box-shadow: var(--shadow-sm);
  transition: transform .22s, box-shadow .22s;
  display: flex; flex-direction: column; gap: .75rem;
}
.article-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.article-card h2 {
  font-size: clamp(1.15rem, 2vw, 1.4rem);
  font-weight: 500; margin: 0;
}
.article-card h2 a { color: var(--black); transition: color .18s; }
.article-card h2 a:hover { color: var(--saffron); }
.article-card p { font-size: .9rem; flex: 1; margin: 0; }
.article-meta {
  display: flex; align-items: center; gap: 12px;
  flex-wrap: wrap;
  font-size: .78rem; color: var(--light);
  padding-top: .75rem; border-top: 1px solid var(--rule);
}
.article-meta span { display: inline-flex; align-items: center; gap: 4px; }
/* article detail page */
.article-body { font-size: .97rem; line-height: 1.82; color: var(--ink); margin: 2rem 0; }
.article-body p { margin-bottom: 1.25rem; color: var(--ink); }
.article-body h2, .article-body h3 { margin: 2rem 0 .75rem; }
.article-body ul, .article-body ol { margin: 1rem 0; padding-left: 1.5rem; }
.article-body li { margin-bottom: .5rem; }

/* ═══════════════════════════════════════════
   SHOP – reusable card (cart / orders)
   ═══════════════════════════════════════════ */
.shop-content { padding: 3rem 0 4rem; }
.shop-card {
  background: var(--white);
  border-radius: var(--radius-lg);
  padding: 1.75rem;
  box-shadow: var(--shadow-md);
}
.shop-card + .shop-card { margin-top: 1.5rem; }
.shop-card h2 { margin-top: 0; font-size: 1.25rem; }
.shop-two-col {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 1.5rem;
  align-items: start;
}
.shop-summary-sticky { position: sticky; top: 96px; }
.order-row {
  display: flex; justify-content: space-between;
  align-items: center; gap: 1rem; flex-wrap: wrap;
  padding: .75rem 0; border-bottom: 1px solid var(--rule);
}
.order-row:last-child { border-bottom: none; }
.order-row-left h3 { margin: .1rem 0; font-size: 1rem; }
.order-row-left p { margin: .3rem 0; color: var(--muted); font-size: .9rem; }
.order-total-line {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: .6rem 0; font-size: .95rem; border-bottom: 1px solid var(--rule);
}
.order-grand-total {
  font-size: 1.55rem; font-weight: 500; color: var(--saffron);
  font-family: var(--font-heading);
}
.cart-item-row {
  display: grid; grid-template-columns: 1fr auto;
  gap: 1rem; align-items: start;
  border: 1px solid var(--rule); border-radius: var(--radius);
  padding: 1rem;
}
.cart-item-info h3 { margin: 0 0 .4rem; font-size: 1rem; }
.cart-item-info p { margin: 0; color: var(--muted); font-size: .9rem; }
.cart-item-actions { display: flex; flex-direction: column; gap: .5rem; text-align: right; }
.cart-qty-input {
  width: 80px; padding: .5rem; border: 1px solid var(--rule);
  border-radius: var(--radius); font-family: var(--font-body); font-size: .9rem;
}
.qty-input:focus { outline: none; border-color: var(--saffron); }

/* payment option radio cards */
.payment-option {
  display: flex; align-items: center; gap: 12px;
  padding: 14px; border: 1.5px solid var(--rule);
  border-radius: var(--radius); cursor: pointer; transition: border-color .18s;
}
.payment-option:hover { border-color: var(--saffron); }
.payment-option input[type="radio"] { accent-color: var(--saffron); }
.payment-option-label strong { font-size: .9rem; display: block; }
.payment-option-label span { font-size: .78rem; color: var(--muted); }

/* coupon row */
.coupon-form {
  display: flex; gap: 0; border: 1.5px solid var(--rule);
  border-radius: var(--radius); overflow: hidden; margin-top: .75rem;
}
.coupon-form input {
  flex: 1; padding: 10px 14px; border: none; outline: none;
  font-family: var(--font-body); font-size: .9rem; color: var(--ink);
  background: #fafafa;
}
.coupon-form input:focus { background: var(--white); }
.coupon-form .button { border-radius: 0; border: none; padding: 10px 18px; font-size: .72rem; }

/* order history list */
.order-history-item {
  background: var(--white); border: 1px solid var(--rule);
  border-radius: var(--radius-lg); padding: 1.5rem;
  box-shadow: var(--shadow-sm); margin-bottom: 1rem;
}
.order-history-header {
  display: flex; justify-content: space-between; align-items: center;
  gap: 1rem; flex-wrap: wrap; margin-bottom: 1rem;
}
.order-history-header h2 { margin: 0; font-size: 1.15rem; }
.order-status-pill {
  padding: .4rem .9rem; border-radius: 999px;
  font-size: .82rem; font-weight: 500;
  background: var(--saffron-pale); color: var(--saffron-dark);
}
.order-items-grid { display: grid; gap: .65rem; }
.order-line-item {
  padding: .75rem 1rem; border: 1px solid var(--rule);
  border-radius: var(--radius); font-size: .9rem;
}

/* ═══════════════════════════════════════════
   PROFILE PAGE
   ═══════════════════════════════════════════ */
.profile-layout {
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: 2rem;
  align-items: start;
}
.profile-sidebar-card {
  background: var(--white);
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  padding: 1.75rem;
  box-shadow: var(--shadow-md);
  position: sticky; top: 88px;
}
.profile-avatar-wrap {
  display: flex; flex-direction: column;
  align-items: center; text-align: center;
  padding-bottom: 1.25rem; margin-bottom: 1.25rem;
  border-bottom: 1px solid var(--rule);
}
.profile-avatar-img {
  width: 100px; height: 100px; border-radius: 50%;
  border: 3px solid var(--saffron);
  object-fit: cover; margin-bottom: 1rem;
}
.profile-avatar-initials {
  width: 100px; height: 100px; border-radius: 50%;
  border: 3px solid var(--saffron);
  background: var(--saffron-pale); color: var(--saffron);
  display: flex; align-items: center; justify-content: center;
  font-size: 2.2rem; font-weight: 700;
  font-family: var(--font-heading);
  margin-bottom: 1rem;
}
.profile-fullname { font-size: 1.1rem; font-weight: 600; color: var(--black); margin: 0 0 .2rem; }
.profile-username { font-size: .82rem; color: var(--muted); margin: 0 0 .15rem; }
.profile-email { font-size: .82rem; color: var(--muted); margin: 0; }
.profile-status-list { display: flex; flex-direction: column; gap: .5rem; margin-bottom: 1.25rem; }
.profile-status-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: .6rem .75rem; background: var(--bg);
  border-radius: var(--radius); font-size: .85rem; color: var(--ink);
}
.profile-status-none { font-size: .78rem; color: var(--light); }
.profile-sidebar-nav { display: flex; flex-direction: column; gap: .5rem; }
.profile-main { display: flex; flex-direction: column; gap: 1.5rem; }
.profile-section-card {
  background: var(--white);
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  padding: 1.75rem;
  box-shadow: var(--shadow-sm);
}
.profile-section-title {
  font-size: 1.15rem; font-weight: 600; color: var(--black);
  margin: 0 0 1.25rem; font-family: var(--font-body);
}
/* form layout inside profile */
.form-row-2 {
  display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-bottom: 1rem;
}
.page-form-error { font-size: .82rem; color: #b91c1c; margin-top: .2rem; }
/* login table */
.profile-login-table {
  width: 100%; border-collapse: collapse; font-size: .88rem;
}
.profile-login-table th {
  text-align: left; padding: .6rem .75rem;
  background: var(--bg); color: var(--muted); font-weight: 600;
  border-bottom: 2px solid var(--rule); font-size: .78rem;
  text-transform: uppercase; letter-spacing: .06em;
}
.profile-login-table td {
  padding: .6rem .75rem; border-bottom: 1px solid var(--rule);
  color: var(--ink);
}
.profile-login-table tr:last-child td { border-bottom: none; }

/* ─── Subscription plan cards ────────── */
.plans-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 24px;
}
.plan-card {
  background: var(--white); border: 1px solid var(--rule);
  border-radius: var(--radius-lg); padding: 2rem;
  text-align: center; position: relative;
  transition: transform .22s, box-shadow .22s;
}
.plan-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.plan-featured { border-color: var(--saffron); box-shadow: 0 8px 30px rgba(232,117,26,.15); }
.plan-badge {
  position: absolute; top: -12px; left: 50%; transform: translateX(-50%);
  background: var(--saffron); color: var(--white);
  font-size: .68rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
  padding: 4px 16px; border-radius: 999px;
}
.plan-interval {
  font-size: .7rem; font-weight: 700; letter-spacing: .22em;
  text-transform: uppercase; color: var(--saffron); margin-bottom: 12px;
}
.plan-name { font-size: 1.4rem; margin-bottom: 10px; }
.plan-desc { font-size: .88rem; color: var(--muted); line-height: 1.65; margin-bottom: 20px; min-height: 72px; }
.plan-price {
  font-family: var(--font-heading); font-size: 2.4rem; font-weight: 500;
  color: var(--black); margin-bottom: 6px;
}
.plan-price span { font-family: var(--font-body); font-size: .78rem; color: var(--muted); font-weight: 400; }
.plan-trial { font-size: .82rem; color: #16a34a; margin-bottom: 16px; }
.plan-card form, .plan-card .button { margin-top: auto; }

/* ─── My subscriptions cards ─────────── */
.sub-card {
  background: var(--white); border: 1px solid var(--rule);
  border-radius: var(--radius-lg); padding: 1.75rem;
  display: flex; justify-content: space-between; align-items: center;
  gap: 1rem; box-shadow: var(--shadow-sm); margin-bottom: 1rem;
}
.sub-card-left { flex: 1; min-width: 0; }
.sub-card-left h3 { font-size: 1.2rem; margin: 8px 0 6px; }
.sub-card-left p { font-size: .88rem; color: var(--muted); margin-bottom: 10px; }
.sub-meta { display: flex; flex-wrap: wrap; gap: 16px; font-size: .82rem; color: var(--muted); }
.sub-meta strong { font-weight: 700; color: var(--black); }
.sub-status {
  display: inline-block; padding: 3px 10px; border-radius: 999px;
  font-size: .68rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
}
.sub-status-active { background: #dcfce7; color: #166534; }
.sub-status-trial { background: #e0f2fe; color: #0369a1; }
.sub-status-cancelled { background: #fde8e8; color: #991b1b; }
.sub-status-expired { background: #f3f4f6; color: #6b7280; }
.sub-status-past_due { background: #fef3c7; color: #92400e; }
.sub-card-right { flex-shrink: 0; }

/* ─── Responsive for profile & shop ─── */
@media (max-width: 900px) {
  .profile-layout { grid-template-columns: 1fr; }
  .profile-sidebar-card { position: static; }
  .shop-two-col { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .form-row-2 { grid-template-columns: 1fr; }
  .article-list { grid-template-columns: 1fr; }
}

/* ===== WHATSAPP FLOATING BUTTON ===== */
.wa-float{position:fixed;bottom:24px;right:24px;z-index:9999;width:56px;height:56px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(0,0,0,.2);transition:transform .2s,box-shadow .2s;text-decoration:none;}
.wa-float:hover{transform:scale(1.08);box-shadow:0 6px 24px rgba(0,0,0,.3);}
.wa-float svg{width:28px;height:28px;fill:#fff;}
.wa-float-tooltip{position:absolute;right:68px;top:50%;transform:translateY(-50%);background:#fff;color:#333;font-size:.82rem;font-weight:600;padding:.5rem 1rem;border-radius:8px;box-shadow:0 2px 12px rgba(0,0,0,.12);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s;}
.wa-float:hover .wa-float-tooltip{opacity:1;}

/* ===== BOOKING/CALENDAR ===== */
.cal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;}
.cal-slot{background:#fff;border:1.5px solid #e5e7eb;border-radius:10px;padding:1rem;text-align:center;transition:all .2s;}
.cal-slot:hover{border-color:#E8751A;box-shadow:0 2px 12px rgba(232,117,26,.1);}
.cal-slot-time{font-size:1.1rem;font-weight:700;color:#1A1A1A;margin-bottom:.3rem;}
.cal-slot-date{font-size:.82rem;color:#888;margin-bottom:.6rem;}
.cal-slot .btn-sm{width:100%;}

/* ===== DASHBOARD UTILITY CLASSES ===== */
/* icon colors for stat cards */
.clr-saffron{color:#E8751A;}
.clr-purple{color:#7c3aed;}
.clr-blue{color:#2563eb;}
.clr-green{color:#059669;}
.clr-red{color:#e74c3c;}
.clr-pink{color:#db2777;}
.clr-yellow{color:#d97706;}
.clr-danger{color:#dc2626;}

/* section header with print buttons */
.dash-section-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;}
.dash-section-header .dash-section-title{margin-bottom:0;}
.dash-section-header .dash-actions{display:flex;gap:.5rem;}

/* order price */
.dash-order-price{color:#E8751A;font-size:1.1rem;font-weight:700;}

/* cancel button (red) */
.btn-cancel{color:#e74c3c;border-color:#e74c3c;font-size:.72rem;}

/* compatibility indicators */
.compat-high{font-size:.8rem;color:#059669;margin-top:.3rem;}
.compat-mid{font-size:.8rem;color:#d97706;margin-top:.3rem;}
.compat-low{font-size:.8rem;color:#dc2626;margin-top:.3rem;}

/* match report name styling */
.match-names{font-size:1rem;font-weight:700;}
.match-meta{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;}

/* empty state icon sizes */
.dash-empty-icon{font-size:3rem;opacity:.3;}

/* hidden helper */
.d-none{display:none;}

/* chart detail panel */
.chart-detail-panel{margin-top:1.5rem;}

/* slot mentor label */
.slot-mentor{font-size:.75rem;color:#888;margin-bottom:.5rem;}

/* card no-border list item */
.dash-list-item-flat{border:none;padding:0;}

/* subscription detail line */
.sub-detail{margin-top:.2rem;}

/* card with center content */
.dash-card-center{text-align:center;padding:2rem;}

/* dash-div-heading consistent style */
.dash-div-heading{margin:1rem 0 .5rem;font-family:var(--font-body);font-size:1rem;font-weight:600;}

/* spacing utilities */
.mb-0{margin-bottom:0;}
.mb-1{margin-bottom:1rem;}
.mb-1h{margin-bottom:1.5rem;}
.mt-1{margin-top:1rem;}
.mt-03{margin-top:.3rem;}
.text-center{text-align:center;}
.flex-1{flex:1;}

/* no-chart CTA amber */
.no-chart-cta{background:linear-gradient(135deg,#fff7ed,#fef3c7);border-color:rgba(245,158,11,.3);}
.no-chart-cta .dash-active-icon{background:#f59e0b;}

/* chart card helpers */
.chart-badge{font-size:.65rem;}
.chart-btn-row{margin-top:.8rem;display:flex;gap:.4rem;}
.chart-detail-rasi{margin-bottom:1rem;}

/* booking helpers */
.booking-desc{font-size:.85rem;color:#666;margin-bottom:1rem;}
.no-slots-icon{font-size:2rem;opacity:.3;}
.no-slots-msg{color:#888;margin-top:.5rem;}

/* subscription name */
.sub-name{font-size:1.05rem;}

/* match report center CTA */
.match-cta{text-align:center;padding:1rem;}

/* panchanga location icon */
.panch-loc-icon{font-size:1.1rem;}
.panch-loc-btn{font-size:.78rem;}
