:root {
      --forest:  #1A3A2A;
      --pine:    #234D36;
      --sage:    #4A9B6F;
      --sage-lt: #6DB892;
      --mint:    #A8D5BA;
      --lime:    #D4EDD8;
      --cream:   #F4F1EB;
      --paper:   #FAFAF7;
      --muted:   #6B7B6D;
      --border:  #DDE8DF;
      --ink:     #0F1B13;
      --white:   #FFFFFF;
      --amber:   #F5A42A;

      --r-sm: 8px;
      --r-md: 12px;
      --r-lg: 18px;
      --shadow-sm: 0 2px 8px rgba(15,27,19,.06);
      --shadow-md: 0 6px 24px rgba(15,27,19,.12);
      --shadow-lg: 0 16px 48px rgba(15,27,19,.16);
      --t: .22s cubic-bezier(.4,0,.2,1);
    }

    *, *::before, *::after { box-sizing: border-box; }
    body {
      font-family: 'Sora', sans-serif;
      background: var(--paper);
      color: var(--ink);
      overflow-x: hidden;
      font-size: 15px;
    }
		
    a { text-decoration: none; color: inherit; }
    ::-webkit-scrollbar { width: 5px; }
    ::-webkit-scrollbar-thumb { background: var(--mint); border-radius: 10px; }
		
    p a, li a { text-decoration: underline;	}
		.alert a { text-decoration: underline dotted; font-weight: 500; }

    /* ══════════ TOPBAR ══════════ */
    .topbar {
      background: var(--forest);
      color: rgba(255,255,255,.6);
      font-size: .72rem;
      padding: .4rem 0;
    }
    .topbar a { color: rgba(255,255,255,.55); transition: color var(--t); }
    .topbar a:hover { color: var(--mint); }

    /* ══════════ NAVBAR ══════════ */
    .navbar {
      background: rgba(255,255,255,.97);
      backdrop-filter: blur(12px);
      -webkit-backdrop-filter: blur(12px);
      border-bottom: 1px solid var(--border);
      padding: 0;
      position: sticky;
      top: 0;
      z-index: 900;
      transition: box-shadow var(--t);
    }
    .navbar.elevated { box-shadow: var(--shadow-md); }
    .navbar-inner { display: flex; align-items: stretch; height: 60px; }

    .nav-brand {
      display: flex; align-items: center; gap: .55rem;
      padding: 0 1.4rem 0 0;
      border-right: 1px solid var(--border);
      margin-right: 1rem;
      flex-shrink: 0;
			text-decoration: none;
    }
    .brand-icon {
      width: 34px; height: 34px;
      background: var(--forest);
      border-radius: var(--r-sm);
      display: grid; place-items: center;
      font-size: 1rem;
    }
    .brand-text { font-size: 1.5rem; font-weight: 800; color: var(--forest); }
    .brand-text span { color: var(--sage); }

    .nav-tabs-bar {
      display: flex; align-items: stretch; gap: 0; flex: 1;
      overflow-x: auto; scrollbar-width: none;
    }
    .nav-tabs-bar::-webkit-scrollbar { display: none; }
    .nav-tab {
      display: flex; align-items: center; gap: .4rem;
      padding: 0 1rem;
      font-size: .8rem; font-weight: 500; color: var(--muted);
      border-bottom: 3px solid transparent;
      white-space: nowrap;
      transition: color var(--t), border-color var(--t);
    }
    .nav-tab:hover { color: var(--forest); }
    .nav-tab.active { color: var(--forest); border-bottom-color: var(--sage); font-weight: 600; }
    .nav-tab .cnt {
      background: var(--lime); color: var(--pine);
      font-size: .6rem; font-weight: 700;
      padding: .08rem .38rem; border-radius: 20px;
    }
		
		.dropdown-menu {
			background-color: var(--white);
			border: 1px solid var(--border);
			box-shadow: var(--shadow-md);
			padding: .4rem;
			min-width: 180px;
		}

		.dropdown-item {
			font-size: .9rem;
			color: var(--muted);
			border-radius: var(--r-sm);
			padding: .45rem .85rem;
			transition: background var(--t), color var(--t);
		}

		.dropdown-item:hover,
		.dropdown-item:focus {
			background-color: var(--lime);
			color: var(--forest);
		}

		.dropdown-item:active,
		.dropdown-item.active {
			background-color: var(--forest);
			color: var(--white);
		}

		/* Supprime le style Bootstrap par défaut au focus */
		.dropdown-item:focus-visible {
			box-shadow: none;
			outline: none;
		}

    .nav-right {
      display: flex; align-items: center; gap: .5rem;
      padding-left: 1rem; border-left: 1px solid var(--border);
      margin-left: auto; flex-shrink: 0;
    }
    .nav-icon-btn {
      width: 34px; height: 34px;
      border-radius: var(--r-sm); border: 1px solid var(--border);
      background: transparent; display: grid; place-items: center;
      color: var(--muted); font-size: .95rem; cursor: pointer;
      transition: background var(--t), color var(--t);
    }
    .nav-icon-btn:hover { background: var(--lime); color: var(--forest); border-color: var(--mint); }
    .btn-nav-cta {
      background: var(--forest); color: var(--white);
      font-size: .76rem; font-weight: 600;
      padding: .4rem .95rem; border-radius: var(--r-sm);
      border: none; display: flex; align-items: center; gap: .3rem;
      cursor: pointer; transition: background var(--t), transform var(--t);
    }
    .btn-nav-cta:hover { background: var(--pine); transform: translateY(-1px); }

    /* ══════════ HERO PHOTO ══════════ */
    .hero-photo {
      position: relative;
      min-height: 520px;
      display: flex;
      align-items: center;
      overflow: hidden;
    }

    /* Photo background via CSS */
    .hero-bg {
      position: absolute; inset: 0;
      background-image: url('/background.php');
      background-size: cover;
      background-position: center 40%;
      filter: brightness(.55) saturate(.9);
			/*transform: scale(1.03);*/
    }

    /* Gradient overlays */
    .hero-overlay {
      position: absolute; inset: 0;
      background:
        linear-gradient(to right, rgba(10,30,18,.85) 0%, rgba(10,30,18,.45) 60%, transparent 100%),
        linear-gradient(to top, rgba(10,30,18,.6) 0%, transparent 50%);
    }

    /* Grain texture */
    .hero-grain {
      position: absolute; inset: 0; opacity: .04;
      background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
      background-size: 200px;
      pointer-events: none;
    }

    .hero-content {
      position: relative; z-index: 2;
      padding: 72px 0 72px;
      width: 100%;
    }

    .hero-eyebrow {
      display: inline-flex; align-items: center; gap: .5rem;
      background: rgba(255,255,255,.1);
      border: 1px solid rgba(255,255,255,.2);
      backdrop-filter: blur(6px);
      color: var(--mint);
      font-size: .68rem; font-weight: 700;
      letter-spacing: .18em; text-transform: uppercase;
      padding: .32rem .85rem; border-radius: 50px;
      margin-bottom: 1.2rem;
    }
    .hero-eyebrow .live-dot {
      width: 6px; height: 6px; border-radius: 50%;
      background: var(--mint);
      animation: blink 2s infinite;
    }
    @keyframes blink { 0%,100%{opacity:1} 50%{opacity:.3} }

    .hero-content h1 {
      font-family: 'Lora', serif;
      font-size: clamp(2rem, 4.5vw, 3.4rem);
      font-weight: 600;
      color: var(--white);
      line-height: 1.18;
      margin-bottom: .8rem;
    }
    .hero-content h1 em {
      font-style: italic;
      color: var(--mint);
    }
    .hero-sub {
      color: rgba(255,255,255,.65);
      font-size: .9rem; line-height: 1.7;
      max-width: 500px; margin-bottom: 2rem;
    }
		
		@media (max-width: 576px) {
			.hero-sub {
				max-width: 320px;
			}
		}

    /* ── Search bar ── */
    .search-wrap {
      max-width: 640px;
      background: var(--white);
      border-radius: var(--r-lg);
      display: flex; align-items: center;
      gap: .5rem;
      padding: .45rem .45rem .45rem 1.1rem;
      box-shadow: 0 12px 40px rgba(0,0,0,.35);
    }
    .search-wrap > i { color: var(--muted); font-size: 1rem; flex-shrink: 0; }
    .search-wrap input {
      flex: 1; border: none; outline: none;
      font-family: 'Sora', sans-serif; font-size: .88rem;
      color: var(--ink); background: transparent;
    }
		
		@media (max-width: 576px) {
			.search-wrap input {
				width: calc(100% - 80px);
			}
		}
		
		.form-control {
      font-family: 'Sora', sans-serif; font-size: .88rem;
      color: var(--ink);
		}
    .search-wrap input::placeholder, .form-control::placeholder { color: #aaa; }
    .search-sep { width: 1px; height: 20px; background: var(--border); flex-shrink: 0; }
    .search-select {
      border: none; outline: none;
      font-family: 'Sora', sans-serif; font-size: .76rem;
      color: var(--muted); background: transparent;
      padding: 0 .25rem; cursor: pointer; flex-shrink: 0;
    }
    .btn-primary, .btn-primary.active {
			background: var(--sage); color: var(--white);
			font-family: 'Sora', sans-serif; font-size: .82rem;
			padding: .62rem 1.3rem; border-radius: var(--r-md);
			border: none; cursor: pointer; white-space: nowrap;
			align-items: center; gap: .35rem;
			transition: background var(--t), transform var(--t);
			flex-shrink: 0;
			--bs-btn-focus-shadow-rgb: 74, 155, 111; /* supprime le halo bleu */
		}
		/*.btn-search {
			display: flex;
			font-weight: 700;
		}*/
    .btn-primary:hover
		{ background: var(--pine); transform: translateY(-1px); }
		
		.btn-primary:active,
		.btn-primary:focus,
		.btn-primary:focus-visible,
		.btn-primary:first-child:active {
			background: var(--pine);
			border-color: transparent;
			box-shadow: none;
			color: var(--white);
		}

    .pop-searches {
      margin-top: 1rem;
      display: flex; gap: .45rem; flex-wrap: wrap; align-items: center;
    }
    .pop-label { font-size: .7rem; color: rgba(255,255,255,.45); }
    .pop-tag {
      background: rgba(255,255,255,.1);
      border: 1px solid rgba(255,255,255,.18);
      color: rgba(255,255,255,.75);
      font-size: .7rem; padding: .22rem .7rem; margin-right: .33rem;
      border-radius: 50px; cursor: pointer;
      transition: background var(--t), color var(--t);
    }
    .pop-tag:hover { background: rgba(255,255,255,.2); color: var(--white); }

    /* ── Hero stats ── */
    .hero-stats-row {
      display: flex; gap: 2.5rem; flex-wrap: wrap;
      margin-top: 2.8rem;
      padding-top: 2rem;
      border-top: 1px solid rgba(255,255,255,.12);
    }
    .h-stat-num {
      font-family: 'Lora', serif; font-size: 1.7rem; font-weight: 600;
      color: var(--mint); line-height: 1;
    }
    .h-stat-lbl { font-size: .7rem; color: rgba(255,255,255,.45); margin-top: .2rem; }

    /* Photo credit */
    .photo-credit {
      position: absolute; bottom: 16px; right: 16px;
      font-size: .7rem; color: rgba(255,255,255,.3); z-index: 3;
    }

    /* ══════════ CATEGORY STRIP ══════════ */
    .cat-strip {
      background: var(--white);
      border-bottom: 1px solid var(--border);
      padding: 0;
      overflow-x: auto; scrollbar-width: none;
    }
    .cat-strip::-webkit-scrollbar { display: none; }
    .cat-strip-inner {
      display: flex; align-items: center;
      gap: 0; padding: 0;
      min-width: max-content;
    }
    .cat-pill {
      display: flex; align-items: center; gap: .45rem;
      padding: .85rem 1.4rem;
      font-size: .78rem; font-weight: 500; color: var(--muted);
      border-bottom: 3px solid transparent;
      white-space: nowrap; cursor: pointer;
      transition: color var(--t), border-color var(--t), background var(--t);
    }
    .cat-pill:hover { color: var(--forest); background: var(--paper); }
    .cat-pill.active { color: var(--forest); border-bottom-color: var(--sage); font-weight: 600; }
    .cat-pill .cat-icon { font-size: 1rem; }
    .cat-pill .cat-cnt {
      background: var(--lime); color: var(--pine);
      font-size: .62rem; font-weight: 700;
      padding: .08rem .4rem; border-radius: 20px;
    }

    /* ══════════ MAIN ══════════ */
    .main-wrap { padding: 36px 0 80px; }

    /* ══════════ SIDEBAR ══════════ */
    /*.sidebar { position: sticky; top: 80px; }*/

    .scard {
      background: var(--white);
      border: 1px solid var(--border);
      border-radius: var(--r-lg);
      overflow: hidden;
      margin-bottom: 1rem;
    }
    .scard-head {
      padding: .8rem 1.1rem;
      border-bottom: 1px solid var(--border);
      display: flex; align-items: center; justify-content: space-between;
    }
    .scard-title { font-size: .72rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); }
    .scard-reset { font-size: .7rem; color: var(--sage); cursor: pointer; font-weight: 500; }
    .scard-reset:hover { text-decoration: underline; }

    .fgroup { padding: .75rem 1.1rem; border-bottom: 1px solid var(--border); }
    .fgroup:last-child { border-bottom: none; }
    .fgroup-lbl { font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: var(--muted); margin-bottom: .6rem; }

    .fitem {
      display: flex; align-items: center; justify-content: space-between;
      padding: .3rem 0; cursor: pointer;
    }
    .fitem-l { display: flex; align-items: center; gap: .55rem; }
    .fchk {
      width: 16px; height: 16px;
      border: 1.5px solid var(--border);
      border-radius: 50%; flex-shrink: 0;
      display: grid; place-items: center;
      transition: all var(--t);
    }
    .fitem.on .fchk { border-color: var(--sage); background: transparent; }
		.fitem.on .fchk::after {
			content: '';
			width: 8px; height: 8px;
			border-radius: 50%;
			background: var(--sage);
		}
    .fitem-lbl { font-size: .8rem; color: var(--ink); transition: color var(--t); }
    .fitem:hover .fitem-lbl { color: var(--forest); }
    .fitem-cnt { font-size: .68rem; background: var(--lime); color: var(--pine); padding: .08rem .42rem; border-radius: 20px; font-weight: 600; }

    /* Type dots */
    .tdot { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; }

    /* Theme pills */
    .tpill {
      display: flex; align-items: center; gap: .6rem;
      padding: .55rem .8rem; border-radius: var(--r-sm);
      cursor: pointer; transition: background var(--t);
    }
    .tpill:hover, .tpill.active { background: var(--lime); }
    .tpill-ico { width: 28px; height: 28px; border-radius: 7px; display: grid; place-items: center; font-size: .85rem; flex-shrink: 0; }
    .tpill-name { font-size: .8rem; font-weight: 500; flex: 1; }
    .tpill-n { font-size: .68rem; color: var(--muted); }

    /* ══════════ RESULTS BAR ══════════ */
    .rbar {
      display: flex; align-items: center; gap: .75rem;
      margin-bottom: 1.2rem; flex-wrap: wrap;
    }
    .rbar-count { font-size: .82rem; color: var(--muted); flex: 1; }
    .rbar-count strong { color: var(--ink); }
    .sort-sel {
      border: 1px solid var(--border); border-radius: var(--r-sm);
      padding: .35rem .7rem;
      font-family: 'Sora', sans-serif; font-size: .76rem; color: var(--ink);
      background: var(--white); outline: none; cursor: pointer;
    }
    .view-tog { display: flex; border: 1px solid var(--border); border-radius: var(--r-sm); overflow: hidden; }
    .vbtn {
      width: 32px; height: 32px; display: grid; place-items: center;
      background: var(--white); border: none; color: var(--muted);
      font-size: .88rem; cursor: pointer; transition: background var(--t), color var(--t);
    }
    .vbtn.active, .vbtn:hover { background: var(--lime); color: var(--forest); }

    /* Active chips */
    .achips { display: flex; gap: .45rem; flex-wrap: wrap; margin-bottom: .9rem; }
    .achip {
      background: var(--lime); border: 1px solid var(--mint);
      color: var(--pine); font-size: .7rem; font-weight: 600;
      padding: .25rem .6rem; border-radius: 50px;
      display: flex; align-items: center; gap: .35rem; cursor: pointer;
      transition: background var(--t), opacity var(--t);
    }
    .achip:hover { background: var(--mint); }

    /* ══════════ RESOURCE CARD ══════════ */
    .rc {
      background: var(--white);
      border: 1px solid var(--border);
      border-radius: var(--r-lg);
      overflow: hidden;
      display: flex; flex-direction: column; height: 100%;
      transition: box-shadow var(--t), transform var(--t), border-color var(--t);
    }
    .rc:hover { box-shadow: var(--shadow-lg); transform: translateY(-3px); border-color: var(--mint); }
		
		.rc h3, .rc p { cursor: pointer !important; }

    /* Thumbnail strip with photo */
    .rc-thumb {
      height: 130px; position: relative; overflow: hidden;
      background: var(--cream);
    }
    .rc-thumb img {
      width: 100%; height: 100%; object-fit: cover;
      filter: brightness(.85) saturate(.9);
      transition: transform .45s ease, filter .3s;
    }
    .rc:hover .rc-thumb img { transform: scale(1.06); filter: brightness(.75) saturate(1); }
    .rc-thumb-overlay {
      position: absolute; inset: 0;
      background: linear-gradient(to top, rgba(10,30,18,.55) 0%, transparent 60%);
    }

    /* Type badge on thumb */
    .rc-type {
      position: absolute; top: 10px; left: 10px;
      display: inline-flex; align-items: center; gap: .3rem;
      font-size: .62rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase;
      padding: .22rem .6rem; border-radius: 50px;
    }
    /* Colors */
    .t-document	{ background: rgba(53,114,176,.9); color: #fff; }
    .t-video	  { background: rgba(180,90,30,.88); color: #fff; }
    .t-site		  { background: rgba(35,77,54,.9);   color: #fff; }
    .t-livre    { background: rgba(100,75,160,.88); color: #fff; }
    .t-billet   { background: rgba(160,115,30,.88); color: #fff; }

    .rc-body { padding: 1.1rem 1.2rem .8rem; flex: 1; }
    .rc-body h3 {
      font-family: 'Lora', serif; font-size: .97rem; font-weight: 600;
      color: var(--ink); line-height: 1.38; margin-bottom: .45rem;
      transition: color var(--t);
    }
    .rc:hover h3 { color: var(--forest); }
    .rc-body p { font-size: .78rem; color: var(--muted); line-height: 1.6; margin: 0; }
    .rc-tags { display: flex; gap: .35rem; flex-wrap: wrap; margin-top: .7rem; }
    .rtag { background: var(--cream); color: var(--muted); font-size: .62rem; font-weight: 500; padding: .14rem .5rem; border-radius: 4px; }

    .rc-foot {
      padding: .75rem 1.2rem;
      border-top: 1px solid var(--border);
      display: flex; align-items: center; justify-content: space-between;
      background: var(--paper); gap: .4rem;
    }
    .rc-meta { font-size: .7rem; color: var(--muted); display: flex; gap: .4rem; align-items: center; }
    .rc-meta .sep { opacity: .35; }
    .rc-acts { display: flex; gap: .35rem; }
    .ract {
      width: 28px; height: 28px; border-radius: var(--r-sm);
      border: 1px solid var(--border); background: var(--white);
      display: grid; place-items: center; font-size: .78rem; color: var(--muted);
      cursor: pointer; transition: all var(--t);
    }
    .ract:hover { background: var(--forest); color: var(--white); border-color: var(--forest); }
    .ract.on { background: var(--lime); color: var(--pine); border-color: var(--mint); }
    .btn-open {
      background: var(--forest); color: var(--white);
      font-size: .7rem; font-weight: 700;
      padding: .32rem .8rem; border-radius: var(--r-sm);
      border: none; display: flex; align-items: center; gap: .28rem;
      cursor: pointer; transition: background var(--t);
      white-space: nowrap;
    }
    .btn-open:hover { background: var(--pine); }

    /* ══════════ LIST ROW ══════════ */
    .rrow {
      background: var(--white);
      border: 1px solid var(--border); border-radius: var(--r-md);
      padding: .9rem 1.1rem;
      display: flex; align-items: center; gap: .9rem;
      margin-bottom: .55rem;
      transition: box-shadow var(--t), border-color var(--t);
    }
    .rrow:hover { box-shadow: var(--shadow-md); border-color: var(--mint); }
    .rrow-ico {
      width: 40px; height: 40px; border-radius: var(--r-sm);
      display: grid; place-items: center; font-size: 1.05rem; flex-shrink: 0;
    }
    .rrow-body { flex: 1; min-width: 0; }
    .rrow-body h4 {
      font-family: 'Lora', serif; font-size: .92rem; font-weight: 600;
      color: var(--ink); margin: 0 0 .22rem;
      white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    }
    .rrow-meta { font-size: .7rem; color: var(--muted); display: flex; gap: .45rem; flex-wrap: wrap; align-items: center; }
    .rrow-acts { display: flex; gap: .35rem; flex-shrink: 0; align-items: center; }

    /* ══════════ PAGINATION ══════════ */
    .pagination { display: flex; justify-content: center; gap: .35rem; margin: 2rem auto; }
    .pbtn {
      width: 34px; height: 34px; border: 1px solid var(--border); border-radius: var(--r-sm);
      background: var(--white); color: var(--muted); font-size: .8rem;
      font-family: 'Sora', sans-serif; display: grid; place-items: center;
      cursor: pointer; transition: all var(--t);
    }
    .pbtn:hover { border-color: var(--sage); color: var(--forest); }
    .pbtn.active { background: var(--forest); color: var(--white); border-color: var(--forest); }
    .pbtn.wide { width: auto; padding: 0 .8rem; }

    /* ══════════ FOOTER ══════════ */
    footer {
      background: var(--ink);
      color: rgba(255,255,255,.5);
      padding: 52px 0 28px;
    }
    .ft-grid {
      /*display: grid;
      gap: 2rem;*/
      padding-bottom: 2.2rem;
      border-bottom: 1px solid rgba(255,255,255,.07);
    }
    /*@media(max-width:768px){ .ft-grid{ grid-template-columns:1fr 1fr; } }
    @media(max-width:480px){ .ft-grid{ grid-template-columns:1fr; } }*/
    .ft-brand { display: flex; align-items: center; gap: .5rem; margin-bottom: .6rem; }
    .ft-brand .brand-text { color: var(--white); }
    .ft-tagline { font-size: .78rem; color: rgba(255,255,255,.35); line-height: 1.6; }
    .ft-h { font-size: .7rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: rgba(255,255,255,.28); margin-bottom: .85rem; }
		@media (max-width: 991.98px) { 
			footer .ft-h {
				margin: .85rem auto;
			}
		}
    .ft-links { list-style: none; padding: 0; margin: 0; }
    .ft-links li { margin-bottom: .42rem; }
    .ft-links a { font-size: .8rem; color: rgba(255,255,255,.48); transition: color var(--t); }
    .ft-links a:hover { color: var(--mint); }
    .ft-bottom {
      /*display: flex; */align-items: center; justify-content: space-between;
      flex-wrap: wrap; gap: .5rem; margin-top: 1.6rem; font-size: .7rem;
    }
    .soc-row { display: flex; gap: .45rem; }
    .soc {
      width: 32px; height: 32px; border-radius: var(--r-sm);
      border: 1px solid rgba(255,255,255,.1); display: grid; place-items: center;
      color: rgba(255,255,255,.38); font-size: 1.2rem; transition: all var(--t);
    }
    .soc:hover { border-color: var(--mint); color: var(--mint); }

    /* ══════════ PAGE DOCUMENT ══════════ */

    /* ─ Barre de progression de lecture ─ */
    .reading-bar {
      position: fixed; top: 0; left: 0;
      height: 3px; background: var(--sage);
      z-index: 9999; width: 0;
      transition: width .1s linear;
    }

    /* ─ Hero document ─ */
    .doc-hero {
      position: relative;
      height: 340px;
      display: flex;
      align-items: flex-end;
      overflow: hidden;
    }
    .doc-hero-bg {
      position: absolute; inset: 0;
      background-size: cover;
      background-position: center 55%;
      filter: brightness(.45) saturate(.85);
      transition: transform 8s ease;
    }
    /*.doc-hero:hover .doc-hero-bg { transform: scale(1.025); }*/
    .doc-hero-overlay {
      position: absolute; inset: 0;
      background: linear-gradient(to top, rgba(10,25,15,.92) 0%, rgba(10,25,15,.35) 55%, transparent 100%);
    }
    .doc-hero-grain {
      position: absolute; inset: 0; opacity: .035;
      background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
      background-size: 200px; pointer-events: none;
    }
    .doc-hero-content { position: relative; z-index: 2; padding-bottom: 2rem; width: 100%; }

    /* ─ Fil d'Ariane ─ */
    .breadcrumb-doc { display: flex; align-items: center; gap: .4rem; font-size: .7rem; color: rgba(255,255,255,.5); margin-bottom: 1rem; flex-wrap: wrap; }
    .breadcrumb-doc a { color: rgba(255,255,255,.55); transition: color var(--t); }
    .breadcrumb-doc a:hover { color: var(--mint); }
    .breadcrumb-doc i { font-size: .6rem; opacity: .4; }

    /* ─ Badge de type sur le hero ─ */
    .hero-type { display: inline-flex; align-items: center; gap: .35rem; font-size: .65rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; padding: .25rem .7rem; border-radius: 50px; margin-bottom: .75rem; }

    .doc-hero h1 {
      font-family: 'Lora', serif;
      font-size: clamp(1.5rem, 3.5vw, 2.4rem);
      font-weight: 600; color: var(--white);
      line-height: 1.2; margin-bottom: .6rem;
      max-width: 780px;
    }
    .doc-hero-meta { display: flex; align-items: center; gap: .65rem; flex-wrap: wrap; font-size: .75rem; color: rgba(255,255,255,.55); }
    .doc-hero-meta .sep { opacity: .3; }
    .doc-hero-meta strong { color: rgba(255,255,255,.85); }

    /* ─ Layout principal ─ */
    .doc-layout { padding: 44px 0 80px; }

    /* ─ Cartes de contenu éditorial ─ */
    .content-card {
      background: var(--white);
      border: 1px solid var(--border);
      border-radius: var(--r-lg);
      overflow: hidden;
      margin-bottom: 1.4rem;
    }
    .cc-head {
      padding: 1rem 1.4rem;
      border-bottom: 1px solid var(--border);
      display: flex; align-items: center; justify-content: space-between;
    }
    .cc-title { font-size: .72rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); display: flex; align-items: center; gap: .4rem; }
    .cc-body { padding: 1.4rem; }

    /* ─ Résumé / texte éditorial ─ */
    .abstract-text {
      font-family: 'Lora', serif;
      font-size: 1rem; font-weight: 400;
      color: var(--ink); line-height: 1.8;
      border-left: 3px solid var(--sage);
      padding-left: 1.2rem;
      margin-bottom: 1.2rem;
      font-style: italic;
    }
    /*.doc-body-text { font-size: .9rem; color: #3a4a3d; line-height: 1.75; }
    .doc-body-text p { margin-bottom: .9rem; }
    .doc-body-text p:last-child { margin-bottom: 0; }*/
		
		#section-main-content, table { font-size: .9rem; color: #3a4a3d; line-height: 1.75; }
    #section-main-content p { margin-bottom: .9rem; }
    #section-main-content p:last-child { margin-bottom: 0; }

    /* ─ Tags documentaires ─ */
    .tags-wrap { display: flex; gap: .45rem; flex-wrap: wrap; }
    .dtag {
      background: var(--cream); color: var(--muted);
      font-size: .72rem; font-weight: 500;
      padding: .3rem .75rem; border-radius: 50px;
      border: 1px solid var(--border);
      transition: background var(--t), color var(--t), border-color var(--t);
			text-decoration: none;
      cursor: pointer;
    }
    .dtag:hover { background: var(--lime); color: var(--pine); border-color: var(--mint); }
    .dtag.primary { background: var(--lime); color: var(--pine); border-color: var(--mint); font-weight: 600; }

    /* ─ Tableau de métadonnées ─ */
    .meta-table { width: 100%; border-collapse: collapse; }
    .meta-table tr { border-bottom: 1px solid var(--border); }
    .meta-table tr:last-child { border-bottom: none; }
    .meta-table td { padding: .65rem 0; font-size: .82rem; vertical-align: top; }
    .meta-table td:first-child { color: var(--muted); font-weight: 500; width: 38%; white-space: nowrap; padding-right: 1rem; }
    .meta-table td:last-child { color: var(--ink); }
    .meta-table a { color: var(--sage); }
    .meta-table a:hover { text-decoration: underline; }

    /* ─ Bloc lien source externe ─ */
    .source-link-wrap {
      background: var(--cream); border: 1px solid var(--border);
      border-radius: var(--r-md); padding: .9rem 1.1rem;
      display: flex; align-items: center; gap: .75rem;
    }
    .source-link-icon { width: 40px; height: 40px; background: var(--lime); border-radius: var(--r-sm); display: grid; place-items: center; font-size: 1.1rem; color: var(--sage); flex-shrink: 0; }
    .source-link-label { font-size: .72rem; color: var(--muted); }
    .source-link-url { font-size: .82rem; font-weight: 600; color: var(--forest); word-break: break-all; }
    .btn-ext { background: var(--sage); color: var(--white); font-size: .75rem; font-weight: 700; padding: .42rem 1rem; border-radius: var(--r-sm); border: none; cursor: pointer; white-space: nowrap; display: flex; align-items: center; gap: .3rem; margin-left: auto; flex-shrink: 0; transition: background var(--t); }
    .btn-ext:hover { background: var(--pine); }

    /* ─ Carte de téléchargement ─ */
    .dl-card {
      background: var(--white);
      border: 1px solid var(--border);
      border-radius: var(--r-lg);
      overflow: hidden;
      margin-bottom: 1.4rem;
      position: sticky;
      top: 76px;
    }
    .dl-thumb { height: 180px; position: relative; overflow: hidden; }
    .dl-thumb img { width: 100%; height: 100%; object-fit: contain; /*filter: brightness(.6) saturate(.85);*/ transition: transform .4s; }
    .dl-card:hover .dl-thumb img { transform: scale(1.04); }
    .dl-thumb-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(10,25,15,.75) 0%, transparent 55%); }
    .dl-thumb-badge { position: absolute; bottom: 10px; left: 12px; display: flex; align-items: center; gap: .4rem; }
    .dl-format-pill { background: rgba(255,255,255,.15); backdrop-filter: blur(6px); border: 1px solid rgba(255,255,255,.2); color: var(--white); font-size: .65rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; padding: .22rem .65rem; border-radius: 50px; }
    .dl-body { padding: 1.2rem 1.3rem 1rem; }
    .dl-title { font-family: 'Lora', serif; font-size: .95rem; font-weight: 600; color: var(--ink); line-height: 1.35; margin-bottom: .6rem; }
    .dl-meta-row { display: flex; gap: .5rem; font-size: .72rem; color: var(--muted); margin-bottom: 1rem; flex-wrap: wrap; }
    .dl-meta-sep { opacity: .35; }

    /* ─ Boutons de téléchargement ─ */
    .btn-dl-primary {
      width: 100%; background: var(--forest); color: var(--white);
      font-family: 'Sora', sans-serif; font-size: .88rem; font-weight: 700;
      padding: .8rem 1rem; border-radius: var(--r-md); border: none;
      display: flex; align-items: center; justify-content: center; gap: .5rem;
      cursor: pointer; transition: background var(--t), transform var(--t);
      margin-bottom: .6rem;
    }
    .btn-dl-primary:hover { background: var(--pine); transform: translateY(-1px); }
    .btn-dl-ghost {
      width: 100%; background: transparent; color: var(--forest);
      font-family: 'Sora', sans-serif; font-size: .8rem; font-weight: 600;
      padding: .6rem 1rem; border-radius: var(--r-md);
      border: 1.5px solid var(--border);
      display: flex; align-items: center; justify-content: center; gap: .45rem;
      cursor: pointer; transition: border-color var(--t), background var(--t);
    }
    .btn-dl-ghost:hover { border-color: var(--sage); background: var(--lime); }

    /* ─ Rangée d'actions (Sauvegarder / Partager / Imprimer) ─ */
    .action-row { display: flex; gap: .5rem; margin: .9rem 0 .5rem; }
    .action-btn {
      flex: 1; background: var(--paper); border: 1px solid var(--border); border-radius: var(--r-sm);
      color: var(--muted); font-size: .75rem; font-family: 'Sora', sans-serif;
      font-weight: 500; padding: .5rem .4rem;
      display: flex; align-items: center; justify-content: center; gap: .3rem;
      cursor: pointer; transition: all var(--t);
    }
    .action-btn:hover { background: var(--lime); color: var(--forest); border-color: var(--mint); }
    .action-btn.saved { background: var(--lime); color: var(--pine); border-color: var(--mint); }

    /* ─ Avertissement droits d'auteur ─ */
    .disclaimer {
      background: rgba(245,164,42,.07);
      border: 1px solid rgba(245,164,42,.3);
      border-radius: var(--r-sm);
      padding: .8rem .9rem;
      font-size: .72rem; color: #7a5a10; line-height: 1.55;
      display: flex; gap: .5rem; margin-top: .6rem;
    }
    .disclaimer i { color: var(--amber); font-size: .9rem; flex-shrink: 0; margin-top: .05rem; }

    /* ─ Statistiques carte DL ─ */
    .dl-stats { display: flex; justify-content: space-around; padding: .9rem 0; border-top: 1px solid var(--border); margin-top: .5rem; }
    .dl-stat { text-align: center; }
    .dl-stat-num { font-family: 'Lora', serif; font-size: 1.1rem; font-weight: 600; color: var(--forest); }
    .dl-stat-lbl { font-size: .63rem; color: var(--muted); margin-top: .1rem; }

    /* ─ Widgets sidebar ─ */
    .widget { background: var(--white); border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; margin-bottom: 1rem; }
    .widget-head { padding: .8rem 1.1rem; border-bottom: 1px solid var(--border); font-size: .72rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); display: flex; align-items: center; gap: .4rem; }
    .widget-body { padding: .8rem 1rem; }

    /* ─ Ressources similaires ─ */
    .related-card { display: flex; gap: .7rem; align-items: flex-start; padding: .65rem 0; border-bottom: 1px solid var(--border); transition: opacity var(--t); }
    .related-card:last-child { border-bottom: none; padding-bottom: 0; }
    .related-card:hover { opacity: .8; }
    .related-thumb { width: 60px; height: 56px; border-radius: var(--r-sm); overflow: hidden; flex-shrink: 0; }
    .related-thumb img { width: 100%; height: 100%; object-fit: cover; filter: brightness(.8); }
    .related-type { font-size: .6rem; font-weight: 700; color: var(--sage); letter-spacing: .07em; text-transform: uppercase; }
    .related-title { font-family: 'Lora', serif; font-size: .82rem; font-weight: 600; color: var(--ink); line-height: 1.3; margin-top: .1rem; }
    .related-org { font-size: .67rem; color: var(--muted); margin-top: .15rem; }

    /* ─ Widget newsletter compact ─ */
    .nl-widget { background: linear-gradient(135deg, var(--forest), #0F2B1C); border-radius: var(--r-lg); padding: 1.3rem; margin-bottom: 1rem; }
    .nl-widget-title { font-family: 'Lora', serif; font-size: 1rem; font-weight: 600; color: var(--white); margin-bottom: .35rem; }
    .nl-widget-sub { font-size: .75rem; color: rgba(255,255,255,.55); line-height: 1.5; margin-bottom: .9rem; }
    .nl-input { width: 100%; background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.18); color: var(--white); font-family: 'Sora', sans-serif; font-size: .8rem; padding: .55rem .85rem; border-radius: var(--r-sm); outline: none; margin-bottom: .5rem; }
    .nl-input::placeholder { color: rgba(255,255,255,.4); }
    .nl-input:focus { border-color: var(--mint); background: rgba(255,255,255,.15); }
    .btn-nl { width: 100%; background: var(--sage); color: var(--white); font-family: 'Sora', sans-serif; font-size: .8rem; font-weight: 700; padding: .55rem 1rem; border-radius: var(--r-sm); border: none; cursor: pointer; transition: background var(--t); }
    .btn-nl:hover { background: var(--sage-lt); }

    /* ─ Modal de téléchargement ─ */
    .dl-modal-bg {
      display: none;
      position: fixed; inset: 0;
      background: rgba(10,25,15,.55);
      backdrop-filter: blur(4px);
      z-index: 1050;
      align-items: center; justify-content: center;
    }
    .dl-modal-bg.open { display: flex; }
    .dl-modal { background: var(--white); border-radius: var(--r-lg); max-width: 480px; width: 90%; box-shadow: var(--shadow-lg); overflow: hidden; animation: popIn .25s cubic-bezier(.34,1.56,.64,1); }
    @keyframes popIn { from{transform:scale(.88);opacity:0} to{transform:scale(1);opacity:1} }
    .dl-modal-head { background: var(--forest); padding: 1.2rem 1.4rem; }
    .dl-modal-head h4 { font-family: 'Lora', serif; color: var(--white); font-size: 1.05rem; margin: 0; }
    .dl-modal-body { padding: 1.3rem 1.4rem; }
    .dl-modal-body p { font-size: .84rem; color: var(--muted); line-height: 1.65; margin-bottom: .9rem; }
    .dl-modal-body p:last-of-type { margin-bottom: 0; }
    .dl-modal-warn { background: rgba(245,164,42,.08); border: 1px solid rgba(245,164,42,.3); border-radius: var(--r-sm); padding: .75rem .9rem; font-size: .78rem; color: #7a5a10; line-height: 1.55; display: flex; gap: .5rem; margin-bottom: 1.1rem; }
    .dl-modal-warn i { color: var(--amber); flex-shrink: 0; margin-top: .05rem; }
    .dl-modal-actions { display: flex; gap: .6rem; flex-wrap: wrap; }
    .btn-modal-accept { flex: 1; background: var(--forest); color: var(--white); font-family: 'Sora', sans-serif; font-size: .82rem; font-weight: 700; padding: .7rem 1rem; border-radius: var(--r-md); border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; gap: .4rem; transition: background var(--t); }
    .btn-modal-accept:hover { background: var(--pine); }
    .btn-modal-refuse { flex: 1; background: var(--paper); color: var(--muted); font-family: 'Sora', sans-serif; font-size: .82rem; font-weight: 500; padding: .7rem 1rem; border-radius: var(--r-md); border: 1px solid var(--border); cursor: pointer; transition: background var(--t); }
    .btn-modal-refuse:hover { background: var(--cream); }

    /* ─ Notation par étoiles ─ */
    .rating-stars { display: flex; gap: .2rem; }
    .star { font-size: 1.1rem; color: var(--amber); cursor: pointer; transition: transform var(--t); }
    .star:hover { transform: scale(1.25); }
    .star.empty { color: var(--border); }

    /* ──────── Responsive page document ──────── */
    @media(max-width:991px){ .dl-card { position: static; } }
    @media(max-width:767px){ .doc-hero { height: 280px; } .doc-hero h1 { font-size: 1.4rem; } }

    /* ══════════ ANIMATIONS ══════════ */
    .fade-up { opacity: 0; transform: translateY(16px); transition: opacity .5s ease, transform .5s ease; }
    .fade-up.in { opacity: 1; transform: translateY(0); }

    @media(max-width:991px){
      .sidebar { position: static; }
      .nav-tabs-bar { display: none; }
    }
    @media(max-width:767px){
      .hero-photo { min-height: 420px; }
      .hero-content { padding: 56px 0 52px; }
    }

#divLoading {
	text-align: center;
	display: none;
}

.hidden {
	display: none;
}

.img-404 {
	max-height: 170px;
	float: left;
	margin: 8px;
}

.float-right {
	float: right;
}

.float-left {
	float: left;
}

h2 {
	font-size: 1.33rem;
}

h3 {
	font-size: 1.25rem;
}