/* /public_html/assets/css/legal-pages.css */
/* V48.8.3 — Documents légaux EDQ : socle visuel commun. */

:root {
  color-scheme: light;
  --legal-bg: #eef6ff;
  --legal-bg-2: #fff7ed;
  --legal-card: rgba(255, 255, 255, .92);
  --legal-card-strong: rgba(255, 255, 255, .98);
  --legal-border: rgba(37, 99, 235, .14);
  --legal-border-strong: rgba(14, 165, 233, .28);
  --legal-text: #0f172a;
  --legal-muted: #64748b;
  --legal-soft: #f8fafc;
  --legal-accent: #0ea5e9;
  --legal-accent-strong: #0369a1;
  --legal-warning: #92400e;
  --legal-warning-bg: rgba(251, 191, 36, .16);
  --legal-danger: #991b1b;
  --legal-danger-bg: rgba(248, 113, 113, .13);
  --legal-success: #047857;
  --legal-radius-xl: 1.65rem;
  --legal-radius-lg: 1.1rem;
  --legal-shadow: 0 26px 72px rgba(15, 23, 42, .12);
}

* {
  box-sizing: border-box;
}

html {
  min-height: 100%;
  background:
    radial-gradient(circle at 14% 8%, rgba(14, 165, 233, .22), transparent 32rem),
    radial-gradient(circle at 86% 0%, rgba(244, 114, 182, .16), transparent 28rem),
    linear-gradient(135deg, var(--legal-bg), var(--legal-bg-2));
}

body {
  min-height: 100%;
  margin: 0;
  color: var(--legal-text);
  background: transparent;
  font-family: Montserrat, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  line-height: 1.62;
}

button,
a {
  -webkit-tap-highlight-color: transparent;
}

.legal-page {
  width: min(100%, 1020px);
  margin: 0 auto;
  padding: max(1.1rem, env(safe-area-inset-top, 0px)) 1rem 4rem;
}

.legal-card {
  overflow: hidden;
  border: 1px solid var(--legal-border);
  border-radius: var(--legal-radius-xl);
  background: var(--legal-card);
  box-shadow: var(--legal-shadow);
  backdrop-filter: blur(24px) saturate(1.1);
}

.legal-hero {
  display: grid;
  gap: 1rem;
  padding: clamp(1.25rem, 3.4vw, 2.2rem);
  border-bottom: 1px solid rgba(148, 163, 184, .16);
  background:
    radial-gradient(circle at 15% 0%, rgba(14, 165, 233, .18), transparent 24rem),
    linear-gradient(135deg, rgba(255,255,255,.82), rgba(248,250,252,.56));
}

.legal-brand {
  display: flex;
  align-items: center;
  gap: .9rem;
}

.legal-logo {
  display: block;
  width: 8.8rem;
  height: 3rem;
  color: color-mix(in srgb, var(--legal-accent-strong) 70%, #0f172a 30%);
  background: linear-gradient(135deg, currentColor, color-mix(in srgb, currentColor 74%, #0f172a 16%));
  -webkit-mask: url('/assets/img/logo.svg') center / contain no-repeat;
  mask: url('/assets/img/logo.svg') center / contain no-repeat;
}

.legal-kicker {
  margin: 0;
  color: var(--legal-accent-strong);
  font-size: .72rem;
  font-weight: 950;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.legal-title {
  margin: 0;
  max-width: 760px;
  font-size: clamp(1.82rem, 5vw, 3rem);
  font-weight: 950;
  line-height: 1.02;
  letter-spacing: -.045em;
}

.legal-subtitle {
  margin: 0;
  max-width: 760px;
  color: var(--legal-muted);
  font-size: .98rem;
  font-weight: 650;
}

.legal-meta {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
  margin: .15rem 0 0;
  padding: 0;
  list-style: none;
}

.legal-pill {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  min-height: 2rem;
  padding: .38rem .68rem;
  border: 1px solid rgba(14, 165, 233, .18);
  border-radius: 999px;
  color: #075985;
  background: rgba(224, 242, 254, .72);
  font-size: .72rem;
  font-weight: 850;
}

.legal-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  margin-top: .3rem;
}

.legal-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .48rem;
  min-height: 2.42rem;
  padding: .58rem .86rem;
  border: 1px solid rgba(15, 23, 42, .12);
  border-radius: 999px;
  color: var(--legal-text);
  background: rgba(255, 255, 255, .86);
  box-shadow: 0 10px 24px rgba(15, 23, 42, .06);
  font: inherit;
  font-size: .8rem;
  font-weight: 850;
  text-decoration: none;
  cursor: pointer;
}

.legal-button:hover,
.legal-button:focus-visible {
  border-color: var(--legal-border-strong);
  background: white;
  outline: none;
}

.legal-button--primary {
  border-color: color-mix(in srgb, var(--legal-accent) 54%, transparent);
  color: #f8fafc;
  background: linear-gradient(135deg, var(--legal-accent), var(--legal-accent-strong));
}

.legal-content {
  display: grid;
  gap: 1rem;
  padding: clamp(1rem, 3vw, 2rem);
}

.legal-toc {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .55rem;
  margin: 0 0 .25rem;
}

.legal-toc a {
  display: flex;
  align-items: center;
  gap: .55rem;
  min-height: 2.85rem;
  padding: .62rem .72rem;
  border: 1px solid rgba(148, 163, 184, .16);
  border-radius: var(--legal-radius-lg);
  color: inherit;
  background: rgba(248, 250, 252, .76);
  font-size: .76rem;
  font-weight: 850;
  text-decoration: none;
}

.legal-toc i,
.legal-section h2 i,
.legal-note i {
  color: var(--legal-accent-strong);
}

.legal-section {
  padding: clamp(.95rem, 2.6vw, 1.35rem);
  border: 1px solid rgba(148, 163, 184, .16);
  border-radius: var(--legal-radius-lg);
  background: rgba(255, 255, 255, .64);
}

.legal-section h2 {
  display: flex;
  align-items: center;
  gap: .62rem;
  margin: 0 0 .72rem;
  font-size: 1.08rem;
  line-height: 1.18;
}

.legal-section h3 {
  margin: 1rem 0 .45rem;
  color: #1e293b;
  font-size: .95rem;
  line-height: 1.25;
}

.legal-section p,
.legal-section ul,
.legal-section ol {
  margin-top: .48rem;
  margin-bottom: .48rem;
}

.legal-section ul,
.legal-section ol {
  padding-left: 1.18rem;
}

.legal-section li + li {
  margin-top: .26rem;
}

.legal-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .72rem;
}

.legal-info {
  min-width: 0;
  padding: .74rem .78rem;
  border: 1px solid rgba(148, 163, 184, .16);
  border-radius: .9rem;
  background: rgba(248, 250, 252, .82);
}

.legal-info span {
  display: block;
  margin-bottom: .16rem;
  color: var(--legal-muted);
  font-size: .66rem;
  font-weight: 950;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.legal-info strong,
.legal-info code {
  overflow-wrap: anywhere;
}

.legal-info strong {
  color: var(--legal-text);
}

.legal-table-wrap {
  overflow-x: auto;
  margin-top: .7rem;
  border: 1px solid rgba(148, 163, 184, .16);
  border-radius: .95rem;
  background: white;
}

.legal-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 680px;
  font-size: .82rem;
}

.legal-table th,
.legal-table td {
  padding: .72rem .78rem;
  border-bottom: 1px solid rgba(148, 163, 184, .16);
  text-align: left;
  vertical-align: top;
}

.legal-table th {
  color: #334155;
  background: rgba(241, 245, 249, .92);
  font-size: .7rem;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.legal-table tr:last-child td {
  border-bottom: 0;
}

.legal-note {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: .72rem;
  align-items: start;
  padding: .86rem .9rem;
  border: 1px solid rgba(14, 165, 233, .2);
  border-radius: var(--legal-radius-lg);
  color: #075985;
  background: rgba(224, 242, 254, .64);
  font-size: .86rem;
  font-weight: 650;
}

.legal-note--warning {
  border-color: rgba(245, 158, 11, .25);
  color: var(--legal-warning);
  background: var(--legal-warning-bg);
}

.legal-note--danger {
  border-color: rgba(239, 68, 68, .22);
  color: var(--legal-danger);
  background: var(--legal-danger-bg);
}

.legal-note p {
  margin: 0;
}

.legal-code,
code {
  display: inline-block;
  max-width: 100%;
  padding: .12rem .38rem;
  border-radius: .38rem;
  color: #075985;
  background: rgba(14, 165, 233, .09);
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: .88em;
  overflow-wrap: anywhere;
}

.legal-placeholder {
  color: var(--legal-warning);
  font-weight: 850;
}

.legal-value {
  color: var(--legal-text);
  font-weight: 850;
}

.legal-footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem .85rem;
  justify-content: center;
  padding: 1.1rem clamp(1rem, 3vw, 2rem) 1.35rem;
  border-top: 1px solid rgba(148, 163, 184, .16);
  color: var(--legal-muted);
  background: rgba(248, 250, 252, .58);
  font-size: .78rem;
  font-weight: 850;
}

.legal-footer-links a {
  color: var(--legal-accent-strong);
  text-decoration: none;
}

.legal-footer-links a:hover,
.legal-footer-links a:focus-visible {
  text-decoration: underline;
  outline: none;
}

@media (max-width: 760px) {
  .legal-page {
    padding-inline: .72rem;
  }

  .legal-card {
    border-radius: 1.25rem;
  }

  .legal-hero {
    padding: 1.05rem;
  }

  .legal-logo {
    width: 7.8rem;
    height: 2.75rem;
  }

  .legal-toc,
  .legal-grid {
    grid-template-columns: 1fr;
  }

  .legal-section {
    padding: .9rem;
  }

  .legal-table {
    min-width: 620px;
  }
}

@media print {
  :root {
    --legal-bg: #fff;
    --legal-bg-2: #fff;
    --legal-card: #fff;
    --legal-shadow: none;
  }

  html,
  body {
    background: #fff !important;
  }

  .legal-page {
    max-width: none;
    padding: 0;
  }

  .legal-card,
  .legal-section,
  .legal-note,
  .legal-info,
  .legal-table-wrap {
    border-color: #cbd5e1 !important;
    box-shadow: none !important;
  }

  .legal-actions,
  .legal-toc,
  .legal-footer-links {
    display: none !important;
  }
}
