/* ============================================================================
   MITCON Credensia — Legal Pages Layout
   ----------------------------------------------------------------------------
   Typography-focused styling for Privacy, Terms, Disclaimer, Cookie,
   Accessibility, and Sitemap pages. Optimized for long-form reading and
   excellent print output.
   ============================================================================ */

/* ============================================================================
   1. PAGE HEADER
   ============================================================================ */
.legal-header {
  background: linear-gradient(
    180deg,
    var(--color-primary-lighter) 0%,
    var(--color-bg) 100%
  );
  padding-block: var(--space-10) var(--space-12);
  border-bottom: 1px solid var(--color-grey-light);
}

.legal-header__breadcrumb {
  margin-bottom: var(--space-6);
}

.legal-header__breadcrumb-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin: 0;
  padding: 0;
  list-style: none;
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
}

.legal-header__breadcrumb-list li:not(:last-child)::after {
  content: "/";
  margin-left: var(--space-2);
  color: var(--color-grey);
}

.legal-header__breadcrumb-list a {
  color: var(--color-primary);
  text-decoration: none;
  transition: var(--transition-color);
}

.legal-header__breadcrumb-list a:hover {
  color: var(--color-accent);
  text-decoration: underline;
}

.legal-header__breadcrumb-list a:focus-visible {
  outline: var(--focus-ring-width) var(--focus-ring-style) var(--color-focus-ring);
  outline-offset: var(--focus-ring-offset);
  border-radius: var(--radius-sm);
}

.legal-header__breadcrumb-list [aria-current="page"] {
  color: var(--color-text-secondary);
  font-weight: var(--fw-medium);
}

.legal-header__eyebrow {
  display: inline-block;
  padding: var(--space-1) var(--space-3);
  background-color: var(--color-bg);
  color: var(--color-primary);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: var(--ls-widest);
  border-radius: var(--radius-full);
  border: 1px solid var(--color-primary-lighter);
  margin-bottom: var(--space-4);
}

.legal-header__title {
  font-size: clamp(var(--fs-3xl), 4vw, var(--fs-4xl));
  line-height: var(--lh-tight);
  letter-spacing: -0.02em;
  color: var(--color-dark);
  margin-bottom: var(--space-4);
  font-weight: var(--fw-bold);
}

.legal-header__lead {
  font-size: var(--fs-md);
  line-height: var(--lh-relaxed);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-4);
  max-width: 56ch;
}

.legal-header__updated {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  background-color: var(--color-bg);
  border: 1px solid var(--color-grey-light);
  border-radius: var(--radius-full);
  font-size: var(--fs-sm);
  color: var(--color-text-secondary);
  margin: 0;
}

.legal-header__updated svg {
  color: var(--color-accent);
  flex-shrink: 0;
}

.legal-header__updated time {
  font-weight: var(--fw-semibold);
  color: var(--color-dark);
}

/* ============================================================================
   2. BODY (article container)
   ============================================================================ */
.legal-body {
  padding-block: var(--space-12) var(--space-16);
}

.legal-body__article {
  max-width: 72ch;                                    /* ~720px optimal reading */
  margin-inline: auto;
}

.legal-body__intro {
  font-size: var(--fs-md);
  line-height: var(--lh-relaxed);
  color: var(--color-text);
  margin-bottom: var(--space-8);
  padding: var(--space-5) var(--space-6);
  background-color: var(--color-primary-lighter);
  border-left: 3px solid var(--color-primary);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
}

/* ============================================================================
   3. TYPOGRAPHY (article body)
   ============================================================================ */
.legal-body__article h2 {
  font-size: var(--fs-2xl);
  line-height: var(--lh-tight);
  color: var(--color-dark);
  margin-top: var(--space-10);
  margin-bottom: var(--space-4);
  padding-top: var(--space-4);
  font-weight: var(--fw-bold);
  scroll-margin-top: calc(var(--navbar-height-desktop) + var(--space-4));
}

.legal-body__article h2:first-of-type {
  margin-top: 0;
  padding-top: 0;
}

.legal-body__article h3 {
  font-size: var(--fs-lg);
  line-height: var(--lh-snug);
  color: var(--color-dark);
  margin-top: var(--space-6);
  margin-bottom: var(--space-3);
  font-weight: var(--fw-semibold);
}

.legal-body__article p {
  font-size: var(--fs-base);
  line-height: var(--lh-relaxed);
  color: var(--color-text);
  margin-bottom: var(--space-4);
}

.legal-body__article ul,
.legal-body__article ol {
  margin-bottom: var(--space-5);
  padding-left: var(--space-6);
}

.legal-body__article li {
  font-size: var(--fs-base);
  line-height: var(--lh-relaxed);
  color: var(--color-text);
  margin-bottom: var(--space-2);
}

.legal-body__article li::marker {
  color: var(--color-accent);
}

.legal-body__article a {
  color: var(--color-primary);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.15em;
  transition: var(--transition-color);
}

.legal-body__article a:hover {
  color: var(--color-accent);
  text-decoration-thickness: 2px;
}

.legal-body__article a:focus-visible {
  outline: var(--focus-ring-width) var(--focus-ring-style) var(--color-focus-ring);
  outline-offset: var(--focus-ring-offset);
  border-radius: var(--radius-sm);
}

.legal-body__article strong {
  color: var(--color-dark);
  font-weight: var(--fw-semibold);
}

.legal-body__article code {
  font-family: var(--font-mono);
  font-size: 0.9em;
  background-color: var(--color-grey-lighter);
  color: var(--color-primary);
  padding: 0.125em 0.375em;
  border-radius: var(--radius-sm);
}

/* ============================================================================
   4. SPECIAL CONTENT BLOCKS
   ============================================================================ */
.legal-body__important {
  padding: var(--space-5) var(--space-6);
  background-color: var(--color-warning-bg);
  border-left: 4px solid var(--color-warning);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  margin-block: var(--space-6);
  font-size: var(--fs-base);
  line-height: var(--lh-relaxed);
}

.legal-body__address {
  display: block;
  padding: var(--space-5) var(--space-6);
  background-color: var(--color-bg-light);
  border: 1px solid var(--color-grey-light);
  border-radius: var(--radius-md);
  margin-block: var(--space-5);
  font-size: var(--fs-base);
  line-height: var(--lh-relaxed);
  font-style: normal;
}

.legal-body__address strong {
  display: inline-block;
  margin-bottom: var(--space-2);
  color: var(--color-primary);
}

.legal-body__closing {
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
  margin-top: var(--space-8);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-grey-light);
}

/* ============================================================================
   5. HELP STRIP (bottom of every legal page)
   ============================================================================ */
.legal-body__help {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
  margin-top: var(--space-12);
  padding: var(--space-6);
  background: linear-gradient(
    135deg,
    var(--color-primary) 0%,
    var(--color-primary-dark) 100%
  );
  color: var(--color-text-on-primary);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
  max-width: 72ch;
  margin-inline: auto;
}

.legal-body__help-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  flex-shrink: 0;
  background-color: rgba(255, 255, 255, 0.15);
  border: 1px solid rgba(255, 255, 255, 0.20);
  border-radius: var(--radius-full);
  color: var(--color-accent);
}

.legal-body__help-text {
  flex: 1;
  min-width: 0;
}

.legal-body__help-heading {
  font-size: var(--fs-lg);
  font-weight: var(--fw-bold);
  color: var(--color-text-on-primary);
  margin: 0 0 var(--space-1);
}

.legal-body__help-text p {
  font-size: var(--fs-base);
  line-height: var(--lh-relaxed);
  margin: 0;
  color: rgba(255, 255, 255, 0.92);
}

.legal-body__help-text a {
  color: var(--color-text-on-primary);
  font-weight: var(--fw-semibold);
  text-decoration: underline;
}

.legal-body__help-text a:hover {
  color: var(--color-accent);
}

.legal-body__help-text a:focus-visible {
  outline: var(--focus-ring-width) var(--focus-ring-style) var(--color-bg);
  outline-offset: var(--focus-ring-offset);
}

/* ============================================================================
   6. SITEMAP (overrides for sitemap.blade.php)
   ============================================================================ */
.legal-sitemap__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
}

@media (min-width: 48em) {
  .legal-sitemap__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-8) var(--space-10);
  }
}

@media (min-width: 64em) {
  .legal-sitemap__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

.legal-sitemap__group {
  padding: var(--space-5) var(--space-6);
  background-color: var(--color-bg);
  border: 1px solid var(--color-grey-light);
  border-radius: var(--radius-xl);
}

.legal-sitemap__heading {
  font-size: var(--fs-base) !important;
  font-weight: var(--fw-bold);
  color: var(--color-primary);
  margin: 0 0 var(--space-3) !important;
  padding: 0 !important;
  text-transform: uppercase;
  letter-spacing: var(--ls-wider);
  border-bottom: 1px solid var(--color-grey-light);
  padding-bottom: var(--space-2) !important;
}

.legal-sitemap__list {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.legal-sitemap__list li {
  padding: var(--space-1) 0;
  margin-bottom: 0 !important;
  font-size: var(--fs-sm) !important;
}

.legal-sitemap__list a {
  display: inline-block;
  padding: var(--space-1) 0;
  color: var(--color-dark) !important;
  text-decoration: none !important;
  transition: var(--transition-color), padding-left var(--duration-fast) var(--ease-out);
}

.legal-sitemap__list a:hover {
  color: var(--color-primary) !important;
  padding-left: var(--space-2);
}

.legal-sitemap__list a[aria-current="page"] {
  color: var(--color-accent) !important;
  font-weight: var(--fw-semibold);
}

.legal-sitemap__list span {
  color: var(--color-text-muted);
  font-size: var(--fs-sm);
}

.legal-sitemap__list em {
  color: var(--color-grey);
  font-style: italic;
  font-size: var(--fs-xs);
}

/* ============================================================================
   7. PRINT (legal pages need to print well — auditors print these)
   ============================================================================ */
@media print {
  .legal-header {
    background: transparent;
    border-bottom: 2px solid black;
    padding-block: var(--space-4);
  }

  .legal-header__breadcrumb,
  .legal-body__help {
    display: none;
  }

  .legal-header__updated {
    background: transparent;
    border: 1px solid black;
    color: black;
  }

  .legal-body__article h2,
  .legal-body__article h3 {
    page-break-after: avoid;
  }

  .legal-body__article p,
  .legal-body__article li {
    orphans: 3;
    widows: 3;
  }

  .legal-body__intro {
    background: transparent;
    border-left: 3px solid black;
  }

  .legal-body__important {
    background: transparent;
    border: 1px solid black;
  }

  .legal-body__address {
    background: transparent;
    border: 1px solid black;
  }

  .legal-sitemap__group {
    break-inside: avoid;
    background: transparent;
    border: 1px solid black;
  }
}

/* ============================================================================
   8. REDUCED MOTION
   ============================================================================ */
@media (prefers-reduced-motion: reduce) {
  .legal-body__article a,
  .legal-sitemap__list a {
    transition: none;
  }
}

/* ============================================================================
   9. HIGH-CONTRAST FALLBACK
   ============================================================================ */
@media (prefers-contrast: more), (forced-colors: active) {
  .legal-header {
    background: Canvas;
  }

  .legal-body__intro,
  .legal-body__important,
  .legal-body__address,
  .legal-sitemap__group {
    background: Canvas;
    border: 2px solid CanvasText;
    color: CanvasText;
  }

  .legal-body__help {
    background: Canvas;
    color: CanvasText;
    border: 2px solid CanvasText;
  }
}