/*
 * WinetPay — Vitrine publique (A-16b, SCR-PUB-HOME, §104). Marque PLATEFORME.
 * Consomme EXCLUSIVEMENT les tokens du design-system (public/css/tokens.css) :
 * aucune couleur en dur (garde-fou DesignSystemGuardTest) — uniquement var(--…) + rgba() neutres.
 * Mobile-first, HTML-first, dégradation progressive, motion respectueuse (prefers-reduced-motion).
 */

*, *::before, *::after { box-sizing: border-box; }

body { margin: 0; }

.site {
    font-family: var(--font-sans);
    font-size: var(--fs-body);
    line-height: var(--lh-normal);
    color: var(--c-text);
    background: var(--c-bg);
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
}

.site-container { width: 100%; max-width: 1160px; margin-inline: auto; padding-inline: var(--sp-5); }

a { color: inherit; }
img { max-width: 100%; display: block; }

.site :focus-visible { outline: var(--focus-ring); outline-offset: var(--focus-offset); border-radius: var(--r-sm); }

.site-skip { position: absolute; left: -9999px; top: 0; z-index: var(--z-toast); padding: 10px 16px; background: var(--c-primary); color: var(--c-text-inverse); border-radius: var(--r-md); }
.site-skip:focus { left: var(--sp-3); top: var(--sp-3); }

/* ---------- Boutons ---------- */
.btn {
    display: inline-flex; align-items: center; justify-content: center; gap: var(--sp-2);
    padding: 12px 22px; border-radius: var(--r-full); border: 1px solid transparent;
    font-weight: var(--fw-semibold); font-size: var(--fs-body); text-decoration: none; cursor: pointer;
    transition: transform var(--t-fast) var(--ease-out), box-shadow var(--t-fast) var(--ease-out),
        background var(--t-fast) var(--ease-out), border-color var(--t-fast) var(--ease-out);
}
.btn-primary {
    color: var(--c-text-inverse);
    background: linear-gradient(135deg, var(--c-primary), var(--c-accent));
    box-shadow: 0 8px 24px -8px var(--c-primary), var(--e1);
}
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 14px 34px -8px var(--c-primary), var(--e2); }
.btn-ghost { color: var(--c-primary); background: var(--c-surface); border-color: var(--c-border); }
.btn-ghost:hover { border-color: var(--c-primary); background: var(--c-primary-50); }
.btn-inverse { color: var(--c-primary); background: var(--c-surface); }
.btn-inverse:hover { transform: translateY(-2px); box-shadow: var(--e3); }
.btn-lg { padding: 15px 30px; font-size: var(--fs-h4); }
.btn svg { width: 18px; height: 18px; }

/* ---------- Navbar (glass, sticky) ---------- */
.site-nav {
    position: sticky; top: 0; z-index: var(--z-sticky);
    background: rgba(255, 255, 255, 0.72);
    backdrop-filter: saturate(180%) blur(14px);
    -webkit-backdrop-filter: saturate(180%) blur(14px);
    border-bottom: 1px solid var(--c-border);
}
.site-nav-inner { display: flex; align-items: center; gap: var(--sp-4); min-height: 68px; }
.site-brand { display: inline-flex; align-items: center; gap: var(--sp-2); text-decoration: none; font-weight: var(--fw-bold); color: var(--c-text); }
.site-brand img { height: 30px; width: auto; }
.site-brand span { font-size: var(--fs-h4); letter-spacing: -0.01em; }
.site-nav-links { display: flex; gap: var(--sp-5); margin-inline-start: var(--sp-6); }
.site-nav-links a { text-decoration: none; color: var(--c-text-muted); font-weight: var(--fw-medium); font-size: var(--fs-small); }
.site-nav-links a:hover { color: var(--c-primary); }
.site-nav-right { display: flex; align-items: center; gap: var(--sp-3); margin-inline-start: auto; }
.site-lang { display: inline-flex; gap: 2px; padding: 3px; border: 1px solid var(--c-border); border-radius: var(--r-full); background: var(--c-surface); }
.site-lang a { text-decoration: none; padding: 3px 10px; border-radius: var(--r-full); font-size: var(--fs-caption); font-weight: var(--fw-semibold); color: var(--c-text-muted); }
.site-lang a.is-active { color: var(--c-text-inverse); background: var(--c-primary); }
.site-nav-signin { text-decoration: none; color: var(--c-text); font-weight: var(--fw-medium); font-size: var(--fs-small); }
.site-nav-signin:hover { color: var(--c-primary); }

/* Menu mobile (checkbox hack, sans JS) */
.site-nav-check, .site-burger { display: none; }
.site-burger { width: 44px; height: 44px; border: 1px solid var(--c-border); border-radius: var(--r-md); background: var(--c-surface); align-items: center; justify-content: center; cursor: pointer; }
.site-burger svg { width: 22px; height: 22px; color: var(--c-text); }

/* ---------- Hero ---------- */
.hero { position: relative; padding-block: clamp(var(--sp-10), 8vw, 96px) var(--sp-16); overflow: hidden; }
.hero-grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: var(--sp-10); align-items: center; }
.hero-eyebrow {
    display: inline-flex; align-items: center; gap: var(--sp-2);
    padding: 6px 14px; border-radius: var(--r-full);
    background: var(--c-primary-50); color: var(--c-primary-strong);
    font-size: var(--fs-small); font-weight: var(--fw-semibold);
}
.hero-eyebrow .dot { width: 8px; height: 8px; border-radius: var(--r-full); background: var(--c-accent); }
.hero-title {
    margin: var(--sp-5) 0 0; font-family: var(--font-display);
    font-size: clamp(2.2rem, 5.2vw, 3.6rem); line-height: 1.05; letter-spacing: -0.02em; font-weight: var(--fw-bold);
}
.grad {
    background: linear-gradient(120deg, var(--c-primary), var(--c-accent));
    -webkit-background-clip: text; background-clip: text; color: transparent;
}
.hero-lead { margin: var(--sp-5) 0 0; max-width: 34ch; font-size: var(--fs-h4); color: var(--c-text-muted); }
.hero-actions { display: flex; flex-wrap: wrap; gap: var(--sp-3); margin-top: var(--sp-8); }
.hero-trust { display: flex; flex-wrap: wrap; gap: var(--sp-5); margin-top: var(--sp-8); color: var(--c-text-muted); font-size: var(--fs-small); }
.hero-trust span { display: inline-flex; align-items: center; gap: var(--sp-2); }
.hero-trust svg { width: 18px; height: 18px; color: var(--c-success); }
.hero-media { position: relative; }
.hero-media img { width: 100%; height: auto; filter: drop-shadow(0 30px 60px rgba(0, 0, 0, 0.18)); border-radius: var(--r-xl); }

/* Blobs décoratifs */
.blob { position: absolute; border-radius: var(--r-full); filter: blur(60px); opacity: 0.5; z-index: -1; pointer-events: none; }
.blob-1 { width: 420px; height: 420px; top: -120px; inset-inline-end: -80px; background: var(--c-primary-200); }
.blob-2 { width: 360px; height: 360px; bottom: -140px; inset-inline-start: -120px; background: var(--c-accent-300); opacity: 0.35; }

/* ---------- Bande de confiance ---------- */
.trust-strip { border-block: 1px solid var(--c-border); background: var(--c-surface); }
.trust-strip .site-container { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: var(--sp-6) var(--sp-10); padding-block: var(--sp-6); }
.trust-item { display: inline-flex; align-items: center; gap: var(--sp-2); color: var(--c-text-muted); font-weight: var(--fw-medium); font-size: var(--fs-small); }
.trust-item svg { width: 20px; height: 20px; color: var(--c-primary); }

/* ---------- Sections ---------- */
.section { padding-block: clamp(var(--sp-12), 9vw, 104px); }
.section-alt { background: var(--c-surface); border-block: 1px solid var(--c-border); }
.section-head { max-width: 640px; margin-inline: auto; text-align: center; margin-bottom: var(--sp-10); }
.section-eyebrow { color: var(--c-primary); font-weight: var(--fw-semibold); font-size: var(--fs-small); letter-spacing: 0.04em; text-transform: uppercase; }
.section-title { margin: var(--sp-2) 0 0; font-size: clamp(1.7rem, 3.6vw, 2.4rem); line-height: 1.15; letter-spacing: -0.01em; font-weight: var(--fw-bold); }
.section-lead { margin: var(--sp-3) 0 0; color: var(--c-text-muted); font-size: var(--fs-h4); }

/* ---------- Features ---------- */
.features-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-5); }
.feature {
    padding: var(--sp-6); background: var(--c-surface); border: 1px solid var(--c-border);
    border-radius: var(--r-lg); box-shadow: var(--e1);
    transition: transform var(--t-base) var(--ease-out), box-shadow var(--t-base) var(--ease-out), border-color var(--t-base) var(--ease-out);
}
.feature:hover { transform: translateY(-4px); box-shadow: var(--e3); border-color: var(--c-primary-200); }
.feature-icon {
    display: grid; place-items: center; width: 52px; height: 52px; border-radius: var(--r-md);
    color: var(--c-text-inverse); background: linear-gradient(135deg, var(--c-primary), var(--c-accent));
    box-shadow: 0 8px 20px -8px var(--c-primary);
}
.feature-icon svg { width: 26px; height: 26px; }
.feature h3 { margin: var(--sp-4) 0 var(--sp-2); font-size: var(--fs-h4); }
.feature p { margin: 0; color: var(--c-text-muted); font-size: var(--fs-small); }

/* ---------- Étapes ---------- */
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-6); counter-reset: step; }
.step { position: relative; padding: var(--sp-6); text-align: center; }
.step-num {
    display: grid; place-items: center; width: 56px; height: 56px; margin-inline: auto;
    border-radius: var(--r-full); font-size: var(--fs-h3); font-weight: var(--fw-bold);
    color: var(--c-primary); background: var(--c-primary-50); border: 2px solid var(--c-surface);
    box-shadow: var(--e2);
}
.step h3 { margin: var(--sp-4) 0 var(--sp-2); font-size: var(--fs-h4); }
.step p { margin: 0; color: var(--c-text-muted); font-size: var(--fs-small); }

/* ---------- Tarifs ---------- */
.pricing { display: grid; grid-template-columns: repeat(2, minmax(0, 380px)); gap: var(--sp-6); justify-content: center; }
.plan {
    position: relative; padding: var(--sp-8); background: var(--c-surface);
    border: 1px solid var(--c-border); border-radius: var(--r-xl); box-shadow: var(--e1);
}
.plan.is-featured { border-color: var(--c-primary); box-shadow: 0 24px 60px -24px var(--c-primary), var(--e2); }
.plan-badge {
    position: absolute; top: 0; inset-inline-end: var(--sp-6); transform: translateY(-50%);
    padding: 5px 14px; border-radius: var(--r-full); font-size: var(--fs-caption); font-weight: var(--fw-semibold);
    color: var(--c-text-inverse); background: linear-gradient(135deg, var(--c-primary), var(--c-accent));
}
.plan-name { font-size: var(--fs-h3); font-weight: var(--fw-bold); }
.plan-tagline { margin: var(--sp-2) 0 var(--sp-5); color: var(--c-text-muted); font-size: var(--fs-small); }
.plan-price { font-size: var(--fs-display); font-weight: var(--fw-bold); line-height: 1; letter-spacing: -0.02em; }
.plan-price small { font-size: var(--fs-body); font-weight: var(--fw-medium); color: var(--c-text-muted); }
.plan-list { list-style: none; margin: var(--sp-6) 0; padding: 0; display: grid; gap: var(--sp-3); }
.plan-list li { display: flex; align-items: flex-start; gap: var(--sp-2); font-size: var(--fs-small); }
.plan-list svg { flex: 0 0 auto; width: 18px; height: 18px; margin-top: 2px; color: var(--c-success); }
.plan .btn { width: 100%; }

/* ---------- FAQ ---------- */
.faq { max-width: 760px; margin-inline: auto; display: grid; gap: var(--sp-3); }
.faq-item { background: var(--c-surface); border: 1px solid var(--c-border); border-radius: var(--r-lg); overflow: hidden; }
.faq-q {
    list-style: none; cursor: pointer; padding: var(--sp-5); font-weight: var(--fw-semibold);
    display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3);
}
.faq-q::-webkit-details-marker { display: none; }
.faq-q .chev { width: 20px; height: 20px; flex: 0 0 auto; color: var(--c-text-muted); transition: transform var(--t-fast) var(--ease-out); }
.faq-item[open] .faq-q .chev { transform: rotate(180deg); }
.faq-a { padding: 0 var(--sp-5) var(--sp-5); margin: 0; color: var(--c-text-muted); font-size: var(--fs-small); }

/* ---------- Bande CTA finale ---------- */
.cta-band { padding-block: clamp(var(--sp-12), 8vw, 88px); }
.cta-card {
    position: relative; overflow: hidden; text-align: center;
    padding: clamp(var(--sp-8), 6vw, 64px) var(--sp-6);
    border-radius: var(--r-xl); color: var(--c-text-inverse);
    background: linear-gradient(135deg, var(--c-primary-700), var(--c-primary-900));
    box-shadow: var(--e4);
}
.cta-card::after { content: ""; position: absolute; width: 320px; height: 320px; border-radius: var(--r-full); background: var(--c-accent-500); opacity: 0.25; filter: blur(70px); top: -120px; inset-inline-end: -60px; }
.cta-card h2 { position: relative; margin: 0; font-size: clamp(1.7rem, 4vw, 2.4rem); letter-spacing: -0.01em; }
.cta-card p { position: relative; margin: var(--sp-3) auto var(--sp-8); max-width: 46ch; opacity: 0.9; }
.cta-card .btn { position: relative; }

/* ---------- Footer ---------- */
.site-footer { background: var(--c-surface); border-top: 1px solid var(--c-border); padding-block: var(--sp-12) var(--sp-6); }
.footer-grid { display: grid; grid-template-columns: 1.4fr repeat(4, 1fr); gap: var(--sp-6); }
.footer-brand img { height: 30px; margin-bottom: var(--sp-3); }
.footer-brand p { color: var(--c-text-muted); font-size: var(--fs-small); max-width: 30ch; }
.footer-social { display: flex; gap: var(--sp-2); margin-top: var(--sp-4); }
.footer-social a { display: grid; place-items: center; width: 38px; height: 38px; border-radius: var(--r-full); border: 1px solid var(--c-border); color: var(--c-text-muted); }
.footer-social a:hover { color: var(--c-primary); border-color: var(--c-primary); }
.footer-social svg { width: 18px; height: 18px; }
.footer-col h4 { margin: 0 0 var(--sp-3); font-size: var(--fs-small); text-transform: uppercase; letter-spacing: 0.04em; color: var(--c-text-muted); }
.footer-col a { display: block; text-decoration: none; color: var(--c-text); font-size: var(--fs-small); margin-bottom: var(--sp-2); }
.footer-col a:hover { color: var(--c-primary); }
.footer-bottom { display: flex; flex-wrap: wrap; gap: var(--sp-3); align-items: center; justify-content: space-between; margin-top: var(--sp-10); padding-top: var(--sp-6); border-top: 1px solid var(--c-border); color: var(--c-text-muted); font-size: var(--fs-caption); }

/* ---------- Bandeau cookies ---------- */
.cookie { position: fixed; inset-inline: var(--sp-4); bottom: var(--sp-4); z-index: var(--z-toast); }
.cookie[hidden] { display: none; }
.cookie-inner {
    max-width: 720px; margin-inline: auto; display: flex; flex-wrap: wrap; align-items: center; gap: var(--sp-4);
    padding: var(--sp-4) var(--sp-5); background: var(--c-surface); border: 1px solid var(--c-border);
    border-radius: var(--r-lg); box-shadow: var(--e3);
}
.cookie-inner p { margin: 0; flex: 1 1 260px; font-size: var(--fs-small); color: var(--c-text-muted); }
.cookie-inner .btn { padding: 9px 18px; }

/* ---------- Révélation au scroll (progressive) ---------- */
/* État masqué appliqué UNIQUEMENT si JS est actif (classe .js) → sans JS, tout reste visible. */
.js .reveal { opacity: 0; transform: translateY(16px); transition: opacity var(--t-slow) var(--ease-out), transform var(--t-slow) var(--ease-out); }
.js .reveal.is-visible { opacity: 1; transform: none; }

/* ---------- Pages légales (SCR-PUB-LEGAL) ---------- */
.legal { padding-block: var(--sp-8) var(--sp-16); }
.legal-crumb { display: flex; flex-wrap: wrap; gap: var(--sp-2); align-items: center; margin-bottom: var(--sp-6); font-size: var(--fs-small); color: var(--c-text-muted); }
.legal-crumb a { color: var(--c-primary); text-decoration: none; }
.legal-crumb a:hover { text-decoration: underline; }
.legal-crumb .is-current { color: var(--c-text); font-weight: var(--fw-medium); }
.legal-grid { display: grid; grid-template-columns: 250px minmax(0, 1fr); gap: var(--sp-8); align-items: start; }
.legal-nav { position: sticky; top: 88px; padding: var(--sp-5); background: var(--c-surface); border: 1px solid var(--c-border); border-radius: var(--r-lg); }
.legal-nav h2 { margin: 0 0 var(--sp-3); font-size: var(--fs-small); text-transform: uppercase; letter-spacing: 0.04em; color: var(--c-text-muted); }
.legal-nav ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 2px; }
.legal-nav a { display: block; padding: 8px 12px; border-radius: var(--r-sm); text-decoration: none; color: var(--c-text); font-size: var(--fs-small); }
.legal-nav a:hover { background: var(--c-primary-50); color: var(--c-primary); }
.legal-nav a.is-active { background: var(--c-primary); color: var(--c-text-inverse); font-weight: var(--fw-medium); }
.legal-content { min-width: 0; }
.legal-head { margin-bottom: var(--sp-6); padding-bottom: var(--sp-5); border-bottom: 1px solid var(--c-border); }
.legal-head h1 { margin: 0; font-size: clamp(1.6rem, 3.4vw, 2.2rem); letter-spacing: -0.01em; }
.legal-updated { margin: var(--sp-2) 0 0; color: var(--c-text-muted); font-size: var(--fs-small); }
.legal-notice { display: flex; align-items: flex-start; gap: var(--sp-2); margin-top: var(--sp-4); padding: var(--sp-3) var(--sp-4); background: var(--c-warning-bg); color: var(--c-warning); border-radius: var(--r-md); font-size: var(--fs-small); }
.legal-notice svg { flex: 0 0 auto; width: 18px; height: 18px; margin-top: 1px; }
.legal-content > .btn { margin-top: var(--sp-8); }

/* Typographie de contenu long (Markdown rendu) */
.prose { max-width: 72ch; color: var(--c-text); }
.prose h2 { margin: var(--sp-8) 0 var(--sp-3); font-size: var(--fs-h3); letter-spacing: -0.01em; }
.prose h3 { margin: var(--sp-6) 0 var(--sp-2); font-size: var(--fs-h4); }
.prose p { margin: 0 0 var(--sp-4); line-height: 1.7; }
.prose ul, .prose ol { margin: 0 0 var(--sp-4); padding-inline-start: var(--sp-6); }
.prose li { margin-bottom: var(--sp-2); line-height: 1.6; }
.prose strong { font-weight: var(--fw-semibold); }
.prose a { color: var(--c-primary); text-decoration: underline; text-underline-offset: 2px; }
.prose a:hover { color: var(--c-primary-strong); }
.prose em { color: var(--c-text-muted); }
.prose hr { border: 0; border-top: 1px solid var(--c-border); margin: var(--sp-6) 0; }
.prose table { width: 100%; border-collapse: collapse; margin: 0 0 var(--sp-4); font-size: var(--fs-small); }
.prose th, .prose td { padding: var(--sp-2) var(--sp-3); border: 1px solid var(--c-border); text-align: start; }
.prose th { background: var(--c-primary-50); }

/* ---------- Responsive ---------- */
@media (max-width: 900px) {
    .legal-grid { grid-template-columns: 1fr; }
    .legal-nav { position: static; }
    .hero-grid { grid-template-columns: 1fr; }
    .hero-media { order: -1; max-width: 460px; margin-inline: auto; }
    .features-grid, .steps { grid-template-columns: 1fr 1fr; }
    .footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
    .site-nav-links { display: none; }
    .site-burger { display: inline-flex; }
    .site-nav-check:checked ~ .site-nav-links {
        display: flex; flex-direction: column; gap: var(--sp-2);
        position: absolute; inset-inline: 0; top: 68px; margin: 0; padding: var(--sp-4) var(--sp-5);
        background: var(--c-surface); border-bottom: 1px solid var(--c-border); box-shadow: var(--e2);
    }
    .features-grid, .steps, .pricing, .footer-grid { grid-template-columns: 1fr; }
    .plan.is-featured { order: -1; }
}
@media (prefers-reduced-motion: reduce) {
    .js .reveal { opacity: 1; transform: none; transition: none; }
    .btn, .feature { transition: none; }
}
