
:root {
  --navy: #002868; --navy-d: #001a45; --navy-l: #003a8c; --navy-xl: #e8ecf7;
  --red: #BF0A30; --red-l: #ffeaea;
  --green: #00875A; --green-l: #e6f5f0;
  --amber: #D97706; --amber-l: #fef3c7;
  --g50: #f8fafc; --g100: #f1f5f9; --g200: #e2e8f0; --g300: #cbd5e1;
  --g400: #94a3b8; --g500: #64748b; --g600: #475569; --g700: #334155; --g900: #0f172a;
  --r: 12px; --rl: 18px;
  --sh: 0 4px 20px rgba(0,40,104,.06);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:var(--g50);color:var(--g900);font-size:14px;line-height:1.6}
h1,h2,h3,h4,h5{font-family:'Montserrat',sans-serif}

/* ── HEADER ── */
.hdr { background:var(--navy-d); position:relative; overflow:hidden; padding:56px 20px 48px; text-align:center; color:#fff; }
.hdr-bg { position:absolute; inset:0; background:linear-gradient(135deg, #001a45 0%, #002868 50%, #004aad 100%); z-index:0; }
.hdr-dots { position:absolute; inset:0; background-image:radial-gradient(rgba(255,255,255,.05) 1px,transparent 1px); background-size:30px 30px; z-index:1; }
.hdr-inner { position:relative; z-index:2; max-width: 900px; margin: 0 auto; }
.hdr .brand { font-size:11px; font-weight:800; letter-spacing:2px; text-transform:uppercase; color:rgba(255,255,255,.6); margin-bottom:12px; }
.hdr h1 { font-size:clamp(26px, 4vw, 44px); font-weight:900; letter-spacing:-1px; line-height:1.15; margin-bottom:16px; }
.hdr h1 span { color:#7fd6e8; }
.hdr .sub { color:rgba(255,255,255,.8); font-size:16px; margin-bottom:24px; }
.pill-row { display:flex; flex-wrap:wrap; gap:8px; justify-content:center; }
.pill { background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.2); border-radius:100px; padding:6px 14px; font-size:12px; font-weight:600; }
.pill.hi { background:rgba(0,135,90,.25); border-color:rgba(0,135,90,.4); color:#6ee7b7; }

/* ── CALCULATOR SHELL ── */
.wrap { max-width:1200px; margin: -30px auto 80px; padding: 0 16px; position:relative; z-index:10; }
.card { background:#fff; border-radius:var(--rl); box-shadow:var(--sh); padding:32px; margin-bottom:24px; border:1px solid var(--g200); }

.grid-2 { display:grid; grid-template-columns: 1fr 1.1fr; gap:32px; }
@media(max-width:960px) { .grid-2 { grid-template-columns: 1fr; } }

.sec-ttl { display:flex; align-items:center; gap:12px; margin-bottom:20px; }
.sec-ttl .ico { width:36px; height:36px; border-radius:10px; background:var(--navy-xl); display:flex; align-items:center; justify-content:center; font-size:18px; color:var(--navy); }
.sec-ttl h2 { font-size:18px; font-weight:800; color:var(--navy); }

/* ── INPUTS ── */
.igrid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:16px; }
.fg { display:flex; flex-direction:column; gap:6px; }
.fg label { font-size:12px; font-weight:700; color:var(--g700); display:flex; align-items:center; gap:5px; text-transform:uppercase; letter-spacing:0.5px; }
.irow { display:flex; align-items:center; border:1.5px solid var(--g200); border-radius:8px; overflow:hidden; background:#fff; transition:border-color .15s; }
.irow:focus-within { border-color:var(--navy); box-shadow:0 0 0 3px rgba(0,40,104,.08); }
.ipfx, .isfx { padding:0 12px; background:var(--g50); color:var(--g600); font-weight:700; font-size:13px; height:44px; display:flex; align-items:center; border-right:1px solid var(--g200); }
.isfx { border-right:none; border-left:1px solid var(--g200); }
.fg input, .fg select { flex:1; border:none; outline:none; padding:0 14px; font-family:'Inter',sans-serif; font-size:15px; font-weight:600; height:44px; color:var(--g900); width:100%; }
.hint { font-size:11px; color:var(--g500); margin-top:2px; line-height:1.4; }

.tip { display:inline-flex; align-items:center; justify-content:center; width:14px; height:14px; background:var(--g300); border-radius:50%; font-size:9px; font-weight:800; color:#fff; cursor:help; position:relative; }
.tip:hover::after { content:attr(data-t); position:absolute; bottom:20px; left:50%; transform:translateX(-50%); background:var(--navy); color:#fff; padding:8px 12px; border-radius:6px; width:220px; font-size:11px; font-weight:500; text-transform:none; letter-spacing:0; text-align:center; z-index:10; }

hr { border:none; border-top:1px solid var(--g200); margin:24px 0; }

/* ── RESULTS ── */
.res-panel { background:var(--g50); border:1px solid var(--g200); border-radius:var(--r); padding:24px; height:100%; display:flex; flex-direction:column; }
.kpi-main { background:var(--navy); border-radius:12px; padding:24px; color:#fff; margin-bottom:20px; text-align:center; position:relative; overflow:hidden; }
.kpi-main::before { content:''; position:absolute; top:0; left:0; width:100%; height:4px; background:var(--green); }
.kpi-main.rent-wins::before { background:var(--amber); }

.kpi-main .lbl { font-size:13px; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:rgba(255,255,255,.8); margin-bottom:8px; }
.kpi-main .val { font-family:'Montserrat',sans-serif; font-size:36px; font-weight:900; line-height:1.2; margin-bottom:8px; color: #fff;}
.kpi-main .sub { font-size:14px; font-weight:500; color:rgba(255,255,255,.9); }

.mgrid { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:24px; }
.mc { background:#fff; border:1px solid var(--g200); border-radius:10px; padding:16px; border-left:4px solid var(--navy); }
.mc.g { border-left-color:var(--green); }
.mc.a { border-left-color:var(--amber); }
.mc.r { border-left-color:var(--red); }
.mc .ml { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:0.5px; color:var(--g500); margin-bottom:4px; }
.mc .mv { font-family:'Montserrat',sans-serif; font-size:20px; font-weight:800; color:var(--g900); }

/* Chart Container */
.chart-wrap { width:100%; height:260px; margin-bottom:24px; background:#fff; border:1px solid var(--g200); border-radius:10px; padding:16px; }

/* Breakdown Table */
.breakdown { background:#fff; border:1px solid var(--g200); border-radius:10px; overflow:hidden; }
.bd-row { display:flex; justify-content:space-between; padding:12px 16px; border-bottom:1px solid var(--g100); font-size:13.5px; font-weight:500; }
.bd-row:last-child { border-bottom:none; }
.bd-row.hl { background:var(--navy-xl); font-weight:700; color:var(--navy); }
.bd-row.hl2 { background:var(--amber-l); font-weight:700; color:#92400e; }
.bd-row.neg { color:var(--red); }
.bd-row.pos { color:var(--green); }
.bd-head { background:var(--g50); font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--g500); padding:8px 16px; border-bottom:1px solid var(--g200); }

/* Time Horizon Slider */
.roi-box { background:#fff; border:1px solid var(--g200); border-radius:10px; padding:20px; margin-bottom:20px; }
.roi-box h4 { color:var(--navy); font-size:14px; margin-bottom:12px; display:flex; align-items:center; gap:8px; }

/* Buttons */
.btn-row { display:flex; flex-wrap:wrap; gap:12px; margin-top:24px; }
.btn { flex:1; padding:12px 14px; border-radius:8px; font-family:'Montserrat',sans-serif; font-size:12px; font-weight:700; cursor:pointer; display:flex; justify-content:center; align-items:center; gap:8px; transition:all .2s; border:2px solid; white-space:nowrap; }
.btn-p { background:var(--navy); border-color:var(--navy); color:#fff; }
.btn-p:hover { background:var(--navy-d); }
.btn-wa { background:#25D366; border-color:#25D366; color:#fff; }
.btn-wa:hover { background:#128C7E; border-color:#128C7E; }
.btn-clear { background:#fff; border-color:var(--red); color:var(--red); }
.btn-clear:hover { background:var(--red-l); }
/* ── LAYOUT ── */
.rvb-wrap { max-width: 1100px; margin: 0 auto 80px; padding: 0 20px; }
@media (max-width: 640px) { .rvb-wrap { padding: 0 14px; } }

/* ── SHARED CARD ── */
.rvb-card {
  background: #fff;
  border-radius: var(--rl);
  box-shadow: var(--sh);
  border: 1px solid var(--g200);
  margin-bottom: 28px;
  overflow: hidden;
}
.rvb-card-body { padding: 36px 40px; }
@media (max-width: 640px) { .rvb-card-body { padding: 22px 16px; } }

/* ── SECTION HEADER BAND ── */
.rvb-section-head {
  background: var(--navy-d);
  border-radius: var(--rl);
  padding: 40px 40px 36px;
  margin-bottom: 28px;
  position: relative;
  overflow: hidden;
}
.rvb-section-head::before {
  content:'';
  position:absolute; inset:0;
  background:linear-gradient(135deg,#001a45 0%,#002868 60%,#004aad 100%);
  z-index:0;
}
.rvb-section-head::after {
  content:'';
  position:absolute; inset:0;
  background-image:radial-gradient(rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:28px 28px;
  z-index:1;
}
.rvb-sh-inner { position:relative; z-index:2; }
.rvb-sh-eyebrow {
  font-size:11px; font-weight:800; letter-spacing:2.5px;
  text-transform:uppercase; color:rgba(255,255,255,.5); margin-bottom:14px;
}
.rvb-sh-inner h2 {
  font-size: clamp(22px, 3.5vw, 34px);
  font-weight:900; color:#fff; line-height:1.2; margin-bottom:12px;
}
.rvb-sh-inner h2 span { color:#7fd6e8; }
.rvb-sh-inner p { font-size:15px; color:rgba(255,255,255,.75); max-width:680px; line-height:1.7; margin-bottom:24px; }
.rvb-sh-pills { display:flex; flex-wrap:wrap; gap:8px; }
.rvb-sh-pill {
  background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.18);
  border-radius:100px; padding:5px 14px; font-size:12px; font-weight:600;
  color:rgba(255,255,255,.85);
}
.rvb-sh-pill.g { background:rgba(0,135,90,.25); border-color:rgba(0,135,90,.4); color:#6ee7b7; }
.rvb-sh-pill.a { background:rgba(217,119,6,.25); border-color:rgba(217,119,6,.4); color:#fde68a; }
@media (max-width: 600px) { .rvb-section-head { padding: 26px 16px; } }

/* ── TYPOGRAPHY ── */
.rvb-body { font-size:15px; color:var(--g700); line-height:1.8; margin-bottom:18px; }
.rvb-body strong { color:var(--g900); font-weight:700; }
.rvb-body a { color:var(--navy); font-weight:600; text-decoration:none; }
.rvb-body a:hover { text-decoration:underline; }

.rvb-sub-head {
  font-family:'Montserrat',sans-serif; font-size:18px; font-weight:800;
  color:var(--navy); margin:32px 0 14px; padding-bottom:10px;
  border-bottom:2px solid var(--navy-xl);
  display:flex; align-items:center; gap:10px;
}
@media (max-width: 480px) { .rvb-sub-head { font-size:16px; } }

/* ── FORMULA BOX ── */
.rvb-formula-box {
  background:var(--navy); border-radius:12px;
  padding:24px 28px; margin:24px 0;
  position:relative; overflow:hidden;
}
.rvb-formula-box::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--green),#7fd6e8);
}
.rvb-fb-label {
  font-family:'Montserrat',sans-serif; font-size:10px; font-weight:800;
  letter-spacing:2px; text-transform:uppercase;
  color:rgba(255,255,255,.5); margin-bottom:10px;
}
.rvb-fb-formula {
  font-family:'Montserrat',sans-serif;
  font-size:clamp(14px,2.5vw,20px);
  font-weight:900; color:#7fd6e8; line-height:1.5; margin-bottom:12px;
  word-break:break-word;
}
.rvb-fb-vars { display:flex; flex-wrap:wrap; gap:8px; }
.rvb-fb-var {
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12);
  border-radius:6px; padding:4px 12px; font-size:12px;
  font-weight:600; color:rgba(255,255,255,.85);
}
@media (max-width: 480px) { .rvb-formula-box { padding:16px 14px; } }

/* ── FORMULA STEPS ── */
.rvb-steps { counter-reset:rvbstep; display:flex; flex-direction:column; gap:12px; margin:20px 0; }
.rvb-step {
  display:flex; gap:16px; align-items:flex-start;
  background:var(--g50); border:1px solid var(--g200);
  border-radius:10px; padding:14px 16px; position:relative;
}
.rvb-step::before {
  counter-increment:rvbstep; content:counter(rvbstep);
  font-family:'Montserrat',sans-serif; font-size:12px; font-weight:900;
  color:#fff; background:var(--navy);
  min-width:26px; height:26px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.rvb-step-title { font-weight:700; font-size:14px; color:var(--g900); margin-bottom:4px; }
.rvb-step-detail { font-size:13px; color:var(--g600); line-height:1.65; }
.rvb-step-math {
  font-family:'Montserrat',sans-serif; font-size:13px; font-weight:700;
  color:var(--navy); background:var(--navy-xl);
  display:inline-block; padding:3px 10px; border-radius:5px; margin-top:6px;
  word-break:break-all;
}
@media (max-width: 480px) { .rvb-step { gap:10px; padding:12px; } }

/* ── VS BAR (BUY vs RENT) ── */
.rvb-vs-bar {
  display:grid; grid-template-columns:1fr 56px 1fr;
  gap:12px; align-items:stretch; margin:24px 0;
}
@media (max-width: 580px) {
  .rvb-vs-bar { grid-template-columns:1fr; }
  .rvb-vs-center { display:none; }
}
.rvb-vs-buy { background:var(--navy-xl); border:1.5px solid #c7d2fe; border-radius:12px; padding:20px; }
.rvb-vs-rent { background:var(--green-l); border:1.5px solid #a7f3d0; border-radius:12px; padding:20px; }
.rvb-vs-center { display:flex; align-items:center; justify-content:center; }
.rvb-vs-badge {
  width:44px; height:44px; background:var(--g200); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-family:'Montserrat',sans-serif; font-size:11px; font-weight:900; color:var(--g600);
}
.rvb-vs-tag {
  display:inline-block; font-size:10px; font-weight:800;
  letter-spacing:1px; text-transform:uppercase;
  padding:2px 10px; border-radius:100px; margin-bottom:8px;
}
.rvb-vs-buy .rvb-vs-tag { background:var(--navy); color:#fff; }
.rvb-vs-rent .rvb-vs-tag { background:var(--green); color:#fff; }
.rvb-vs-buy h4 { font-size:14px; font-weight:800; color:var(--navy); margin-bottom:8px; }
.rvb-vs-rent h4 { font-size:14px; font-weight:800; color:var(--green); margin-bottom:8px; }
.rvb-vs-buy p, .rvb-vs-rent p { font-size:13px; color:var(--g700); line-height:1.65; }

/* ── TWO COLUMN ── */
.rvb-two-col { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin:20px 0; }
@media (max-width: 620px) { .rvb-two-col { grid-template-columns:1fr; } }
.rvb-col-box { background:var(--g50); border:1px solid var(--g200); border-radius:10px; padding:20px; }
.rvb-col-box h4 { font-family:'Montserrat',sans-serif; font-size:13px; font-weight:800; color:var(--navy); margin-bottom:10px; }
.rvb-col-list { list-style:none; display:flex; flex-direction:column; gap:8px; }
.rvb-col-list li { font-size:13px; color:var(--g700); display:flex; gap:8px; align-items:flex-start; line-height:1.55; }
.rvb-col-list li::before { content:'✓'; color:var(--green); font-weight:900; flex-shrink:0; }
.rvb-col-list li.no::before { content:'✗'; color:var(--red); }

/* ── CALLOUT ── */
.rvb-callout {
  border-radius:10px; padding:18px 20px; margin:20px 0;
  display:flex; gap:14px; align-items:flex-start; border:1px solid;
}
.rvb-callout.navy { background:var(--navy-xl); border-color:#c7d2fe; }
.rvb-callout.green { background:var(--green-l); border-color:#a7f3d0; }
.rvb-callout.amber { background:var(--amber-l); border-color:#fde68a; }
.rvb-callout.red { background:var(--red-l); border-color:#fca5a5; }
.rvb-callout-ico { font-size:22px; flex-shrink:0; line-height:1; }
.rvb-callout-body { font-size:13.5px; color:var(--g700); line-height:1.7; }
.rvb-callout-body strong { color:var(--g900); font-weight:700; }

/* ── INSIGHT CARDS ── */
.rvb-insight-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin:20px 0; }
@media (max-width: 700px) { .rvb-insight-grid { grid-template-columns:1fr 1fr; } }
@media (max-width: 420px) { .rvb-insight-grid { grid-template-columns:1fr; } }
.rvb-insight-card { border-radius:10px; padding:18px; border:1.5px solid; }
.rvb-insight-card.blue { background:var(--navy-xl); border-color:#c7d2fe; }
.rvb-insight-card.green { background:var(--green-l); border-color:#a7f3d0; }
.rvb-insight-card.amber { background:var(--amber-l); border-color:#fde68a; }
.rvb-insight-card.red { background:var(--red-l); border-color:#fca5a5; }
.rvb-insight-num { font-family:'Montserrat',sans-serif; font-size:32px; font-weight:900; line-height:1; margin-bottom:4px; }
.rvb-insight-card.blue .rvb-insight-num { color:var(--navy); }
.rvb-insight-card.green .rvb-insight-num { color:var(--green); }
.rvb-insight-card.amber .rvb-insight-num { color:var(--amber); }
.rvb-insight-card.red .rvb-insight-num { color:var(--red); }
.rvb-insight-label { font-family:'Montserrat',sans-serif; font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:.8px; color:var(--g600); margin-bottom:6px; }
.rvb-insight-desc { font-size:12.5px; color:var(--g700); line-height:1.6; }

/* ── DEMO CALC BOX ── */
.rvb-demo-calc {
  background:var(--navy); border-radius:14px;
  padding:28px; margin:24px 0; color:#fff;
  position:relative; overflow:hidden;
}
.rvb-demo-calc::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--green),#7fd6e8,var(--amber));
}
.rvb-dc-title {
  font-family:'Montserrat',sans-serif; font-size:11px; font-weight:900;
  letter-spacing:2px; text-transform:uppercase;
  color:rgba(255,255,255,.5); margin-bottom:16px;
}
.rvb-dc-scenario {
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1);
  border-radius:10px; padding:16px; margin-bottom:16px;
  font-size:13px; color:rgba(255,255,255,.85); line-height:1.7;
}
.rvb-dc-scenario strong { color:#7fd6e8; }
.rvb-dc-result-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
@media (max-width: 560px) { .rvb-dc-result-grid { grid-template-columns:1fr 1fr; } }
@media (max-width: 360px) { .rvb-dc-result-grid { grid-template-columns:1fr; } }
.rvb-dc-r { background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.08); border-radius:8px; padding:12px; text-align:center; }
.rvb-dc-num { font-family:'Montserrat',sans-serif; font-size:20px; font-weight:900; color:#6ee7b7; line-height:1; }
.rvb-dc-num.warn { color:#fcd34d; }
.rvb-dc-num.bad { color:#fca5a5; }
.rvb-dc-lbl { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.5px; color:rgba(255,255,255,.5); margin-top:4px; }
@media (max-width: 480px) { .rvb-demo-calc { padding:18px 14px; } }

/* ── BENCHMARK / DATA TABLE ── */
.rvb-table-scroll { overflow-x:auto; -webkit-overflow-scrolling:touch; border-radius:10px; }
.rvb-table {
  width:100%; border-collapse:collapse; font-size:13px; min-width:520px;
}
.rvb-table thead tr { background:var(--navy); color:#fff; }
.rvb-table thead th {
  font-family:'Montserrat',sans-serif; font-size:11px; font-weight:800;
  letter-spacing:.8px; text-transform:uppercase;
  padding:11px 14px; text-align:left; white-space:nowrap;
}
.rvb-table thead th:first-child { border-radius:8px 0 0 0; }
.rvb-table thead th:last-child { border-radius:0 8px 0 0; }
.rvb-table tbody tr { border-bottom:1px solid var(--g200); transition:background .15s; }
.rvb-table tbody tr:hover { background:var(--g50); }
.rvb-table tbody tr:last-child { border-bottom:none; }
.rvb-table tbody td { padding:11px 14px; color:var(--g700); vertical-align:middle; }
.rvb-table tbody td:first-child { font-weight:700; color:var(--g900); }
.rvb-pill-g { display:inline-block; background:#d1fae5; color:#065f46; font-size:11px; font-weight:700; padding:2px 10px; border-radius:100px; }
.rvb-pill-a { display:inline-block; background:#fef3c7; color:#92400e; font-size:11px; font-weight:700; padding:2px 10px; border-radius:100px; }
.rvb-pill-r { display:inline-block; background:#fee2e2; color:#991b1b; font-size:11px; font-weight:700; padding:2px 10px; border-radius:100px; }
.rvb-pill-n { display:inline-block; background:var(--navy-xl); color:var(--navy); font-size:11px; font-weight:700; padding:2px 10px; border-radius:100px; }

/* ── PRO TIPS ── */
.rvb-tips-grid { display:flex; flex-direction:column; gap:16px; margin:20px 0; }
.rvb-tip-card {
  background:#fff; border:1px solid var(--g200); border-radius:var(--rl);
  box-shadow:var(--sh); overflow:hidden;
  display:grid; grid-template-columns:72px 1fr;
}
@media (max-width: 480px) { .rvb-tip-card { grid-template-columns:56px 1fr; } }
.rvb-tip-num {
  background:var(--navy); display:flex; flex-direction:column;
  align-items:center; justify-content:center; padding:20px 10px; gap:4px;
}
.rvb-tip-num .tn { font-family:'Montserrat',sans-serif; font-size:28px; font-weight:900; color:#fff; line-height:1; }
.rvb-tip-num .tl { font-size:9px; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:rgba(255,255,255,.5); }
@media (max-width: 480px) { .rvb-tip-num .tn { font-size:22px; } }
.rvb-tip-body { padding:20px 22px; }
@media (max-width: 480px) { .rvb-tip-body { padding:14px 14px; } }
.rvb-tip-tag {
  display:inline-block; font-size:10px; font-weight:800; letter-spacing:1px;
  text-transform:uppercase; padding:2px 10px; border-radius:100px;
  margin-bottom:8px;
}
.rvb-tip-tag.buy { background:var(--navy-xl); color:var(--navy); }
.rvb-tip-tag.rent { background:var(--green-l); color:var(--green); }
.rvb-tip-tag.both { background:var(--amber-l); color:var(--amber); }
.rvb-tip-title { font-family:'Montserrat',sans-serif; font-size:15px; font-weight:800; color:var(--g900); margin-bottom:6px; line-height:1.3; }
@media (max-width:480px) { .rvb-tip-title { font-size:14px; } }
.rvb-tip-desc { font-size:13.5px; color:var(--g600); line-height:1.7; }

/* ── CONTENT LIST ── */
.rvb-list { padding-left:0; list-style:none; display:flex; flex-direction:column; gap:10px; margin:16px 0; }
.rvb-list li { font-size:14px; color:var(--g700); display:flex; gap:12px; align-items:flex-start; line-height:1.7; }
.rvb-list li .li-ico { flex-shrink:0; font-size:16px; }

/* ── WARNING / SUCCESS STRIP ── */
.rvb-warning { background:var(--red-l); border:1px solid #fca5a5; border-left:5px solid var(--red); border-radius:10px; padding:16px 20px; margin:20px 0; font-size:13.5px; color:#7f1d1d; line-height:1.7; }
.rvb-success { background:var(--green-l); border:1px solid #a7f3d0; border-left:5px solid var(--green); border-radius:10px; padding:16px 20px; margin:20px 0; font-size:13.5px; color:#064e3b; line-height:1.7; }

/* ── FAQ ── */
.rvb-faq-header {
  text-align:center; padding:40px 20px 10px;
}
.rvb-faq-header h2 { font-size:clamp(20px,3vw,28px); font-weight:900; color:var(--navy); margin-bottom:10px; }
.rvb-faq-header p { font-size:14px; color:var(--g500); max-width:560px; margin:0 auto; }

.rvb-faq-list { display:flex; flex-direction:column; gap:0; margin:24px 0; }
.rvb-faq-item { border:1px solid var(--g200); border-radius:10px; background:#fff; margin-bottom:10px; overflow:hidden; transition:box-shadow .2s; }
.rvb-faq-item.is-open { box-shadow:var(--sh); }
.rvb-faq-question {
  width:100%; background:none; border:none; cursor:pointer;
  display:flex; align-items:center; gap:12px;
  padding:16px 20px; text-align:left;
}
@media (max-width:480px) { .rvb-faq-question { padding:14px 14px; } }
.rvb-faq-q-label {
  font-family:'Montserrat',sans-serif; font-size:11px; font-weight:900;
  color:#fff; background:var(--navy); border-radius:6px;
  padding:2px 8px; flex-shrink:0; letter-spacing:.5px;
}
.rvb-faq-q-text {
  font-family:'Montserrat',sans-serif; font-size:14px; font-weight:700;
  color:var(--g900); line-height:1.4; flex:1;
}
@media (max-width:480px) { .rvb-faq-q-text { font-size:13px; } }
.rvb-faq-q-icon {
  font-family:'Montserrat',sans-serif; font-size:22px; font-weight:300;
  color:var(--g400); flex-shrink:0; transition:transform .25s, color .2s;
  line-height:1;
}
.rvb-faq-item.is-open .rvb-faq-q-icon { transform:rotate(45deg); color:var(--navy); }
.rvb-faq-item.is-open .rvb-faq-q-label { background:var(--green); }
.rvb-faq-answer {
  display:none; padding:0 20px 18px 20px;
  font-size:14px; color:var(--g600); line-height:1.8;
  border-top:1px solid var(--g100);
}
@media (max-width:480px) { .rvb-faq-answer { padding:0 14px 14px; } }
.rvb-faq-item.is-open .rvb-faq-answer { display:block; }
.rvb-faq-answer p { margin-top:14px; }

/* ── RELATED CALCULATORS ── */
.rvb-related-grid {
  display:grid; grid-template-columns:repeat(auto-fill, minmax(220px,1fr));
  gap:14px; margin-top:20px;
}
@media (max-width:480px) { .rvb-related-grid { grid-template-columns:1fr; } }
.rvb-related-card {
  background:#fff; border:1.5px solid var(--g200); border-radius:var(--r);
  padding:18px; display:flex; flex-direction:column; gap:10px;
  text-decoration:none; color:inherit;
  transition:box-shadow .2s, border-color .2s, transform .15s;
  position:relative; overflow:hidden;
}
.rvb-related-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--navy); border-radius:var(--r) var(--r) 0 0; opacity:0; transition:opacity .2s; }
.rvb-related-card:hover { box-shadow:var(--sh-hover); border-color:var(--navy-l); transform:translateY(-2px); }
.rvb-related-card:hover::before { opacity:1; }
.rvb-rc-icon { width:40px; height:40px; background:var(--navy-xl); border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:20px; flex-shrink:0; }
.rvb-rc-name { font-family:'Montserrat',sans-serif; font-size:13px; font-weight:800; color:var(--g900); line-height:1.3; margin-bottom:3px; }
.rvb-rc-desc { font-size:12px; color:var(--g500); line-height:1.55; flex:1; }
.rvb-rc-footer { display:flex; align-items:center; justify-content:space-between; margin-top:auto; padding-top:8px; border-top:1px solid var(--g100); }
.rvb-rc-tag { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.5px; padding:3px 8px; border-radius:100px; background:var(--navy-xl); color:var(--navy); }
.rvb-rc-arrow { font-size:16px; color:var(--g300); transition:transform .2s, color .2s; }
.rvb-related-card:hover .rvb-rc-arrow { transform:translateX(3px); color:var(--navy); }

/* ── DISCLAIMER ── */
.rvb-disclaimer {
  background:#fff; border:1px solid var(--g200); border-radius:var(--rl);
  padding:28px 32px; box-shadow:var(--sh); margin-bottom:28px;
  display:flex; gap:20px; align-items:flex-start;
}
@media (max-width:600px) { .rvb-disclaimer { flex-direction:column; gap:14px; padding:20px 16px; } }
.rvb-disc-ico { font-size:32px; flex-shrink:0; }
.rvb-disc-body h3 { font-family:'Montserrat',sans-serif; font-size:15px; font-weight:800; color:var(--navy); margin-bottom:8px; }
.rvb-disc-body p { font-size:13px; color:var(--g600); line-height:1.75; }
.rvb-disc-body p + p { margin-top:8px; }

/* Section divider */
.rvb-divider { border:none; border-top:2px solid var(--g200); margin:32px 0; }

/* ============================================================
   RENT VS BUY: FIXED MOBILE OVERRIDE
   ============================================================ */
@media (max-width: 768px) {
  /* 1. Reset Global Containers */
  html, body {
    max-width: 100vw;
    overflow-x: hidden;
    position: relative;
  }

  .wrap, .rvb-wrap {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto !important;
    padding: 0 12px !important;
  }

  /* 2. Fix Cards and Spacing */
  .card, .rvb-card, .rvb-section-head {
    padding: 20px 15px !important;
    margin-bottom: 16px !important;
    border-radius: 12px !important;
  }

  .rvb-card-body {
    padding: 20px 0 !important; /* Remove heavy side padding */
  }

  /* 3. Force Grid Stacking */
  .grid-2, .mgrid, .igrid, .rvb-two-col, .rvb-insight-grid, .rvb-dc-result-grid {
    display: flex !important;
    flex-direction: column !important;
    gap: 15px !important;
    width: 100% !important;
  }

  /* 4. Fix Input Rows & Icons */
  .irow {
    width: 100% !important;
  }
  
  .fg label {
    font-size: 11px;
  }

  /* 5. Chart Responsiveness */
  .chart-wrap {
    height: 300px !important;
    padding: 10px !important;
    width: 100% !important;
    box-sizing: border-box;
  }

  /* 6. Fix Results Panel */
  .res-panel {
    padding: 15px !important;
    margin-top: 20px;
  }

  .kpi-main .val {
    font-size: 28px !important;
  }

  /* 7. Button Stacking */
  .btn-row {
    flex-direction: column !important;
  }
  
  .btn {
    width: 100% !important;
    justify-content: center;
  }

  /* 8. Table & Formula Fixes */
  .rvb-table-scroll {
    margin: 0 -15px; /* Bleed to edges for easier scrolling */
    padding: 0 15px;
  }

  .rvb-fb-formula {
    font-size: 15px !important;
    line-height: 1.4;
  }

  /* 9. Header Adjustments */
  .hdr {
    padding: 40px 15px 60px !important;
  }
  
  .hdr h1 {
    font-size: 26px !important;
  }
}