/* home.css — Page d'accueil — MediProvital */


/* ── Variables ── */
:root {
    --mpv-blue: #1A6FA8;
    --mpv-blue-dark: #0D4D78;
    --mpv-navy: #1A3A5C;
    --mpv-blue-light: #EBF4FB;
    --mpv-gray: #F5F7FA;
    --mpv-border: #E2EBF3;
    --mpv-text: #2C3E50;
    --mpv-muted: #6B7C93;
    --mpv-radius: 12px;
    --mpv-shadow: 0 2px 12px rgba(26,111,168,.10);
    --mpv-shadow-hover: 0 8px 28px rgba(26,111,168,.18);
    --mpv-transition: all .25s ease;
}

/* ── Sections ── */
.mpv-section { padding: 70px 0; }
.mpv-section--white { background: #fff; }
.mpv-section--gray  { background: var(--mpv-gray); }
.mpv-section--blue  { background: var(--mpv-navy); }
.mpv-section-head { text-align:center; margin-bottom:45px; }
.mpv-section-head h2 { font-size:2rem; font-weight:700; color:var(--mpv-navy); margin-bottom:10px; }
.mpv-section-head p  { color:var(--mpv-muted); font-size:1.05rem; }
.mpv-section-head--white h2, .mpv-section-head--white p { color:#fff; }
.mpv-section-head--white p { opacity:.8; }
.mpv-section-cta { text-align:center; margin-top:40px; }

/* ── Buttons ── */
.mpv-btn-primary {
    display:inline-flex; align-items:center; gap:8px;
    background:var(--mpv-blue); color:#fff; padding:12px 26px;
    border-radius:8px; font-weight:600; text-decoration:none;
    transition:var(--mpv-transition); border:2px solid var(--mpv-blue);
}
.mpv-btn-primary:hover { background:var(--mpv-blue-dark); border-color:var(--mpv-blue-dark); color:#fff; transform:translateY(-2px); }

.mpv-btn-outline {
    display:inline-flex; align-items:center; gap:8px;
    background:transparent; color:var(--mpv-blue); padding:12px 26px;
    border-radius:8px; font-weight:600; text-decoration:none;
    transition:var(--mpv-transition); border:2px solid var(--mpv-blue);
}
.mpv-btn-outline:hover { background:var(--mpv-blue); color:#fff; transform:translateY(-2px); }

.mpv-btn-outline-dark {
    display:inline-flex; align-items:center; gap:8px;
    background:transparent; color:var(--mpv-navy); padding:11px 26px;
    border-radius:8px; font-weight:600; text-decoration:none;
    transition:var(--mpv-transition); border:2px solid var(--mpv-navy);
}
.mpv-btn-outline-dark:hover { background:var(--mpv-navy); color:#fff; }

/* ── Hero ── */
.mpv-hero {
    position: relative;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    min-height: 560px;
    display: flex;
    align-items: center;
    padding: 80px 0 0;
}
.mpv-hero-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(135deg, rgba(8,24,50,.82) 0%, rgba(13,77,120,.70) 100%);
}
.mpv-hero-inner {
    position: relative; z-index: 2;
    text-align: center;
    display: flex; flex-direction: column; align-items: center;
    padding-bottom: 0;
}
.mpv-hero-audiences {
    display: flex; gap: 10px; flex-wrap: wrap; justify-content: center;
    margin-bottom: 22px;
}
.mpv-hero-audiences span {
    display: inline-flex; align-items: center; gap: 5px;
    background: rgba(255,255,255,.15); color: #fff;
    padding: 5px 14px; border-radius: 20px; font-size: 12.5px; font-weight: 500;
    border: 1px solid rgba(255,255,255,.25);
    backdrop-filter: blur(4px);
}
.mpv-hero-audiences svg { opacity: .85; }
.mpv-hero-title {
    font-size: 3rem; font-weight: 800; color: #fff;
    line-height: 1.18; margin-bottom: 18px;
    text-shadow: 0 2px 12px rgba(0,0,0,.35);
}
.mpv-hero-accent { color: #6EC6F0; }
.mpv-hero-desc {
    color: rgba(255,255,255,.88); font-size: 1.12rem;
    line-height: 1.7; margin-bottom: 32px; max-width: 600px;
}
.mpv-hero-ctas { display: flex; gap: 14px; flex-wrap: wrap; justify-content: center; margin-bottom: 52px; }
.mpv-hero-btn-primary {
    display: inline-flex; align-items: center; gap: 9px;
    background: var(--mpv-blue); color: #fff;
    padding: 14px 30px; border-radius: 8px; font-weight: 700;
    text-decoration: none; font-size: 1rem;
    transition: var(--mpv-transition);
    box-shadow: 0 4px 20px rgba(26,111,168,.45);
}
.mpv-hero-btn-primary:hover { background: var(--mpv-blue-dark); transform: translateY(-2px); color: #fff; }
.mpv-hero-btn-outline {
    display: inline-flex; align-items: center; gap: 9px;
    background: rgba(255,255,255,.12); color: #fff;
    padding: 14px 30px; border-radius: 8px; font-weight: 700;
    text-decoration: none; font-size: 1rem;
    border: 2px solid rgba(255,255,255,.55);
    transition: var(--mpv-transition);
    backdrop-filter: blur(4px);
}
.mpv-hero-btn-outline:hover { background: rgba(255,255,255,.25); color: #fff; transform: translateY(-2px); }

/* Barre de stats collée en bas du hero */
.mpv-hero-statsbar {
    width: 100%;
    background: rgba(255,255,255,.1);
    backdrop-filter: blur(8px);
    border-top: 1px solid rgba(255,255,255,.18);
    display: flex; justify-content: center; align-items: center;
    gap: 0; flex-wrap: wrap;
    padding: 0;
}
.mpv-hero-stat {
    flex: 1; min-width: 140px; text-align: center;
    padding: 18px 20px; color: #fff;
}
.mpv-hero-stat strong { display: block; font-size: 1.6rem; font-weight: 800; color: #6EC6F0; }
.mpv-hero-stat span   { font-size: .78rem; opacity: .85; font-weight: 500; }
.mpv-hero-stat-sep    { width: 1px; height: 40px; background: rgba(255,255,255,.2); align-self: center; }

/* ── Trust ── */
.mpv-trust { background:var(--mpv-navy); padding:16px 0; }
.mpv-trust-inner {
    display:flex; justify-content:space-around; align-items:center;
    flex-wrap:wrap; gap:12px;
}
.mpv-trust-item { display:flex; align-items:center; gap:10px; color:#fff; }
.mpv-trust-item svg { width:22px; height:22px; color:var(--mpv-blue); flex-shrink:0; }
.mpv-trust-item strong { display:block; font-size:.85rem; font-weight:600; }
.mpv-trust-item span   { font-size:.75rem; opacity:.75; }

/* ── Categories row ── */
.mpv-cats-row {
    display:grid; grid-template-columns:repeat(5,1fr); gap:20px;
}
.mpv-cat-card {
    background:#fff; border:1.5px solid var(--mpv-border); border-radius:var(--mpv-radius);
    padding:28px 18px; text-align:center; text-decoration:none;
    transition:var(--mpv-transition); display:flex; flex-direction:column; align-items:center; gap:10px;
}
.mpv-cat-card-icon {
    width:56px; height:56px; border-radius:14px; background:var(--mpv-blue-light);
    display:flex; align-items:center; justify-content:center; margin-bottom:4px;
}
.mpv-cat-card-icon svg { width:26px; height:26px; color:var(--mpv-blue); }
.mpv-cat-card h4 { font-size:.92rem; font-weight:700; color:var(--mpv-navy); margin:0; }
.mpv-cat-card p  { font-size:.78rem; color:var(--mpv-muted); margin:0; line-height:1.4; }
.mpv-cat-card-link { font-size:.8rem; color:var(--mpv-blue); font-weight:600; margin-top:auto; }
.mpv-cat-card:hover {
    border-color:var(--mpv-blue); box-shadow:var(--mpv-shadow-hover);
    transform:translateY(-4px);
}
.mpv-cat-card:hover .mpv-cat-card-icon { background:var(--mpv-blue); }
.mpv-cat-card:hover .mpv-cat-card-icon svg { color:#fff; }
.mpv-cat-card--photo {
    background-image: var(--cat-bg);
    background-size: cover; background-position: center;
    position: relative; overflow: hidden;
}
.mpv-cat-card--photo::before {
    content:''; position:absolute; inset:0;
    background: linear-gradient(180deg, rgba(13,30,60,.45) 0%, rgba(13,30,60,.75) 100%);
    border-radius: inherit;
}
.mpv-cat-card--photo > * { position: relative; z-index: 1; }
.mpv-cat-card--photo .mpv-cat-card-icon { background: rgba(255,255,255,.18); }
.mpv-cat-card--photo .mpv-cat-card-icon svg { color: #fff; }
.mpv-cat-card--photo h4 { color: #fff; }
.mpv-cat-card--photo p  { color: rgba(255,255,255,.8); }
.mpv-cat-card--photo .mpv-cat-card-link { color: var(--mpv-blue-light, #A8D4F0); }
.mpv-cat-card--photo:hover .mpv-cat-card-icon { background: var(--mpv-blue); }

/* ── Promo grid (section photos) ── */
.mpv-promo-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    height: 520px;
}
.mpv-promo-col {
    display: grid;
    grid-template-rows: 1fr 1fr;
}
.mpv-promo-card {
    position: relative;
    display: flex;
    align-items: flex-end;
    background-size: cover;
    background-position: center;
    overflow: hidden;
    text-decoration: none;
    transition: transform .4s ease;
}
.mpv-promo-card:hover { transform: scale(1.02); z-index: 1; }
.mpv-promo-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(0deg, rgba(8,24,50,.82) 0%, rgba(8,24,50,.25) 60%, transparent 100%);
}
.mpv-promo-overlay--accent {
    background: linear-gradient(0deg, rgba(180,50,0,.78) 0%, rgba(180,50,0,.2) 60%, transparent 100%);
}
.mpv-promo-content {
    position: relative; z-index: 1;
    padding: 28px 28px 28px;
    display: flex; flex-direction: column; gap: 6px;
}
.mpv-promo-tag {
    display: inline-flex; align-items: center; gap: 5px;
    background: rgba(255,255,255,.18); color: #fff;
    padding: 4px 12px; border-radius: 20px; font-size: 11.5px; font-weight: 600;
    border: 1px solid rgba(255,255,255,.3); width: fit-content;
    backdrop-filter: blur(4px);
}
.mpv-promo-tag--orange { background: rgba(230,126,34,.6); border-color: rgba(230,126,34,.8); }
.mpv-promo-content h3 { color: #fff; font-size: 1.15rem; font-weight: 700; margin: 0; line-height: 1.3; }
.mpv-promo-card--large .mpv-promo-content h3 { font-size: 1.55rem; }
.mpv-promo-content p { color: rgba(255,255,255,.82); font-size: .82rem; margin: 0; line-height: 1.5; }
.mpv-promo-card--large .mpv-promo-content p { font-size: .92rem; }
.mpv-promo-btn {
    display: inline-flex; align-items: center; gap: 6px;
    color: #6EC6F0; font-size: .82rem; font-weight: 700;
    margin-top: 6px;
}
.mpv-promo-card--large .mpv-promo-btn { font-size: .9rem; }

/* ── Bandeau promo pleine largeur ── */
.mpv-promo-banner {
    position: relative;
    background-size: cover; background-position: center;
    padding: 60px 0;
}
.mpv-promo-banner-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(90deg, rgba(8,24,50,.88) 0%, rgba(13,77,120,.65) 60%, transparent 100%);
}
.mpv-promo-banner-inner {
    position: relative; z-index: 1;
    display: flex; align-items: center; justify-content: space-between;
    gap: 30px; flex-wrap: wrap;
}
.mpv-promo-banner-text h2 { color: #fff; font-size: 1.9rem; font-weight: 800; margin: 0 0 10px; line-height: 1.25; }
.mpv-promo-banner-text p  { color: rgba(255,255,255,.8); font-size: 1rem; margin: 0; }
.mpv-promo-banner-btn {
    display: inline-flex; align-items: center; gap: 10px;
    background: var(--mpv-blue); color: #fff;
    padding: 15px 32px; border-radius: 8px; font-weight: 700; font-size: 1rem;
    text-decoration: none; white-space: nowrap;
    transition: var(--mpv-transition);
    box-shadow: 0 4px 20px rgba(26,111,168,.5);
    flex-shrink: 0;
}
.mpv-promo-banner-btn:hover { background: var(--mpv-blue-dark); transform: translateY(-2px); color: #fff; }

@media (max-width: 768px) {
    .mpv-promo-grid { grid-template-columns: 1fr; height: auto; }
    .mpv-promo-card--large { min-height: 280px; }
    .mpv-promo-col .mpv-promo-card { min-height: 200px; }
    .mpv-promo-banner-inner { flex-direction: column; text-align: center; }
    .mpv-promo-banner-text h2 { font-size: 1.4rem; }
}

/* ── Section promotions ── */
.mpv-section--promo {
    background: linear-gradient(135deg, #fff8f0 0%, #fff3e8 100%);
    border-top: 3px solid #E8621A;
}
.mpv-promo-head-left { flex: 1; }
.mpv-promo-eyebrow {
    display: inline-flex; align-items: center; gap: 6px;
    background: rgba(232,98,26,.12); color: #E8621A;
    padding: 5px 13px; border-radius: 20px; font-size: 12.5px; font-weight: 700;
    margin-bottom: 8px;
}
.mpv-section-head {
    display: flex; align-items: flex-end; justify-content: space-between;
    margin-bottom: 32px; flex-wrap: wrap; gap: 16px;
}
.mpv-section-head h2 { margin: 0 0 4px; }
.mpv-section-head p  { margin: 0; color: var(--mpv-muted); font-size: .93rem; }
.mpv-promo-products-row {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
}
@media (max-width: 900px) { .mpv-promo-products-row { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 540px) { .mpv-promo-products-row { grid-template-columns: 1fr; } }

/* ── Filter bar ── */
.mpv-filter-bar {
    display:flex; flex-wrap:wrap; gap:8px; justify-content:center; margin-bottom:10px;
}
.mpv-filter {
    padding:8px 20px; border-radius:20px; border:1.5px solid var(--mpv-border);
    background:#fff; color:var(--mpv-text); font-size:.88rem; font-weight:500;
    cursor:pointer; transition:var(--mpv-transition);
}
.mpv-filter:hover, .mpv-filter.active {
    background:var(--mpv-blue); border-color:var(--mpv-blue); color:#fff;
}

/* ── Product cards ── */
.mpv-prod-card {
    background:#fff; border:1.5px solid var(--mpv-border); border-radius:var(--mpv-radius);
    overflow:hidden; transition:var(--mpv-transition); position:relative; height:100%;
    display:flex; flex-direction:column;
}
.mpv-prod-card:hover { box-shadow:var(--mpv-shadow-hover); border-color:var(--mpv-blue); transform:translateY(-4px); }
.mpv-prod-badge {
    position:absolute; top:12px; left:12px; z-index:2;
    background:var(--mpv-blue); color:#fff; font-size:11px; font-weight:700;
    padding:3px 10px; border-radius:6px; text-transform:uppercase; letter-spacing:.5px;
}
.mpv-prod-badge--promo { background:#E74C3C; }
.mpv-prod-badge--new   { background:#27AE60; }
.mpv-prod-img-wrap     { display:block; position:relative; overflow:hidden; aspect-ratio:4/3; }
.mpv-prod-img          { width:100%; height:100%; object-fit:cover; transition:transform .35s ease; }
.mpv-prod-card:hover .mpv-prod-img { transform:scale(1.04); }
.mpv-prod-placeholder  {
    width:100%; aspect-ratio:4/3; background:var(--mpv-blue-light);
    display:flex; align-items:center; justify-content:center;
}
.mpv-prod-placeholder svg { width:44px; height:44px; color:#A8C8E8; }
.mpv-prod-overlay {
    position:absolute; inset:0; background:rgba(26,111,168,.5);
    display:flex; align-items:center; justify-content:center;
    opacity:0; transition:opacity .25s;
}
.mpv-prod-card:hover .mpv-prod-overlay { opacity:1; }
.mpv-prod-action {
    width:44px; height:44px; background:#fff; border-radius:50%;
    display:flex; align-items:center; justify-content:center; color:var(--mpv-blue);
    text-decoration:none; transition:var(--mpv-transition);
}
.mpv-prod-action:hover { background:var(--mpv-blue); color:#fff; }
.mpv-prod-action svg   { width:18px; height:18px; }
.mpv-prod-body { padding:15px; flex:1; display:flex; flex-direction:column; gap:4px; }
.mpv-prod-cat  { font-size:11px; font-weight:600; color:var(--mpv-blue); text-transform:uppercase; letter-spacing:.5px; }
.mpv-prod-name { font-size:.92rem; font-weight:600; color:var(--mpv-navy); margin:0; line-height:1.4; }
.mpv-prod-name a { color:inherit; text-decoration:none; }
.mpv-prod-name a:hover { color:var(--mpv-blue); }
.mpv-prod-ref  { font-size:.75rem; color:var(--mpv-muted); }
.mpv-prod-stars { display:flex; align-items:center; gap:5px; font-size:.78rem; color:var(--mpv-muted); }
.mpv-prod-footer {
    display:flex; justify-content:space-between; align-items:center;
    margin-top:auto; padding-top:10px; border-top:1px solid var(--mpv-border);
}
.mpv-prod-price { font-size:1.15rem; font-weight:700; color:var(--mpv-blue); }
.mpv-add-btn {
    display:inline-flex; align-items:center; gap:5px;
    background:var(--mpv-blue); color:#fff; padding:7px 14px;
    border-radius:7px; font-size:.82rem; font-weight:600; text-decoration:none;
    transition:var(--mpv-transition);
}
.mpv-add-btn:hover { background:var(--mpv-blue-dark); color:#fff; }

/* ── Advantages ── */
.mpv-advantage {
    background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12);
    border-radius:var(--mpv-radius); padding:30px 24px; text-align:center; height:100%;
    transition:var(--mpv-transition);
}
.mpv-advantage:hover { background:rgba(255,255,255,.14); }
.mpv-advantage-icon {
    width:60px; height:60px; border-radius:14px; background:rgba(255,255,255,.15);
    display:flex; align-items:center; justify-content:center; margin:0 auto 16px;
}
.mpv-advantage-icon svg { width:28px; height:28px; color:#fff; }
.mpv-advantage h4 { font-size:1rem; font-weight:700; color:#fff; margin-bottom:10px; }
.mpv-advantage p  { font-size:.88rem; color:rgba(255,255,255,.7); line-height:1.65; margin:0; }

/* ── FAQ ── */
.mpv-faq { max-width:760px; margin:0 auto; }
.mpv-faq-item { border:1.5px solid var(--mpv-border); border-radius:10px; margin-bottom:10px; overflow:hidden; }
.mpv-faq-toggle {
    width:100%; background:#fff; border:none; padding:18px 22px;
    display:flex; justify-content:space-between; align-items:center; gap:12px;
    cursor:pointer; text-align:left; font-size:.97rem; font-weight:600; color:var(--mpv-navy);
    transition:background .15s;
}
.mpv-faq-toggle:hover, .mpv-faq-item.open .mpv-faq-toggle { background:var(--mpv-blue-light); }
.mpv-faq-icon { width:18px; height:18px; flex-shrink:0; color:var(--mpv-blue); transition:transform .2s; }
.mpv-faq-item.open .mpv-faq-icon { transform:rotate(180deg); }
.mpv-faq-body { padding:0 22px 18px; background:var(--mpv-blue-light); }
.mpv-faq-body p { margin:0; padding-top:6px; color:var(--mpv-text); line-height:1.75; font-size:.93rem; }

/* ── Blog ── */
.mpv-blog-card {
    background:#fff; border-radius:var(--mpv-radius); border:1.5px solid var(--mpv-border);
    overflow:hidden; transition:var(--mpv-transition); height:100%;
}
.mpv-blog-card:hover { box-shadow:var(--mpv-shadow-hover); border-color:var(--mpv-blue); transform:translateY(-4px); }
.mpv-blog-img { width:100%; height:200px; object-fit:cover; }
.mpv-blog-img-placeholder {
    width:100%; height:200px; background:var(--mpv-blue-light);
    display:flex; align-items:center; justify-content:center;
}
.mpv-blog-img-placeholder svg { width:40px; height:40px; color:#A8C8E8; }
.mpv-blog-body { padding:20px; }
.mpv-blog-date { display:flex; align-items:center; gap:5px; font-size:.78rem; color:var(--mpv-muted); margin-bottom:10px; }
.mpv-blog-title { font-size:1rem; font-weight:700; color:var(--mpv-navy); margin-bottom:10px; line-height:1.45; }
.mpv-blog-title a { color:inherit; text-decoration:none; }
.mpv-blog-title a:hover { color:var(--mpv-blue); }
.mpv-blog-excerpt { font-size:.85rem; color:var(--mpv-muted); line-height:1.65; margin-bottom:14px; }
.mpv-blog-link { font-size:.85rem; font-weight:600; color:var(--mpv-blue); text-decoration:none; }
.mpv-blog-link:hover { color:var(--mpv-blue-dark); }

/* ── Responsive ── */
@media(max-width:991px) {
    .mpv-hero-inner  { grid-template-columns:1fr; gap:40px; }
    .mpv-hero-title  { font-size:2rem; }
    .mpv-cats-row    { grid-template-columns:repeat(3,1fr); }
    .mpv-cat-grid    { grid-template-columns:1fr 1fr; }
}
@media(max-width:768px) {
    .mpv-section { padding:50px 0; }
    .mpv-hero    { padding:50px 0; }
    .mpv-cats-row { grid-template-columns:repeat(2,1fr); }
    .mpv-hero-stats { flex-wrap:wrap; }
}
@media(max-width:576px) {
    .mpv-cats-row   { grid-template-columns:1fr 1fr; }
    .mpv-cat-grid   { grid-template-columns:1fr 1fr; }
    .mpv-trust-item { width:45%; }
    .mpv-hero-title { font-size:1.7rem; }
}
