/*
 * Fameen News — feuille de style responsive.
 * Chargée après style.css (functions.php). Approche desktop-first :
 * points de rupture descendants 1024 (tablette) / 768 (mobile) / 480 (petit mobile).
 * Charte : #1C2F6B / #D71920 / #FFFFFF / #F3F5F7 / #444444.
 */

/* ==========================================================================
   Tablette (≤ 1024px)
   ========================================================================== */
@media (max-width: 1024px) {
  .fn-layout { grid-template-columns: 1fr; }
  .fn-sidebar { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; align-items: start; }
  .fn-header__ads { display: none; }
  .fn-hero-carousel { min-height: 400px; }
  .fn-grid--3, .fn-grid--4 { grid-template-columns: repeat(2, 1fr); }
  .fn-rubriques { grid-template-columns: repeat(3, 1fr); }
  .fn-footer__widgets { grid-template-columns: repeat(2, 1fr); }
  .fn-values, .fn-offers { grid-template-columns: repeat(2, 1fr); }
  .fn-packs { grid-template-columns: 1fr; max-width: 520px; margin: 0 auto; }
}

/* ==========================================================================
   Mobile (≤ 768px) — menu tiroir + accordéons, grilles 1 colonne
   ========================================================================== */
@media (max-width: 768px) {
  .fn-menu-toggle { display: inline-flex; padding: 14px 16px; }
  .fn-nav {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--fn-navy-dark);
    box-shadow: var(--fn-shadow-hover);
    max-height: calc(100vh - 60px);
    overflow-y: auto;
  }
  .fn-nav.is-open { display: block; }
  .fn-nav ul { flex-direction: column; }
  .fn-nav li { display: block; position: relative; }
  .fn-nav a { padding: 14px 20px; border-bottom: 1px solid rgba(255, 255, 255, .08); display: block; }

  /* Sous-menu mobile : replié par défaut, ouvert via le bouton ▾ */
  .fn-nav .menu-item-has-children > a,
  .fn-nav .page_item_has_children > a { padding-right: 56px; }
  .fn-nav .menu-item-has-children > a::after,
  .fn-nav .page_item_has_children > a::after { content: none; }
  .fn-submenu-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: 0; right: 0;
    width: 52px; height: 51px;
    background: rgba(255, 255, 255, .06);
    border: 0;
    border-left: 1px solid rgba(255, 255, 255, .1);
    color: var(--fn-white);
    font-size: 13px;
    cursor: pointer;
    transition: transform .2s ease, background .2s ease;
  }
  .fn-nav li.is-open > .fn-submenu-toggle { background: var(--fn-red); transform: rotate(180deg); border-left: 0; }
  .fn-nav .sub-menu {
    display: none;
    position: static;
    background: rgba(0, 0, 0, .18);
    box-shadow: none;
    border-radius: 0;
    border-top: 0;
    min-width: 0;
  }
  /* Sur mobile, seule l'ouverture via le bouton compte (pas le survol) */
  .fn-nav li:hover > .sub-menu,
  .fn-nav li:focus-within > .sub-menu { display: none; }
  .fn-nav li.is-open > .sub-menu { display: block; }
  .fn-nav li:last-child > .sub-menu { left: auto; right: auto; }

  /* Mega menu mobile : accordéon simple, aperçu d'articles masqué */
  .fn-nav li.menu-item-has-children { position: relative; }
  .fn-mega {
    position: static;
    background: rgba(0, 0, 0, .18);
    border: 0;
    border-radius: 0;
    box-shadow: none;
  }
  .fn-nav li:hover > .fn-mega,
  .fn-nav li:focus-within > .fn-mega { display: none; }
  .fn-nav li.is-open > .fn-mega { display: block; }
  .fn-mega__inner { display: block; max-width: none; padding: 0; }
  .fn-mega .fn-mega__links { display: flex; flex-direction: column; flex: none; }
  .fn-mega .fn-mega__links a {
    color: rgba(255, 255, 255, .85);
    border-radius: 0;
    padding: 12px 20px 12px 32px;
    border-bottom: 1px solid rgba(255, 255, 255, .06);
  }
  .fn-mega .fn-mega__links a:hover { background: rgba(255, 255, 255, .06); color: var(--fn-white); }
  .fn-mega .fn-mega__links .current-menu-item > a { background: transparent; color: var(--fn-white); }
  .fn-mi { color: rgba(255, 255, 255, .6); }
  .fn-mega .fn-mega__links a:hover .fn-mi { color: var(--fn-white); }
  .fn-mega .fn-mega__posts { display: none; }
  .fn-nav .sub-menu a { color: rgba(255, 255, 255, .85); padding-left: 36px; border-bottom: 1px solid rgba(255, 255, 255, .06); }
  .fn-navbar__inner { position: relative; }
  .fn-navbar .fn-btn-subscribe { padding: 0 16px; font-size: 12px; }

  .fn-topbar__links { display: none; }

  .fn-hero { grid-template-columns: 1fr; }
  .fn-hero-carousel { min-height: 340px; }
  .fn-hero-carousel .fn-hero-card__title { font-size: 22px; }
  .fn-hero-carousel .fn-hero-card__excerpt { display: none; }
  .fn-hero__secondary { grid-template-rows: none; grid-template-columns: 1fr; }
  .fn-hero__secondary .fn-hero-card { min-height: 150px; }

  .fn-breaking__time, .fn-breaking__nav { display: none; }

  .fn-grid, .fn-grid--3, .fn-grid--4 { grid-template-columns: 1fr; }
  .fn-related .fn-grid { grid-template-columns: 1fr; }
  .fn-rubriques { grid-template-columns: 1fr; }
  .fn-sidebar { grid-template-columns: 1fr; }

  .fn-article { padding: 24px 20px; }
  .fn-article__title { font-size: 27px; }
  .fn-article__content { font-size: 16.5px; }
  .fn-page { padding: 28px 22px; }
  .fn-page__title { font-size: 27px; }

  .fn-list-item { grid-template-columns: 1fr; }
  .fn-list-item__body { padding: 0 20px 18px; }

  .fn-info-cards, .fn-ad-formats { grid-template-columns: 1fr; }
  .fn-archive-header { padding: 24px; }
  .fn-archive-header__title { font-size: 25px; }
  .fn-archive-header--author { grid-template-columns: 72px 1fr; }

  .fn-footer__widgets { grid-template-columns: 1fr; gap: 32px; }
  .fn-footer__bottom { flex-direction: column; text-align: center; }

  /* Pages institutionnelles */
  .fn-page-hero { padding: 36px 0 30px; }
  .fn-page-hero h1 { font-size: 27px; }
  .fn-split { grid-template-columns: 1fr; gap: 24px; }
  .fn-split__media { min-height: 200px; }
  .fn-duo { grid-template-columns: 1fr; }
  .fn-values { grid-template-columns: 1fr; }
  .fn-checklist { grid-template-columns: 1fr; }
  .fn-group-block { grid-template-columns: 1fr; padding: 28px 22px; text-align: center; }
  .fn-engage { padding: 26px 20px; }
  .fn-offers, .fn-packs { grid-template-columns: 1fr; }
  .fn-contact-layout { grid-template-columns: 1fr; }
  .fn-form { padding: 22px 18px; }
  .fn-cta-row .fn-btn { width: 100%; justify-content: center; }

  .fn-author-box { grid-template-columns: 64px 1fr; padding: 18px; }
  .fn-post-nav { flex-direction: column; }
  .fn-post-nav a:last-child { text-align: left; }

  /* Publicités articles — formats mobiles */
  .fn-adslot--top .fn-ad__placeholder { min-height: 100px; max-width: 320px; margin: 0 auto; } /* 320x100 */
  .fn-adslot--inline .fn-ad__placeholder { min-height: 250px; max-width: 300px; margin: 0 auto; } /* 300x250 */
  .fn-adslot--middle { display: none; } /* 728x90 : desktop uniquement, lecture mobile préservée */
  .fn-adslot--sidebar600 { position: static; } /* pas de sticky quand la sidebar passe sous le contenu */
  .fn-sticky-ad { display: block; }
  body.fn-has-sticky-ad { padding-bottom: 78px; }
  body.fn-has-sticky-ad .fn-back-top { bottom: 92px; }

  /* Zones publicitaires du thème (fameen_ad_zone) — mobile */
  .fn-adzone { margin: 20px auto; }
  .fn-adzone--sidebar600 { position: static; } /* la demi-page ne colle plus quand la sidebar passe sous le contenu */
  .fn-adzone--sidebar600 .fn-adzone__fallback { min-height: 250px; } /* pas d'immense vide 600px sur mobile */
}

/* ==========================================================================
   Petit mobile (≤ 480px)
   ========================================================================== */
@media (max-width: 480px) {
  .fn-topbar__date { display: none; }
  .fn-logo__text { font-size: 24px; }
  .fn-logo img { max-height: 56px; }
  .fn-hero-carousel { min-height: 280px; }
  .fn-breaking__label { padding: 6px 10px; font-size: 11px; }
  .fn-share__btn { padding: 9px 14px; font-size: 13px; }
  .fn-article__title { font-size: 23px; }
}
