/* styles spécifiques à la page produit "Ontis" */
/* Les classes communes aux pages intérieures (.section, .wrap, .eyebrow, .sec-head, .ghost,
   .split, .checklist, .check, .stats, .badge-soft, .ph, .int-hero, …) sont fournies par
   assets/css/inner-pages.css, assets/css/inner-hero.css et style.css, chargés globalement. */

/* ─── HERO — GRILLE TEXTE + APERÇU NAVIGATEUR ─────────────────── */
.oh-inner {
    position: relative;
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: center;
    gap: 56px;
    padding: 64px 0 78px;
}

@media (max-width: 980px) {
    .oh-inner {
        grid-template-columns: 1fr;
        gap: 44px;
        padding: 48px 0 56px;
    }
}

.oh-copy .lede {
    max-width: 540px;
}

.oh-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 28px;
}

.oh-pill {
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 12.5px;
    color: rgba(255, 255, 255, 0.78);
    background: rgba(255, 255, 255, 0.07);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 999px;
    padding: 8px 16px;
}

/* ─── APERÇU NAVIGATEUR (browser frame mockup) ────────────────── */
.bframe {
    background: #ffffff;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 30px 80px rgba(0, 0, 0, 0.35);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.bframe-bar {
    display: flex;
    align-items: center;
    gap: 7px;
    background: #eef2f9;
    padding: 12px 16px;
    border-bottom: 1px solid #e6ecf4;
}

.bframe-dot {
    width: 11px;
    height: 11px;
    border-radius: 50%;
    display: inline-block;
}

.bd-red { background: #ff5f57; }
.bd-yellow { background: #febc2e; }
.bd-green { background: #28c840; }

.bframe-bar .url {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    margin: 0 auto;
    background: #ffffff;
    border: 1px solid #e6ecf4;
    border-radius: 999px;
    padding: 6px 18px;
    font-family: 'IBM Plex Mono', monospace;
    font-size: 12px;
    color: #5b6b82;
}

.bframe-bar .url svg {
    width: 13px;
    height: 13px;
    color: #8593a6;
}

.bframe img {
    display: block;
    width: 100%;
    height: auto;
}

/* ─── CAPACITÉS — GRILLE DE CARTES ────────────────────────────── */
.cap-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
}

@media (max-width: 980px) {
    .cap-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 560px) {
    .cap-grid {
        grid-template-columns: 1fr;
    }
}

.cap {
    background: #ffffff;
    border: 1px solid #e6ecf4;
    border-radius: 18px;
    padding: 26px 24px;
    transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s;
}

.cap:hover {
    transform: translateY(-4px);
    box-shadow: 0 18px 44px rgba(16, 38, 76, 0.10);
    border-color: transparent;
}

.cap .ci {
    width: 46px;
    height: 46px;
    border-radius: 12px;
    background: #e7edff;
    color: #2e5bff;
    display: grid;
    place-items: center;
    margin-bottom: 16px;
}

.cap .ci svg {
    width: 23px;
    height: 23px;
}

.cap h3 {
    font-family: 'Poppins', sans-serif;
    font-size: 16.5px;
    font-weight: 700;
    color: #142036;
    margin-bottom: 8px;
}

.cap p {
    color: #5b6b82;
    font-size: 13.5px;
    line-height: 1.6;
}

/* ─── AUDIENCES — ORGANISATEURS / GESTIONNAIRES ───────────────── */
.aud {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 26px;
}

@media (max-width: 820px) {
    .aud {
        grid-template-columns: 1fr;
    }
}

.aud-card {
    background: #ffffff;
    border: 1px solid #e6ecf4;
    border-radius: 22px;
    padding: 34px 32px;
}

.aud-card .ai {
    width: 50px;
    height: 50px;
    border-radius: 14px;
    display: grid;
    place-items: center;
    margin-bottom: 18px;
}

.aud-card .ai svg {
    width: 25px;
    height: 25px;
}

.aud-card.org .ai {
    background: #e7edff;
    color: #2e5bff;
}

.aud-card.ges .ai {
    background: #dcfce7;
    color: #16a34a;
}

.aud-card .badge-soft {
    margin-bottom: 14px;
}

.aud-card.ges .badge-soft {
    color: #16a34a;
    background: #dcfce7;
}

.aud-card h3 {
    font-family: 'Poppins', sans-serif;
    font-size: 21px;
    font-weight: 800;
    letter-spacing: -0.02em;
    color: #142036;
    margin-bottom: 10px;
}

.aud-card p {
    color: #5b6b82;
    font-size: 14.5px;
    line-height: 1.7;
}

.aud-card ul {
    display: flex;
    flex-direction: column;
    gap: 14px;
    margin-top: 26px;
}

.aud-card ul li {
    display: flex;
    align-items: flex-start;
    gap: 13px;
    color: #5b6b82;
    font-size: 14px;
    line-height: 1.6;
}

.aud-card ul li .ck {
    flex-shrink: 0;
    width: 24px;
    height: 24px;
    border-radius: 8px;
    display: grid;
    place-items: center;
    margin-top: 1px;
}

.aud-card ul li .ck svg {
    width: 13px;
    height: 13px;
}

.aud-card.org ul li .ck {
    background: #e7edff;
    color: #2e5bff;
}

.aud-card.ges ul li .ck {
    background: #dcfce7;
    color: #16a34a;
}

/* ─── BANDEAU CTA SPÉCIAL ONTIS (cta-brand) ───────────────────── */
/* Variante distincte du .cta-band global du site (style.css) :
   markup et palette propres à la page produit Ontis. */
.cta-brand {
    position: relative;
    overflow: hidden;
    background: #0d1b2a;
    border-radius: 28px;
    padding: 76px 56px;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 20px;
}

.cta-brand-glow {
    position: absolute;
    top: -120px;
    left: 50%;
    transform: translateX(-50%);
    width: 520px;
    height: 360px;
    background: radial-gradient(ellipse, rgba(46, 91, 255, 0.32), transparent 68%);
    pointer-events: none;
}

.cta-brand-tag {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 9px;
    padding: 8px 16px;
    border-radius: 999px;
    background: rgba(46, 91, 255, 0.18);
    color: #a8bcff;
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 12.5px;
    letter-spacing: 0.13em;
    text-transform: uppercase;
}

.cta-brand-tag .dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: #2e5bff;
}

.cta-brand h2 {
    position: relative;
    font-family: 'Poppins', sans-serif;
    font-size: clamp(28px, 4vw, 40px);
    font-weight: 800;
    letter-spacing: -0.02em;
    line-height: 1.2;
    color: #ffffff;
    max-width: 620px;
}

.cta-brand h2 .blue {
    color: #7e9cff;
}

.cta-brand p {
    position: relative;
    color: rgba(255, 255, 255, 0.62);
    font-size: 16px;
    line-height: 1.7;
    max-width: 560px;
}

.cta-brand-actions {
    position: relative;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 16px;
    margin-top: 12px;
}

.btn-white,
.btn-dark {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 15px;
    border-radius: 12px;
    padding: 16px 30px;
    text-decoration: none;
    transition: transform 0.18s, background 0.2s, box-shadow 0.2s;
}

.btn-white {
    background: #ffffff;
    color: #142036;
    box-shadow: 0 16px 34px rgba(0, 0, 0, 0.22);
}

.btn-white:hover {
    transform: translateY(-2px);
    box-shadow: 0 20px 44px rgba(0, 0, 0, 0.28);
}

.btn-white svg {
    width: 17px;
    height: 17px;
}

.btn-dark {
    background: rgba(255, 255, 255, 0.06);
    color: #ffffff;
    border: 1px solid rgba(255, 255, 255, 0.18);
}

.btn-dark:hover {
    background: rgba(255, 255, 255, 0.12);
    transform: translateY(-2px);
}

@media (max-width: 640px) {
    .cta-brand {
        padding: 56px 28px;
    }
}
