/* === RBI Listing Page v1 — Full SEO Edition === */

.rbi-listing { font-family: 'Roboto', sans-serif; color: #4B4B4B; line-height: 1.6; overflow: hidden; }
.rbi-listing * { box-sizing: border-box; margin: 0; padding: 0; }
.rbi-listing img { max-width: 100%; height: auto; }
.rbi-listing a { text-decoration: none; color: inherit; }
.rbi-listing h1, .rbi-listing h2, .rbi-listing h3 { font-family: 'EB Garamond', serif; color: #405363; font-weight: 500; line-height: 1.25; }

/* === Animations === */
@keyframes rbiFadeUp { from { opacity: 0; transform: translateY(24px); } to { opacity: 1; transform: translateY(0); } }
@keyframes rbiScaleIn { from { opacity: 0; transform: scale(1.05); } to { opacity: 1; transform: scale(1); } }

/* === HERO === */
.rbi-hero { background: #405363; color: #fff; padding: 80px 0 72px; }
.rbi-hero-inner { max-width: 1200px; margin: 0 auto; padding: 0 32px; display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: stretch; }
.rbi-hero-breadcrumb { font-family: 'Roboto', sans-serif; font-size: 13px; font-weight: 500; letter-spacing: 2px; text-transform: uppercase; color: rgba(255,255,255,0.6); margin-bottom: 20px; animation: rbiFadeUp 0.7s cubic-bezier(0.4,0,0.2,1) both; }
.rbi-hero h1 { font-size: 44px; color: #fff; margin-bottom: 24px; animation: rbiFadeUp 0.7s cubic-bezier(0.4,0,0.2,1) 0.15s both; }
.rbi-hero-desc { font-size: 16px; line-height: 1.7; color: rgba(255,255,255,0.85); margin-bottom: 16px; animation: rbiFadeUp 0.7s cubic-bezier(0.4,0,0.2,1) 0.3s both; }
.rbi-hero-cta { display: inline-block; margin-top: 16px; padding: 14px 36px; font-family: 'Roboto', sans-serif; font-size: 13px; font-weight: 500; letter-spacing: 1.5px; text-transform: uppercase; color: #fff; border: 1px solid rgba(255,255,255,0.4); transition: all 0.3s cubic-bezier(0.4,0,0.2,1); animation: rbiFadeUp 0.7s cubic-bezier(0.4,0,0.2,1) 0.45s both; }
.rbi-hero-cta:hover { background: #fff; color: #405363; border-color: #fff; }
.rbi-hero-image { border-radius: 4px; overflow: hidden; animation: rbiScaleIn 1s cubic-bezier(0.4,0,0.2,1) 0.2s both; }
.rbi-hero-image img { width: 100%; height: 100%; object-fit: cover; min-height: 0; }

/* === SUMMARY BAR === */
.rbi-summary { background: #36464f; padding: 32px 0; }
.rbi-summary-inner { max-width: 1200px; margin: 0 auto; padding: 0 32px; display: flex !important; align-items: center; justify-content: center; gap: 48px; }
.rbi-summary-item { text-align: center; }
.rbi-summary-number { display: block; font-family: 'EB Garamond', serif; font-size: 28px; font-weight: 600; color: #fff; line-height: 1.2; }
.rbi-summary-label { display: block; font-size: 12px; font-weight: 500; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(255,255,255,0.55); margin-top: 4px; }
.rbi-summary-divider { width: 1px; height: 40px; background: rgba(255,255,255,0.15); }

/* === META BAR === */
.rbi-meta-bar { background: #fff; padding: 16px 0; border-bottom: 1px solid #eef0f2; }
.rbi-meta-inner { max-width: 1200px; margin: 0 auto; padding: 0 32px; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 8px; }
.rbi-meta-updated { font-size: 13px; font-weight: 500; color: #405363; }
.rbi-meta-author { font-size: 13px; color: #75767A; }

/* === TABLE OF CONTENTS === */
.rbi-toc { background: #fff; padding: 24px 0; border-bottom: 1px solid #eef0f2; }
.rbi-toc-inner { max-width: 1200px; margin: 0 auto; padding: 0 32px; display: flex !important; align-items: center; gap: 20px; }
.rbi-toc-label { font-size: 12px; font-weight: 500; letter-spacing: 1.5px; text-transform: uppercase; color: #75767A; white-space: nowrap; }
.rbi-toc-links { display: flex !important; flex-wrap: wrap; gap: 8px; }
.rbi-toc-links a { font-size: 13px; color: #405363; padding: 6px 14px; border: 1px solid #e0e3e6; border-radius: 3px; transition: all 0.25s ease; }
.rbi-toc-links a:hover { background: #405363; color: #fff; border-color: #405363; }

/* === COMPARISON TABLE === */
.rbi-table-section { background: #fff; padding: 80px 0 60px; }
.rbi-table-inner { max-width: 1200px; margin: 0 auto; padding: 0 32px; }
.rbi-table-section h2 { font-size: 36px; text-align: center; margin-bottom: 16px; }
.rbi-table-subtitle { font-size: 16px; color: #75767A; text-align: center; margin-bottom: 48px; max-width: 700px; margin-left: auto; margin-right: auto; }
.rbi-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.rbi-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.rbi-table thead { background: #405363; color: #fff; }
.rbi-table th { padding: 14px 16px; text-align: left; font-family: 'Roboto', sans-serif; font-weight: 500; font-size: 12px; letter-spacing: 1px; text-transform: uppercase; white-space: nowrap; }
.rbi-table td { padding: 13px 16px; border-bottom: 1px solid #eef0f2; vertical-align: top; }
.rbi-table tbody tr:hover { background: #f9fafb; }
.rbi-table td:first-child { font-weight: 500; white-space: nowrap; }
.rbi-table td:first-child a { color: #405363; border-bottom: 1px solid transparent; transition: border-color 0.2s ease; }
.rbi-table td:first-child a:hover { border-color: #405363; }

/* === CARD GRID === */
.rbi-grid-section { background: #fff; padding: 80px 0; }
.rbi-grid-inner { max-width: 1200px; margin: 0 auto; padding: 0 32px; }
.rbi-grid-title { font-size: 36px; text-align: center; margin-bottom: 56px; }
.rbi-region-title { font-size: 24px; color: #405363; margin-top: 48px; margin-bottom: 8px; padding-bottom: 12px; border-bottom: 2px solid #eef0f2; }
.rbi-region-title:first-of-type { margin-top: 0; }
.rbi-region-desc { font-size: 15px; color: #75767A; line-height: 1.7; margin-bottom: 32px; }
.rbi-cards { display: grid !important; grid-template-columns: repeat(4, 1fr) !important; gap: 48px 40px; margin-bottom: 56px; }
.rbi-card { transition: transform 0.35s cubic-bezier(0.4,0,0.2,1), box-shadow 0.35s cubic-bezier(0.4,0,0.2,1); padding: 24px 8px 16px; border-radius: 4px; }
.rbi-card:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(64,83,99,0.08); }
.rbi-card-crest { width: 60px; height: 60px; margin: 0 auto 20px; display: flex; align-items: center; justify-content: center; transition: transform 0.35s cubic-bezier(0.4,0,0.2,1); }
.rbi-card:hover .rbi-card-crest { transform: scale(1.05); }
.rbi-card-crest img { max-width: 60px; max-height: 60px; object-fit: contain; }
.rbi-card h3 { font-size: 22px; text-align: center; margin-bottom: 12px; color: #405363; }
.rbi-card-desc { font-size: 14px; color: #75767A; line-height: 1.6; text-align: center; margin-bottom: 20px; }
.rbi-card-link { display: flex; align-items: center; justify-content: center; gap: 8px; font-size: 13px; font-weight: 500; letter-spacing: 1px; text-transform: uppercase; color: #405363; transition: gap 0.3s cubic-bezier(0.4,0,0.2,1); }
.rbi-card:hover .rbi-card-link { gap: 14px; }
.rbi-card-link span { font-size: 16px; }

/* === MID-PAGE CTA === */
.rbi-midcta { background: #f9fafb; padding: 56px 0; border-top: 1px solid #eef0f2; border-bottom: 1px solid #eef0f2; }
.rbi-midcta-inner { max-width: 700px; margin: 0 auto; padding: 0 32px; text-align: center; }
.rbi-midcta h3 { font-size: 28px; color: #405363; margin-bottom: 12px; }
.rbi-midcta p { font-size: 16px; color: #75767A; line-height: 1.7; margin-bottom: 24px; }
.rbi-midcta-btn { display: inline-block; padding: 14px 36px; font-size: 13px; font-weight: 500; letter-spacing: 1.5px; text-transform: uppercase; color: #fff; background: #405363; border: 3px solid #405363; border-radius: 8px; transition: all 0.3s cubic-bezier(0.4,0,0.2,1); }
.rbi-midcta-btn:hover { background: #fff; color: #405363; border: 3px solid #405363; }

/* === HOW IT WORKS (PROCESS) === */
.rbi-process { background: #fff; padding: 80px 0; }
.rbi-process-inner { max-width: 1200px; margin: 0 auto; padding: 0 32px; }
.rbi-process h2 { font-size: 36px; text-align: center; margin-bottom: 12px; }
.rbi-process-subtitle { font-size: 16px; color: #75767A; text-align: center; margin-bottom: 56px; }
.rbi-steps { display: grid !important; grid-template-columns: repeat(3, 1fr) !important; gap: 40px; }
.rbi-step { padding: 32px 24px; border: 1px solid #eef0f2; border-radius: 4px; transition: border-color 0.3s ease; }
.rbi-step:hover { border-color: #405363; }
.rbi-step-num { display: block; font-family: 'EB Garamond', serif; font-size: 36px; font-weight: 600; color: #e0e3e6; margin-bottom: 16px; line-height: 1; }
.rbi-step:hover .rbi-step-num { color: #405363; }
.rbi-step h3 { font-size: 18px; margin-bottom: 10px; color: #405363; }
.rbi-step p { font-size: 14px; color: #75767A; line-height: 1.65; }

/* === WHO IS THIS FOR === */
.rbi-audience { background: #f9fafb; padding: 80px 0; }
.rbi-audience-inner { max-width: 1200px; margin: 0 auto; padding: 0 32px; }
.rbi-audience h2 { font-size: 36px; text-align: center; margin-bottom: 56px; }
.rbi-audience-grid { display: grid !important; grid-template-columns: repeat(2, 1fr) !important; gap: 40px; }
.rbi-audience-item { padding: 32px; background: #fff; border-radius: 4px; border: 1px solid #eef0f2; }
.rbi-audience-item h3 { font-size: 20px; margin-bottom: 12px; color: #405363; }
.rbi-audience-item p { font-size: 15px; color: #75767A; line-height: 1.7; }
.rbi-audience-item a { color: #405363; border-bottom: 1px solid #405363; }

/* === 2026 UPDATES === */
.rbi-updates { background: #fff; padding: 80px 0; }
.rbi-updates-inner { max-width: 900px; margin: 0 auto; padding: 0 32px; }
.rbi-updates h2 { font-size: 36px; text-align: center; margin-bottom: 12px; }
.rbi-updates-subtitle { font-size: 16px; color: #75767A; text-align: center; margin-bottom: 48px; }
.rbi-updates-list { display: flex; flex-direction: column; gap: 24px; }
.rbi-update-item { padding: 28px 32px; border: 1px solid #eef0f2; border-radius: 4px; border-left: 3px solid #405363; }
.rbi-update-badge { display: inline-block; font-size: 11px; font-weight: 500; letter-spacing: 1.5px; text-transform: uppercase; color: #fff; background: #405363; padding: 3px 10px; border-radius: 2px; margin-bottom: 12px; }
.rbi-update-item h3 { font-size: 18px; margin-bottom: 8px; color: #405363; }
.rbi-update-item p { font-size: 15px; color: #75767A; line-height: 1.7; }
.rbi-update-item a { color: #405363; border-bottom: 1px solid #405363; }

/* === RESIDENCE PLANNING === */
.rbi-planning { background: #f9fafb; padding: 80px 0; }
.rbi-planning-inner { max-width: 1200px; margin: 0 auto; padding: 0 32px; }
.rbi-planning-title { font-size: 36px; text-align: center; margin-bottom: 56px; }
.rbi-planning-grid { display: grid !important; grid-template-columns: repeat(3, 1fr) !important; gap: 40px; }
.rbi-planning-col h3 { font-size: 20px; margin-bottom: 16px; color: #405363; }
.rbi-planning-col p { font-size: 15px; color: #75767A; line-height: 1.7; margin-bottom: 16px; }
.rbi-planning-col a { color: #405363; border-bottom: 1px solid #405363; }
.rbi-planning-link { font-size: 13px; font-weight: 500; letter-spacing: 1px; text-transform: uppercase; color: #405363; display: inline-flex; align-items: center; gap: 8px; transition: gap 0.3s cubic-bezier(0.4,0,0.2,1); border-bottom: none !important; }
.rbi-planning-link:hover { gap: 14px; }

/* === SEO CONTENT === */
.rbi-content { background: #fff; padding: 80px 0; }
.rbi-content-inner { max-width: 800px; margin: 0 auto; padding: 0 32px; }
.rbi-content h2 { font-size: 32px; margin-bottom: 24px; margin-top: 56px; }
.rbi-content h2:first-child { margin-top: 0; }
.rbi-content p { font-size: 16px; line-height: 1.8; color: #4B4B4B; margin-bottom: 20px; }
.rbi-content a { color: #405363; border-bottom: 1px solid #405363; }

/* === FAQ === */
.rbi-faq { background: #f9fafb; padding: 80px 0; }
.rbi-faq-inner { max-width: 900px; margin: 0 auto; padding: 0 32px; }
.rbi-faq h2 { font-size: 36px; text-align: center; margin-bottom: 48px; }
.rbi-faq-list { display: flex; flex-direction: column; gap: 20px; }
.rbi-faq-item { padding: 28px 32px; background: #fff; border: 1px solid #eef0f2; border-radius: 4px; }
.rbi-faq-item h3 { font-size: 18px; color: #405363; margin-bottom: 12px; }
.rbi-faq-item p { font-size: 15px; color: #4B4B4B; line-height: 1.7; }

/* === PAGE-LEVEL OVERRIDES === */
.page-id-193 .site-content { padding-top: 3px !important; margin-top: 0 !important; }
.page-id-193 #primary { padding: 0 !important; margin: 0 !important; }
.page-id-193 .ast-container { max-width: 100% !important; padding-left: 0 !important; padding-right: 0 !important; }
.page-id-193 .entry-content { margin: 0 !important; padding: 0 !important; }
.page-id-193 article { padding: 0 !important; margin: 0 !important; }
.page-id-193 .ast-article-single { padding: 0 !important; max-width: 100% !important; }

/* === Astra Override Fixes === */
.page-id-193 .entry-content > .rbi-listing { max-width: 100% !important; width: 100% !important; }
.page-id-193 .entry-content .rbi-summary-inner { display: flex !important; flex-direction: row !important; align-items: center !important; justify-content: center !important; }
.page-id-193 .entry-content .rbi-toc-inner { display: flex !important; flex-direction: row !important; align-items: center !important; }
.page-id-193 .entry-content .rbi-toc-links { display: flex !important; flex-direction: row !important; flex-wrap: wrap !important; }
.page-id-193 .entry-content .rbi-cards { display: grid !important; }
.page-id-193 .entry-content .rbi-steps { display: grid !important; }
.page-id-193 .entry-content .rbi-audience-grid { display: grid !important; }
.page-id-193 .entry-content .rbi-planning-grid { display: grid !important; }
.page-id-193 .entry-content .rbi-hero-inner { display: grid !important; }
.page-id-193 .entry-content a.rbi-midcta-btn { display: inline-block !important; padding: 14px 36px !important; font-size: 13px !important; font-weight: 500 !important; letter-spacing: 1.5px !important; text-transform: uppercase !important; color: #fff !important; background: #405363 !important; border: 3px solid #405363 !important; border-radius: 8px !important; transition: all 0.3s cubic-bezier(0.4,0,0.2,1) !important; }
.page-id-193 .entry-content a.rbi-midcta-btn:hover { background: #fff !important; color: #405363 !important; border: 3px solid #405363 !important; }

/* === SR-ONLY === */
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* === CONTACT CTA === */
.rbi-contact-cta { max-width: 100%; margin: 0; padding: 0; overflow: hidden; }
.rbi-contact-wrapper { display: grid; grid-template-columns: 1fr 1fr; min-height: 520px; }
.rbi-contact-content { display: flex; flex-direction: column; justify-content: center; padding: 80px 80px 80px 0; max-width: 600px; margin-left: auto; }
.rbi-contact-label { font-size: 12px; font-weight: 500; letter-spacing: 3px; text-transform: uppercase; color: #75767A; margin-bottom: 20px; animation: rbiFadeUp 0.6s cubic-bezier(0.4,0,0.2,1) 0.2s both; }
.rbi-contact-title { font-family: 'EB Garamond', serif; font-size: 52px; font-weight: 400; color: #405363; line-height: 1.15; margin-bottom: 28px; animation: rbiFadeUp 0.7s cubic-bezier(0.4,0,0.2,1) 0.35s both; }
.rbi-contact-desc { font-size: 17px; line-height: 1.7; color: #4B4B4B; margin-bottom: 40px; max-width: 440px; animation: rbiFadeUp 0.7s cubic-bezier(0.4,0,0.2,1) 0.5s both; }
.rbi-contact-btn { display: inline-flex; align-items: center; gap: 10px; font-size: 12px; font-weight: 500; letter-spacing: 2.5px; text-transform: uppercase; color: #405363; border: 1.5px solid #405363; padding: 16px 36px; background: transparent; transition: all 0.4s cubic-bezier(0.4,0,0.2,1); animation: rbiFadeUp 0.7s cubic-bezier(0.4,0,0.2,1) 0.65s both; }
.rbi-contact-btn:hover { background: #405363; color: #fff; }
.rbi-contact-arrow { font-size: 16px; transition: transform 0.3s cubic-bezier(0.4,0,0.2,1); }
.rbi-contact-btn:hover .rbi-contact-arrow { transform: translateX(4px); }
.rbi-contact-image { position: relative; overflow: hidden; }
.rbi-contact-image img { width: 100%; height: 100%; object-fit: cover; object-position: center top; display: block; animation: rbiScaleIn 1.2s cubic-bezier(0.4,0,0.2,1) 0.3s both; }
.rbi-contact-image::after { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: linear-gradient(to right, rgba(255,255,255,0.15) 0%, transparent 30%); pointer-events: none; }

/* === OL STEPS RESET === */
.rbi-steps { list-style: none; }

/* === MOBILE FIXES — Comprehensive === */

/* --- Tablet (max 1199px) --- */
@media (max-width: 1199px) {
    .rbi-hero-inner { grid-template-columns: 1fr !important; gap: 40px !important; }
    .rbi-hero-image { order: -1 !important; }
    .rbi-hero h1 { font-size: 36px !important; }
    .rbi-hero-image img { min-height: 300px !important; }
    .rbi-cards { grid-template-columns: repeat(2, 1fr) !important; gap: 40px 32px !important; }
    .rbi-planning-grid { grid-template-columns: repeat(2, 1fr) !important; }
    .rbi-steps { grid-template-columns: repeat(2, 1fr) !important; }
    .rbi-summary-inner { gap: 32px !important; flex-wrap: wrap !important; }
    .rbi-contact-wrapper { grid-template-columns: 1fr !important; min-height: auto !important; }
    .rbi-contact-content { padding: 60px 40px !important; max-width: 100% !important; margin: 0 !important; order: 2 !important; }
    .rbi-contact-title { font-size: 42px !important; }
    .rbi-contact-image { order: 1 !important; height: 380px !important; }
}

/* --- Mobile (max 767px) --- */
@media (max-width: 767px) {
    /* Hero */
    .rbi-hero { padding: 48px 0 40px !important; }
    .rbi-hero-inner { padding: 0 20px !important; gap: 32px !important; }
    .rbi-hero h1 { font-size: 28px !important; }
    .rbi-hero-desc { font-size: 15px !important; }
    .rbi-hero-image img { min-height: 220px !important; }
    .rbi-hero-cta { padding: 12px 28px !important; font-size: 12px !important; width: 100%; text-align: center; }

    /* Meta bar */
    .rbi-meta-inner { flex-direction: column !important; align-items: flex-start !important; padding: 0 20px !important; }

    /* Summary bar */
    .rbi-summary { padding: 24px 0 !important; }
    .rbi-summary-inner { padding: 0 20px !important; gap: 20px !important; justify-content: space-around !important; flex-wrap: wrap !important; }
    .rbi-summary-divider { display: none !important; }
    .rbi-summary-number { font-size: 22px !important; }
    .rbi-summary-label { font-size: 10px !important; letter-spacing: 1px !important; }

    /* TOC */
    .rbi-toc-inner { flex-direction: column !important; align-items: flex-start !important; gap: 12px !important; padding: 0 20px !important; }
    .rbi-toc-links { gap: 6px !important; }
    .rbi-toc-links a { font-size: 12px !important; padding: 5px 10px !important; }

    /* Comparison table */
    .rbi-table-section { padding: 48px 0 40px !important; }
    .rbi-table-inner { padding: 0 20px !important; }
    .rbi-table-section h2 { font-size: 24px !important; }
    .rbi-table-subtitle { font-size: 14px !important; margin-bottom: 24px !important; }
    .rbi-table-wrap { margin: 0 -20px; padding: 0 20px; position: relative; }
    .rbi-table-wrap::after { content: 'Scroll \2192'; position: absolute; top: -28px; right: 20px; font-size: 12px; color: #75767A; letter-spacing: 0.5px; }
    .rbi-table { font-size: 13px !important; min-width: 600px; }
    .rbi-table th { padding: 10px 12px !important; font-size: 11px !important; }
    .rbi-table td { padding: 10px 12px !important; }

    /* Card grid */
    .rbi-grid-section { padding: 48px 0 !important; }
    .rbi-grid-inner { padding: 0 20px !important; }
    .rbi-grid-title { font-size: 26px !important; margin-bottom: 32px !important; }
    .rbi-cards { grid-template-columns: 1fr !important; gap: 24px !important; margin-bottom: 40px !important; }
    .rbi-card { padding: 20px 16px 16px !important; }
    .rbi-card h3 { font-size: 20px !important; }
    .rbi-card-desc { font-size: 13px !important; }
    .rbi-region-title { font-size: 20px !important; margin-top: 36px !important; }
    .rbi-region-desc { font-size: 14px !important; margin-bottom: 24px !important; }

    /* Mid CTA */
    .rbi-midcta { padding: 40px 0 !important; }
    .rbi-midcta-inner { padding: 0 20px !important; }
    .rbi-midcta h3 { font-size: 22px !important; }
    .rbi-midcta p { font-size: 15px !important; }
    .rbi-midcta-btn,
    .page-id-193 .entry-content a.rbi-midcta-btn { padding: 12px 28px !important; font-size: 12px !important; width: 100% !important; text-align: center !important; display: block !important; }

    /* Process steps */
    .rbi-process { padding: 48px 0 !important; }
    .rbi-process-inner { padding: 0 20px !important; }
    .rbi-process h2 { font-size: 26px !important; }
    .rbi-process-subtitle { font-size: 14px !important; margin-bottom: 32px !important; }
    .rbi-steps { grid-template-columns: 1fr !important; gap: 20px !important; }
    .rbi-step { padding: 24px 20px !important; }
    .rbi-step-num { font-size: 28px !important; }
    .rbi-step h3 { font-size: 16px !important; }
    .rbi-step p { font-size: 13px !important; }

    /* Audience */
    .rbi-audience { padding: 48px 0 !important; }
    .rbi-audience-inner { padding: 0 20px !important; }
    .rbi-audience h2 { font-size: 26px !important; margin-bottom: 32px !important; }
    .rbi-audience-grid { grid-template-columns: 1fr !important; gap: 20px !important; }
    .rbi-audience-item { padding: 24px 20px !important; }
    .rbi-audience-item h3 { font-size: 18px !important; }
    .rbi-audience-item p { font-size: 14px !important; }

    /* Updates */
    .rbi-updates { padding: 48px 0 !important; }
    .rbi-updates-inner { padding: 0 20px !important; }
    .rbi-updates h2 { font-size: 26px !important; }
    .rbi-updates-subtitle { font-size: 14px !important; margin-bottom: 32px !important; }
    .rbi-update-item { padding: 20px !important; }
    .rbi-update-item h3 { font-size: 16px !important; }
    .rbi-update-item p { font-size: 14px !important; }

    /* Planning */
    .rbi-planning { padding: 48px 0 !important; }
    .rbi-planning-inner { padding: 0 20px !important; }
    .rbi-planning-title { font-size: 26px !important; margin-bottom: 32px !important; }
    .rbi-planning-grid { grid-template-columns: 1fr !important; gap: 32px !important; }
    .rbi-planning-col h3 { font-size: 18px !important; }
    .rbi-planning-col p { font-size: 14px !important; }

    /* SEO content */
    .rbi-content { padding: 48px 0 !important; }
    .rbi-content-inner { padding: 0 20px !important; }
    .rbi-content h2 { font-size: 24px !important; margin-top: 40px !important; }
    .rbi-content p { font-size: 15px !important; }

    /* FAQ */
    .rbi-faq { padding: 48px 0 !important; }
    .rbi-faq-inner { padding: 0 20px !important; }
    .rbi-faq h2 { font-size: 26px !important; margin-bottom: 32px !important; }
    .rbi-faq-list { gap: 12px !important; }
    .rbi-faq-item { padding: 20px !important; }
    .rbi-faq-item h3 { font-size: 16px !important; }
    .rbi-faq-item p { font-size: 14px !important; }

    /* Contact CTA */
    .rbi-contact-wrapper { grid-template-columns: 1fr !important; }
    .rbi-contact-content { padding: 40px 20px !important; max-width: 100% !important; margin: 0 !important; order: 2 !important; }
    .rbi-contact-title { font-size: 30px !important; }
    .rbi-contact-desc { font-size: 15px !important; }
    .rbi-contact-image { order: 1 !important; height: 260px !important; }
    .rbi-contact-btn { padding: 14px 28px !important; width: 100% !important; justify-content: center !important; }
}

/* --- Small phones (max 400px) --- */
@media (max-width: 400px) {
    .rbi-hero h1 { font-size: 24px !important; }
    .rbi-hero-inner { padding: 0 16px !important; }
    .rbi-summary-inner { padding: 0 16px !important; flex-direction: column !important; gap: 16px !important; }
    .rbi-summary-item { width: 100%; }
    .rbi-toc-inner { padding: 0 16px !important; }
    .rbi-toc-links { flex-direction: column !important; width: 100%; }
    .rbi-toc-links a { display: block !important; width: 100% !important; text-align: center !important; }
    .rbi-table-inner,
    .rbi-grid-inner,
    .rbi-process-inner,
    .rbi-audience-inner,
    .rbi-updates-inner,
    .rbi-planning-inner,
    .rbi-content-inner,
    .rbi-faq-inner,
    .rbi-midcta-inner,
    .rbi-meta-inner { padding: 0 16px !important; }
    .rbi-contact-content { padding: 32px 16px !important; }
    .rbi-contact-title { font-size: 26px !important; }
    .rbi-contact-image { height: 220px !important; }
    .rbi-grid-title,
    .rbi-planning-title { font-size: 24px !important; }
}