    :root{
      --header-height: 112px;
      --accent: #006633;
      --max-width: 1100px;
      --bg-opacity: 0.3;
      font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial;
    }

    *{box-sizing: border-box}
    html,body{height:100%;margin:0}

    body{
      min-height:100%;
      background:#fff url('images/header-noroitex.png') center center / cover no-repeat fixed;
      color:#111;
      line-height:1.45;
      -webkit-font-smoothing:antialiased;
      -moz-osx-font-smoothing:grayscale;
      position:relative;
    }

    body::before{
      content:"";
      position:fixed;
      inset:0;
      background:rgba(255,255,255,var(--bg-opacity));
      z-index:-1;
    }

    header{
      position:fixed;
      top:0;left:0;right:0;
      height:var(--header-height);
      display:flex;
      align-items:center;
      justify-content:center;
      padding:0 24px;
      z-index:40;
      backdrop-filter: blur(6px);
      background: rgba(255,255,255,0.9);
      border-bottom: 1px solid #ddd;
      color:#111;
    }

    .header-inner{
      width:100%;
      max-width:var(--max-width);
      display:flex;
      gap:28px;
      align-items:center;
    }

    .logo{
      display:flex;align-items:center;gap:14px;flex:0 0 auto;
      text-decoration:none;color:inherit
    }
    .logo img{height:80px;width:auto;display:block}
    .logo .brand{font-weight:700;font-size:1.35rem}

    /* Menu déroulant */
    nav{
      margin-left:16px;
      display:flex;gap:24px;flex:1 1 auto;justify-content:center;
    }
    nav ul{list-style:none;margin:0;padding:0;display:flex;gap:24px}
    nav li{position:relative}
    nav a{
      text-decoration:none;color:inherit;padding:12px 14px;border-radius:10px;font-weight:600;font-size:1.05rem;display:flex;align-items:center;gap:6px
    }
    nav a:hover{background:#f3f4f6}

    /* flèche indicateur */
    .has-submenu > a::after{
      content:"▾";
      font-size:0.75rem;
      transition: transform 0.25s ease;
    }
    .has-submenu:hover > a::after{
      transform: rotate(180deg);
    }

    /* sous-menu avec animation */
    nav ul ul{
      position:absolute;left:0;top:100%;
      background:#fff;
      box-shadow:0 4px 8px rgba(0,0,0,0.1);
      border-radius:8px; 
      min-width:180px;
      flex-direction:column;
      padding:8px 0;

      opacity:0;
      transform: translateY(10px);
      pointer-events:none;
      transition: opacity 0.25s ease, transform 0.25s ease;
    }
    nav ul ul li{width:100%}
    nav ul ul a{padding:0px 0px;font-weight:500;font-size:0.95rem}
    nav ul li:hover > ul{
      opacity:1;
      transform: translateY(0);
      pointer-events:auto;
    }

    .contact{
      /*display:flex;align-items:center;gap:16px;flex:0 0 auto;font-size:1rem;color:#111*/
      display:flex;
      flex-direction:column;
      align-items:flex-end;
      justify-content:center;
      gap:6px;
      flex:0 0 auto;
      font-size:1rem;
      color:#111;
    }
    .contact .phone{font-weight:600;font-size:1.1rem}
    .contact small{display:block;opacity:0.8;font-size:0.9rem}

    .cta{
      background:var(--accent);color:#fff;padding:10px 14px;border-radius:10px;font-weight:700;text-decoration:none;margin-left:8px;font-size:1rem
    }

    main{
      position:relative;z-index:10;padding: calc(var(--header-height) + 28px) 24px 80px;
      min-height: calc(100vh - var(--header-height));
      display:flex;justify-content:center;align-items:flex-start;
      color:#111;
    }

    .container{width:100%;max-width:var(--max-width)}
    .hero-card{background:#fff;border-radius:14px;padding:40px;box-shadow:0 4px 14px rgba(0,0,0,0.1)}

    h1{margin:0 0 24px; font-family: 'Garamond';font-size:2rem;color:#D21034; font-variant-caps: all-small-caps;text-align: center}
    h2{margin:0 0 12px; font-family: 'Garamond';font-size:1.6rem;color:#006633;text-align: left}
    h3{margin:0}
    p.lead{margin:0 0 22px;opacity:0.95;font-size:1.1rem}
    .h1italic{font-variant-caps:normal; font-style:italic}

    .features{display:grid;grid-template-columns:repeat(auto-fit,minmax(480px,1fr));gap:20px;margin-top:0px}
    .feature{background:#f9fafb;padding:16px;border-radius:12px}

    /* Responsive */
    .menu-toggle{display:none;cursor:pointer}
    @media (max-width:840px){
      nav{display:none}
      .menu-toggle{display:inline-flex;align-items:center;gap:8px;border-radius:10px;padding:10px;background:#f3f4f6;color:#111;font-size:1rem}
      .contact .phone{display:none}
    }

    .mobile-nav{
      max-height:0;
      overflow:hidden;
      opacity:0;
      transform: translateY(-10px);
      transition: max-height 0.3s ease, opacity 0.3s ease, transform 0.3s ease, padding 0.3s ease;

      position:fixed;left:12px;right:12px;top:calc(var(--header-height) + 12px);z-index:45;background:#fff;box-shadow:0 4px 10px rgba(0,0,0,0.1);padding:0;border-radius:12px;color:#111
    }
    .mobile-nav a{display:block;padding:12px 16px;border-radius:10px;color:#111;font-size:1rem}
    .mobile-nav.show{
      max-height:440px;
      opacity:1;
      transform: translateY(0);
      padding:14px;
    }

    .close-btn{
      display:none;
      position:absolute;top:10px;right:14px;
      font-size:1.5rem;
      background:none;
      border:none;
      cursor:pointer;
      color:#111;
    }
    .mobile-nav.show .close-btn{display:block}

	.selectedNav{
    // color:#D21034;
    // text-decoration: underline;
    background-color:lightgray;
	}

    footer{color:#555;margin-top:20px;font-size:0.95rem}

/* Styles basiques pour le bandeau cookies */
#cookie-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: #222;
  color: #fff;
  padding: 15px;
  font-size: 14px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  z-index: 9999;
  gap: 10px;
  flex-wrap: wrap;
}
#cookie-banner .text {
  flex: 1;
}
#cookie-banner a {
  color: #4CAF50;
  text-decoration: underline;
}
#cookie-banner .buttons {
  display: flex;
  gap: 10px;
}
#cookie-banner button {
  border: none;
  padding: 8px 15px;
  border-radius: 5px;
  cursor: pointer;
  font-size: 14px;
}
#accept-cookies {
  background: #4CAF50;
  color: #fff;
}
#accept-cookies:hover {
  background: #45a049;
}
#reject-cookies {
  background: #888;
  color: #fff;
}
#reject-cookies:hover {
  background: #666;
}

.gauche-droite {
      width: 100%;              /* prend toute la largeur */
      display: flex;            /* active Flexbox */
      justify-content: space-between; /* espace entre les deux éléments */
      align-items: center;      /* alignement vertical au centre */
      padding: 10px 20px;
      font-family: Arial, sans-serif;
    }

.gauche {
      text-align: left;
    }

.droite {
      text-align: right;
    }

#versions {
  width: 80%;
  padding-left: 5px;
  background: #ddd;
}

#register-form, #login-form, #upload-form
{
    width: 100%;
    border: 1px solid black;
}

#register-form button, #login-form button, #upload-form button
 {
	margin-left: 100px;
    width:20%;
    display:inline-block
}

#register-form select, #login-form select, #upload-form select
 {
    width:30%;
    display:inline-block
}

#register-form label, #login-form label, #upload-form label
{
    width:600px;
    text-align: right;
    display:inline-block;
    margin-bottom: 5px;
}

#register-form span, #login-form span, #upload-form span
{
    width:200px;
    text-align: right;
    display:inline-block
}


/* ===== Style Global Harmonisé ===== */

.nfeature {
  border: 1px solid #006633;
  margin-bottom: 10px;
  padding: 10px;
  display: flex;
  gap: 15px;
  align-items: flex-start;
  max-width: 100%;
  background: #f9fdf9; /* très léger fond pour respiration */
}

.styleRouge {
  border: 1px solid #FF0000;
  background: #ffd5d5; /* très léger fond pour respiration */
}

/* Image à gauche */
.nfeature img {
  border: 3px solid #006633;
  width: 250px;
  max-width: 250px;
  flex-shrink: 0;
  border-radius: 4px;
}

.nfeature img .icone20 {
  width: 20px;
  max-width: 20px;
}

.iconeh20 {
  height: 20px;
  max-width: 20px;
}

.icone10 {
  height: 10px;
  max-width: 10px;
}

.nfeature img .icone16 {
  width: 16px;
  max-width: 16px;
}

/* Zone contenu */
.nfeature .content {
  flex: 1;
  overflow-wrap: break-word;
}

/* Boutons / liens */
.nfeature a {
  color: #006633;
  text-decoration: none;
  font-weight: 500;
}

.nfeature a:hover {
  text-decoration: underline;
  color: #00994d; /* Vert plus clair au hover */
}

/* Encadré historique */
.nfeature details {
  border: 1px solid #ddd;
  background: #ffffff;
  padding: 8px 10px;
  border-radius: 4px;
  margin-top: 8px;
}

.nfeature details summary {
  cursor: pointer;
  color: #006633;
  font-weight: bold;
}

.nfeature ul {
  margin: 8px 0;
  padding-left: 18px;
}

.nfeature li {
  padding: 3px 0;
  border-bottom: 1px dashed #ccc;
}

.nfeature li:last-child {
  border-bottom: none;
}

/* Responsive mobile */
@media (max-width: 600px) {
  .nfeature {
    flex-direction: column;
    text-align: center;
  }

  .nfeature img {
    margin: 0 auto 10px !important;
  }
}

/* === Badge Statut === */
.badgeJaune {
  display: inline-block;
  background: #fff7cc; /* jaune très léger */
  border: 1px solid #e6c200;
  padding: 8px 8px 8px 8px;
  border-radius: 4px;
  font-weight: bold;
  color: #6b5d00;
  font-size: 16px;
  /*width: 300px;*/
  max-width: 100%;
  display: flex;
  gap: 15px;
  align-items: flex-start;
}

.badgeBlanc {
  display: inline-block;
  background: #ffffff; /* blanc */
  border: 1px solid #dddddd;
  padding: 8px 8px 8px 8px;
  border-radius: 4px;
  /*font-weight: bold;*/
  color: #000000;
  font-size: 16px;
  /*width: 300px;*/
  max-width: 100%;
  display: flex;
  gap: 15px;
  align-items: flex-start;
}

.badgeVert {
  display: inline-block;
  background: #ffffff; /* jaune très léger */
  border: 1px solid #006633;
  padding: 2px 8px;
  border-radius: 4px;
  font-weight: bold;
  color: #6b5d00;
}

.badgeRouge {
  display: inline-block;
  background: #FFAAAA; /* rouge très léger */
  border: 1px solid #660000;
  padding: 2px 8px;
  border-radius: 4px;
  font-weight: bold;
  color: #000000;
}

.badgeGris {
  display: inline-block;
  background: #f0f0f0; /* gris léger */
  border: 1px solid #333333;
  padding: 2px 8px;
  border-radius: 4px;
  font-weight: normal;
  color: #000000;
  font-size: 14px;
}

.badgeRouge {
  display: inline-block;
  background: #FFAAAA; /* rouge très léger */
  border: 1px solid #660000;
  padding: 2px 8px;
  border-radius: 4px;
  font-weight: bold;
  color: #000000;
}

.badgePadding {
  padding-bottom: 8px;
}

/* === Animation d'ouverture du <details> === */
.nfeature details {
  transition: all 0.3s ease;
  overflow: hidden;
}

.nfeature details[open] {
  animation: slideDown 0.3s ease forwards;
}

@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-5px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* === Désactivation d'un manuscrit terminé === */
.disable {
  /* Note: pointer-events not supported by IE10 and under */
  pointer-events: none;
  opacity: 0.2;
}

/* Disable scrolling on child elements */
.disable div,
.disable textarea {
  overflow: hidden;
}

textarea {
    vertical-align: top;
}

/* === Buttons === */
.stepButton {
	width: 250px;
}