/*
  Charte Corsica Ferries :
  Couleurs (web slide + éléments graphiques §1.2) :
  Corsica Yellow        #FFED00 (Pantone 102 C) — usages privilégiés : CTA, survol, sélection
  Corsica Blue (web)    #223266 — UI digitale ·  Corsica Blue (print) #252B6A — autres supports
  Lightgrey/Darkgrey    #F3F3F3 · #575757  ·  Bleu select #DCE0ED (≈DCE2ED) · Light blue #F1F3F8
  États (§1.2)          succès #57820A · danger #CE1D13 · attention #D17500
  Ombres : digital #0C2D5D · UI cartes (§1.2 ombre bleu sélect.)  2px 3px 10px #DCE0ED
*/
:root {
  --cf-white: #ffffff;
  --cf-yellow: #ffed00;
  --cf-navy: #223266;
  --cf-navy-rgb: 34, 50, 102;
  --cf-black: #20201e;

  --cf-bg-page: #ffffff;
  /* Bandes hub / listes : gris charte */
  --cf-bg-soft-grey: #f3f3f3;
  /* Fond lecteur (hors carte blanche) : bleu très clair charte */
  --cf-bg-soft-blue: #f1f3f8;
  --cf-ink: var(--cf-navy);
  --cf-ink-muted: #575757;
  /* Alias pour cohérence avec l’ancien nom des variables */
  --cf-blue: var(--cf-navy);
  --cf-blue-deep: #1a2249;
  --cf-blue-soft: #e8ecf5;
  --cf-yellow-dark: #e6d500;
  --cf-yellow-tint: #fffce6;
  --cf-bleu-select: #dce0ed;
  --cf-border: var(--cf-bleu-select);
  --cf-state-success: #57820a;
  --cf-state-danger: #ce1d13;
  --cf-state-beware: #d17500;
  /* Ombre « cartes / modules » (charte §1.2) */
  --cf-shadow-ui: 2px 3px 10px rgb(220 224 237 / 0.85);
  --cf-shadow: 0 10px 32px rgba(var(--cf-navy-rgb), 0.1);
  --cf-shadow-lg: 0 18px 48px rgba(var(--cf-navy-rgb), 0.14);

  font-family: "Montserrat", system-ui, sans-serif;
  line-height: 1.45;
}

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

body {
  margin: 0;
  min-height: 100vh;
  background: var(--cf-bg-page);
  color: var(--cf-ink);
  -webkit-font-smoothing: antialiased;
  border-top: 6px solid var(--cf-yellow);
}

.grain {
  pointer-events: none;
  position: fixed;
  inset: 0;
  z-index: 0;
  opacity: 0.018;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.47'/%3E%3C/svg%3E");
  mix-blend-mode: multiply;
}

.shell {
  max-width: 72rem;
  margin: 0 auto;
  padding: 0 1rem;
}

@media (min-width: 640px) {
  .shell {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }
}

/* Header (barre type charte : marine + filet jaune) */

.site-header {
  position: relative;
  z-index: 10;
  border-bottom: 4px solid var(--cf-yellow);
  background: var(--cf-navy);
  box-shadow: 0 4px 16px rgba(var(--cf-navy-rgb), 0.22);
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 0;
}

.brand-link {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  text-decoration: none;
  color: inherit;
}

.header-nav {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.header-link {
  font-size: 0.8125rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.85);
  text-decoration: none;
}

.header-link:hover {
  color: #ffffff;
}

.header-link--active {
  color: var(--cf-yellow);
}

.inline-link {
  color: var(--cf-navy);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.inline-link:hover {
  color: var(--cf-black);
}

.body-hub .inline-link {
  color: var(--cf-navy);
}

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

.brand-mark {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  flex-shrink: 0;
  padding: 5px;
  border-radius: 0.75rem;
  border: none;
  background: var(--cf-yellow);
  color: var(--cf-navy);
  box-shadow: 0 2px 0 rgba(0, 0, 0, 0.12);
}

.brand-mark__img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.brand-title {
  margin: 0;
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 700;
  font-size: 1.05rem;
  color: var(--cf-white);
}

@media (min-width: 640px) {
  .brand-title {
    font-size: 1.125rem;
  }
}

.brand-sub {
  margin: 0;
  font-size: 0.75rem;
  color: rgba(255, 255, 255, 0.75);
}

/* Hero */

main {
  position: relative;
  z-index: 1;
}

.hero {
  overflow: hidden;
  border-bottom: none;
  padding: 0 0 3.5rem;
  background:
    linear-gradient(180deg, var(--cf-yellow) 0, var(--cf-yellow) 12px, var(--cf-bg-page) 12px, var(--cf-bg-page) 100%);
}

.hero .shell,
.hero .hero-inner {
  padding-top: 2.75rem;
}

@media (min-width: 640px) {
  .hero .shell,
  .hero .hero-inner {
    padding-top: 3.5rem;
  }
}

.hero.hero--photo {
  position: relative;
  min-height: 17rem;
  padding-bottom: 3.5rem;
  background: var(--cf-navy);
}

.hero--photo .hero-photo {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}

.hero--photo .hero-photo img {
  width: 100%;
  height: 100%;
  min-height: 17rem;
  object-fit: cover;
  object-position: center 42%;
}

.hero--photo::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(
    165deg,
    rgba(34, 50, 102, 0.5) 0%,
    rgba(34, 50, 102, 0.72) 45%,
    rgba(34, 50, 102, 0.9) 100%
  );
}

.hero-inner {
  position: relative;
  z-index: 2;
}

.hero--photo .hero-title,
.hero--photo .hero-lead {
  color: var(--cf-white);
  text-shadow: 0 1px 12px rgba(0, 0, 0, 0.25);
}

.hero--photo .hero-lead {
  color: rgba(255, 255, 255, 0.93);
}

.hero--photo .hero-hint {
  color: rgba(255, 255, 255, 0.82);
}

.hero--photo .pill {
  border-color: rgba(255, 255, 255, 0.85);
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
}

.pill {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  margin: 0 0 1rem;
  padding: 0.35rem 0.9rem;
  border-radius: 9999px;
  border: 2px solid var(--cf-navy);
  background: var(--cf-yellow);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--cf-navy);
}

.pilldots {
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--cf-navy);
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.9);
}

.hero-title {
  margin: 0;
  max-width: 48rem;
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 800;
  font-size: clamp(2rem, 5vw, 3.5rem);
  letter-spacing: -0.02em;
  line-height: 1.08;
  color: var(--cf-navy);
}

.hero-lead {
  margin: 1.5rem 0 0;
  max-width: 40rem;
  font-size: 1rem;
  color: var(--cf-ink-muted);
}

@media (min-width: 640px) {
  .hero-lead {
    font-size: 1.125rem;
    line-height: 1.6;
  }
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem;
  margin-top: 2.5rem;
}

.hero-search {
  flex: 1 1 12rem;
  min-width: min(100%, 11.5rem);
  max-width: 22rem;
}

.hero--photo .hero-search__input {
  color: var(--cf-navy);
  background: rgba(255, 255, 255, 0.96);
  border-color: rgba(255, 255, 255, 0.95);
  box-shadow: 0 2px 14px rgba(0, 0, 0, 0.15);
}

.hero-search__input {
  box-sizing: border-box;
  width: 100%;
  margin: 0;
  padding: 0.62rem 0.85rem;
  border-radius: 4px;
  border: 2px solid var(--cf-navy);
  background: var(--cf-white);
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--cf-navy);
  transition: box-shadow 0.15s ease, border-color 0.15s ease;
}

.hero-search__input::placeholder {
  color: rgba(34, 50, 102, 0.45);
  font-weight: 500;
}

.hero-search__input:hover {
  border-color: rgba(var(--cf-navy-rgb), 0.85);
}

.hero-search__input:focus {
  outline: none;
  border-color: var(--cf-navy);
  box-shadow: 0 0 0 3px rgba(255, 237, 0, 0.55);
}

.hub-search-status {
  min-height: 1.25rem;
  margin: 0 0 0.35rem;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--cf-ink-muted);
}

.hub-search-empty {
  margin: 0 0 0.75rem;
  padding: 0.65rem 0.85rem;
  border-radius: 0.4rem;
  border: 1px dashed rgba(var(--cf-navy-rgb), 0.25);
  background: rgba(255, 255, 255, 0.65);
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--cf-navy);
}

.hub-page-results {
  margin: 0 0 1.25rem;
  padding: 0;
  border: 0;
}

.hub-page-results[hidden] {
  display: none !important;
}

.hub-page-results__legend {
  margin: 0 0 0.5rem;
  font-size: 0.8125rem;
  font-weight: 800;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: var(--cf-navy);
}

.hub-page-results__list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  max-height: min(52vh, 22rem);
  overflow-y: auto;
  overscroll-behavior: contain;
  border-radius: 0.42rem;
  border: 1px solid rgba(var(--cf-navy-rgb), 0.14);
  background: var(--cf-white);
  box-shadow: var(--cf-shadow-ui);
}

.hub-page-results__item {
  margin: 0;
  padding: 0;
  border-bottom: 1px solid rgba(var(--cf-navy-rgb), 0.08);
}

.hub-page-results__item:last-child {
  border-bottom: 0;
}

.hub-page-results__link {
  display: block;
  padding: 0.55rem 0.72rem;
  color: inherit;
  text-decoration: none;
}

.hub-page-results__link:hover {
  background: rgba(255, 237, 0, 0.18);
}

.hub-page-results__link:focus-visible {
  outline: 2px solid var(--cf-navy);
  outline-offset: -2px;
}

.hub-page-results__meta {
  margin: 0 0 0.22rem;
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--cf-ink-muted);
}

.hub-page-results__title {
  margin: 0;
  font-size: 0.93rem;
  font-weight: 800;
  line-height: 1.28;
  color: var(--cf-navy);
}

.hub-page-results__snippet {
  margin: 0.28rem 0 0;
  font-size: 0.785rem;
  font-weight: 500;
  line-height: 1.38;
  color: var(--cf-ink-muted);
}

@media (max-width: 520px) {
  .hero-search {
    flex: 1 1 100%;
    max-width: none;
  }
}

.btn-primary {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  padding: 0.8rem 1.45rem;
  border-radius: 4px;
  background: var(--cf-yellow);
  color: var(--cf-navy);
  font-size: 0.875rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  text-decoration: none;
  border: 2px solid var(--cf-navy);
  box-shadow: 4px 4px 0 rgba(var(--cf-navy-rgb), 0.2);
  transition:
    transform 0.12s ease,
    box-shadow 0.12s ease;
}

.btn-primary:hover {
  transform: translate(-2px, -2px);
  box-shadow: 6px 6px 0 rgba(var(--cf-navy-rgb), 0.22);
}

.btn-primary:focus-visible {
  outline: 3px solid var(--cf-navy);
  outline-offset: 2px;
}

.hero-hint {
  font-size: 0.875rem;
  color: var(--cf-ink-muted);
}

/* Cards */

.section {
  scroll-margin-top: 5rem;
  padding: 3.5rem 0;
}

/* Bande teintée charte (liste manuels) — contraste avec le blanc pur du hero */
.section--tint {
  background: var(--cf-bg-soft-grey);
  border-top: 2px solid var(--cf-yellow);
  border-bottom: 2px solid var(--cf-navy);
}

.section-muted {
  border-top: 1px solid var(--cf-border);
  background: var(--cf-bg-soft-grey);
  padding-bottom: 3rem;
}

.section-title {
  margin: 0;
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 700;
  font-size: clamp(1.35rem, 3vw, 1.85rem);
  color: var(--cf-ink);
}

.section-note {
  margin: 0.5rem 0 0;
  max-width: 40rem;
  font-size: 0.875rem;
  color: var(--cf-ink-muted);
}

.cards {
  display: grid;
  gap: 1.25rem;
  margin: 2.5rem 0 0;
  padding: 0;
  list-style: none;
}

@media (min-width: 1024px) {
  .cards {
    grid-template-columns: repeat(3, 1fr);
  }
}

.card {
  position: relative;
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
  padding: 1.5rem;
  border-radius: 1rem;
  border: 2px solid rgba(var(--cf-navy-rgb), 0.14);
  background: var(--cf-white);
  box-shadow: var(--cf-shadow-ui);
  transition:
    border-color 0.2s,
    box-shadow 0.2s,
    transform 0.2s;
}

.card::before {
  content: "";
  position: absolute;
  right: -3rem;
  top: -3rem;
  width: 10rem;
  height: 10rem;
  border-radius: 50%;
  filter: blur(40px);
  opacity: 0.55;
  pointer-events: none;
}

.card:hover {
  border-color: var(--cf-navy);
  box-shadow: var(--cf-shadow-lg);
  transform: translateY(-3px);
}

.card-accent-a::before {
  background: linear-gradient(135deg, rgba(255, 237, 0, 0.55), rgba(var(--cf-navy-rgb), 0.15));
}

.card-accent-b::before {
  background: linear-gradient(135deg, rgba(var(--cf-navy-rgb), 0.3), rgba(255, 237, 0, 0.35));
}

.card-accent-c::before {
  background: linear-gradient(135deg, rgba(var(--cf-navy-rgb), 0.15), rgba(255, 237, 0, 0.4));
}

.card-accent-d::before {
  background: linear-gradient(135deg, rgba(100, 80, 200, 0.2), rgba(255, 237, 0, 0.25));
}

.card-accent-e::before {
  background: linear-gradient(135deg, rgba(255, 150, 60, 0.28), rgba(var(--cf-navy-rgb), 0.12));
}

.card-accent-f::before {
  background: linear-gradient(135deg, rgba(148, 163, 184, 0.35), rgba(var(--cf-navy-rgb), 0.1));
}

.card--placeholder {
  opacity: 0.95;
}

.card--placeholder .card-tag {
  color: var(--cf-ink-muted);
}

.card-tag {
  margin: 0;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--cf-navy);
}

.card-title {
  margin: 0.75rem 0 0;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--cf-ink);
}

.card-blurb {
  margin: 0.75rem 0 0;
  flex: 1;
  font-size: 0.9rem;
  line-height: 1.55;
  color: var(--cf-ink-muted);
}

.card-link {
  margin-top: 1.25rem;
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--cf-blue-deep);
  text-decoration: none;
  align-self: flex-start;
}

.card-link:hover {
  color: var(--cf-yellow-dark);
}

.card-link:focus-visible {
  outline: 2px solid var(--cf-yellow);
  outline-offset: 2px;
  border-radius: 2px;
}

/* Extras list */

.extras {
  margin: 1.5rem 0 0;
  padding: 0;
  list-style: none;
  border: 1px solid var(--cf-border);
  border-radius: 1rem;
  background: var(--cf-white);
  box-shadow: var(--cf-shadow-ui);
  overflow: hidden;
}

.extras-row {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  padding: 1rem 1.15rem;
  border-bottom: 1px solid var(--cf-border);
}

@media (min-width: 640px) {
  .extras-row {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
  }
}

.extras-row:last-child {
  border-bottom: none;
}

.extras-title {
  margin: 0;
  font-weight: 600;
  color: var(--cf-ink);
}

.extras-hint {
  margin: 0.15rem 0 0;
  font-size: 0.875rem;
  color: var(--cf-ink-muted);
}

.extras-pdf {
  flex-shrink: 0;
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--cf-blue);
  text-decoration: none;
}

.extras-pdf:hover {
  color: var(--cf-yellow-dark);
}

/* Footer */

.site-footer {
  position: relative;
  z-index: 1;
  border-top: 4px solid var(--cf-yellow);
  padding: 2.25rem 0;
  background: var(--cf-navy);
}

.footer-inner {
  font-size: 0.875rem;
  color: rgba(255, 255, 255, 0.82);
}

.footer-inner p {
  margin: 0;
}

.copyright {
  margin-top: 1rem;
}

html {
  scroll-behavior: smooth;
}

/* Lecteur section (TOC + page) */

.body-reader main,
.body-reader > .reader-shell {
  position: relative;
  z-index: 1;
}

.body-reader {
  background: var(--cf-bg-soft-blue);
  /* Évite le zoom auto du texte sur iOS qui casse les grilles / mesures en « px » implicites */
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

/* Médias dans la zone article : largeur intrinsèque bornée (sauf sprites / petites icônes dimensionnées en composant) */
.body-reader .reader-main img:not(.reader-ospit-proto__ico-sprite):not(.reader-ospit-flusso__ico):not(.reader-ospit-casi__ico):not(.reader-ospit-tratt__rowico):not(.reader-contrib__bg-img):not(.reader-cameriere-finale__go-img):not(.reader-cameriere-flusso__step-icon),
.body-reader .reader-main video {
  max-width: 100%;
  height: auto;
}

.reader-shell {
  padding-bottom: 3rem;
}

.breadcrumb {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem;
  padding: 1.25rem 0 0;
  font-size: 0.8125rem;
  color: var(--cf-ink-muted);
}

.breadcrumb a {
  color: var(--cf-blue);
  text-decoration: none;
}

.breadcrumb a:hover {
  color: var(--cf-blue-deep);
}

.breadcrumb-sep {
  opacity: 0.45;
}

.pill--sm {
  margin-left: 0.35rem;
  padding: 0.15rem 0.5rem;
  font-size: 0.65rem;
  background: var(--cf-yellow);
  border: 1px solid var(--cf-navy);
  color: var(--cf-navy);
}

.reader-layout {
  display: grid;
  gap: 1.5rem;
  margin-top: 1rem;
  min-width: 0;
}

/* Mobile : marge lors du scroll ciblé vers #reader-main (reader-scroll.js) */
@media (max-width: 899px) {
  .reader-shell .reader-main {
    scroll-margin-top: 0.5rem;
    scroll-margin-bottom: 0.75rem;
  }
}

@media (min-width: 900px) {
  .reader-layout {
    grid-template-columns: 16rem minmax(0, 1fr);
    align-items: start;
  }
}

.reader-toc {
  padding: 1rem 1rem 1rem 0;
  border-bottom: 1px solid var(--cf-border);
}

@media (min-width: 900px) {
  .reader-toc {
    border-bottom: none;
    border-right: 1px solid var(--cf-border);
    position: sticky;
    top: 4.5rem;
    max-height: calc(100dvh - 5rem);
    overflow-y: auto;
    padding-right: 1rem;
  }
}

.reader-toc-title {
  margin: 0 0 0.65rem;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--cf-ink-muted);
}

/* Couverture : titre + progression visibles dans le panneau d’index (pas sous la photo) */
.reader-toc-rail {
  margin: 0 0 1rem;
  padding: 0.85rem 0.65rem;
  border-radius: 0.45rem;
  border-left: 4px solid var(--cf-yellow);
  background: linear-gradient(
    135deg,
    rgba(255, 237, 0, 0.16) 0%,
    rgba(241, 243, 248, 0.85) 100%
  );
}

.reader-toc-rail-title {
  margin: 0 0 0.35rem;
  font-size: 0.88rem;
  font-weight: 800;
  line-height: 1.28;
  color: var(--cf-navy);
}

.reader-toc-rail-meta {
  margin: 0;
  font-size: 0.7rem;
  font-weight: 600;
  color: var(--cf-ink-muted);
  letter-spacing: 0.03em;
}

.reader-toc-list {
  margin: 0;
  padding: 0 0 0 1.25rem;
  font-size: 0.875rem;
  line-height: 1.4;
}

.reader-toc-list li {
  margin-bottom: 0.35rem;
}

.reader-toc-link {
  color: var(--cf-ink-muted);
  text-decoration: none;
}

.reader-toc-link:hover:not(.is-active) {
  display: inline-block;
  padding: 0.3rem 0.55rem;
  margin-left: calc(-1 * 0.55rem - 4px);
  border-radius: 4px;
  background: var(--cf-bg-soft-grey);
  color: var(--cf-blue);
}

.reader-toc-link.is-active {
  display: inline-block;
  padding: 0.3rem 0.55rem;
  margin-left: calc(-1 * 0.55rem - 4px);
  border-radius: 4px;
  background: var(--cf-yellow);
  color: var(--cf-navy);
  font-weight: 700;
}

.reader-main {
  padding: 1.5rem 1.25rem 2rem;
  min-width: 0;
  background: var(--cf-bg-page);
  border-radius: 1rem;
  border: 2px solid rgba(var(--cf-navy-rgb), 0.12);
  border-left: 6px solid var(--cf-yellow);
  box-shadow: var(--cf-shadow-ui);
}

/* Couverture / hero : image entière visible dans le cadre blanc (comme la slide), sans rognage */
.reader-main--hero {
  padding-top: 1rem;
  overflow: hidden;
}

.reader-hero {
  margin: 0 0 1.25rem;
  border-radius: 0.5rem;
  background: var(--cf-bg-soft-grey);
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 0;
}

.reader-hero img {
  display: block;
  margin-inline: auto;
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: min(72vh, 560px);
  object-fit: contain;
  object-position: center center;
}

/* Couverture PPT : photo + bandeau PNG en bas à gauche */
.reader-main--cover-stack {
  padding-top: 1rem;
  overflow: hidden;
}

.reader-cover-stack {
  position: relative;
  margin: 0 0 1rem;
  border-radius: 0.5rem;
  overflow: hidden;
  background: var(--cf-bg-soft-grey);
}

.reader-cover-stack .reader-hero {
  margin-bottom: 0;
  border-radius: 0;
}

/* Autres livrets : figure classique sous reader-cover-stack */
.reader-cover-stack .reader-hero.reader-hero--stack {
  position: relative;
  display: block;
  width: fit-content;
  max-width: 100%;
  margin-inline: auto;
  min-height: 0;
}

.reader-cover-stack .reader-hero--stack img {
  display: block;
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: min(72vh, 560px);
  object-fit: contain;
}

.reader-cover-stack .reader-hero img {
  max-height: min(72vh, 560px);
}

.reader-main--cameriere-essenza {
  background: #f5f5f6;
}

.reader-cameriere-essenza {
  padding: clamp(1rem, 2.3vw, 1.5rem) clamp(0.2rem, 1.5vw, 0.65rem) 0.4rem;
}

.reader-cameriere-essenza__title {
  margin: 0 0 clamp(1rem, 2.8vw, 1.7rem);
  text-align: center;
  color: var(--cf-navy);
  font-size: clamp(1.45rem, 3.2vw, 2.85rem);
  font-weight: 800;
  line-height: 1.1;
}

.reader-cameriere-essenza__grid {
  display: grid;
  gap: clamp(0.9rem, 2vw, 1.5rem);
}

@media (min-width: 900px) {
  .reader-cameriere-essenza__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: start;
  }
}

.reader-cameriere-essenza__card {
  display: grid;
  justify-items: center;
  text-align: center;
}

.reader-cameriere-essenza__icon {
  width: clamp(108px, 18vw, 190px);
  height: auto;
  object-fit: contain;
}

.reader-cameriere-essenza__tag {
  margin: 0.45rem 0 0.7rem;
  display: inline-block;
  padding: 0.4rem 1rem 0.38rem;
  min-height: 2.1rem;
  background: var(--cf-yellow);
  color: var(--cf-navy);
  font-weight: 800;
  font-size: clamp(1rem, 1.8vw, 1.9rem);
  line-height: 1.07;
  border-radius: 0.08rem;
  transform: rotate(-2.3deg);
  box-shadow: 0 3px 8px rgba(34, 50, 102, 0.2);
}

.reader-cameriere-essenza__text {
  margin: 0;
  max-width: 22ch;
  color: #22304f;
  font-size: clamp(1.02rem, 1.45vw, 1.58rem);
  line-height: 1.3;
}

/* Cameriere — Il Codice di Comportamento (split bleu / blanc) */
.reader-main--cameriere-codice {
  --cameriere-codice-navy: #102a54;
  background: #fff;
  overflow: hidden;
}

.reader-cameriere-codice {
  padding: 0;
}

.reader-cameriere-codice__head {
  display: flex;
  justify-content: center;
  padding: clamp(0.85rem, 2vw, 1.25rem) 1rem 0.35rem;
  background: linear-gradient(90deg, var(--cameriere-codice-navy) 50%, #fff 50%);
}

.reader-cameriere-codice__ribbon {
  margin: 0;
  display: inline-block;
  padding: 0.35rem 1.35rem 0.32rem;
  max-width: min(100%, 26rem);
  background: var(--cf-yellow);
  color: var(--cameriere-codice-navy);
  font-weight: 800;
  font-size: clamp(1.05rem, 2.2vw, 1.85rem);
  line-height: 1.12;
  text-align: center;
  transform: rotate(-2deg);
  box-shadow: 0 4px 12px rgba(34, 50, 102, 0.22);
}

.reader-cameriere-codice__split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: min(62vh, 520px);
}

.reader-cameriere-codice__col {
  padding: clamp(1rem, 2.5vw, 1.75rem) clamp(0.75rem, 2vw, 1.35rem) clamp(1.25rem, 3vw, 2rem);
}

.reader-cameriere-codice__col--pos {
  background: var(--cameriere-codice-navy);
  color: #fff;
}

.reader-cameriere-codice__col--neg {
  background: #fff;
  color: var(--cameriere-codice-navy);
}

.reader-cameriere-codice__col-title {
  margin: 0 0 clamp(0.85rem, 2vw, 1.35rem);
  text-align: center;
  font-size: clamp(1.05rem, 2vw, 1.65rem);
  font-weight: 800;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.reader-cameriere-codice__list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: clamp(0.65rem, 1.5vw, 1rem);
}

.reader-cameriere-codice__li {
  display: flex;
  align-items: flex-start;
  gap: 0.65rem;
  text-align: left;
  font-size: clamp(0.92rem, 1.35vw, 1.12rem);
  line-height: 1.35;
}

.reader-cameriere-codice__li-icon {
  flex: 0 0 auto;
  width: clamp(22px, 3.2vw, 30px);
  height: clamp(22px, 3.2vw, 30px);
  object-fit: contain;
  margin-top: 0.12rem;
}

@media (max-width: 720px) {
  .reader-cameriere-codice__split {
    grid-template-columns: 1fr;
  }

  .reader-cameriere-codice__head {
    background: var(--cameriere-codice-navy);
  }
}

/* Cameriere — post-it PNG + 3 étapes (écoute / rassurer / résoudre) */
.reader-main.reader-main--cameriere-flusso-cliente {
  background: #fff;
  padding-top: 0.35rem;
}

.reader-main.reader-main--cameriere-flusso-cliente > .reader-page-head--cover {
  margin-bottom: 0.3rem;
}

.reader-main.reader-main--cameriere-flusso-cliente > .reader-page-head--cover .reader-progress {
  margin-top: 0.35rem;
}

@media (min-width: 640px) {
  .reader-main.reader-main--cameriere-flusso-cliente {
    padding-top: 0.45rem;
  }
}

.reader-cameriere-flusso {
  --cameriere-flusso-ico: min(100px, 26vw);
  padding: 0.15rem clamp(0.35rem, 1.2vw, 0.75rem) clamp(0.75rem, 2vw, 1.35rem);
}

.reader-cameriere-flusso__tape {
  position: relative;
  max-width: min(640px, 96%);
  margin: 0 auto 0.35rem;
  transform: none;
  filter: drop-shadow(0 6px 14px rgba(34, 50, 102, 0.18));
}

.reader-cameriere-flusso__tape-img {
  display: block;
  width: 100%;
  height: auto;
  vertical-align: top;
}

.reader-cameriere-flusso__tape-cap {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.12em;
  padding: 19% 14% 19% 14%;
  box-sizing: border-box;
  text-align: center;
  color: var(--cf-navy);
  font-weight: 800;
  line-height: 1.12;
  pointer-events: none;
  transform: rotate(-10deg);
  transform-origin: center center;
}

.reader-cameriere-flusso__tape-line {
  display: block;
  max-width: min(24ch, 92%);
  margin-inline: auto;
  font-size: clamp(0.8rem, 1.75vw, 1.28rem);
}

.reader-cameriere-flusso__steps {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.35rem;
  padding-top: 0.15rem;
}

.reader-cameriere-flusso__step {
  display: grid;
  grid-template-rows: var(--cameriere-flusso-ico) auto 1fr;
  justify-items: center;
  align-items: start;
  text-align: center;
  max-width: 22rem;
}

.reader-cameriere-flusso__step-icon {
  box-sizing: border-box;
  width: var(--cameriere-flusso-ico);
  height: var(--cameriere-flusso-ico);
  padding: clamp(4px, 1.2vw, 8px);
  object-fit: contain;
  object-position: center;
  align-self: center;
  display: block;
}

.reader-cameriere-flusso__step-title {
  margin: 0.35rem 0 0.25rem;
  color: var(--cf-navy);
  font-size: clamp(1.02rem, 1.9vw, 1.45rem);
  font-weight: 800;
}

.reader-cameriere-flusso__step-body {
  margin: 0;
  color: #1a1a1a;
  font-size: clamp(0.92rem, 1.35vw, 1.08rem);
  line-height: 1.35;
}

.reader-cameriere-flusso__arrow {
  flex: 0 0 auto;
  align-self: center;
  width: clamp(2rem, 5.5vw, 3.4rem);
  height: clamp(1.1rem, 2.9vw, 1.9rem);
  margin: 0.15rem 0;
  background: var(--cf-yellow);
  clip-path: polygon(0 42%, 58% 42%, 58% 12%, 100% 50%, 58% 88%, 58% 58%, 0 58%);
  box-shadow: 0 2px 0 rgba(34, 50, 102, 0.12);
}

@media (min-width: 900px) {
  .reader-cameriere-flusso__steps {
    display: grid;
    grid-template-columns: 1fr auto 1fr auto 1fr;
    align-items: start;
    gap: 0.35rem 0.2rem;
    max-width: 72rem;
    margin: 0 auto;
  }

  .reader-cameriere-flusso__step {
    max-width: none;
    grid-template-rows: var(--cameriere-flusso-ico) auto 1fr;
  }

  .reader-cameriere-flusso__arrow {
    margin-top: calc(var(--cameriere-flusso-ico) * 0.42);
  }
}

/* Cameriere — Il Flusso del Servizio (ruban + pastilles ; tout le texte sous le ruban) */
.reader-main.reader-main--cameriere-flusso-servizio {
  background: #fff;
  padding-top: 0.65rem;
  padding-bottom: 0.85rem;
}

.reader-main.reader-main--cameriere-flusso-servizio > .reader-page-head--cover {
  margin-bottom: 0.45rem;
}

.reader-main.reader-main--cameriere-flusso-servizio > .reader-page-head--cover .reader-progress {
  margin-top: 0.35rem;
}

@media (min-width: 640px) {
  .reader-main.reader-main--cameriere-flusso-servizio {
    padding-top: 0.75rem;
    padding-bottom: 1rem;
  }
}

.reader-cameriere-servizio {
  padding: 0.2rem clamp(0.3rem, 1vw, 0.55rem) clamp(0.5rem, 1.5vw, 0.85rem);
}

.reader-cameriere-servizio__title {
  margin: 0 0 clamp(0.5rem, 1.65vw, 1rem);
  text-align: center;
  color: var(--cf-navy);
  font-size: clamp(1.42rem, 3.1vw, 2.1rem);
  font-weight: 800;
  letter-spacing: 0.02em;
  line-height: 1.12;
  text-wrap: balance;
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.85);
}

.reader-cameriere-servizio__wrap {
  position: relative;
  margin: 0 auto;
  max-width: min(92rem, 100%);
  padding: clamp(0.2rem, 0.9vw, 0.45rem) clamp(0.2rem, 1vw, 0.5rem);
}

.reader-cameriere-servizio__tape {
  position: absolute;
  left: 0.5%;
  right: 0.5%;
  top: 50%;
  height: clamp(38px, 5vw, 50px);
  transform: translateY(-50%) rotate(-1.6deg);
  background: linear-gradient(
    180deg,
    #ffe94a 0%,
    var(--cf-yellow) 40%,
    #e8c400 100%
  );
  border-radius: 2px;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.4) inset,
    0 5px 14px rgba(34, 50, 102, 0.14);
  z-index: 0;
  pointer-events: none;
}

.reader-cameriere-servizio__cols {
  position: relative;
  z-index: 1;
  isolation: isolate;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(0.92rem, 2.65vw, 1.72rem);
  align-items: stretch;
}

.reader-cameriere-servizio__col {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  /* Pas de gap global : pastille/trait resserrés vs trait/texte séparés par padding ciblé */
  gap: 0;
  width: 100%;
  min-width: 0;
  min-height: 0;
}

.reader-cameriere-servizio__region--grow {
  flex: 1 1 0;
  width: 100%;
  min-height: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.reader-cameriere-servizio__region--empty {
  pointer-events: none;
  /* Évite que le ruban (50 % du wrap) recouvre titre / pastilles quand cette zone s’effondrait */
  flex: 1 1 auto;
  min-height: clamp(2.25rem, 11vmin, 5.5rem);
}

.reader-cameriere-servizio__region--text {
  justify-content: flex-start;
  padding-top: clamp(0.18rem, 1.05vmin, 0.48rem);
  flex: 1 1 auto;
}

.reader-cameriere-servizio__bundle {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(0.15rem, 1vmin, 0.45rem);
  width: 100%;
  box-sizing: border-box;
  padding-inline: clamp(0.28rem, 1.5vw, 0.65rem);
  padding-bottom: clamp(0.15rem, 1.2vmin, 0.5rem);
}

/* Trait centré : pastille → ligne (serré) → texte (air sous le trait) */
.reader-cameriere-servizio__connector {
  flex: 0 0 auto;
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: clamp(1px, 0.35vmin, 5px) 0 clamp(0.42rem, 2.2vmin, 0.92rem);
}

.reader-cameriere-servizio__connector .reader-cameriere-servizio__vline {
  display: block;
  width: 2px;
  height: clamp(14px, 2.2vw, 26px);
  margin: 0;
  background: var(--cf-navy);
  flex-shrink: 0;
  border-radius: 1px;
}

.reader-cameriere-servizio__badge-wrap {
  flex: 0 0 auto;
  position: relative;
  z-index: 2;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-block: clamp(2px, 0.4vmin, 7px);
  margin-bottom: 0;
}

.reader-cameriere-servizio__region--empty + .reader-cameriere-servizio__badge-wrap {
  margin-top: 0;
}

.reader-cameriere-servizio__badge {
  flex: 0 0 auto;
  box-sizing: border-box;
  width: clamp(23px, calc(6.75vmin + 5px), 44px);
  height: clamp(23px, calc(6.75vmin + 5px), 44px);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--cf-navy);
  color: #fff;
  font-weight: 800;
  font-size: clamp(0.56rem, calc(2.65vmin + 0.42rem), 1.06rem);
  line-height: 1;
  box-shadow: 0 2px 6px rgba(34, 50, 102, 0.24);
}

.reader-cameriere-servizio__step-head {
  margin: 0 0 clamp(0.22rem, 1.1vmin, 0.42rem);
  color: var(--cf-navy);
  font-size: clamp(0.74rem, calc(1.75vmin + 0.58rem), 0.93rem);
  font-weight: 800;
  line-height: 1.28;
  width: 100%;
  max-width: min(38ch, 100%);
  margin-inline: auto;
  text-align: center;
  text-wrap: balance;
}

.reader-cameriere-servizio__step-body {
  margin: 0;
  color: #141414;
  font-size: clamp(0.7rem, calc(1.55vmin + 0.48rem), 0.86rem);
  line-height: 1.52;
  width: 100%;
  max-width: min(42ch, 100%);
  margin-inline: auto;
  text-align: center;
}

.reader-cameriere-servizio__step-body p {
  margin: 0 0 clamp(0.38rem, 1.8vmin, 0.62rem);
  text-align: center;
  text-wrap: pretty;
}

.reader-cameriere-servizio__step-body p:last-child {
  margin-bottom: 0;
}

/* Tablette / petit laptop : 2×2 pour éviter 4 colonnes illisibles qui « montent » sur tout */
@media (max-width: 1140px) {
  .reader-cameriere-servizio__wrap {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    padding-top: 0.1rem;
  }

  .reader-cameriere-servizio__tape {
    position: relative;
    left: 0;
    right: 0;
    top: auto;
    width: 100%;
    max-width: none;
    margin: 0 0 clamp(0.55rem, 2vw, 0.85rem);
    height: clamp(11px, 1.6vw, 14px);
    transform: rotate(-1deg);
    flex-shrink: 0;
  }

  .reader-cameriere-servizio__cols {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    /* Rangées plus espacées : texte d’une étape ↔ pastille de l’étape suivante (2×2) */
    gap: clamp(1.5rem, 4.25vw, 2.35rem) clamp(0.95rem, 2.8vw, 1.45rem);
  }

  .reader-cameriere-servizio__col {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    min-height: 0;
    padding-bottom: clamp(0.25rem, 1.8vmin, 0.65rem);
  }

  .reader-cameriere-servizio__region--text {
    padding-top: clamp(0.15rem, 1.15vmin, 0.42rem);
  }

  .reader-cameriere-servizio__connector {
    padding: clamp(1px, 0.32vmin, 5px) 0 clamp(0.38rem, 2vmin, 0.85rem);
  }

  .reader-cameriere-servizio__region--empty {
    display: none;
    min-height: 0;
    flex: 0 0 0;
  }

  .reader-cameriere-servizio__title {
    font-size: clamp(1.28rem, 3.6vw, 1.85rem);
    margin-bottom: clamp(0.4rem, 1.5vw, 0.75rem);
  }

  .reader-cameriere-servizio__step-head,
  .reader-cameriere-servizio__step-body {
    max-width: min(48ch, 100%);
  }

  .reader-main.reader-main--cameriere-flusso-servizio .reader-nav {
    margin-top: 1.35rem;
    padding-top: 1rem;
  }
}

@media (max-width: 560px) {
  .reader-cameriere-servizio__cols {
    grid-template-columns: 1fr;
    /* Large entre fin du texte et pastille de l’étape suivante */
    gap: clamp(1.85rem, 8vmin, 3.35rem);
  }

  .reader-cameriere-servizio__col {
    padding-block: clamp(0.45rem, 3vmin, 1.05rem);
    padding-bottom: clamp(0.75rem, 5vmin, 1.85rem);
    border-bottom: 1px solid rgba(var(--cf-navy-rgb), 0.12);
  }

  .reader-cameriere-servizio__col:last-child {
    border-bottom: 0;
    padding-bottom: clamp(0.25rem, 2vmin, 0.65rem);
  }

  .reader-cameriere-servizio__title {
    font-size: clamp(1.02rem, 4.35vw, 1.45rem);
    margin-bottom: clamp(0.45rem, 2vw, 0.7rem);
  }

  .reader-cameriere-servizio__tape {
    margin-bottom: clamp(0.55rem, 2.6vw, 0.92rem);
  }

  .reader-cameriere-servizio__badge {
    width: clamp(22px, calc(6vmin + 4px), 38px);
    height: clamp(22px, calc(6vmin + 4px), 38px);
    font-size: clamp(0.52rem, calc(2.35vmin + 0.38rem), 0.95rem);
  }

  .reader-cameriere-servizio__connector .reader-cameriere-servizio__vline {
    height: clamp(13px, 3.25vmin, 26px);
  }

  .reader-cameriere-servizio__connector {
    padding: clamp(1px, 0.42vmin, 5px) 0 clamp(0.45rem, 2.6vmin, 0.98rem);
  }

  .reader-cameriere-servizio__region--text {
    padding-top: clamp(0.12rem, 0.95vmin, 0.38rem);
  }

  .reader-cameriere-servizio__bundle {
    padding-bottom: clamp(0.12rem, 1.35vmin, 0.42rem);
  }

  .reader-cameriere-servizio__step-head {
    font-size: clamp(0.76rem, calc(2vmin + 0.52rem), 0.88rem);
  }

  .reader-cameriere-servizio__step-body {
    font-size: clamp(0.7rem, calc(1.75vmin + 0.42rem), 0.82rem);
    line-height: 1.52;
  }

  .reader-cameriere-servizio__step-body p {
    margin-bottom: clamp(0.42rem, 2.2vmin, 0.65rem);
  }
}

@media (max-width: 400px) {
  .reader-cameriere-servizio__cols {
    gap: clamp(1.65rem, 8.5vmin, 3rem);
  }

  .reader-cameriere-servizio__badge {
    width: clamp(20px, calc(5.5vmin + 3px), 34px);
    height: clamp(20px, calc(5.5vmin + 3px), 34px);
    font-size: clamp(0.48rem, calc(2.2vmin + 0.34rem), 0.82rem);
  }

  .reader-cameriere-servizio__step-head {
    font-size: clamp(0.72rem, calc(1.85vmin + 0.46rem), 0.82rem);
  }

  .reader-cameriere-servizio__step-body {
    font-size: clamp(0.665rem, calc(1.65vmin + 0.38rem), 0.78rem);
  }
}

/* Cameriere — Regole planetarie / mappa servizio */
.reader-main--cameriere-mappa-servizio {
  background: #fff;
}

.reader-cameriere-mappa {
  padding: clamp(0.35rem, 1.2vw, 0.85rem) clamp(0.35rem, 1.2vw, 0.75rem) 0;
  display: flex;
  flex-direction: column;
  min-height: min(70vh, 640px);
}

.reader-cameriere-mappa__title {
  margin: 0 0 clamp(0.65rem, 1.8vw, 1.1rem);
  text-align: center;
  color: var(--cf-navy);
  font-size: clamp(1.05rem, 2.1vw, 1.5rem);
  font-weight: 800;
  line-height: 1.2;
  letter-spacing: 0.02em;
}

.reader-cameriere-mappa__grid {
  flex: 1 1 auto;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(200px, 38%) minmax(0, 1fr);
  gap: clamp(0.5rem, 2vw, 1.25rem);
  align-items: center;
  margin-bottom: clamp(0.75rem, 2vw, 1.25rem);
}

.reader-cameriere-mappa__left,
.reader-cameriere-mappa__right {
  min-width: 0;
}

.reader-cameriere-mappa__left-h,
.reader-cameriere-mappa__right-h {
  margin: 0 0 0.45rem;
  font-size: clamp(0.82rem, 1.35vw, 1rem);
  font-weight: 800;
  line-height: 1.25;
}

.reader-cameriere-mappa__left-h {
  color: var(--cf-navy);
}

.reader-cameriere-mappa__right-h {
  color: var(--cf-yellow-dark);
  text-shadow:
    0 0 1px rgba(255, 255, 255, 0.9),
    0 1px 0 rgba(34, 50, 102, 0.12);
}

.reader-cameriere-mappa__body {
  margin: 0;
  color: #1a1a1a;
  font-size: clamp(0.82rem, 1.2vw, 0.98rem);
  line-height: 1.4;
}

.reader-cameriere-mappa__center {
  display: flex;
  justify-content: center;
  align-items: center;
}

.reader-cameriere-mappa__diagram {
  display: block;
  width: 100%;
  max-width: min(420px, 100%);
  height: auto;
  object-fit: contain;
}

.reader-cameriere-mappa__foot {
  margin: 0 calc(-1 * clamp(0.5rem, 2vw, 1rem));
  padding: clamp(0.55rem, 1.4vw, 0.85rem) clamp(0.75rem, 2vw, 1.25rem);
  background: var(--cf-navy);
  color: #fff;
  font-size: clamp(0.78rem, 1.15vw, 0.95rem);
  font-weight: 600;
  text-align: center;
  line-height: 1.35;
}

@media (max-width: 720px) {
  .reader-cameriere-mappa__grid {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .reader-cameriere-mappa__left,
  .reader-cameriere-mappa__right {
    text-align: center;
  }

  .reader-cameriere-mappa__center {
    order: -1;
  }
}

/* Cameriere — L'arte del servizio (3 cartes bordées + icônes) */
.reader-main--cameriere-arte-servizio {
  background: #fff;
}

.reader-cameriere-arte {
  padding: clamp(0.55rem, 1.5vw, 1rem) clamp(0.35rem, 1.2vw, 0.75rem) clamp(0.45rem, 1.2vw, 0.75rem);
}

.reader-cameriere-arte__title {
  margin: 0 0 clamp(0.65rem, 1.8vw, 1.15rem);
  text-align: center;
  color: var(--cf-navy);
  font-size: clamp(1.28rem, 2.6vw, 2.05rem);
  font-weight: 800;
  line-height: 1.12;
  letter-spacing: 0.02em;
}

.reader-cameriere-arte__grid {
  display: grid;
  gap: clamp(0.65rem, 1.8vw, 1.1rem);
}

@media (min-width: 768px) {
  .reader-cameriere-arte__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: stretch;
  }
}

.reader-cameriere-arte__card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  margin: 0;
  padding: clamp(0.65rem, 1.6vw, 1rem) clamp(0.5rem, 1.3vw, 0.85rem) clamp(0.75rem, 1.8vw, 1.05rem);
  border: 2px solid #1a1a1a;
  border-radius: 2px;
  background: #fff;
  box-sizing: border-box;
  min-width: 0;
}

.reader-cameriere-arte__icon {
  display: block;
  width: clamp(96px, 20vw, 150px);
  height: auto;
  max-height: min(180px, 28vh);
  object-fit: contain;
}

.reader-cameriere-arte__tag {
  margin: clamp(0.4rem, 1.1vw, 0.6rem) 0 clamp(0.3rem, 0.85vw, 0.45rem);
  padding: 0;
  border: none;
  background: none;
  color: var(--cf-yellow-dark);
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: clamp(0.92rem, 1.5vw, 1.15rem);
  font-weight: 800;
  line-height: 1.15;
  letter-spacing: 0.02em;
}

.reader-cameriere-arte__text {
  margin: 0;
  max-width: 38ch;
  color: var(--cf-navy);
  font-size: clamp(0.78rem, 1.1vw, 0.95rem);
  line-height: 1.42;
  text-wrap: pretty;
}

/* Cameriere — Sbarazzo e Tempi (texte ruban jaune + schéma) */
.reader-main--cameriere-sbarazzo-tempi {
  background: #fff;
}

.reader-cameriere-sbarazzo {
  padding: clamp(0.45rem, 1.2vw, 0.85rem) clamp(0.35rem, 1.2vw, 0.75rem) clamp(0.4rem, 1.2vw, 0.7rem);
}

.reader-cameriere-sbarazzo__page-title {
  margin: 0 0 clamp(0.65rem, 1.8vw, 1.1rem);
  text-align: left;
  color: var(--cf-navy);
  font-size: clamp(1.2rem, 2.4vw, 1.85rem);
  font-weight: 800;
  line-height: 1.12;
  letter-spacing: 0.02em;
}

.reader-cameriere-sbarazzo__split {
  display: grid;
  gap: clamp(1rem, 2.5vw, 1.5rem);
  align-items: start;
  grid-template-columns: 1fr;
}

@media (min-width: 880px) {
  .reader-cameriere-sbarazzo__split {
    grid-template-columns: minmax(0, 1.08fr) minmax(220px, 0.92fr);
  }
}

.reader-cameriere-sbarazzo__copy {
  display: flex;
  flex-direction: column;
  gap: clamp(0.85rem, 2vw, 1.25rem);
  min-width: 0;
}

.reader-cameriere-sbarazzo__block {
  margin: 0;
}

.reader-cameriere-sbarazzo__tape-title {
  margin: 0 0 clamp(0.35rem, 1vw, 0.55rem);
  padding: 0;
  border: none;
  font: inherit;
  line-height: 1.2;
}

.reader-cameriere-sbarazzo__tape-label {
  display: inline-block;
  padding: 0.32rem 0.95rem 0.38rem;
  background: linear-gradient(
    180deg,
    #fff59a 0%,
    var(--cf-yellow) 42%,
    #e6cf00 100%
  );
  color: var(--cf-navy);
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: clamp(0.86rem, 1.2vw, 1.02rem);
  font-weight: 800;
  letter-spacing: 0.02em;
  transform: rotate(-1deg);
  transform-origin: left center;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.45) inset,
    0 2px 0 rgba(34, 50, 102, 0.08),
    0 4px 10px rgba(34, 50, 102, 0.12);
  border-radius: 1px;
}

.reader-cameriere-sbarazzo__body {
  margin: 0;
  max-width: 52ch;
  color: #1a1a1a;
  font-size: clamp(0.8rem, 1.1vw, 0.95rem);
  line-height: 1.45;
  text-wrap: pretty;
}

.reader-cameriere-sbarazzo__fig {
  margin: 0;
  padding: 0;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  min-width: 0;
}

.reader-cameriere-sbarazzo__img {
  display: block;
  width: 100%;
  max-width: min(380px, 100%);
  height: auto;
  object-fit: contain;
}

@media (max-width: 879px) {
  .reader-cameriere-sbarazzo__fig {
    justify-content: center;
    padding-top: 0.25rem;
  }

  .reader-cameriere-sbarazzo__img {
    max-width: min(300px, 92%);
  }
}

/* Cameriere — Il Rituale del Vino (timeline jaune + icônes blanches sur fond navy) */
.reader-main.reader-main--cameriere-rituale-vino {
  --rituale-navy: #0e1a3d;
  --rituale-navy-deep: #0a142f;
  background: linear-gradient(165deg, var(--rituale-navy) 0%, var(--rituale-navy-deep) 100%);
  border-color: rgba(255, 255, 255, 0.12);
  color: #fff;
}

.reader-main.reader-main--cameriere-rituale-vino .reader-page-head--cover .reader-progress {
  color: rgba(255, 255, 255, 0.72);
}

.reader-main.reader-main--cameriere-rituale-vino .reader-nav {
  border-top-color: rgba(255, 255, 255, 0.18);
}

.reader-main.reader-main--cameriere-rituale-vino .reader-nav-btn {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.28);
  color: rgba(255, 255, 255, 0.95);
  box-shadow: none;
}

.reader-main.reader-main--cameriere-rituale-vino .reader-nav-btn--next {
  background: var(--cf-yellow);
  border-color: var(--cf-yellow);
  color: var(--cf-navy);
}

.reader-main.reader-main--cameriere-rituale-vino .reader-nav-btn--hub {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(255, 255, 255, 0.35);
  color: #fff;
}

.reader-cameriere-rituale {
  padding: clamp(0.45rem, 1.2vw, 0.85rem) clamp(0.35rem, 1.2vw, 0.75rem) clamp(0.5rem, 1.4vw, 0.85rem);
}

.reader-cameriere-rituale__title {
  margin: 0 0 clamp(0.85rem, 2.2vw, 1.35rem);
  text-align: left;
  color: var(--cf-yellow);
  font-size: clamp(1.05rem, 2.1vw, 1.65rem);
  font-weight: 800;
  line-height: 1.15;
  letter-spacing: 0.02em;
  max-width: 22ch;
}

.reader-cameriere-rituale__icons-full {
  display: none;
  margin: 0 0 clamp(0.75rem, 2vw, 1.1rem);
  padding: 0;
  justify-content: center;
}

.reader-cameriere-rituale__icons-full-img {
  display: block;
  width: 100%;
  max-width: min(11rem, 72vw);
  max-height: min(200px, 32vh);
  height: auto;
  object-fit: contain;
  filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.2));
}

.reader-cameriere-rituale__grid {
  display: grid;
  grid-template-columns: 2.85rem minmax(4.5rem, 7rem) minmax(0, 1fr);
  column-gap: clamp(0.75rem, 1.8vw, 1.15rem);
  row-gap: clamp(1rem, 2.6vw, 1.85rem);
  align-items: center;
  position: relative;
  z-index: 0;
}

.reader-cameriere-rituale__grid::before {
  content: "";
  position: absolute;
  left: calc(2.85rem / 2);
  top: 0.35rem;
  bottom: 0.35rem;
  width: 2px;
  transform: translateX(-50%);
  background: var(--cf-yellow);
  border-radius: 1px;
  opacity: 0.95;
  z-index: 0;
  pointer-events: none;
}

.reader-cameriere-rituale__rail-cell {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  align-self: center;
}

.reader-cameriere-rituale__num {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  background: var(--cf-yellow);
  color: var(--cf-navy);
  font-weight: 800;
  font-size: clamp(0.88rem, 1.25vw, 1rem);
  line-height: 1;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.25);
}

.reader-cameriere-rituale__icon-cell {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 0;
  align-self: center;
}

.reader-cameriere-rituale__icon-mask {
  position: relative;
  width: min(5.75rem, 100%);
  height: clamp(3.85rem, 10.5vw, 5.45rem);
  overflow: hidden;
  flex-shrink: 0;
}

.reader-cameriere-rituale__icons-img--strip {
  position: absolute;
  left: 50%;
  top: 0;
  transform: translate(-50%, 0);
  width: min(5.5rem, 100%);
  height: auto;
  max-width: none;
  display: block;
  filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.2));
}

.reader-cameriere-rituale__icon-mask--2 .reader-cameriere-rituale__icons-img--strip {
  transform: translate(-50%, calc(-100% / 3));
}

.reader-cameriere-rituale__icon-mask--3 .reader-cameriere-rituale__icons-img--strip {
  transform: translate(-50%, calc(-200% / 3));
}

.reader-cameriere-rituale__step {
  margin: 0;
  align-self: center;
  min-width: 0;
}

.reader-cameriere-rituale__step-head {
  margin: 0 0 0.4rem;
  color: #fff;
  font-size: clamp(0.95rem, 1.4vw, 1.12rem);
  font-weight: 800;
  line-height: 1.2;
}

.reader-cameriere-rituale__step-body {
  margin: 0;
  color: rgba(255, 255, 255, 0.92);
  font-size: clamp(0.82rem, 1.15vw, 0.98rem);
  line-height: 1.45;
  max-width: 52ch;
  text-wrap: pretty;
}

.reader-cameriere-rituale__step-body strong {
  color: #fff;
  font-weight: 800;
}

@media (max-width: 720px) {
  .reader-cameriere-rituale__icons-full {
    display: flex;
  }

  .reader-cameriere-rituale__grid {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: clamp(1rem, 3vw, 1.35rem);
  }

  .reader-cameriere-rituale__grid::before {
    display: none;
  }

  .reader-cameriere-rituale__rail-cell,
  .reader-cameriere-rituale__icon-cell {
    display: none;
  }

  .reader-cameriere-rituale__step {
    display: grid;
    grid-template-columns: 2.6rem 1fr;
    column-gap: 0.65rem;
    align-items: start;
    align-self: stretch;
  }

  .reader-cameriere-rituale__step::before {
    content: attr(data-step);
    grid-row: 1 / span 2;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    margin-top: 0.1rem;
    border-radius: 50%;
    background: var(--cf-yellow);
    color: var(--cf-navy);
    font-weight: 800;
    font-size: 0.95rem;
    line-height: 2.25rem;
    text-align: center;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.22);
  }

  .reader-cameriere-rituale__step-head {
    grid-column: 2;
  }

  .reader-cameriere-rituale__step-body {
    grid-column: 2;
    max-width: none;
  }
}

.reader-cover-band {
  position: absolute;
  left: 2.5%;
  bottom: 3%;
  max-width: min(520px, 90%);
  z-index: 2;
  line-height: 0;
  filter: drop-shadow(0 6px 18px rgba(34, 50, 102, 0.35));
}

.reader-cover-band img {
  display: block;
  width: 100%;
  height: auto;
  vertical-align: top;
}

/* Slide type PPT deux colonnes (accueil / benvenuto) */
.reader-main--split-photo .reader-slide-split {
  margin-top: -0.25rem;
}

.reader-slide-split {
  display: grid;
  gap: 1.35rem;
  align-items: start;
  min-width: 0;
}

@media (min-width: 840px) {
  .reader-slide-split {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.08fr);
    gap: 1.75rem;
    align-items: stretch;
  }
}

.reader-slide-split__fig {
  margin: 0;
  min-width: 0;
  border-radius: 0.5rem;
  overflow: hidden;
  border: 1px solid var(--cf-border);
  background: var(--cf-bg-soft-grey);
}

.reader-slide-split__fig img {
  display: block;
  width: 100%;
  height: auto;
  min-height: 200px;
  max-height: 420px;
  object-fit: cover;
  object-position: center;
}

.reader-slide-split__text {
  min-width: 0;
}

.reader-framed-h {
  margin: 0 0 1rem;
  padding: 0.5rem 0.95rem;
  border: 2px solid var(--cf-yellow);
  font-size: clamp(1rem, 2.8vw, 1.125rem);
  font-weight: 700;
  color: var(--cf-navy);
  line-height: 1.3;
}

.reader-framed-h--spacing {
  margin-top: 1.5rem;
  margin-bottom: 0.75rem;
}

.reader-slide-split__text .reader-p {
  margin-top: 0;
}

.reader-ul--anchors {
  margin: 0 0 1.25rem 0;
  padding: 0;
  list-style: none;
  color: var(--cf-navy);
}

.reader-ul--anchors li {
  display: flex;
  gap: 0.65rem;
  align-items: flex-start;
  margin-bottom: 0.65rem;
  font-weight: 500;
  line-height: 1.5;
}

.reader-ul--anchors li::before {
  content: "⚓";
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  margin-top: 0.1rem;
  font-size: 0.82rem;
  line-height: 1;
  background: var(--cf-yellow);
  color: var(--cf-navy);
  border-radius: 3px;
}

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  clip-path: inset(50%);
  white-space: nowrap;
  border: 0;
}

.reader-page-head--cover {
  margin-bottom: 1rem;
}

.reader-page-head--cover .reader-progress {
  margin-top: 0.25rem;
}

@media (min-width: 640px) {
  .reader-main {
    padding: 1.75rem 1.75rem 2.25rem;
  }
}

.reader-page-head {
  margin-bottom: 1.5rem;
}

.reader-kicker {
  margin: 0 0 0.35rem;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--cf-blue);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.reader-h1 {
  margin: 0;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: clamp(1.65rem, 4vw, 2.25rem);
  font-weight: 800;
  line-height: 1.15;
  color: var(--cf-ink);
}

.reader-progress {
  margin: 0.75rem 0 0;
  font-size: 0.875rem;
  color: var(--cf-ink-muted);
}

.reader-p {
  margin: 0 0 1rem;
  font-size: 1rem;
  line-height: 1.65;
  color: var(--cf-ink);
}

.reader-slide-split__text .reader-p br {
  display: inline;
}

.reader-p br {
  line-height: inherit;
}

.reader-page-head--cover-sr {
  margin: 0;
  padding: 0;
  min-height: 0;
}

.reader-main--marinai-cover {
  padding-top: 1rem;
  overflow: hidden;
}

.reader-marinai-cover {
  position: relative;
  margin: 0 0 0.25rem;
  border-radius: 0.55rem;
  overflow: hidden;
  background: #0f1d3a;
  line-height: 0;
  box-shadow:
    0 12px 40px rgba(15, 29, 58, 0.45),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.reader-marinai-cover__img {
  display: block;
  width: 100%;
  height: auto;
  max-height: min(86vh, 860px);
  object-fit: contain;
  object-position: center center;
  vertical-align: top;
}

/* Accueil à bord (Ospitalità) — couverture (PNG pleine largeur) */
.reader-main--ospitalita-cover {
  padding-top: 1rem;
  overflow: hidden;
}

.reader-ospit-cover {
  position: relative;
  margin: 0 0 0.25rem;
  border-radius: 0.55rem;
  overflow: hidden;
  background: #0a1933;
  line-height: 0;
  box-shadow:
    0 12px 40px rgba(15, 29, 58, 0.45),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.reader-ospit-cover__img {
  display: block;
  width: 100%;
  height: auto;
  max-height: min(94vh, 1040px);
  object-fit: contain;
  object-position: center center;
  vertical-align: top;
}

.reader-ospit-cover-body {
  margin-top: 1rem;
  margin-bottom: 0.35rem;
  padding: clamp(1rem, 3vw, 1.35rem) clamp(0.75rem, 3vw, 1.25rem);
  border-radius: 0.55rem;
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.97) 0%,
    var(--cf-bg-soft-grey) 100%
  );
  border: 1px solid rgba(var(--cf-navy-rgb), 0.1);
}

.reader-main--ospitalita-cover .reader-ospit-cover-body .reader-p {
  margin-bottom: 0.65rem;
  font-size: clamp(0.9rem, 2.35vw, 1.035rem);
  font-weight: 600;
  line-height: 1.55;
  color: var(--cf-ink);
}

.reader-main--ospitalita-cover .reader-ospit-cover-body .reader-p:last-child {
  margin-bottom: 0;
}

/* Couverture Ospitalità — panneau Navy (texte + logo, façon slide) */
.reader-main--ospitalita-cover:has(.reader-ospit-cv) {
  background: linear-gradient(180deg, #0b1f42 0%, #061832 52%, #040d20 100%);
  border-color: rgba(255, 255, 255, 0.1);
  padding-top: 1rem;
  padding-bottom: 1.75rem;
}

.reader-main--ospitalita-cover:has(.reader-ospit-cv) .reader-progress {
  color: rgba(255, 255, 255, 0.9);
}

.reader-ospit-cv {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: min(74vh, 640px);
  margin: 0 -0.75rem;
  padding: clamp(1.5rem, 5vw, 3rem) 1rem;
  border-radius: 0.55rem;
}

.reader-ospit-cv__panel {
  max-width: min(46rem, 100%);
  width: 100%;
  margin: 0 auto;
  text-align: center;
  color: #fff;
}

.reader-ospit-cv__logoimg {
  display: block;
  width: min(420px, 94%, 92vw);
  height: auto;
  margin: 0 auto 1.15rem;
  object-fit: contain;
}

.reader-ospit-cv__brand {
  margin: 0 0 1.35rem;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.12rem, 2.85vw, 1.28rem);
  font-weight: 400;
  letter-spacing: 0.04em;
  text-transform: lowercase;
  color: rgba(255, 255, 255, 0.95);
}

.reader-ospit-cv__h1 {
  margin: 0 0 0.45rem;
  font-size: clamp(2.42rem, 7.1vw, 3.38rem);
  font-weight: 800;
  line-height: 1.22;
  color: #fff;
}

.reader-ospit-cv__yellow {
  margin: 0 0 1.75rem;
  font-size: clamp(2.08rem, 6.05vw, 2.88rem);
  font-weight: 800;
  line-height: 1.22;
  color: var(--cf-yellow);
}

.reader-ospit-cv__man {
  margin: 0;
  font-size: clamp(1.04rem, 2.58vw, 1.12rem);
  font-weight: 500;
  letter-spacing: 0.03em;
  color: rgba(255, 255, 255, 0.78);
}

.reader-main--ospitalita-acc {
  background: #fff;
  border-left-color: var(--cf-yellow);
}

.reader-ospit-acc {
  margin-top: -0.1rem;
  color: var(--cf-navy);
}

.reader-ospit-acc__h {
  margin: 0 0 1rem;
  font-size: clamp(1.28rem, 3.85vw, 1.72rem);
  font-weight: 800;
  line-height: 1.2;
  color: var(--cf-navy);
}

.reader-ospit-acc__main {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.15fr);
  gap: clamp(0.75rem, 3vw, 1.65rem);
  align-items: start;
}

.reader-ospit-acc__fig-col {
  min-width: 0;
}

.reader-ospit-acc__fig-row {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  gap: clamp(0.35rem, 1.8vw, 0.65rem);
  align-items: flex-end;
  justify-content: center;
}

.reader-ospit-acc__fig--duo {
  flex: 1 1 50%;
  min-width: 0;
}

.reader-ospit-acc__fig {
  margin: 0;
  padding: 0;
  border-radius: 0.5rem;
  background: linear-gradient(180deg, #f7fafc 0%, #eef2f8 100%);
  overflow: hidden;
  text-align: center;
  box-shadow: 0 6px 20px rgba(19, 43, 73, 0.08);
}

.reader-ospit-acc__fig--duo .reader-ospit-acc__img {
  max-width: 100%;
}

.reader-ospit-acc__img {
  display: block;
  width: 100%;
  max-width: min(360px, 100%);
  height: auto;
  margin: 0 auto;
  object-fit: contain;
  vertical-align: top;
}

.reader-ospit-acc__list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.reader-ospit-acc__item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.55rem 0.72rem;
  align-items: start;
  margin: 0 0 0.85rem;
}

.reader-ospit-acc__item:last-child {
  margin-bottom: 0;
}

.reader-ospit-acc__badge {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  background: var(--cf-yellow);
  color: var(--cf-navy);
  font-size: 0.95rem;
  font-weight: 800;
  line-height: 1;
  box-shadow: inset 0 0 0 2px rgba(19, 43, 73, 0.12);
}

.reader-ospit-acc__body {
  display: flex;
  flex-direction: column;
  gap: 0.22rem;
  min-width: 0;
}

.reader-ospit-acc__lead {
  font-size: clamp(0.86rem, 2.22vw, 0.9725rem);
  font-weight: 800;
  line-height: 1.28;
  color: var(--cf-navy);
}

.reader-ospit-acc__detail {
  font-size: clamp(0.8rem, 2.08vw, 0.895rem);
  font-weight: 600;
  line-height: 1.45;
  color: rgba(19, 43, 73, 0.88);
}

.reader-main--ospitalita-cabina {
  background: #fafbfd;
  border-left-color: var(--cf-yellow);
}

.reader-ospit-cab__title {
  margin: 0 0 1rem;
  text-align: center;
  font-size: clamp(1.15rem, 3.4vw, 1.58rem);
  font-weight: 800;
  line-height: 1.22;
  color: var(--cf-navy);
}

.reader-ospit-cab__hero-wrap {
  margin: 0 auto 1.25rem;
  padding: 0;
  max-width: 440px;
  border-radius: 0.55rem;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 8px 28px rgba(19, 43, 73, 0.1);
  text-align: center;
}

.reader-ospit-cab__hero {
  display: block;
  width: 100%;
  max-width: 100%;
  max-height: min(300px, 46vh);
  height: auto;
  margin-inline: auto;
  object-fit: contain;
  vertical-align: top;
}

.reader-ospit-cab__cards {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(0.55rem, 2vw, 1rem);
  align-items: stretch;
  margin-bottom: 1.1rem;
}

.reader-ospit-cab__card {
  margin: 0;
  padding: 0.75rem 0.72rem 0.85rem;
  border-radius: 0.45rem;
  border: 2px solid rgba(19, 43, 73, 0.28);
  background: #fff;
  box-shadow: 0 4px 14px rgba(19, 43, 73, 0.05);
}

.reader-ospit-cab__ico {
  display: block;
  width: 52px;
  height: 52px;
  margin: 0 0 0.45rem;
  object-fit: contain;
}

.reader-ospit-cab__h {
  margin: 0 0 0.35rem;
  font-size: clamp(0.78rem, 2vw, 0.8625rem);
  font-weight: 800;
  line-height: 1.2;
  color: var(--cf-navy);
}

.reader-ospit-cab__p {
  margin: 0;
  font-size: clamp(0.71rem, 1.92vw, 0.8rem);
  font-weight: 600;
  line-height: 1.48;
  color: rgba(19, 43, 73, 0.9);
}

.reader-ospit-cab__band {
  margin: 0;
  padding: 0.88rem 1rem 0.92rem;
  border-radius: 0.38rem;
  background: var(--cf-yellow);
  color: var(--cf-navy);
  font-size: clamp(0.76rem, 2vw, 0.8675rem);
  font-weight: 800;
  line-height: 1.42;
  text-align: center;
  box-shadow: 0 6px 18px rgba(237, 200, 0, 0.28);
}

/* Accueil — courtoisie MAI / SEMPRE (libellés italiens conservés pour l’écran) */
.reader-main--ospitalita-cortesia {
  background: #fff;
  border-left-color: var(--cf-yellow);
}

.reader-ospit-cort {
  margin-top: -0.12rem;
  color: var(--cf-navy);
}

.reader-ospit-cort__title {
  margin: 0 0 1.25rem;
  text-align: center;
  font-size: clamp(1.12rem, 3.25vw, 1.62rem);
  font-weight: 800;
  line-height: 1.28;
  color: var(--cf-navy);
  text-wrap: balance;
}

.reader-ospit-cort__cols {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(1rem, 4vw, 2rem);
  align-items: start;
  margin-bottom: 1.35rem;
}

.reader-ospit-cort__col {
  margin: 0;
  padding: 0;
}

.reader-ospit-cort__head {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.35rem;
  margin-bottom: 0.75rem;
  text-align: center;
}

.reader-ospit-cort__glyph {
  display: block;
  font-size: clamp(2.25rem, 7vw, 3rem);
  font-weight: 700;
  line-height: 1;
}

.reader-ospit-cort__glyph--mai {
  color: #b22222;
}

.reader-ospit-cort__glyph--sempre {
  color: #3d9428;
}

.reader-ospit-cort__h {
  margin: 0;
  font-size: clamp(0.88rem, 2.35vw, 1.02rem);
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.reader-ospit-cort__head--mai .reader-ospit-cort__h {
  color: #b22222;
}

.reader-ospit-cort__head--sempre .reader-ospit-cort__h {
  color: #3d9428;
}

.reader-ospit-cort__ul {
  margin: 0;
  padding: 0 0 0 1rem;
  list-style: disc;
}

.reader-ospit-cort__li {
  margin: 0 0 0.5rem;
  font-size: clamp(0.8rem, 2.08vw, 0.9025rem);
  font-weight: 600;
  line-height: 1.42;
  color: var(--cf-navy);
}

.reader-ospit-cort__li:last-child {
  margin-bottom: 0;
}

.reader-ospit-cort__footer {
  margin: 0;
  padding-top: 0.25rem;
  text-align: center;
  font-size: clamp(0.88rem, 2.4vw, 1.0625rem);
  font-weight: 700;
  line-height: 1.42;
  color: var(--cf-navy);
}

/* Accueil — phrases IT / FR (tableau clair) */
.reader-main--ospitalita-frasi {
  background: #fff;
  border-left-color: var(--cf-yellow);
}

.reader-ospit-fr {
  margin-top: -0.12rem;
}

.reader-ospit-fr__title {
  margin: 0 auto 1.15rem;
  text-align: center;
  font-size: clamp(1.12rem, 3.35vw, 1.62rem);
  font-weight: 800;
  line-height: 1.35;
  color: var(--cf-navy);
  text-wrap: balance;
}

.reader-ospit-fr__table-wrap {
  margin: 0 auto;
  max-width: 42rem;
  overflow-x: auto;
  border-radius: 0.4rem;
  border: 1px solid rgba(19, 43, 73, 0.18);
  box-shadow: 0 4px 18px rgba(19, 43, 73, 0.06);
}

.reader-ospit-fr__table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
  background: #fff;
}

.reader-ospit-fr__th,
.reader-ospit-fr__td {
  padding: clamp(0.55rem, 2vw, 0.82rem) clamp(0.5rem, 1.8vw, 0.9rem);
  text-align: center;
  vertical-align: middle;
  border: 1px solid rgba(19, 43, 73, 0.2);
  font-size: clamp(0.76rem, 2vw, 0.8925rem);
  line-height: 1.38;
}

.reader-ospit-fr__th {
  font-weight: 800;
  background: #e9ecef;
  color: var(--cf-navy);
}

.reader-ospit-fr__th--fr {
  font-family: inherit;
}

.reader-ospit-fr__tr:nth-child(even) {
  background: #f3f5f8;
}

.reader-ospit-fr__td {
  font-weight: 600;
  color: #1a2744;
}

.reader-ospit-fr__td--fr {
  font-weight: 800;
}

/* Cameriere — frasario IT / FR (tableau clair, titres bicolores) */
.reader-main--cameriere-frasi {
  background: #fff;
  border-left-color: var(--cf-yellow);
}

.reader-cameriere-fr {
  margin-top: -0.12rem;
}

.reader-cameriere-fr__title {
  margin: 0 0 clamp(0.85rem, 2vw, 1.15rem);
  text-align: left;
  font-size: clamp(1.05rem, 2.8vw, 1.5rem);
  font-weight: 800;
  line-height: 1.25;
  color: var(--cf-navy);
  text-wrap: balance;
}

.reader-cameriere-fr__table-wrap {
  margin: 0;
  max-width: 44rem;
  overflow-x: auto;
  border-radius: 2px;
  border: 1px solid var(--cf-navy);
  box-shadow: 0 4px 18px rgba(var(--cf-navy-rgb), 0.08);
}

.reader-cameriere-fr__table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
  background: #fff;
}

.reader-cameriere-fr__th,
.reader-cameriere-fr__td {
  padding: clamp(0.55rem, 1.8vw, 0.85rem) clamp(0.55rem, 1.8vw, 0.95rem);
  text-align: left;
  vertical-align: middle;
  border: 1px solid var(--cf-navy);
  font-size: clamp(0.78rem, 1.9vw, 0.95rem);
  line-height: 1.42;
}

.reader-cameriere-fr__th {
  font-weight: 800;
}

.reader-cameriere-fr__th--it {
  background: var(--cf-navy);
  color: #fff;
}

.reader-cameriere-fr__th--fr {
  background: var(--cf-yellow);
  color: var(--cf-navy);
}

.reader-cameriere-fr__td {
  font-weight: 600;
  color: var(--cf-navy);
}

.reader-cameriere-fr__td--it {
  background: #e8ecf2;
}

.reader-cameriere-fr__td--fr {
  background: #fff;
  font-weight: 600;
}

/* Ospitalità — Trattamento Ospite (Standard / Gold / VIP) */
.reader-main--ospitalita-tratt {
  background: #fff;
  border-left-color: var(--cf-yellow);
}

.reader-ospit-tratt {
  margin-top: -0.1rem;
  min-width: 0;
  width: 100%;
  max-width: 100%;
}

.reader-ospit-tratt__title {
  margin: 0 0 clamp(0.65rem, 1.8vw, 1rem);
  font-size: clamp(1.05rem, 2.65vw, 1.45rem);
  font-weight: 800;
  line-height: 1.2;
  color: var(--cf-navy);
  text-align: left;
  text-wrap: balance;
}

.reader-ospit-tratt__scroll {
  overflow-x: auto;
  overflow-y: hidden;
  margin: 0 -0.1rem;
  padding: 0.1rem;
  border-radius: 0.45rem;
  -webkit-overflow-scrolling: touch;
  touch-action: pan-x pan-y pinch-zoom;
  overscroll-behavior-x: contain;
  width: 100%;
  max-width: 100%;
  min-width: 0;
}

.reader-ospit-tratt__table {
  width: 100%;
  min-width: 520px;
  border-collapse: separate;
  border-spacing: 0;
  border: 1px solid rgba(19, 43, 73, 0.2);
  border-radius: 0.45rem;
  overflow: hidden;
  background: #e9edf3;
  box-shadow: 0 4px 18px rgba(var(--cf-navy-rgb), 0.08);
}

.reader-ospit-tratt__th {
  padding: clamp(0.45rem, 1.4vw, 0.62rem) clamp(0.42rem, 1.2vw, 0.55rem);
  font-size: clamp(0.68rem, 1.55vw, 0.8rem);
  font-weight: 800;
  text-align: center;
  vertical-align: middle;
  border: 1px solid rgba(19, 43, 73, 0.22);
}

.reader-ospit-tratt__th--corner {
  width: 8.5rem;
  background: #e9edf3;
}

.reader-ospit-tratt__th--std {
  background: #dfe4ec;
  color: var(--cf-navy);
}

.reader-ospit-tratt__th--gold {
  background: #fff6c8;
  color: var(--cf-navy);
}

.reader-ospit-tratt__th--vip {
  background: var(--cf-navy);
  color: #fff;
  border-color: rgba(255, 214, 60, 0.55);
  box-shadow: inset 0 0 0 1px rgba(255, 214, 60, 0.35);
}

.reader-ospit-tratt__th--row {
  text-align: left;
  background: #f1f4f9;
  vertical-align: middle;
}

.reader-ospit-tratt__rowhead {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  min-width: 0;
}

.reader-ospit-tratt__rowico {
  flex-shrink: 0;
  width: clamp(1.55rem, 3.5vw, 1.85rem);
  max-width: 1.9rem;
  max-height: 1.9rem;
  height: auto;
  object-fit: contain;
}

.reader-ospit-tratt__rowlab {
  font-size: clamp(0.7rem, 1.5vw, 0.82rem);
  font-weight: 800;
  line-height: 1.25;
  color: var(--cf-navy);
}

.reader-ospit-tratt__td {
  padding: clamp(0.45rem, 1.4vw, 0.62rem) clamp(0.4rem, 1.2vw, 0.55rem);
  vertical-align: top;
  border: 1px solid rgba(19, 43, 73, 0.18);
  background: #fff;
}

.reader-ospit-tratt__td--std {
  background: #f7f9fc;
}

.reader-ospit-tratt__td--gold {
  background: #fffef5;
}

.reader-ospit-tratt__td--vip {
  background: var(--cf-navy);
  border-color: rgba(255, 214, 60, 0.45);
  color: #fff;
}

.reader-ospit-tratt__cell {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 0.45rem 0.5rem;
  min-width: 0;
}

.reader-ospit-tratt__cell--has-trail {
  align-items: flex-end;
}

.reader-ospit-tratt__lead {
  flex-shrink: 0;
  object-fit: contain;
}

.reader-ospit-tratt__lead--bottle {
  margin-top: 0.12rem;
  width: clamp(1.2rem, 2.8vw, 1.45rem);
  max-width: 100%;
  height: auto;
  object-fit: contain;
}

.reader-ospit-tratt__lead--vip {
  margin-top: 0.05rem;
  width: clamp(1.35rem, 3.1vw, 1.75rem);
  max-width: 100%;
  height: auto;
  object-fit: contain;
}

.reader-ospit-tratt__td--vip .reader-ospit-tratt__lead--bottle,
.reader-ospit-tratt__td--vip .reader-ospit-tratt__lead--vip {
  filter: brightness(1.12) contrast(1.05);
}

.reader-ospit-tratt__txt {
  flex: 1 1 12ch;
  min-width: 0;
  font-size: clamp(0.66rem, 1.45vw, 0.78rem);
  font-weight: 700;
  line-height: 1.38;
  color: var(--cf-navy);
}

.reader-ospit-tratt__td--vip .reader-ospit-tratt__txt {
  color: #fff;
}

.reader-ospit-tratt__trail {
  flex: 0 1 auto;
  width: auto;
  max-width: min(100%, 4.25rem);
  height: auto;
  max-height: min(3rem, 14vw);
  object-fit: contain;
  margin-left: auto;
  align-self: flex-end;
}

.reader-ospit-tratt__mark {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 0.08rem;
  width: 1.05rem;
  height: 1.05rem;
  font-size: 0.62rem;
  line-height: 1;
}

.reader-ospit-tratt__mark--check {
  border-radius: 2px;
  background: #1c9d55;
  color: #fff;
  font-weight: 900;
}

.reader-ospit-tratt__mark--check::before {
  content: "✓";
  font-size: 0.72rem;
  translate: 0 0.02em;
}

.reader-ospit-tratt__mark--cross {
  color: #d12b2b;
  font-weight: 900;
  font-size: 0.95rem;
  width: auto;
  height: auto;
}

.reader-ospit-tratt__mark--cross::before {
  content: "✕";
}

.reader-ospit-tratt__mark--star {
  width: auto;
  height: auto;
  color: #e6b800;
  font-size: 1.05rem;
}

.reader-ospit-tratt__mark--star::before {
  content: "★";
}

.reader-ospit-tratt__mark--warn {
  width: auto;
  height: auto;
  color: #7a8499;
  font-size: 0.95rem;
}

.reader-ospit-tratt__mark--warn::before {
  content: "⚠";
}

.reader-ospit-tratt__mark--dblcheck {
  width: auto;
  height: auto;
  display: inline-flex;
  gap: 0.12rem;
}

.reader-ospit-tratt__mark--dblcheck::before,
.reader-ospit-tratt__mark--dblcheck::after {
  content: "✓";
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 0.88rem;
  height: 0.88rem;
  border-radius: 2px;
  background: #1c9d55;
  color: #fff;
  font-size: 0.58rem;
  font-weight: 900;
}

.reader-ospit-tratt__td--vip .reader-ospit-tratt__mark--warn {
  color: #ffe766;
}

.reader-ospit-tratt__td--vip .reader-ospit-tratt__mark--dblcheck::before,
.reader-ospit-tratt__td--vip .reader-ospit-tratt__mark--dblcheck::after {
  background: #43c77a;
  color: #fff;
}

@media (max-width: 640px) {
  .reader-ospit-tratt__table {
    min-width: 480px;
  }

  .reader-ospit-tratt__cell--has-trail {
    flex-direction: column;
    align-items: stretch;
    gap: 0.35rem;
  }

  .reader-ospit-tratt__trail {
    margin-left: 0;
    align-self: flex-start;
    max-width: 100%;
    max-height: min(2.75rem, 22vw);
  }
}

/* Ospitalità — sanificazione pigne doccia / rubinetti */
.reader-main--ospitalita-sani {
  background: #fff;
  border-left-color: var(--cf-yellow);
}

.reader-ospit-sani {
  margin-top: -0.08rem;
  min-width: 0;
  width: 100%;
  max-width: 100%;
}

.reader-ospit-sani__main-title {
  margin: 0 0 clamp(0.85rem, 2vw, 1.15rem);
  text-align: center;
  font-size: clamp(0.92rem, 2.15vw, 1.22rem);
  font-weight: 800;
  line-height: 1.28;
  color: var(--cf-navy);
  text-wrap: balance;
}

.reader-ospit-sani__block {
  margin: 0 0 clamp(0.65rem, 1.6vw, 0.85rem);
}

.reader-ospit-sani__step-title {
  margin: 0 0 0.45rem;
  font-size: clamp(0.78rem, 1.65vw, 0.92rem);
  font-weight: 800;
  color: #111;
  line-height: 1.25;
}

.reader-ospit-sani__panel {
  border-radius: 0.42rem;
  padding: clamp(0.65rem, 1.8vw, 0.95rem);
  border: 1px solid rgba(19, 43, 73, 0.12);
  min-width: 0;
}

.reader-ospit-sani__panel--mint {
  background: #e8f5e9;
}

.reader-ospit-sani__panel--grey {
  background: #eceff1;
}

.reader-ospit-sani__band {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: clamp(0.55rem, 1.8vw, 1rem);
  min-width: 0;
}

.reader-ospit-sani__band--step2 {
  align-items: flex-start;
}

.reader-ospit-sani__fig {
  margin: 0;
  padding: 0;
  line-height: 0;
}

.reader-ospit-sani__fig--product {
  flex: 0 0 auto;
}

.reader-ospit-sani__fig--decs {
  flex: 0 0 auto;
  max-width: min(8.5rem, 32vw);
}

.reader-ospit-sani__fig--flow {
  flex: 1 1 min(320px, 100%);
  min-width: 0;
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
}

.reader-ospit-sani__img {
  display: block;
  width: auto;
  max-width: min(5.5rem, 22vw);
  height: auto;
}

.reader-ospit-sani__fig--decs .reader-ospit-sani__img {
  max-width: 100%;
}

.reader-ospit-sani__flow-img {
  display: block;
  width: auto;
  max-width: min(100%, 720px);
  height: auto;
  max-height: min(168px, 26vw);
  object-fit: contain;
  object-position: left center;
}

.reader-ospit-sani__immerse {
  margin: 0;
  flex: 0 1 10rem;
  font-size: clamp(0.72rem, 1.45vw, 0.85rem);
  font-weight: 700;
  line-height: 1.35;
  color: #1a2744;
}

.reader-ospit-sani__aside {
  flex: 1 1 14rem;
  min-width: min(100%, 14rem);
}

.reader-ospit-sani__duration {
  margin: 0 0 0.28rem;
  font-size: clamp(0.85rem, 2vw, 1.05rem);
  font-weight: 800;
  color: #111;
}

.reader-ospit-sani__instruction {
  margin: 0;
  font-size: clamp(0.72rem, 1.45vw, 0.86rem);
  font-weight: 700;
  line-height: 1.38;
  color: #1a2744;
}

.reader-ospit-sani__warn {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.65rem;
  margin: clamp(0.55rem, 1.5vw, 0.75rem) 0 clamp(0.65rem, 1.8vw, 0.9rem);
  padding: clamp(0.45rem, 1.3vw, 0.62rem) clamp(0.55rem, 1.5vw, 0.85rem);
  border-radius: 0.35rem;
  background: #c62828;
  border: 1px solid rgba(0, 0, 0, 0.15);
  box-shadow: 0 4px 14px rgba(198, 40, 40, 0.25);
}

.reader-ospit-sani__warn-ico {
  flex-shrink: 0;
  width: clamp(2.75rem, 8vw, 3.5rem);
  height: auto;
  object-fit: contain;
  filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.2));
}

.reader-ospit-sani__warn-txt {
  margin: 0;
  flex: 1 1 16rem;
  font-size: clamp(0.68rem, 1.4vw, 0.82rem);
  font-weight: 800;
  line-height: 1.35;
  color: #fff;
  text-wrap: pretty;
}

@media (max-width: 560px) {
  .reader-ospit-sani__panel {
    overflow-x: auto;
    overflow-y: visible;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
    touch-action: pan-x pan-y pinch-zoom;
  }

  .reader-ospit-sani__band {
    flex-direction: column;
    align-items: stretch;
  }

  /* APESIN (ospitalita13.png) : moins large en colonne sur mobile */
  .reader-ospit-sani__fig--product {
    align-self: center;
    max-width: min(4.75rem, 42vw);
  }

  .reader-ospit-sani__fig--product .reader-ospit-sani__img {
    max-width: 100%;
  }

  .reader-ospit-sani__fig--flow {
    flex-basis: auto;
    max-width: 100%;
  }

  .reader-ospit-sani__flow-img {
    max-width: 100%;
    max-height: min(140px, 36vw);
  }

  .reader-ospit-sani__immerse {
    flex-basis: auto;
  }

  .reader-ospit-sani__aside {
    flex-basis: auto;
  }
}

/* Ospitalità — ispezione cimici / heatmap cabina */
.reader-main--ospitalita-cimici {
  background: #fff;
  border-left-color: var(--cf-yellow);
}

.reader-ospit-cimici {
  margin-top: -0.05rem;
  min-width: 0;
}

.reader-ospit-cimici__head {
  margin-bottom: clamp(0.65rem, 1.8vw, 0.95rem);
}

.reader-ospit-cimici__title {
  margin: 0 0 0.45rem;
  text-align: left;
  font-size: clamp(0.95rem, 2.2vw, 1.32rem);
  font-weight: 800;
  line-height: 1.22;
  color: var(--cf-navy);
  text-wrap: balance;
}

.reader-ospit-cimici__lead {
  margin: 0;
  max-width: 58ch;
  font-size: clamp(0.72rem, 1.5vw, 0.86rem);
  font-weight: 600;
  line-height: 1.45;
  color: #5a6478;
  text-wrap: pretty;
}

.reader-ospit-cimici__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.95fr);
  gap: clamp(0.75rem, 2.2vw, 1.25rem);
  align-items: start;
  margin-bottom: clamp(0.75rem, 2vw, 1.1rem);
  min-width: 0;
}

.reader-ospit-cimici__grid > * {
  min-width: 0;
}

.reader-ospit-cimici__hero {
  margin: 0;
  padding: 0.5rem;
  border: 1px solid rgba(19, 43, 73, 0.25);
  border-radius: 0.5rem;
  background: #fafbfc;
  line-height: 0;
  min-width: 0;
  max-width: 100%;
  overflow: hidden;
}

.reader-ospit-cimici__hero-img {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
  object-fit: contain;
}

.reader-ospit-cimici__cards {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.reader-ospit-cimici__card {
  position: relative;
  display: flex;
  gap: 0.55rem;
  align-items: flex-start;
  padding: clamp(0.5rem, 1.4vw, 0.68rem) clamp(0.55rem, 1.5vw, 0.78rem);
  border: 2px solid var(--cf-navy);
  border-radius: 0.42rem;
  background: #fff;
  box-shadow: 0 3px 12px rgba(var(--cf-navy-rgb), 0.06);
}

.reader-ospit-cimici__num {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.65rem;
  height: 1.65rem;
  margin-top: 0.06rem;
  border-radius: 0.28rem;
  background: var(--cf-yellow);
  color: var(--cf-navy);
  font-weight: 900;
  font-size: clamp(0.72rem, 1.45vw, 0.82rem);
  line-height: 1;
}

.reader-ospit-cimici__card-p {
  margin: 0;
  font-size: clamp(0.7rem, 1.45vw, 0.84rem);
  font-weight: 600;
  line-height: 1.42;
  color: var(--cf-navy);
  min-width: 0;
  overflow-wrap: anywhere;
}

.reader-ospit-cimici__lab {
  font-weight: 800;
}

.reader-ospit-cimici__banner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.65rem;
  margin: 0;
  padding: clamp(0.55rem, 1.5vw, 0.78rem) clamp(0.65rem, 1.8vw, 0.95rem);
  border: 2px solid var(--cf-navy);
  border-radius: 0.45rem;
  background: linear-gradient(180deg, #fff9c4 0%, var(--cf-yellow) 100%);
  box-shadow: 0 4px 16px rgba(var(--cf-navy-rgb), 0.1);
}

.reader-ospit-cimici__banner-ico {
  flex-shrink: 0;
  width: clamp(2.4rem, 6.5vw, 3.1rem);
  height: auto;
  object-fit: contain;
}

.reader-ospit-cimici__banner-txt {
  margin: 0;
  flex: 1 1 16rem;
  min-width: 0;
  font-size: clamp(0.72rem, 1.5vw, 0.88rem);
  font-weight: 700;
  line-height: 1.4;
  color: var(--cf-navy);
  text-wrap: pretty;
  overflow-wrap: anywhere;
}

@media (max-width: 860px) {
  .reader-ospit-cimici__grid {
    grid-template-columns: 1fr;
  }
}

/* Ospitalità — protocollo operativo trattamento cimici (biforcazione post-ispezione) */
.reader-main--ospitalita-proto-cimici {
  background: #fff;
  border-left-color: var(--cf-yellow);
}

.reader-ospit-proto {
  margin-top: -0.05rem;
  min-width: 0;
}

.reader-ospit-proto__title {
  margin: 0 0 clamp(0.65rem, 1.8vw, 0.95rem);
  text-align: left;
  font-size: clamp(0.95rem, 2.15vw, 1.28rem);
  font-weight: 800;
  line-height: 1.22;
  color: var(--cf-navy);
  text-wrap: balance;
}

.reader-ospit-proto__hubflow {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
  width: 100%;
  max-width: 100%;
  min-width: 0;
}

.reader-ospit-proto__hub {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
  max-width: 100%;
  box-sizing: border-box;
  padding: clamp(0.45rem, 1.3vw, 0.62rem) clamp(0.85rem, 2vw, 1.25rem);
  border-radius: 0.4rem;
  background: var(--cf-navy);
  border: 2px solid rgba(255, 255, 255, 0.12);
  box-shadow: 0 6px 20px rgba(var(--cf-navy-rgb), 0.18);
}

.reader-ospit-proto__hub-ico {
  display: block;
  width: clamp(2.25rem, 5.5vw, 2.85rem);
  height: auto;
  object-fit: contain;
}

.reader-ospit-proto__hub-txt {
  font-size: clamp(0.78rem, 1.65vw, 0.95rem);
  font-weight: 800;
  letter-spacing: 0.02em;
  color: #fff;
  min-width: 0;
  overflow-wrap: anywhere;
  text-align: center;
}

.reader-ospit-proto__fork {
  display: flex;
  justify-content: space-between;
  width: min(22rem, 88%);
  margin: 0.15rem auto 0.35rem;
  padding: 0 min(18%, 4rem);
  font-size: clamp(1.45rem, 3.6vw, 1.62rem);
  line-height: 1;
  color: var(--cf-navy);
  opacity: 0.72;
}

.reader-ospit-proto__chev::before {
  content: "↓";
}

.reader-ospit-proto__cols {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: clamp(0.65rem, 1.8vw, 1rem);
  width: 100%;
  max-width: 100%;
  min-width: 0;
  align-items: stretch;
}

.reader-ospit-proto__col {
  display: flex;
  flex-direction: column;
  min-width: 0;
  border-radius: 0.45rem;
  overflow: hidden;
}

.reader-ospit-proto__col--a {
  border: 2px solid #66bb6a;
  background: #e8f5e9;
}

.reader-ospit-proto__col--b {
  border: 2px solid #e53935;
  background: #fff;
}

.reader-ospit-proto__col-head {
  margin: 0;
  padding: 0.42rem 0.55rem;
  font-size: clamp(0.72rem, 1.45vw, 0.85rem);
  font-weight: 800;
  text-align: center;
  color: #fff;
}

.reader-ospit-proto__col--a .reader-ospit-proto__col-head {
  background: #2e7d32;
}

.reader-ospit-proto__col-head--danger {
  background: #c62828;
}

.reader-ospit-proto__panel {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: clamp(0.5rem, 1.5vw, 0.72rem);
  align-items: stretch;
  padding: clamp(0.55rem, 1.5vw, 0.78rem);
  border: none;
  background: transparent;
}

.reader-ospit-proto__panel--a {
  background: transparent;
}

.reader-ospit-proto__panel--b {
  background: transparent;
}

.reader-ospit-proto__step {
  display: grid;
  grid-template-columns: auto auto minmax(0, 1fr);
  gap: clamp(0.3rem, 0.95vmin + 0.2vw, 0.55rem);
  align-items: center;
  width: 100%;
  min-width: 0;
}

.reader-ospit-proto__num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  min-width: clamp(0.92rem, 3.85vmin + 0.35rem, 1.42rem);
  width: clamp(0.92rem, 3.85vmin + 0.35rem, 1.42rem);
  height: clamp(0.92rem, 3.85vmin + 0.35rem, 1.42rem);
  padding: 0;
  flex-shrink: 0;
  border-radius: 999px;
  font-size: clamp(0.58rem, 2.85vmin + 0.06rem, 0.82rem);
  font-weight: 800;
  line-height: 1;
  color: #fff;
}

.reader-ospit-proto__panel--a .reader-ospit-proto__num {
  background: #2e7d32;
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.12);
}

.reader-ospit-proto__panel--b .reader-ospit-proto__num {
  background: #c62828;
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.12);
}

.reader-ospit-proto__ico-frame {
  position: relative;
  margin: 0;
  padding: 0;
  width: clamp(1.85rem, 5.75vmin + 0.95vw, 3.05rem);
  height: clamp(1.85rem, 5.75vmin + 0.95vw, 3.05rem);
  overflow: hidden;
  flex-shrink: 0;
  align-self: center;
}

.reader-ospit-proto__ico-sprite {
  display: block;
  width: 100%;
  height: calc(var(--n) * 100%);
  max-width: none;
  object-fit: fill;
  object-position: top center;
  transform: translateY(calc(-100% * var(--i) / var(--n)));
}

.reader-ospit-proto__step-txt {
  margin: 0;
  font-size: clamp(0.62rem, 1.95vmin + 0.32vw, 0.8rem);
  font-weight: 600;
  line-height: 1.42;
  color: var(--cf-navy);
  min-width: 0;
  overflow-wrap: anywhere;
}

@media (max-width: 720px) {
  .reader-ospit-proto__cols {
    grid-template-columns: 1fr;
  }

  .reader-ospit-proto__fork {
    display: none;
  }

  .reader-ospit-proto__panel {
    gap: clamp(0.42rem, 2.8vw, 0.72rem);
  }

  .reader-ospit-proto__step {
    gap: clamp(0.24rem, 1.85vmin + 0.06rem, 0.48rem);
  }

  .reader-ospit-proto__title {
    font-size: clamp(0.86rem, 3.85vmin + 0.25rem, 1.28rem);
  }

  .reader-ospit-proto__col-head {
    font-size: clamp(0.68rem, 2.85vmin + 0.06rem, 0.85rem);
    padding: 0.35rem 0.48rem;
  }

  .reader-ospit-proto__hub-txt {
    font-size: clamp(0.7rem, 2.95vmin + 0.06rem, 0.95rem);
  }
}

@media (max-width: 480px) {
  .reader-ospit-proto__num {
    min-width: clamp(0.85rem, 9.25vw, 1.06rem);
    width: clamp(0.85rem, 9.25vw, 1.06rem);
    height: clamp(0.85rem, 9.25vw, 1.06rem);
    font-size: clamp(0.52rem, 3.95vw + 0.06rem, 0.72rem);
  }

  .reader-ospit-proto__ico-frame {
    width: clamp(1.55rem, 15.8vw, 2.35rem);
    height: clamp(1.55rem, 15.8vw, 2.35rem);
  }

  .reader-ospit-proto__step-txt {
    font-size: clamp(0.58rem, 3.4vw + 0.06rem, 0.74rem);
    line-height: 1.44;
  }
}

/* Cameriere — clôture : slide = image (post-it déjà dans le visuel) + bandeau GO compact + footer, fond page blanc */
.reader-main.reader-main--cameriere-finale {
  background: #fff;
  border-color: rgba(var(--cf-navy-rgb), 0.12);
}

.reader-cameriere-finale {
  margin: 0.2rem 0 0;
  min-width: 0;
}

.reader-cameriere-finale__scene {
  margin: 0;
  padding: 0;
  width: 100%;
  max-width: 100%;
  border-radius: 0.45rem;
  overflow: hidden;
  background: #e8ecf4;
  line-height: 0;
}

.reader-cameriere-finale__scene-img {
  display: block;
  width: 100%;
  height: auto;
  vertical-align: top;
}

.reader-cameriere-finale__tail {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.45rem;
  margin-top: 0.45rem;
  padding: 0 0.35rem 0.15rem;
  width: 100%;
  box-sizing: border-box;
}

.reader-cameriere-finale__footer {
  margin: 0;
  order: 0;
  max-width: 38rem;
  padding: 0 0.25rem;
  text-align: center;
  font-size: clamp(0.78rem, 1.95vw, 0.95rem);
  font-weight: 600;
  line-height: 1.42;
  color: var(--cf-navy);
  text-wrap: balance;
}

.reader-cameriere-finale__go-wrap {
  margin: 0;
  padding: 0;
  order: 1;
  flex-shrink: 0;
  align-self: center;
  display: flex;
  justify-content: center;
  line-height: 0;
}

.reader-cameriere-finale__go-img {
  display: block;
  width: auto;
  max-width: min(9rem, 36vw);
  height: auto;
  object-fit: contain;
}

.reader-cameriere-finale__go-fallback {
  margin: 0;
  order: 1;
  flex-shrink: 0;
  align-self: center;
  padding: 0.28rem 0.55rem 0.32rem;
  max-width: min(9.5rem, 40vw);
  text-align: center;
  font-size: clamp(0.62rem, 2.4vw, 0.78rem);
  font-weight: 900;
  letter-spacing: 0.05em;
  line-height: 1.05;
  color: var(--cf-yellow);
  background: #0f1f52;
  border: 1px solid rgba(0, 0, 0, 0.28);
  border-radius: 3px;
}

/* Petit écran : taille max du bandeau GO */
@media (max-width: 760px) {
  .reader-cameriere-finale__go-img {
    max-width: min(7.25rem, 58vw);
  }

  .reader-cameriere-finale__go-fallback {
    max-width: min(8rem, 72vw);
  }
}

/* Accueil — slogan nettoyage (diagonale + chariot + blocs ; texte contenu italien à l’écran) */
.reader-main--ospitalita-pulizia {
  background: #fff;
  border-left-color: var(--cf-yellow);
}

.reader-main--ospitalita-pulizia-flow {
  background: #fff;
  border-left-color: var(--cf-yellow);
}

.reader-main--ospitalita-allestimento {
  background: #fff;
  border-left-color: var(--cf-yellow);
}

.reader-main--ospitalita-casi {
  background: #fff;
  border-left-color: var(--cf-yellow);
}

.reader-main--ospitalita-checklist {
  background: #fff;
  border-left-color: var(--cf-yellow);
}

.reader-ospit-casi {
  margin: 0;
  padding: 0 0 0.5rem;
  min-width: 0;
}

.reader-ospit-casi__title {
  margin: 0 0 clamp(0.95rem, 2.4vw, 1.35rem);
  font-size: clamp(1.12rem, 3.1vw, 1.72rem);
  font-weight: 800;
  line-height: 1.2;
  color: var(--cf-navy);
  text-wrap: balance;
  text-align: left;
}

.reader-ospit-casi__stack {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.reader-ospit-casi__rule {
  margin: clamp(0.65rem, 2vw, 1rem) 0 clamp(0.68rem, 2vw, 1rem);
  border: none;
  border-top: 2px solid rgba(0, 0, 0, 0.78);
}

.reader-ospit-casi__panel {
  margin: 0;
}

.reader-ospit-casi__panel-grid {
  display: grid;
  grid-template-columns: minmax(72px, 6.5rem) minmax(0, 1fr);
  gap: clamp(0.55rem, 2vw, 1.15rem);
  align-items: center;
  min-width: 0;
}

.reader-ospit-casi__ico {
  display: block;
  width: auto;
  height: auto;
  max-width: min(6.35rem, 30vw, 120px);
  object-fit: contain;
}

.reader-ospit-casi__subh {
  margin: 0 0 0.55rem;
  font-size: clamp(0.96rem, 2.2vw, 1.2rem);
  font-weight: 800;
  color: var(--cf-navy);
  line-height: 1.28;
}

.reader-ospit-casi__ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.reader-ospit-casi__li {
  position: relative;
  margin: 0 0 0.38rem;
  padding-left: 1.2rem;
  font-size: clamp(0.74rem, 1.75vw, 0.9rem);
  font-weight: 600;
  line-height: 1.42;
  color: var(--cf-navy);
}

.reader-ospit-casi__li:last-child {
  margin-bottom: 0;
}

.reader-ospit-casi__li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.45em;
  width: 0.45rem;
  height: 0.45rem;
  border-radius: 50%;
  background: var(--cf-yellow);
  box-shadow: 0 0 0 1px rgba(26, 43, 73, 0.45);
}

.reader-ospit-check {
  position: relative;
  margin: 0;
  padding: 0 0 4.35rem;
  min-width: 0;
}

.reader-ospit-check__title {
  margin: 0 0 clamp(0.85rem, 2.4vw, 1.45rem);
  text-align: center;
  font-size: clamp(1.12rem, 3.05vw, 1.78rem);
  font-weight: 800;
  line-height: 1.2;
  color: var(--cf-navy);
  text-wrap: balance;
}

.reader-ospit-check__center {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  max-width: min(30rem, 100%);
  margin-inline: auto;
  min-width: 0;
  box-sizing: border-box;
  padding-inline: env(safe-area-inset-left, 0) env(safe-area-inset-right, 0);
}

.reader-ospit-check__clipboard {
  width: 100%;
  min-width: 0;
}

.reader-ospit-check__clip {
  display: block;
  width: min(100%, 22rem);
  max-width: 100%;
  height: auto;
  margin: 0 auto -0.08rem;
}

.reader-ospit-check__pad {
  margin: 0 auto;
  width: min(100%, 22rem);
  max-width: 100%;
  box-sizing: border-box;
  padding: clamp(0.82rem, 2.4vw, 1.28rem) clamp(0.92rem, 2.6vw, 1.45rem) clamp(1rem, 3vw, 1.5rem);
  border-radius: 0 0 0.42rem 0.42rem;
  border: 2px solid rgba(26, 43, 73, 0.2);
  border-top: none;
  background: linear-gradient(180deg, #fdfefe 0%, #f6f8fb 100%);
  box-shadow: 0 14px 38px rgba(19, 43, 73, 0.1);
}

.reader-ospit-check__pad--boxed {
  border-radius: 0.42rem;
  border-top: 2px solid rgba(26, 43, 73, 0.2);
}

.reader-ospit-check__ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.reader-ospit-check__li {
  display: flex;
  gap: 0.55rem;
  align-items: flex-start;
  margin: 0 0 0.72rem;
}

.reader-ospit-check__li:last-child {
  margin-bottom: 0;
}

.reader-ospit-check__box {
  flex-shrink: 0;
  width: 1.02rem;
  height: 1.02rem;
  margin-top: 0.22em;
  border: 2px solid var(--cf-navy);
  border-radius: 0.15rem;
  background: #fff;
}

.reader-ospit-check__txt {
  font-size: clamp(0.76rem, 1.85vw, 0.915rem);
  font-weight: 700;
  line-height: 1.4;
  color: var(--cf-navy);
  min-width: 0;
  flex: 1 1 auto;
  overflow-wrap: anywhere;
}

.reader-ospit-check__stamp {
  margin: clamp(1.35rem, 3.6vw, 2rem) auto 0;
  max-width: 22em;
  padding-inline: 0.35rem;
  text-align: center;
  font-size: clamp(1.48rem, 5.2vw, 2.55rem);
  font-weight: 800;
  letter-spacing: 0.04em;
  line-height: 1.22;
  color: var(--cf-yellow);
  -webkit-text-stroke: min(1.75px, 0.06em) #0f172a;
  paint-order: stroke fill;
  text-shadow:
    1px 0 0 rgba(15, 23, 42, 0.92),
    -1px 0 0 rgba(15, 23, 42, 0.92),
    0 1px 0 rgba(15, 23, 42, 0.92),
    0 -1px 0 rgba(15, 23, 42, 0.92),
    1px 1px 0 rgba(15, 23, 42, 0.75),
    -1px -1px 0 rgba(15, 23, 42, 0.75);
}

.reader-ospit-check__brand {
  position: absolute;
  right: 0.15rem;
  bottom: 0.15rem;
  width: min(7rem, 28vw);
  height: auto;
  object-fit: contain;
  opacity: 0.95;
}

@media (max-width: 560px) {
  .reader-ospit-casi__panel-grid {
    grid-template-columns: 1fr;
    justify-items: center;
    text-align: center;
  }

  .reader-ospit-casi__copy {
    width: 100%;
  }

  .reader-ospit-casi__ico {
    max-width: 5rem;
  }

  .reader-ospit-casi__li {
    text-align: left;
  }
}

.reader-ospit-allest {
  margin: 0;
  padding: 0 0 0.35rem;
  min-width: 0;
}

.reader-ospit-allest__title {
  margin: 0 0 clamp(0.95rem, 2.6vw, 1.45rem);
  text-align: center;
  font-size: clamp(1.2rem, 3.4vw, 1.85rem);
  font-weight: 800;
  line-height: 1.2;
  color: var(--cf-navy);
  text-wrap: balance;
}

.reader-ospit-allest__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(10.5rem, 15rem);
  gap: clamp(0.85rem, 2.5vw, 1.75rem);
  align-items: start;
  min-width: 0;
}

.reader-ospit-allest__main {
  min-width: 0;
}

.reader-ospit-allest__cue {
  margin: 0;
  font-size: clamp(0.66rem, 1.45vw, 0.84rem);
  font-weight: 800;
  line-height: 1.35;
  color: var(--cf-navy);
  word-wrap: break-word;
}

.reader-ospit-allest__cue--top {
  position: relative;
  max-width: 22rem;
  margin-inline: auto;
  margin-bottom: 0.5rem;
  padding-bottom: 0.52rem;
  text-align: center;
}

.reader-ospit-allest__cue--top::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  translate: -50% 0;
  width: 0;
  height: 0;
  border-left: 7px solid transparent;
  border-right: 7px solid transparent;
  border-top: 9px solid var(--cf-navy);
}

.reader-ospit-allest__row {
  display: grid;
  grid-template-columns: minmax(5.75rem, 8.75rem) minmax(0, 1fr) minmax(5.75rem, 8.75rem);
  gap: clamp(0.25rem, 1.75vw, 0.72rem);
  align-items: center;
  min-width: 0;
}

.reader-ospit-allest__cue-spacer {
  display: block;
  min-height: 1px;
}

.reader-ospit-allest__cue--left {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: center;
  gap: 0.35rem;
  text-align: right;
}

.reader-ospit-allest__cue--left::after {
  content: "";
  width: 0;
  height: 0;
  border-top: 6px solid transparent;
  border-bottom: 6px solid transparent;
  border-left: 10px solid var(--cf-navy);
}

.reader-ospit-allest__cue--right {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 0.35rem;
  padding-top: 0.35rem;
  text-align: left;
}

.reader-ospit-allest__cue--right::before {
  content: "";
  width: 0;
  height: 0;
  border-top: 6px solid transparent;
  border-bottom: 6px solid transparent;
  border-right: 10px solid var(--cf-navy);
  align-self: flex-start;
  margin-bottom: 0.08rem;
}

.reader-ospit-allest__fig {
  margin: 0;
  border-radius: 0.42rem;
  overflow: hidden;
  background: #e8eef5;
  border: 1px solid rgba(35, 60, 120, 0.22);
  min-width: 0;
}

.reader-ospit-allest__img {
  display: block;
  width: 100%;
  height: auto;
  max-height: min(54vh, 420px);
  object-fit: contain;
  object-position: center bottom;
}

.reader-ospit-allest__credit {
  margin: 0.62rem 0 0;
  font-size: 0.615rem;
  line-height: 1.38;
  color: rgba(55, 65, 81, 0.85);
}

.reader-ospit-allest__aside {
  align-self: stretch;
  padding: clamp(0.68rem, 2vw, 1rem);
  border-radius: 0.42rem;
  border: 1px solid rgba(35, 60, 120, 0.22);
  background: linear-gradient(180deg, #f9fbfd 0%, #eef3fa 100%);
  min-height: min-content;
}

.reader-ospit-allest__aside-h {
  margin: 0 0 0.62rem;
  font-size: clamp(0.86rem, 2vw, 1.06rem);
  font-weight: 800;
  line-height: 1.28;
  color: #2f62b0;
}

.reader-ospit-allest__aside-ul {
  margin: 0;
  padding-left: 1rem;
}

.reader-ospit-allest__aside-li {
  margin: 0 0 0.4rem;
  font-size: clamp(0.72rem, 1.55vw, 0.8525rem);
  font-weight: 600;
  line-height: 1.42;
  color: #374151;
}

.reader-ospit-allest__aside-li:last-child {
  margin-bottom: 0;
}

@media (max-width: 800px) {
  .reader-ospit-allest__grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 560px) {
  .reader-ospit-allest__row {
    grid-template-columns: 1fr;
    gap: 0.55rem;
  }

  .reader-ospit-allest__cue--left,
  .reader-ospit-allest__cue--right {
    align-items: center;
    text-align: center;
  }

  .reader-ospit-allest__cue--left::after,
  .reader-ospit-allest__cue--right::before {
    margin-inline: auto;
    align-self: center;
  }

  .reader-ospit-allest__cue--left::after {
    rotate: 90deg;
  }

  .reader-ospit-allest__cue--right::before {
    rotate: 90deg;
    order: 0;
    margin-bottom: 0;
  }
}

.reader-ospit-flusso {
  margin: -0.15rem -0.25rem 0;
  padding: clamp(0.35rem, 2vw, 0.65rem) 0 0;
  min-width: 0;
  max-width: 100%;
}

.reader-ospit-flusso__title {
  margin: 0 0 clamp(1rem, 3vw, 1.55rem);
  text-align: center;
  font-size: clamp(1.42rem, 4.35vw, 2.15rem);
  font-weight: 800;
  line-height: 1.22;
  color: var(--cf-navy);
  text-wrap: balance;
}

.reader-ospit-flusso__track {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: stretch;
  justify-content: space-between;
  gap: clamp(3px, 0.85vw, 8px);
  width: 100%;
  max-width: 100%;
  min-width: 0;
  overflow-x: visible;
  overflow-y: visible;
  padding: 0.15rem 0 0.5rem;
}

.reader-ospit-flusso__card {
  flex: 1 1 0;
  min-width: 0;
  max-width: none;
  margin: 0;
  padding: clamp(0.32rem, 1.35vw, 0.72rem);
  box-sizing: border-box;
  border-radius: 0.35rem;
  border: 1px solid rgba(35, 60, 120, 0.38);
  background: #fff;
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.04);
}

.reader-ospit-flusso__ico-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: clamp(2.35rem, 7.5vw, 3.2rem);
  margin: 0 0 0.35rem;
}

.reader-ospit-flusso__ico {
  display: block;
  width: auto;
  height: auto;
  max-width: min(4.5rem, 22vw, 96px);
  max-height: min(4.5rem, 22vw, 96px);
  object-fit: contain;
}

.reader-ospit-flusso__step-h {
  margin: 0 0 0.32rem;
  font-size: clamp(0.62rem, 1.45vw + 0.12rem, 0.9rem);
  font-weight: 800;
  line-height: 1.25;
  text-align: center;
  color: #2f62b0;
  word-wrap: break-word;
  overflow-wrap: break-word;
  hyphens: auto;
}

.reader-ospit-flusso__step-p {
  margin: 0;
  font-size: clamp(0.58rem, 1.15vw + 0.1rem, 0.785rem);
  font-weight: 600;
  line-height: 1.34;
  text-align: center;
  color: #3f4a58;
  word-wrap: break-word;
  overflow-wrap: break-word;
  hyphens: auto;
}

.reader-ospit-flusso__arrow {
  display: flex;
  flex-direction: row;
  align-items: center;
  flex: 0 0 auto;
  flex-shrink: 1;
  min-width: 0;
  align-self: center;
  padding: 0 1px;
}

.reader-ospit-flusso__shaft {
  display: block;
  width: clamp(6px, 1.5vw, 18px);
  height: 6px;
  background: var(--cf-navy);
  border-radius: 1px 0 0 1px;
}

.reader-ospit-flusso__point {
  display: block;
  width: 0;
  height: 0;
  margin-left: -1px;
  border-top: 7px solid transparent;
  border-bottom: 7px solid transparent;
  border-left: clamp(7px, 1.4vw, 11px) solid var(--cf-navy);
}

@media (min-width: 900px) {
  .reader-ospit-flusso__track {
    justify-content: center;
    gap: clamp(5px, 1vw, 12px);
    max-width: min(56rem, 100%);
    margin-inline: auto;
  }

  .reader-ospit-flusso__card {
    flex: 1 1 0;
    max-width: 12.5rem;
  }

  .reader-ospit-flusso__arrow {
    flex-shrink: 0;
    padding: 0 clamp(2px, 0.5vw, 6px);
  }
}

@media (max-width: 640px) {
  .reader-ospit-flusso__track {
    flex-direction: column;
    align-items: stretch;
    overflow-x: visible;
  }

  .reader-ospit-flusso__card {
    min-width: 0;
    max-width: none;
  }

  .reader-ospit-flusso__arrow {
    transform: rotate(90deg);
    align-self: center;
    padding: 0.35rem 0;
    margin: 0.08rem 0;
  }

  .reader-ospit-flusso__step-p {
    max-width: 36rem;
    margin-inline: auto;
  }
}

/* Ospitalità — Cabin Delivery (ligne jaune, hexagones, cartes alternées) */
.reader-main--ospitalita-cabin-delivery {
  background: #e8eaed;
  border-left-color: var(--cf-yellow);
}

.reader-ospit-cd {
  margin: -0.2rem -0.15rem 0;
  padding: clamp(0.45rem, 1.8vw, 0.85rem) clamp(0.35rem, 1.2vw, 0.65rem)
    clamp(0.65rem, 2vw, 1rem);
  min-width: 0;
}

.reader-ospit-cd__title {
  margin: 0 0 clamp(0.85rem, 2.5vw, 1.35rem);
  padding: clamp(0.35rem, 1.2vw, 0.55rem) clamp(0.55rem, 1.5vw, 0.85rem);
  max-width: min(42rem, 100%);
  border-radius: 0.4rem;
  border: 1px solid rgba(35, 60, 120, 0.22);
  background: #fff;
  font-size: clamp(1.05rem, 2.8vw, 1.45rem);
  font-weight: 800;
  line-height: 1.2;
  color: var(--cf-navy);
  text-wrap: balance;
}

.reader-ospit-cd__diagram {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-template-rows: auto auto auto;
  gap: clamp(0.35rem, 1.4vw, 0.65rem) clamp(0.35rem, 1.5vw, 0.85rem);
  align-items: start;
  padding: clamp(0.25rem, 1.5vw, 0.55rem) 0;
  min-width: min(100%, 52rem);
}

.reader-ospit-cd__pad {
  min-height: 0;
  pointer-events: none;
}

.reader-ospit-cd__pad--row1 {
  grid-row: 1;
}

.reader-ospit-cd__pad--row3 {
  grid-row: 3;
}

.reader-ospit-cd__card--row1 {
  grid-row: 1;
}

.reader-ospit-cd__card--row3 {
  grid-row: 3;
}

.reader-ospit-cd__track-row {
  position: relative;
  grid-column: 1 / -1;
  grid-row: 2;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: center;
  min-height: clamp(2.85rem, 9vw, 4rem);
  z-index: 1;
}

.reader-ospit-cd__rail {
  position: absolute;
  left: 3%;
  right: 3%;
  top: 50%;
  height: clamp(7px, 1.4vw, 10px);
  margin-top: calc(clamp(7px, 1.4vw, 10px) / -2);
  border-radius: 999px;
  background: #fbd304;
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.06);
  z-index: 0;
}

.reader-ospit-cd__icon-slot {
  position: relative;
  justify-self: center;
  z-index: 2;
}

.reader-ospit-cd__hex {
  width: clamp(2.65rem, 8vw, 3.85rem);
  height: clamp(2.65rem, 8vw, 3.85rem);
  margin: 0 auto;
  clip-path: polygon(25% 0%, 75% 0%, 100% 50%, 75% 100%, 25% 100%, 0% 50%);
  background: #1a2b5a;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.18);
}

.reader-ospit-cd__ico {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.reader-ospit-cd__card {
  width: 100%;
  margin: 0;
  padding: clamp(0.38rem, 1.2vw, 0.58rem) clamp(0.42rem, 1.25vw, 0.62rem);
  box-sizing: border-box;
  border-radius: 0.42rem;
  border: 1px solid rgba(35, 60, 120, 0.28);
  background: #fff;
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.04);
}

.reader-ospit-cd__card--hilite {
  border-width: 3px;
  border-color: #fbd304;
  box-shadow:
    0 0 0 1px rgba(251, 211, 4, 0.35),
    0 2px 10px rgba(26, 43, 90, 0.08);
}

.reader-ospit-cd__card-h {
  margin: 0 0 clamp(0.28rem, 1vw, 0.42rem);
  font-size: clamp(0.68rem, 1.35vw + 0.08rem, 0.88rem);
  font-weight: 800;
  line-height: 1.25;
  color: #1a2b5a;
  text-wrap: balance;
}

.reader-ospit-cd__card-p {
  margin: 0;
  font-size: clamp(0.58rem, 1.12vw + 0.08rem, 0.78rem);
  font-weight: 600;
  line-height: 1.38;
  color: #2f3540;
}

@media (max-width: 900px) {
  .reader-ospit-cd {
    overflow-x: auto;
    overflow-y: visible;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 0.4rem;
    margin-inline: -0.2rem;
    padding-inline: 0.25rem;
    scrollbar-gutter: stable;
  }

  .reader-ospit-cd__diagram {
    min-width: min(36rem, 155%);
  }
}

/* Ospitalità — anatomie setup Dom Pérignon (photo + callouts + bandeau) */
.reader-main--ospitalita-dom-perignon {
  background: #e4e6ea;
  border-left-color: var(--cf-yellow);
}

.reader-ospit-dp {
  margin: -0.15rem -0.2rem 0;
  padding: clamp(0.45rem, 1.6vw, 0.75rem) clamp(0.35rem, 1.2vw, 0.65rem)
    clamp(0.55rem, 1.8vw, 0.85rem);
  border: 2px solid rgba(26, 43, 90, 0.55);
  border-radius: 0.48rem;
  background: #e8eaed;
  box-sizing: border-box;
  min-width: 0;
}

.reader-ospit-dp__title {
  margin: 0 0 clamp(0.65rem, 2vw, 1rem);
  font-size: clamp(0.92rem, 2.35vw, 1.22rem);
  font-weight: 800;
  line-height: 1.25;
  color: var(--cf-navy);
  text-wrap: balance;
}

.reader-ospit-dp__stage {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 2.8fr) minmax(0, 1fr);
  grid-template-rows: auto 1fr auto;
  grid-template-areas:
    ". photo tr"
    "ml photo mr"
    ". photo br";
  gap: clamp(0.4rem, 1.5vw, 0.75rem) clamp(0.45rem, 1.8vw, 0.85rem);
  align-items: center;
  width: 100%;
  max-width: 100%;
  min-width: 0;
}

.reader-ospit-dp__photo {
  grid-area: photo;
  margin: 0;
  align-self: stretch;
  min-width: 0;
}

.reader-ospit-dp__photo-img {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
  border-radius: 0.38rem;
  border: 1px solid rgba(35, 60, 120, 0.35);
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
}

.reader-ospit-dp__callout {
  margin: 0;
  min-width: 0;
}

.reader-ospit-dp__callout--tr {
  grid-area: tr;
  align-self: start;
}

.reader-ospit-dp__callout--ml {
  grid-area: ml;
  align-self: center;
}

.reader-ospit-dp__callout--mr {
  grid-area: mr;
  align-self: center;
}

.reader-ospit-dp__callout--br {
  grid-area: br;
  align-self: end;
}

.reader-ospit-dp__callout-inner {
  display: flex;
  gap: clamp(0.28rem, 1vw, 0.45rem);
  align-items: flex-start;
  padding: clamp(0.32rem, 1.1vw, 0.48rem) clamp(0.38rem, 1.15vw, 0.52rem);
  border-radius: 0.4rem;
  border: 1px solid rgba(35, 60, 120, 0.42);
  background: #fff;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
  min-width: 0;
}

.reader-ospit-dp__callout-ico {
  flex: 0 0 auto;
  width: clamp(1.85rem, 5vw, 2.35rem);
  max-width: 100%;
  height: auto;
  max-height: 2.45rem;
  object-fit: contain;
}

.reader-ospit-dp__callout-txt {
  margin: 0;
  font-size: clamp(0.58rem, 1.12vw + 0.06rem, 0.76rem);
  font-weight: 600;
  line-height: 1.38;
  color: #2a3140;
  min-width: 0;
  overflow-wrap: anywhere;
}

.reader-ospit-dp__callout-lead {
  font-weight: 800;
  color: var(--cf-navy);
}

.reader-ospit-dp__warn {
  display: flex;
  align-items: center;
  gap: clamp(0.45rem, 1.5vw, 0.65rem);
  margin-top: clamp(0.65rem, 2vw, 1rem);
  padding: clamp(0.42rem, 1.35vw, 0.62rem) clamp(0.48rem, 1.5vw, 0.72rem);
  border-radius: 0.42rem;
  border: 2px solid #1a1a1a;
  background: var(--cf-yellow);
}

.reader-ospit-dp__warn-badge {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.65rem;
  height: 1.45rem;
  clip-path: polygon(50% 0%, 100% 100%, 0% 100%);
  background: #f2c200;
  box-shadow: inset 0 -2px 0 rgba(0, 0, 0, 0.15);
  font-size: 1rem;
  font-weight: 900;
  line-height: 1;
  color: #1a1a1a;
}

.reader-ospit-dp__warn-txt {
  margin: 0;
  flex: 1 1 auto;
  font-size: clamp(0.62rem, 1.18vw + 0.08rem, 0.82rem);
  font-weight: 700;
  line-height: 1.38;
  color: #1a1a1a;
}

@media (max-width: 820px) {
  .reader-ospit-dp__stage {
    grid-template-columns: 1fr;
    grid-template-rows: none;
    grid-template-areas:
      "photo"
      "tr"
      "mr"
      "ml"
      "br";
  }

  .reader-ospit-dp__callout--tr,
  .reader-ospit-dp__callout--ml,
  .reader-ospit-dp__callout--mr,
  .reader-ospit-dp__callout--br {
    align-self: stretch;
  }
}

.reader-ospit-puli {
  position: relative;
  isolation: isolate;
  margin: -0.35rem -0.25rem 0;
  padding: clamp(1rem, 3.2vw, 1.45rem) clamp(0.55rem, 2vw, 1rem);
  border-radius: 0.55rem;
  overflow: hidden;
}

.reader-ospit-puli__sheet {
  position: absolute;
  inset: 0;
  z-index: 0;
  border-radius: inherit;
  background: linear-gradient(
    128deg,
    #ffffff 0%,
    #ffffff 42%,
    #fff9e6 46%,
    var(--cf-yellow) 52%,
    #f0cd00 100%
  );
  pointer-events: none;
}

.reader-ospit-puli__title {
  position: relative;
  z-index: 1;
  margin: 0 0 1.25rem;
  text-align: center;
  font-size: clamp(1.58rem, 5.2vw, 2.45rem);
  font-weight: 800;
  line-height: 1.18;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--cf-navy);
  text-wrap: balance;
}

.reader-ospit-puli__grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: clamp(0.72rem, 3vw, 1.35rem);
  align-items: stretch;
  max-width: min(30rem, 100%);
  margin-inline: auto;
}

.reader-ospit-puli__visual {
  min-width: 0;
  min-height: clamp(9rem, 23vw, 10.75rem);
  max-height: clamp(9.4rem, 26vw, 11.35rem);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.reader-ospit-puli__fig {
  margin: 0;
  text-align: center;
}

.reader-ospit-puli__img {
  display: block;
  width: 100%;
  max-width: min(158px, 82%);
  max-height: min(118px, 18vh);
  height: auto;
  margin: 0 auto;
  object-fit: contain;
  vertical-align: top;
}

.reader-ospit-puli__tag {
  margin: 0.32rem 0 0;
  text-align: center;
  font-weight: 800;
  font-size: clamp(0.82rem, 2.35vw, 1.02rem);
  line-height: 1.3;
  color: var(--cf-navy);
}

.reader-ospit-puli__aside {
  align-self: stretch;
  margin: 0;
  padding: clamp(0.52rem, 2vw, 0.82rem);
  border-radius: 0.42rem;
  border: 2px solid var(--cf-yellow);
  background: linear-gradient(180deg, #123a6d 0%, #0c284d 55%, #061a38 100%);
  box-shadow: 0 12px 36px rgba(0, 10, 32, 0.28);
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: clamp(9rem, 23vw, 10.75rem);
  max-height: clamp(9.4rem, 26vw, 11.35rem);
  box-sizing: border-box;
}

.reader-ospit-puli__ul {
  margin: 0;
  padding: 0;
  list-style: none;
  width: 100%;
}

.reader-ospit-puli__li {
  position: relative;
  margin: 0 0 0.32rem;
  padding-left: 1.32rem;
  color: rgba(255, 255, 255, 0.96);
  font-size: clamp(0.68rem, 1.82vw, 0.795rem);
  font-weight: 600;
  line-height: 1.36;
  text-align: left;
}

.reader-ospit-puli__li:last-child {
  margin-bottom: 0;
}

.reader-ospit-puli__li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.48em;
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 50%;
  background: var(--cf-yellow);
  box-shadow: 0 0 0 2px rgba(19, 43, 73, 0.85);
}

@media (max-width: 720px) {
  .reader-ospit-puli__grid {
    grid-template-columns: 1fr;
  }

  .reader-ospit-cort__cols {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 820px) {
  .reader-ospit-cab__cards {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .reader-ospit-acc__main {
    grid-template-columns: 1fr;
  }

  .reader-ospit-acc__fig-col {
    max-width: min(340px, 100%);
    margin-inline: auto;
  }

  .reader-ospit-acc__fig-row {
    gap: 0.35rem;
  }

  .reader-ospit-acc__fig:not(.reader-ospit-acc__fig--duo) {
    max-width: 300px;
    margin-inline: auto;
  }

  .reader-ospit-cv {
    margin: 0 -0.5rem;
    min-height: min(68vh, 520px);
  }
}

/* Accueil — slide partagée (figurine + liste + bande navy) */
.reader-main--ospitalita-divisa {
  background: #fff;
  border-left-color: var(--cf-yellow);
}

.reader-ospit-uni {
  margin-top: -0.15rem;
  color: var(--cf-navy);
}

.reader-ospit-uni__title {
  margin: 0 0 1rem;
  font-size: clamp(1.15rem, 3.5vw, 1.62rem);
  font-weight: 800;
  line-height: 1.25;
  color: var(--cf-navy);
}

.reader-ospit-uni__main {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.12fr);
  gap: clamp(0.75rem, 3vw, 1.75rem);
  align-items: start;
  margin-bottom: 1.15rem;
}

.reader-ospit-uni__fig {
  margin: 0;
  padding: 0;
  border-radius: 0.5rem;
  background: linear-gradient(180deg, #f7f9fc 0%, #eef2f9 100%);
  text-align: center;
  overflow: hidden;
  box-shadow: 0 6px 22px rgba(19, 43, 73, 0.1);
}

.reader-ospit-uni__img {
  display: block;
  width: 100%;
  max-width: min(268px, 100%);
  height: auto;
  margin: 0 auto;
  object-fit: contain;
  vertical-align: top;
}

.reader-ospit-uni__list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.reader-ospit-uni__item {
  position: relative;
  margin: 0 0 0.55rem;
  padding-left: 1.05rem;
  font-size: clamp(0.78rem, 2.05vw, 0.88rem);
  font-weight: 600;
  line-height: 1.42;
  color: var(--cf-navy);
}

.reader-ospit-uni__item::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.45em;
  width: 0.35rem;
  height: 0.35rem;
  border-radius: 50%;
  background: var(--cf-yellow);
  box-shadow: 0 0 0 2px var(--cf-navy);
}

.reader-ospit-uni__item:last-child {
  margin-bottom: 0;
}

.reader-ospit-uni__band {
  margin: 0;
  padding: 0.85rem 1rem 0.92rem;
  border-radius: 0.4rem;
  background: linear-gradient(180deg, #0e2d5a 0%, #061a38 55%, #031028 100%);
  color: #fff;
  font-size: clamp(0.74rem, 1.98vw, 0.8525rem);
  font-weight: 600;
  line-height: 1.48;
  box-shadow: 0 10px 28px rgba(0, 12, 38, 0.22);
}

@media (max-width: 720px) {
  .reader-ospit-uni__main {
    grid-template-columns: 1fr;
  }

  .reader-ospit-uni__fig {
    max-width: min(240px, 58vw);
    margin-inline: auto;
  }

  .reader-ospit-uni__img {
    max-width: min(220px, 100%);
  }
}

@media (max-width: 480px) {
  .reader-ospit-uni__fig {
    max-width: min(200px, 52vw);
  }

  .reader-ospit-uni__img {
    max-width: min(190px, 100%);
  }
}

/* Marins — image pro / PDP (slide navy + mascotte + encadré) */
.reader-main--marinai-immagine {
  --marinai-im-blue: #132b49;
  background: var(--marinai-im-blue);
  border-color: rgba(255, 255, 255, 0.12);
  border-left-color: var(--cf-yellow);
  color: #fff;
}

.reader-main--marinai-immagine .reader-progress {
  color: rgba(255, 255, 255, 0.88);
}

.reader-marinai-im {
  margin-top: -0.25rem;
  padding-bottom: 0.5rem;
}

.reader-marinai-im__head {
  margin-bottom: 1rem;
}

.reader-marinai-im__tape-wrap {
  display: inline-block;
  margin-bottom: 0.85rem;
  filter: drop-shadow(0 4px 14px rgba(0, 0, 0, 0.28));
}

.reader-marinai-im__tape {
  margin: 0;
  padding: 0.5rem 1.15rem 0.52rem;
  background: linear-gradient(
    -2deg,
    var(--cf-yellow) 0%,
    #ffe433 52%,
    #ffed00 100%
  );
  color: var(--marinai-im-blue);
  font-size: clamp(0.88rem, 2.55vw, 1.125rem);
  font-weight: 800;
  line-height: 1.35;
  transform: rotate(-1.05deg);
  clip-path: polygon(
    0 6px,
    3% 0,
    10% 4px,
    18% 0,
    28% 5px,
    40% 0,
    52% 4px,
    64% 0,
    76% 5px,
    88% 0,
    96% 4px,
    100% 8px,
    100% calc(100% - 6px),
    96% 100%,
    82% calc(100% - 5px),
    68% 100%,
    54% calc(100% - 4px),
    40% 100%,
    26% calc(100% - 5px),
    12% 100%,
    0 calc(100% - 8px),
    0 6px
  );
}

.reader-marinai-im__lead {
  margin: 0 0 0.4rem;
  font-size: clamp(0.82rem, 2.1vw, 0.95rem);
  font-weight: 500;
  color: rgba(255, 255, 255, 0.95);
  line-height: 1.45;
}

.reader-marinai-im__stage {
  position: relative;
  max-width: 34rem;
  margin: 0.5rem auto 0;
  min-height: clamp(260px, 48vw, 400px);
  padding: 0 0.35rem;
}

.reader-marinai-im__mascotte {
  display: block;
  margin: 0 auto;
  width: auto;
  max-width: min(220px, 58vw);
  height: auto;
}

.reader-marinai-im__callout {
  position: absolute;
  z-index: 2;
  box-sizing: border-box;
  max-width: min(11.75rem, 38vw);
  padding: 0.5rem 0.62rem;
  border: 2px solid var(--cf-yellow);
  background: rgba(19, 43, 73, 0.96);
  border-radius: 2px;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.25);
}

.reader-marinai-im__callout-arr {
  position: absolute;
  width: 0;
  height: 0;
  border: solid transparent;
}

.reader-marinai-im__callout--ml .reader-marinai-im__callout-arr {
  right: -10px;
  top: 50%;
  transform: translateY(-50%);
  border-width: 7px 0 7px 10px;
  border-left-color: var(--cf-yellow);
}

.reader-marinai-im__callout--tr .reader-marinai-im__callout-arr,
.reader-marinai-im__callout--br .reader-marinai-im__callout-arr {
  left: -10px;
  top: 50%;
  transform: translateY(-50%);
  border-width: 7px 10px 7px 0;
  border-right-color: var(--cf-yellow);
}

.reader-marinai-im__callout--ml {
  left: 0;
  top: 36%;
}

.reader-marinai-im__callout--tr {
  right: 0;
  top: 8%;
}

.reader-marinai-im__callout--br {
  right: 0;
  bottom: 6%;
  top: auto;
}

.reader-marinai-im__callout-txt {
  margin: 0;
  font-size: clamp(0.68rem, 1.95vw, 0.8125rem);
  font-weight: 700;
  line-height: 1.38;
  color: #fff;
}

@media (max-width: 640px) {
  .reader-marinai-im__stage {
    min-height: 0;
    padding-bottom: 0.25rem;
  }

  .reader-marinai-im__callout {
    position: relative;
    left: auto;
    right: auto;
    top: auto;
    bottom: auto;
    max-width: 100%;
    margin-top: 0.65rem;
  }

  .reader-marinai-im__callout .reader-marinai-im__callout-arr {
    display: none;
  }
}

/* Marins — trois phases garage : grande flèche de fond + trois chevrons au-dessus → droite */
.reader-main--marinai-phases {
  border-left-color: var(--cf-yellow);
}

.reader-marinai-phases {
  --ph-tip: clamp(13px, 4.2vw, 26px);
  --ph-notch: clamp(12px, 3.8vw, 21px);
  margin-top: -0.35rem;
}

.reader-marinai-phases__band {
  margin: 0 -0.25rem 1.35rem;
  padding: 0.88rem 1rem 0.92rem;
  text-align: center;
  border-radius: 0.35rem;
  box-shadow: 0 2px 14px rgba(19, 43, 73, 0.1);
}

.reader-marinai-phases__band--tape {
  background: linear-gradient(180deg, #fff34d 0%, var(--cf-yellow) 45%, #ffe208 100%);
  border: 2px dashed rgba(19, 43, 73, 0.12);
}

.reader-marinai-phases__title {
  margin: 0;
  color: var(--cf-navy);
  font-size: clamp(1rem, 3vw, 1.28rem);
  font-weight: 800;
  line-height: 1.35;
}

.reader-marinai-phases__flow {
  display: grid;
  grid-template-columns: 1fr;
  justify-items: stretch;
  margin: 0.35rem -0.35rem 0.25rem;
}

.reader-marinai-phases__mega {
  pointer-events: none;
  grid-row: 1;
  grid-column: 1;
  align-self: center;
  justify-self: stretch;
  z-index: 0;
  margin: 0 clamp(6px, 1.5vw, 14px);
  height: clamp(5.15rem, 11.5vw, 6.45rem);
  background: linear-gradient(180deg, #fff4a3 0%, #f6d90a 48%, #e8c800 100%);
  border: 2px solid rgba(255, 255, 255, 0.65);
  box-shadow:
    inset 0 2px 0 rgba(255, 255, 255, 0.45),
    0 4px 18px rgba(19, 43, 73, 0.11);
  opacity: 0.52;
  --mega-tip: clamp(40px, 10vw, 58px);
  --mega-tail: clamp(16px, 3.5vw, 24px);
  clip-path: polygon(
    var(--mega-tail) 0,
    calc(100% - var(--mega-tip)) 0,
    100% 50%,
    calc(100% - var(--mega-tip)) 100%,
    var(--mega-tail) 100%,
    0 50%
  );
}

.reader-marinai-phases__track {
  position: relative;
  z-index: 1;
  grid-row: 1;
  grid-column: 1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
  align-items: start;
}

.reader-marinai-phases__cell {
  text-align: center;
}

.reader-marinai-phases__stage {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 5.85rem;
  margin-bottom: 0.75rem;
}

.reader-marinai-phases__ribbon {
  position: absolute;
  inset: auto 0 auto 0;
  top: 50%;
  height: 3.4rem;
  transform: translateY(-50%);
  background: linear-gradient(180deg, #fff34d 0%, var(--cf-yellow) 50%, #f2d800 100%);
  border: 2px solid rgba(255, 255, 255, 0.95);
  box-shadow:
    inset 0 2px 0 rgba(255, 255, 255, 0.35),
    0 2px 14px rgba(19, 43, 73, 0.16);
}

/* Flèche vers la droite ; queue plate à gauche sur le premier segment */
.reader-marinai-phases__stage--1 .reader-marinai-phases__ribbon {
  left: -2px;
  right: clamp(-8px, -1vw, -3px);
  clip-path: polygon(
    0 0,
    calc(100% - var(--ph-tip)) 0,
    100% 50%,
    calc(100% - var(--ph-tip)) 100%,
    0 100%
  );
}

/* Encoche à gauche (accueille la pointe précédente) + pointe vers segment suivant / fin → droite */
.reader-marinai-phases__stage--2 .reader-marinai-phases__ribbon {
  left: clamp(-14px, -2.5vw, -6px);
  right: clamp(-14px, -2.5vw, -6px);
  clip-path: polygon(
    var(--ph-notch) 0,
    calc(100% - var(--ph-tip)) 0,
    100% 50%,
    calc(100% - var(--ph-tip)) 100%,
    var(--ph-notch) 100%,
    0 50%
  );
}

.reader-marinai-phases__stage--3 .reader-marinai-phases__ribbon {
  left: clamp(-12px, -2.2vw, -5px);
  right: -2px;
  clip-path: polygon(
    var(--ph-notch) 0,
    calc(100% - var(--ph-tip)) 0,
    100% 50%,
    calc(100% - var(--ph-tip)) 100%,
    var(--ph-notch) 100%,
    0 50%
  );
}

.reader-marinai-phases__icon {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  width: clamp(5rem, 18vw, 6.85rem);
  height: clamp(5rem, 18vw, 6.85rem);
}

.reader-marinai-phases__icon img {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.12));
}

.reader-marinai-phases__h {
  margin: 0 0 0.35rem;
  font-size: clamp(0.78rem, 2vw, 0.95rem);
  font-weight: 800;
  color: var(--cf-navy);
  line-height: 1.35;
}

.reader-marinai-phases__sub {
  margin: 0;
  font-size: clamp(0.7rem, 1.85vw, 0.835rem);
  font-weight: 600;
  color: var(--cf-navy);
  line-height: 1.38;
}

@media (max-width: 520px) {
  .reader-marinai-phases__mega {
    display: none;
  }

  .reader-marinai-phases__flow {
    display: block;
    margin-left: 0;
    margin-right: 0;
  }

  .reader-marinai-phases__track {
    display: block;
  }

  .reader-marinai-phases__stage .reader-marinai-phases__ribbon {
    position: relative;
    inset: auto;
    top: auto;
    left: auto;
    right: auto;
    transform: none;
    height: auto;
    min-height: 3rem;
    margin: 0 0 0.6rem;
    clip-path: none;
    border-radius: 8px;
  }
}

/* Marins — checklist (bandes jaunes + carrés jaunes / coches navy) */
.reader-main--marinai-checklist {
  background: #fff;
  border-left-color: var(--cf-yellow);
}

.reader-marinai-cl {
  margin-top: -0.25rem;
  color: var(--cf-navy);
}

.reader-marinai-cl__band {
  margin: 0 -0.25rem 1.35rem;
  padding: 0.82rem 1rem 0.88rem;
  text-align: center;
  border-radius: 0.35rem;
  box-shadow: 0 2px 14px rgba(19, 43, 73, 0.08);
}

.reader-marinai-cl__band--tape {
  background: linear-gradient(180deg, #fff34d 0%, var(--cf-yellow) 45%, #ffe208 100%);
  border: 2px dashed rgba(19, 43, 73, 0.12);
}

.reader-marinai-cl__title {
  margin: 0 auto;
  max-width: 26rem;
  color: var(--cf-navy);
  font-size: clamp(1.02rem, 3vw, 1.3rem);
  font-weight: 800;
  line-height: 1.38;
}

.reader-marinai-cl__intro {
  margin: 0 0 1rem;
  color: var(--cf-navy);
  font-weight: 500;
  font-size: 0.9375rem;
  line-height: 1.5;
}

.reader-marinai-cl__list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.reader-marinai-cl__row {
  display: grid;
  grid-template-columns: 3rem minmax(0, 1fr);
  gap: 1rem 1rem;
  align-items: flex-start;
  margin-bottom: 1.08rem;
}

.reader-marinai-cl__row:last-child {
  margin-bottom: 0;
}

.reader-marinai-cl__chk {
  display: grid;
  place-items: center;
  width: 3rem;
  height: 3rem;
  box-sizing: border-box;
  border: 4px solid var(--cf-yellow);
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 2px 14px rgba(19, 43, 73, 0.08);
}

.reader-marinai-cl__chk-mark {
  display: block;
  width: 0.45rem;
  height: 0.85rem;
  margin-top: -3px;
  margin-left: 2px;
  border: solid var(--cf-navy);
  border-width: 0 3.5px 3.5px 0;
  transform: rotate(45deg);
}

.reader-marinai-cl__txt {
  display: block;
  padding-top: 0.22rem;
  font-size: clamp(0.82rem, 2.1vw, 0.95rem);
  font-weight: 600;
  line-height: 1.45;
  color: var(--cf-navy);
}

.reader-marinai-cl__note {
  margin-top: 1.25rem;
}

@media (max-width: 480px) {
  .reader-marinai-cl__row {
    grid-template-columns: 2.65rem minmax(0, 1fr);
    gap: 0.75rem 0.85rem;
  }

  .reader-marinai-cl__chk {
    width: 2.65rem;
    height: 2.65rem;
    border-width: 3px;
    border-radius: 8px;
  }
}

/* Marins — phase 2 règles d’or (bandeau navy + ruban jaune + grille 2×2) */
.reader-main--marinai-manovra {
  background: #fff;
  border-left-color: var(--cf-yellow);
}

.reader-marinai-mv {
  --mv-navy-deep: #002147;
  margin-top: -0.3rem;
}

.reader-marinai-mv__banner {
  position: relative;
  margin: 0 -0.2rem 1.65rem;
  padding: 0.92rem clamp(2.25rem, 7vw, 3.85rem);
  background: linear-gradient(180deg, #003068 0%, var(--mv-navy-deep) 42%, #001632 100%);
  border-radius: 7px;
  box-shadow:
    0 10px 32px rgba(0, 10, 40, 0.38),
    inset 0 1px 0 rgba(255, 255, 255, 0.07);
}

.reader-marinai-mv__ribbon {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: clamp(17px, 4vw, 24px);
  height: min(74%, 3.95rem);
  background: linear-gradient(
    90deg,
    #fff7a0 0%,
    var(--cf-yellow) 35%,
    #e6cf00 100%
  );
  box-shadow:
    inset 2px 0 0 rgba(255, 255, 255, 0.45),
    inset -1px 0 0 rgba(0, 0, 0, 0.12),
    2px 4px 10px rgba(0, 0, 0, 0.2);
}

.reader-marinai-mv__ribbon--l {
  left: -4px;
  clip-path: polygon(0 18%, 100% 0, 100% 100%, 0 82%);
}

.reader-marinai-mv__ribbon--r {
  right: -4px;
  clip-path: polygon(0 0, 100% 18%, 100% 82%, 0 100%);
}

.reader-marinai-mv__banner-inner {
  position: relative;
  z-index: 1;
  text-align: center;
}

.reader-marinai-mv__title {
  margin: 0 auto;
  max-width: 36rem;
  font-size: clamp(0.88rem, 2.85vw, 1.28rem);
  font-weight: 800;
  line-height: 1.42;
}

.reader-marinai-mv__title-k {
  margin-right: 0.38em;
  color: var(--cf-yellow);
}

.reader-marinai-mv__title-rest {
  color: #fff;
}

.reader-marinai-mv__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem 1rem;
  align-items: stretch;
}

.reader-marinai-mv-card {
  display: flex;
  flex-direction: row;
  align-items: stretch;
  min-height: 7.15rem;
  border-radius: 10px;
  overflow: hidden;
  background: var(--mv-navy-deep);
  box-shadow: 0 10px 28px rgba(0, 16, 45, 0.32);
}

.reader-marinai-mv-card__media {
  flex: 0 0 clamp(5.5rem, 30%, 7.15rem);
  display: grid;
  place-items: center;
  padding: 0.5rem 0.35rem;
  background: linear-gradient(180deg, #001c3d 0%, #00152e 100%);
  border-right: 1px solid rgba(255, 255, 255, 0.08);
}

.reader-marinai-mv-card__img {
  width: 100%;
  max-width: 5.35rem;
  height: auto;
  max-height: 5.25rem;
  object-fit: contain;
}

.reader-marinai-mv-card__img--svg {
  max-width: 5.1rem;
  max-height: 5rem;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.25));
}

.reader-marinai-mv-card__body {
  flex: 1;
  min-width: 0;
  padding: 0.85rem 0.95rem 0.95rem 0.85rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.reader-marinai-mv-card__h {
  margin: 0 0 0.48rem;
  font-size: clamp(0.68rem, 1.75vw, 0.8rem);
  font-weight: 800;
  letter-spacing: 0.04em;
  line-height: 1.25;
  color: #fff;
}

.reader-marinai-mv-card__p {
  margin: 0;
  font-size: clamp(0.78rem, 2vw, 0.9rem);
  font-weight: 500;
  line-height: 1.45;
  color: rgba(255, 255, 255, 0.96);
}

@media (max-width: 720px) {
  .reader-marinai-mv__grid {
    grid-template-columns: 1fr;
  }

  .reader-marinai-mv-card {
    min-height: 0;
  }
}

@media (max-width: 420px) {
  .reader-marinai-mv-card {
    flex-direction: column;
  }

  .reader-marinai-mv-card__media {
    flex: 0 0 auto;
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    padding: 0.65rem;
  }
}

/* Marins — langue des signaux : trois gestes (images collées sur la slide) */
.reader-main--marinai-segnali-trio {
  background: #fff;
  border-left-color: var(--cf-yellow);
}

.reader-marinai-st {
  margin-top: -0.15rem;
}

.reader-marinai-st__head {
  margin-bottom: 1.85rem;
  text-align: center;
}

.reader-marinai-st__tape-wrap {
  display: inline-flex;
  justify-content: center;
  max-width: 100%;
  margin: 0 auto;
  filter: drop-shadow(0 5px 16px rgba(0, 0, 0, 0.2));
}

.reader-marinai-st__tape {
  display: inline-block;
  margin: 0;
  padding: 0.52rem 1.38rem 0.54rem;
  background: linear-gradient(
    -2deg,
    var(--cf-yellow) 0%,
    #ffe433 52%,
    #ffed00 100%
  );
  transform: rotate(-0.85deg);
  color: var(--cf-navy);
  font-size: clamp(0.88rem, 2.85vw, 1.22rem);
  font-weight: 700;
  line-height: 1.38;
  clip-path: polygon(
    0 6px,
    4% 0,
    12% 4px,
    22% 0,
    34% 4px,
    48% 0,
    60% 5px,
    72% 0,
    84% 4px,
    94% 0,
    100% 6px,
    100% calc(100% - 6px),
    94% 100%,
    80% calc(100% - 5px),
    66% 100%,
    52% calc(100% - 4px),
    38% 100%,
    24% calc(100% - 5px),
    10% 100%,
    0 calc(100% - 8px),
    0 6px
  );
}

.reader-marinai-st__tape-em {
  margin-left: 0.38em;
  font-weight: 900;
}

.reader-marinai-st__head--navy-strip {
  margin-bottom: 1.85rem;
  text-align: center;
}

.reader-marinai-st__head--navy-strip .reader-marinai-st__navy-plate {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 -0.2rem 0;
  padding: 1.06rem 0.95rem;
  background: linear-gradient(180deg, #073b72 0%, #002147 48%, #001020 100%);
  border-radius: 8px;
  box-shadow: 0 12px 32px rgba(0, 10, 42, 0.38);
}

.reader-marinai-st__tape.reader-marinai-st__tape--darkcopy,
.reader-marinai-st__tape.reader-marinai-st__tape--darkcopy .reader-marinai-st__tape-plain,
.reader-marinai-st__tape.reader-marinai-st__tape--darkcopy .reader-marinai-st__tape-em {
  color: #101828;
}

.reader-marinai-st__primary {
  margin: 0 0 0.38rem;
  font-size: clamp(0.86rem, 2.2vw, 1.03rem);
  font-weight: 700;
  line-height: 1.42;
  color: var(--cf-navy);
}

.reader-marinai-st__primary strong {
  font-weight: 800;
}

.reader-marinai-st__slash {
  font-weight: 600;
  color: var(--cf-navy);
  opacity: 0.88;
}

.reader-marinai-st__stop {
  color: #d4001a;
  font-weight: 900;
}

/* Slide « bloc véhicule » — barre bleue, languette jaune en haut, titre blanc */
.reader-marinai-st__head--white-navy {
  margin-bottom: 1.85rem;
  text-align: center;
}

.reader-marinai-st__white-navy-plate {
  position: relative;
  margin: 0 -0.15rem 0;
  padding: 1.38rem 1rem 1.18rem;
  background: linear-gradient(180deg, #05376b 0%, #002147 52%, #001224 100%);
  border-radius: 6px;
  box-shadow: 0 10px 30px rgba(0, 12, 38, 0.36);
}

.reader-marinai-st__white-navy-tab {
  position: absolute;
  left: 50%;
  top: 0;
  transform: translate(-50%, -40%);
  width: clamp(4.5rem, 24vw, 7.75rem);
  height: 0.78rem;
  background: linear-gradient(180deg, #fff89a 0%, var(--cf-yellow) 50%, #e6cd00 100%);
  border-radius: 2px;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.25);
  clip-path: polygon(3% 0, 97% 0, 100% 100%, 0 100%);
}

.reader-marinai-st__white-navy-title {
  margin: 0;
  font-size: clamp(0.88rem, 2.75vw, 1.2rem);
  font-weight: 700;
  line-height: 1.38;
  color: #fff;
}

.reader-marinai-st__white-navy-title-pre {
  font-weight: 700;
}

.reader-marinai-st__white-navy-title-em {
  margin-left: 0.3em;
  font-weight: 900;
}

.reader-marinai-st--blocco .reader-marinai-st__cols {
  gap: 0;
  margin-top: 0.15rem;
  border: 1px solid #111;
  border-radius: 4px;
  overflow: hidden;
}

.reader-marinai-st--blocco .reader-marinai-st__col {
  padding: 1.05rem 0.72rem 1.2rem;
}

.reader-marinai-st--blocco .reader-marinai-st__col + .reader-marinai-st__col {
  border-left: 1px solid #111;
}

.reader-marinai-st__cols {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1rem, 3.8vw, 2rem);
  align-items: start;
}

.reader-marinai-st__col {
  margin: 0;
  text-align: center;
}

.reader-marinai-st__fig-wrap {
  margin: 0 auto 1rem;
  max-width: min(240px, 86vw);
  line-height: 0;
}

.reader-marinai-st__fig {
  display: block;
  width: 100%;
  height: auto;
  max-height: min(320px, 48vh);
  object-fit: contain;
  object-position: center bottom;
}

.reader-marinai-st__cap {
  margin: 0;
}

.reader-marinai-st__fr {
  margin: 0 0 0.42rem;
  font-size: clamp(0.8rem, 2vw, 0.92rem);
  font-weight: 600;
  line-height: 1.42;
  color: var(--cf-navy);
}

.reader-marinai-st__it {
  margin: 0;
  font-size: clamp(0.88rem, 2.15vw, 1.035rem);
  font-weight: 700;
  line-height: 1.38;
  color: var(--cf-navy);
}

.reader-marinai-st__hint {
  margin: 0.45rem 0 0;
  font-size: clamp(0.73rem, 1.82vw, 0.8625rem);
  font-weight: 500;
  font-style: italic;
  color: var(--cf-navy);
}

@media (max-width: 780px) {
  .reader-marinai-st__cols {
    grid-template-columns: 1fr;
    gap: 1.75rem;
  }

  .reader-marinai-st--blocco .reader-marinai-st__cols {
    gap: 0;
  }

  .reader-marinai-st--blocco .reader-marinai-st__col + .reader-marinai-st__col {
    border-left: none;
    border-top: 1px solid #111;
  }

  .reader-marinai-st__fig-wrap {
    max-width: min(280px, 72vw);
  }
}

/* Marins — stationnement sûr : bandeau + encadré PMR + chevrons horizontaux */
.reader-main--marinai-stazionamento {
  background: var(--cf-white);
  border-left-color: var(--cf-yellow);
}

.reader-marinai-sz {
  margin-top: -0.2rem;
}

.reader-marinai-sz .reader-marinai-st__head--white-navy {
  margin-bottom: 1.25rem;
}

.reader-marinai-sz__toprow {
  display: flex;
  justify-content: flex-start;
  margin: 0 0 1.35rem;
}

.reader-marinai-sz__pmr {
  --sz-pmr-pad-y: 0.38rem;
  --sz-pmr-pad-x: 0.85rem;
  margin: 0;
  max-width: min(100%, 22rem);
  padding: var(--sz-pmr-pad-y) var(--sz-pmr-pad-x);
  background: linear-gradient(180deg, #fffef0 0%, var(--cf-yellow) 48%, #e6d500 100%);
  color: var(--cf-navy);
  font-size: clamp(0.78rem, 2vw, 0.9rem);
  font-weight: 800;
  line-height: 1.35;
  clip-path: polygon(
    0 4px,
    5% 0,
    12% 3px,
    22% 0,
    34% 4px,
    48% 0,
    62% 3px,
    76% 0,
    88% 4px,
    100% 2px,
    100% calc(100% - 3px),
    92% 100%,
    78% calc(100% - 3px),
    64% 100%,
    50% calc(100% - 4px),
    36% 100%,
    22% calc(100% - 3px),
    8% 100%,
    0 calc(100% - 4px)
  );
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.12);
}

.reader-marinai-sz__flow {
  --sz-chev-notch: clamp(18px, 3.2vw, 26px);
  display: flex;
  flex-wrap: nowrap;
  align-items: stretch;
  gap: 0;
  margin: 0 -0.35rem;
  padding: 0 0 0.25rem;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
}

.reader-marinai-sz__chev {
  position: relative;
  flex: 1 1 0;
  min-width: min(11.5rem, 78vw);
  margin: 0;
  padding: 0.98rem 0.72rem 0.98rem calc(var(--sz-chev-notch) + 0.55rem);
  scroll-snap-align: start;
  clip-path: polygon(
    0 0,
    calc(100% - var(--sz-chev-notch)) 0,
    100% 50%,
    calc(100% - var(--sz-chev-notch)) 100%,
    0 100%,
    var(--sz-chev-notch) 50%
  );
}

.reader-marinai-sz__chev.reader-marinai-sz__chev--1 {
  padding-left: 0.72rem;
  clip-path: polygon(
    0 0,
    calc(100% - var(--sz-chev-notch)) 0,
    100% 50%,
    calc(100% - var(--sz-chev-notch)) 100%,
    0 100%
  );
}

.reader-marinai-sz__chev + .reader-marinai-sz__chev {
  margin-left: calc(-0.92 * var(--sz-chev-notch));
}

.reader-marinai-sz__chev--outline {
  background: #fff;
  color: var(--cf-navy);
  filter: drop-shadow(0 0 0 #223266) drop-shadow(0 0 0 #223266) drop-shadow(0 0 0 #223266)
    drop-shadow(0 0 0 #223266);
}

.reader-marinai-sz__chev--navy {
  background: linear-gradient(180deg, #05376b 0%, #002147 52%, #001224 100%);
  color: #fff;
  box-shadow: 0 8px 22px rgba(0, 14, 40, 0.28);
}

.reader-marinai-sz__chev--yellow {
  background: linear-gradient(
    -2deg,
    #fff789 0%,
    var(--cf-yellow) 45%,
    #e6d500 100%
  );
  color: var(--cf-navy);
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.16);
}

.reader-marinai-sz__chev--1 {
  z-index: 4;
}

.reader-marinai-sz__chev--2 {
  z-index: 5;
}

.reader-marinai-sz__chev--3 {
  z-index: 6;
}

.reader-marinai-sz__chev--4 {
  z-index: 7;
}

.reader-marinai-sz__hi {
  margin: 0 0 0.42rem;
  font-size: clamp(0.8rem, 2.15vw, 0.94rem);
  font-weight: 800;
  line-height: 1.3;
}

.reader-marinai-sz__chev--navy .reader-marinai-sz__hi {
  color: #fff;
}

.reader-marinai-sz__body {
  margin: 0;
  font-size: clamp(0.73rem, 1.92vw, 0.8625rem);
  font-weight: 600;
  line-height: 1.42;
}

.reader-marinai-sz__chev--navy .reader-marinai-sz__body {
  color: rgba(255, 255, 255, 0.92);
}

/* Marins — accueil au garage : bande jaune + deux colonnes */
.reader-main--marinai-accogl {
  background: var(--cf-white);
  border-left-color: var(--cf-yellow);
}

.reader-marinai-ag {
  margin-top: -0.2rem;
}

.reader-marinai-ag__head {
  margin: 0 0 1.35rem;
  text-align: center;
}

.reader-marinai-ag__tape-wrap {
  display: inline-flex;
  justify-content: center;
  max-width: 100%;
  margin: 0 auto;
  filter: drop-shadow(0 4px 14px rgba(0, 0, 0, 0.18));
}

.reader-marinai-ag__tape {
  margin: 0;
  padding: 0.55rem 1.25rem 0.58rem;
  background: linear-gradient(-2deg, #fff089 0%, #fff24a 42%, var(--cf-yellow) 100%);
  color: var(--cf-navy);
  font-size: clamp(0.82rem, 2.65vw, 1.06rem);
  font-weight: 800;
  line-height: 1.38;
  text-align: center;
  transform: rotate(-0.45deg);
  clip-path: polygon(
    0 5px,
    6% 0,
    16% 4px,
    30% 0,
    44% 5px,
    58% 0,
    72% 4px,
    86% 0,
    100% 5px,
    100% calc(100% - 5px),
    92% 100%,
    78% calc(100% - 4px),
    64% 100%,
    50% calc(100% - 5px),
    38% 100%,
    24% calc(100% - 4px),
    10% 100%,
    0 calc(100% - 6px)
  );
}

.reader-marinai-ag__tape-a {
  font-weight: 800;
}

.reader-marinai-ag__tape-b {
  display: inline;
  margin-left: 0.35em;
  font-weight: 900;
}

.reader-marinai-ag__cols {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0;
  overflow: visible;
  border-radius: 8px;
  border: 2px solid #121820;
  box-shadow: 0 10px 32px rgba(var(--cf-navy-rgb), 0.12);
}

.reader-marinai-ag__col {
  --reader-ag-pad-x: clamp(0.85rem, 3vw, 1.45rem);
  --reader-ag-pad-y-top: clamp(1.05rem, 2.8vw, 1.55rem);
  --reader-ag-pad-y-bot: clamp(1.35rem, 3.2vw, 1.95rem);
  position: relative;
  padding: var(--reader-ag-pad-y-top) var(--reader-ag-pad-x) var(--reader-ag-pad-y-bot);
  text-align: left;
}

.reader-marinai-ag__col--do {
  background: linear-gradient(180deg, #e8f4fc 0%, #e2f1fa 54%, #d9ebf8 100%);
  color: var(--cf-navy);
}

.reader-marinai-ag__col--dont {
  background: linear-gradient(180deg, #001f3d 0%, #00152e 54%, #000f24 100%);
  color: #fff;
}

.reader-marinai-ag__h--bar {
  position: relative;
  z-index: 1;
  margin: calc(-1 * var(--reader-ag-pad-y-top)) calc(-1 * var(--reader-ag-pad-x)) 0;
  padding: 0.58rem var(--reader-ag-pad-x) 0.62rem;
  font-size: clamp(0.95rem, 2.75vw, 1.2rem);
  font-weight: 900;
  line-height: 1.25;
  border-bottom: 1px solid rgba(0, 0, 0, 0.12);
}

.reader-marinai-ag__h--bar-do {
  background: linear-gradient(180deg, #0a3a6b 0%, #001f3d 100%);
  color: #fff;
}

.reader-marinai-ag__h--bar-dont {
  margin-bottom: 0;
  background: rgba(0, 0, 0, 0.22);
  color: #fff;
  border-bottom-color: rgba(255, 255, 255, 0.12);
}

.reader-marinai-ag__do-core {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(6.5rem, 34%);
  gap: 0.35rem 0.65rem;
  align-items: start;
  padding-top: clamp(1rem, 2.5vw, 1.45rem);
}

.reader-marinai-ag__list--dont {
  position: relative;
  z-index: 1;
  padding-top: clamp(1rem, 2.5vw, 1.45rem);
}

.reader-marinai-ag__h {
  margin: 0 0 0.85rem;
  font-size: clamp(1rem, 2.85vw, 1.35rem);
  font-weight: 900;
  line-height: 1.28;
}


.reader-marinai-ag__h--light {
  color: #fff;
}

.reader-marinai-ag__list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.reader-marinai-ag__li {
  display: flex;
  align-items: flex-start;
  gap: 0.55rem;
  margin: 0 0 0.72rem;
  font-size: clamp(0.78rem, 2vw, 0.895rem);
  font-weight: 600;
  line-height: 1.45;
}

.reader-marinai-ag__col--dont .reader-marinai-ag__li {
  margin-bottom: 0.82rem;
  font-size: clamp(0.8rem, 2.05vw, 0.92rem);
}

.reader-marinai-ag__li:last-child {
  margin-bottom: 0;
}

.reader-marinai-ag__mark {
  flex: 0 0 1rem;
  width: 1rem;
  height: 1rem;
  margin-top: 0.16rem;
  border-radius: 2px;
}

.reader-marinai-ag__mark--ok {
  position: relative;
  background: var(--cf-state-success);
  box-shadow: none;
}

.reader-marinai-ag__mark--ok::after {
  content: "";
  position: absolute;
  inset: 0;
  margin: auto;
  width: 0.32rem;
  height: 0.55rem;
  border-right: 2.5px solid #fff;
  border-bottom: 2.5px solid #fff;
  transform: translate(-5%, -12%) rotate(45deg);
}

.reader-marinai-ag__mark--no {
  position: relative;
  background: var(--cf-state-danger);
}

.reader-marinai-ag__mark--no::before,
.reader-marinai-ag__mark--no::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 62%;
  height: 2.5px;
  background: #fff;
  border-radius: 1px;
  transform-origin: center;
}

.reader-marinai-ag__mark--no::before {
  transform: translate(-50%, -50%) rotate(45deg);
}

.reader-marinai-ag__mark--no::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}

.reader-marinai-ag__col--dont .reader-marinai-ag__mark--no::before,
.reader-marinai-ag__col--dont .reader-marinai-ag__mark--no::after {
  background: var(--cf-yellow);
}

.reader-marinai-ag__fig {
  margin: 0;
  padding: 0;
  text-align: center;
  align-self: center;
}

.reader-marinai-ag__fig-img {
  display: inline-block;
  width: 100%;
  max-width: 220px;
  height: auto;
  max-height: min(360px, 48vh);
  object-fit: contain;
  filter: drop-shadow(0 8px 16px rgba(0, 0, 0, 0.12));
}

.reader-marinai-ag__hazz {
  z-index: 0;
  position: absolute;
  pointer-events: none;
  width: clamp(52px, 18vw, 88px);
  height: clamp(52px, 18vw, 88px);
  background: repeating-linear-gradient(
    -28deg,
    var(--cf-state-danger) 0 6px,
    var(--cf-yellow) 6px 12px
  );
  opacity: 0.94;
}

.reader-marinai-ag__hazz--tl {
  top: 0;
  left: 0;
  clip-path: polygon(0 0, 100% 0, 0 100%);
}

.reader-marinai-ag__hazz--br {
  right: 0;
  bottom: 0;
  clip-path: polygon(100% 0, 100% 100%, 0 100%);
}

@media (max-width: 780px) {
  .reader-marinai-sz__flow {
    flex-wrap: wrap;
    margin: 0;
    overflow: visible;
    scroll-snap-type: none;
    gap: 0.65rem;
  }

  .reader-marinai-sz__chev,
  .reader-marinai-sz__chev--1 {
    flex: 1 1 100%;
    min-width: 0;
    width: 100%;
    max-width: 100%;
    margin-left: 0 !important;
    padding: 0.92rem 0.92rem !important;
    clip-path: none;
    border-radius: 8px;
    box-sizing: border-box;
    z-index: auto;
  }

  .reader-marinai-sz__chev--outline {
    border: 3px solid var(--cf-navy);
    filter: none;
    box-shadow: 0 2px 10px rgba(19, 43, 73, 0.12);
  }

  .reader-marinai-sz__chev--navy,
  .reader-marinai-sz__chev--yellow {
    border: 2px solid rgba(255, 255, 255, 0.35);
  }

  .reader-marinai-ag__cols {
    grid-template-columns: 1fr;
  }

  .reader-marinai-ag__col--dont {
    border-top: 3px solid rgba(255, 255, 255, 0.12);
  }

  .reader-marinai-ag__h--bar {
    margin-top: calc(-1 * clamp(1.05rem, 2.8vw, 1.55rem));
  }

  .reader-marinai-ag__do-core {
    grid-template-columns: 1fr;
    justify-items: center;
    padding-top: 1rem;
  }

  .reader-marinai-ag__do-core .reader-marinai-ag__list {
    justify-self: stretch;
    width: 100%;
  }

  .reader-marinai-ag__fig-img {
    max-width: 240px;
  }
}

/* Marins — criticités / courtoisie : tableau dans encadré jaune */
.reader-main--marinai-criticita {
  background: var(--cf-white);
  border-left-color: var(--cf-yellow);
}

.reader-marinai-cr {
  margin-top: -0.2rem;
}

.reader-marinai-cr .reader-marinai-st__head--white-navy {
  margin-bottom: 1.1rem;
}

.reader-marinai-cr__intro {
  margin: 0 auto 0.35rem;
  max-width: 36rem;
  text-align: center;
  font-size: clamp(0.84rem, 2.2vw, 0.98rem);
  font-weight: 600;
  line-height: 1.5;
  color: var(--cf-navy);
}

.reader-marinai-cr__intro--sub {
  margin-bottom: 1.15rem;
  font-weight: 600;
}

.reader-marinai-cr__frame {
  margin: 0 auto;
  max-width: 44rem;
  padding: clamp(0.85rem, 2.4vw, 1.25rem);
  border-radius: 12px;
  border: 5px solid var(--cf-yellow);
  background: #fff;
  box-shadow: var(--cf-shadow-ui);
}

.reader-marinai-cr__table {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border-radius: 6px;
  border: 2px solid var(--cf-navy);
}

.reader-marinai-cr__row {
  display: grid;
  grid-template-columns: minmax(4.5rem, 7rem) minmax(0, 1fr);
  align-items: stretch;
  border-bottom: 2px solid var(--cf-navy);
  min-height: clamp(4rem, 14vw, 5.5rem);
}

.reader-marinai-cr__row:last-child {
  border-bottom: none;
}

.reader-marinai-cr__ico {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0.55rem 0.45rem;
  background: linear-gradient(180deg, #f0f7fc 0%, #e8f2f8 100%);
  border-right: 2px solid var(--cf-navy);
}

.reader-marinai-cr__ico-img {
  width: min(4.25rem, 14vw);
  height: auto;
  max-height: 4.5rem;
  object-fit: contain;
}

.reader-marinai-cr__line {
  margin: 0;
  padding: 0.75rem clamp(0.65rem, 2.2vw, 1.05rem);
  font-size: clamp(0.8rem, 2.1vw, 0.95rem);
  font-weight: 600;
  line-height: 1.45;
  color: var(--cf-navy);
  background: linear-gradient(180deg, #f7fbfe 0%, #edf4fa 100%);
}

.reader-marinai-cr__lemma {
  font-weight: 800;
  margin-right: 0.12em;
}

@media (max-width: 780px) {
  .reader-marinai-cr__frame {
    padding: 0.65rem;
  }

  .reader-marinai-cr__row {
    grid-template-columns: minmax(4rem, 5.5rem) minmax(0, 1fr);
    min-height: 0;
  }

  .reader-marinai-cr__line {
    padding-top: 0.85rem;
    padding-bottom: 0.85rem;
  }
}

/* Marins — formule (Venn) + slide de clôture jaune */
.reader-main--marinai-formula {
  background: linear-gradient(180deg, #f7f8fb 0%, #eceff5 100%);
  border-left-color: var(--cf-yellow);
}

.reader-marinai-fmv {
  margin-top: -0.2rem;
}

.reader-marinai-fmv__head {
  margin: 0 0 1.25rem;
  text-align: center;
}

.reader-marinai-fmv__tape-wrap {
  display: inline-flex;
  justify-content: center;
  max-width: 100%;
  margin: 0 auto;
  filter: drop-shadow(0 4px 14px rgba(19, 43, 73, 0.14));
}

.reader-marinai-fmv__tape {
  margin: 0;
  padding: 0.52rem 1.2rem 0.55rem;
  background: linear-gradient(-2deg, #fff089 0%, #fff24a 42%, var(--cf-yellow) 100%);
  color: #0a0f18;
  font-size: clamp(0.76rem, 2.35vw, 1.02rem);
  font-weight: 800;
  line-height: 1.38;
  text-align: center;
  transform: rotate(-0.35deg);
  clip-path: polygon(
    0 5px,
    5% 0,
    14% 4px,
    28% 0,
    42% 5px,
    56% 0,
    70% 4px,
    84% 0,
    94% 5px,
    100% 6px,
    100% calc(100% - 5px),
    93% 100%,
    78% calc(100% - 4px),
    64% 100%,
    48% calc(100% - 5px),
    34% 100%,
    20% calc(100% - 4px),
    8% 100%,
    0 calc(100% - 6px)
  );
}

.reader-marinai-fmv__tape-a {
  font-weight: 800;
}

.reader-marinai-fmv__tape-b {
  margin-left: 0.35em;
  font-weight: 900;
}

.reader-marinai-fmv__venn {
  position: relative;
  width: 100%;
  max-width: 34rem;
  height: clamp(340px, 62vw, 400px);
  margin: 0 auto 1.25rem;
}

.reader-marinai-fmv__blob {
  position: absolute;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  width: clamp(174px, 48%, 220px);
  height: clamp(174px, 48%, 220px);
  padding: clamp(0.65rem, 3vw, 1rem) clamp(0.55rem, 2.4vw, 0.95rem);
  border-radius: 50%;
  text-align: center;
  line-height: 1.32;
}

.reader-marinai-fmv__blob--tl {
  left: 0;
  top: 0;
  z-index: 1;
  background: linear-gradient(165deg, #102c59 0%, #061834 52%, #040f26 100%);
  color: #fff;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.14),
    0 14px 32px rgba(0, 8, 30, 0.35);
  border: 2px solid rgba(0, 0, 0, 0.25);
}

.reader-marinai-fmv__blob--tr {
  right: 0;
  top: 0;
  z-index: 2;
  background: linear-gradient(165deg, #fff44a 0%, var(--cf-yellow) 48%, #e6cf00 100%);
  color: #101018;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.35),
    0 14px 32px rgba(0, 0, 0, 0.18);
  border: 3px solid rgba(19, 43, 73, 0.22);
}

.reader-marinai-fmv__blob--b {
  left: 50%;
  bottom: 0;
  z-index: 1;
  width: clamp(198px, 54%, 244px);
  height: clamp(198px, 54%, 244px);
  transform: translateX(-50%);
  background: #fff;
  color: #101018;
  border: 4px solid var(--cf-navy);
  box-shadow: 0 14px 32px rgba(19, 43, 73, 0.12);
}

.reader-marinai-fmv__blob-h {
  font-size: clamp(0.72rem, 2.05vw, 0.88rem);
  font-weight: 900;
}

.reader-marinai-fmv__blob-p {
  font-size: clamp(0.61rem, 1.72vw, 0.7525rem);
  font-weight: 600;
  opacity: 0.96;
}

.reader-marinai-fmv__blob--tl .reader-marinai-fmv__blob-p {
  opacity: 0.9;
}

.reader-marinai-fmv__shield {
  position: absolute;
  left: 50%;
  top: 47%;
  z-index: 4;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.08rem;
  width: clamp(104px, 28%, 128px);
  min-height: 5.5rem;
  padding: 0.55rem 0.45rem 0.92rem;
  transform: translate(-50%, -50%);
  background: linear-gradient(180deg, #fff44a 0%, var(--cf-yellow) 55%, #e6cf00 100%);
  border: 3px solid var(--cf-navy);
  clip-path: polygon(8% 0, 92% 0, 100% 12%, 100% 74%, 50% 100%, 0 74%, 0 12%);
  text-align: center;
  box-shadow: 0 10px 28px rgba(0, 8, 30, 0.28);
}

.reader-marinai-fmv__shield-line {
  display: block;
  font-size: clamp(0.62rem, 1.82vw, 0.7825rem);
  font-weight: 900;
  line-height: 1.22;
  color: #080c14;
}

.reader-marinai-fmv__shield-line:last-child {
  font-size: clamp(0.68rem, 1.92vw, 0.8375rem);
}

.reader-marinai-fmv__footer {
  margin: 0 auto;
  max-width: 38rem;
  text-align: center;
  font-size: clamp(0.78rem, 2.08vw, 0.9175rem);
  font-weight: 800;
  line-height: 1.42;
  color: var(--cf-navy);
}

@media (max-width: 680px) {
  .reader-marinai-fmv__venn {
    display: flex;
    flex-direction: column;
    align-items: center;
    height: auto;
    padding-bottom: 0.5rem;
    gap: 0.15rem;
  }

  .reader-marinai-fmv__blob {
    position: relative;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    bottom: auto !important;
    transform: none !important;
    width: 100% !important;
    height: auto !important;
    min-height: 6.85rem;
    margin: 0;
    max-width: 22rem;
    border-radius: 1.15rem !important;
  }

  .reader-marinai-fmv__shield {
    position: relative;
    left: auto;
    top: auto;
    transform: none;
    margin: 0.5rem auto 0;
    width: min(132px, 46vw);
  }
}

/* Marins — tableau de phrases bilingue (fond navy, grille jaune) */
.reader-main--marinai-frasario {
  background: linear-gradient(165deg, #0c1a3d 0%, #07152f 48%, #040d22 100%);
  border-left-color: var(--cf-yellow);
  color: #fff;
}

.reader-main--marinai-frasario .reader-page-head {
  border-bottom-color: rgba(255, 255, 255, 0.12);
}

.reader-main--marinai-frasario .reader-progress {
  color: rgba(255, 255, 255, 0.72);
}

.reader-main--marinai-frasario .reader-nav {
  border-top-color: rgba(255, 255, 255, 0.22);
}

.reader-main--marinai-frasario .reader-nav-btn {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.35);
  color: #fff;
}

.reader-main--marinai-frasario .reader-nav-btn:hover:not(.reader-nav-btn--next):not(.reader-nav-btn--hub) {
  background: rgba(255, 255, 255, 0.14);
  border-color: var(--cf-yellow);
}

.reader-marinai-fr {
  margin-top: -0.15rem;
}

.reader-marinai-fr__title {
  margin: 0 auto 1.35rem;
  max-width: 36rem;
  text-align: center;
  font-size: clamp(1.05rem, 3.1vw, 1.45rem);
  font-weight: 800;
  line-height: 1.35;
  color: #fff;
  text-wrap: balance;
}

.reader-marinai-fr__table-wrap {
  margin: 0 auto;
  max-width: 44rem;
  padding: 0.2rem;
  border-radius: 4px;
  background: var(--cf-yellow);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.35);
}

.reader-marinai-fr__table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
  border: 2px solid var(--cf-yellow);
  background: rgba(8, 18, 45, 0.97);
}

.reader-marinai-fr__th,
.reader-marinai-fr__td {
  padding: clamp(0.65rem, 2.2vw, 0.95rem) clamp(0.55rem, 2vw, 1rem);
  text-align: center;
  vertical-align: middle;
  border: 2px solid var(--cf-yellow);
  font-size: clamp(0.78rem, 2.05vw, 0.92rem);
  line-height: 1.42;
}

.reader-marinai-fr__th {
  font-weight: 800;
}

.reader-marinai-fr__th--it {
  color: #fff;
  text-decoration: underline;
  text-underline-offset: 0.2em;
  text-decoration-thickness: 2px;
}

.reader-marinai-fr__th--fr {
  color: var(--cf-yellow);
  text-decoration: none;
}

.reader-marinai-fr__td {
  font-weight: 700;
}

.reader-marinai-fr__td--it {
  color: #fff;
}

.reader-marinai-fr__td--fr {
  color: var(--cf-yellow);
}

/* Marins — phase 3 débarquement : bande jaune + feu + trois textes */
.reader-main--marinai-fase3 {
  background: #fff;
  border-left-color: var(--cf-yellow);
}

.reader-marinai-f3 {
  margin-top: -0.2rem;
  color: var(--cf-navy);
}

.reader-marinai-f3__band {
  margin: 0 -0.2rem 1.35rem;
  padding: 0.75rem 1rem 0.82rem;
  text-align: center;
  border-radius: 2px;
  background: linear-gradient(180deg, #fff54a 0%, var(--cf-yellow) 42%, #e6cf00 100%);
  border: 2px solid rgba(19, 43, 73, 0.18);
  box-shadow: 0 4px 18px rgba(19, 43, 73, 0.12);
  clip-path: polygon(
    0 5px,
    4% 0,
    10% 4px,
    18% 0,
    28% 5px,
    40% 0,
    52% 4px,
    64% 0,
    76% 5px,
    88% 0,
    96% 4px,
    100% 6px,
    100% calc(100% - 5px),
    96% 100%,
    84% calc(100% - 4px),
    72% 100%,
    58% calc(100% - 5px),
    44% 100%,
    30% calc(100% - 4px),
    16% 100%,
    6% calc(100% - 5px),
    0 calc(100% - 4px)
  );
}

.reader-marinai-f3__band-title {
  margin: 0 auto;
  max-width: 36rem;
  font-size: clamp(0.88rem, 2.45vw, 1.12rem);
  font-weight: 900;
  line-height: 1.35;
  color: #0a0f18;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.reader-marinai-f3__grid {
  display: grid;
  grid-template-columns: minmax(7.5rem, 32%) minmax(0, 1fr);
  gap: clamp(0.85rem, 3vw, 1.75rem);
  align-items: center;
}

.reader-marinai-f3__fig {
  margin: 0;
  padding: 0;
  justify-self: center;
  align-self: stretch;
  display: flex;
  align-items: center;
  justify-content: center;
}

.reader-marinai-f3__img {
  display: block;
  width: 100%;
  max-width: 280px;
  height: auto;
  object-fit: contain;
  filter: drop-shadow(0 8px 20px rgba(19, 43, 73, 0.12));
}

.reader-marinai-f3__steps {
  display: grid;
  grid-template-rows: repeat(3, minmax(min-content, 1fr));
  gap: clamp(0.65rem, 2.4vw, 1.35rem);
  align-items: center;
}

.reader-marinai-f3__step {
  margin: 0;
  font-size: clamp(0.82rem, 2.12vw, 0.96rem);
  font-weight: 700;
  line-height: 1.45;
  color: var(--cf-navy);
}

.reader-marinai-f3__step--1 {
  border-left: 4px solid #d9232d;
  padding-left: 0.72rem;
}

.reader-marinai-f3__step--2 {
  border-left: 4px solid var(--cf-yellow-dark);
  padding-left: 0.72rem;
}

.reader-marinai-f3__step--3 {
  border-left: 4px solid #2d8f47;
  padding-left: 0.72rem;
}

@media (max-width: 680px) {
  /* Bloc tableau → cartes empilées (sinon table-layout: fixed garde 2 colonnes) */
  .reader-marinai-fr__table {
    display: block;
    width: 100%;
  }

  .reader-marinai-fr__thead {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip-path: inset(50%);
    white-space: nowrap;
    border: 0;
  }

  .reader-marinai-fr__table tbody {
    display: block;
    width: 100%;
  }

  .reader-marinai-fr__tr {
    display: block;
    width: 100%;
    margin-bottom: 0.85rem;
    border: 2px solid var(--cf-yellow);
    border-radius: 4px;
    overflow: hidden;
    background: rgba(8, 18, 45, 0.97);
  }

  .reader-marinai-fr__tr:last-child {
    margin-bottom: 0;
  }

  .reader-marinai-fr__td {
    display: block;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    border: none;
    border-bottom: 2px solid var(--cf-yellow);
    text-align: left;
    padding-left: 0.95rem;
    padding-right: 0.95rem;
  }

  .reader-marinai-fr__tr .reader-marinai-fr__td:last-child {
    border-bottom: none;
  }

  .reader-marinai-fr__td--it::before {
    content: "Italiano : ";
    display: block;
    margin-bottom: 0.2rem;
    font-size: 0.72rem;
    font-weight: 800;
    text-decoration: underline;
    text-underline-offset: 0.12em;
    color: rgba(255, 255, 255, 0.75);
    letter-spacing: 0.04em;
    text-transform: uppercase;
  }

  .reader-marinai-fr__td--fr::before {
    content: "Français : ";
    display: block;
    margin-bottom: 0.2rem;
    font-size: 0.72rem;
    font-weight: 800;
    color: var(--cf-yellow);
    letter-spacing: 0.04em;
    text-transform: uppercase;
  }

  .reader-marinai-f3__grid {
    grid-template-columns: 1fr;
    justify-items: center;
  }

  .reader-marinai-f3__fig {
    max-width: 220px;
  }

  .reader-marinai-f3__steps {
    width: 100%;
    align-items: start;
  }
}

.reader-main--marinai-immagine .reader-nav {
  margin-top: 1.85rem;
  padding-top: 1.35rem;
  border-top-color: rgba(255, 255, 255, 0.22);
}

.reader-main--marinai-cover .reader-nav {
  margin-top: 1.75rem;
}

.reader-main--ospitalita-cover .reader-nav {
  margin-top: 1.75rem;
}

.reader-main--cover-stack .reader-nav {
  margin-top: 1.75rem;
}

.reader-ul {
  margin: 0 0 1.25rem 1rem;
  padding: 0;
  color: var(--cf-ink);
}

.reader-ul li {
  margin-bottom: 0.5rem;
}

.reader-note {
  margin-top: 1rem;
  padding: 1rem 1rem 1rem 1rem;
  border-radius: 0.75rem;
  border-left: 4px solid var(--cf-navy);
  background: var(--cf-blue-soft);
  font-size: 0.9rem;
  color: var(--cf-ink-muted);
}

.reader-nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  margin-top: 2.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--cf-border);
}

.reader-nav-btn {
  display: inline-flex;
  align-items: center;
  padding: 0.65rem 1.15rem;
  border-radius: 9999px;
  border: 1px solid var(--cf-border);
  background: var(--cf-bg-page);
  color: var(--cf-blue-deep);
  font-size: 0.875rem;
  font-weight: 600;
  text-decoration: none;
  transition:
    border-color 0.15s,
    background 0.15s;
  box-shadow: var(--cf-shadow-ui);
}

.reader-nav-btn--next {
  margin-left: auto;
  border-color: var(--cf-navy);
  background: var(--cf-yellow);
  color: var(--cf-navy);
  font-weight: 800;
}

.reader-nav-btn--hub {
  border-color: var(--cf-navy);
  color: var(--cf-white);
  background: var(--cf-navy);
}

.reader-nav-btn:hover:not(.reader-nav-btn--next):not(.reader-nav-btn--hub) {
  border-color: var(--cf-navy);
  background: var(--cf-yellow-tint);
}

.reader-nav-btn--next:hover {
  filter: brightness(1.06);
}

.reader-nav-btn--hub:hover {
  filter: brightness(1.15);
}

.reader-nav-spacer {
  flex: 0 0 auto;
  min-width: 1rem;
}

/* —— Livret Accoglienza : slides « chiffres », timeline, destinations —— */
.reader-main--stats {
  background: linear-gradient(165deg, #171f4a 0%, #12183a 55%, #0f1430 100%);
  border-color: rgba(255, 255, 255, 0.12);
}

.reader-main--stats .reader-kicker {
  color: rgba(255, 255, 255, 0.88);
}

.reader-main--stats .reader-h1 {
  color: var(--cf-white);
}

.reader-main--stats .reader-progress {
  color: rgba(255, 255, 255, 0.65);
}

.reader-main--stats .reader-nav {
  border-top-color: rgba(255, 255, 255, 0.2);
}

.reader-main--stats .reader-nav-btn {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.35);
  color: rgba(255, 255, 255, 0.95);
  box-shadow: none;
}

.reader-main--stats .reader-nav-btn:hover:not(.reader-nav-btn--next):not(.reader-nav-btn--hub) {
  border-color: var(--cf-yellow);
  background: rgba(255, 237, 0, 0.08);
}

.reader-main--stats .reader-nav-btn--next {
  border-color: var(--cf-yellow);
  background: var(--cf-yellow);
  color: var(--cf-navy);
}

.reader-main--stats .reader-nav-btn--hub {
  border-color: rgba(255, 255, 255, 0.55);
  background: transparent;
  color: var(--cf-white);
}

.reader-main--stats .reader-nav-btn--hub:hover {
  border-color: var(--cf-yellow);
  background: rgba(255, 255, 255, 0.08);
  filter: none;
}

.reader-stats {
  margin-top: 0.75rem;
}

.reader-stats__cols {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}

@media (min-width: 720px) {
  .reader-stats__cols {
    flex-direction: row;
    align-items: stretch;
    gap: 1rem;
  }

  .reader-stats__col {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
    min-width: 0;
  }
}

.reader-stat-card {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 1rem;
  padding: 1.05rem 1.15rem;
  border-radius: 0.85rem;
  background: var(--cf-white);
  box-shadow: 0 6px 28px rgba(0, 0, 0, 0.28);
}

.reader-stat-card--prose {
  align-items: flex-start;
}

.reader-stat-card__media {
  flex: 0 0 auto;
}

.reader-stat-card__main {
  min-width: 0;
}

.reader-stat-card__num {
  margin: 0 0 0.2rem;
  font-size: clamp(1.75rem, 4vw, 2.35rem);
  font-weight: 800;
  line-height: 1.05;
  color: var(--cf-yellow);
}

.reader-stat-card__lbl {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 600;
  line-height: 1.45;
  color: #2b2b2b;
}

.reader-stat-card--prose .reader-stat-card__lbl {
  font-weight: 600;
}

.reader-stat-card--prose.reader-stat-card .reader-stat-card__lbl {
  font-size: 0.93rem;
}

.reader-stat-icon {
  display: block;
  width: 56px;
  height: 56px;
  flex-shrink: 0;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}

img.reader-stat-icon--asset {
  object-fit: contain;
}

.reader-stat-icon--people {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='%23FFED00' stroke-width='2'%3E%3Cpath d='M26 16a6 6 0 1 0-12 0 6 6 0 0 0 12 0Zm16 0a6 6 0 1 0-12 0 6 6 0 0 0 12 0ZM12 36c0-5 5-9 11-9s11 4 11 9M34 36c0-4 3-8 8-9'/%3E%3C/svg%3E");
}

.reader-stat-icon--map {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='%23FFED00' stroke-width='2'%3E%3Cpath d='M8 10 20 6l16 6v30l-16-6-12 4V10Z'/%3E%3Cpath d='m20 27 4-4 4 6' stroke-dasharray='3 3'/%3E%3Ccircle cx='25' cy='16' r='2' fill='%23FFED00'/%3E%3C/svg%3E");
}

.reader-stat-icon--ship {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='%23FFED00' stroke-width='2'%3E%3Cpath d='M6 28h40l-8-12H14L6 28Zm4-12 4-14h20l4 14'/%3E%3Cpath d='M10 32c4 2 8 3 16 3s12-1 16-3'/%3E%3C/svg%3E");
}

.reader-stat-icon--clock {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='%23FFED00' stroke-width='2'%3E%3Ccircle cx='28' cy='28' r='18'/%3E%3Cpath d='M28 18v12l8 5'/%3E%3C/svg%3E");
}

.reader-stat-icon--trophy {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='%23223266' stroke-width='2'%3E%3Cpath d='M16 10h24v4c0 6-4 10-10 10h-4c-6 0-10-4-10-10V10Z'/%3E%3Cpath d='M20 34h16v6H20v-6Zm4-10h8v4h-8v-4Z'/%3E%3Cpath d='M10 10H6v4c0 3 2 5 5 5M46 10h4v4c0 3-2 5-5 5'/%3E%3C/svg%3E");
}

/* Timeline */
.reader-main--timeline {
  background: #f4f4f4;
  border-color: rgba(var(--cf-navy-rgb), 0.1);
}

.reader-main--timeline .reader-progress {
  color: var(--cf-ink-muted);
}

.reader-timeline {
  margin-top: 0.85rem;
  position: relative;
}

.reader-timeline-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 0.45rem 0.65rem;
  align-items: end;
}

@media (max-width: 1040px) {
  .reader-timeline {
    overflow-x: auto;
    overscroll-behavior-x: contain;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 0.75rem;
    margin-left: -0.25rem;
    margin-right: -0.25rem;
    padding-left: 0.25rem;
    padding-right: 0.35rem;
  }

  .reader-timeline-grid {
    /* ~190px/col : largeur minimale lisible lors du swipe horizontal sur mobile/tablette */
    min-width: min(920px, max(760px, 92vw));
  }

  .reader-tl-card__body {
    flex-direction: column;
    align-items: stretch;
    text-align: center;
  }

  .reader-tl-card__thumb {
    width: 3.65rem;
    height: 3.65rem;
    margin-inline: auto;
    flex-shrink: 0;
  }

  .reader-tl-card__txt {
    text-align: center;
  }
}

.reader-t-slot {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  min-width: 0;
}

.reader-t-slot--top {
  justify-content: flex-end;
  min-height: 0;
}

.reader-t-slot--bot {
  justify-content: flex-start;
  min-height: 0;
}

.reader-t-rail {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  align-items: center;
  position: relative;
  height: 2.25rem;
  margin: 0.15rem 0 0.35rem;
}

.reader-t-rail::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 50%;
  height: 6px;
  margin-top: -3px;
  border-radius: 9999px;
  background: var(--cf-yellow);
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.06);
}

.reader-t-rail__dot {
  position: relative;
  z-index: 1;
  display: flex;
  justify-content: center;
}

.reader-t-rail__dot > span {
  display: block;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--cf-white);
  border: 3px solid var(--cf-yellow);
  box-shadow: 0 0 0 1px rgba(var(--cf-navy-rgb), 0.12);
}

.reader-tl-year {
  margin: 0;
  font-size: clamp(1.15rem, 2.8vw, 1.65rem);
  font-weight: 800;
  color: var(--cf-yellow-dark);
}

.reader-tl-year--railabove {
  margin-bottom: auto;
}

.reader-tl-year--railbelow {
  margin-top: auto;
}

.reader-tl-card {
  /* Toutes les cartes : même gabarit (les colonnes de grille ont la même largeur) */
  container-name: tl-card;
  container-type: size;
  position: relative;
  display: flex;
  flex-direction: column;
  width: 100%;
  margin-inline: auto;
  height: 11.75rem;
  min-height: 11.75rem;
  max-height: 11.75rem;
  padding: 0.6rem 0.55rem;
  border-radius: 0.75rem;
  background: var(--cf-white);
  box-shadow: 0 10px 28px rgba(var(--cf-navy-rgb), 0.12);
  /* visible : ne pas masquer trait + pastille liaison (::before / ::after) */
  overflow: visible;
  box-sizing: border-box;
}

.reader-tl-card__body {
  display: flex;
  flex-direction: row;
  flex: 1 1 auto;
  align-items: stretch;
  gap: 0.5rem;
  text-align: left;
  width: 100%;
  min-width: 0;
  min-height: 0;
}

.reader-tl-card__thumb {
  width: 3.85rem;
  height: 3.85rem;
  flex-shrink: 0;
  border-radius: 50%;
  padding: 3px;
  background: linear-gradient(145deg, var(--cf-yellow), #ffd000);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.reader-tl-card__thumb img {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  object-fit: cover;
}

.reader-tl-card__txt {
  margin: 0;
  align-self: stretch;
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-gutter: stable;
  overflow-wrap: break-word;
  word-break: normal;
  /* Police indexée à la largeur de la carte (container query) puis bornée au min/max */
  font-size: clamp(0.595rem, 0.53rem + 0.58vw, 0.735rem);
  font-weight: 600;
  line-height: 1.32;
  letter-spacing: 0.008em;
  color: var(--cf-navy);
}

@supports (width: 1cqw) {
  .reader-tl-card .reader-tl-card__txt {
    font-size: clamp(10px, calc(6.8cqw + 0.1cqh), 12.5px);
  }
}

@supports (-webkit-hyphens: auto) or (hyphens: auto) {
  .reader-tl-card__txt {
    hyphens: auto;
    -webkit-hyphens: auto;
  }
}

.reader-tl-card__txt::-webkit-scrollbar {
  width: 6px;
}

.reader-tl-card__txt::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: rgba(var(--cf-navy-rgb), 0.2);
}

.reader-t-slot--top .reader-tl-card {
  margin-bottom: 0.5rem;
}

.reader-t-slot--top .reader-tl-card::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -0.55rem;
  width: 2px;
  height: 0.55rem;
  margin-left: -1px;
  background: var(--cf-navy);
}

.reader-t-slot--bot .reader-tl-card {
  margin-top: 0.5rem;
}

.reader-t-slot--bot .reader-tl-card::before {
  content: "";
  position: absolute;
  left: 50%;
  top: -0.55rem;
  width: 2px;
  height: 0.55rem;
  margin-left: -1px;
  background: var(--cf-navy);
}

.reader-t-slot--top .reader-tl-year--railbelow {
  margin-bottom: 0;
  margin-top: 0;
  padding-bottom: 0.15rem;
}

.reader-t-slot--bot .reader-tl-year--railabove {
  margin-bottom: 0;
  padding-top: 0.15rem;
}

/* Destinations */
.reader-main--destinations {
  background: #fafafa;
  background-image:
    linear-gradient(#e9ecef 1px, transparent 1px),
    linear-gradient(90deg, #e9ecef 1px, transparent 1px);
  background-size: 18px 18px;
}

.reader-main--destinations .reader-progress {
  color: var(--cf-ink-muted);
}

.reader-destinations {
  display: grid;
  gap: 1.25rem;
  margin-top: 0.85rem;
  align-items: start;
}

@media (min-width: 900px) {
  .reader-destinations {
    grid-template-columns: minmax(0, 0.92fr) minmax(0, 2.4fr);
    gap: 1.65rem;
  }
}

.reader-destinations__aside {
  padding: 0.25rem 0;
}

.reader-dest-block + .reader-dest-block {
  margin-top: 1rem;
}

.reader-dest-zona {
  margin: 0 0 0.2rem;
  font-weight: 800;
  font-size: 0.95rem;
  color: var(--cf-navy);
}

.reader-dest-ports {
  margin: 0;
  font-size: 0.93rem;
  font-weight: 500;
  line-height: 1.48;
  color: #222;
}

.reader-destinations__map {
  margin: 0;
  padding: 0;
  border-radius: 0.65rem;
  overflow: hidden;
  background: var(--cf-bg-soft-grey);
  box-shadow: 0 8px 30px rgba(var(--cf-navy-rgb), 0.1);
  border: 1px solid rgba(var(--cf-navy-rgb), 0.1);
}

.reader-destinations__map img {
  display: block;
  width: 100%;
  height: auto;
  vertical-align: top;
}

/* Sous-titres de slide sous le titre de page */
.reader-doc-subtitle {
  margin: 0.35rem 0 0;
  font-size: clamp(0.95rem, 2vw, 1.1rem);
  font-weight: 800;
  color: var(--cf-navy);
  line-height: 1.3;
}

/* —— Organisation à terre —— */
.reader-main--org-terra {
  background: #fafafa;
  background-image:
    linear-gradient(#e9ecef 1px, transparent 1px),
    linear-gradient(90deg, #e9ecef 1px, transparent 1px);
  background-size: 18px 18px;
}

.reader-terra {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.1rem;
  margin-top: 0.85rem;
}

@media (min-width: 780px) {
  .reader-terra {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.25rem;
    align-items: stretch;
  }
}

.reader-terra-card {
  background: var(--cf-white);
  border-radius: 0.65rem;
  box-shadow: var(--cf-shadow-ui);
  border: 1px solid rgba(var(--cf-navy-rgb), 0.1);
  overflow: hidden;
}

.reader-terra-card__ribbon {
  margin: 0;
  padding: 0.45rem 0.75rem;
  background: var(--cf-yellow);
  color: var(--cf-navy);
  font-weight: 800;
  font-size: 0.92rem;
  letter-spacing: 0.02em;
  text-align: center;
}

.reader-terra-card__list {
  margin: 0;
  padding: 0.85rem 0.75rem 1rem;
  list-style: none;
}

.reader-terra-card__item {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin-bottom: 0.55rem;
}

.reader-terra-card__item:last-child {
  margin-bottom: 0;
}

.reader-terra-card__lbl {
  flex: 1;
  min-width: 0;
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--cf-navy);
  line-height: 1.38;
  text-align: left;
}

.terra-strip-ico {
  flex: 0 0 auto;
  display: inline-block;
  background-repeat: no-repeat;
  background-position-x: center;
  vertical-align: middle;
  background-size: 100% calc(var(--n) * 100%);
  background-position-y: calc(var(--i) * 100% / (var(--n) - 1));
}

.terra-strip-ico[data-strip="bastia"] {
  width: clamp(2.05rem, 5.2vw, 2.5rem);
  aspect-ratio: 144 / calc(662 / 5);
}

.terra-strip-ico[data-strip="savona"] {
  width: clamp(2.08rem, 5.4vw, 2.55rem);
  aspect-ratio: 158 / calc(693 / 6);
}

.terra-strip-ico[data-strip="fleet-servizi"] {
  aspect-ratio: 96 / calc(356 / 5);
}

.terra-strip-ico--fleet-list {
  width: clamp(1.92rem, 4.4vw, 2.22rem);
  align-self: center;
}

.reader-main--fleet-showcase {
  background: #fafafa;
  background-image:
    linear-gradient(#e9ecef 1px, transparent 1px),
    linear-gradient(90deg, #e9ecef 1px, transparent 1px);
  background-size: 18px 18px;
}

.reader-flotta-showcase {
  display: grid;
  gap: 1.2rem;
  margin-top: 0.85rem;
  align-items: stretch;
}

@media (min-width: 900px) {
  .reader-flotta-showcase {
    grid-template-columns: minmax(0, 0.88fr) minmax(0, 1.35fr);
    gap: 1.35rem;
    align-items: start;
  }
}

.reader-flotta-panel {
  padding: 1rem 1rem 1.1rem;
  border-radius: 0.75rem;
  background: rgba(255, 255, 255, 0.95);
  border: 1px solid rgba(var(--cf-navy-rgb), 0.1);
  box-shadow: var(--cf-shadow-ui);
}

.reader-flotta-block + .reader-flotta-block {
  margin-top: 1rem;
}

.reader-flotta-h {
  margin: 0 0 0.35rem;
  font-size: 0.92rem;
  font-weight: 800;
  color: var(--cf-navy);
}

.reader-flotta-line {
  margin: 0;
  font-size: 0.9rem;
  font-weight: 600;
  color: #2a2a2a;
}

.reader-flotta-block--serv .reader-flotta-h {
  margin-bottom: 0.45rem;
}

.reader-flotta-bullets {
  margin: 0;
  padding: 0;
  list-style: none;
}

.reader-flotta-bullets li,
.reader-flotta-bullets__row {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  margin-bottom: 0.45rem;
  font-size: 0.88rem;
  font-weight: 600;
  color: #222;
  line-height: 1.42;
}

.reader-flotta-bullets__txt {
  flex: 1;
  min-width: 0;
}

.reader-flotta-dot {
  display: inline-block;
  width: 0.52rem;
  height: 0.52rem;
  margin-top: 0.42em;
  border-radius: 50%;
  flex-shrink: 0;
  background: var(--cf-yellow);
  box-shadow: 0 0 0 1px rgba(var(--cf-navy-rgb), 0.12);
}

.reader-flotta-foot {
  margin: 0.85rem 0 0;
  font-size: 0.78rem;
  font-weight: 600;
  line-height: 1.45;
  color: var(--cf-ink-muted);
}

.reader-flotta-fig {
  margin: 0;
  align-self: start;
  width: 100%;
  min-height: 0;
}

.reader-flotta-photo {
  border-radius: 0.65rem;
  overflow: hidden;
  background: var(--cf-bg-soft-grey);
  box-shadow: 0 10px 36px rgba(var(--cf-navy-rgb), 0.12);
}

.reader-flotta-photo img {
  display: block;
  width: 100%;
  height: auto;
  max-height: min(72vh, 640px);
  object-fit: cover;
  object-position: center;
}

.reader-main--roles-table {
  background: #fafafa;
  background-image:
    linear-gradient(#e9ecef 1px, transparent 1px),
    linear-gradient(90deg, #e9ecef 1px, transparent 1px);
  background-size: 18px 18px;
}

.reader-roles-wrap {
  margin-top: 0.85rem;
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.reader-roles-table {
  width: 100%;
  max-width: 52rem;
  margin-inline: auto;
  border-collapse: collapse;
  font-size: 0.86rem;
  font-weight: 600;
  color: var(--cf-navy);
  line-height: 1.4;
  box-shadow: var(--cf-shadow-ui);
  border: 1px solid rgba(var(--cf-navy-rgb), 0.22);
  border-radius: 0.4rem;
  overflow: hidden;
}

.reader-roles-table th,
.reader-roles-table td {
  padding: 0.65rem 0.75rem;
  border: 1px solid rgba(var(--cf-navy-rgb), 0.2);
  vertical-align: top;
  text-align: left;
}

.reader-roles-table thead th {
  background: var(--cf-navy);
  color: var(--cf-white);
  font-size: 0.88rem;
  font-weight: 800;
  letter-spacing: 0.02em;
}

.reader-roles-table tbody tr:nth-child(even) {
  background: rgba(var(--cf-navy-rgb), 0.045);
}

.reader-roles-table tbody tr:nth-child(odd) {
  background: #fff;
}

@media (max-width: 640px) {
  .reader-roles-table {
    font-size: 0.78rem;
  }

  .reader-roles-table th,
  .reader-roles-table td {
    padding: 0.5rem 0.45rem;
  }
}

.reader-orgchart {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 0.75rem;
  max-width: 44rem;
  margin-inline: auto;
}

.reader-org-node {
  border-radius: 0.35rem;
  text-align: center;
}

.reader-org-node__title {
  margin: 0 0 0.45rem;
  font-size: 1.05rem;
  font-weight: 900;
}

.reader-org-node__desc {
  margin: 0;
  font-size: 0.82rem;
  font-weight: 600;
  line-height: 1.45;
}

.reader-org-node--captain {
  background: var(--cf-yellow);
  border: 3px solid #0f0f0f;
  padding: 0.95rem 1.25rem;
  margin-inline: auto;
  max-width: 22rem;
  width: 100%;
}

.reader-org-node--captain .reader-org-node__title {
  font-size: 1.08rem;
  color: var(--cf-navy);
}

.reader-org-node--captain .reader-org-node__desc {
  color: #1a2140;
}

.reader-orgchart__lines {
  display: block;
  width: min(94%, 28rem);
  height: 3.35rem;
  margin: -0.1rem auto -0.2rem;
}

.reader-orgchart__row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.85rem;
  width: 100%;
}

.reader-org-node--dept {
  position: relative;
  padding: 0.9rem 1rem 1.9rem;
  background: var(--cf-navy);
  color: var(--cf-white);
  border: 2px solid rgba(255, 255, 255, 0.95);
  box-shadow:
    inset -5px -5px 0 rgba(255, 255, 255, 0.35),
    5px 5px 0 rgba(var(--cf-navy-rgb), 0.2);
}

.reader-org-node--dept .reader-org-node__title {
  font-size: 0.96rem;
  color: var(--cf-white);
}

.reader-org-node--dept .reader-org-node__desc {
  font-size: 0.78rem;
  color: rgba(255, 255, 255, 0.92);
}

.reader-org-corner {
  position: absolute;
  display: block;
  width: clamp(28px, 8vw, 40px);
  height: auto;
  object-fit: contain;
}

.reader-org-corner--br {
  right: 0.45rem;
  bottom: 0.42rem;
}

.reader-org-corner--bl {
  left: 0.45rem;
  bottom: 0.42rem;
}

@media (max-width: 640px) {
  /* Organigramme en colonne : pas de H / lignes de bifurcation */
  .reader-orgchart__lines {
    display: none;
  }

  .reader-orgchart__row {
    grid-template-columns: 1fr;
    gap: 0.65rem;
    margin-top: 0.35rem;
  }
}

.reader-main--ten-rules {
  background: #fafafa;
  background-image:
    linear-gradient(#e9ecef 1px, transparent 1px),
    linear-gradient(90deg, #e9ecef 1px, transparent 1px);
  background-size: 18px 18px;
}

.reader-ten-rules {
  display: grid;
  gap: 0.95rem;
  grid-template-columns: repeat(auto-fill, minmax(9.25rem, 1fr));
  margin-top: 0.75rem;
  max-width: 58rem;
  margin-inline: auto;
}

.reader-ten-rule-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 1rem 0.62rem;
  border-radius: 0.45rem;
  background: var(--cf-white);
  border: 1px solid rgba(var(--cf-navy-rgb), 0.1);
  box-shadow: 0 6px 20px rgba(var(--cf-navy-rgb), 0.1);
}

.reader-ten-rule-card__media {
  display: grid;
  place-items: center;
  margin-bottom: 0.65rem;
}

.reader-ten-rule-card__media img {
  width: clamp(4.65rem, 14vw, 5.85rem);
  height: auto;
  object-fit: contain;
}

.reader-ten-rule-card__lbl {
  margin: 0;
  font-size: 0.8rem;
  font-weight: 700;
  line-height: 1.42;
  color: var(--cf-navy);
}

@media (min-width: 900px) {
  .reader-ten-rules {
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 1rem 0.72rem;
  }
}

.reader-main--wifi-plans {
  background: #fff;
  background-image:
    linear-gradient(#e9ecef 1px, transparent 1px),
    linear-gradient(90deg, #e9ecef 1px, transparent 1px);
  background-size: 22px 22px;
}

.reader-wifi {
  margin-top: 0.5rem;
  max-width: 52rem;
  margin-inline: auto;
}

.reader-wifi-highlight {
  margin: 0 0 0.95rem;
  padding: 0.65rem 1rem;
  background: var(--cf-yellow);
  border-radius: 0.35rem;
  border: 1px solid rgba(0, 0, 0, 0.08);
}

.reader-wifi-highlight__txt {
  margin: 0;
  font-size: 0.92rem;
  font-weight: 800;
  color: var(--cf-navy);
  text-align: center;
  line-height: 1.4;
}

.reader-wifi-alert {
  display: flex;
  gap: 0.75rem;
  align-items: flex-start;
  margin: 0 0 1.15rem;
  padding: 0.72rem 0.98rem;
  border: 2px solid var(--cf-navy);
  border-radius: 0.42rem;
  background: rgba(255, 255, 255, 0.95);
}

.reader-wifi-alert__tri {
  flex-shrink: 0;
  position: relative;
  width: 1.82rem;
  height: 1.82rem;
  margin-top: 0.1rem;
  background: linear-gradient(#d32f2f, #c62828);
  clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
}

.reader-wifi-alert__bang {
  position: absolute;
  left: 50%;
  top: calc(54% + 2px);
  transform: translate(-50%, -50%);
  font-size: 0.85rem;
  font-weight: 900;
  color: var(--cf-white);
  line-height: 1;
}

.reader-wifi-alert__txt {
  margin: 0;
  font-size: 0.9rem;
  font-weight: 600;
  font-style: italic;
  text-decoration: underline;
  color: var(--cf-navy);
  line-height: 1.45;
}

.reader-wifi-plans-head {
  margin: 0 0 1.1rem;
  font-size: 1.06rem;
  font-weight: 900;
  text-align: center;
  color: var(--cf-navy);
}

.reader-wifi-plans-row {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(9.85rem, 1fr));
  gap: 0.92rem;
  justify-content: center;
}

.reader-wifi-plan {
  padding: 0.92rem 0.82rem;
  border-radius: 0.45rem;
  background: var(--cf-white);
  border: 1px solid rgba(var(--cf-navy-rgb), 0.13);
  box-shadow:
    0 4px 14px rgba(var(--cf-navy-rgb), 0.1),
    0 2px 0 rgba(var(--cf-navy-rgb), 0.04);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.reader-wifi-plan__name {
  margin: 0 0 0.62rem;
  font-size: 0.93rem;
  font-weight: 900;
  color: var(--cf-navy);
}

.reader-wifi-plan__badge {
  width: clamp(44px, 12vw, 56px);
  height: auto;
  object-fit: contain;
  margin-bottom: 0.55rem;
}

.reader-wifi-plan__data {
  margin: 0 0 0.72rem;
  font-size: 1.6rem;
  font-weight: 900;
  letter-spacing: 0.02em;
  color: var(--cf-navy);
  line-height: 1;
}

.reader-wifi-plan__price {
  margin: 0;
  font-size: 0.93rem;
  font-weight: 800;
  color: var(--cf-navy);
}

.reader-wifi-plan__price--ico {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.42rem;
  flex-wrap: wrap;
}

.reader-wifi-plan__price--ico img {
  flex-shrink: 0;
}

@media (min-width: 960px) {
  .reader-wifi-plans-row {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

.reader-main--hr-portal {
  background: #fff;
  background-image:
    linear-gradient(rgba(120, 160, 215, 0.18) 1px, transparent 1px),
    linear-gradient(90deg, rgba(120, 160, 215, 0.18) 1px, transparent 1px);
  background-size: 22px 22px;
}

.reader-hr {
  position: relative;
  overflow: visible;
}

.reader-hr__decoration {
  pointer-events: none;
  position: absolute;
  inset: 0;
  z-index: 0;
}

.reader-hr__deco {
  position: absolute;
  opacity: 0.22;
  color: rgba(34, 50, 102, 0.55);
  font-size: clamp(2.2rem, 7vw, 3rem);
  line-height: 1;
  user-select: none;
}

.reader-hr__deco--wheel {
  width: 2.85rem;
  height: 2.85rem;
  border-radius: 50%;
  border: 0.38rem dashed currentColor;
  font-size: 0;
}

.reader-hr__deco--wheel::after {
  content: '';
  position: absolute;
  left: 50%;
  top: 50%;
  width: 0.52rem;
  height: 0.52rem;
  margin: -0.26rem 0 0 -0.26rem;
  border-radius: 50%;
  background: currentColor;
}

.reader-hr__deco--anchor::before {
  content: '⚓';
}

.reader-hr__deco--tr {
  top: 2%;
  right: 4%;
}

.reader-hr__deco--tr2 {
  top: 8%;
  right: 18%;
  font-size: clamp(1.8rem, 5vw, 2.35rem);
}

.reader-hr__deco--bl {
  bottom: 8%;
  left: 6%;
}

.reader-hr__deco--bc {
  bottom: 4%;
  left: 42%;
}

.reader-hr__grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1.12fr) minmax(56px, 0.42fr) minmax(0, 1.05fr);
  gap: 0.65rem 0.95rem;
  align-items: center;
  max-width: 53rem;
  margin: 0.6rem auto 0;
}

.reader-hr__visual {
  position: relative;
  min-height: 0;
  padding-bottom: 0.25rem;
}

.reader-hr__devices {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: flex-end;
  gap: 0;
  padding: 4.2rem 0.75rem 0.85rem;
  color: var(--cf-navy);
}

.reader-hr__devices--asset {
  padding: 0.85rem 0.5rem 0.85rem;
  align-items: center;
}

.reader-hr__stack {
  position: relative;
  display: inline-block;
  vertical-align: top;
  width: fit-content;
  max-width: min(300px, 94vw);
  margin: 0 auto;
  line-height: 0;
  /* Ajuster ici pour aligner l’encadré avec la zone écran du PNG (slide 12) */
  --hr-screen-left: 52%;
  --hr-screen-top: 6%;
  --hr-screen-w: min(56%, 12.2rem);
  --hr-callout-nudge-x: -28%;
}

.reader-hr__stack .reader-hr__devices-img {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
  object-fit: contain;
}

.reader-hr__laptop {
  width: min(296px, 100%);
}

.reader-hr__phone {
  width: clamp(64px, 18vw, 78px);
  margin-left: -30px;
  margin-bottom: 6px;
  z-index: 1;
}

.reader-hr-callout:not(.reader-hr-callout--dock) {
  position: absolute;
  left: 0;
  top: 0;
  display: flex;
  gap: 0.55rem;
  align-items: flex-start;
  max-width: min(19rem, 96%);
  padding: 0.68rem 0.78rem;
  background: var(--cf-yellow);
  border-radius: 0.48rem;
  border: 1px solid rgba(0, 0, 0, 0.07);
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.12);
}

.reader-hr-callout.reader-hr-callout--dock {
  position: absolute;
  z-index: 2;
  left: var(--hr-screen-left);
  top: var(--hr-screen-top);
  width: var(--hr-screen-w);
  transform: translateX(var(--hr-callout-nudge-x, -30%));
  max-width: 13rem;
  padding: 0.52rem 0.62rem;
  margin: 0;
  display: flex;
  gap: 0.45rem;
  align-items: flex-start;
  background: var(--cf-yellow);
  border-radius: 0.4rem;
  border: 2px solid rgba(0, 0, 0, 0.76);
  box-shadow: 0 6px 14px rgba(0, 0, 0, 0.12);
}

.reader-hr-callout__ico {
  flex-shrink: 0;
  margin-top: 0.1rem;
  color: var(--cf-navy);
}

.reader-hr-callout__txt {
  margin: 0;
  font-size: 0.78rem;
  font-weight: 700;
  line-height: 1.45;
  color: var(--cf-navy);
}

.reader-hr-callout__addr {
  display: inline;
  font-weight: 900;
  word-break: break-all;
}

.reader-hr__stack .reader-hr-callout--dock .reader-hr-callout__txt {
  font-size: 0.7rem;
  line-height: 1.35;
}

.reader-hr__stack .reader-hr-callout--dock .reader-hr-callout__ico-img {
  width: clamp(28px, 7vw, 36px);
}

@media (max-width: 520px) {
  .reader-hr__stack {
    --hr-screen-top: 8%;
    --hr-screen-left: 50%;
    --hr-callout-nudge-x: -35%;
    --hr-screen-w: min(60%, 12rem);
  }
}

.reader-hr__connector {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 2.5rem;
}

.reader-hr__arrow {
  width: clamp(52px, 11vw, 118px);
  height: auto;
  color: var(--cf-navy);
}

.reader-hr__arrow--asset {
  display: block;
  width: clamp(100px, 18vw, 168px);
  max-height: 40px;
  height: auto;
  object-fit: contain;
}

.reader-hr__arrow--svg {
  display: block;
}

.reader-hr__aside {
  align-self: center;
}

.reader-hr-credentials {
  margin: 0 0 0.88rem;
  font-size: 0.88rem;
  font-weight: 600;
  line-height: 1.48;
  color: var(--cf-navy);
}

.reader-hr-panel {
  padding: 1rem 1.05rem 1.05rem;
  border-radius: 0.55rem;
  background: var(--cf-white);
  border: 1px solid rgba(var(--cf-navy-rgb), 0.12);
  box-shadow: 0 10px 28px rgba(var(--cf-navy-rgb), 0.1);
}

.reader-hr-panel__title {
  margin: 0 0 0.58rem;
  font-size: 0.9rem;
  font-weight: 900;
  color: var(--cf-navy);
}

.reader-hr-panel__list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.reader-hr-panel__list li {
  display: flex;
  gap: 0.55rem;
  align-items: flex-start;
  margin-bottom: 0.45rem;
  font-size: 0.87rem;
  font-weight: 600;
  line-height: 1.42;
  color: #243054;
}

.reader-hr-panel__list li:last-child {
  margin-bottom: 0;
}

.reader-hr-panel__dot {
  flex-shrink: 0;
  width: 0.54rem;
  height: 0.54rem;
  margin-top: 0.4em;
  border-radius: 50%;
  background: var(--cf-yellow);
  box-shadow: 0 0 0 1px rgba(var(--cf-navy-rgb), 0.12);
}

@media (max-width: 880px) {
  .reader-hr__grid {
    grid-template-columns: 1fr;
    gap: 0.6rem;
  }

  .reader-hr__connector {
    order: 3;
    margin: -0.2rem auto 0;
  }

  .reader-hr__arrow:not(.reader-hr__arrow--asset) {
    width: clamp(36px, 14vw, 72px);
    transform: rotate(90deg);
  }

  .reader-hr__arrow--asset {
    width: clamp(88px, 22vw, 140px);
    max-height: 46px;
    transform: rotate(90deg);
  }

  .reader-hr__aside {
    order: 4;
  }
}

.reader-main--ristorazione {
  background: #fafbfc;
  background-image:
    linear-gradient(#e4e8ee 1px, transparent 1px),
    linear-gradient(90deg, #e4e8ee 1px, transparent 1px);
  background-size: 18px 18px;
}

.reader-risto-page {
  max-width: 58rem;
  margin-inline: auto;
}

.reader-hr-callout__ico-img {
  display: block;
  width: clamp(36px, 9vw, 46px);
  height: auto;
  border-radius: 0.4rem;
  object-fit: contain;
}

.reader-risto-grid {
  display: grid;
  gap: 0.92rem;
  grid-template-columns: repeat(auto-fill, minmax(12.5rem, 1fr));
  margin-top: 1.05rem;
}

@media (min-width: 960px) {
  .reader-risto-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1.05rem;
  }
}

.reader-risto-cell {
  display: flex;
  flex-direction: column;
  background: var(--cf-white);
  border-radius: 0.45rem;
  overflow: hidden;
  border: 1px solid rgba(var(--cf-navy-rgb), 0.12);
  box-shadow: 0 8px 22px rgba(var(--cf-navy-rgb), 0.1);
}

.reader-risto-cell__thumb {
  aspect-ratio: 1;
  overflow: hidden;
  background: #eceff3;
}

.reader-risto-cell__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.reader-risto-cell__caption {
  padding: 0.65rem 0.75rem 0.78rem;
  text-align: center;
}

.reader-risto-cell__title {
  margin: 0 0 0.15rem;
  font-size: 0.94rem;
  font-weight: 900;
  color: var(--cf-navy);
}

.reader-risto-cell__sub {
  margin: 0;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--cf-navy);
  line-height: 1.35;
}

.reader-risto {
  max-width: 46rem;
  margin-inline: auto;
}

.reader-risto .reader-p {
  font-size: 0.93rem;
  font-weight: 700;
  color: var(--cf-navy);
  line-height: 1.55;
}

.reader-risto__venues {
  margin: 1rem 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(13.5rem, 1fr));
  gap: 0.55rem 1rem;
}

.reader-risto__venues li {
  position: relative;
  padding: 0.55rem 0.65rem 0.55rem 1.15rem;
  font-size: 0.86rem;
  font-weight: 700;
  color: var(--cf-navy);
  line-height: 1.35;
  background: rgba(255, 255, 255, 0.92);
  border-radius: 0.42rem;
  border: 1px solid rgba(var(--cf-navy-rgb), 0.13);
}

.reader-risto__venues li::before {
  content: '';
  position: absolute;
  left: 0.52rem;
  top: 0.85rem;
  width: 0.42rem;
  height: 0.42rem;
  border-radius: 50%;
  background: var(--cf-yellow);
}

.reader-main--grooming {
  background: #f7f8fa;
  background-image:
    linear-gradient(rgba(var(--cf-navy-rgb), 0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(var(--cf-navy-rgb), 0.05) 1px, transparent 1px);
  background-size: 20px 20px;
}

.reader-groom {
  display: grid;
  gap: 0.92rem;
  grid-template-columns: repeat(auto-fill, minmax(15rem, 1fr));
  margin-top: 0.5rem;
  max-width: 52rem;
  margin-inline: auto;
}

.reader-groom-card {
  padding: 0.92rem 1rem 1rem;
  border-radius: 0.5rem;
  background: var(--cf-white);
  border: 1px solid rgba(var(--cf-navy-rgb), 0.13);
  box-shadow:
    0 4px 14px rgba(var(--cf-navy-rgb), 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.reader-groom-card__title {
  margin: 0 0 0.62rem;
  font-size: 0.95rem;
  font-weight: 900;
  color: var(--cf-navy);
  padding-bottom: 0.4rem;
  border-bottom: 3px solid var(--cf-yellow);
}

.reader-groom-card__list {
  margin: 0;
  padding-left: 1.08rem;
  font-size: 0.84rem;
  font-weight: 600;
  line-height: 1.52;
  color: #273152;
}

.reader-groom-card__list li {
  margin-bottom: 0.4rem;
}

.reader-groom-card__list li:last-child {
  margin-bottom: 0;
}

.reader-main--contribute {
  background: #fafcfa;
}

.reader-main.reader-main--contrib-hero {
  padding: 0;
  overflow-x: hidden;
  overflow-y: visible;
  background: transparent;
  border: none;
  border-left: none;
  box-shadow: none;
}

.reader-contrib {
  position: relative;
  max-width: 48rem;
  margin-inline: auto;
}
.reader-contrib--hero {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  max-width: none;
  margin: 0;
  min-height: min(92vh, 880px);
  display: flex;
  flex-direction: column;
  border-radius: inherit;
}

.reader-contrib__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  border-radius: inherit;
  pointer-events: none;
}

.reader-contrib__bg-img {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  max-width: none;
  margin: 0;
  object-fit: cover;
  object-position: center 38%;
}

.reader-contrib__surface {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: clamp(1.75rem, 4vh, 2.85rem);
  align-items: center;
  padding: clamp(1.85rem, 5vw, 2.95rem) clamp(1rem, 4vw, 2rem)
    clamp(2rem, 5vw, 2.85rem);
  max-width: 56rem;
  margin-inline: auto;
  justify-content: space-between;
}

.reader-contrib--hero .reader-contrib__surface {
  min-height: min(92vh, 880px);
}

.reader-contrib-card--glass {
  width: min(22rem, 88vw);
  max-width: 22rem;
  margin: 0 auto;
  padding: clamp(0.92rem, 3.2vw, 1.28rem) clamp(1rem, 3.8vw, 1.42rem)
    clamp(1.02rem, 3.2vw, 1.22rem);
  border-radius: 2.75rem;
  background: rgba(255, 255, 255, 0.9);
  border: 2px solid rgba(255, 255, 255, 0.66);
  box-shadow:
    0 10px 42px rgba(0, 0, 0, 0.2),
    inset 0 1px 0 rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(10px);
}

.reader-contrib-card__heading {
  margin: 0 0 0.62rem;
  font-size: clamp(1.12rem, 3.25vw, 1.42rem);
  font-weight: 900;
  line-height: 1.28;
  color: var(--cf-navy);
  text-transform: capitalize;
}

.reader-contrib-card__txt--html {
  font-size: clamp(0.81rem, 2.2vw, 0.91rem);
  font-weight: 600;
  line-height: 1.55;
}

.reader-contrib-pill {
  display: flex;
  align-items: center;
  gap: 1rem;
  width: min(43rem, 100%);
  margin-top: auto;
  padding: 0.85rem clamp(1.1rem, 3vw, 1.85rem);
  border-radius: 9999px;
  background: var(--cf-yellow);
  border: solid 5px rgba(255, 255, 255, 0.96);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.2);
}

.reader-contrib-pill__icon {
  flex-shrink: 0;
  align-self: center;
  width: 48px;
  height: auto;
}

.reader-contrib-pill__icon-img {
  display: block;
  width: 52px;
  height: 52px;
  object-fit: contain;
}

.reader-contrib-pill__icon--svg {
  display: grid;
  place-items: center;
  width: 48px;
  height: auto;
  color: var(--cf-navy);
}

.reader-contrib-pill__body {
  flex: 1;
  min-width: 0;
}

.reader-contrib-pill__txt {
  margin: 0;
  font-size: clamp(0.84rem, 2.35vw, 0.93rem);
  font-weight: 600;
  line-height: 1.52;
  color: var(--cf-navy);
}

.reader-contrib-pill__txt a,
.reader-contrib-pill__a {
  font-weight: 800;
  color: var(--cf-navy);
  text-decoration: underline;
}

.reader-contrib--hero .reader-contrib-brand {
  align-self: flex-end;
  margin: 0.35rem 0 0 auto;
  padding-right: clamp(0.2rem, 1.8vw, 0.65rem);
  padding-bottom: clamp(0.15rem, 1.2vw, 0.5rem);
}

.reader-contrib--hero .reader-contrib-brand img {
  filter: drop-shadow(0 2px 6px rgba(0, 0, 0, 0.2));
  max-width: min(12rem, 55%);
  max-height: 3.35rem;
  width: auto;
}

.reader-contrib__grid {
  display: grid;
  gap: 0.82rem;
  grid-template-columns: repeat(auto-fill, minmax(14rem, 1fr));
  margin-top: 0.55rem;
}

.reader-contrib-card {
  padding: 0.95rem 0.92rem;
  border-radius: 0.52rem;
  background: linear-gradient(180deg, #fff 0%, #fafbff 100%);
  border: 1px solid rgba(var(--cf-navy-rgb), 0.12);
  box-shadow: 0 6px 22px rgba(var(--cf-navy-rgb), 0.08);
}

.reader-contrib-card__txt {
  margin: 0;
  font-size: 0.85rem;
  font-weight: 700;
  line-height: 1.52;
  color: var(--cf-navy);
}

.reader-contrib-card__txt--html strong {
  font-weight: 900;
}

.reader-contrib-security {
  margin-top: 1.15rem;
  padding: 1rem 1.05rem;
  border-radius: 0.45rem;
  border: 2px solid rgba(var(--cf-navy-rgb), 0.22);
  background: rgba(255, 255, 255, 0.95);
  border-left: 5px solid var(--cf-yellow);
}

.reader-contrib-security__lead {
  margin: 0 0 0.55rem;
  font-size: 0.86rem;
  font-weight: 700;
  line-height: 1.5;
  color: var(--cf-navy);
}

.reader-contrib-security__link {
  font-size: 0.86rem;
  font-weight: 800;
  color: #1a4b8c;
  text-decoration: underline;
  word-break: break-all;
}

.reader-contrib-security__link:hover {
  color: var(--cf-navy);
}

.reader-contrib-brand {
  margin: 1.35rem 0 0;
  text-align: right;
}

.reader-contrib-brand img {
  max-width: min(18rem, 88vw);
  height: auto;
  object-fit: contain;
}

/* Accoglienza p.15 (fond photo) : petits écrans — même principe que desktop (fond plein, contenu par-dessus) */
@media (max-width: 760px) {
  .reader-main.reader-main--contrib-hero {
    overflow-x: hidden;
    overflow-y: visible;
  }

  .reader-contrib--hero {
    min-height: min(100dvh, 900px);
    overflow: hidden;
  }

  .reader-contrib--hero .reader-contrib__surface {
    min-height: min(100dvh, 900px);
    box-sizing: border-box;
    justify-content: space-between;
    gap: clamp(1rem, 3vh, 1.75rem);
    padding: clamp(1.1rem, 4.5vw, 1.65rem) clamp(0.6rem, 3vw, 1rem)
      clamp(1.2rem, 4vw, 1.85rem);
  }

  .reader-contrib-card--glass {
    width: min(22rem, calc(100vw - 2.5rem));
    max-width: calc(100vw - 2.5rem);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    background: rgba(255, 255, 255, 0.96);
  }

  .reader-contrib-pill {
    flex-wrap: wrap;
    align-items: flex-start;
    width: 100%;
    max-width: 100%;
    margin-top: auto;
    border-radius: 1.05rem;
    padding: 0.72rem 0.88rem;
    box-sizing: border-box;
  }

  .reader-contrib-pill__body {
    flex: 1 1 10rem;
    min-width: 0;
  }

  .reader-contrib-pill__txt {
    overflow-wrap: anywhere;
  }

  .reader-contrib--hero .reader-contrib-brand img {
    max-width: min(11rem, 70vw);
  }
}

.reader-groom-board {
  display: grid;
  gap: 0.95rem;
  grid-template-columns: repeat(auto-fit, minmax(14.5rem, 1fr));
  margin-top: 0.65rem;
  max-width: 56rem;
  margin-inline: auto;
  align-items: stretch;
}

.reader-groom-col {
  display: flex;
  flex-direction: column;
  border-radius: 0.48rem;
  overflow: hidden;
  border: 1px solid rgba(var(--cf-navy-rgb), 0.14);
  background: var(--cf-white);
  box-shadow: 0 8px 24px rgba(var(--cf-navy-rgb), 0.11);
}

.reader-groom-col__head {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: 0.55rem;
  padding: 1rem 0.78rem 0.78rem;
  min-height: 0;
  text-align: center;
}

.reader-groom-col--yellow .reader-groom-col__head {
  background: var(--cf-yellow);
  color: var(--cf-navy);
}

.reader-groom-col--navy .reader-groom-col__head {
  background: var(--cf-navy);
  color: var(--cf-white);
}

.reader-groom-col__badge-slot {
  flex-shrink: 0;
  width: 5.25rem;
  height: 5.25rem;
  display: grid;
  place-items: center;
}

.reader-groom-col__badge {
  width: 100%;
  height: 100%;
  max-width: 5.25rem;
  max-height: 5.25rem;
  object-fit: contain;
}

.reader-groom-col--navy .reader-groom-col__badge-slot {
  border-radius: 0.4rem;
  border: 1px solid rgba(255, 255, 255, 0.35);
  background: rgba(0, 0, 0, 0.08);
  padding: 0.35rem;
  box-sizing: border-box;
}

.reader-groom-col--yellow .reader-groom-col__badge-slot {
  background: transparent;
}

.reader-groom-col__h {
  margin: 0;
  font-size: 0.91rem;
  font-weight: 900;
  line-height: 1.35;
  text-align: center;
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 0.2rem;
}

.reader-groom-col__body {
  padding: 0.78rem 0.85rem 0.95rem;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.reader-groom-col__list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.reader-groom-col__list li {
  display: flex;
  gap: 0.45rem;
  align-items: flex-start;
  margin-bottom: 0.45rem;
  font-size: 0.8rem;
  font-weight: 600;
  line-height: 1.48;
  color: #1e2845;
}

.reader-groom-col__list li:last-child {
  margin-bottom: 0;
}

.reader-groom-col__list--ok li {
  color: #1b5e20;
}

.reader-groom-col__list--no li {
  color: #b71c1c;
}

.reader-groom-mark {
  flex-shrink: 0;
  display: inline-grid;
  place-items: center;
  width: 1.15rem;
  height: 1.15rem;
  margin-top: 0.12em;
  font-size: 0.68rem;
  font-weight: 900;
  line-height: 1;
  border-radius: 2px;
}

.reader-groom-mark--ok {
  background: rgba(46, 125, 50, 0.15);
  color: #2e7d32;
}

.reader-groom-mark--no {
  background: rgba(198, 40, 40, 0.12);
  color: #c62828;
}
