/* Pose les fondations visuelles globales : variables, corps de page, liens et conteneurs communs. */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  overflow-x: hidden;
}

body {
  min-height: 100vh;
  margin: 0;
  overflow-x: hidden;
  color: var(--text);
  font-family: var(--font-body);
  line-height: 1.6;
  background:
    radial-gradient(820px 560px at 16% 18%, rgba(34, 211, 238, 0.13), transparent 64%),
    radial-gradient(760px 520px at 82% 16%, rgba(180, 76, 255, 0.17), transparent 64%),
    radial-gradient(820px 600px at 50% 96%, rgba(255, 31, 114, 0.15), transparent 70%),
    linear-gradient(145deg, #040003 0%, #100208 34%, #1b0624 68%, #320820 100%);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background-image:
    radial-gradient(circle at 18% 20%, rgba(34, 211, 238, 0.08), transparent 22%),
    radial-gradient(circle at 78% 16%, rgba(122, 92, 255, 0.1), transparent 25%),
    radial-gradient(circle at 50% 82%, rgba(255, 31, 114, 0.08), transparent 28%);
  background-size: 100% 100%;
  mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.68), transparent 78%);
}

img {
  display: block;
  max-width: 100%;
  height: auto;
}

a {
  color: var(--link);
  overflow-wrap: anywhere;
  text-decoration-color: rgba(50, 217, 200, 0.45);
  text-underline-offset: 0.18em;
  transition: color 180ms ease, text-decoration-color 180ms ease;
}

a:hover {
  color: var(--link-hover);
  text-decoration-color: currentColor;
}

#content {
  overflow: clip;
}

p,
li,
dd,
figcaption,
.df-article,
.df-panel,
.df-teaser,
.df-card {
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: normal;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  min-width: 0;
  overflow-wrap: anywhere;
  text-wrap: balance;
}

::selection {
  color: #071016;
  background: var(--secondary);
}

.df-container,
.df-article,
.df-home__inner,
.df-nav__inner,
.df-footer__inner {
  width: var(--container);
  margin-inline: auto;
}
