/* pricing-extras.css — Composants spécifiques pricing/docs/gallery (FIX-MK01) */

/* Toggle Mensuel/Annuel */
.billing-row { display:inline-flex; background:var(--bg-surface); border:1px solid var(--border-subtle); border-radius:999px; padding:3px; margin-top:24px; }
.bi-btn { padding:9px 22px; background:transparent; border:0; border-radius:999px; cursor:pointer; font:inherit; font-size:13px; font-weight:500; color:var(--fg-2); transition:all 200ms var(--ease); }
.bi-btn.is-active { background:var(--color-ink); color:#fff; }
.bi-btn .save-pill { font-family:var(--font-mono); font-size:10px; margin-left:6px; background:var(--color-success); color:#052e16; padding:1px 6px; border-radius:8px; font-weight:600; letter-spacing:0; }

/* Compare table */
.section-compare { background:var(--bg-base); }
.compare-wrap { overflow-x:auto; background:var(--bg-surface); border:1px solid var(--border-subtle); border-radius:16px; }
.compare-table { width:100%; border-collapse:collapse; font-size:14px; min-width:720px; }
.compare-table th, .compare-table td { padding:14px 18px; text-align:left; border-bottom:1px solid var(--border-subtle); }
.compare-table thead th { background:var(--bg-base); font-family:var(--font-mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--fg-2); font-weight:600; }
.compare-table thead th.ct-plan { text-align:center; }
.compare-table thead th.ct-featured { color:var(--accent); }
.compare-table td.ct-plan, .compare-table td:nth-child(n+2) { text-align:center; font-family:var(--font-mono); font-size:13px; }
.compare-table .ct-no { color:var(--fg-3); }
.compare-table tr.ct-group td { background:var(--color-ink); color:var(--accent); font-family:var(--font-mono); font-size:11px; text-transform:uppercase; letter-spacing:.08em; font-weight:600; padding:10px 18px; }
.compare-table tbody tr:not(.ct-group):hover { background:var(--bg-base); }

/* FAQ */
.faq-list { display:flex; flex-direction:column; gap:8px; }
.faq-item { background:var(--bg-base); border:1px solid var(--border-subtle); border-radius:12px; overflow:hidden; transition:border-color 150ms var(--ease); }
.faq-item:hover { border-color:var(--border-strong); }
.faq-item summary { padding:18px 22px; cursor:pointer; list-style:none; display:flex; justify-content:space-between; align-items:center; font-weight:600; font-size:15px; letter-spacing:-0.01em; color:var(--fg-1); }
.faq-item summary::-webkit-details-marker { display:none; }
.faq-item summary::after { content:'+'; font-size:22px; color:var(--fg-2); font-weight:300; transition:transform .2s; }
.faq-item[open] summary::after { transform:rotate(45deg); color:var(--accent); }
.faq-item .faq-answer { padding:0 22px 18px; color:var(--fg-2); font-size:14px; line-height:1.6; }

/* Docs sidebar */
.docs-layout { display:grid; grid-template-columns:260px 1fr; gap:48px; padding:48px 0; }
.docs-sidebar { position:sticky; top:108px; align-self:start; max-height:calc(100vh - 130px); overflow-y:auto; padding-right:8px; }
.docs-sidebar h4 { font-size:11px; font-weight:700; color:var(--fg-3); text-transform:uppercase; letter-spacing:.08em; margin:18px 0 8px; padding-left:12px; }
.docs-sidebar a { display:block; padding:7px 12px; color:var(--fg-2); font-size:13.5px; border-radius:6px; border-left:2px solid transparent; transition:all .12s; text-decoration:none; }
.docs-sidebar a:hover { color:var(--fg-1); background:var(--bg-base); }
.docs-sidebar a.is-active { color:var(--accent); border-left-color:var(--accent); background:var(--accent-soft); }
.docs-content { min-width:0; max-width:760px; }
.docs-content h1 { font-size:clamp(36px,4vw,52px); letter-spacing:-0.03em; margin-bottom:10px; }
.docs-content .meta { color:var(--fg-2); font-size:13px; margin-bottom:32px; font-family:var(--font-mono); }
.docs-content h2 { font-size:26px; font-weight:700; margin:48px 0 14px; padding-top:24px; border-top:1px solid var(--border-subtle); letter-spacing:-0.01em; scroll-margin-top:108px; }
.docs-content h2:first-of-type { border:0; padding-top:0; margin-top:0; }
.docs-content h3 { font-size:18px; font-weight:600; margin:24px 0 8px; }
.docs-content p { margin-bottom:14px; color:var(--fg-1); }
.docs-content ul, .docs-content ol { margin:14px 0 14px 24px; color:var(--fg-1); }
.docs-content li { margin-bottom:6px; }
.docs-content code { background:var(--bg-base); padding:2px 6px; border-radius:4px; color:var(--color-primary); font-size:12.5px; border:1px solid var(--border-subtle); }
.docs-content pre { background:var(--color-ink); color:#A4ABBE; padding:18px 22px; border-radius:10px; overflow-x:auto; margin:18px 0; }
.docs-content pre code { background:transparent; border:0; padding:0; color:#fff; font-size:13px; }
.docs-content kbd { background:#fff; border:1px solid var(--border-strong); border-bottom:2px solid var(--border-strong); border-radius:4px; padding:2px 8px; font-size:12px; font-family:var(--font-mono); color:var(--fg-1); }
.docs-content .callout { background:var(--accent-soft); border:1px solid var(--border-subtle); border-left:3px solid var(--accent); padding:14px 18px; border-radius:8px; margin:20px 0; color:var(--fg-1); }

@media (max-width:900px) { .docs-layout { grid-template-columns:1fr; gap:20px; } .docs-sidebar { position:relative; top:0; max-height:none; } }

/* Gallery page */
.gallery-page { padding:48px 0 96px; }
.gallery-page .hero-row { display:grid; grid-template-columns:1fr 1fr; gap:48px; padding-bottom:48px; border-bottom:1px solid var(--border-subtle); margin-bottom:32px; align-items:end; }
@media (max-width:900px) { .gallery-page .hero-row { grid-template-columns:1fr; gap:24px; } }
.gallery-page .hero-row h1 { font-size:clamp(40px,5vw,72px); line-height:1; letter-spacing:-0.04em; }
.gallery-page .filters { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:24px; }
.g-filter { padding:7px 14px; border-radius:999px; background:var(--bg-surface); border:1px solid var(--border-subtle); color:var(--fg-2); font-size:13px; font-family:inherit; cursor:pointer; transition:all .15s; }
.g-filter:hover { border-color:var(--border-strong); color:var(--fg-1); }
.g-filter.is-active { background:var(--color-ink); color:#fff; border-color:transparent; }
