@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap");

@font-face {
  font-family: "League Spartan";
  src: url("/fonts/league-spartan-400.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "League Spartan";
  src: url("/fonts/league-spartan-700.ttf") format("truetype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Fineday Two";
  src: url("/fonts/fineday-two.woff2") format("woff2"),
       url("/fonts/fineday-two.woff") format("woff"),
       url("/fonts/fineday-two.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

:root {
  --color-primary: #1b6598;
  --color-primary-strong: #02356c;
  --color-accent: #779e21;
  --color-rock-dark: #243e5a;
  --color-text: #1f2f43;
  --color-muted: #3d556d;
  --color-bg: #edf4f8;
  --color-surface: #ffffff;
  --color-line: #c9d9e4;

  --font-body: "Inter", "Segoe UI", Helvetica, Arial, sans-serif;
  --font-heading: "League Spartan", "Arial Black", sans-serif;
  --font-logo-script: "Fineday Two", "Kaushan Script", cursive;

  --hero-figure-width-large: 80%;
  --hero-figure-width-medium: 70%;
  --hero-figure-width-compact: 60%;
  --hero-figure-width-small: 40%;
}

body {
  font-family: var(--font-body);
  color: var(--color-text);
  background: linear-gradient(180deg, #f5f9fc 0%, #edf4f8 100%);
}

h1,
h2,
h3,
h4,
h5,
h6,
.main__title,
.post__title {
  color: var(--color-rock-dark);
  font-family: var(--font-heading);
  letter-spacing: 0.01em;
}

p,
li,
.main__content,
.post__content,
.footer,
.footer a,
input,
textarea,
button {
  font-family: var(--font-body);
}

.header {
  background: transparent;
  z-index: 50;
}

.header .container {
  padding-top: 0;
  padding-bottom: 0;
}

.logo {
  text-align: center;
  padding: 0.5rem 0.75rem 0.25rem;
}

.logo__link {
  display: inline-block;
  margin: 0 auto;
}

.logo__img {
  width: auto;
  max-height: 340px;
  display: block;
}

.header .menu {
  border-bottom: 0;
  margin-top: 0.25rem;
}

.header .menu__list {
  margin: 0;
  padding: 0.15rem;
  background: var(--color-primary);
  border-radius: 999px;
  box-shadow: 0 6px 16px rgba(47, 70, 88, 0.16);
}

.menu__item,
.menu__item:first-child {
  border: 0;
}

.menu__link {
  font-family: var(--font-heading);
  font-weight: 700;
  text-transform: none;
  letter-spacing: 0.02em;
  color: #fff;
  border-radius: 999px;
  padding: 0.55rem 0.95rem;
}

.menu__item:hover,
.menu__item--active {
  background: transparent;
}

.menu__item:hover .menu__link,
.menu__item--active .menu__link,
.menu__link:focus {
  background: var(--color-primary-strong);
  color: #fff;
}

.menu__hamburger {
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.28rem;
  min-height: 1.15rem;
}

.menu__hamburger span {
  display: block;
  width: 1.35rem;
  height: 0.14rem;
  border-radius: 999px;
  background: currentColor;
}

@media screen and (min-width: 767px) {
  .header .menu__list {
    justify-content: center;
  }
}

.collectif-home {
  display: grid;
  gap: 1.5rem;
}

.collectif-hero,
.collectif-callout,
.collectif-card {
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: 14px;
  box-shadow: 0 10px 26px rgba(47, 70, 88, 0.08);
}

.collectif-hero h1 {
  margin: 0 0 0.75rem;
  font-family: var(--font-heading);
}

.collectif-lead {
  margin: 0;
  color: var(--color-muted);
  line-height: 1.6;
}

.collectif-actions {
  margin-top: 0.9rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.collectif-actions--hero-outside {
  justify-content: center;
  margin-top: -0.2rem;
}

.collectif-actions--after-grid {
  justify-content: center;
  margin-top: 1rem;
}

.collectif-btn,
.collectif-btn:link,
.collectif-btn:visited,
.collectif-btn.secondary,
.collectif-btn.secondary:link,
.collectif-btn.secondary:visited,
.collectif-callout .collectif-actions .collectif-btn,
.collectif-callout .collectif-actions .collectif-btn:link,
.collectif-callout .collectif-actions .collectif-btn:visited,
.collectif-actions--after-grid .collectif-btn,
.collectif-actions--after-grid .collectif-btn:link,
.collectif-actions--after-grid .collectif-btn:visited,
.collectif-actions--hero-outside .collectif-btn,
.collectif-actions--hero-outside .collectif-btn:link,
.collectif-actions--hero-outside .collectif-btn:visited,
.collectif-actions--hero-outside .collectif-btn.secondary,
.collectif-actions--hero-outside .collectif-btn.secondary:link,
.collectif-actions--hero-outside .collectif-btn.secondary:visited {
  background: var(--color-accent);
  color: #fff;
  border: 0;
  border-radius: 999px;
  text-decoration: none;
  padding: 0.65rem 1rem;
  font-family: var(--font-heading);
  font-weight: 700;
  letter-spacing: 0.015em;
  transition: background-color 0.2s ease, transform 0.2s ease;
}

.collectif-btn:hover,
.collectif-btn:focus,
.collectif-btn.secondary:hover,
.collectif-btn.secondary:focus,
.collectif-callout .collectif-actions .collectif-btn:hover,
.collectif-callout .collectif-actions .collectif-btn:focus,
.collectif-actions--after-grid .collectif-btn:hover,
.collectif-actions--after-grid .collectif-btn:focus,
.collectif-actions--hero-outside .collectif-btn:hover,
.collectif-actions--hero-outside .collectif-btn:focus,
.collectif-actions--hero-outside .collectif-btn.secondary:hover,
.collectif-actions--hero-outside .collectif-btn.secondary:focus {
  background: var(--color-primary);
  color: #fff;
  transform: translateY(-1px);
}

.collectif-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.collectif-card {
  padding: 1rem;
}

.collectif-card > :last-child {
  margin-bottom: 0;
}

.collectif-card--install,
.collectif-card--sensibilisation,
.collectif-card--reconditionnement {
  display: flex;
  flex-direction: column;
}

.collectif-card h3 {
  margin-top: 0;
  margin-bottom: 0.5rem;
}

.collectif-card-media {
  display: block;
  width: 100%;
  height: auto;
  margin-top: 0.85rem;
  border-radius: 10px;
}

.collectif-card-media--half {
  width: 60%;
  margin-top: auto;
  margin-left: auto;
  margin-right: auto;
}

.collectif-callout {
  padding: 1rem;
}

.collectif-callout ul {
  margin: 0.5rem 0 0.75rem 1.2rem;
}

.collectif-callout-media {
  display: block;
  width: min(240px, 70%);
  height: auto;
  margin: 1rem auto 0;
}

.collectif-why-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(280px, 0.75fr);
  gap: 1rem;
  align-items: start;
}

.collectif-why-text > :first-child {
  margin-top: 0;
}

.collectif-why-media {
  margin: 0;
}

.collectif-why-media img {
  width: 100%;
  display: block;
  border-radius: 0;
  border: 0;
}

.collectif-form {
  display: grid;
  gap: 0.5rem;
  margin: 1rem 0;
}

.collectif-form input,
.collectif-form textarea {
  border: 1px solid var(--color-line);
  border-radius: 10px;
  padding: 0.6rem;
  font: inherit;
}

.collectif-contact-layout {
  display: grid;
  grid-template-columns: minmax(240px, 0.9fr) minmax(0, 1.1fr);
  gap: 1.2rem;
  align-items: start;
}

.collectif-contact-aside p:first-of-type,
.collectif-contact-layout h2 {
  margin-top: 0;
}

@media screen and (max-width: 900px) {
  .collectif-contact-layout {
    grid-template-columns: 1fr;
  }
}

.footer {
  background: var(--color-primary);
  color: #fff;
}

.footer a {
  color: #fff;
}

.footer a:hover,
.footer a:focus {
  color: #95c0d1;
}

.font-fineday-two {
  font-family: var(--font-logo-script);
}

.font-league-spartan {
  font-family: var(--font-heading);
}

@media screen and (max-width: 760px) {
  .collectif-why-layout {
    grid-template-columns: 1fr;
  }
}

/* ===== V2 Banner Refresh ===== */
.header {
  position: relative;
}

.header::before {
  content: "";
  position: absolute;
  inset: -30px 0 auto 0;
  height: 360px;
  z-index: -1;
  background:
    radial-gradient(1200px 300px at 20% 0%, rgba(148, 192, 209, 0.35), transparent 60%),
    radial-gradient(900px 260px at 80% 0%, rgba(119, 158, 33, 0.22), transparent 60%),
    linear-gradient(180deg, #f8fbfd 0%, rgba(248, 251, 253, 0) 100%);
}

.logo {
  padding: 0.35rem 0.75rem 0.15rem;
}

.logo__img {
  max-height: 240px;
}

.header .menu {
  margin-top: 0.15rem;
}

.header .menu__list {
  padding: 0.2rem;
  border-radius: 999px;
  backdrop-filter: blur(4px);
  box-shadow: 0 8px 24px rgba(2, 53, 108, 0.18);
}

.menu__link {
  padding: 0.5rem 0.9rem;
  font-size: 0.95rem;
}

.collectif-hero {
  position: relative;
  padding: 1.8rem;
  border-radius: 18px;
  border: 1px solid #c9d9e4;
  box-shadow: 0 16px 36px rgba(36, 62, 90, 0.12);
  background: linear-gradient(140deg, #ffffff 0%, #f1f7fb 68%, #ebf4fa 100%);
  overflow: hidden;
}

.collectif-hero::after {
  content: "";
  position: absolute;
  width: 340px;
  height: 340px;
  right: -120px;
  top: -120px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(80, 175, 219, 0.20) 0%, rgba(80, 175, 219, 0) 70%);
}

.collectif-hero h1 {
  position: relative;
  z-index: 1;
  margin-bottom: 0.7rem;
  max-width: none;
  font-size: clamp(1.7rem, 3vw, 2.4rem);
}

.collectif-lead {
  position: relative;
  z-index: 1;
  max-width: none;
  font-size: 1.06rem;
}

.collectif-hero-subnav {
  position: relative;
  z-index: 1;
  margin: 0.95rem 0 0;
  font-size: 0.98rem;
  font-weight: 600;
}

.collectif-hero-subnav a {
  color: var(--color-primary-strong);
  text-decoration: none;
  border-bottom: 1px solid rgba(2, 53, 108, 0.35);
}

.collectif-hero-subnav a:hover,
.collectif-hero-subnav a:focus {
  color: var(--color-primary);
  border-bottom-color: var(--color-primary);
}

.collectif-actions--after-grid {
  margin-top: 1.2rem;
}

@media screen and (max-width: 900px) {
  .logo__img {
    max-height: 210px;
  }

  .header .menu__list {
    border-radius: 14px;
  }

  .collectif-hero {
    padding: 1.25rem;
    border-radius: 14px;
  }

  .collectif-hero h1 {
    max-width: none;
  }
}

/* Header variant: logo + external title */
.logo--mixed {
  text-align: left;
}

.logo--mixed .logo__link {
  display: inline-flex;
  align-items: center;
  gap: 0.9rem;
  margin: 0 auto;
}

.logo--mixed .logo__img {
  max-height: 190px;
}

.logo--mixed .logo__text {
  padding: 0;
}

.logo__title {
  font-family: var(--font-heading);
  font-size: clamp(1.55rem, 2.5vw, 2.2rem);
  color: var(--color-rock-dark);
  line-height: 1.02;
  margin: 0;
}

.logo__tagline {
  margin-top: 0.35rem;
  font-family: var(--font-body);
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  color: var(--color-primary-strong);
  text-transform: none;
}

@media screen and (max-width: 900px) {
  .logo--mixed .logo__link {
    gap: 0.7rem;
  }

  .logo--mixed .logo__img {
    max-height: 150px;
  }

  .logo__tagline {
    font-size: 0.86rem;
  }
}

@media screen and (max-width: 640px) {
  .logo--mixed .logo__link {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 0.35rem;
  }

  .logo--mixed .logo__img {
    max-height: 132px;
  }
}

/* Environment watermark (recette/dev) */
.header__watermark {
  position: absolute;
  top: 3rem;
  right: -1.2rem;
  transform: rotate(45deg);
  font-family: var(--font-heading);
  font-size: 0.63rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(199, 59, 92, 0.55);
  background: rgba(255, 255, 255, 0.6);
  border: 2px solid rgba(199, 59, 92, 0.4);
  border-radius: 8px;
  padding: 0.2rem 0.6rem;
  z-index: 2;
  pointer-events: none;
}

@media screen and (max-width: 900px) {
  .header__watermark {
    top: 3rem;
    right: -1.6rem;
    font-size: 0.525rem;
  }
}

.collectif-page {
  display: grid;
  gap: 1.5rem;
}

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

.collectif-callout--media {
  overflow: hidden;
}

.collectif-media-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.8fr);
  gap: 1rem;
  align-items: start;
}

.collectif-media-layout--hero {
  grid-template-columns: minmax(0, 1.2fr) minmax(240px, 0.8fr);
  align-items: center;
}

.collectif-media-layout--align-center {
  align-items: center;
}

.collectif-media-layout--balanced {
  align-items: center;
  grid-template-columns: minmax(300px, 0.9fr) minmax(0, 1.1fr);
}

.collectif-illu {
  margin: 0;
}

.collectif-illu img {
  width: 100%;
  display: block;
  border: 1px solid var(--color-line);
  border-radius: 10px;
  background: #fff;
}

.collectif-illu--hero img {
  border: 0;
  border-radius: 0;
  background: transparent;
  max-width: 100%;
}

.collectif-illu--plain,
.collectif-illu--plain img {
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.collectif-illu--center {
  display: flex;
  justify-content: center;
  align-items: center;
}

.collectif-illu--size-large img {
  width: 91%;
  margin: 0 auto;
}

.collectif-illu--size-small img {
  width: 35%;
  margin: 0 auto;
}

.collectif-illu--size-open img {
  width: 100%;
  height: auto;
  max-height: none;
  object-fit: contain;
  display: block;
  margin: 0 auto;
}

.collectif-illu--tools img {
  width: var(--hero-figure-width-large, 80%);
  margin: 0 auto;
}

.collectif-illu--agenda img {
  width: var(--hero-figure-width-medium, 70%);
  margin: 0 auto;
}

.collectif-illu--contact-hero img {
  width: var(--hero-figure-width-compact, 60%);
  margin: 0 auto;
}

.collectif-illu--come img {
  width: var(--hero-figure-width-small, 40%);
  margin: 0 auto;
}

.collectif-illu--app img {
  width: 100%;
  max-width: 320px;
  margin: 0 auto;
}

@media screen and (max-width: 900px) {
  .collectif-duo {
    grid-template-columns: 1fr;
  }

  .collectif-media-layout {
    grid-template-columns: 1fr;
  }

  .collectif-media-layout--hero {
    grid-template-columns: 1fr;
  }

  .collectif-media-layout--balanced {
    grid-template-columns: 1fr;
  }

  .collectif-actions {
    justify-content: center;
  }

  .collectif-card-media--half {
    width: min(60%, 180px);
  }

  .collectif-callout-media {
    width: min(220px, 60%);
  }

  .collectif-illu--tools img {
    width: 90%;
  }

  .collectif-illu--agenda img {
    width: min(80%, 260px);
  }

  .collectif-illu--contact-hero img {
    width: min(72%, 220px);
  }

  .collectif-illu--come img {
    width: min(52%, 170px);
  }
}

/* Alternate layout: reverse text/illustration on one section out of two */
.collectif-media-layout--reverse > .collectif-illu {
  order: -1;
}

@media screen and (max-width: 900px) {
  .collectif-media-layout--reverse > .collectif-illu {
    order: 0;
  }
}

.collectif-page--collectif .collectif-media-layout--reverse {
  grid-template-columns: minmax(220px, 0.6fr) minmax(0, 1.4fr);
  align-items: stretch;
  column-gap: 1.8rem;
}

.collectif-page--collectif .collectif-media-layout--reverse:has(.collectif-illu--open) {
  grid-template-columns: minmax(320px, 0.9fr) minmax(0, 1.1fr);
}

.collectif-page--collectif .collectif-media-layout--reverse .collectif-illu {
  height: 100%;
}

.collectif-page--collectif .collectif-media-layout--reverse .collectif-illu img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  background: transparent;
}
.collectif-page--collectif img[src="/images/super-tux.png"] {
  width: 80%;
  margin: 0 auto;
}

.collectif-page--collectif img[src="/images/super-tux-open.png"] {
  width: 100%;
  height: auto;
  margin: 0 auto;
  object-fit: contain;
  display: block;
}

.collectif-page--collectif .collectif-media-layout:has(.collectif-illu--teaching) {
  grid-template-columns: minmax(0, 1.05fr) minmax(340px, 0.95fr);
}

.collectif-page--collectif .collectif-media-layout--reverse:has(.collectif-illu--welcome) {
  grid-template-columns: minmax(320px, 0.95fr) minmax(0, 1.05fr);
  grid-template-areas:
    "image text"
    "image actions";
  align-items: center;
}

.collectif-page--collectif .collectif-illu--teaching img {
  width: 100%;
  height: auto;
  margin: 0 auto;
  object-fit: contain;
  display: block;
}

.collectif-page--collectif .collectif-illu--welcome img {
  width: 100%;
  height: auto;
  margin: 0 auto;
  object-fit: contain;
  display: block;
  border: 0;
  background: transparent;
}

.collectif-page--collectif .collectif-join-text {
  grid-area: text;
}

.collectif-page--collectif .collectif-illu--welcome {
  grid-area: image;
}

.collectif-page--collectif .collectif-actions--join {
  grid-area: actions;
  justify-content: flex-start;
}

@media screen and (max-width: 900px) {
  .collectif-page--collectif .collectif-media-layout:has(.collectif-illu--teaching) {
    grid-template-columns: 1fr;
  }

  .collectif-page--collectif .collectif-media-layout--reverse:has(.collectif-illu--welcome) {
    grid-template-columns: 1fr;
    grid-template-areas:
      "text"
      "image"
      "actions";
  }
}

.collectif-page--collectif .collectif-media-layout--reverse .collectif-illu--open {
  height: auto;
  align-self: center;
  width: 100%;
  margin-left: 0;
}

@media screen and (max-width: 900px) {
  .collectif-page--collectif .collectif-media-layout--reverse:has(.collectif-illu--open) {
    grid-template-columns: 1fr;
  }
}

@media screen and (max-width: 766px) {
  .header .menu {
    position: relative;
    z-index: 60;
  }

  .header .menu__btn {
    background: transparent;
    color: var(--color-rock-dark);
  }

  .header .menu__btn-title {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    padding: 0.7rem 0.15rem 0.7rem 1rem;
    text-align: right;
    font-family: var(--font-heading);
    font-weight: 700;
    color: var(--color-rock-dark);
  }

  .header .js .menu__list {
    position: absolute;
    top: calc(100% + 0.25rem);
    right: 0;
    left: auto;
    width: min(18rem, calc(100vw - 1.5rem));
    background: var(--color-primary);
    border-radius: 18px;
    box-shadow: 0 12px 28px rgba(2, 53, 108, 0.22);
    transform-origin: top right;
    overflow: hidden;
    z-index: 1000;
  }

  .header .menu__item,
  .header .menu__item:first-child {
    border: 0;
  }

  .header .menu__link {
    padding: 0.8rem 1rem;
    text-align: right;
    white-space: normal;
  }
}

.cookie-banner {
  position: fixed;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1200;
}

.cookie-banner__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  max-width: 1080px;
  margin: 0 auto;
  padding: 0.95rem 1rem;
  background: rgba(36, 62, 90, 0.96);
  color: #fff;
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: 0 -8px 24px rgba(18, 35, 56, 0.18);
}

.cookie-banner__text {
  margin: 0;
  color: #fff;
  font-size: 0.98rem;
  line-height: 1.5;
}

.cookie-banner__text a {
  color: #fff;
  text-decoration: underline;
}

.cookie-banner__actions {
  display: flex;
  flex: 0 0 auto;
}

.cookie-banner__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.72rem 1rem;
  border: 0;
  border-radius: 999px;
  background: var(--color-accent);
  color: #fff;
  font-family: var(--font-heading);
  font-weight: 700;
  cursor: pointer;
}

.cookie-banner__button:hover,
.cookie-banner__button:focus {
  background: var(--color-primary);
  color: #fff;
}

@media screen and (max-width: 766px) {
  .cookie-banner {
    right: 0;
    bottom: 0;
    left: 0;
  }

  .cookie-banner__inner {
    flex-direction: column;
    align-items: stretch;
    padding: 0.9rem;
  }

  .cookie-banner__actions {
    justify-content: center;
  }

  .cookie-banner__button {
    width: 100%;
  }
}

.footer__social {
  display: flex;
  align-items: center;
  justify-content: center;
}

.footer__social-link {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  color: #fff;
  text-decoration: none;
  font-weight: 600;
}

.footer__social-link:hover,
.footer__social-link:focus {
  color: #fff;
  text-decoration: underline;
}

.footer__social-icon {
  width: 1.1rem;
  height: 1.1rem;
  fill: currentColor;
}

.collectif-resource-list {
  list-style: none;
  margin: 1.25rem 0 0;
  padding: 0;
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.collectif-callout--resources > h2 {
  margin-bottom: 0.6rem;
}

.collectif-resource-toc {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.collectif-resource-toc__link {
  display: inline-flex;
  align-items: center;
  padding: 0.55rem 0.9rem;
  border-radius: 999px;
  background: rgba(36, 62, 90, 0.08);
  color: var(--color-title);
  text-decoration: none;
  font-family: "League Spartan", sans-serif;
}

.collectif-resource-toc__link:hover,
.collectif-resource-toc__link:focus {
  background: rgba(135, 171, 54, 0.18);
  color: var(--color-menu);
}

.collectif-resource-group + .collectif-resource-group {
  margin-top: 1.5rem;
  padding-top: 1.25rem;
  border-top: 1px solid rgba(27, 101, 152, 0.12);
}

.collectif-resource-group {
  padding: 1rem 1.05rem;
  border-radius: 18px;
  background: rgba(135, 171, 54, 0.06);
}

.collectif-resource-group h3 {
  margin: 0 0 0.55rem;
  color: var(--color-title);
}

.collectif-resource-item {
  border: 1px solid rgba(27, 101, 152, 0.16);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
}

.collectif-resource-link {
  display: grid;
  grid-template-columns: 70px minmax(0, 1fr);
  align-items: center;
  gap: 1rem;
  padding: 1rem 1.1rem;
  color: var(--color-title);
  text-decoration: none;
}

.collectif-resource-link:hover,
.collectif-resource-link:focus {
  background: rgba(135, 171, 54, 0.08);
  color: var(--color-menu);
}

.collectif-resource-logo {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 70px;
  height: 70px;
  padding: 0.6rem;
  border-radius: 16px;
  background: #fff;
  border: 1px solid rgba(27, 101, 152, 0.12);
}

.collectif-resource-logo img {
  max-width: 100%;
  max-height: 100%;
  display: block;
}

.collectif-resource-copy {
  display: block;
  min-width: 0;
}

.collectif-resource-inline {
  display: inline;
}

.collectif-resource-title {
  font-family: "League Spartan", sans-serif;
  font-size: 1.05rem;
  line-height: 1.2;
}

.collectif-resource-badge {
  display: inline-flex;
  margin-left: 0.55rem;
  padding: 0.18rem 0.45rem;
  border-radius: 999px;
  background: rgba(227, 107, 1, 0.12);
  color: #a54c00;
  font-size: 0.78rem;
  font-weight: 700;
  vertical-align: middle;
}

.collectif-resource-description {
  color: var(--color-text);
  line-height: 1.5;
}

@media screen and (max-width: 980px) {
  .collectif-resource-list {
    grid-template-columns: 1fr;
  }
}

@media screen and (max-width: 640px) {
  .collectif-resource-link {
    grid-template-columns: 1fr;
    justify-items: start;
  }
}

.collectif-illu--read img {
  width: 36%;
  margin: 0 auto;
}
