/* style.css - Styles unifiés pour le frontend public */

* { margin:0; padding:0; box-sizing:border-box;}
a {text-decoration:none; color:inherit;}

.aligncenter      {align-items:center;}
.alignstart       {align-items:start;}
.block            {display:block;}
.borderwhite, .border1, .border2 , .border3 {border-width:1px; border-style:solid;}
.center           {text-align:center;}
.clear            {clear:both;}
.displaynone      {display:none;}
.flex             {display:flex;}
.flexstart        {align-items:flex-start;}
.flexend          {align-items:flex-end;}
.flexcolumn       {flex-direction:column;}
.floatright       {float:right;}
.floatleft        {float:left;}
.gap              {gap:clamp(15px, 3vw, 40px);}
.gap10            {gap:10px;}
.gap20            {gap:20px;}
.gap30            {gap:30px;}
.gap40            {gap:40px;}
.grid             {display:grid;}
.img              {width:100%; height:auto; display:block;}
.italic           {font-style:italic;}
.justify          {text-align:justify;}
.justifyspacebtw  {justify-content:space-between;}
.justifycenter    {justify-content:center;}
.justifyend       {justify-content:end;}
.lineheight       {line-height:clamp(1.4em, 4vw, 1.6em);}
.luminosity       {mix-blend-mode:luminosity;}
.martop0          {margin-top:0;}
.martom           {margin-bottom:clamp(15px, 3vw, 30px);}
.martom10         {margin-bottom:10px;}
.martom20         {margin-bottom:20px;}
.martom30         {margin-bottom:30px;}
.martom40         {margin-bottom:40px;}
.marginauto       {margin:auto;}
.margin0          {margin:0;}
.marginright20    {margin-right:20px;}
.max300           {max-width:300px;}
.maxsize          {width:100%; max-width:1330px; padding:0 clamp(10px, 4vw, 30px);}
.minsize          {width:100%; max-width:1158px; padding:0 clamp(10px, 4vw, 30px);}
.nospace          {white-space:nowrap;}
.overden          {overflow:hidden;}
.padding0         {padding:0;}
.padding          {padding:clamp(10px, 3vw, 20px) clamp(15px, 3vw, 20px);}
.paddingtop0      {padding-top:0;}
.padding10        {padding:10px;}
.padding20        {padding:20px;}
.padding30        {padding:30px;}
.paddingright20   {padding-right:20px;}
.radius           {border-radius:clamp(6px, 3vw, 12px);}
.radius8          {border-radius:8px;}
.radius12         {border-radius:12px;}
.radius16         {border-radius:16px;}
.relative         {position:relative;}
.shadow           {box-shadow:0 8px 30px rgba(0, 0, 0, 0.12);}
.strong           {font-weight:600;}
.text             {font-size:clamp(1em, 3vw, 1.2em);}
.textindent10     {text-indent:10px;}
.textindent15     {text-indent:15px;}
.textindent20     {text-indent:20px;}
.underline        {text-decoration:underline;}
.uppercase        {text-transform:uppercase;}
.width100         {width:100%;}
.width75          {width:75%;}
.width50          {width:50%;}
.width33          {width:33%;}
.width25          {width:25%;}
.wrap             {flex-wrap:wrap;}

.mob              {display:none;}

.zoom {z-index:10; -webkit-transition:all .5s ease-out; -moz-transition:all .5s ease-out; -o-transition:all .5s ease-out; transition:all .5s ease-out; -webkit-backface-visibility:hidden; -webkit-perspective:1000;}
.zoom:hover {-moz-transform:scale(1.1); -webkit-transform:scale(1.1); -o-transform:scale(1.1); transform:scale(1.1); -ms-transform:scale(1.1); filter:progid:DXImageTransform.Microsoft.Matrix(sizingMethod='auto expand', M11=2, M12=-0, M21=0, M22=2);}


.blink {animation:blink-animation 1s steps(1) infinite;}
@keyframes blink-animation {
    0%, 50% { visibility:visible; }
    50.1%, 100% { visibility:hidden; }
}



  /*******************************/
 /* === CONTENUS PRINCIPAUX === */
/*******************************/

body {font-family:var(--primary-font), sans-serif; font-weight:var(--font-weight); letter-spacing:0.2px; font-size:var(--font-size);}
h1 {font-size:clamp(1.7em, 4vw, 3em); line-height:clamp(1em, 5vw, 1.5em); font-weight:600; font-family:var(--primary-font);}
h2 {font-size:clamp(1.2em, 2vw, 1.5em); font-weight:500; font-family:var(--secondary-font); display:flex;}
h3, h4 {font-size:clamp(1.1em, 2vw, 1.3em); font-weight:500;}
/*h1, h2 {margin-bottom:clamp(15px, 3vw, 30px);}*/

#wrapper {}
.wrapper {height: 100vh;}

.toggle-checkbox {display:none;}
.menu-button {position:absolute; top:12px; left:20px; transform:translateX(250px); z-index:10; width:36px; height:36px; display:flex; align-items:center; justify-content:center; cursor:pointer; transition:all 0.6s ease; padding:8px; border-radius:50%;}

/* Icone du burger */
.menu-icon {position:relative; width:100%; height:3px; background:transparent;}
.menu-icon::before, .menu-icon::after {content:''; position:absolute; width:100%; height:3px; background-color:var(--white); transition:all 0.6s ease;}
.menu-icon::before {top:-8px;}
.menu-icon {transition:opacity 0.6s ease;}
.menu-icon::after {bottom:-8px;}

/* Animation du burger pour l'état fermé */
.toggle-checkbox:not(:checked) ~ .menu-button .menu-icon::before {transform:rotate(0deg); top:-8px;}
.toggle-checkbox:not(:checked) ~ .menu-button .menu-icon::after {transform:rotate(0deg); bottom:-8px;}
.toggle-checkbox:not(:checked) ~ .menu-button .menu-icon {background-color:var(--white);}

/* Animation du burger pour l'état ouvert */
.toggle-checkbox:checked ~ .menu-button .menu-icon::before {transform:rotate(45deg); top:0; background-color:var(--white);}
.toggle-checkbox:checked ~ .menu-button .menu-icon::after {transform:rotate(-45deg); bottom:0; background-color:var(--white);}
.toggle-checkbox:checked ~ .menu-button .menu-icon {background:transparent;}

/* État :menu ouvert */
.toggle-checkbox:checked ~ .menu-sidebar {width:250px; min-width:250px;}
.toggle-checkbox:checked ~ .menu-sidebar .menu-content {transform:translateX(0);}
.toggle-checkbox:checked ~ .content {margin:0;}
.toggle-checkbox:checked ~ .menu-button {left:102px; transform:translateX(10px);}

/* État :menu fermé */
.toggle-checkbox:not(:checked) ~ .menu-sidebar {width:0; min-width:0; box-shadow:none;}
.toggle-checkbox:not(:checked) ~ .menu-sidebar .menu-content {transform:translateX(-500px);}
.toggle-checkbox:not(:checked) ~ .content {margin-left:0;}
.toggle-checkbox:not(:checked) ~ .menu-button {left:10px; transform:translateX(10px);}

/* Colonne menu */
.menu-sidebar {/*height:100vh;*/ overflow:hidden; box-shadow:2px 0 5px rgba(0, 0, 0, 0.5); position:relative; overflow-y:auto; scrollbar-width:none; transition:all 0.6s ease;}
.menu-content {position:relative; transform:translateX(-250px); transition:transform 0.6s ease; padding:60px 20px 20px; margin:auto; display:flex; flex-direction:column; gap:20px;}

nav {/*flex-grow:1; flex-basis:300px;*/}
nav a {text-decoration:none; transform:translatex(0); transition:transform 0.4s ease-in-out; font-size:1.2em; color:#c3d0d8;}
nav a::before {content:""; height:2px; background:#f5f5f5; width:100%; position:absolute; bottom:-2px; left:0; transform:translatex(-50%); opacity:0; transition:transform 0.4s ease-in-out, opacity 0.4s linear;}
nav a:hover::before {transform:translatex(0);  opacity:1;}
nav ul {list-style:none; padding:0; display:flex; flex-direction:column; gap:15px;}
nav li {display:flex; align-items:center; gap:10px; cursor:pointer; font-size: 0.8em; letter-spacing: 0.5px;}

.icon {width:27px; height:27px; min-width:27px; border-radius:50%; position:relative; cursor:pointer; transition:transform 0.3s ease;}
.icon::before, .icon::after {content:""; position:absolute;  width:18px; height:4px; top:50%; left:50%; transform:translate(-50%, -50%) rotate(135deg); transition:transform 0.3s ease;}
.icon::after {transform:translate(-50%, -50%) rotate(45deg);}
.menu li:hover .icon::before, .menu li:active .icon::before {transform:translate(-50%, -50%) rotate(0deg);}
.menu li:hover .icon::after, .menu li:active .icon::after {transform:translate(-50%, -50%) rotate(-90deg);}

.container {margin:0 auto;}
.content {flex:1; transition:margin-left 0.6s ease; width:100%; min-width:320px; overflow-y:auto; /*height:100vh; scrollbar-width:none;*/}

main {}

  /*************************/
 /* === HEADER COMMUN === */
/*************************/

.header-logo {display: flex; flex-direction: column; justify-content: center; align-items: flex-start; padding:20px 0 10px;}
.header-content {}
.stats {font-size:0.9rem;}
.nav-header a {padding:3px 10px; border-radius:6px; transition:all 0.3s;}
.page-header {margin:0 auto 30px;}
.page-header-bloc {}
.page-header-bloc h1 {font-size: clamp(1.3em, 4vw, 1.7em); margin: 0 0 0 10px; font-weight: 400;}

/* #### TOGGLE CSS ### */

input[type="checkbox"] {display:none;}

/* Variante fermée par défaut (desktop + mobile) */
.toggleable_closed .toggleable_content {max-height:0; overflow:hidden; transition:max-height .8s cubic-bezier(0,1,0,1);}
.toggleable_closed .toggleable_control:checked ~ .toggleable_content {max-height:3000px; transition-timing-function:ease-in-out;}
.toggleable_closed .toggleable_label::after {content:"OUVRIR ▼";}
.toggleable_closed .toggleable_control:checked ~ .toggleable_label::after {content:"FERMER ▲";}

.toggleable_content {max-height:3000px; display:flex; flex-direction:column; gap:20px; overflow:hidden; transition:max-height .8s cubic-bezier(1,0,1,0)}
.toggleable_control:checked ~ .toggleable_content {transition-timing-function:ease-in-out; max-height:0px;}
.toggleable_label {width:100%; transition:width .8s; display:flex; justify-content:space-between; align-items:center; gap:15px; cursor:pointer; position:relative; z-index:10; margin:auto;}
.toggleable_control:checked ~ .toggleable_label {transition-timing-function:ease-in-out; width:95%;}
.toggleable_label::after {content:"FERMER ▲"; font-size:0.8rem; padding:9px 11px 10px 14px; border-radius:6px; white-space:nowrap;}
.toggleable_control:checked ~ .toggleable_label::after {content:"OUVRIR ▼";}
.site-description {}

/* Styles pour les boutons de filtrage par type de contenu*/
.content-filter-btn-index .count {font-size:0.8em;}

  /**********************/
 /* === BREADCRUMB === */
/**********************/
.breadcrumb {}
.breadcrumb a {transition:all 0.3s;}
.breadcrumb a:hover {border-radius: 6px; padding: 2px 6px;}
.breadcrumb-separator {margin:0 8px;}
.breadcrumb-current {}


  /***************************/
 /* === Dropdowns perso === */
/***************************/
.filters-controls {}
.dropdown {position:relative;}
.dropdown-toggle {display:inline-block; padding:10px; font-weight:600; text-align:left; white-space:nowrap; cursor:pointer; border:none; border-radius:8px; user-select:none; min-width:180px; transition:all 0.15s ease-in-out;}
span.selected-text.widgetcatimg {}
.dropdown-toggle:hover, .dropdown-toggle:focus {text-decoration:none; outline:0;}
.dropdown-toggle.active, .dropdown.open .dropdown-toggle {outline:0;}
.dropdown-menu {position:absolute; list-style:none; z-index:1000; display:none;  min-width:100%; margin:5px 0 0; border-radius:8px; box-shadow:0 6px 12px rgba(0, 0, 0, 0.175); background-clip:padding-box;}
.dropdown.open .dropdown-menu {display:block;}
.dropdown-menu li button {display:block; width:100%; padding:8px 0 8px 10px; clear:both; white-space:nowrap; cursor:pointer; border:none; background:none; text-align:left; border-radius:4px; margin:5px 0px 5px 10px; transition:all 0.2s ease;}
.dropdown-menu li button a {text-decoration:none; color:inherit;}
.dropdown-menu li button:hover, .dropdown-menu li button:focus {outline:none;}
.caret {border-top:4px dashed; border-right:4px solid transparent; border-left:4px solid transparent; float:right; margin-top:6px; transition:transform 0.3s ease;}
.dropdown.open .caret {transform:rotate(180deg);}


  /***************************/
 /* === GALERIE MASONRY === */
/***************************/
#gallery {width:100%; margin:0 auto 40px; transition:height 180ms ease; position:relative;}
.gallery {}
.image-card, .ad-card { border-radius:12px 12px 4px 4px; overflow:hidden; /*break-inside:avoid; transition:all 0.3s ease;*/ cursor:pointer;}
.ad-card {}
.ad-content {width:100%; align-items:center; flex-direction:column; justify-content:flex-start; min-height:80px;}
.ad-content img {width:100%; height:auto;}
.image-card:hover {}
.ad-card:hover {}
.gallery-item {position:absolute; transition:transform 280ms cubic-bezier(.22,.61,.36,1), opacity 220ms ease; will-change:transform, opacity;}
.image-wrapper {width:100%; display:block; overflow:hidden;}
.image-wrapper img {display:block; width:100%; height:auto; transform:translateZ(0); transition: transform 0.3s ease;}
.image-wrapper img:hover {transform: scale(1.1);}
.image-info {padding:10px 12px;}
.image-title {margin: 0 0 10px;}
.image-description {line-height: 1.2; font-size: 0.9em; text-align: justify; display: -webkit-box; -webkit-line-clamp: 8; -webkit-box-orient: vertical; overflow: hidden; text-overflow: ellipsis;}
.image-date {font-size:12px; color:#888; display:none;}
/*.ad-card::before {content:"Publicité"; position:absolute; top:5px; right:8px; background:rgba(0, 0, 0, 0.1); color:#eee; font-size:10px; padding:2px 6px; border-radius:3px; text-transform:uppercase; letter-spacing:0.5px; z-index:10;}*/

/* === Respect des préférences d’animations réduites === */
@media (prefers-reduced-motion:reduce) {
  #gallery.gallery { transition:none; }
  .gallery-item { transition:none !important; }
  .loading .spinner { animation:none; }
}

/* === États (loading / vide / erreur) === */
.empty-state, .error-message {width:100%; text-align:center; color:#ccc; padding:24px 12px;}
.empty-state .empty-icon { font-size:40px; margin-bottom:8px; }
.error-message { color:#ff6b6b; }
.error-message strong { color:#ff8a8a; }

/* === Spinner === */
.loading .spinner {--size:28px; --border:3px; display:inline-block; width:var(--size); height:var(--size); border:var(--border) solid rgba(255,255,255,0.15); border-top-color:rgba(255,255,255,0.9); border-radius:50%; animation:spin 0.9s linear infinite; margin-bottom:10px;}
@keyframes spin { to { transform:rotate(360deg); } }

/* === États === */
#loading { display:none; }
#emptyState { display:none; color:#aaa; text-align:center; padding:40px 0; }
#errorState { display:none; color:#f66; text-align:center; padding:20px 0; }

/* === Erreurs === */
.error-message {background:#fee; color:#c33; padding:15px; border-radius:8px; margin:20px; text-align:center; border-left:4px solid #c33;}
.error-state {text-align:center; padding:80px 20px; color:#666;}
.error-icon {font-size:4rem; margin-bottom:20px; opacity:0.3;}

/* === OVERLAY INFINITE SCROLL === */
.load-more-overlay {position:fixed; bottom:20px; right:20px; background:rgba(33, 150, 243, 0.9); color:var(--white); padding:10px 20px; border-radius:25px; font-size:0.9rem; font-weight:600; display:none; align-items:center; gap:10px; z-index:200;}
.load-more-overlay .mini-spinner {border:2px solid rgba(255,255,255,0.3); border-top:2px solid white; border-radius:50%; width:16px; height:16px; animation:spin 1s linear infinite;}

.gallery-pagination {display:flex; justify-content:center; align-items:center; gap:10px; margin:0 0 20px; padding:0 10px 20px; flex-wrap:wrap;}
.pagination-btn.active {cursor:default;}
.pagination-btn {min-width:40px; height:40px; padding:0 12px; border-radius:8px; cursor:pointer; transition:all 0.2s;}
.pagination-btn:disabled {opacity:0.5; cursor:not-allowed;}
.pagination-dots {padding:0 8px; font-weight:bold;}


  /*********************/
 /* === image.php === */
/*********************/
.container-image {margin:0 auto 20px; padding:0 10px;}
.image-detail {grid-template-columns:1fr auto;}
.image-description-detail {flex-grow:1; -webkit-line-clamp:unset;}
.image-description-detail p {text-align:justify; margin-bottom:var(--martom);}
.image-description-detail p:last-of-type {margin-bottom:0;}
.image-description-detail ul {list-style:disc; margin-block-start:1em; margin-block-end:1em; padding-inline-start:40px;}
.vignette-video, .vignette-blog {width:100%; max-width:330px; margin:0 30px 10px 0;}
.image-section h1 {margin-bottom:0;}
.main-image {height:auto; box-shadow:0 4px 15px rgba(0,0,0,0.1); transition:transform 0.3s ease;}
.main-image:hover {transform:scale(1.02);}
video {width:100%; border-radius:8px;}
.info-section {width:300px; align-items:center; position:sticky; top:10px;}

/* Tags dans image.php */
.tags-container {}
.tag-link {display:inline-block; padding:10px 15px; text-decoration:none; border-radius:8px; font-size:12px; transition:all 0.2s;}
.tag-link:hover {transform:translateY(-2px);}

/* === Pubs générales image === */
.pub1 img, .pub2 img, .pub3 img, .pub4 img {height:auto; width:100%; display:block;}

/* === Pub dans le player === */
@keyframes fadeInScale {
  from { opacity:0; transform:scale(0.9); }
  to { opacity:1; transform:scale(1); }
}
.close-ad-button:hover {transform:translateY(-2px); box-shadow:0 6px 20px rgba(0,0,0,0.3); background:#f0f0f0;}
.video-player-container video, .video-player-container iframe {width:100%; height:auto; min-height:400px; display:block; object-fit:cover;}

.call {font-size:clamp(23px, 3vw, 27px);}
.call strong {font-size:1.5em;}

/* === Styles Galerie Strip === */
.profile-gallery-section h3 {margin-bottom:12px;}
.gallery-strip {--gap:12px; --cells:3;  position:relative; overflow:hidden; border-radius:10px;}

/* Dégradés indicateurs (ajout/ retrait via .has-left/.has-right en JS) */
.gallery-strip::before, .gallery-strip::after {content:""; position:absolute; top:0; bottom:0; width:40px; pointer-events:none; opacity:0; transition:opacity .2s ease;}
.gallery-strip.has-left::before {left:0; background:linear-gradient(90deg, rgba(0,0,0,.12), rgba(0,0,0,0)); opacity:1;}
.gallery-strip.has-right::after {right:0; background:linear-gradient(270deg, rgba(0,0,0,.12), rgba(0,0,0,0)); opacity:1;}

/* Piste scrollable */
.strip-track {display:flex; gap:var(--gap); padding:6px; overflow-x:auto; overflow-y:hidden; scroll-behavior:smooth; scrollbar-width:none; cursor:grab; touch-action:pan-y;}
.strip-track::-webkit-scrollbar {display:none;}

/* Cellules :3 visibles – largeur fixe, hauteur libre */
.strip-cell {flex:0 0 calc( (100% - (var(--gap) * (var(--cells) - 1))) / var(--cells) ); display:block; background-color:var(--white); border:1px solid #ddd; border-radius:10px; padding:8px; transition:transform .15s ease;}
.strip-cell:hover { transform:scale(1.01); }

/* Désactive le drag natif & la sélection pendant le slide */
.strip-img {display:block; width:100%; height:auto; border-radius:6px; -webkit-user-drag:none; user-select:none; pointer-events:none;}
.strip-track.is-dragging, .strip-track.is-dragging * {cursor:grabbing !important; user-select:none;}

/* Zones cliquables pour “clic-maintenu” (auto-défilement) */
.strip-zone {position:absolute; top:0; bottom:0; width:48px; background:transparent; border:0; padding:0; cursor:ew-resize; z-index:2;}
.zone-left  {left:0;}
.zone-right {right:0;}

/* Bonus accessibilité au clavier (si jamais focus) */
.strip-zone:focus-visible {outline:2px solid #888; outline-offset:-2px;}

/* Responsive :sur petits écrans on peut garder 3 (ou passer à 2 si tu veux) */
@media (max-width:640px) {
  .gallery-strip { --cells:2; }
}

/* RESPONSIVE */
@media (max-width:768px) {
    .profile-photo {float:none; max-width:100%; margin:0 0 20px 0;}
    .profile-gallery-masonry {column-count:1; max-height:500px;}
}

/* === Insert HTML/JS spécifique image === */
.custom-html {}
.custom-js {}

/* === Widget === */
.widget {}
.widget h3 {padding:12px; margin-bottom:15px;}
.widget-content {padding:0 5px; font-size:0.8em;}
.widget-content li {padding:0 0 10px;}
.widget-content-image {column-count:2; column-gap:20px; padding-top:10px;}
.widget-content img {width:100%; height:auto; display:block; margin-bottom:20px; transition:transform 0.3s ease;}
.widget-content img:hover {transform:scale(1.1);}
.nav a {text-decoration:none; transform:translatex(0); transition:transform 0.4s ease-in-out; font-weight:500; color:inherit;}
.nav a::before {content:""; height:2px; width:100%; position:absolute; bottom:-2px; left:0; transform:translatex(-50%); opacity:0; transition:transform 0.4s ease-in-out, opacity 0.4s linear;}
.nav a:hover::before {transform:translatex(0);  opacity:1;}
.nav ul {list-style:none; padding:0; display:flex; flex-direction:column; margin-bottom:5px;}
.nav li {display:flex; align-items:center; cursor:pointer; margin:0 0 10px;}

.video-container {margin:20px 0;}
.video-embed-container {position:relative; padding-bottom:56.25%; /* Ratio 16:9 */ height:0; overflow:hidden; border-radius:8px;}
.video-embed-container iframe {position:absolute; top:0; left:0; width:100%; height:100%; border-radius:8px;}
.main-video {background:#000; object-fit:contain;}
.video-error {background:#f8f9fa; border:2px dashed #dee2e6; border-radius:8px; padding:40px; text-align:center; color:#6c757d;}
.custom-html-content {line-height:1.6;}
.custom-html-content img {max-width:100%; height:auto; border-radius:8px;}

/* Contenu relatif */
.related-content {padding:clamp(10px, 2vw, 30px);}
.related-title {}
.related-grid {}
.related-item {text-decoration:none; display:block; transition:transform 0.3s ease;}
.related-item:hover {transform:translateY(-5px);}
.related-item:hover img {transform:scale(1.1);}
.related-image-wrapper {/*height:150px;*/ box-shadow:0 2px 4px rgba(0,0,0,0.1); }
.related-image-wrapper img {width:100%; height:100%; object-fit:cover; transition:transform 0.3s ease; display:block;}
.related-item-title {font-size:clamp(15px, 2vw, 20px); line-height:1.3; padding:15px 10px 0;}


  /********************/
 /* === page.php === */
/********************/
.page-main {}
.page-article {}
.page-content {}
.page-content-custom {}
.misenpage {display:flex; flex-direction:column; gap:20px; padding:10px 0 0;}
.misenpage h2 {font-family:var(--secondary-font); line-height:clamp(25px, 4vw, 50px); display:flex;}
.misenpage h3 {font-family:var(--secondary-font); font-weight:500;}
.misenpage p {text-align:justify;}
.misenpage strong {font-weight:600;}
.misenpage ul {list-style:inside;}
.misenpage li {}


  /******************/
 /* === footer === */
/******************/
.site-footer {margin:0; box-shadow:0 -2px 10px rgba(0, 0, 0, 0.1); padding:20px 0 0;}
.footer-content {padding:clamp(10px, 3vw, 20px);}
.footer-blocks {display:grid; gap:20px; align-items:center;}
.footer-blocks-1 {grid-template-columns:1fr; text-align:center;}
.footer-blocks-2 {grid-template-columns:repeat(2, 1fr);}
.footer-blocks-3 {grid-template-columns:repeat(3, 1fr);}
.footer-blocks-4 {grid-template-columns:repeat(4, 1fr);}
.footer-block h3, .footer-block h4, .footer-block h5 {margin-bottom:10px; font-weight:600;}
.footer-block img {width:100%; height:auto; border-radius:8px; display:block;}
.footer-block a {text-decoration:none;}
.footer-block a:hover {}
.footer-bottom {padding:20px 0;}
.footer-copyright {font-size:0.9em;}


  /**********************/
 /* === DISCLAIMER === */
/**********************/
body.disclaimer-active > *:not(.disclaimer-overlay):not(.disclaimer-modal) {filter: blur(10px);}
body.disclaimer-active {pointer-events: none;}
.disclaimer-overlay {position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.35); z-index: 9998; opacity: 0; transition: opacity 0.3s ease; backdrop-filter: blur(5px);}
.disclaimer-overlay.show {opacity: 1;}
/* Modal centré */
.disclaimer-modal {position: fixed; top: 50%; left: 50%; transform: translate(-50%, -50%) scale(0.9); z-index: 9999; max-width: 500px; width: 90%; opacity: 0; transition: all 0.3s ease; pointer-events: auto; filter: none;}
.disclaimer-modal.show {opacity: 1; transform: translate(-50%, -50%) scale(1);}
/* Contenu du modal */
.disclaimer-content {background-color:var(--white); border-radius:16px; padding: clamp(20px, 2vw, 40px) clamp(20px, 2vw, 40px); text-align:center; box-shadow:0 20px 60px rgba(0, 0, 0, 0.5);}
.disclaimer-site-name {font-size:clamp(25px, 2vw, 33px); font-weight:700; color:#2c3e50; margin:0 0 23px 0;}
.disclaimer-title {font-size: clamp(20px, 2vw, 26px); font-weight:600; color:#e74c3c; margin:0 0 30px 0;}
/* Boutons */
.disclaimer-buttons {display: flex; gap: 15px; justify-content: center; margin-bottom: 20px;}
.disclaimer-btn {padding: 15px 50px; font-size: 18px; font-weight: 600; border: none; border-radius: 8px; cursor: pointer; transition: all 0.2s ease; min-width: 120px;}
.disclaimer-btn-yes {background: linear-gradient(135deg, #27ae60, #229954); color: var(--white);}
.disclaimer-btn-yes:hover {transform: translateY(-2px); box-shadow: 0 6px 20px rgba(39, 174, 96, 0.4);}
.disclaimer-btn-no {background: linear-gradient(135deg, #e74c3c, #c0392b); color: white;}
.disclaimer-btn-no:hover {transform: translateY(-2px); box-shadow: 0 6px 20px rgba(231, 76, 60, 0.4);}
/* Texte explicatif */
.disclaimer-text {font-size:clamp(14px, 2vw, 20px); padding:0 20px;}

  /********************/
 /* ===  COOKIES === */
/********************/

.cookie-consent {position:fixed; left:20px; bottom:20px; max-width: 210px; z-index: 99999;}
.cookie-text {margin:0; font-size:14px; line-height:1.1;}
.cookie-actions button {border:none; cursor:pointer;}

  /*************************/
 /* === Scroll to Top === */
/*************************/
.scroll-to-top {position:fixed; bottom:20px; right:20px; width:50px; height:46px; border:none; cursor:pointer; font-size:12px; font-weight:600; text-decoration:none; z-index:1000; opacity:0; transform:translateY(100px); transition:all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94); pointer-events:none;}
.scroll-to-top.visible {opacity:1; transform:translateY(0); pointer-events:auto;}
.scroll-to-top:hover {transform:translateY(-3px); box-shadow:0 6px 20px rgba(0, 0, 0, 0.2);}
.scroll-to-top:active {transform:translateY(-1px) scale(0.95);}


  /**************************/
 /* === CATEGORIES.PHP === */
/**************************/
.category-card {transition:transform 0.3s ease, box-shadow 0.3s ease; cursor:pointer;}
.category-card:hover {transform:translateY(-5px); box-shadow:0 8px 25px rgba(0,0,0,0.15);}
.category-color-dot {padding: 10px 15px;}
.category-color-dot h2 {font-size: 30px; font-weight: 400;}
.category-image {overflow:hidden;}
.category-image img {width:100%; height:auto; object-fit:cover; transition:transform 0.3s ease;}
.category-image img:hover {transform:scale(1.1);}
.category-meta {border-top:1px solid #eee; padding-top:15px; margin-top:15px;}
.image-count-text {font-size:0.9rem; font-weight:500;}
.view-link {color:#bbb; text-decoration:none; font-weight:500; font-size:0.9rem; transition:color 0.3s ease;}
.view-link:hover {color:#333;}


  /**********************/
 /* === RESPONSIVE === */
/**********************/
@media (max-width:1025px) {
    .desk {display:none;}
    .tab {display:block;}
    .footer-blocks-3 {grid-template-columns:repeat(2, 1fr);}
    .footer-block-1 {grid-column:1 / -1;}
    .footer-blocks-4 {grid-template-columns:repeat(2, 1fr);}
}

@media (max-width:768px) {
    .tab {display:none;}
    .mob {display:block;}
    .disclaimer-buttons {flex-direction: column;}
    .header-content {justify-content: center; background:none;}
    .logo {width: 100%; text-align: center;}
    .page-header h1 {margin:0 auto 10px; text-align: center;}
    .breadcrumb-wrapper {justify-content: center;}
    .filters-controls {width:100%; justify-content:center; /*flex-wrap:wrap;*/ gap: 10px;}

    .categories-grid {grid-template-columns:repeat(auto-fill, minmax(280px, 1fr)); gap:15px;}
    .categories-navigation {flex-direction:column; gap:15px;}
    .stats-bar {justify-content:center;}
    .categories-header {flex-direction:column; align-items:stretch; gap:20px;}
    .categories-controls {flex-direction:row; justify-content:space-between; align-items:center;}

    .related-grid {grid-template-columns:repeat(2, 1fr) !important;}
    .footer-blocks-4 {grid-template-columns: 1fr;}
    .footer-blocks-3 {grid-template-columns: 1fr;}

    .image-detail {grid-template-columns:1fr; width:100%;}
    .vignette-blog {max-width:100%; margin:0 auto 20px;}
    .info-section {width:100%; align-items:center;}
    .scroll-to-top {bottom:20px; right:20px; width:50px; height:50px;}
    .scroll-to-top .arrow {font-size:14px;}
    .scroll-to-top .text {font-size:8px;}
}

@media (max-width:640px) {
    .imgmob100 {max-width:100%;}
    /*.toggleable_label {width:100%;}
    .toggleable_content {max-height:0; overflow:hidden; transition:max-height .8s cubic-bezier(0,1,0,1)}
    .toggleable_control:checked ~ .toggleable_content {transition-timing-function:ease-in-out; max-height:3000px;}
    .toggleable_content {margin-top:10px;}
    .toggleable_label::after {content:"OUVRIR ▼"; font-size:0.8rem;}
    .toggleable_control:checked ~ .toggleable_label::after {content:"FERMER ▲";}*/
 }

@media (max-width:480px) {
    .dropdown-toggle {min-width:150px;}
    .related-grid {grid-template-columns:1fr !important;}
    .footer-blocks-2 {grid-template-columns: 1fr;}
}
