/* ============================================================
   Yombi — Site vitrine (marketing). Thème de marque.
   ============================================================ */
:root {
    --yombi-dark:  #0A3B2A;
    --yombi-green: #2D7A4B;
    --yombi-light: #3A9B5E;
    --yombi-mint:  #eaf6ef;
    --ink:    #1d2b24;
    --muted:  #5b6b64;
    --line:   #e6ede9;
    --grad: linear-gradient(135deg, #0A3B2A 0%, #2D7A4B 55%, #3A9B5E 100%);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    font-family: 'Segoe UI', 'Trebuchet MS', system-ui, Arial, sans-serif;
    color: var(--ink);
    line-height: 1.6;
    margin: 0;
    -webkit-font-smoothing: antialiased;
}
a { text-decoration: none; }
section { padding: 84px 0; }
.section-title { font-weight: 800; letter-spacing: -.5px; }
.eyebrow {
    text-transform: uppercase; letter-spacing: 2px; font-size: .8rem;
    font-weight: 700; color: var(--yombi-green);
}
.text-muted2 { color: var(--muted); }

/* ── Boutons ── */
.btn-yombi {
    background: var(--yombi-green); color: #fff; border: none;
    padding: .8rem 1.7rem; border-radius: 999px; font-weight: 600;
    transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
    display: inline-block;
}
.btn-yombi:hover { background: var(--yombi-dark); color: #fff; transform: translateY(-2px); box-shadow: 0 10px 24px rgba(10,59,42,.25); }
.btn-ghost {
    background: transparent; color: #fff; border: 1.5px solid rgba(255,255,255,.5);
    padding: .8rem 1.7rem; border-radius: 999px; font-weight: 600; display: inline-block;
    transition: background .15s ease, border-color .15s ease;
}
.btn-ghost:hover { background: rgba(255,255,255,.12); color: #fff; border-color: #fff; }
.btn-outline-yombi {
    background: #fff; color: var(--yombi-green); border: 1.5px solid var(--yombi-green);
    padding: .8rem 1.7rem; border-radius: 999px; font-weight: 600; display: inline-block;
    transition: all .15s ease;
}
.btn-outline-yombi:hover { background: var(--yombi-green); color: #fff; }

/* ── Navbar ── */
.nav-wrap {
    position: sticky; top: 0; z-index: 1030; background: rgba(255,255,255,.92);
    backdrop-filter: blur(10px); border-bottom: 1px solid var(--line);
}
.nav-inner { display: flex; align-items: center; justify-content: space-between; padding: 12px 0; }
.nav-logo img { height: 38px; }
.nav-links { display: flex; align-items: center; gap: 28px; }
.nav-links a { color: var(--ink); font-weight: 500; font-size: .95rem; }
.nav-links a:hover { color: var(--yombi-green); }
@media (max-width: 860px) { .nav-links .nav-link-item { display: none; } }

/* ── Hero ── */
.hero { background: var(--grad); color: #fff; padding: 96px 0 110px; position: relative; overflow: hidden; }
.hero::after {
    content: ""; position: absolute; right: -120px; top: -120px;
    width: 420px; height: 420px; border-radius: 50%;
    background: radial-gradient(circle, rgba(255,255,255,.10), transparent 70%);
}
.hero h1 { font-size: clamp(2.1rem, 4.5vw, 3.4rem); font-weight: 800; letter-spacing: -1px; line-height: 1.12; }
.hero .lead { font-size: 1.2rem; opacity: .92; max-width: 560px; }
.hero .badge-soft {
    display: inline-block; background: rgba(255,255,255,.14); border: 1px solid rgba(255,255,255,.25);
    padding: 6px 14px; border-radius: 999px; font-size: .82rem; font-weight: 600; margin-bottom: 18px;
}
.hero-card {
    background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.18);
    border-radius: 22px; padding: 14px; box-shadow: 0 30px 70px rgba(0,0,0,.25);
}
.hero-card .mock {
    background: #fff; border-radius: 14px; aspect-ratio: 16/10; width: 100%;
    display: flex; align-items: center; justify-content: center; color: var(--muted);
    flex-direction: column; gap: 8px; text-align: center; padding: 16px;
}
.hero-card .mock i { font-size: 2.4rem; color: var(--yombi-light); }

/* ── Stats bar ── */
.stats { background: #fff; border-bottom: 1px solid var(--line); }
.stat h3 { font-weight: 800; color: var(--yombi-green); font-size: 2rem; margin: 0; }
.stat p { color: var(--muted); margin: 0; font-size: .92rem; }

/* ── Valeur (cards) ── */
.value-card {
    background: #fff; border: 1px solid var(--line); border-radius: 18px; padding: 28px;
    height: 100%; transition: transform .18s ease, box-shadow .18s ease;
}
.value-card:hover { transform: translateY(-4px); box-shadow: 0 18px 40px rgba(10,59,42,.10); }
.value-ico {
    width: 54px; height: 54px; border-radius: 14px; background: var(--yombi-mint);
    color: var(--yombi-green); display: flex; align-items: center; justify-content: center;
    font-size: 1.4rem; margin-bottom: 16px;
}

/* ── Modules ── */
.modules { background: var(--yombi-mint); }
.module-tile {
    background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 18px 16px;
    text-align: center; height: 100%; transition: transform .15s ease, box-shadow .15s ease;
}
.module-tile:hover { transform: translateY(-3px); box-shadow: 0 12px 28px rgba(10,59,42,.10); }
.module-tile i { font-size: 1.5rem; color: var(--yombi-green); margin-bottom: 8px; }
.module-tile span { display: block; font-weight: 600; font-size: .92rem; }

/* ── Captures ── */
.shot {
    background: #fff; border: 1px solid var(--line); border-radius: 16px; overflow: hidden;
    box-shadow: 0 14px 34px rgba(10,59,42,.08);
}
.shot .ph {
    aspect-ratio: 16/10; background: linear-gradient(135deg,#f2f8f4,#e3f0e8);
    display: flex; align-items: center; justify-content: center; flex-direction: column;
    color: var(--muted); gap: 8px;
}
.shot .ph i { font-size: 2.2rem; color: var(--yombi-light); }
.shot .cap { padding: 14px 18px; font-weight: 600; }

/* Zoom au survol : la capture s'agrandit pour une meilleure lecture */
#apercu .shot { transition: transform .3s ease, box-shadow .3s ease; cursor: zoom-in; }
#apercu .shot:hover {
    transform: scale(1.65);
    position: relative;
    z-index: 30;
    box-shadow: 0 30px 75px rgba(10,59,42,.32);
}
/* Garde les captures de bord dans le cadre (origine du zoom adaptée) */
#apercu .row > div:first-child .shot { transform-origin: left center; }
#apercu .row > div:last-child  .shot { transform-origin: right center; }
@media (max-width: 767.98px) { #apercu .shot:hover { transform: scale(1.05); } }

/* ── Forfaits ── */
.plan {
    background: #fff; border: 1px solid var(--line); border-radius: 20px; padding: 32px 28px;
    height: 100%; display: flex; flex-direction: column; transition: transform .18s ease, box-shadow .18s ease;
}
.plan:hover { transform: translateY(-4px); box-shadow: 0 18px 44px rgba(10,59,42,.12); }
.plan.featured { border: 2px solid var(--yombi-green); position: relative; }
.plan.featured::before {
    content: "Le plus choisi"; position: absolute; top: -13px; left: 50%; transform: translateX(-50%);
    background: var(--yombi-green); color: #fff; font-size: .72rem; font-weight: 700;
    padding: 5px 14px; border-radius: 999px; letter-spacing: .5px;
}
.plan .plan-name { font-weight: 800; font-size: 1.3rem; color: var(--yombi-dark); }
.plan .plan-tag { color: var(--muted); font-size: .92rem; margin-bottom: 18px; }
.plan ul { list-style: none; padding: 0; margin: 0 0 24px; }
.plan li { padding: 7px 0; border-bottom: 1px dashed var(--line); font-size: .95rem; }
.plan li i { color: var(--yombi-green); margin-right: 8px; }
.plan li.off { color: #aab4af; }
.plan li.off i { color: #cdd6d1; }

/* ── CTA finale ── */
.cta { background: var(--grad); color: #fff; border-radius: 28px; padding: 56px; text-align: center; }
.cta h2 { font-weight: 800; }

/* Formulaire de demande (démo / devis) */
.lead-form .lf {
    width: 100%; padding: 12px 14px; border: none; border-radius: 12px;
    font-size: .95rem; font-family: inherit; color: var(--ink); background: #fff;
}
.lead-form .lf::placeholder { color: #9aa5a2; }
.lead-form .lf:focus { outline: 3px solid rgba(255,255,255,.4); }
.lead-form select.lf { appearance: auto; }
.lead-form .form-msg { margin-top: 14px; padding: 12px 16px; border-radius: 12px; font-weight: 600; font-size: .92rem; }
.lead-form .form-msg.ok { background: #e7f7ee; color: #0a3b2a; }
.lead-form .form-msg.err { background: #fde8e8; color: #7a1f1f; }
.lead-form .form-msg.pending { background: rgba(255,255,255,.2); color: #fff; }

/* ── Footer ── */
footer { background: var(--yombi-dark); color: #cfe0d7; padding: 48px 0 28px; }
footer a { color: #cfe0d7; }
footer a:hover { color: #fff; }
footer .brand img { height: 34px; }
.footer-sep { border-top: 1px solid rgba(255,255,255,.12); margin: 26px 0 16px; }
