.elementor-31707 .elementor-element.elementor-element-f40790f{--display:flex;box-shadow:0px 0px 10px 0px rgba(0,0,0,0.5);--padding-top:120px;--padding-bottom:40px;--padding-left:80px;--padding-right:80px;}.elementor-31707 .elementor-element.elementor-element-f40790f:not(.elementor-motion-effects-element-type-background), .elementor-31707 .elementor-element.elementor-element-f40790f > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:transparent;background-image:linear-gradient(180deg, #EEEEEEFC 0%, #357A6AF0 0%);}.elementor-widget-heading .elementor-heading-title{color:var( --e-global-color-primary );}.elementor-31707 .elementor-element.elementor-element-4fbe443 .elementor-heading-title{color:#4EB39B24;}.elementor-31707 .elementor-element.elementor-element-00481ae{--display:flex;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-31707 .elementor-element.elementor-element-97a6591{--display:flex;--padding-top:0px;--padding-bottom:80px;--padding-left:20px;--padding-right:20px;}.elementor-31707 .elementor-element.elementor-element-2d18043{--display:flex;--padding-top:80px;--padding-bottom:80px;--padding-left:20px;--padding-right:20px;}.elementor-31707 .elementor-element.elementor-element-2d18043:not(.elementor-motion-effects-element-type-background), .elementor-31707 .elementor-element.elementor-element-2d18043 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:transparent;background-image:linear-gradient(160deg, #0E2B25 0%, #193D35 100%);}.elementor-31707 .elementor-element.elementor-element-3a9c28d{--display:flex;--padding-top:80px;--padding-bottom:80px;--padding-left:20px;--padding-right:20px;}.elementor-31707 .elementor-element.elementor-element-41f0dea{--display:flex;--padding-top:0px;--padding-bottom:80px;--padding-left:20px;--padding-right:20px;}.elementor-31707 .elementor-element.elementor-element-5d13be9{--display:flex;--padding-top:80px;--padding-bottom:80px;--padding-left:20px;--padding-right:20px;}.elementor-31707 .elementor-element.elementor-element-5d13be9:not(.elementor-motion-effects-element-type-background), .elementor-31707 .elementor-element.elementor-element-5d13be9 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:transparent;background-image:linear-gradient(160deg, #0E2B25 0%, #193D35 100%);}.elementor-31707 .elementor-element.elementor-element-6d3e2a6{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:80px;--padding-bottom:80px;--padding-left:20px;--padding-right:20px;}.elementor-31707 .elementor-element.elementor-element-484206f{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:80px;--padding-bottom:80px;--padding-left:20px;--padding-right:20px;}.elementor-31707 .elementor-element.elementor-element-35d5763{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:80px;--padding-bottom:80px;--padding-left:20px;--padding-right:20px;}.elementor-31707 .elementor-element.elementor-element-d1ab9ee{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:80px;--padding-bottom:80px;--padding-left:20px;--padding-right:20px;}:root{--page-title-display:none;}body.elementor-page-31707 #main.site-main{z-index:0;}@media(max-width:1440px){.elementor-31707 .elementor-element.elementor-element-f40790f{--padding-top:120px;--padding-bottom:40px;--padding-left:20px;--padding-right:20px;}.elementor-31707 .elementor-element.elementor-element-97a6591{--padding-top:0px;--padding-bottom:60px;--padding-left:20px;--padding-right:20px;}.elementor-31707 .elementor-element.elementor-element-2d18043{--padding-top:60px;--padding-bottom:60px;--padding-left:20px;--padding-right:20px;}.elementor-31707 .elementor-element.elementor-element-3a9c28d{--padding-top:60px;--padding-bottom:60px;--padding-left:20px;--padding-right:20px;}.elementor-31707 .elementor-element.elementor-element-41f0dea{--padding-top:0px;--padding-bottom:40px;--padding-left:20px;--padding-right:20px;}.elementor-31707 .elementor-element.elementor-element-5d13be9{--padding-top:60px;--padding-bottom:60px;--padding-left:20px;--padding-right:20px;}.elementor-31707 .elementor-element.elementor-element-6d3e2a6{--padding-top:60px;--padding-bottom:60px;--padding-left:20px;--padding-right:20px;}.elementor-31707 .elementor-element.elementor-element-484206f{--padding-top:60px;--padding-bottom:60px;--padding-left:20px;--padding-right:20px;}.elementor-31707 .elementor-element.elementor-element-35d5763{--padding-top:60px;--padding-bottom:60px;--padding-left:20px;--padding-right:20px;}.elementor-31707 .elementor-element.elementor-element-d1ab9ee{--padding-top:60px;--padding-bottom:60px;--padding-left:20px;--padding-right:20px;}}@media(max-width:767px){.elementor-31707 .elementor-element.elementor-element-97a6591{--padding-top:0px;--padding-bottom:60px;--padding-left:0px;--padding-right:0px;}}/* Start custom CSS */:root {
    --black: #0d0d0d;
    --white: #ffffff;
    --off-white: #f4f7f6;
    --orange: #f09835;
    --orange-dim: #c97820;
    --teal: #4eb39b;
    --teal-dark: #357a6a;
    --teal-bg: #0e2b25;
    --teal-dim: rgba(78,179,155,.12);
    --gray-light: #eef2f1;
    --gray-mid: #8fa39d;
    --gray-dark: #3a4a46;
    --text: #1a2622;
    --serif: 'Montserrat', sans-serif;
    --body: 'Raleway', sans-serif;
    --mono: 'Montserrat', monospace;
  }

/* ── HERO ── */
  .hero {
    background: linear-gradient(135deg, #071a15 0%, #0b2a22 50%, #0e3530 100%);
  }
  .textback {
    position: absolute !important; bottom: -1.5rem !important; right: -1rem !important; font-size: 14vw; font-weight: 800;
    color: rgba(78,179,155,.08); line-height: 1; pointer-events: none;
    white-space: nowrap;
  }
  .hero-breadcrumb {
    font-family: var(--mono); font-size: .72rem; color: var(--teal);
    letter-spacing: .12em; text-transform: uppercase; margin-bottom: 1.5rem;
  }
  .hero-breadcrumb a { color: var(--gray-mid); text-decoration: none; }
  .hero-breadcrumb a:hover { color: var(--orange); }
  .hero-acronym {
    font-family: var(--mono); font-size: .9rem; font-weight: 500;
    color: var(--teal); letter-spacing: .15em; text-transform: uppercase;
    background: rgba(78,179,155,.15); display: inline-block;
    padding: .3rem .9rem; border-left: 3px solid var(--teal); margin-bottom: 1.5rem;
  }
  .hero h1 {
    font-family: var(--serif); font-weight: 800; font-size: clamp(1.8rem, 4vw, 3.2rem);
    color: #ffffff; line-height: 1.15; max-width: 820px;
    margin-bottom: 1.5rem;
    text-shadow: 0 2px 16px rgba(0,0,0,.6), 0 1px 4px rgba(0,0,0,.8);
  }
  .hero h1 em { color: var(--orange); font-style: normal; text-shadow: 0 2px 12px rgba(0,0,0,.5); }
  .hero-meta {
    display: flex; flex-wrap: wrap; gap: 1.5rem; margin-top: 2.5rem;
  }
  .hero-meta-item {
    display: flex; flex-direction: column; gap: .2rem;
  }
  .hero-meta-label {
    font-family: var(--mono); font-size: .65rem; color: rgba(255,255,255,.5);
    letter-spacing: .12em; text-transform: uppercase;
  }
  .hero-meta-value {
    font-size: .9rem; color: var(--white); font-weight: 500;
  }
  .hero-scroll {
    display: flex; align-items: center; gap: .6rem; margin-top: 3rem;
    color: rgba(255,255,255,.4); font-size: .78rem; letter-spacing: .08em;
    text-transform: uppercase; font-family: var(--mono);
  }
  .hero-scroll span { display: inline-block; width: 40px; height: 1px; background: rgba(255,255,255,.4); }
  
  /* ── STICKY SUBNAV ── */
  .subnav {
    background: var(--off-white);
    border-bottom: 2px solid var(--teal);
    overflow-x: auto;
    white-space: nowrap;
  }
  .subnav ul {
    display: inline-flex; list-style: none; padding: 0 2.5rem;
  }
  .subnav ul li a {
    display: inline-block; padding: .9rem 1.2rem;
    font-family: var(--mono); font-size: .72rem; font-weight: 500;
    color: #4a6660; text-decoration: none; letter-spacing: .08em;
    text-transform: uppercase; border-bottom: 2px solid transparent;
    transition: all .2s; padding-bottom: .1rem;
  }
  .subnav ul li a:hover, .subnav ul li a.active {
    color: var(--teal) !important; border-bottom-color: var(--teal) !important;
  }
  
  
/* ── SECTIONS LAYOUT ── */

  .section-label {
    font-family: var(--mono); font-size: .7rem; color: var(--teal);
    letter-spacing: .15em; text-transform: uppercase;
    margin-bottom: .8rem; display: block;
  }
  .section-title {
    font-family: var(--serif); font-weight: 800; font-size: clamp(1.6rem, 3vw, 2.4rem);
    line-height: 1.1; margin-bottom: 2.5rem;
    border-left: 4px solid var(--orange); padding-left: 1rem;
  }
  .section-divider {
    width: 50px; height: 3px; background: var(--orange); margin: 1.5rem 0;
  }

  
  .two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; }
  .three-col { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; }
  
  /* ── ABOUT ── */
  #about .about-text {
    font-size: 1.05rem; line-height: 1.85; color: var(--gray-dark);
    font-weight: 300;
  }
  #about .about-text p + p { margin-top: 1.2rem; }
  #about .about-text strong { color: var(--text); font-weight: 500; }
  .methodology-box {
    background: linear-gradient(135deg, #0e2b25, #14403a); color: var(--white);
    padding: 2rem 2.5rem; border-left: 4px solid var(--teal);
  }
  .methodology-box h3 {
    font-family: var(--serif); font-size: 1.1rem; color: var(--teal);
    margin-bottom: 1rem; letter-spacing: .04em;
  }
  .methodology-box ul { list-style: none; }
  .methodology-box ul li {
    padding: .5rem 0; border-bottom: 1px solid rgba(255,255,255,.08);
    font-size: .9rem; display: flex; gap: .8rem; align-items: flex-start;
    font-weight: 300; line-height: 1.6;
  }
  .methodology-box ul li::before {
    content: '→'; color: var(--orange); flex-shrink: 0; font-weight: 600;
  }

  /* ── TEAM ── */
  #team { background: linear-gradient(160deg, #0e2b25, #193d35); }
  #team .section-title { color: var(--white); }
  #team .section-label { color: var(--orange); }
  .team-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 2rem; }
  .team-card {
    position: relative; overflow: hidden;
    border: 1px solid rgba(255,255,255,.08);
    transition: transform .3s, border-color .3s;
  }
  .team-card:hover { transform: translateY(-4px); border-color: var(--teal); }
  .team-avatar {
    width: 100%; aspect-ratio: 1;
    background: var(--gray-dark);
    display: flex; align-items: center; justify-content: center;
    overflow: hidden;
  }
  /* Cartoon-style SVG avatar placeholder */
  .avatar-svg {
    width: 80%; height: 80%;
  }
  .team-info { padding: 1.2rem; }
  .team-name {
    font-family: var(--serif); font-size: 1rem; font-weight: 700;
    color: var(--white); margin-bottom: .25rem; line-height: 1.3;
  }
  .team-role {
    font-family: var(--mono); font-size: .65rem; color: var(--teal);
    letter-spacing: .1em; text-transform: uppercase; margin-bottom: .6rem;
  }
  .team-bio {
    font-size: .8rem; color: var(--gray-mid); line-height: 1.6; font-weight: 300;
  }

  /* ── NEWS ── */
  .news-grid { display: grid; gap: 0; border: 1px solid #d0ccc3; }
  .news-item {
    display: grid; grid-template-columns: 80px 1fr auto;
    align-items: start; gap: 1.5rem; padding: 1.5rem;
    border-bottom: 1px solid #d0ccc3; transition: background .2s;
  }
  .news-item:last-child { border-bottom: none; }
  .news-item:hover { background: white; }
  .news-date {
    font-family: var(--mono); font-size: .7rem; color: var(--orange);
    letter-spacing: .06em; line-height: 1.4; text-transform: uppercase;
  }
  .news-title {
    font-family: var(--serif); font-size: 1rem; font-weight: 700;
    line-height: 1.35; margin-bottom: .3rem;
  }
  .news-excerpt { font-size: .82rem; color: var(--gray-dark); line-height: 1.6; font-weight: 300; }
  .news-tag {
    font-family: var(--mono); font-size: .62rem; letter-spacing: .1em;
    text-transform: uppercase; padding: .2rem .6rem;
    background: var(--orange); color: var(--black); white-space: nowrap; font-weight: 500;
  }

  /* ── POLICY BRIEFS ── */
  .pb-card {
    background: white; border: 1px solid #d0ccc3;
    padding: 1.5rem; position: relative; overflow: hidden;
    transition: box-shadow .3s;
  }
  .pb-card-2, .pb-card-3 {
    display: none;
  }
  .pb-card:hover { box-shadow: 5px 5px 0 var(--teal); }
  .pb-card::before {
    content: 'PB'; position: absolute; top: -1rem; right: -0.5rem;
    font-family: var(--serif); font-size: 4rem; font-weight: 800;
    color: rgba(240,152,53,.07); line-height: 1;
  }
  .pb-number {
    font-family: var(--mono); font-size: .65rem; color: var(--teal);
    letter-spacing: .12em; text-transform: uppercase; margin-bottom: .5rem;
  }
  .pb-title {
    font-family: var(--serif); font-size: 1rem; font-weight: 700;
    line-height: 1.35; margin-bottom: .8rem;
  }
  .pb-authors { font-size: .78rem; color: var(--gray-mid); margin-bottom: 1rem; font-style: italic; }
  .pb-actions { display: flex; gap: .5rem; flex-wrap: wrap; }
  .btn {
    display: inline-flex; align-items: center; gap: .4rem;
    font-family: var(--mono); font-size: .68rem; font-weight: 500;
    letter-spacing: .08em; text-transform: uppercase; padding: .45rem .9rem;
    text-decoration: none; transition: all .2s; cursor: pointer;
  }
  .btn-primary { background: var(--orange); color: var(--black); border: 1px solid var(--orange); }
  .btn-primary:hover { background: var(--orange-dim); border-color: var(--orange-dim); }
  .btn-outline { background: transparent; color: var(--teal-dark); border: 1px solid var(--teal); }
  .btn-outline:hover { background: var(--teal); color: var(--white); border-color: var(--teal); }

  /* ── AUDIO WOLOF ── */
  #audio { background: linear-gradient(160deg, #0e2b25, #193d35); }
  #audio .section-title { color: var(--white); }
  .audio-grid { display: grid; gap: 1rem; }
  .audio-card {
    display: grid; grid-template-columns: 60px 1fr auto;
    align-items: center; gap: 1.2rem;
    background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08);
    padding: 1rem 1.2rem; transition: border-color .2s;
  }
  .audio-card:hover { border-color: var(--teal); }
  .audio-play {
    width: 44px; height: 44px; border-radius: 50%;
    background: var(--teal); border: none; cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    color: var(--black); font-size: 1rem; flex-shrink: 0;
    transition: background .2s;
  }
  .audio-play:hover { background: var(--teal-dark); }
  .audio-title {
    font-family: var(--serif); font-size: .95rem; color: var(--white);
    font-weight: 600; margin-bottom: .2rem;
  }
  .audio-subtitle { font-size: .75rem; color: var(--gray-mid); font-weight: 300; }
  .audio-duration {
    font-family: var(--mono); font-size: .75rem; color: var(--gray-mid);
  }
  .wolof-badge {
    display: inline-flex; align-items: center; gap: .4rem;
    background: rgba(78,179,155,.15); border: 1px solid rgba(78,179,155,.3);
    color: var(--teal); padding: .3rem .7rem; margin-bottom: 1.5rem;
    font-family: var(--mono); font-size: .68rem; letter-spacing: .1em; text-transform: uppercase;
  }

  /* ── FORUM ── */
  .forum-intro {
    font-size: 1rem; color: var(--gray-dark); line-height: 1.75;
    font-weight: 300; max-width: 700px; margin-bottom: 2rem;
  }
  .forum-prompts { display: grid; gap: 1rem; margin-bottom: 2.5rem; }
  .forum-prompt {
    background: white; border: 1px solid #d0ccc3; border-left: 3px solid var(--teal);
    padding: 1.2rem 1.5rem; cursor: pointer; transition: all .2s;
  }
  .forum-prompt:hover { background: var(--off-white); transform: translateX(4px); }
  .forum-prompt-q {
    font-family: var(--serif); font-size: 1rem; font-weight: 700;
    margin-bottom: .3rem;
  }
  .forum-prompt-sub { font-size: .8rem; color: var(--gray-mid); font-weight: 300; }
  .forum-box {
    background: white; border: 1px solid #d0ccc3; padding: 1.5rem;
  }
  .forum-box h4 {
    font-family: var(--serif); font-size: 1rem; font-weight: 700;
    margin-bottom: 1rem; color: var(--text);
  }
  .forum-selected-q {
    font-family: var(--body); font-size: .9rem; color: var(--orange);
    font-style: italic; margin-bottom: 1rem; padding: .8rem 1rem;
    background: rgba(240,152,53,.06); border-left: 3px solid var(--orange);
    display: none;
  }
  .forum-textarea {
    width: 100%; min-height: 120px; padding: .9rem 1rem;
    font-family: var(--body); font-size: .9rem;
    border: 1px solid #d0ccc3; resize: vertical; outline: none;
    background: var(--white); color: var(--text);
    transition: border-color .2s;
  }
  .forum-textarea:focus { border-color: var(--teal); }
  .forum-submit { margin-top: .8rem; }

  /* ── BLOG / FIELD NOTES ── */
  #blog { background: var(--gray-light); }
  .blog-header {
    display: flex; align-items: baseline; justify-content: space-between;
    margin-bottom: 2rem; flex-wrap: wrap; gap: 1rem;
  }
  .field-notes-label {
    font-family: var(--mono); font-size: .7rem; color: var(--gray-mid);
    letter-spacing: .12em; text-transform: uppercase;
    border: 1px solid var(--gray-mid); padding: .3rem .8rem;
  }
  .blog-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 1.5rem; }
  .blog-card {
    background: white; overflow: hidden; border: 1px solid #d0ccc3;
    transition: transform .3s, box-shadow .3s;
  }
  .blog-card:hover { transform: translateY(-3px); box-shadow: 0 8px 24px rgba(78,179,155,.15), 0 2px 8px rgba(0,0,0,.08); }
  .blog-img {
    width: 100%; height: 160px; object-fit: cover;
    background: var(--gray-dark); display: flex; align-items: center; justify-content: center;
    overflow: hidden;
  }
  .blog-img-placeholder {
    width: 100%; height: 160px; background: linear-gradient(135deg, var(--gray-dark), #1a1816);
    display: flex; align-items: center; justify-content: center;
    font-family: var(--mono); font-size: .7rem; color: var(--gray-mid);
    letter-spacing: .1em; text-transform: uppercase;
  }
  .blog-body { padding: 1.2rem; }
  .blog-meta {
    font-family: var(--mono); font-size: .65rem; color: var(--teal);
    letter-spacing: .1em; text-transform: uppercase; margin-bottom: .5rem;
  }
  .blog-title {
    font-family: var(--serif); font-size: 1rem; font-weight: 700;
    line-height: 1.3; margin-bottom: .5rem;
  }
  .blog-excerpt { font-size: .82rem; color: var(--gray-dark); line-height: 1.6; font-weight: 300; }
  .blog-author { margin-top: .8rem; font-size: .75rem; color: var(--gray-mid); font-style: italic; }

  /* ── SELF-EVALUATION TOOL ── */
  #eval { background: linear-gradient(160deg, #0e2b25, #193d35); }
  #eval .section-title { color: var(--white); }
  .eval-intro {
    font-size: .95rem; color: var(--gray-mid); line-height: 1.8;
    font-weight: 300; max-width: 680px; margin-bottom: 2.5rem;
  }
  .eval-form { max-width: 750px; }
  .eval-question {
    margin-bottom: 2rem; padding-bottom: 2rem;
    border-bottom: 1px solid rgba(255,255,255,.06);
  }
  .eval-question:last-of-type { border-bottom: none; }
  .eval-q-text {
    font-family: var(--serif); font-size: 1rem; font-weight: 600;
    color: var(--white); margin-bottom: 1rem; line-height: 1.4;
  }
  .eval-options { display: flex; flex-direction: column; gap: .6rem; }
  .eval-option {
    display: flex; align-items: center; gap: .8rem;
    padding: .7rem 1rem; border: 1px solid rgba(255,255,255,.1);
    cursor: pointer; transition: all .2s; color: var(--gray-mid); font-size: .88rem;
  }
  .eval-option input[type="radio"] { accent-color: var(--orange); }
  .eval-option:hover, .eval-option:has(input:checked) {
    background: rgba(78,179,155,.1); border-color: var(--teal); color: var(--white);
  }
  .eval-submit-btn {
    width: 100%; padding: 1rem; background: var(--teal); color: var(--white);
    border: none; font-family: var(--serif); font-size: 1rem; font-weight: 700;
    cursor: pointer; letter-spacing: .06em; transition: background .2s; margin-top: 1rem;
  }
  .eval-submit-btn:hover { background: var(--teal-dark); }
  .eval-result { display: none; margin-top: 2rem; }
  .eval-result-box {
    padding: 2rem; border: 2px solid; text-align: center;
  }
  .eval-result-box.colonial { border-color: #e63946; }
  .eval-result-box.not-colonial { border-color: var(--teal); }
  .eval-result-box.ambiguous { border-color: var(--orange); }
  .eval-result-title {
    font-family: var(--serif); font-size: 2rem; font-weight: 800;
    margin-bottom: .8rem;
  }
  .eval-result-title.colonial { color: #e63946; }
  .eval-result-title.not-colonial { color: #4eb39b; }
  .eval-result-title.ambiguous { color: var(--orange); }
  .eval-result-desc { font-size: .9rem; color: var(--gray-mid); line-height: 1.7; font-weight: 300; }

  /* ── PUBLICATION ── */
  #publication { background: var(--white); }
  .pub-card {
    display: grid; grid-template-columns: 120px 1fr;
    gap: 2rem; background: white; border: 1px solid #d0ccc3;
    padding: 2rem; transition: box-shadow .3s;
  }
  .pub-card:hover { box-shadow: 6px 6px 0 var(--teal); }
  .pub-cover {
    background: var(--black); aspect-ratio: 3/4;
    display: flex; align-items: center; justify-content: center;
    flex-direction: column; gap: .5rem; padding: .8rem; text-align: center;
  }
  .pub-cover-title {
    font-family: var(--serif); font-size: .65rem; font-weight: 700;
    color: var(--white); line-height: 1.3;
  }
  .pub-cover-label {
    font-family: var(--mono); font-size: .55rem; color: var(--teal);
    letter-spacing: .08em; text-transform: uppercase;
  }
  .pub-journal {
    font-family: var(--mono); font-size: .68rem; color: var(--teal);
    letter-spacing: .1em; text-transform: uppercase; margin-bottom: .5rem;
  }
  .pub-title {
    font-family: var(--serif); font-size: 1.15rem; font-weight: 700;
    line-height: 1.3; margin-bottom: .6rem;
  }
  .pub-authors { font-size: .82rem; color: var(--gray-dark); margin-bottom: .4rem; font-style: italic; }
  .pub-abstract {
    font-size: .83rem; color: var(--gray-dark); line-height: 1.65;
    font-weight: 300; margin-bottom: 1.2rem;
  }

  

  /* ── ANIMATIONS ── */
  @keyframes fadeUp {
    from { opacity: 0; transform: translateY(30px); }
    to { opacity: 1; transform: translateY(0); }
  }
  .fade-up { animation: fadeUp .7s ease forwards; }
  .fade-up-delay { animation: fadeUp .7s .2s ease forwards; opacity: 0; }
  .fade-up-delay-2 { animation: fadeUp .7s .4s ease forwards; opacity: 0; }

/* ════════════════════════════
   TABLETTE — max 768px
════════════════════════════ */
@media (max-width: 768px) {

  /* Hero */
  
  .textback { display: none; }
  .hero h1 {
    font-size: clamp(1.5rem, 5vw, 2.4rem);
  }
  .hero-meta { gap: 1rem; }
  .hero-scroll { margin-top: 2rem; }

  /* Subnav */
  .subnav { top: 64px; }
  .subnav ul { padding: 0 1rem; }
  .subnav ul li a { font-size: .65rem; padding: .75rem .8rem; }

  /* Sections */
  section { padding: 3.5rem 1.8rem; }
  .container { padding: 0; }
  .section-title { font-size: clamp(1.3rem, 3.5vw, 2rem); }

  /* About */
  .two-col { grid-template-columns: 1fr; gap: 2rem; }

  /* Team — 2 colonnes */
  .team-grid { grid-template-columns: repeat(2, 1fr); gap: 1.2rem; }

  /* News */
  .news-item { grid-template-columns: 60px 1fr; gap: 1rem; }
  .news-tag { display: none; }

  /* Policy Briefs — 2 colonnes */
  .three-col { grid-template-columns: repeat(2, 1fr); }

  /* Audio */
  .audio-card { grid-template-columns: 50px 1fr; }
  .audio-duration { display: none; }

  /* Blog */
  .blog-header { flex-direction: column; align-items: flex-start; gap: .5rem; }
  .blog-grid { grid-template-columns: repeat(2, 1fr); }

  /* Forum */
  .forum-prompts { gap: .75rem; }
  .forum-box > div:last-of-type {
    flex-direction: column;
  }
  .forum-box > div:last-of-type input[type="text"] {
    width: 100%;
  }
  .forum-box > div:last-of-type .btn {
    width: 100%;
    justify-content: center;
  }

  /* Eval */
  .eval-form { max-width: 100%; }

  /* Publication */
  .pub-card {
    grid-template-columns: 90px 1fr;
    gap: 1.2rem;
    padding: 1.2rem;
  }
}


/* ════════════════════════════
   MOBILE — max 480px
════════════════════════════ */
@media (max-width: 480px) {

  /* Hero */
  .hero-breadcrumb { font-size: .62rem; }
  .hero h1 { font-size: clamp(1.4rem, 6vw, 1.9rem); }
  .hero-meta { flex-direction: column; gap: .8rem; margin-top: 1.5rem; }
  .hero-meta-item { flex-direction: row; align-items: center; gap: .6rem; }
  .hero-meta-label { min-width: 100px; }
  .hero-scroll { display: none; }

  /* Subnav — labels courts */
  .subnav ul li a {
    font-size: .6rem;
    padding: .65rem .55rem;
    letter-spacing: .04em;
  }

  /* Sections */
  section { padding: 2.5rem 1.2rem; }
  .section-title { margin-bottom: 1.5rem; }

  /* Team — 1 colonne, card horizontale */
  .team-grid { grid-template-columns: 1fr; gap: 1rem; }
  .team-card {
    display: flex;
    flex-direction: row;
    align-items: stretch;
  }
  .team-avatar {
    width: 80px;
    min-width: 80px;
    aspect-ratio: unset;
  }
  .team-info { padding: .8rem 1rem; }
  .team-bio { font-size: .75rem; }

  /* News */
  .news-item {
    grid-template-columns: 52px 1fr;
    gap: .75rem;
    padding: 1rem;
  }
  .news-date { font-size: .62rem; }
  .news-title { font-size: .88rem; }

  /* Policy Briefs — 1 colonne */
  .three-col { grid-template-columns: 1fr; }
  .pb-card { padding: 1.2rem; }
  .pb-actions { flex-direction: row; flex-wrap: wrap; }

  /* Audio */
  .audio-card {
    grid-template-columns: 44px 1fr;
    padding: .75rem 1rem;
  }

  /* Forum */
  .forum-prompt { padding: 1rem 1.2rem; }
  .forum-prompt-q { font-size: .9rem; }

  /* Blog — 1 colonne */
  .blog-grid { grid-template-columns: 1fr; }

  /* Eval */
  .eval-q-text { font-size: .9rem; }
  .eval-option { font-size: .82rem; padding: .6rem .75rem; }
  .eval-submit-btn { font-size: .9rem; }

  /* Publication — 1 colonne, couverture masquée */
  .pub-card {
    grid-template-columns: 1fr;
    gap: 1rem;
  }
  .pub-cover { display: none; }
  .pub-title { font-size: 1rem; }
}


/* ════════════════════════════
   TRÈS PETIT — max 360px
════════════════════════════ */
@media (max-width: 360px) {
  .hero h1 { font-size: 1.3rem; }
  .subnav ul li a { font-size: .55rem; padding: .6rem .45rem; }
  .team-avatar { width: 65px; min-width: 65px; }
  .news-item { grid-template-columns: 45px 1fr; }
  .pb-actions { flex-direction: column; }
  .pb-actions .btn { width: 100%; justify-content: center; }
}/* End custom CSS */