/* style.css - Styles unifiés pour le frontend public */

* {
    margin:0;
    padding:0;
    box-sizing:border-box;
}
.outfit {font-family:"Outfit", sans-serif;}
.bgwhite {background-color:white;}
.bg1 {background-color:#f5f5f5;}
.bg2 {background-color:#fafafa;}
.bg3 {background-color:#f2f2f2;}
.colorwhite {color:white;}
.color1 {color:#333;}
.color2 {color:#fafafa;}
.color3 {color:#495057;}
.borderwhite {border-color:white;}
.border1 {border-color:#f5f5f5;}
.border2 {border-color:#fafafa;}
.border3 {border-color:#f0f0f0;}
.borderwhite, .border1, .border2, .border3 {border-width:1px; border-style:solid;}

.aligncenter {align-items:center;}
.alignstart {align-items:start;}
.block {display:block;}
.center {text-align:center;}
.flex {display:flex;}
.flexstart {align-items:flex-start;}
.flexend {align-items:flex-end;}
.flexcolumn {flex-direction:column;}
.floatright {float:right;}
.floatleft {float:left;}
.gap10 {gap:10px;}
.gap20 {gap:20px;}
.gap30 {gap:30px;}
.gap40 {gap:40px;}
.grid {display:grid;}
.img {width:100%; height:auto; display:block;}
.justify {text-align:justify;}
.justifyspacebtw {justify-content:space-between;}
.justifycenter {justify-content:center;}
.lineheight {line-height:1.6;}
.luminosity {mix-blend-mode:luminosity;}
.martop0 {margin-top:0;}
.martom20 {margin-bottom:20px;}
.martom30 {margin-bottom:30px;}
.martom40 {margin-bottom:40px;}
.marginauto {margin:auto;}
.margin0 {margin:0;}
.marginright20 {margin-right:20px;}
.maxsize {width:100%; max-width:1330px;}
.minsize {width:100%; max-width:1158px;}
.nospace {white-space:nowrap;}
.overden {overflow:hidden;}
.padding0 {padding:0;}
.paddingtop0 {padding-top:0;}
.padding10 {padding:10px;}
.padding20 {padding:20px;}
.padding30 {padding:30px;}
.paddingright20 {padding-right:20px;}
.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);}
.text {font-size:clamp(1em, 3vw, 1.2em);}
.textindent10 {text-indent:10px;}
.textindent15 {text-indent:15px;}
.textindent20 {text-indent:20px;}
.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;}


.blink {animation: blink-animation 1s steps(1) infinite;}
@keyframes blink-animation {
    0%, 50% { visibility: visible; }
    50.1%, 100% { visibility: hidden; }
}

.pubtel-V {}
.pubtel-V h2 {font-size:1.5em; padding:10px 0 0; color:#333; font-weight:700;}
.pubtel-V p {color:#555; line-height:1.3; font-size:0.9em; padding:0 0 10px; text-align:justify;}
.pubtel-V p span {float: left; padding: 5px 8px; border-radius: 4px; color: white; background-color: #1c355f; margin-right: 10px; font-weight: 600; font-size: 1.2em;}
.numero {font-size:2em; font-weight:600; background-color:#1c355f; color:white; text-align: center; border-radius:8px;}



  /*******************************/
 /* === CONTENUS PRINCIPAUX === */
/*******************************/
a {text-decoration:none;}

body {font-family:"Outfit", sans-serif; font-size:14px;}

.container {margin:0 auto; padding:0 10px;}
.page-header {margin:0 auto 20px; padding:10px; border-bottom:2px solid #ccc;}
.page-header-bloc {}
h1 {font-size:clamp(1.4em, 2vw, 1.5em); text-indent: clamp(1px, 1vw, 15px); font-weight:600;}
.site-description {padding:0 1.2vw;}

  /*************************/
 /* === HEADER COMMUN === */
   /**********************/

.header {padding:clamp(5px, 1.5vw, 20px) 0; box-shadow:0 2px 10px rgba(0,0,0,0.1); /*position:sticky; top:0; z-index:100;*/}
.header-content {margin:0 auto; padding:0 20px;}
.logo {font-size:1.8rem; background:linear-gradient(45deg, #2196F3, #4CAF50); -webkit-background-clip:text; -webkit-text-fill-color:transparent; font-weight:700;}
.logo a {text-decoration:none; color:inherit;}

.stats {font-size:0.9rem; color:#666;}
nav {}
nav a {color:#495057; text-decoration:none; font-weight:600; padding:3px 10px; border-radius:6px; transition:all 0.3s;}
nav a:hover {background:#ccc; color:#fff;}

/* Styles pour les boutons de filtrage par type de contenu*/
.content-filter-btn-index.active {background:#ccc; color:white;}
.content-filter-btn-index .count {font-size:0.8em;}

  /**********************/
 /* === BREADCRUMB === */
/**********************/

.breadcrumb {gap:5px; font-weight:500;}
.breadcrumb a {color:#495057; text-decoration:none; transition:all 0.3s;}
.breadcrumb a:hover {color:#fff; background:#ccc; }
.breadcrumb-separator {color:#495057; margin:0 8px;}
.breadcrumb-current {background: linear-gradient(135deg, #aaa 0%, #ccc 100%); color:white; padding:2px 6px; border-radius:6px;}


  /***************************/
 /* === Dropdowns perso === */
/***************************/
.filters-controls {}
.dropdown {position:relative;}
.dropdown-toggle {font-family:"Outfit", sans-serif; 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 {font-weight:700; font-size:1.4em; color:#333;}
.dropdown-toggle:hover, .dropdown-toggle:focus {background-color:#eee; text-decoration:none; outline:0;}
.dropdown-toggle.active, .dropdown.open .dropdown-toggle {background-color:#f5f5f5; outline:0;}
.dropdown-menu {position:absolute; /*top:100%; left:0; float:left;  */ list-style:none; z-index:1000; display:none;  min-width:100%; margin:5px 0 0; background-color:#fff; 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 {font-family:"Outfit", sans-serif; 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 {color:#fff; background-color:#ddd; outline:none;}
.caret {/*display:inline-block; width:0; height:0; margin-left:2px; vertical-align:middle;*/ 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;  /* requis pour le positionnement absolu des items */}
.gallery {}
.image-card, .ad-card {background:white; border:1px solid #eee; border-radius:12px 12px 4px 4px; overflow:hidden; /*break-inside:avoid; transition:all 0.3s ease;*/ cursor:pointer;}
.ad-card {/*position:relative;*/ }
.ad-content {width:100%; /*display:flex;*/ 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;}
.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 {font:600 14px/1.3 system-ui, -apple-system, Segoe UI, Roboto, sans-serif; margin:0 0 6px;}
.image-description {font:12px/1.35 system-ui, -apple-system, Segoe UI, Roboto, sans-serif; color:#bbb; 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: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: 8px; margin: 40px 0 20px; padding: 20px; flex-wrap: wrap;}
.pagination-btn {min-width: 40px; height: 40px; padding: 0 12px; border: 1px solid #ddd; background: white; color: #333; border-radius: 6px; cursor: pointer; font-size: 14px; font-weight: 500; transition: all 0.2s;}
.pagination-btn:hover {background: #f8f9fa; border-color: #aaa;}
.pagination-btn.active {background: #007bff; color: white; border-color: #007bff; cursor: default;}
.pagination-btn:disabled {opacity: 0.5; cursor: not-allowed;}
.pagination-dots {padding: 0 8px; color: #999; font-weight: bold;}


  /*********************/
 /* === image.php === */
/*********************/

.container-image {margin:0 auto 20px; padding:0 clamp(10px, 2vw, 20px);}
.image-detail {grid-template-columns:1fr auto;}
.image-section {padding: clamp(10px, 2vw, 30px);}
.image-description-detail {font-size: clamp(0.8em, 2vw, 1.2em); flex-grow:1; -webkit-line-clamp:unset;}
.vignette-video, .vignette-blog {width:100%; max-width:320px; margin:0 30px 10px 0;}
.image-title-detail {font-size:clamp(1.3em, 2vw, 1.5em); text-indent:clamp(1px, 1vw, 15px); font-weight:600;}
.main-image {height:auto; box-shadow:0 4px 15px rgba(0,0,0,0.1); cursor:pointer; 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;}

/* Tags dans image.php */
.tags-container {}
.tag-link {display:inline-block; padding:4px 10px 6px; background: linear-gradient(135deg, #aaa 0%, #ccc 100%); color:white; text-decoration:none; border-radius:8px; font-size:12px; transition:all 0.2s;}
.tag-link:hover {transform: translateY(-2px); box-shadow: 0 4px 12px rgba(102, 126, 234, 0.4);}

/* === Pubs générales image === */
.pub1 img, .pub2 img, .pub3 img, .pub4 img {height:auto; width:100%; display: block;}

/* === Insert HTML/JS spécifique image === */
.custom-html {}
.custom-js {}

/* === Widget === */
.widget-image {}
.widget-title {margin-bottom:10px; box-shadow:0 4px 15px rgba(0,0,0,0.1); padding:10px 20px;}
.widget-content {padding: 0 clamp(5px, 1.2vw, 20px); 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; background:#bbb; 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;}

.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;}
.related-item-title {font-weight:500; color:#333; font-size:14px; line-height:20px; padding-top:5px;}
.related-item:hover .related-item-title {color:#bbb;}

/* Responsive pour mobile */
@media (max-width:968px) {
    
}

@media (max-width:768px) {
    .related-grid {grid-template-columns:repeat(2, 1fr) !important;}
}

@media (max-width:480px) {
    .related-grid {grid-template-columns:1fr !important;}
}


  /******************/
 /* === footer === */
/******************/
.site-footer {margin:0; box-shadow:0 -2px 10px rgba(0, 0, 0, 0.1); padding:20px 0 0;}
.footer-content {margin:auto; padding:0 10px 10px;}

.footer-blocks {display:grid; gap:3%; align-items:center;}
/* Grilles responsives selon le nombre de blocs */
.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(2, 1fr);}

.footer-block h3,.footer-block h4,.footer-block h5 {color:#495057;  margin-bottom:10px; font-weight:600;}
.footer-block img {width:100%; height:auto; border-radius:8px; display:block;}
.footer-block a {text-decoration:none; transition:color 0.3s ease;}
.footer-block a:hover {text-decoration:underline;}

@media (min-width:768px) {
    .footer-blocks-4 {
        grid-template-columns:repeat(4, 1fr);
    }
}


.footer-bottom {background:#e9ecef; padding:20px 0; border-top:1px solid #dee2e6;}
.footer-copyright {
    text-align:center;
    color:#6c757d;
    font-size:0.9em;
}

/* Responsive */
@media (max-width:767px) {
    .footer-blocks-2,
    .footer-blocks-3,
    .footer-blocks-4 {
        grid-template-columns:1fr;
        text-align:center;
    }
    
    .footer-content {
        padding:30px 0 15px;
    }
}


  /*************************/
 /* === Scroll to Top === */
/*************************/

.scroll-to-top {
    position:fixed;
    bottom:20px;
    right:20px;
    width:50px;
    height:40px;
    background-color:rgba(253, 122, 122, 0.8);
    border:none;
    border-radius:8px;
    cursor:pointer;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:flex-start;
    color:white;
    font-size:11px;
    font-weight:600;
    text-decoration:none;
    z-index:1000;
    /* Animation d'apparition */
    opacity:0;
    transform:translateY(100px);
    transition:all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    pointer-events:none;
    /* Ombre douce */
    box-shadow:0 4px 20px rgba(0, 0, 0, 0.15);
}

.scroll-to-top.visible {opacity:1; transform:translateY(0); pointer-events:auto;}
.scroll-to-top:hover {background-color:rgba(253, 122, 122, 0.8); color:#eee; transform:translateY(-3px); box-shadow:0 6px 20px rgba(0, 0, 0, 0.2);}
.scroll-to-top .arrow {font-size:16px; margin-top:-2px;}
.scroll-to-top .text {font-size:9px; line-height:1;}
.scroll-to-top:active {transform:translateY(-1px) scale(0.95);}

/* Responsive */
@media (max-width:768px) {
    .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;}
}

/* === STYLES SPÉCIFIQUES CATÉGORIE === */

.container-categorie {
    max-width:1200px;
    margin:0 auto;
}

.categories-header .page-title {
    margin:0 0 5px 0;
    font-size:2rem;
    color:#333;
}

.categories-header .page-subtitle {
    margin:0 0 15px 0;
    color:#666;
    font-size:1.1rem;
}

.stats-bar {
    font-size:0.9rem;
}

.stat-number {
    font-weight:700;
    color:#2196F3;
    font-size:1.2em;
}

.stat-label {
    color:#666;
    margin-left:5px;
}

.stat-divider {
    color:#ccc;
}

.categories-controls {
    display:flex;
    flex-direction:column;
    gap:15px;
    align-items:flex-end;
}

.sort-controls select {
    padding:8px 12px;
    border:1px solid #ddd;
    border-radius:6px;
    font-size:0.9rem;
}

.view-controls {
    display:flex;
    gap:5px;
}

.view-btn {
    padding:8px 12px;
    border:1px solid #ddd;
    background:white;
    border-radius:6px;
    cursor:pointer;
    transition:all 0.3s ease;
}

.view-btn.active {
    background:#2196F3;
    color:white;
    border-color:#2196F3;
}

/* Vue grille */
.categories-grid {
    display:grid;
    grid-template-columns:repeat(auto-fill, minmax(300px, 1fr));
    gap:20px;
}

.category-card {
    overflow:hidden;
    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-header {
    position:relative;
    height:60px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:0 20px;
}

.category-color-dot {
    width:20px;
    height:20px;
    border-radius:50%;
    border:2px solid white;
    box-shadow:0 2px 4px rgba(0,0,0,0.1);
}

.category-count {
    background:rgba(255,255,255,0.9);
    padding:5px 10px;
    border-radius:12px;
    font-weight:600;
    font-size:0.9rem;
}

.category-image {
    height:180px;
    overflow:hidden;
}

.category-image img {
    width:100%;
    height:100%;
    object-fit:cover;
    transition:transform 0.3s ease;
}

.category-card:hover .category-image img {
    transform:scale(1.05);
}

.category-name {
    margin:0 0 10px 0;
    font-size:1.3rem;
    color:#333;
}

.category-description {
    margin:0 0 15px 0;
    color:#666;
    line-height:1.5;
    font-size:0.95rem;
}

.category-description.default {
    font-style:italic;
    opacity:0.8;
}

.category-meta {
    border-top:1px solid #eee;
    padding-top:15px;
    margin-top:15px;
}

.image-count-text {
    font-size:0.9rem;
    color:#666;
    font-weight:500;
}

.view-link {
    color:#2196F3;
    text-decoration:none;
    font-weight:500;
    font-size:0.9rem;
    transition:color 0.3s ease;
}

.view-link:hover {
    color:#1976D2;
    text-decoration:underline;
}

/* Vue liste */
.list-header {
    background:#f8f9fa;
    border-bottom:1px solid #eee;
}

.list-header-row {
    display:grid;
    grid-template-columns:1fr auto auto;
    gap:20px;
    font-weight:600;
    color:#333;
}

.list-row {
    display:grid;
    grid-template-columns:1fr auto auto;
    gap:20px;
    align-items:center;
    border-bottom:1px solid #f0f0f0;
    transition:background 0.3s ease;
}

.list-row:hover {
    background:#f8f9fa;
}

.list-row:last-child {
    border-bottom:none;
}

.list-thumb {
    width:50px;
    height:50px;
    object-fit:cover;
    border-radius:8px;
}

.category-color-indicator {
    width:12px;
    height:12px;
    border-radius:50%;
    flex-shrink:0;
}

.list-category-name {
    margin:0 0 5px 0;
    font-size:1.1rem;
    color:#333;
}

.list-category-description {
    margin:0;
    font-size:0.9rem;
    color:#666;
}

.count-badge {
    background:#e3f2fd;
    color:#1976d2;
    padding:4px 8px;
    border-radius:12px;
    font-weight:600;
    font-size:0.85rem;
}

.btn {
    padding:8px 16px;
    background:#2196F3;
    color:white;
    text-decoration:none;
    border-radius:6px;
    font-size:0.9rem;
    transition:all 0.3s ease;
    border:none;
    cursor:pointer;
}

.btn:hover {
    background:#1976D2;
}

.btn-sm {
    padding:6px 12px;
    font-size:0.85rem;
}

.nav-link {
    color:#2196F3;
    text-decoration:none;
    transition:color 0.3s ease;
}

.nav-link:hover {
    color:#1976D2;
    text-decoration:underline;
}

.empty-state {
    text-align:center;
    padding:60px 20px;
}

.empty-icon {
    font-size:4rem;
    margin-bottom:20px;
    opacity:0.5;
}

/* Responsive */
@media (max-width:768px) {
    .categories-header {
        flex-direction:column;
        align-items:stretch;
        gap:20px;
    }

    .categories-controls {
        flex-direction:row;
        justify-content:space-between;
        align-items:center;
    }

    .stats-bar {
        justify-content:center;
    }

    .categories-grid {
        grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));
        gap:15px;
    }

    .list-header-row,
    .list-row {
        grid-template-columns:1fr auto;
        gap:15px;
    }

    .list-action {
        grid-column:1 / -1;
        margin-top:10px;
    }

    .categories-navigation {
        flex-direction:column;
        gap:15px;
    }
}



/* === EN-TÊTE CATÉGORIE (category.php) === 
.category-header {
    text-align:center;
    margin-bottom:40px;
    padding:30px 20px;
    background:linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
    border-radius:12px;
    border:1px solid #dee2e6;
}

.category-title {
    font-size:2.5rem;
    font-weight:700;
    color:#333;
    margin-bottom:15px;
}

.category-description {
    font-size:1.1rem;
    color:#6c757d;
    line-height:1.6;
    max-width:600px;
    margin:0 auto 20px;
}

.category-meta {
    display:flex;
    align-items:center;
    justify-content:center;
    gap:15px;
    margin-top:20px;
}

.image-count {
    font-size:1rem;
    color:#495057;
    font-weight:600;
}

.category-color-indicator {
    width:20px;
    height:20px;
    border-radius:50%;
    border:2px solid white;
    box-shadow:0 2px 4px rgba(0,0,0,0.1);
}
*/

/* === BARRE D'OUTILS === 
.toolbar {
    display:flex;
    justify-content:space-between;
    align-items:center;
    margin-bottom:30px;
    padding:15px 20px;
    background:white;
    border-radius:8px;
    box-shadow:0 2px 8px rgba(0,0,0,0.05);
    border:1px solid #e9ecef;
}

.sort-options label {
    font-weight:600;
    color:#495057;
    margin-right:10px;
}

.sort-options select {
    padding:8px 12px;
    border:1px solid #dee2e6;
    border-radius:6px;
    background:white;
    color:#495057;
    font-size:14px;
}
*/

  /**********************/
 /* === 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: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: 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;}


  /**********************/
 /* === RESPONSIVE === */
/**********************/

@media (max-width:1024px) {
    .desk {display:none;}
    .tab {display:block;}
}

@media (max-width:768px) {
    .tab {display:none;}
    .mob {display:block;}
    .disclaimer-buttons {flex-direction: column;}
    .header-content {padding:0 10px; justify-content: center;}
    .logo {width: 100%; text-align: center;}
    .page-header h1 {margin:0 auto 10px;}
    .filters-controls {width:100%; justify-content:center; /*flex-wrap:wrap;*/ gap: 10px;}

    .image-detail {grid-template-columns:1fr; width:100%;}
    .info-section {width:100%; align-items:center;}
}

@media (max-width:480px) {
    .page-header-bloc {background: none; padding: 0 10px;}
    .dropdown-toggle {min-width:150px;}
    .vignette-blog {max-width: 100%; margin: 0 auto 20px;}

}





@media (max-width:768px) {
    
    .category-h1 {
        font-size:2rem;
    }
    
    .category-info {
        margin-bottom:30px;
    }
    
    .category-description {
        font-size:1rem;
    }
}

@media (max-width:480px) {

    
    .breadcrumb-content {
        padding:0 15px;
    }
      
    .back-btn {
        padding:8px 16px;
        font-size:0.9rem;
    }
        
}




