/**
 * global.css — styles de présentation des composants ianaos (FSE).
 * Importe d'abord _variables.css (alias tokens theme.json).
 *
 * @package Ianaos_FSE
 */

/* ============================================================ HEADER */
.ianaos-header { position: sticky; top: 0; z-index: 100; border-bottom: 1px solid var(--dtn-border); backdrop-filter: saturate(120%) blur(4px); }
.ianaos-logo { display: inline-flex; align-items: center; line-height: 0; }
.ianaos-logo img { height: 38px; width: auto; display: block; }
.ianaos-header .wp-block-navigation a { color: var(--dtn-primary); font-weight: 500; }
.ianaos-header .wp-block-navigation a:hover { color: var(--ianaos); }
.ianaos-header-cta .wp-block-button__link { background-color: var(--ianaos); }
.ianaos-header-cta .wp-block-button__link:hover { background-color: var(--ianaos-dark); }

/* ============================================================ FOOTER */
.ianaos-footer-main { background-color: #0F172A; color: #cbd5e1; }
.ianaos-footer-main .ianaos-footer-heading a,
.ianaos-footer-main .ianaos-footer-heading { color: #fff; font-size: 0.95rem; letter-spacing: 0.04em; text-transform: uppercase; }
.ianaos-footer-list { list-style: none; padding-left: 0; }
.ianaos-footer-list li { margin: 0.4em 0; }
.ianaos-footer-list a { color: #cbd5e1; text-decoration: none; }
.ianaos-footer-list a:hover { color: var(--ianaos); }
.ianaos-footer-bottom { background-color: #0b1120; color: #94a3b8; }
.ianaos-footer-bottom a { color: #cbd5e1; }
.ianaos-footer-copyright { font-size: 0.85rem; margin: 0; }

/* ============================================================ HERO */
.ianaos-hero { background: linear-gradient(135deg, #0F172A 0%, #155E86 60%, #2293D2 100%); color: #fff; }
.ianaos-hero__title { color: #fff; font-size: clamp(2rem, 5vw, 3.25rem); line-height: 1.1; letter-spacing: -0.02em; }
.ianaos-hero__title .ianaos-accent { color: #9CD8F5; }
.ianaos-hero__subtitle { color: #cbd5e1; font-size: 1.2rem; max-width: 42ch; }
.ianaos-hero__actions .wp-block-button.is-style-outline .wp-block-button__link { color: #fff; border-color: rgba(255,255,255,0.5); }
.ianaos-hero__actions .wp-block-button.is-style-outline .wp-block-button__link:hover { border-color: #fff; background: rgba(255,255,255,0.08); }
.ianaos-badges { display: flex; gap: 0.5rem; flex-wrap: wrap; margin-bottom: 1rem; }
.ianaos-badge { display: inline-flex; align-items: center; gap: 0.4rem; padding: 0.3rem 0.8rem; border-radius: var(--radius-full); background: rgba(156,216,245,0.15); border: 1px solid rgba(156,216,245,0.35); color: #cdeafa; font-size: 0.8rem; font-weight: 600; }
.ianaos-hero__visual { background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.1); border-radius: var(--radius-xl); padding: 1.5rem; box-shadow: var(--shadow-xl); }

/* ============================================================ EYEBROW / SECTION TITLES */
.ianaos-eyebrow { display: inline-block; color: var(--ianaos); font-weight: 700; font-size: 0.8rem; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 0.5rem; }
.ianaos-section-title { font-size: clamp(1.6rem, 3.5vw, 2.4rem); letter-spacing: -0.01em; }
.ianaos-section-subtitle { color: var(--dtn-muted); font-size: 1.1rem; max-width: 60ch; margin-inline: auto; }

/* ============================================================ CARDS */
.ianaos-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1.5rem; }
.ianaos-card { background: var(--dtn-base); border: 1px solid var(--dtn-border); border-radius: var(--radius-xl); padding: 1.75rem; box-shadow: var(--shadow-sm); transition: var(--transition-fast); display: flex; flex-direction: column; }
.ianaos-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-3px); border-color: #b3ddf3; }
.ianaos-card__icon { width: 48px; height: 48px; display: flex; align-items: center; justify-content: center; border-radius: var(--radius-lg); background: var(--ianaos-light); color: var(--ianaos); margin-bottom: 1rem; }
.ianaos-card__icon svg { width: 24px; height: 24px; }
.ianaos-card__title { font-size: 1.2rem; font-weight: 700; color: var(--dtn-primary); margin: 0 0 0.5rem; }
.ianaos-card__text { color: var(--dtn-muted); font-size: 0.97rem; line-height: 1.6; margin: 0 0 1rem; }
.ianaos-card__link { margin-top: auto; }
.ianaos-card__link a { color: var(--ianaos); font-weight: 600; text-decoration: none; }
.ianaos-card__link a:hover { color: var(--ianaos-dark); }

/* ============================================================ TRUST BAND */
.ianaos-trust { background: var(--dtn-surface-light); }
.ianaos-trust__title { text-align: center; color: var(--dtn-muted); font-size: 0.95rem; letter-spacing: 0.02em; margin-bottom: 1.1rem; }
.ianaos-trust__signals { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 0.6rem 0.75rem; }
.ianaos-trust__chip { display: inline-flex; align-items: center; padding: 0.4rem 0.9rem; border-radius: var(--radius-full); background: var(--dtn-base); border: 1px solid var(--dtn-border); color: var(--dtn-slate-600); font-size: 0.85rem; font-weight: 600; }
.ianaos-trust__chip::before { content: "✓"; color: var(--ianaos); font-weight: 700; margin-right: 0.45rem; }

/* ============================================================ STAT / ROI */
.ianaos-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 1.5rem; }
.ianaos-stat { text-align: center; }
.ianaos-stat__value { font-family: var(--wp--preset--font-family--heading); font-size: 2.5rem; font-weight: 800; color: var(--ianaos); line-height: 1; }
.ianaos-stat__label { color: var(--dtn-muted); font-size: 0.95rem; margin-top: 0.4rem; }

/* ============================================================ CTA DIAGNOSTIC */
.ianaos-cta { background: linear-gradient(135deg, #1B76A8 0%, #2293D2 100%); border-radius: var(--radius-xl); color: #fff; }
.ianaos-cta__title { color: #fff; }
.ianaos-cta__text { color: #dbeefb; }
.ianaos-cta .wp-block-button__link { background: #fff; color: var(--ianaos-dark); font-weight: 700; }
.ianaos-cta .wp-block-button__link:hover { background: #E8F4FC; }

/* ============================================================ FAQ */
.ianaos-faq { max-width: 760px; margin-inline: auto; }
.ianaos-faq-item { background: var(--dtn-base); border: 1px solid var(--dtn-border); border-radius: var(--radius-lg); margin-bottom: 0.75rem; padding: 0.25rem 1.25rem; }
.ianaos-faq-item[open] { border-color: #b3ddf3; box-shadow: var(--shadow-sm); }
.ianaos-faq-item summary { cursor: pointer; font-weight: 600; color: var(--dtn-primary); padding: 0.9rem 0; list-style: none; display: flex; justify-content: space-between; align-items: center; gap: 1rem; }
.ianaos-faq-item summary::-webkit-details-marker { display: none; }
.ianaos-faq-item summary::after { content: "+"; color: var(--ianaos); font-size: 1.4rem; font-weight: 400; line-height: 1; }
.ianaos-faq-item[open] summary::after { content: "–"; }
.ianaos-faq-item > p { color: var(--dtn-muted); padding-bottom: 1rem; margin: 0; }

/* ============================================================ STEPS / GABARIT OFFRE */
.ianaos-steps { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1.5rem; counter-reset: step; }
.ianaos-step { background: var(--dtn-base); border: 1px solid var(--dtn-border); border-left: 3px solid var(--ianaos); border-radius: var(--radius-md); padding: 1.25rem; }
.ianaos-step__num { counter-increment: step; font-family: var(--wp--preset--font-family--heading); color: var(--ianaos); font-weight: 800; font-size: 1.1rem; }
.ianaos-checklist { list-style: none; padding-left: 0; }
.ianaos-checklist li { position: relative; padding-left: 1.75rem; margin: 0.6em 0; }
.ianaos-checklist li::before { content: "✓"; position: absolute; left: 0; color: var(--ianaos); font-weight: 700; }

/* ============================================================ LEAD FORM */
.ianaos-lead-form { background: var(--dtn-base); border: 1px solid var(--dtn-border); border-radius: var(--radius-xl); padding: 1.75rem; box-shadow: var(--shadow-md); }
.ianaos-lead-form .ianaos-field { margin-bottom: 1rem; display: flex; flex-direction: column; }
.ianaos-lead-form label { font-weight: 600; color: var(--dtn-primary); font-size: 0.9rem; margin-bottom: 0.35rem; }
.ianaos-lead-form input,
.ianaos-lead-form select,
.ianaos-lead-form textarea { width: 100%; padding: 0.7rem 0.85rem; border: 1px solid var(--dtn-border); border-radius: var(--radius-md); font: inherit; color: var(--dtn-primary); background: #fff; }
.ianaos-lead-form input:focus,
.ianaos-lead-form select:focus,
.ianaos-lead-form textarea:focus { outline: 2px solid var(--ianaos); border-color: var(--ianaos); }
.ianaos-lead-form .ianaos-consent { display: flex; gap: 0.6rem; align-items: flex-start; font-size: 0.85rem; color: var(--dtn-muted); }
.ianaos-lead-form .ianaos-consent input { width: auto; margin-top: 0.2rem; }
.ianaos-lead-form button { background: var(--ianaos); color: #fff; border: 0; border-radius: var(--radius-md); padding: 0.85rem 1.5rem; font-weight: 700; cursor: pointer; width: 100%; transition: var(--transition-fast); }
.ianaos-lead-form button:hover { background: var(--ianaos-dark); }
.ianaos-lead-form button:disabled { opacity: 0.6; cursor: progress; }
/* Honeypot — masqué visuellement et aux lecteurs d'écran */
.ianaos-hp { position: absolute !important; left: -9999px !important; width: 1px; height: 1px; overflow: hidden; }
.ianaos-form-status { margin-top: 1rem; padding: 0.8rem 1rem; border-radius: var(--radius-md); font-size: 0.9rem; display: none; }
.ianaos-form-status.is-success { display: block; background: #d1fae5; color: #065f46; }
.ianaos-form-status.is-error { display: block; background: #fee2e2; color: #991b1b; }

/* ============================================================ COOKIE CMP */
.ianaos-cmp { position: fixed; inset: auto 1rem 1rem 1rem; z-index: 9999; max-width: 460px; margin-inline: auto; background: #fff; border: 1px solid var(--dtn-border); border-radius: var(--radius-lg); box-shadow: var(--shadow-xl); padding: 1.25rem; font-size: 0.9rem; }
.ianaos-cmp[hidden] { display: none; }
.ianaos-cmp p { margin: 0 0 0.9rem; color: var(--dtn-slate-600); }
.ianaos-cmp a { color: var(--ianaos); }
.ianaos-cmp__actions { display: flex; gap: 0.6rem; flex-wrap: wrap; }
.ianaos-cmp__actions button { flex: 1 1 auto; border-radius: var(--radius-md); padding: 0.6rem 1rem; font-weight: 600; cursor: pointer; border: 1px solid var(--dtn-border); }
.ianaos-cmp__accept { background: var(--ianaos); color: #fff; border-color: var(--ianaos); }
.ianaos-cmp__accept:hover { background: var(--ianaos-dark); }
.ianaos-cmp__refuse { background: #fff; color: var(--dtn-primary); }

/* ============================================================ GUIDES / ARTICLES */
.ianaos-byline { color: var(--dtn-muted); font-size: 0.92rem; margin: 0.75rem 0 0; }
.ianaos-byline strong { color: var(--dtn-primary); }
.ianaos-byline a { color: var(--ianaos); text-decoration: none; }
.ianaos-byline a:hover { text-decoration: underline; }
.ianaos-byline__author { margin: 0; }
.ianaos-byline__dates { margin: 0.2rem 0 0; font-size: 0.85rem; opacity: 0.85; }
.ianaos-updated { color: var(--dtn-muted); }
.ianaos-hero__meta { color: #cbd5e1; font-size: 0.92rem; margin-top: 0.75rem; }
.ianaos-hero__meta a { color: #fff; }

.ianaos-toc { border: 1px solid var(--dtn-border); border-radius: var(--radius-lg); padding: 1.25rem 1.5rem; background: var(--dtn-surface-light); }
.ianaos-toc__title { font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; font-size: 0.85rem; color: var(--ianaos); margin: 0 0 0.6rem; }
.ianaos-toc ol, .ianaos-toc ul { margin: 0; padding-left: 1.2rem; line-height: 1.85; }
.ianaos-toc a { color: var(--dtn-primary); text-decoration: none; }
.ianaos-toc a:hover { color: var(--ianaos); text-decoration: underline; }

.ianaos-tldr { margin: 0; }

.ianaos-table-wrap { overflow-x: auto; margin: 1.25rem 0; }
.ianaos-table { width: 100%; border-collapse: collapse; font-size: 0.95rem; }
.ianaos-table caption { caption-side: top; text-align: left; color: var(--dtn-muted); font-size: 0.9rem; margin-bottom: 0.5rem; }
.ianaos-table th, .ianaos-table td { border: 1px solid var(--dtn-border); padding: 0.7rem 0.9rem; text-align: left; vertical-align: top; }
.ianaos-table thead th { background: var(--dtn-surface-light); color: var(--dtn-primary); font-weight: 700; }
.ianaos-table tbody tr:nth-child(even) td { background: #fafcff; }

.ianaos-callout { border-left: 3px solid var(--ianaos); background: var(--ianaos-light); border-radius: var(--radius-md); padding: 1rem 1.25rem; margin: 1.25rem 0; }
.ianaos-callout p { margin: 0; }

/* ============================================================ BLOG — LISTING */
.ianaos-blog-title { margin-bottom: 0.4rem; }
.ianaos-blog-term-description { max-width: 60ch; margin-inline: auto; color: var(--dtn-muted); }
.ianaos-blog-term-description p { margin: 0; }

/* Grille de cartes — le nb de colonnes est géré par le bloc (minimumColumnWidth:300px) */
.ianaos-blog-grid { gap: 2rem 1.75rem; }

/* Carte d'article */
.ianaos-blog-card { display: flex; flex-direction: column; height: 100%; background: var(--dtn-base); border: 1px solid var(--dtn-border); border-radius: var(--radius-xl); overflow: hidden; box-shadow: var(--shadow-sm); transition: var(--transition-fast); }
.ianaos-blog-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-4px); border-color: #b3ddf3; }
.ianaos-blog-card__media { margin: 0; line-height: 0; }
.ianaos-blog-card__media img { width: 100%; aspect-ratio: 16 / 9; object-fit: cover; display: block; }
.ianaos-blog-card__inner { display: flex; flex-direction: column; flex: 1 1 auto; padding: 1.5rem; }
.ianaos-blog-card__cat { margin: 0 0 0.5rem; font-size: 0.72rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ianaos); }
.ianaos-blog-card__cat a { color: inherit; text-decoration: none; }
.ianaos-blog-card__cat a:hover { color: var(--ianaos-dark); }
.ianaos-blog-card__title { margin: 0 0 0.6rem; font-size: 1.2rem; line-height: 1.3; }
.ianaos-blog-card__title a { color: var(--dtn-primary); text-decoration: none; }
.ianaos-blog-card__title a:hover { color: var(--ianaos); }
.ianaos-blog-card__excerpt { margin: 0 0 1.25rem; color: var(--dtn-muted); font-size: 0.95rem; line-height: 1.6; }
.ianaos-blog-card__excerpt p { margin: 0; }
.ianaos-blog-card__meta { display: flex; align-items: center; justify-content: space-between; gap: 0.75rem; margin-top: auto; padding-top: 0.9rem; border-top: 1px solid var(--dtn-border); }
.ianaos-blog-card__date { font-size: 0.8rem; color: var(--dtn-muted); }
.ianaos-blog-card__date time { color: inherit; }
.ianaos-blog-card__more { color: var(--ianaos); font-weight: 600; font-size: 0.85rem; text-decoration: none; white-space: nowrap; }
.ianaos-blog-card__more:hover { color: var(--ianaos-dark); }

/* État vide */
.ianaos-blog-empty { max-width: 52ch; margin-inline: auto; color: var(--dtn-muted); }

/* Pagination du blog */
.wp-block-query-pagination { gap: 0.4rem; flex-wrap: wrap; }
.wp-block-query-pagination .page-numbers,
.wp-block-query-pagination .wp-block-query-pagination-previous,
.wp-block-query-pagination .wp-block-query-pagination-next { display: inline-flex; align-items: center; justify-content: center; min-width: 2.4rem; height: 2.4rem; padding: 0 0.7rem; border: 1px solid var(--dtn-border); border-radius: var(--radius-md); color: var(--dtn-slate-600); font-size: 0.9rem; font-weight: 600; text-decoration: none; transition: var(--transition-fast); }
.wp-block-query-pagination a.page-numbers:hover,
.wp-block-query-pagination .wp-block-query-pagination-previous:hover,
.wp-block-query-pagination .wp-block-query-pagination-next:hover { border-color: var(--ianaos); color: var(--ianaos); }
.wp-block-query-pagination .page-numbers.current { background: var(--ianaos); border-color: var(--ianaos); color: #fff; }

/* ============================================================ BLOG — ARTICLE (single) */
.ianaos-article { margin-inline: auto; }
.ianaos-article__cat { margin-bottom: 0.75rem; }
.ianaos-article__cat a { color: var(--ianaos); text-decoration: none; }
.ianaos-article__cat a:hover { color: var(--ianaos-dark); }
.ianaos-article__title { margin: 0 0 1rem; font-size: clamp(1.9rem, 1rem + 3vw, 2.6rem); line-height: 1.15; letter-spacing: -0.01em; }
.ianaos-article__meta { gap: 0.6rem; color: var(--dtn-muted); font-size: 0.92rem; }
.ianaos-article__meta .wp-block-post-author { display: inline-flex; align-items: center; gap: 0.5rem; }
.ianaos-article__meta .wp-block-post-author__avatar img { border-radius: var(--radius-full); }
.ianaos-article__meta .wp-block-post-author__content { line-height: 1.2; }
.ianaos-article__meta .wp-block-post-author__byline { margin: 0; font-size: 0.78rem; opacity: 0.8; }
.ianaos-article__meta .wp-block-post-author__name { margin: 0; font-weight: 600; color: var(--dtn-slate-600); }
.ianaos-article__image img { width: 100%; object-fit: cover; }
.ianaos-article .wp-block-post-content { font-size: 1.07rem; line-height: 1.8; }
.ianaos-article .wp-block-post-content h2 { margin-top: 1.9em; font-size: 1.55rem; }
.ianaos-article .wp-block-post-content h3 { margin-top: 1.5em; font-size: 1.25rem; }
.ianaos-article .wp-block-post-content > ul,
.ianaos-article .wp-block-post-content > ol { padding-left: 1.4rem; }
.ianaos-article__tags { font-size: 0.85rem; color: var(--dtn-muted); }
.ianaos-article__tags a { color: var(--dtn-slate-600); text-decoration: none; }
.ianaos-article__tags a:hover { color: var(--ianaos); }

/* Articles liés */
.ianaos-related__title { margin-bottom: var(--spacing-lg); font-size: 1.5rem; }

/* ============================================================ RESPONSIVE */
@media (max-width: 781px) {
  .ianaos-hero__subtitle { max-width: none; }
  .ianaos-trust__logos { gap: 1.5rem; }
  .ianaos-trust__logos img { height: 30px; }
  .ianaos-blog-grid { gap: 1.5rem; }
  .ianaos-blog-card__inner { padding: 1.25rem; }
}

/* ============================================================ A11Y */
.ianaos-skip-link { position: absolute; left: -9999px; }
.ianaos-skip-link:focus { left: 1rem; top: 1rem; z-index: 1000; background: #fff; padding: 0.5rem 1rem; border-radius: var(--radius-md); }
:focus-visible { outline: 2px solid var(--ianaos); outline-offset: 2px; }

/* ============================================================ MULTILINGUE (FR/EN) */
.ianaos-lang { display: inline-flex; align-items: center; gap: 0.4rem; font-size: 0.85rem; font-weight: 600; line-height: 1; }
.ianaos-lang__link { color: var(--dtn-slate-600, #475569); text-decoration: none; padding: 0.15rem 0.1rem; border-radius: var(--radius-sm, 4px); transition: color 0.2s ease; }
.ianaos-lang__link:hover { color: var(--ianaos); }
.ianaos-lang__link.is-active { color: var(--ianaos); font-weight: 800; pointer-events: none; }
.ianaos-lang__sep { color: var(--dtn-border, #e2e8f0); }
