/* ==========================================================================
   Indiatutors Online — Legal Pages (Privacy Policy & Terms of Service)
   Premium design: sticky TOC sidebar, purple hero banner, clean typography.
   ========================================================================== */

html { scroll-behavior: smooth; }

/* ── Variables ─────────────────────────────────────────────────────────── */
:root {
  /* v1.9.72: repalette to canonical WinQuest Rose. */
  --legal-purple:       #ff3870;
  --legal-purple-dark:  #c8154b;
  --legal-purple-soft:  #fff5fa;
  --legal-purple-mid:   #ff5d8c;
  --legal-heading:      #5c1d35;
  --legal-body:         #4a3540;
  --legal-muted:        #6b556a;
  --legal-border:       #f1e1e7;
  --legal-bg-page:      #fdf8fa;
  --legal-bg-card:      #ffffff;
  --legal-hero-from:    #d63265;
  --legal-hero-to:      #ff7da0;
  --legal-radius:       14px;
  --legal-radius-sm:    8px;
  --legal-shadow:       0 4px 24px rgba(255,56,112,.10);
  --legal-shadow-lg:    0 8px 40px rgba(255,31,89,.14);
  --legal-font-heading: "Poppins", system-ui, -apple-system, sans-serif;
  --legal-font-body:    "Inter", system-ui, -apple-system, sans-serif;
  --legal-toc-width:    272px;
  --legal-sticky-top:   110px;
}

/* ── Page shell ─────────────────────────────────────────────────────────── */
.legal-page {
  font-family: var(--legal-font-body);
  font-size: 16px;
  color: var(--legal-body);
  line-height: 1.78;
  background: var(--legal-bg-page);
  /* Full-width breakout handled globally via ito_print_global_layout_styles().
     Overflow-x intentionally NOT hidden here — breaks position:sticky TOC. */
}

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

.legal-page .container {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 28px;
}

.legal-page a {
  color: var(--legal-purple);
  text-decoration: none;
  transition: color .15s;
}
.legal-page a:hover { color: var(--legal-purple-mid); text-decoration: underline; }
.legal-page a:focus-visible {
  outline: 2px solid var(--legal-purple);
  outline-offset: 3px;
  border-radius: 3px;
}

/* ── Hero ───────────────────────────────────────────────────────────────── */
.legal-hero {
  /* v1.9.72: 3-stop WQ hero gradient (#d63265 → #b91d4e → #ff7da0) matches /shop/ */
  background: linear-gradient(135deg, #d63265 0%, #b91d4e 50%, #ff7da0 100%);
  color: #fff;
  padding: 80px 0 68px;
  position: relative;
  overflow: hidden;
}

/* Decorative orb */
.legal-hero::before {
  content: "";
  position: absolute;
  inset: -60px -60px auto auto;
  width: 380px;
  height: 380px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,31,89,.35) 0%, transparent 70%);
  pointer-events: none;
}

.legal-hero__inner { max-width: 740px; }

.legal-hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.25);
  color: rgba(255,255,255,.9);
  font-family: var(--legal-font-heading);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 5px 14px;
  border-radius: 999px;
  margin-bottom: 20px;
}

.legal-hero__title {
  font-family: var(--legal-font-heading);
  font-size: clamp(2rem, 4.5vw, 3.2rem);
  font-weight: 800;
  line-height: 1.1;
  margin: 0 0 18px;
  color: #fff;
  letter-spacing: -.01em;
}

.legal-hero__meta {
  font-size: .88rem;
  color: rgba(255,255,255,.62);
  margin: 0 0 20px;
  display: flex;
  flex-wrap: wrap;
  gap: 0 16px;
  align-items: center;
}
.legal-hero__meta strong { color: rgba(255,255,255,.88); }

.legal-hero__meta::before {
  content: "";
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--legal-purple);
  flex-shrink: 0;
}

.legal-hero__lead {
  font-size: 1.05rem;
  color: rgba(255,255,255,.78);
  max-width: 620px;
  margin: 0;
  line-height: 1.7;
}

/* ── Body layout ────────────────────────────────────────────────────────── */
.legal-body {
  display: grid;
  grid-template-columns: var(--legal-toc-width) 1fr;
  column-gap: 56px;
  align-items: start;
  padding: 64px 0 96px;
}

/* ── TOC sidebar ────────────────────────────────────────────────────────── */
.legal-toc {
  position: sticky;
  top: var(--legal-sticky-top);
}

.legal-toc__card {
  background: var(--legal-bg-card);
  border: 1px solid var(--legal-border);
  border-radius: var(--legal-radius);
  padding: 24px 20px 20px;
  box-shadow: var(--legal-shadow);
}

.legal-toc__heading {
  font-family: var(--legal-font-heading);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--legal-muted);
  margin: 0 0 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--legal-border);
}

.legal-toc__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.legal-toc__list li { margin: 0; padding: 0; }

.legal-toc__list a {
  display: block;
  font-size: .81rem;
  color: var(--legal-muted);
  padding: 6px 10px 6px 14px;
  border-left: 2px solid transparent;
  border-radius: 0 6px 6px 0;
  line-height: 1.45;
  transition: color .15s, border-color .15s, background .15s;
  text-decoration: none;
}
.legal-toc__list a:hover,
.legal-toc__list a:focus-visible {
  color: var(--legal-purple);
  border-left-color: var(--legal-purple);
  background: var(--legal-purple-soft);
  text-decoration: none;
}

/* ── Article ────────────────────────────────────────────────────────────── */
.legal-article { min-width: 0; }

/* ── Sections ───────────────────────────────────────────────────────────── */
.legal-section {
  margin-bottom: 52px;
  padding-bottom: 44px;
  border-bottom: 1px solid var(--legal-border);
  scroll-margin-top: 120px;
}
.legal-section:last-child { border-bottom: none; margin-bottom: 0; }

.legal-section__title {
  font-family: var(--legal-font-heading);
  font-size: 1.42rem;
  font-weight: 700;
  color: var(--legal-heading);
  margin: 0 0 22px;
  line-height: 1.3;
  border-left: 3px solid var(--legal-purple);
  padding-left: 16px;
}

.legal-section__sub {
  font-family: var(--legal-font-heading);
  font-size: 1rem;
  font-weight: 600;
  color: var(--legal-heading);
  margin: 30px 0 10px;
  padding-left: 0;
}

.legal-section p {
  margin: 0 0 14px;
  color: var(--legal-body);
  font-size: .96rem;
}
.legal-section p:last-child { margin-bottom: 0; }

.legal-section ul,
.legal-section ol {
  margin: 4px 0 16px 22px;
  padding: 0;
}
.legal-section li {
  margin-bottom: 7px;
  color: var(--legal-body);
  font-size: .96rem;
}

/* ── Definition list ────────────────────────────────────────────────────── */
.legal-dl {
  margin: 8px 0 16px;
  padding: 0;
  background: var(--legal-bg-card);
  border: 1px solid var(--legal-border);
  border-radius: var(--legal-radius-sm);
  overflow: hidden;
}

.legal-dl dt,
.legal-dl dd {
  margin: 0;
  padding: 10px 18px;
}

.legal-dl dt {
  font-weight: 700;
  color: var(--legal-heading);
  font-size: .88rem;
  background: #f6f5ff;
  border-top: 1px solid var(--legal-border);
  letter-spacing: .01em;
}
.legal-dl dt:first-child { border-top: none; }

.legal-dl dd {
  font-size: .9rem;
  color: var(--legal-body);
  line-height: 1.65;
  border-top: 1px solid #f0f0f8;
}

/* ── Callout ────────────────────────────────────────────────────────────── */
.legal-callout {
  background: var(--legal-purple-soft);
  border-left: 4px solid var(--legal-purple);
  border-radius: 0 var(--legal-radius-sm) var(--legal-radius-sm) 0;
  padding: 16px 20px;
  margin: 20px 0;
}
.legal-callout p { margin: 0; color: var(--legal-purple-dark); font-size: .94rem; }
.legal-callout strong { color: var(--legal-purple); }

/* ── Contact card ───────────────────────────────────────────────────────── */
.legal-contact-card {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
  gap: 14px;
  margin-top: 28px;
}

.legal-contact-card__item {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  background: var(--legal-bg-card);
  border: 1px solid var(--legal-border);
  border-radius: var(--legal-radius-sm);
  padding: 18px 16px;
  line-height: 1.5;
  font-size: .88rem;
  transition: box-shadow .18s, border-color .18s;
}
.legal-contact-card__item:hover {
  box-shadow: var(--legal-shadow);
  border-color: rgba(255,31,89,.3);
}

.legal-contact-card__icon {
  font-size: 1.3rem;
  flex-shrink: 0;
  margin-top: 1px;
  line-height: 1;
}

.legal-contact-card__item strong {
  display: block;
  font-size: .69rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .09em;
  color: var(--legal-muted);
  margin-bottom: 3px;
}

.legal-contact-card__item a {
  color: var(--legal-purple);
  font-weight: 500;
  font-size: .88rem;
}

/* ── Responsive ─────────────────────────────────────────────────────────── */
@media (max-width: 920px) {
  .legal-body {
    grid-template-columns: 1fr;
    gap: 0;
    padding-top: 40px;
    padding-bottom: 64px;
  }

  .legal-toc {
    position: static;
    margin-bottom: 36px;
  }

  .legal-toc__card {
    padding: 18px 16px;
  }

  .legal-toc__list { gap: 0; }
  .legal-toc__list a { padding: 8px 10px 8px 14px; }

  .legal-hero { padding: 52px 0 44px; }
  .legal-hero__title { font-size: 1.9rem; }
}

@media (max-width: 560px) {
  .legal-page .container { padding: 0 16px; }
  .legal-hero { padding: 40px 0 36px; }
  .legal-hero__title { font-size: 1.6rem; }
  .legal-hero__lead { font-size: .96rem; }
  .legal-section__title { font-size: 1.2rem; }
  .legal-contact-card { grid-template-columns: 1fr; }
}

/* ── Print ──────────────────────────────────────────────────────────────── */
@media print {
  .legal-toc { display: none; }
  .legal-body { grid-template-columns: 1fr; }
  .legal-hero { background: #fff; color: #000; }
  .legal-hero__title { color: #000; }
}

/* ==========================================================================
   REFUND PAGE EXTRAS — table, highlight cards, step list, note box
   ========================================================================== */

/* ── At-a-Glance highlight card grid ───────────────────────────────────── */
.legal-highlight-cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 14px;
  margin: 22px 0 8px;
}

.legal-card {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 18px 16px;
  border-radius: var(--legal-radius-sm);
  border: 1px solid var(--legal-border);
  background: var(--legal-bg-card);
  font-family: var(--legal-font-body);
  font-size: .88rem;
  line-height: 1.55;
  transition: box-shadow .18s;
}
.legal-card:hover { box-shadow: var(--legal-shadow); }

.legal-card__icon {
  font-size: 1.35rem;
  flex-shrink: 0;
  margin-top: 1px;
  line-height: 1;
}

.legal-card strong {
  display: block;
  font-family: var(--legal-font-heading);
  font-size: .82rem;
  font-weight: 700;
  color: var(--legal-heading);
  margin-bottom: 4px;
}

.legal-card p {
  margin: 0 !important;
  color: var(--legal-body);
  font-size: .84rem;
}

.legal-card--green {
  border-left: 3px solid #22c55e;
  background: #f0fdf4;
}
.legal-card--yellow {
  border-left: 3px solid #f59e0b;
  background: #fffbeb;
}
.legal-card--red {
  border-left: 3px solid #ef4444;
  background: #fef2f2;
}

/* ── Data table ─────────────────────────────────────────────────────────── */
.legal-table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--legal-font-body);
  font-size: .88rem;
  margin: 18px 0 24px;
  border-radius: var(--legal-radius-sm);
  overflow: hidden;
  border: 1px solid var(--legal-border);
}

.legal-table thead tr {
  background: var(--legal-purple);
  color: #fff;
}
.legal-table thead th {
  padding: 12px 16px;
  text-align: left;
  font-family: var(--legal-font-heading);
  font-size: .76rem;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
  white-space: nowrap;
}

.legal-table tbody tr:nth-child(even) { background: #f8f7ff; }
.legal-table tbody tr:hover { background: var(--legal-purple-soft); }

.legal-table tbody td {
  padding: 11px 16px;
  color: var(--legal-body);
  border-bottom: 1px solid var(--legal-border);
  vertical-align: top;
  line-height: 1.5;
}
.legal-table tbody tr:last-child td { border-bottom: none; }

/* ── Step list ──────────────────────────────────────────────────────────── */
.legal-steps {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin: 18px 0 24px;
  padding: 0;
}
.legal-steps li {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 18px 18px 18px 16px;
  background: var(--legal-bg-card);
  border: 1px solid var(--legal-border);
  border-radius: var(--legal-radius-sm);
  font-family: var(--legal-font-body);
  font-size: .90rem;
  color: var(--legal-body);
  line-height: 1.55;
  margin: 0;
}
.legal-steps li::before { display: none; }
.legal-steps li ul { margin: 8px 0 0 0; }
.legal-steps li ul li {
  padding: 0;
  background: none;
  border: none;
  font-size: .86rem;
  display: list-item;
  padding-left: 0;
}
.legal-steps li ul li::before { display: inline; }

.legal-steps__num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: var(--legal-purple);
  color: #fff;
  font-family: var(--legal-font-heading);
  font-size: .80rem;
  font-weight: 800;
  line-height: 1;
  margin-top: 1px;
}

/* ── Note / info box ────────────────────────────────────────────────────── */
.legal-note {
  background: var(--legal-purple-soft);
  border-left: 4px solid var(--legal-purple);
  border-radius: 0 var(--legal-radius-sm) var(--legal-radius-sm) 0;
  padding: 14px 18px;
  margin: 18px 0;
  font-family: var(--legal-font-body);
  font-size: .88rem;
  color: var(--legal-purple-dark);
  line-height: 1.6;
}
.legal-note--info {
  background: #eff6ff;
  border-left-color: #3b82f6;
  color: #1e3a5f;
}
.legal-note strong { color: inherit; }

/* ── Related links in TOC sidebar ──────────────────────────────────────── */
.legal-toc__related {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.legal-toc__related a {
  display: block;
  padding: 7px 12px;
  font-family: var(--legal-font-body);
  font-size: .82rem;
  color: var(--legal-muted);
  border-radius: 6px;
  transition: background .15s, color .15s;
  text-decoration: none;
}
.legal-toc__related a:hover {
  background: var(--legal-purple-soft);
  color: var(--legal-purple);
}

/* ── Responsive extras ──────────────────────────────────────────────────── */
@media (max-width: 680px) {
  .legal-highlight-cards { grid-template-columns: 1fr; }
  .legal-table { font-size: .80rem; }
  .legal-table thead th,
  .legal-table tbody td { padding: 9px 12px; }
}


/* =========================================================================
   v1.9.91 — Restyle Elementor content rendered inside .legal-page--rendered

   page-ca-policy.php / page-deib-policy.php / page-refer-earn-policy.php
   render the existing WP page content (Elementor blocks) inside our
   .legal-page wrapper. The Elementor markup ships with its own font
   stack, sizes, and colours which don't match Terms.

   These rules force the Elementor output to inherit Terms typography
   and palette — without touching the text itself. Scoped tightly to
   .legal-page--rendered .legal-article so other Elementor pages are
   untouched.
   ========================================================================= */

.legal-page--rendered .legal-article--wide {
  max-width: 960px;
  margin: 0 auto;
}

/* Headings — inherit terms font + palette */
.legal-page--rendered .legal-article :is(h1, h2, h3, h4, h5, h6),
.legal-page--rendered .legal-article :is(
  .elementor-heading-title,
  .elementor-widget-heading .elementor-widget-container > *
) {
  font-family: var(--legal-font-heading) !important;
  color: var(--legal-heading) !important;
  letter-spacing: -.015em !important;
  line-height: 1.22 !important;
}
.legal-page--rendered .legal-article h2,
.legal-page--rendered .legal-article .elementor-widget-heading h2 {
  font-size: clamp(1.35rem, 2.2vw, 1.6rem) !important;
  font-weight: 700 !important;
  margin: 30px 0 12px !important;
  padding-bottom: 8px !important;
  border-bottom: 1px solid var(--legal-border) !important;
}
.legal-page--rendered .legal-article h3,
.legal-page--rendered .legal-article .elementor-widget-heading h3 {
  font-size: clamp(1.05rem, 1.6vw, 1.18rem) !important;
  font-weight: 700 !important;
  color: var(--legal-purple) !important;
  margin: 22px 0 8px !important;
}

/* Body text — terms colour + size */
.legal-page--rendered .legal-article :is(p, li, dd, dt, span, td, th),
.legal-page--rendered .legal-article .elementor-widget-text-editor :is(p, li),
.legal-page--rendered .legal-article .elementor-widget-text-editor .elementor-widget-container {
  font-family: var(--legal-font-body) !important;
  color: var(--legal-body) !important;
  font-size: 1rem !important;
  line-height: 1.68 !important;
}
.legal-page--rendered .legal-article strong,
.legal-page--rendered .legal-article b { color: var(--legal-heading) !important; }
.legal-page--rendered .legal-article a {
  color: var(--legal-purple) !important;
  text-decoration: underline !important;
  text-decoration-thickness: 1px !important;
  text-underline-offset: 2px !important;
}
.legal-page--rendered .legal-article a:hover { color: var(--legal-purple-dark) !important; }

/* Lists — uniform spacing */
.legal-page--rendered .legal-article :is(ul, ol) {
  padding-left: 22px !important;
  margin: 10px 0 16px !important;
}
.legal-page--rendered .legal-article :is(ul, ol) li { margin: 4px 0 !important; }

/* Strip Elementor section background / extreme padding — we want the
   .legal-body container to control spacing, not nested Elementor
   sections that may have inherited big margins. */
.legal-page--rendered .legal-article .elementor-section,
.legal-page--rendered .legal-article .elementor-container,
.legal-page--rendered .legal-article .e-con,
.legal-page--rendered .legal-article .elementor-column-wrap {
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
}
.legal-page--rendered .legal-article .elementor-column {
  width: 100% !important;
  padding: 0 !important;
}

/* Widget gaps — reasonable rhythm */
.legal-page--rendered .legal-article .elementor-widget {
  margin-bottom: 14px !important;
}

/* Block editor (Gutenberg) wrappers, same idea */
.legal-page--rendered .legal-article .wp-block-group {
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
}

/* === /v1.9.91 elementor content restyle inside legal-page === */


/* =========================================================================
   v1.9.94 — Full-width parent containers for the rendered policy pages

   v1.9.93 tried a 100vw + margin-left:-50vw full-bleed on .legal-hero.
   That technique requires the immediate parent to be CENTERED inside
   the viewport, otherwise the negative margin shifts the hero off the
   left edge. The user's screenshots showed exactly that: "California
   Consumer Privacy Notice" title cut off on the left, "Diversity,
   Equity, Inclusion & Belonging Statement" same.

   New approach — instead of breaking the hero out of its parent, force
   every wrapping container on CA Policy + DEIB Statement pages to span
   the full viewport. The hero is then naturally 100% wide of a 100%
   wide parent, with zero positioning math.

   Scoped to the two body classes WordPress sets when our templates are
   active, so other pages (refund / privacy / terms) are untouched.
   ========================================================================= */

.page-template-page-ca-policy-php #content,
.page-template-page-ca-policy-php .ast-container,
.page-template-page-ca-policy-php .legal-page,
.page-template-page-deib-policy-php #content,
.page-template-page-deib-policy-php .ast-container,
.page-template-page-deib-policy-php .legal-page {
  max-width: none !important;
  width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* Re-center the body container at 1440 — matches refund-policy reading
   width with sane gutters. */
.legal-page--rendered .legal-body {
  width: 100% !important;
  max-width: 1440px !important;
  margin: 0 auto !important;
  padding: 0 28px !important;
  box-sizing: border-box !important;
}

/* Article reads at 1100px (refund-policy parity), gutters from .legal-body. */
.legal-page--rendered .legal-article--wide {
  max-width: 1100px !important;
  margin: 28px auto 60px !important;
  padding: 0 !important;
}

/* Hero — make absolutely sure no leftover v1.9.93 transform / position
   sneaks back in via cache. */
.legal-page--rendered .legal-hero {
  position: relative !important;
  width: 100% !important;
  max-width: 100% !important;
  left: auto !important;
  right: auto !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

@media (max-width: 720px) {
  .legal-page--rendered .legal-body {
    padding: 0 16px !important;
  }
  .legal-page--rendered .legal-article--wide {
    margin: 16px auto 36px !important;
  }
}

/* === /v1.9.94 full-width parent containers for rendered legal pages === */


/* =========================================================================
   v1.9.96 — Layout CA + DEIB content to match Privacy Policy

   User: "check privacy policy...accordingly the DEIB and CA policy
   should be arranged". Privacy Policy uses:
     - LEFT  : ~280px sticky sidebar with numbered TOC (clean, no card)
     - RIGHT : ~900px wide article body, sections numbered

   v1.9.95 force-stacked everything which lost the sidebar entirely.
   Reverted. New approach detects the Elementor 2-column case via :has()
   and pins first child to 280px, second to flex 1. Single-column pages
   (DEIB has effectively one body column) get full width.

   No card / border / background on any Elementor wrapper — that strips
   the white-box look the user called "the divider".
   ========================================================================= */

/* Keep Elementor's flex row layout but force consistent geometry. */
.legal-page--rendered .legal-article .elementor-section > .elementor-container,
.legal-page--rendered .legal-article .e-con > .e-con-inner,
.legal-page--rendered .legal-article > .e-con,
.legal-page--rendered .legal-article > .elementor-section > .elementor-container {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  align-items: flex-start !important;
  gap: 36px !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* 2-column case: first child = sidebar (280px), second = body (flex 1).
   Uses :has() — Chrome 105+, Safari 15.4+. Safe baseline for nuvio. */
.legal-page--rendered .legal-article .elementor-container:has(> .elementor-column:nth-child(2)) > .elementor-column:first-child,
.legal-page--rendered .legal-article .e-con-inner:has(> .e-con:nth-child(2)) > .e-con:first-child {
  flex: 0 0 280px !important;
  width: 280px !important;
  max-width: 280px !important;
  position: sticky !important;
  top: 110px !important;
  align-self: flex-start !important;
}

.legal-page--rendered .legal-article .elementor-container:has(> .elementor-column:nth-child(2)) > .elementor-column:nth-child(n+2),
.legal-page--rendered .legal-article .e-con-inner:has(> .e-con:nth-child(2)) > .e-con:nth-child(n+2) {
  flex: 1 1 0 !important;
  width: auto !important;
  max-width: none !important;
  min-width: 0 !important;
}

/* 1-column case (or :has() fallback): full width for every column. */
.legal-page--rendered .legal-article .elementor-container:not(:has(> .elementor-column:nth-child(2))) > .elementor-column,
.legal-page--rendered .legal-article .e-con-inner:not(:has(> .e-con:nth-child(2))) > .e-con,
.legal-page--rendered .legal-article > .e-con:only-child {
  flex: 1 1 100% !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
}

/* Strip all card / divider styling — no backgrounds, borders, shadows,
   or rounded corners on any Elementor wrapper inside the article. */
.legal-page--rendered .legal-article .elementor-section,
.legal-page--rendered .legal-article .elementor-container,
.legal-page--rendered .legal-article .elementor-column,
.legal-page--rendered .legal-article .elementor-column-wrap,
.legal-page--rendered .legal-article .elementor-widget-wrap,
.legal-page--rendered .legal-article .elementor-element-populated,
.legal-page--rendered .legal-article .e-con,
.legal-page--rendered .legal-article .e-con-inner,
.legal-page--rendered .legal-article .e-con-boxed {
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
}

/* Widget container inside columns — full width of its column. */
.legal-page--rendered .legal-article .elementor-widget,
.legal-page--rendered .legal-article .elementor-widget-text-editor,
.legal-page--rendered .legal-article .elementor-widget-text-editor .elementor-widget-container,
.legal-page--rendered .legal-article .elementor-widget-heading,
.legal-page--rendered .legal-article .elementor-widget-heading .elementor-widget-container {
  width: 100% !important;
  max-width: 100% !important;
  padding: 0 !important;
  margin: 0 0 14px !important;
}

/* Sidebar TOC links — match Privacy Policy's simple numbered list. */
.legal-page--rendered .legal-article .elementor-column:first-child .elementor-widget-text-editor ul,
.legal-page--rendered .legal-article .elementor-column:first-child .elementor-widget-text-editor ol,
.legal-page--rendered .legal-article .e-con:first-child .elementor-widget-text-editor ul,
.legal-page--rendered .legal-article .e-con:first-child .elementor-widget-text-editor ol {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.legal-page--rendered .legal-article .elementor-column:first-child .elementor-widget-text-editor li,
.legal-page--rendered .legal-article .e-con:first-child .elementor-widget-text-editor li {
  font-size: 0.92rem !important;
  line-height: 1.5 !important;
  margin: 6px 0 !important;
}

/* Responsive — stack to single column under 900px so the sidebar drops
   above the body content. */
@media (max-width: 900px) {
  .legal-page--rendered .legal-article .elementor-container:has(> .elementor-column:nth-child(2)) > .elementor-column:first-child,
  .legal-page--rendered .legal-article .elementor-container:has(> .elementor-column:nth-child(2)) > .elementor-column:nth-child(n+2),
  .legal-page--rendered .legal-article .e-con-inner:has(> .e-con:nth-child(2)) > .e-con:first-child,
  .legal-page--rendered .legal-article .e-con-inner:has(> .e-con:nth-child(2)) > .e-con:nth-child(n+2) {
    flex: 1 1 100% !important;
    width: 100% !important;
    max-width: 100% !important;
    position: static !important;
  }
}

/* === /v1.9.96 CA + DEIB layout matches privacy-policy (sidebar + body) === */


/* =========================================================================
   v1.10.2 — Download button used in CA Policy §14 + DEIB Statement §4

   Hardcoded templates page-ca-policy.php and page-deib-policy.php each
   end with a download link to the PDF version. Pink pill style matching
   the rest of the legal-page palette.
   ========================================================================= */

.legal-download-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  background: linear-gradient(135deg, var(--legal-purple-mid) 0%, var(--legal-purple) 100%) !important;
  color: #fff !important;
  font-family: var(--legal-font-heading) !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  padding: 14px 28px !important;
  border-radius: 999px !important;
  text-decoration: none !important;
  box-shadow: 0 8px 20px rgba(255, 56, 112, 0.32) !important;
  transition: transform .12s, box-shadow .15s !important;
}
.legal-download-btn:hover,
.legal-download-btn:focus-visible {
  color: #fff !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 12px 28px rgba(255, 56, 112, 0.42) !important;
  text-decoration: none !important;
}

/* === /v1.10.2 legal download button === */

