/* ==========================
   Largeurs de conteneur personnalisées
   ========================== */

@media (min-width: 768px) {
  body > header,
  body > main,
  body > footer {
    max-width: 700px;
  }
}

@media (min-width: 1024px) {
  body > header,
  body > main,
  body > footer {
    max-width: 960px;
  }
}

@media (min-width: 1280px) {
  body > header,
  body > main,
  body > footer {
    max-width: 1024px;
  }
}

@media (min-width: 1536px) {
  body > header,
  body > main,
  body > footer {
    max-width: 1280px;
  }
}


/* ==========================
   Navigation & Liens
   ========================== */

a#theme-toggle.theme-toggle {
  text-decoration: none;
}

a.logo {
  padding: var(--pico-spacing) 0;
}

a.title {
  text-decoration: none;
}

.menu {
  display: flex;
}

.menu a {
  padding: var(--pico-spacing);
  text-decoration-line: none;
}

a,
.menu a:hover,
.menu a[aria-current] {
  color: inherit;
  text-decoration-line: underline;
  text-decoration-thickness: var(--pico-border-width);
  text-underline-offset: calc(var(--pico-spacing)/3);
  text-decoration-color: var(--pico-primary);
}

a:hover {
  text-decoration-color: var(--pico-secondary);
}


/* ==========================
   Boutons
   ========================== */

button,
[type="submit"],
[type="reset"],
[type="button"],
[type="file"]::file-selector-button,
[role="button"] {
  border-radius: var(--pico-border-button-radius);
}

a.button {
  border-radius: var(--pico-border-button-radius);
  border:solid var(--pico-primary) var(--pico-border-width);
  padding: calc(var(--pico-spacing)/2) var(--pico-spacing);
  text-decoration:none;
}
a.button:hover {
  background-color:var(--pico-primary);
  color:var(--pico-primary-inverse);
}


.breve a.button {
  border:solid var(--pico-primary-inverse) var(--pico-border-width);
  color:var(--pico-primary-inverse);
}

.breve a.button:hover {
  background-color:var(--pico-primary-inverse);
  border:solid var(--pico-primary) var(--pico-border-width);
  color:var(--pico-primary);
}
.button.small {
  padding: calc(var(--pico-form-element-spacing-vertical)/16) calc(var(--pico-form-element-spacing-horizontal)/2);
}

a.button.primary-inverse {
  padding: .4rem .75rem;
  border: var(--pico-border-width) solid var(--pico-primary-inverse);
  border-radius: var(--pico-border-button-radius);
  color: var(--pico-primary-inverse);
  text-decoration: none;
}

a.button.primary-inverse:hover {
  border-color: color-mix(in srgb, var(--pico-primary-inverse) 20%, transparent);
  color: color-mix(in srgb, var(--pico-primary-inverse) 20%, transparent);
}

nav li [role="button"] {
  padding: calc(var(--pico-nav-link-spacing-vertical) - var(--pico-border-width) * 2) calc(var(--pico-nav-link-spacing-horizontal)*2);
}

:is(button, [type="submit"], [type="button"], [role="button"]).outline, [type="reset"].outline {
  --pico-background-color: transparent;
  --pico-color: var(--pico-primary);
  --pico-border-color: var(--pico-primary);
}

/* ==========================
   Cards - Base
   ========================== */

article.card {
  border: var(--pico-border-width) solid var(--pico-primary);
  position: relative;
  overflow: hidden;
  border-radius: var(--pico-border-radius);
  box-shadow: var(--pico-box-shadow);
  width: 100%;
  height: 100%;
  margin: 0;
  display: block;
  padding: 0;
}

.card-link {
  text-decoration: none;
  display: block;
}

.card-link:hover {
  text-decoration: none;
  opacity: 1;
}


/* ==========================
   Cards - Overlay
   ========================== */

.card .overlay {
  position: absolute;
  inset: 0;
  background: color-mix(in srgb, var(--pico-primary) 90%, transparent);
  color: var(--pico-primary-inverse, #fff);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: var(--pico-spacing);
  border-radius: inherit;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.card:hover .overlay {
  opacity: 1;
}

.overlay h2 {
  color: var(--pico-primary-inverse);
}


/* ==========================
   Cards - Category
   ========================== */

article.card-category {
  aspect-ratio: 1 / 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 0;
  position: relative;
  overflow: hidden;
}

.card-category .card-content {
  padding: var(--pico-spacing);
}

.card-category .card-title {
  margin: 0;
}

.card-category .card-icon {
  margin: 0;
  padding: var(--pico-spacing);
  display: flex;
  align-items: flex-end;
  justify-content: center;
}

.card-category .card-icon svg {
  width: 100%;
  max-width: 75%;
  height: auto;
  color: var(--pico-primary);
  margin-bottom: -0.4rem;
}

/* Overlay pour card-category */
.card-category .overlay2 {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  background: color-mix(in srgb, var(--pico-primary) 90%, transparent);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
  padding: 0;
}

.card-category:hover .overlay2 {
  opacity: 1;
}

.card-category .overlay2 .card-content {
  padding: var(--pico-spacing);
}

.card-category .overlay2 .card-title {
  margin: 0;
  color: var(--pico-primary-inverse);
}

.card-category .overlay2 .card-icon {
  margin: 0;
  padding: var(--pico-spacing);
  display: flex;
  align-items: flex-end;
  justify-content: center;
}

.card-category .overlay2 svg {
  width: 100%;
  max-width: 75%;
  height: auto;
  color: var(--pico-primary-inverse);
}


/* ==========================
   Cards - Horizontal
   ========================== */

.card-horizontal {
  padding: 0;
  display: grid !important;
  grid-template-columns: 1fr;
  gap: 0;
}

/* Sur mobile, image en premier */
.card-horizontal__image {
  order: 1;
}

.card-horizontal__content {
  order: 2;
  padding: calc(var(--pico-spacing) * 2);
}

/* À partir de 768px, côte à côte avec texte à gauche */
@media (min-width: 48rem) {
  .card-horizontal {
    grid-template-columns: 1fr 2fr;
  }
  
  .card-horizontal__content {
    order: 1;
  }
  
  .card-horizontal__image {
    order: 2;
  }
}

.card-horizontal figure {
  margin: 0;
  height: 100%;
}

.info-card {
  padding: calc(var(--pico-spacing) * 2);
}


/* ==========================
   Cards - Article
   ========================== */

.card-article figure {
  margin: 0;
}

.card-article .overlay {
  background: color-mix(in srgb, var(--pico-primary) 90%, transparent);
}

.card-article:hover {
  color: var(--pico-primary-inverse);
}

.card-article:hover .tag.small {
  border-color: var(--pico-primary-inverse);
  color: var(--pico-primary-inverse);
}


/* ==========================
   Hero
   ========================== */

.hero.grid.column {
  margin-bottom: 0;
}

.hero-projet {
  height: auto;
  overflow: hidden;
}

.hero-projet .hero-image {
  height: auto;
}

.hero-projet .hero-image img {
  width: 100%;
  height: auto;
  object-fit: cover;
}

.hero-projet .hero-texte p {
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

@media (min-width: 1024px) {
  .hero-projet {
    height: auto;
  }
}


/* ==========================
   Hero Banner
   ========================== */

.hero-banner {
  position: relative;
  width: 100vw;
  margin-left: 50%;
  transform: translateX(-50%);
  min-height: 200px;
  display: flex;
  align-items: center;
  margin-bottom: 3rem;
  overflow: hidden;
}

.hero-banner__image {
  position: absolute;
  inset: 0;
  z-index: 1;
}

.hero-banner__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.hero-banner__overlay {
  position: relative;
  z-index: 2;
  width: 100%;
  padding: calc(var(--pico-spacing) * 2);
  background: color-mix(in srgb, var(--pico-primary) 90%, transparent);
}

.hero-banner__overlay h1, .hero-banner__overlay h2, .hero-banner__overlay h3, .hero-banner__overlay p,
.hero-banner__overlay .meta {
  color: var(--pico-primary-inverse);
}

.hero-banner__overlay h1 {
  margin-bottom: 0.5rem;
}

.hero-banner__overlay .tag {
  color: var(--pico-primary-inverse);
  border: solid var(--pico-primary-inverse) var(--pico-border-width);
}

@media (min-width: 60rem) {
  .hero-banner {
    min-height: 200px;
  }
}


/* ==========================
   Images
   ========================== */

.img {
  display: block;
  position: relative;
  aspect-ratio: var(--w) / var(--h);
  overflow: hidden;
}

.img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}


/* ==========================
   Listes
   ========================== */

li {
  list-style: none;
}

ul.wiki-list {padding : 0}

aside li {
  padding: 0;
}

/* ==========================
   Tags
   ========================== */

.tags {
  display: flex;
  flex-wrap: wrap;
 /* gap: calc(var(--pico-spacing)/1.5);*/
  padding: 0;
}

.tags li {
  list-style: none;
}

.tags a {
/*  padding: calc(var(--pico-nav-link-spacing-vertical) - var(--pico-border-width) * 2) calc(var(--pico-nav-link-spacing-horizontal)*2);
  border: var(--pico-border-width) solid var(--pico-color);
  border-radius: var(--pico-border-button-radius);*/
  text-decoration: none;
}

.tags a[aria-current="true"] {
  background: var(--pico-primary);
  color: var(--pico-primary-inverse);
}

a.tag.is-active {
  background: color-mix(in srgb, var(--pico-primary) 80%, transparent);
  color: var(--pico-primary-inverse);
}

.tag.small {
  padding: calc(var(--pico-spacing)/4) calc(var(--pico-spacing)/2);
  border: var(--pico-border-width) solid var(--pico-color);
/*  border-radius: var(--pico-border-button-radius); */
  font-size: .75rem;
  line-height: 1;
  margin: calc(var(--pico-spacing)/4) calc(var(--pico-spacing)/3);

}

.card-meta {
  display: flex;
  gap: calc(var(--pico-spacing)/2);
  align-items: center;
  font-size: .85rem;
  opacity: .9;
}


/* ==========================
   Blocs de contenu
   ========================== */

.intro {
  padding: var(--pico-spacing);
  background: color-mix(in srgb, var(--pico-primary) 25%, transparent);
  border-radius: var(--pico-border-radius);
}

.intro p {
  margin: 0;
  padding: 0;
}

.commentaire {
  padding: var(--pico-spacing);
  background: var(--pico-tertiary-50);
  border-radius: var(--pico-border-radius);
}

aside {
  border-left: var(--pico-border-width) var(--pico-primary-25) solid;
  padding: var(--pico-spacing);
}


/* ==========================
   Projets
   ========================== */

.projet .grid > .column {
  margin-bottom: 0;
}

.related-projects {
  padding: calc(var(--pico-spacing) * 2) 0;
}

.folio-project {
  padding: 0;
  border-radius: 0;
  background: none;
  box-shadow: none;
}

.folio-project header {
  padding: 0;
  border-radius: 0;
  background: none;
  box-shadow: none;
}


/* ==========================
   Breadcrumb
   ========================== */

.breadcrumb ul {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.4rem;
  list-style: none;
  padding: 0;
  margin: 0;
}

.breadcrumb li {
  position: relative;
  white-space: nowrap;
  padding: var(--pico-spacing) 0;
  display: flex;
  align-items: center;
}

.breadcrumb li::after {
  content: "/";
  margin: 0 0.15rem;
  opacity: 0.4;
}

.breadcrumb li:last-child::after {
  content: "";
}

.breadcrumb li.current {
  font-weight: 600;
}

.breadcrumb a {
  text-decoration: none;
  color: inherit;
}

.breadcrumb a:hover {
  text-decoration: underline;
}

.breadcrumb li.home::after {
  content: "/";
}

.breadcrumb i {
  vertical-align: .105em;
}


/* ==========================
   Icônes
   ========================== */

[class^="icon-"],
[class*=" icon-"] {
  vertical-align: -0.105em;
}

i#theme-icon {
  vertical-align: 0em;
}


/* ==========================
   SVG - Classes utilitaires
   ========================== */

.svg-primary-border {
  fill: none;
  stroke: var(--pico-primary);
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: calc(var(--pico-border-width)/2.85);
}

.svg-current-border {
  fill: none;
  stroke: currentcolor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: calc(var(--pico-border-width)/2.85);
}

.svg-primary-50-fill {
  fill: color-mix(in srgb, var(--pico-primary) 50%, transparent);
}

.svg-secondary-25-fill {
  fill: color-mix(in srgb, var(--pico-secondary) 25%, transparent);
}

.svg-secondary-current-fill {
  fill: currentcolor;
}

.svg-primary-fill {
  fill: var(--pico-primary);
}

.cls-0 {
  fill: none;
  stroke: currentcolor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: calc(var(--pico-border-width)*1.5);
}

.cls-1 {
  fill: none;
  stroke: currentcolor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: calc(var(--pico-border-width)/2.85);
}

.cls-2 {
  fill: var(--pico-primary-50);
}

.cls-3 {
  fill: var(--pico-secondary-25);
}

.cls-4 {
  fill: none;
  stroke: currentcolor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: calc(var(--pico-border-width)/3.5);
}

.cls-5 {
  fill: var(--pico-secondary);
}

.cls-6 {
  fill: currentcolor;
}


/* ==========================
   Divers
   ========================== */

hr {
  border: calc(var(--pico-border-width)/2) solid var(--pico-primary-25);
}

html {
  scroll-behavior: smooth;
}

figcaption {
  font-style: italic;
  font-family: var(--pico-font-family-serif);
}

figure {
  text-align: center;
}

/* ==========================
   Gestion des boutons de thème (desktop/mobile)
   ========================== */

/* Bouton de thème dans le menu desktop */
#theme-toggle-mobile {
  display: none;
}

.theme-toggle {
  color: var(--pico-color);
  cursor: pointer;
}

.theme-toggle i {
  display: block;
  color: currentColor;
}

.theme-toggle:hover {
  color: var(--pico-primary);
}

@media (max-width: 768px) {
  /* Masquer le bouton de thème du menu desktop en mobile */
  .menu #theme-toggle {
    display: none;
  }
  
  /* Afficher le bouton de thème dans la zone social en mobile */
  #theme-toggle-mobile {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--pico-spacing);
    text-decoration: none;
    color: var(--pico-color);
  }
  
  #theme-toggle-mobile:hover {
    color: var(--pico-primary);
  }
}


/* ==========================
   Menu Mobile Toggle
   ========================== */

#menu-toggle {
  display: none;
  padding: var(--pico-spacing);
  background: none;
  border: none;
  cursor: pointer;
  font-size: 1.5rem;
  color: var(--pico-color);
  margin: 0;
  line-height: 1;
}

#menu-toggle i {
  display: block;
  color: var(--pico-primary);
}

#menu-toggle:hover {
  color: var(--pico-primary);
}

#menu-toggle:focus {
  outline: var(--pico-outline-width) solid var(--pico-primary-focus);
  outline-offset: 0.25rem;
}

@media (max-width: 768px) {
  #menu-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
  }
  
  /* Masquer la navigation desktop en mobile */
  .header .menu {
    display: none !important;
  }
  
  /* Afficher la zone social avec les boutons utilitaires */
  .header .social {
    display: flex;
    align-items: center;
    gap: calc(var(--pico-spacing) / 2);
  }
  
  /* Menu mobile en overlay */
  #mobile-menu {
    display: none;
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: var(--pico-background-color);
    z-index: 999;
    padding: calc(var(--pico-spacing) * 3) calc(var(--pico-spacing) * 2);
    overflow-y: auto;
    animation: slideIn 0.3s ease;
  }
  
  #mobile-menu.is-active {
    display: block;
  }
  
  #mobile-menu nav {
    display: flex;
    flex-direction: column;
  }
  
  #mobile-menu ul {
    display: flex;
    flex-direction: column;
    margin: 0;
    padding: 0;
    list-style: none;
  }
  
  #mobile-menu li {
    width: 100%;
    padding: var(--pico-spacing) 0;
    border-bottom: var(--pico-border-width) solid var(--pico-muted-border-color);
  }
  
  #mobile-menu li:last-child {
    border-bottom: none;
  }
  
  #mobile-menu a {
    display: block;
    width: 100%;
    font-size: 1.2rem;
    padding: calc(var(--pico-spacing) / 2) 0;
  }
  
  @keyframes slideIn {
    from {
      opacity: 0;
      transform: translateY(-1rem);
    }
    to {
      opacity: 1;
      transform: translateY(0);
    }
  }
}

@media (min-width: 769px) {
  /* Afficher la nav desktop et masquer le menu mobile */
  .header .menu {
    display: flex !important;
  }
  
  #mobile-menu {
    display: none !important;
  }
  
  /* Masquer la zone social en desktop (le bouton thème est dans le menu) */
  .header .social {
    display: none;
  }
}


/* ==========================
   Bouton Retour en haut
   ========================== */

.back-to-top {
  position: fixed;
  bottom: calc(var(--pico-spacing) * 2);
  right: calc(var(--pico-spacing) * 2);
  width: 3rem;
  height: 3rem;
  border-radius: 50%;
  background: var(--pico-primary);
  color: var(--pico-primary-inverse);
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  box-shadow: 0 0.25rem 0.5rem rgba(0, 0, 0, 0.2);
  opacity: 0;
  visibility: hidden;
  transform: translateY(1rem);
  transition: opacity 0.3s ease, 
              visibility 0.3s ease, 
              transform 0.3s ease,
              background-color 0.2s ease;
  z-index: 998;
}

.back-to-top.is-visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.back-to-top:hover {
  background: var(--pico-primary-hover);
  transform: translateY(-0.2rem);
  box-shadow: 0 0.375rem 0.75rem rgba(0, 0, 0, 0.25);
}

.back-to-top:active {
  transform: translateY(0);
}

.back-to-top:focus {
  outline: var(--pico-outline-width) solid var(--pico-primary-focus);
  outline-offset: 0.25rem;
}

.back-to-top i {
  line-height: 1;
}

/* Adapter la position en mobile */
@media (max-width: 768px) {
  .back-to-top {
    bottom: var(--pico-spacing);
    right: var(--pico-spacing);
    width: 2.5rem;
    height: 2.5rem;
    font-size: 1.2rem;
  }
}

/* Ajuster si le menu mobile est ouvert */
#mobile-menu.is-active ~ .back-to-top {
  z-index: 1000;
}

/* ==========================
   Wiki Aside - Arborescence
   ========================== */

/* Toggle checkbox (caché) */
.wiki-toggle {
  display: none;
}

/* Label cliquable avec icône */
.wiki-toggle-label {
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.2rem;
  height: 1.2rem;
  flex-shrink: 0;
  transition: transform 0.2s ease;
}

/* Rotation de l'icône quand ouvert */
.wiki-toggle:checked + .wiki-toggle-label {
  transform: rotate(90deg);
}

/* Sous-liste (cachée par défaut) */
.wiki-sublist {
  display: none;
  margin-left: 1rem;
  margin-top: 0.5rem;
  padding-left: 0.5rem;
  border-left: 2px solid var(--pico-muted-border-color);
  width: 100%;
}

/* Afficher la sous-liste quand toggle activé */
.wiki-toggle:checked ~ .wiki-sublist {
  display: block;
}

/* ==========================
   Wiki Lists
   ========================== */

.wiki-list {
  list-style: none;
  padding: 0;
}

.wiki-list li {
  margin-bottom: 0.5rem;
}

/* Wrapper pour toggle + lien sur la même ligne */
.wiki-list > li > .wiki-toggle-label + a,
.wiki-list > li > a {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  text-decoration: none;
  vertical-align: middle;
}

/* S'assurer que toggle et lien sont côte à côte */
.wiki-list > li > .wiki-toggle-label {
  display: inline-flex;
  vertical-align: middle;
  margin-right: 0.25rem;
}

.wiki-list .icon {
  display: inline-flex;
  flex-shrink: 0;
}

.wiki-list .title {
  flex: 1;
  word-break: break-word;
  overflow-wrap: break-word;
}

/* Pour les fichiers : permettre le retour à la ligne */
.wiki-list .filename {
  word-break: break-word;
  overflow-wrap: break-word;
  hyphens: auto;
  max-width: 100%;

}

/* Item actif */
.wiki-list li.is-active > a {
  font-weight: 600;
  color: var(--pico-primary);
}

/* Extension de fichier */
.wiki-list .file-ext {
  opacity: 0.6;
  font-size: 0.85em;
  flex-shrink: 0;
}

.wiki-list li.download {
  padding: calc(var(--pico-spacing) / 2) var(--pico-spacing);
  border: var(--pico-border-width) solid currentcolor;
}
/* ==========================
   Wiki Aside Sections
   ========================== */

.wiki-tree,
.wiki-subpages,
.wiki-attachments {
  margin-bottom: var(--pico-spacing);
}

.wiki-subpages,
.wiki-attachments {
  margin-top: calc(var(--pico-spacing) * 2);
}
aside section:last-child {
  margin-bottom: 0;
}

.spip_logo {
  float: right;
  margin: 0 0 0;
  padding: 0;
  border: none;
}

/* ==========================
   TYPO
   ========================== */

.capitales {text-transform:uppercase;}

/* ==========================
   Blocs de couleurs
   ========================== */

.breve {background-color : var(--pico-primary);color:var(--pico-primary-inverse)}
.breve a, .breve p, .breve h1,.breve h2,.breve h3, .breve h4,.breve h5 {color:var(--pico-primary-inverse)}

/* ================================================
   Correctif PicoCSS × MediaBox (lity)
   PicoCSS cible <dialog> nativement et entre
   en conflit avec le <dialog> généré par lity.
   ================================================ */

dialog.lity {
  /* Réinitialiser le modèle de boîte PicoCSS */
  display: block !important;
  position: fixed !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  max-width: 100% !important;
  max-height: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  background: transparent !important;
  overflow: hidden !important;

  /* Z-index au-dessus de tout */
  z-index: 9999 !important;

  /* S'assurer que PicoCSS ne cache pas la boîte */
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;

  /* Désactiver le backdrop de PicoCSS (lity gère le sien) */
  &::backdrop {
    display: none !important;
  }
}

/* Restaurer le contenu interne de lity */
dialog.lity .lity-wrap {
  position: fixed !important;
  inset: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

dialog.lity .lity-container {
  position: relative !important;
  margin: auto !important;
}

/* ==========================
   Styles du journal
   ========================== */

article.journal {
  box-shadow:none;
  border-bottom: var(--pico-border-width) solid var(--pico-primary-25);
}

.pagination-items {margin-top : var(--pico-spacing);}
/* li.pagination-item {margin: 0 var(--pico-spacing); border:solid var(--pico-border-width) var(--pico-primary);padding: calc(var(--pico-spacing)/2) var(--pico-spacing)}