/* ═══════════════════════════════════════════════
   Agence Noos — Observatoire (section partagée)
   Styles de composants pour les pages de l'Observatoire et
   la page service Diagnostic. Charge APRES /style.css
   (réutilise les tokens, la nav, le footer, les zones, .bp, .reveal).
   ═══════════════════════════════════════════════ */

/* ——— SECTIONS ——— */
.sec{padding:0 clamp(24px,4vw,56px);max-width:1100px;margin:0 auto}
.sec-narrow{max-width:820px}
.sec-first{padding-top:72px}
.sec-mid{padding-top:80px}
.sec-last{padding-top:80px;padding-bottom:112px}

/* ——— LABELS & TITRES ——— */
.label{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted-paper);margin-bottom:16px}
.label-d{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--sage);margin-bottom:16px}
.title{font-family:'Instrument Serif',serif;font-size:clamp(26px,3vw,36px);font-weight:400;line-height:1.15;color:var(--text-dark);margin-bottom:24px}.title em{font-style:normal;color:var(--green)}
.title-d{font-family:'Instrument Serif',serif;font-size:clamp(26px,3vw,36px);font-weight:400;line-height:1.15;color:var(--text-light);margin-bottom:24px}.title-d em{font-style:normal;color:var(--green)}
.subt{font-family:'Instrument Serif',serif;font-size:clamp(19px,2.2vw,23px);font-weight:400;font-style:italic;line-height:1.4;color:var(--text-dark);margin-bottom:20px}
.subt-d{font-family:'Instrument Serif',serif;font-size:clamp(19px,2.2vw,23px);font-weight:400;font-style:italic;line-height:1.4;color:var(--text-light);margin-bottom:20px}

/* ——— PROSE ——— */
.prose{max-width:780px}
.prose p{font-size:17px;color:var(--text-muted-paper);line-height:1.75;font-weight:300;margin-bottom:20px}
.prose p:last-child{margin-bottom:0}
.prose strong{font-weight:500;color:var(--text-dark)}
.prose a{color:var(--green-deep);text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px;transition:color .2s}
.prose a:hover{color:var(--green)}
.prose-d p{color:var(--sage);font-weight:400}
.prose-d strong{color:var(--text-light)}
.prose-d a{color:var(--green-bright)}
.hn{font-family:'JetBrains Mono',monospace;font-weight:500;color:var(--green)}

/* ——— ANSWER BOX (réponse d'abord, citable, GEO) ——— */
.answer{max-width:820px;margin:0 auto;padding:28px 32px;border-radius:16px;background:rgba(41,169,107,.06);border:1px solid rgba(41,169,107,.18)}
.answer p{font-size:clamp(17px,1.8vw,19px);line-height:1.65;color:var(--text-dark);font-weight:400;margin:0}
.answer strong{font-weight:600;color:var(--green-deep)}
.answer-label{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--green);opacity:.8;margin-bottom:12px}

/* ——— PULL QUOTE ——— */
.pq{margin:36px 0;padding:0 0 0 24px;border-left:3px solid var(--green);font-family:'Instrument Serif',serif;font-size:clamp(20px,2.5vw,24px);font-style:italic;color:var(--text-dark);line-height:1.45;max-width:680px}
.pq-d{color:var(--text-light)}

/* ——— STATS / KPI ——— */
.kpi-row{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:8px}
.kpi-n{font-family:'JetBrains Mono',monospace;font-size:clamp(36px,4.5vw,52px);font-weight:500;color:var(--green);line-height:1}
.kpi-t{font-size:15px;color:var(--text-muted-paper);line-height:1.55;font-weight:300;margin-top:10px}
.kpi-row.on-dark .kpi-t{color:var(--sage);font-weight:400}
.stat-aside{padding:32px;border-radius:16px;background:rgba(41,169,107,.05)}
.stat-aside .stat-n{font-family:'JetBrains Mono',monospace;font-size:clamp(44px,5vw,56px);font-weight:500;color:var(--green);line-height:1;display:block;margin-bottom:16px}
.stat-aside .stat-t{font-size:15px;color:var(--text-muted-paper);line-height:1.55;font-weight:300}
.stat-aside .stat-line{width:32px;height:2px;background:rgba(41,169,107,.2);border-radius:1px;margin:14px 0}
.stat-aside .stat-s{font-size:11px;color:var(--text-muted-paper);opacity:.6}
.split-2{display:grid;grid-template-columns:1.5fr 1fr;gap:48px;align-items:start}

/* ——— LISTE DE CONSTATS (numérotée, sur paper ou dark) ——— */
.findings{margin-top:24px;border-top:1px solid var(--border-paper)}
.finding{display:grid;grid-template-columns:48px 1fr;gap:20px;align-items:baseline;padding:28px 0;border-bottom:1px solid var(--border-paper);position:relative}
.finding-num{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--green);font-weight:500}
.finding h3{font-family:'Instrument Serif',serif;font-size:clamp(19px,2vw,23px);font-weight:400;color:var(--text-dark);line-height:1.3;margin-bottom:8px}
.finding h3 em{font-style:normal;color:var(--green)}
.finding p{font-size:15px;color:var(--text-muted-paper);line-height:1.65;font-weight:300}
.finding p strong{font-weight:500;color:var(--text-dark)}
.findings.on-dark{border-top-color:var(--border-dark)}
.findings.on-dark .finding{border-bottom-color:var(--border-dark)}
.findings.on-dark .finding h3{color:var(--text-light)}
.findings.on-dark .finding p{color:var(--sage);font-weight:400}
.findings.on-dark .finding p strong{color:var(--text-light)}

/* ——— TABLEAU DE DONNÉES (par secteur / par marché) ——— */
.som-table{width:100%;border-collapse:collapse;margin-top:24px;font-size:14px}
.som-table caption{text-align:left;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted-paper);opacity:.7;margin-bottom:12px}
.som-table th,.som-table td{text-align:left;padding:12px 14px;border-bottom:1px solid var(--border-paper);vertical-align:top}
.som-table thead th{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted-paper);font-weight:500}
.som-table td{color:var(--text-muted-paper);font-weight:300;line-height:1.5}
.som-table td.num{font-family:'JetBrains Mono',monospace;color:var(--green);font-weight:500;white-space:nowrap}
.som-table tbody tr:hover{background:rgba(41,169,107,.03)}
.som-table .mk{color:var(--text-dark);font-weight:500}
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}

/* ——— FIGURE ——— */
.figure{margin:32px 0;max-width:860px}
.figure img{width:100%;height:auto;display:block;border-radius:12px;border:1px solid var(--border-paper);background:#fff}
.figure figcaption{font-size:13px;color:var(--text-muted-paper);line-height:1.6;margin-top:12px;font-weight:300}
.figure figcaption .src{font-family:'JetBrains Mono',monospace;font-size:11px;opacity:.7}

/* ——— CARTES D'ÉTUDE (hub) ——— */
.study-grid{display:grid;grid-template-columns:1fr;gap:20px;margin-top:8px;max-width:860px}
.study-card{display:block;padding:32px;border-radius:16px;background:var(--ink-90);border:1px solid var(--border-dark);text-decoration:none;transition:border-color .25s,transform .25s}
.study-card:hover{border-color:rgba(41,169,107,.35);transform:translateY(-2px)}
.study-card .sc-tag{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--green);margin-bottom:14px}
.study-card h3{font-family:'Instrument Serif',serif;font-size:clamp(22px,2.4vw,28px);font-weight:400;color:var(--text-light);line-height:1.2;margin-bottom:12px}
.study-card h3 em{font-style:normal;color:var(--green)}
.study-card p{font-size:15px;color:var(--sage);line-height:1.65;font-weight:400;margin-bottom:16px}
.study-card .sc-go{font-size:13px;color:var(--green);font-weight:500}
.study-card .sc-go .ar{display:inline-block;transition:transform .25s}
.study-card:hover .sc-go .ar{transform:translateX(4px)}
.study-card.soon{border-style:dashed;pointer-events:none}
.study-card.soon .sc-tag,.study-card.soon h3,.study-card.soon .sc-go{color:var(--sage)}
.study-card.soon .sc-go{opacity:.85}

/* ——— GRILLE DES SECTEURS (index) ——— */
.sector-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:8px}
.sector-card{display:block;padding:24px;border-radius:14px;background:var(--paper-warm);border:1px solid var(--border-paper);text-decoration:none;transition:border-color .2s,transform .2s,background .2s}
.sector-card:hover{border-color:rgba(41,169,107,.3);transform:translateY(-2px);background:#fff}
.sector-card .scn{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted-paper);opacity:.7;margin-bottom:10px}
.sector-card h3{font-family:'Instrument Serif',serif;font-size:20px;font-weight:400;color:var(--text-dark);line-height:1.25;margin-bottom:8px}
.sector-card p{font-size:13.5px;color:var(--text-muted-paper);line-height:1.55;font-weight:300}
.sector-card .pme{font-family:'JetBrains Mono',monospace;color:var(--green);font-weight:500}

/* ——— DATA NOTE (limites, statut épistémique) ——— */
.data-note{margin-top:40px;padding:20px 24px;border-radius:10px;background:var(--ink-80);border-left:2px solid rgba(41,169,107,.3);font-size:13px;color:var(--sage);line-height:1.65;font-weight:400;max-width:680px}
.data-note.on-paper{background:var(--paper-warm);color:var(--text-muted-paper);border-left-color:rgba(41,169,107,.4)}
.data-note-label{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--green);opacity:.8;margin-right:10px}

/* ——— SOURCE / META ——— */
.src-line{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.03em;color:var(--text-muted-paper);opacity:.7;margin-top:40px;line-height:1.6}
.src-line.on-dark{color:var(--sage)}
.src-line a{color:inherit;text-decoration:underline;text-underline-offset:2px}

/* ——— DIVIDERS ——— */
.dark-div{max-width:1100px;margin:0 auto;padding:0 clamp(24px,4vw,56px)}
.dark-div hr{border:none;height:1px;background:linear-gradient(to right,transparent,rgba(41,169,107,.15) 20%,rgba(41,169,107,.15) 80%,transparent)}
.paper-div{max-width:1100px;margin:0 auto;padding:0 clamp(24px,4vw,56px)}
.paper-div hr{border:none;height:1px;background:rgba(12,18,16,.08)}

/* ——— FAQ ——— */
.faq-list{max-width:820px}
.faq-item{border-bottom:1px solid var(--border-dark)}
.faq-item:first-child{border-top:1px solid var(--border-dark)}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:20px 0;cursor:pointer;font-size:16px;font-weight:500;color:var(--text-light);line-height:1.4;transition:color .2s}
.faq-q:hover{color:var(--green)}
.faq-q .fi{flex-shrink:0;width:20px;height:20px;position:relative}
.faq-q .fi::before,.faq-q .fi::after{content:'';position:absolute;background:var(--sage);border-radius:1px}
.faq-q .fi::before{width:12px;height:1.5px;top:9.25px;left:4px}
.faq-q .fi::after{width:1.5px;height:12px;top:4px;left:9.25px;transition:transform .3s,opacity .3s}
.faq-item.open .faq-q .fi::after{transform:rotate(90deg);opacity:0}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.22,1,.36,1)}
.faq-item.open .faq-a{max-height:800px}
.faq-a-inner{padding:0 0 24px;font-size:15px;color:var(--sage);line-height:1.7;font-weight:400;max-width:720px}
.faq-a-inner a{color:var(--green-bright);text-decoration:underline;text-underline-offset:2px}
/* Variante paper */
.faq-list.on-paper .faq-item{border-color:var(--border-paper)}
.faq-list.on-paper .faq-q{color:var(--text-dark)}
.faq-list.on-paper .faq-q .fi::before,.faq-list.on-paper .faq-q .fi::after{background:var(--text-muted-paper)}
.faq-list.on-paper .faq-a-inner{color:var(--text-muted-paper)}
.faq-list.on-paper .faq-a-inner a{color:var(--green-deep)}

/* ——— CTA FINAL ——— */
.cta-final{padding:72px clamp(24px,4vw,56px) 100px;max-width:1100px;margin:0 auto;text-align:center}
.see-also{margin-bottom:44px}
.see-also-label{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted-paper);margin-bottom:12px;opacity:.6}
.see-also-links{display:flex;gap:16px;align-items:center;justify-content:center;font-size:15px;flex-wrap:wrap}
.see-also-links a{color:var(--text-dark);text-decoration:none;font-weight:400;transition:color .2s;opacity:.75}
.see-also-links a:hover{color:var(--green);opacity:1}
.see-also-sep{color:var(--text-muted-paper);opacity:.3}
.cta-title{font-family:'Instrument Serif',serif;font-size:clamp(28px,3.4vw,40px);font-weight:400;color:var(--text-dark);line-height:1.1;margin-bottom:16px}
.cta-title em{font-style:normal;color:var(--green)}
.cta-sub{font-size:15px;color:var(--text-muted-paper);font-weight:400;margin:0 auto 32px;max-width:520px;line-height:1.6}

/* ——— CTA ZONE (fond crème + transition arrondie, comme le reste du site) ——— */
.cta-zone{background:var(--paper);color:var(--text-dark);position:relative;z-index:5}
.cta-zone::before{content:'';position:absolute;top:-48px;left:0;right:0;height:49px;background:var(--paper);border-radius:32px 32px 0 0}

/* Espace en bas de la derniere section d une zone, avant la zone suivante (evite les bords colles) */
.paper-zone > section:last-child,.dark-zone > section:last-child{padding-bottom:104px}

/* ——— RESPONSIVE ——— */
@media(max-width:900px){
  .sec-first{padding-top:56px}.sec-mid{padding-top:60px}.sec-last{padding-top:60px;padding-bottom:72px}
  .split-2{grid-template-columns:1fr;gap:28px}
  .kpi-row{grid-template-columns:1fr;gap:24px}
  .sector-grid{grid-template-columns:1fr}
  .cta-final{padding:56px 24px 72px}
}
@media(max-width:600px){
  .finding{grid-template-columns:1fr;gap:6px}
  .answer{padding:22px 22px}
}

/* ——— SOMMAIRE DE L ETUDE (sous-nav) ——— */
.study-nav{display:flex;flex-wrap:wrap;gap:8px;margin-top:34px;margin-bottom:44px}
.study-nav a{font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.01em;color:var(--sage);text-decoration:none;padding:7px 14px;border:1px solid var(--border-dark);border-radius:100px;transition:color .2s,border-color .2s,background .2s;white-space:nowrap}
.study-nav a:hover{color:var(--text-light);border-color:rgba(41,169,107,.45)}
.study-nav a.cur{color:var(--ink);background:var(--green);border-color:var(--green);font-weight:500}

/* ——— GRAPHIQUE EN BARRES (natif) ——— */
.barchart{max-width:760px;margin:24px 0}
.bc-title{font-family:'Instrument Serif',serif;font-size:clamp(18px,2vw,22px);color:var(--text-dark);font-weight:400;margin-bottom:18px}
.bc-row{display:grid;grid-template-columns:150px 1fr 50px;column-gap:14px;align-items:center;margin-bottom:9px}
.bc-label{font-size:12.5px;color:var(--text-muted-paper);text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bc-plot{position:relative;height:22px;background:rgba(12,18,16,.05);border-radius:5px}
.bc-fill{position:absolute;top:0;bottom:0;left:0;border-radius:5px;background:var(--text-muted-paper);opacity:.45;min-width:2px}
.bc-fill.hi{background:var(--green);opacity:1}
.bc-val{font-family:'JetBrains Mono',monospace;font-size:11.5px;color:var(--text-muted-paper);font-weight:500}
.barchart.t18 .bc-plot::after{content:'';position:absolute;top:-3px;bottom:-3px;left:18%;border-left:1.5px dashed rgba(12,18,16,.32);z-index:2}
.bc-cap{font-size:12px;color:var(--text-muted-paper);opacity:.8;margin-top:14px;line-height:1.55;max-width:680px}
.bc-cap .k{font-family:'JetBrains Mono',monospace}
.dark-zone .bc-title{color:var(--text-light)}
.dark-zone .bc-label,.dark-zone .bc-val,.dark-zone .bc-cap{color:var(--sage)}
.dark-zone .bc-plot{background:rgba(255,255,255,.06)}

/* ——— TABLEAUX : polish ——— */
.som-table th,.som-table td{padding:13px 16px}
.som-table tbody tr:nth-child(even){background:rgba(12,18,16,.02)}
.som-table tbody tr:hover{background:rgba(41,169,107,.05)}

@media(max-width:600px){
  .bc-row{grid-template-columns:104px 1fr 44px;column-gap:8px}
  .bc-label{font-size:11px}
  .study-nav{gap:6px}
  .study-nav a{font-size:11px;padding:6px 11px}
}
