@charset "utf-8";

/* ── REVIEWS PAGE STYLES ── */
/* Matches pricing/about/services design system */

/* ── HERO ── */
.rv-hero {
  background-image: linear-gradient(180deg, #779eab 0%, #ffffff 70%);
  padding: 40px 20px 50px;
  text-align: center;
}
.rv-hero-inner {
  max-width: 700px;
  margin: 0 auto;
}
.rv-eyebrow {
  font-size: 0.72rem;
  font-weight: bold;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #2b3a4b;
  margin-bottom: 8px;
}
.rv-hero h1 {
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: bold;
  color: #2b3a4b;
  margin-bottom: 12px;
  line-height: 1.15;
}
.rv-hero p {
  font-size: clamp(1rem, 1.5vw, 1.15rem);
  color: #2b3a4b;
  font-weight: bold;
  max-width: 560px;
  margin: 0 auto 24px;
  line-height: 1.5;
}
.rv-hero-btns {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 28px;
}

/* ── DYNAMIC REVIEW COUNT ── */
.rv-hero-count {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  background: rgba(255,255,255,0.7);
  border: 1px solid rgba(119,158,171,0.3);
  border-radius: 10px;
  padding: 10px 18px;
  margin-top: 8px;
}
.rv-hero-count img { flex-shrink: 0; }
.rv-hero-count-text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 3px;
}
.rv-count-num {
  font-size: 1rem;
  font-weight: bold;
  color: #2b3a4b;
  line-height: 1;
}
.rv-count-date {
  font-size: 0.72rem;
  color: #70757a;
}

/* ── STAT STRIP ── */
.rv-stats {
  background: linear-gradient(180deg, #ffffff 0%, #2b3a4b 100%);
  border-top: none;
  border-bottom: none;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.rv-stat-item {
  flex: 1;
  min-width: 130px;
  padding: 22px 16px;
  text-align: center;
  border-right: 1px solid #ffffff;
}
.rv-stat-item:last-child { border-right: none; }
.rv-stat-num {
  font-size: 1.9rem;
  font-weight: bold;
  color: #ffffff;
	text-shadow: 1px 1px 3px rgba(0,0,0,0.6);
  line-height: 1;
}
.rv-stat-label {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: rgba(255,255,255,0.7);
  text-shadow: 1px 1px 2px rgba(0,0,0,0.6);
  font-weight: bold;
  margin-top: 5px;
}

/* ── REVIEWS SECTION ── */
.rv-section {
  padding: 50px 20px;
  background: #2b3a4b;
}
.rv-section-inner {
  max-width: 1100px;
  margin: 0 auto;
}

/* ── 3-COLUMN GRID ── */
.rv-grid {
  columns: 3;
  column-gap: 24px;
  margin-bottom: 32px;
}

/* Override existing rev_box for grid layout */
.rv-grid .rev_box {
  break-inside: avoid;
  display: inline-block;
  width: 100%;
  background: #ffffff;
  border: 1px solid #d0e4ea;
  border-radius: 10px;
  padding: 20px 20px 24px;
  margin-bottom: 24px;
  box-shadow: rgba(0,0,0,0.05) 0px 3px 10px;
  color: #3c4043;
  font-size: 0.9rem;
  /* remove old border-bottom */
  border-bottom: 1px solid #d0e4ea;
}

/* ── "AS OF" DATE ── */
.rv-as-of {
  text-align: right;
  font-size: 0.78rem;
  color: #888;
  margin-bottom: 20px;
  padding-right: 4px;
}

/* ── READ MORE BUTTON ── */
.rv-more-reviews {
  text-align: center;
  margin: 10px 0 0;
}
.btn-rv-google {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: #1a73e8;
  color: #ffffff;
  font-weight: bold;
  font-size: 0.95rem;
  padding: 12px 24px;
  border-radius: 6px;
  text-decoration: none;
  transition: background 0.18s, transform 0.15s;
  box-shadow: rgba(0,0,0,0.15) 0px 3px 10px;
}
.btn-rv-google:hover {
  background: #1558b0;
  transform: translateY(-1px);
}

/* ── CTA BAND ── */
.rv-cta-band {
  background-image: linear-gradient(135deg, #779eab 0%, #5c8d9d 100%);
  color: #ffffff;
  padding: 50px 20px;
}
.rv-cta-h2 {
  font-size: clamp(1.8rem, 3vw, 2.5rem);
  font-weight: bold;
  color: #ffffff;
  margin-bottom: 10px;
  text-shadow: -1px 1px 2px rgba(0,0,0,0.25);
}
.rv-cta-sub {
  color: rgba(255,255,255,0.85);
  font-size: 0.97rem;
  max-width: 560px;
  margin: 0 auto;
  line-height: 1.7;
}

/* ── BUTTONS ── */
.btn-rv-primary {
  display: inline-block;
  background: #f9a525;
  color: #ffffff;
  font-weight: bold;
  font-size: 0.97rem;
  padding: 13px 28px;
  border-radius: 6px;
  text-decoration: none;
  text-shadow: -1px 1px 2px rgba(0,0,0,0.25);
  box-shadow: rgba(0,0,0,0.15) 0px 4px 12px;
  transition: background 0.18s, transform 0.15s;
}
.btn-rv-primary:hover { background: #e0941a; transform: translateY(-1px); }
.btn-rv-ghost {
  display: inline-block;
  background: transparent;
  color: #2b3a4b;
  font-weight: bold;
  font-size: 0.9rem;
  padding: 12px 24px;
  border-radius: 6px;
  border: 2px solid rgba(43,58,75,0.3);
  text-decoration: none;
  transition: border-color 0.18s;
}
.btn-rv-ghost:hover { border-color: rgba(43,58,75,0.6); }
.btn-rv-ghost-light {
  display: inline-block;
  background: transparent;
  color: #ffffff;
  font-weight: bold;
  font-size: 0.9rem;
  padding: 12px 24px;
  border-radius: 6px;
  border: 2px solid rgba(255,255,255,0.5);
  text-decoration: none;
  transition: border-color 0.18s, background 0.18s;
}
.btn-rv-ghost-light:hover { border-color: #ffffff; background: rgba(255,255,255,0.1); }

/* ── RESPONSIVE ── */
@media screen and (max-width: 900px) {
  .rv-grid { columns: 2; }
}
@media screen and (max-width: 560px) {
  .rv-grid { columns: 1; }
  .rv-stat-item { min-width: 110px; padding: 16px 10px; }
}

/* ── REVIEW CARD INNER STYLES ── */
/* Ported from style_reveiw-23.css so only one stylesheet is needed */

.rev_box .rev_btm_sec { padding: 10px 0 0; }
.rev_box .rev_lt_nm_ct { display: flex; padding-bottom: 10px; }
.rev_box .rev_lt_cir {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  height: 32px;
  width: 32px;
  min-width: 32px;
  color: white;
  border-radius: 50%;
}
.rev_box .rev_lt { margin: 0; color: #ffffff; font-weight: bold; }
.rev_box .rev_nm_ct { align-self: center; padding-left: 10px; line-height: 1.2; }
.rev_box .rev_nm cite { font-style: normal; font-weight: bold; }
.rev_box .rev_a { text-decoration: none; color: black; }
.rev_box .rev_a:hover { text-decoration: underline; }
.rev_box .rev_txt_color { color: #70757a; font-size: 0.82rem; }
.rev_box .review-stars { display: flex; padding: 10px 0 4px; }
.rev_box .review-via { align-self: center; padding-left: 10px; }
.rev_box .review-via p { font-size: 0.82rem; color: #70757a; }
.rev_box blockquote p { font-size: 0.88rem; line-height: 1.65; color: #3c4043; }

/* Circle colors */
.rev_cir_bg_mb  { background-color: #512da8; }
.rev_cir_bg_cs  { background-color: #004d40; }
.rev_cir_bg_kg  { background-color: mediumvioletred; }
.rev_cir_bg_jb  { background-color: #0288d1; }
.rev_cir_bg_cc  { background-color: darkslategray; }
.rev_cir_bg_em  { background-color: #00897b; }
.rev_cir_bg_jcg { background-color: #78909c; }
.rev_cir_bg_ld  { background-color: orange; }
.rev_cir_bg_sw  { background-color: #bf360c; }
.rev_cir_bg_gg  { background-color: #33691e; }
.rev_cir_bg_wa  { background-color: #7b1fa2; }
.rev_cir_bg_l   { background-color: #7e57c2; }
.rev_cir_bg_cl  { background-color: #ab47bc; }
.rev_cir_bg_jc  { background-color: #455a64; }
.rev_cir_bg_nc  { background-color: #00897b; }
.rev_cir_bg_jb  { background-color: #0288d1; }

/* Highlight effect */
.highlight {
  background: linear-gradient(90deg, rgba(247,245,11,0) 0, rgba(247,245,11,0.75) 5%, rgba(247,245,11,0.25) 95%, rgba(247,245,11,0) 100%);
  border-radius: 0.1rem;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
  display: inline;
  margin-left: -0.2em;
  margin-right: -0.2em;
  padding-left: 0.2em;
  padding-right: 0.2em;
}
