/* Reddani Widgets — CSS Premium Éditorial v2 (charte Newsreader/Manrope + navy/red/gold/creme) */

/* ============================================================
   BASE COMMUNE — fade-in + typo
   ============================================================ */
.rw-section { opacity: 0; transform: translateY(24px); transition: opacity .9s cubic-bezier(.4,0,.2,1), transform .9s cubic-bezier(.4,0,.2,1); }
.rw-section.rw-in { opacity: 1; transform: translateY(0); }
@media (prefers-reduced-motion: reduce) { .rw-section { opacity: 1 !important; transform: none !important; transition: none !important; } }

.rw-eyebrow {
    display: inline-flex; align-items: center; gap: 14px;
    font-family: 'Manrope', sans-serif;
    font-size: 11px; font-weight: 700; letter-spacing: .24em;
    text-transform: uppercase; color: #C8102E;
    margin: 0 0 22px 0; line-height: 1.4;
}
.rw-eyebrow-center { display: flex; justify-content: center; }
.rw-eyebrow-light { color: #B6924A; }
.rw-eyebrow-dot { display: inline-block; width: 32px; height: 1px; background: currentColor; opacity: 1; }

.rw-section-title {
    font-family: 'Newsreader', Georgia, serif;
    font-weight: 400;
    font-size: clamp(32px, 4.2vw, 52px);
    line-height: 1.12; letter-spacing: -.018em;
    color: #0B2545; margin: 0 0 48px 0;
}
.rw-section-title em, .rw-section-title i {
    font-style: italic; font-weight: 300; color: #B6924A;
}
.rw-title-center { text-align: center; max-width: 860px; margin-left: auto; margin-right: auto; }
.rw-title-center::after {
    content: ''; display: block; width: 48px; height: 1.5px;
    background: #B6924A; margin: 28px auto 0 auto;
}
.rw-title-light { color: #FFFFFF; }
.rw-title-light em { color: #B6924A; }

/* ============================================================
   STATS — numbers énormes + lines verticales
   ============================================================ */
.rw-stats {
    background: #FFFFFF;
    padding: 72px 24px;
    position: relative;
    border-top: 1px solid rgba(11,37,69,.06);
    border-bottom: 1px solid rgba(11,37,69,.06);
}
.rw-stats-inner {
    max-width: 1280px; margin: 0 auto;
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
    position: relative;
}
.rw-stat-card {
    padding: 24px 36px;
    text-align: left;
    position: relative;
    background: transparent;
    border-radius: 0;
    box-shadow: none;
    border: none;
    transition: transform .4s cubic-bezier(.4,0,.2,1);
}
.rw-stat-card:not(:first-child)::before {
    content: ''; position: absolute;
    top: 18%; bottom: 18%; left: 0;
    width: 1px; background: rgba(11,37,69,.14);
}
.rw-stat-card:hover { transform: translateY(-6px); }
.rw-stat-num {
    font-family: 'Newsreader', Georgia, serif;
    font-weight: 400;
    font-size: clamp(64px, 6.8vw, 96px);
    line-height: 1; letter-spacing: -.04em;
    margin: 0 0 14px 0;
    font-feature-settings: "lnum";
}
.rw-stat-red .rw-stat-num { color: #C8102E; }
.rw-stat-gold .rw-stat-num { color: #B6924A; }
.rw-stat-navy .rw-stat-num { color: #0B2545; }
.rw-stat-label {
    font-family: 'Manrope', sans-serif;
    font-size: 13px; font-weight: 500;
    letter-spacing: .02em;
    line-height: 1.55; color: #4A5868;
    max-width: 240px;
}
@media (max-width: 1024px) {
    .rw-stats { padding: 48px 20px; }
    .rw-stats-inner { grid-template-columns: repeat(2, 1fr); gap: 32px 0; }
    .rw-stat-card:nth-child(3)::before { display: none; }
}
@media (max-width: 560px) {
    .rw-stats-inner { grid-template-columns: 1fr; gap: 40px; }
    .rw-stat-card { padding: 0 24px; text-align: center; }
    .rw-stat-card::before { display: none !important; }
    .rw-stat-label { max-width: none; margin: 0 auto; }
}

/* ============================================================
   ALTS — numérotation 01-04 + asymétrie + image gold frame
   ============================================================ */
.rw-alts {
    background: #FFFFFF;
    padding: 80px 24px;
    position: relative;
}
.rw-alts::before {
    content: ''; position: absolute;
    top: 0; left: 50%; transform: translateX(-50%);
    width: 200px; height: 1px;
    background: linear-gradient(90deg, transparent, #B6924A, transparent);
}
.rw-alts-inner { max-width: 1180px; margin: 0 auto; }
.rw-alt-row {
    display: grid; grid-template-columns: 1.05fr .95fr;
    gap: 88px; align-items: center;
    padding: 88px 0;
    border-bottom: 1px solid rgba(11,37,69,.08);
    position: relative;
    counter-increment: rw-alt-counter;
}
.rw-alts { counter-reset: rw-alt-counter; }
.rw-alt-row:last-child { border-bottom: none; }
.rw-alt-row.rw-alt-reverse { grid-template-columns: .95fr 1.05fr; direction: rtl; }
.rw-alt-row.rw-alt-reverse > * { direction: ltr; }

.rw-alt-img-wrap { position: relative; }
.rw-alt-img-wrap::before {
    content: ''; position: absolute;
    top: 16px; left: 16px; right: -16px; bottom: -16px;
    border: 1px solid #B6924A;
    border-radius: 4px;
    z-index: 0;
    transition: transform .5s cubic-bezier(.4,0,.2,1);
}
.rw-alt-reverse .rw-alt-img-wrap::before { left: -16px; right: 16px; }
.rw-alt-row:hover .rw-alt-img-wrap::before { transform: translate(-4px, -4px); }
.rw-alt-img {
    width: 100%; height: 460px; object-fit: cover;
    border-radius: 4px;
    position: relative; z-index: 1;
    display: block;
    box-shadow: 0 24px 60px rgba(11,37,69,.18);
}

.rw-alt-text-wrap { position: relative; padding: 0 4px; }
.rw-alt-text-wrap::before {
    content: "0" counter(rw-alt-counter);
    position: absolute; top: -36px; right: 0;
    font-family: 'Newsreader', Georgia, serif;
    font-style: italic; font-weight: 300;
    font-size: clamp(100px, 11vw, 160px);
    line-height: 1; color: rgba(182,146,74,.10);
    pointer-events: none; user-select: none;
    z-index: 0;
}
.rw-alt-eyebrow {
    font-family: 'Manrope', sans-serif;
    font-size: 11px; font-weight: 700;
    letter-spacing: .22em; text-transform: uppercase;
    color: #C8102E; margin: 0 0 18px 0;
    position: relative; z-index: 1;
    padding-left: 32px;
}
.rw-alt-eyebrow::before {
    content: ''; position: absolute;
    left: 0; top: 50%; transform: translateY(-50%);
    width: 22px; height: 1px; background: #C8102E;
}
.rw-alt-title {
    font-family: 'Newsreader', Georgia, serif;
    font-weight: 400; font-size: clamp(26px, 3.2vw, 36px);
    line-height: 1.18; letter-spacing: -.012em;
    color: #0B2545; margin: 0 0 22px 0;
    position: relative; z-index: 1;
    max-width: 460px;
}
.rw-alt-body p {
    font-family: 'Manrope', sans-serif;
    font-size: 16px; line-height: 1.8;
    color: #4A5868; margin: 0 0 .9em 0;
    position: relative; z-index: 1;
    max-width: 480px;
}
.rw-alt-body p:last-child { margin-bottom: 0; }
@media (max-width: 900px) {
    .rw-alts { padding: 56px 20px; }
    .rw-alt-row, .rw-alt-row.rw-alt-reverse {
        grid-template-columns: 1fr; gap: 40px; padding: 56px 0; direction: ltr;
    }
    .rw-alt-row.rw-alt-reverse { display: flex; flex-direction: column-reverse; }
    .rw-alt-img { height: 320px; }
    .rw-alt-text-wrap::before { font-size: 80px; top: -28px; }
}

/* ============================================================
   PARTNERS — slider Swiper élégant + grain texture
   ============================================================ */
.rw-partners {
    background: #FBF8F2;
    padding: 72px 24px;
    position: relative;
    overflow: hidden;
}
.rw-partners::before, .rw-partners::after {
    content: ''; position: absolute;
    width: 380px; height: 380px;
    border-radius: 50%;
    pointer-events: none;
    opacity: .35;
}
.rw-partners::before {
    top: -180px; left: -120px;
    background: radial-gradient(circle, rgba(182,146,74,.20) 0%, transparent 70%);
}
.rw-partners::after {
    bottom: -180px; right: -120px;
    background: radial-gradient(circle, rgba(200,16,46,.12) 0%, transparent 70%);
}
.rw-partners-inner { max-width: 1180px; margin: 0 auto; position: relative; z-index: 1; }
.rw-partners-grid {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 24px; margin-top: 48px;
}
.rw-partners-swiper { padding: 24px 8px 64px 8px; margin-top: 48px; }
.rw-partners-swiper .swiper-slide { height: auto; display: flex; }
.rw-partners-swiper .swiper-pagination { bottom: 0 !important; }
.rw-partners-swiper .swiper-pagination-bullet {
    background: #0B2545; opacity: .3;
    transition: opacity .25s ease, transform .25s ease;
}
.rw-partners-swiper .swiper-pagination-bullet-active {
    background: #B6924A; opacity: 1; transform: scale(1.4);
}
.rw-partner-card {
    background: #FFFFFF;
    border: 1px solid rgba(11,37,69,.10);
    border-radius: 4px;
    padding: 40px 26px;
    text-align: center;
    transition: border-color .3s ease, transform .3s ease, box-shadow .3s ease;
    flex: 1;
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: 16px; min-height: 160px;
    position: relative;
}
.rw-partner-card::before {
    content: ''; position: absolute;
    top: -1px; left: -1px; right: -1px;
    height: 2px; background: #B6924A;
    opacity: 0; transition: opacity .3s ease;
}
.rw-partner-card:hover {
    border-color: rgba(182,146,74,.50);
    transform: translateY(-6px);
    box-shadow: 0 12px 36px rgba(11,37,69,.10);
}
.rw-partner-card:hover::before { opacity: 1; }
.rw-partner-logo { max-width: 140px; max-height: 60px; object-fit: contain; }
.rw-partner-name {
    font-family: 'Newsreader', Georgia, serif;
    font-weight: 400; font-size: 19px;
    line-height: 1.3; color: #0B2545;
    font-style: italic;
}
@media (max-width: 768px) {
    .rw-partners { padding: 48px 20px; }
    .rw-partners-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
    .rw-partner-name { font-size: 16px; }
}

/* ============================================================
   LOCAL Beauséjour — image gold frame + asymétrie
   ============================================================ */
.rw-local {
    background: #0B2545;
    padding: 80px 24px;
    position: relative;
    overflow: hidden;
}
.rw-local::before {
    content: ''; position: absolute;
    top: -200px; right: -200px;
    width: 600px; height: 600px;
    background: radial-gradient(circle, rgba(182,146,74,.18) 0%, transparent 60%);
    pointer-events: none;
}
.rw-local::after {
    content: ''; position: absolute;
    bottom: -180px; left: -120px;
    width: 460px; height: 460px;
    background: radial-gradient(circle, rgba(200,16,46,.10) 0%, transparent 60%);
    pointer-events: none;
}
.rw-local-inner {
    max-width: 1180px; margin: 0 auto;
    display: grid; grid-template-columns: 1fr 1.1fr;
    gap: 88px; align-items: center;
    position: relative; z-index: 1;
}
.rw-local[data-img-pos="left"] .rw-local-inner { grid-template-columns: 1.1fr 1fr; direction: rtl; }
.rw-local[data-img-pos="left"] .rw-local-inner > * { direction: ltr; }
.rw-local .rw-eyebrow { color: #B6924A; }
.rw-local .rw-section-title { color: #FBF8F2; margin: 0 0 28px 0; }
.rw-local .rw-section-title em { color: #B6924A; }
.rw-local-body p {
    font-family: 'Manrope', sans-serif;
    font-size: 17px; line-height: 1.85;
    color: rgba(255,255,255,.88);
    margin: 0 0 18px 0;
    max-width: 540px;
}
.rw-local-img-wrap { position: relative; }
.rw-local-img-wrap::before {
    content: ''; position: absolute;
    top: -20px; left: -20px;
    width: 100%; height: 100%;
    border: 1.5px solid #B6924A;
    border-radius: 4px;
    z-index: 0;
}
.rw-local[data-img-pos="left"] .rw-local-img-wrap::before { left: auto; right: -20px; }
.rw-local-img {
    width: 100%; height: 480px; object-fit: cover;
    border-radius: 4px;
    box-shadow: 0 30px 60px rgba(0,0,0,.45);
    display: block;
    position: relative; z-index: 1;
}
@media (max-width: 900px) {
    .rw-local { padding: 56px 20px; }
    .rw-local-inner, .rw-local[data-img-pos="left"] .rw-local-inner {
        grid-template-columns: 1fr; gap: 48px; direction: ltr;
    }
    .rw-local-img { height: 320px; }
}

/* ============================================================
   FAQ — numérotation Q01-Q08 éditoriale
   ============================================================ */
.rw-faq {
    background: #FBF8F2;
    padding: 80px 24px;
    position: relative;
}
.rw-faq-inner { max-width: 920px; margin: 0 auto; }
.rw-faq-list { margin-top: 16px; counter-reset: rw-faq-counter; }
.rw-faq-item {
    background: transparent;
    border: none;
    border-bottom: 1px solid rgba(11,37,69,.14);
    border-radius: 0;
    margin-bottom: 0;
    overflow: hidden;
    counter-increment: rw-faq-counter;
    transition: background .25s ease;
}
.rw-faq-item:first-child { border-top: 1px solid rgba(11,37,69,.14); }
.rw-faq-item:hover { background: rgba(255,255,255,.5); }
.rw-faq-item[open] { background: #FFFFFF; }
.rw-faq-q {
    display: grid; grid-template-columns: 64px 1fr 32px;
    align-items: center; gap: 16px;
    padding: 30px 28px;
    cursor: pointer; list-style: none;
    line-height: 1.4;
    transition: color .25s ease;
}
.rw-faq-q::before {
    content: "Q." counter(rw-faq-counter, decimal-leading-zero);
    font-family: 'Newsreader', Georgia, serif;
    font-style: italic; font-weight: 300;
    font-size: 22px; color: #B6924A;
    letter-spacing: -.01em;
}
.rw-faq-q::-webkit-details-marker { display: none; }
.rw-faq-q-text {
    font-family: 'Newsreader', Georgia, serif;
    font-weight: 400; font-size: 19px;
    color: #0B2545; letter-spacing: -.005em;
}
.rw-faq-item[open] .rw-faq-q-text { color: #C8102E; }
.rw-faq-q:hover .rw-faq-q-text { color: #C8102E; }
.rw-faq-icon {
    width: 32px; height: 32px;
    border: 1.5px solid #B6924A;
    border-radius: 50%;
    position: relative;
    transition: background .3s ease;
}
.rw-faq-icon::before, .rw-faq-icon::after {
    content: ''; position: absolute;
    background: #B6924A;
    transition: transform .35s cubic-bezier(.4,0,.2,1);
}
.rw-faq-icon::before { top: 50%; left: 8px; right: 8px; height: 1.5px; transform: translateY(-50%); }
.rw-faq-icon::after { left: 50%; top: 8px; bottom: 8px; width: 1.5px; transform: translateX(-50%); }
.rw-faq-item[open] .rw-faq-icon { background: #B6924A; }
.rw-faq-item[open] .rw-faq-icon::before { background: #FFFFFF; }
.rw-faq-item[open] .rw-faq-icon::after { background: #FFFFFF; transform: translateX(-50%) scaleY(0); }
.rw-faq-a {
    padding: 0 28px 32px 108px;
    font-family: 'Manrope', sans-serif;
    font-size: 15.5px; line-height: 1.8;
    color: #3D4A5C;
}
.rw-faq-a p { margin: 0 0 .8em 0; }
.rw-faq-a p:last-child { margin-bottom: 0; }
@media (max-width: 768px) {
    .rw-faq { padding: 56px 20px; }
    .rw-faq-q { grid-template-columns: 48px 1fr 28px; gap: 12px; padding: 24px 20px; }
    .rw-faq-q::before { font-size: 18px; }
    .rw-faq-q-text { font-size: 17px; }
    .rw-faq-a { padding: 0 20px 24px 80px; font-size: 15px; }
}

/* ============================================================
   CTA — design éditorial minimal avec gold accent
   ============================================================ */
.rw-cta {
    position: relative;
    min-height: 500px;
    display: flex; align-items: center;
    padding: 72px 32px;
    background-size: cover; background-position: center;
    isolation: isolate;
}
.rw-cta-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(135deg, rgba(11,37,69,.94) 0%, rgba(11,37,69,.82) 100%);
    z-index: 1; pointer-events: none;
}
.rw-cta-overlay::after {
    content: ''; position: absolute;
    top: 50%; left: 50%; transform: translate(-50%, -50%);
    width: 70%; height: 70%; max-width: 600px; max-height: 600px;
    background: radial-gradient(circle, rgba(182,146,74,.15) 0%, transparent 60%);
    pointer-events: none;
}
.rw-cta-inner {
    position: relative; z-index: 2;
    max-width: 920px; margin: 0 auto;
    width: 100%; text-align: center;
}
.rw-cta-inner .rw-section-title { margin-bottom: 24px; }
.rw-cta-intro {
    font-family: 'Manrope', sans-serif;
    font-size: 17px; line-height: 1.75;
    color: rgba(255,255,255,.88);
    max-width: 620px; margin: 0 auto 40px auto;
}
.rw-cta-buttons { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }
.rw-btn {
    display: inline-block;
    font-family: 'Manrope', sans-serif;
    font-size: 14.5px; font-weight: 600;
    padding: 18px 40px;
    border-radius: 2px;
    letter-spacing: .06em; text-transform: uppercase;
    text-decoration: none;
    transition: transform .25s ease, box-shadow .25s ease, background .25s ease, border-color .25s ease;
}
.rw-btn-primary {
    background: #C8102E; color: #FFFFFF;
    box-shadow: 0 12px 32px rgba(200,16,46,.40);
}
.rw-btn-primary:hover {
    background: #a30d26; color: #FFFFFF;
    transform: translateY(-3px);
    box-shadow: 0 16px 40px rgba(200,16,46,.55);
}
.rw-btn-secondary {
    background: transparent; color: #FFFFFF;
    border: 1.5px solid rgba(255,255,255,.55);
}
.rw-btn-secondary:hover {
    background: rgba(255,255,255,.10);
    border-color: #B6924A; color: #FFFFFF;
    transform: translateY(-3px);
}
@media (max-width: 768px) {
    .rw-cta { min-height: 320px; padding: 56px 20px; }
    .rw-section-title { font-size: 30px !important; }
    .rw-btn { padding: 14px 28px; font-size: 13px; letter-spacing: .05em; }
}

/* ==========================================================================
   Responsive refinements v1.2.0 — tablette intermédiaire + mobile small
   ========================================================================== */
@media (max-width: 1024px) and (min-width: 901px) {
    .rw-alt-row, .rw-alt-row.rw-alt-reverse { grid-template-columns: 1fr 1fr; }
    .rw-local-inner { grid-template-columns: 1fr 1fr !important; gap: 40px; }
    .rw-partners-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 600px) {
    .rw-partners-grid { grid-template-columns: 1fr !important; gap: 12px; }
    .rw-partner-card { padding: 32px 20px; }
    .rw-cta { padding: 56px 16px; }
    .rw-cta-buttons { flex-direction: column; gap: 12px; }
    .rw-cta-buttons .rw-btn { width: 100%; text-align: center; }
}
@media (max-width: 480px) {
    .rw-stat-num { font-size: 64px; }
    .rw-section-title { font-size: 26px !important; line-height: 1.25; }
    .rw-alt-text-wrap::before, .rw-alt-img-wrap::before { font-size: 96px; }
    .rw-faq-q { grid-template-columns: 36px 1fr 24px !important; gap: 8px; padding: 18px 14px; }
    .rw-faq-q-text { font-size: 15px; }
    .rw-faq-a { padding: 0 14px 18px 58px; font-size: 14px; }
    .rw-local-inner { gap: 32px !important; }
    .rw-local-img-wrap::before { display: none; }
    .rw-alt-img-wrap::before { display: none; }
}



/* ==========================================================================
   Reddani Intro Widget v1.4.0 — premium editorial above-the-fold
   Grid 1fr/1fr | image with gold offset frame | Newsreader italic title
   ========================================================================== */
.rw-intro {
    background: #FBF8F2;
    padding: 96px 24px;
    position: relative;
    overflow: hidden;
}
.rw-intro-inner {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
}
.rw-intro[data-img-pos="right"] .rw-intro-inner {
    grid-template-areas: "text img";
}
.rw-intro[data-img-pos="left"] .rw-intro-inner {
    grid-template-areas: "img text";
}
.rw-intro[data-img-pos="right"] .rw-intro-img-wrap { grid-area: img; }
.rw-intro[data-img-pos="right"] .rw-intro-text { grid-area: text; }
.rw-intro[data-img-pos="left"] .rw-intro-img-wrap { grid-area: img; }
.rw-intro[data-img-pos="left"] .rw-intro-text { grid-area: text; }

.rw-intro-img-wrap {
    position: relative;
}
.rw-intro-img-wrap::before {
    content: '';
    position: absolute;
    top: 22px; right: -22px; bottom: -22px; left: 22px;
    border: 1px solid #B6924A;
    pointer-events: none;
    z-index: 0;
    transition: transform .4s cubic-bezier(.2,.6,.2,1);
}
.rw-intro-img-wrap:hover::before { transform: translate(8px, 8px); }
.rw-intro-img {
    position: relative;
    z-index: 1;
    display: block;
    width: 100%;
    aspect-ratio: 4 / 5;
    object-fit: cover;
    border-radius: 4px;
    box-shadow: 0 18px 48px rgba(11, 37, 69, .14);
    transition: transform .45s cubic-bezier(.2,.6,.2,1);
}
.rw-intro-img-wrap:hover .rw-intro-img { transform: translate(-4px, -4px); }

.rw-intro-text { max-width: 540px; }
.rw-intro-eyebrow {
    font-family: 'Manrope', sans-serif;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: #B6924A;
    margin-bottom: 24px;
    display: flex;
    align-items: center;
    gap: 14px;
}
.rw-intro-bar {
    width: 32px; height: 1px;
    background: #B6924A;
    flex-shrink: 0;
}
.rw-intro-title {
    font-family: 'Newsreader', 'Playfair Display', Georgia, serif;
    font-style: italic;
    font-weight: 500;
    font-size: clamp(32px, 3.8vw, 50px);
    line-height: 1.14;
    letter-spacing: -.01em;
    color: #0B2545;
    margin: 0 0 28px 0;
}
.rw-intro-body {
    font-family: 'Manrope', sans-serif;
    font-size: 17px;
    line-height: 1.72;
    color: rgba(11, 37, 69, .85);
    margin-bottom: 28px;
}
.rw-intro-body p { margin: 0 0 14px 0; }
.rw-intro-body p:last-child { margin-bottom: 0; }
.rw-intro-bullets {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.rw-intro-bullets li {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    font-family: 'Manrope', sans-serif;
    font-size: 15.5px;
    line-height: 1.55;
    color: rgba(11, 37, 69, .9);
}
.rw-bullet-mark {
    flex-shrink: 0;
    width: 10px; height: 10px;
    background: #B6924A;
    margin-top: 9px;
    transform: rotate(45deg);
}

/* Fade-in entrance */
.rw-intro .rw-intro-img-wrap,
.rw-intro .rw-intro-text > * {
    opacity: 0;
    transform: translateY(28px);
    transition: opacity .9s ease, transform .9s ease;
}
.rw-intro.rw-in .rw-intro-img-wrap,
.rw-intro.rw-in .rw-intro-text > * {
    opacity: 1;
    transform: translateY(0);
}
.rw-intro.rw-in .rw-intro-text > *:nth-child(2) { transition-delay: .08s; }
.rw-intro.rw-in .rw-intro-text > *:nth-child(3) { transition-delay: .16s; }
.rw-intro.rw-in .rw-intro-text > *:nth-child(4) { transition-delay: .24s; }

@media (max-width: 1024px) {
    .rw-intro { padding: 72px 28px; }
    .rw-intro-inner { gap: 56px; }
    .rw-intro-title { font-size: clamp(28px, 3.4vw, 40px); }
}
@media (max-width: 768px) {
    .rw-intro { padding: 56px 20px; }
    .rw-intro-inner {
        grid-template-columns: 1fr !important;
        grid-template-areas: "img" "text" !important;
        gap: 40px;
    }
    .rw-intro-img-wrap { max-width: 480px; margin: 0 auto; width: 100%; }
    .rw-intro-text { max-width: 100%; }
    .rw-intro-img-wrap::before {
        top: 14px; right: -14px; bottom: -14px; left: 14px;
    }
}
@media (max-width: 480px) {
    .rw-intro { padding: 40px 16px; }
    .rw-intro-img-wrap::before { display: none; }
    .rw-intro-title { font-size: 26px; }
    .rw-intro-body { font-size: 16px; }
    .rw-intro-bullets li { font-size: 14.5px; }
}
@media (prefers-reduced-motion: reduce) {
    .rw-intro .rw-intro-img-wrap,
    .rw-intro .rw-intro-text > * { opacity: 1 !important; transform: none !important; transition: none !important; }
    .rw-intro-img-wrap:hover::before,
    .rw-intro-img-wrap:hover .rw-intro-img { transform: none !important; }
}
