:root {
    --merlin-primary: #b87333;
    --merlin-primary-dark: #7a4a24;
    --merlin-dark: #2b2520;
    --merlin-text: #3f3a36;
    --merlin-muted: #746b63;
    --merlin-bg: #fbf8f3;
    --merlin-white: #ffffff;
    --merlin-border: #e6d4bd;
    --merlin-shadow: 0 18px 40px rgba(120, 80, 40, .10);
    --radius: 16px;
}

*, *::before, *::after { box-sizing: border-box; }

.merlin-wrapper {
    background: var(--merlin-white);
    max-width: 1120px;
    margin: 0 auto;
    color: var(--merlin-text);
    font-family: Arial, Helvetica, sans-serif;
}

.mm-reveal {
    opacity: 0;
    transform: translateY(18px);
    transition: opacity .65s ease, transform .65s ease;
}
.mm-reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* HERO */
.merlin-hero {
    padding: 52px 24px 44px;
    background: linear-gradient(180deg, #fffaf3 0%, #ffffff 68%);
    text-align: center;
    position: relative;
    overflow: hidden;
}
.merlin-hero::before {
    content: "";
    position: absolute;
    top: -80px; right: -80px;
    width: 380px; height: 380px;
    background: radial-gradient(circle, rgba(184,115,51,.13), transparent 70%);
    pointer-events: none;
}
.merlin-hero-content { max-width: 860px; margin: 0 auto; position: relative; }

.merlin-kicker {
    display: inline-block;
    margin: 0 0 16px;
    padding: 7px 14px;
    border: 1px solid var(--merlin-border);
    border-radius: 999px;
    background: #fff;
    color: #8a5529;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.merlin-h1 {
    font-size: clamp(32px, 4.4vw, 52px);
    font-weight: 900;
    color: var(--merlin-dark);
    margin: 0 0 18px;
    line-height: 1.05;
}
.merlin-hero-p {
    font-size: 17px;
    max-width: 760px;
    margin: 0 auto 28px;
    color: #5d524b;
    line-height: 1.62;
}
.merlin-cta-row {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    justify-content: center;
}
.merlin-main-cta, .merlin-secondary-cta {
    display: inline-block;
    padding: 16px 26px;
    border-radius: 999px;
    font-size: 16px;
    font-weight: 900;
    text-decoration: none !important;
    transition: opacity .2s, transform .15s;
}
.merlin-main-cta {
    background: linear-gradient(135deg, #b87333, #8a5529);
    color: #fff !important;
    box-shadow: 0 12px 28px rgba(184,115,51,.28);
}
.merlin-main-cta:hover { opacity: .92; transform: translateY(-1px); }
.merlin-secondary-cta {
    background: #ffffff;
    color: var(--merlin-dark) !important;
    border: 1.5px solid var(--merlin-border);
}
.merlin-secondary-cta:hover { border-color: var(--merlin-primary); color: var(--merlin-primary) !important; }

/* PREUVE SOCIALE */
.merlin-proof {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1px;
    background: #dcc6a9;
}
.proof-item {
    background: linear-gradient(180deg, #fffaf3, #f8efe3);
    text-align: center;
    padding: 20px 10px;
}
.proof-number {
    display: block;
    font-size: 26px;
    font-weight: 900;
    line-height: 1;
    margin-bottom: 6px;
    color: #9b5f2b;
}
.proof-label {
    display: block;
    font-size: 12px;
    color: #755b45;
    line-height: 1.35;
    text-transform: uppercase;
    letter-spacing: .03em;
}

/* LEAD MAGNET */
.merlin-lead {
    position: relative;
    padding: 40px 24px;
    background: linear-gradient(135deg, #2b2520, #5a3520);
    overflow: hidden;
}
.merlin-lead::after {
    content: "🎩";
    position: absolute;
    right: 28px; bottom: -34px;
    font-size: 132px;
    opacity: .07;
    pointer-events: none;
}
.merlin-lead-grid {
    position: relative;
    display: grid;
    grid-template-columns: .95fr 1.05fr;
    gap: 28px;
    align-items: center;
    max-width: 960px;
    margin: 0 auto;
    z-index: 1;
}
.merlin-lead-badge {
    display: inline-block;
    background: var(--merlin-primary);
    color: #fff;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
    padding: 6px 14px;
    border-radius: 999px;
    margin-bottom: 14px;
}
.merlin-lead-title {
    font-size: clamp(22px, 3vw, 31px);
    font-weight: 900;
    color: #fff8ef;
    margin: 0 0 8px;
    line-height: 1.16;
}
.merlin-lead-sub {
    font-size: 15px;
    color: #e3c7a5;
    margin: 0;
    line-height: 1.55;
}
.merlin-lead-list {
    margin: 16px 0 0;
    padding: 0;
    list-style: none;
    color: #fff8ef;
    font-size: 14px;
    line-height: 1.5;
}
.merlin-lead-list li { margin: 8px 0; }
.merlin-lead-card {
    background: rgba(255,255,255,.09);
    border: 1px solid rgba(255,255,255,.18);
    border-radius: 22px;
    padding: 24px;
    box-shadow: 0 18px 42px rgba(0,0,0,.18);
}
.merlin-lead-form { display: flex; gap: 10px; flex-wrap: wrap; }
.merlin-lead-input {
    flex: 1;
    min-width: 230px;
    padding: 14px 18px;
    border-radius: 999px;
    border: 2px solid transparent;
    font-size: 15px;
    outline: none;
    transition: border-color .2s;
}
.merlin-lead-input:focus { border-color: var(--merlin-primary); }
.merlin-lead-btn {
    padding: 14px 24px;
    border-radius: 999px;
    background: linear-gradient(135deg, #b87333, #8a5529);
    color: #fff;
    font-size: 15px;
    font-weight: 900;
    border: none;
    cursor: pointer;
    white-space: nowrap;
    box-shadow: 0 8px 20px rgba(184,115,51,.35);
    transition: opacity .2s, transform .2s;
}
.merlin-lead-btn:hover { opacity: .9; transform: translateY(-1px); }
.merlin-lead-btn:disabled { opacity: .65; cursor: not-allowed; transform: none; }
.merlin-lead-mention { margin: 12px 0 0; font-size: 11px; color: #c9a985; }
.merlin-lead-success {
    display: none;
    background: rgba(255,255,255,.1);
    border: 1px solid rgba(255,255,255,.2);
    border-radius: 14px;
    padding: 18px;
    color: #fff8ef;
    font-size: 15px;
    line-height: 1.5;
}
.merlin-lead-success strong { display: block; font-size: 18px; margin-bottom: 6px; }

/* ACCÈS RAPIDES */
.quick-access { padding: 42px 18px 44px; background: #ffffff; }
.section-eyebrow {
    display: block;
    text-align: center;
    color: var(--merlin-primary);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
    margin-bottom: 8px;
}
.quick-title, .section-title {
    text-align: center;
    font-size: clamp(24px, 3vw, 33px);
    color: var(--merlin-dark);
    font-weight: 900;
    margin: 0 0 8px;
    line-height: 1.18;
}
.quick-subtitle, .section-subtitle {
    text-align: center;
    max-width: 790px;
    margin: 0 auto 28px;
    color: var(--merlin-muted);
    font-size: 15px;
    line-height: 1.5;
}
.quick-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
}
.quick-card {
    position: relative;
    display: block;
    background: #fff;
    border: 1px solid var(--merlin-border);
    border-radius: 16px;
    padding: 18px 42px 18px 14px;
    text-decoration: none !important;
    color: var(--merlin-dark) !important;
    transition: all .2s ease;
    min-height: 138px;
}
.quick-card:hover {
    transform: translateY(-3px);
    border-color: var(--merlin-primary);
    background: #fff8ef;
    box-shadow: 0 12px 25px rgba(184,115,51,.12);
}
.quick-arrow {
    position: absolute;
    right: 14px; top: 16px;
    color: var(--merlin-primary);
    font-size: 22px;
    font-weight: 700;
    line-height: 1;
}
.quick-card.main-choice .quick-arrow { color: rgba(255,255,255,.7); }
.quick-icon { font-size: 28px; display: block; margin-bottom: 8px; }
.quick-card strong { display: block; font-size: 15px; line-height: 1.2; margin-bottom: 5px; }
.quick-card .quick-desc { display: block; color: var(--merlin-muted); font-size: 13px; line-height: 1.35; }
.quick-card.main-choice {
    background: linear-gradient(135deg, #9b5f2b, #3a2a20);
    color: #fff !important;
    border-color: #9b5f2b;
}
.quick-card.main-choice .quick-desc { color: #f8e6c9; }

/* SECTION MARC */
.marc-section {
    padding: 44px 24px;
    background: linear-gradient(180deg, #fff8ef, #ffffff);
    border-top: 1px solid var(--merlin-border);
    border-bottom: 1px solid var(--merlin-border);
}
.marc-grid {
    display: grid;
    grid-template-columns: 260px 1fr;
    gap: 32px;
    align-items: center;
    max-width: 930px;
    margin: 0 auto;
}
.marc-photo {
    width: 230px; height: 230px;
    margin: 0 auto;
    border-radius: 28px;
    overflow: hidden;
    background: #2b2520;
    box-shadow: var(--merlin-shadow);
    border: 1px solid rgba(184,115,51,.22);
}
.marc-placeholder {
    width: 100%; height: 100%;
    background:
        linear-gradient(rgba(43,37,32,.20), rgba(43,37,32,.62)),
        url('https://merlinmagie.fr/img/merlin-magie.webp') center/cover no-repeat;
}
.marc-copy h2 { font-size: clamp(23px, 3vw, 32px); margin: 0 0 10px; color: var(--merlin-dark); line-height: 1.18; }
.marc-copy p { margin: 0 0 14px; color: #5d524b; font-size: 15px; line-height: 1.65; }
.marc-badges { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 16px; }
.marc-badge {
    display: inline-block;
    padding: 8px 12px;
    border-radius: 999px;
    background: #fff;
    border: 1px solid var(--merlin-border);
    color: #6b3d1d;
    font-size: 12px;
    font-weight: 900;
}

/* PRODUITS VEDETTES */
.featured-products { padding: 44px 18px; background: #fff; }
.featured-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
    max-width: 1020px;
    margin: 0 auto;
}
.featured-card {
    position: relative;
    display: flex;
    flex-direction: column;
    background: #ffffff;
    border: 1px solid var(--merlin-border);
    border-radius: 18px;
    overflow: hidden;
    text-decoration: none !important;
    color: var(--merlin-dark) !important;
    box-shadow: 0 12px 28px rgba(120,80,40,.07);
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.featured-card:hover {
    transform: translateY(-4px);
    border-color: var(--merlin-primary);
    box-shadow: 0 18px 38px rgba(120,80,40,.12);
}
.featured-visual {
    min-height: 138px;
    display: flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, #fff8ef, #f3dfc5);
    font-size: 48px;
}
.featured-content { padding: 18px; flex: 1; display: flex; flex-direction: column; }
.featured-label {
    display: inline-block;
    margin-bottom: 10px;
    padding: 5px 9px;
    border-radius: 999px;
    background: #fff8ef;
    border: 1px solid var(--merlin-border);
    color: #8a5529;
    font-size: 11px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .05em;
}
.featured-content strong { display: block; font-size: 17px; margin-bottom: 8px; line-height: 1.25; }
.featured-content p { margin: 0 0 12px; color: var(--merlin-muted); font-size: 13px; line-height: 1.45; flex: 1; }
.marc-note {
    display: block;
    background: #fbf8f3;
    border-left: 3px solid var(--merlin-primary);
    padding: 10px 12px;
    color: #4a3324;
    font-size: 13px;
    line-height: 1.42;
    border-radius: 0 8px 8px 0;
}
.featured-link { display: inline-block; margin-top: 14px; font-weight: 900; color: var(--merlin-primary); font-size: 13px; }

/* AVIS CLIENTS */
.reviews-section {
    padding: 44px 18px;
    background: var(--merlin-bg);
    border-top: 1px solid var(--merlin-border);
    border-bottom: 1px solid var(--merlin-border);
}
.reviews-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
    max-width: 1010px;
    margin: 0 auto;
}
.review-card {
    background: #fff;
    border: 1px solid var(--merlin-border);
    border-radius: 16px;
    padding: 20px;
    box-shadow: 0 10px 24px rgba(120,80,40,.06);
}
.review-stars { color: #b87333; font-size: 16px; letter-spacing: .08em; margin-bottom: 10px; }
.review-card p { margin: 0 0 14px; color: #4d453f; font-size: 14px; line-height: 1.6; font-style: italic; }
.review-author { display: block; color: var(--merlin-dark); font-size: 13px; font-weight: 900; }
.review-type { display: block; color: var(--merlin-muted); font-size: 12px; margin-top: 2px; }

/* CITATION EXPERT */
.merlin-expert-quote {
    padding: 36px 22px;
    background: linear-gradient(180deg, #fff8ef, #ffffff);
    border-bottom: 1px solid var(--merlin-border);
}
.merlin-expert-quote-inner {
    max-width: 800px;
    margin: 0 auto;
    text-align: center;
    color: #2b2520;
    font-size: 18px;
    line-height: 1.68;
    font-style: italic;
}
.merlin-expert-quote strong {
    display: block;
    margin-top: 14px;
    color: var(--merlin-dark);
    font-style: normal;
    font-size: 14px;
    letter-spacing: .04em;
    text-transform: uppercase;
}

/* VIDÉO */
.video-section {
    padding: 38px 20px 48px;
    background: var(--merlin-bg);
    text-align: center;
}
.video-title { font-size: 26px; font-weight: 900; color: var(--merlin-dark); margin: 0 0 10px; }
.video-text { max-width: 720px; margin: 0 auto 28px; color: var(--merlin-muted); font-size: 15px; line-height: 1.5; }
.video-wrapper {
    position: relative;
    max-width: 330px; margin: 0 auto;
    aspect-ratio: 9 / 16;
    background-color: #000;
    border-radius: 22px; overflow: hidden;
    box-shadow: 0 25px 50px -12px rgba(0,0,0,.25);
    cursor: pointer;
}
.video-facade {
    position: absolute; inset: 0;
    background: linear-gradient(rgba(0,0,0,.15), rgba(0,0,0,.25)), url('https://merlinmagie.fr/img/merlin-magie.webp') center/cover no-repeat;
    display: flex; align-items: center; justify-content: center;
    transition: transform .35s ease;
}
.video-wrapper:hover .video-facade { transform: scale(1.04); }
.play-button {
    width: 72px; height: 72px;
    background: var(--merlin-primary);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    box-shadow: 0 0 30px rgba(184,115,51,.50);
}
.play-button::after {
    content: "";
    border-style: solid;
    border-width: 13px 0 13px 22px;
    border-color: transparent transparent transparent white;
    margin-left: 5px;
}
.video-wrapper iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }

/* RÉASSURANCE */
.merlin-features {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 14px; padding: 24px;
    background: #fff;
    border-top: 1px solid var(--merlin-border);
}
.feature-box {
    background: var(--merlin-bg); padding: 18px;
    border-radius: 12px; text-align: center;
    border: 1px solid var(--merlin-border);
}
.feature-title { font-weight: 900; display: block; color: var(--merlin-dark); font-size: 14px; text-transform: uppercase; margin-bottom: 6px; }
.feature-text { font-size: 13px; line-height: 1.4; color: #5d524b; }

/* SEO BAS DE PAGE */
.merlin-body { padding: 40px 40px 48px; background: #fff; border-top: 1px solid var(--merlin-border); }
.merlin-h2 {
    font-size: 26px; color: var(--merlin-dark); margin: 0 0 18px;
    border-left: 5px solid var(--merlin-primary);
    padding-left: 16px; line-height: 1.2;
}
.merlin-seo-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: 32px; align-items: start; }
.merlin-body p { font-size: 14px; line-height: 1.75; margin: 0 0 16px; }
.merlin-benefits { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.merlin-benefit {
    background: #fff8ef; border: 1px solid var(--merlin-border);
    border-radius: 12px; padding: 15px;
    font-size: 13px; line-height: 1.4; color: #5d524b;
}
.merlin-benefit strong { display: block; color: var(--merlin-dark); font-size: 14px; margin-bottom: 4px; }
.merlin-body a { color: var(--merlin-primary); text-decoration: underline; text-underline-offset: 3px; font-weight: 800; }
.final-cta {
    margin-top: 28px; text-align: center;
    background: linear-gradient(135deg, #3a2a20, #9b5f2b);
    padding: 32px 18px; border-radius: 16px; color: #fff;
}
.final-cta strong { display: block; font-size: 24px; margin-bottom: 14px; }
.final-cta a {
    display: inline-block;
    background: #fff8ef; color: #6b3d1d !important;
    padding: 15px 24px; border-radius: 999px;
    text-decoration: none !important; font-weight: 900; font-size: 16px;
}

/* MOBILE */
@media (max-width: 900px) {
    .merlin-proof { grid-template-columns: repeat(2, 1fr); }
    .merlin-lead-grid, .marc-grid, .merlin-seo-grid { grid-template-columns: 1fr; }
    .quick-grid, .featured-grid, .reviews-grid { grid-template-columns: repeat(2, 1fr); }
    .marc-copy { text-align: center; }
    .marc-badges { justify-content: center; }
}
@media (max-width: 640px) {
    .merlin-hero { padding: 32px 16px 28px; }
    .merlin-main-cta, .merlin-secondary-cta { width: 100%; box-sizing: border-box; text-align: center; }
    .merlin-lead { padding: 28px 16px; }
    .merlin-lead-form { flex-direction: column; }
    .merlin-lead-input, .merlin-lead-btn { width: 100%; }
    .quick-grid, .featured-grid, .reviews-grid { grid-template-columns: 1fr; }
    .merlin-features { grid-template-columns: 1fr; padding: 18px; }
    .merlin-body { padding: 28px 20px 36px; }
    .merlin-benefits { grid-template-columns: 1fr; }
}