/* ── Reset ─────────────────────────────────────────────────────────── */
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
  margin: 0; padding: 0; border: 0; font-size: 100%; font: inherit; vertical-align: baseline;
}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section { display: block; }
body { font-family: 'Roboto', sans-serif; line-height: 1; }
ol, ul { list-style: none; }
blockquote, q { quotes: none; }
blockquote:before, blockquote:after, q:before, q:after { content: ''; content: none; }
table { border-collapse: collapse; border-spacing: 0; }

/* ── Base ──────────────────────────────────────────────────────────── */
body { background: #fcfcfc; }
.body-container { position: relative; }
.container { max-width: 1250px; }
h1, h2, h3, h4, h5, h6 { padding: 15px 0; font-weight: 700; }
img { font-size: 24px; font-weight: 700; }
a { font-weight: 700; color: #005a8c; text-decoration: none; }
sup { vertical-align: super; font-size: smaller; }
.accent-color { color: #005a8c; }
.bold { font-weight: 700; }
p, h1, h2, h3, h4, h5, h6, img, .listing_title, .listing_description, .cta {
  font-weight: 400; line-height: 20pt; color: #000000;
}
.fa-circle-check, .fa-times-circle { margin-right: 5px; }

/* ── Header ────────────────────────────────────────────────────────── */
.header-wrapper { background: #fff; padding: 5px 0; }
.header-content { padding: 8px 15px; }
@media (max-width: 540px) {
  .header-content { padding: 0; }
  .header-content h3 { display: none; }
  .header-content img { position: absolute; top: 15px; left: 44%; z-index: 90; width: 200px; margin-left: -75px; }
}

/* ── Hero / Title ──────────────────────────────────────────────────── */
.title-wrapper {
  position: relative;
  background-color: #9e9e9e;
  background-image: url("../images/background.webp");
  background-position: center;
  background-size: cover;
}
.hero-overlay { position: absolute; top: 0; left: 0; z-index: 0; width: 100%; height: 100%; background: #101f30; opacity: 0.8; }
.title-content { padding: 20px 0 25px; }
@media (max-width: 768px) {
  .title-content { padding: 15px 0 10px; }
  .lander-title { padding-top: 15px; }
}
@media (max-width: 540px) {
  .title-content { padding: 15px 0 10px; }
}
.lander-title { padding: 15px 0 0; font-size: 50px; color: #fff; text-align: center; font-weight: 700; opacity: 1; line-height: normal; }
@media (max-width: 540px) {
  .lander-title { padding-top: 15px; font-size: 24px; text-align: center; }
}
.lander-desc { padding-top: 10px; font-size: 18px; line-height: 24px; color: #fff; }
@media (max-width: 540px) {
  .lander-desc { padding-top: 5px; padding-bottom: 5px; font-size: 14px; }
}
.updated { color: #fff; font-size: 14px; font-weight: 400; text-align: center; margin-top: 10px; }
.updated .fa-circle-check { color: #73AD21; padding-right: 5px; font-size: 16px; }
@media (max-width: 767.98px) {
  .updated { font-size: 12px; margin-top: 10px; }
}

/* ── Author meta line ──────────────────────────────────────────────── */
.author-update-line { font-size: 13px !important; color: #666 !important; margin-bottom: 15px !important; }
.author-update-line strong { font-size: 13px !important; }

/* ── Summary ───────────────────────────────────────────────────────── */
.summary-wrapper { margin-top: 20px; }
.summary-section h2 { font-size: 24px; font-weight: bold; }
.summary-section p { font-size: 17px; line-height: 1.6 !important; margin-bottom: 15px !important; }
.summary-section p .bold { font-weight: 700; }
.summary-section .scroll-down-entry { text-decoration: underline; }
@media (min-width: 540px) {
  .summary-section .visible-mobile { display: none; }
}
@media (max-width: 540px) {
  .summary-section .visible-desktop { display: none; }
}
.summary-title { text-align: left; font-size: 24px; padding-top: 0; }
@media (max-width: 540px) {
  .summary-title { font-size: 20px; padding-bottom: 10px; line-height: 130%; }
}
.summary-subtitle { font-weight: 400; line-height: 150%; font-size: 16px; }
@media (max-width: 540px) {
  .summary-subtitle { font-size: 16px; }
}
.summary-list-base { list-style: disc; margin-left: 40px; margin-top: 30px; margin-bottom: 30px; }
@media (max-width: 540px) {
  .summary-list-base { margin-top: 20px; margin-bottom: 20px; }
}
.summary-list-base li { margin-bottom: 15px; font-size: 16px; }

/* ── Offer / Listings ──────────────────────────────────────────────── */
.offer-wrapper { padding: 0; background-color: #fcfcfc; }
@media (max-width: 540px) { .offer-wrapper { padding: 5px 0 20px; } }
#listings { margin-top: 25px; }
@media (max-width: 540px) { #listings { margin-top: 20px; } }

.provider_logo {
  width: 100%; display: flex; align-items: center; justify-content: center; min-height: 100%;
}
.provider_logo img { display: block; width: 100%; max-width: 250px; margin: 0 auto; padding: 0; }

.listing_container {
  box-sizing: border-box; padding: 20px; margin: 20px 0;
  background-color: #fff; border: solid 1px #fff; border-radius: 5px;
  box-shadow: 0 1px 3px rgba(158,158,158,0.7); transition: 0.2s;
}
.listing_container:hover { box-shadow: 0 0 7px 2px #dcdcdc; }
.highlight { position: relative; border: solid 2px #44803F; }
.highlight .cta { background: #ED8B16; }
.highlight .cta:hover { background: #44803F; }
.highlight:hover { border: solid 2px #44803F; }

span.listing_arrow { position: absolute; top: 0; left: 0; }
.listing_container.group { position: relative; }
span.listing_arrow:before {
  position: absolute; top: 0; left: 0; z-index: 1; padding: 10px; margin: -1px 0 0 -1px;
  font-size: 18px; font-weight: 700; color: #fff; text-align: center;
  content: attr(data-content); background: #b2b2b2; border-radius: 5px 0;
}
span.listing_arrow.num_1:before { background: #44803F; }
span.listing_arrow.best:before { width: 160px; }

.listing_title {
  font-size: 16px; font-weight: 700; line-height: 18px; color: #000000;
  border-bottom: #E1E1E1 1px solid; margin-bottom: 10px;
}
.listing_title .product-name { display: inline-block; padding: 0 10px 5px 0; font-size: 24px; line-height: 1.2; }

.listing_description ul { font-size: 16px; width: 48%; vertical-align: top; display: inline-block; }
.listing_description .left-ul { margin-right: 10px; width: 48%; }
@media (max-width: 1023.98px) {
  .listing_description ul, .listing_description .left-ul { width: 100%; }
}
@media (max-width: 767.98px) {
  .listing_title { margin-top: 5px; text-align: center; }
  .listing_title .product-name { width: 100%; text-align: center; display: block; }
}

.left_column { border-right: #E1E1E1 1px solid; display: flex; align-items: center; justify-content: center; }
.middle_column .fa-circle-check { color: #44803F; }
.middle_column .fa-times-circle { color: #E1523D; }
.right_column { border-left: #E1E1E1 1px solid; }
.right_column .eael-tooltip-text {
  position: relative; background-color: #E1523D; border-radius: 4px; z-index: 1; padding: 5px; margin-top: 10px;
}
.right_column .eael-tooltip-text::before {
  content: ""; position: absolute; top: -5px; left: 50%; transform: translateX(-50%);
  width: 0; height: 0; border-left: 5px solid transparent; border-right: 5px solid transparent; border-bottom: 5px solid #E1523D;
}
.right_column .eael-tooltip-text p { color: #fff; font-weight: 600; font-size: .93rem; line-height: 1.3; }

.cta { width: 100%; padding: 5px; text-align: center; background: #ED8B16; border-radius: 10px; transition: 0.3s; }
.cta a { font-weight: 700; color: #fff; text-decoration: none; text-transform: uppercase; display: block; }
.cta:hover { background: #44803F; }
.lesser-focus { opacity: 0.65; }
.black-text { color: #000000; }
.w-100 { width: 100%; }

.top_listing { position: relative; padding-top: 60px; border: 2px solid #44803F; }
.header_best { position: absolute; top: 0; left: 0; width: 100%; padding: 6px; text-transform: uppercase; background: #44803F; }
.header_best p { font-size: 20px; font-weight: 700; color: #fff; text-align: center; }
@media (max-width: 540px) { .header_best p { font-size: 16px; } }

#listings-best { margin-top: 40px; }
#listings-best .listing_arrow { margin-top: 39px; }
#listings-best .listing_arrow:before { border-radius: 0 0 5px 0; }

/* ── Rating blocks (listing cards) ────────────────────────────────── */
.listing_container .right_column .rating-block {
  display: flex; flex-direction: column; align-items: center;
}
.listing_container .right_column .rating-block .rating-holder { margin-bottom: .5rem; text-align: center; }
.listing_container .right_column .rating-block .score-text {
  font-size: 20px; color: #000; font-weight: normal; width: 100%; display: block; text-align: center;
}
.listing_container .right_column .rating-block .rating-value {
  color: #000000; font-size: 5rem; font-weight: bold; line-height: 1.2; margin: 0;
}
.listing_container .right_column .rating-block .rating-status { font-size: 1.4rem; line-height: 1.4; font-weight: 600; }
.listing_container .right_column .rating-block .rating-status span { color: #44803F; }
.listing_container .right_column .rating-block .rating-status .userraings { line-height: 1.4; font-size: 16px; font-weight: normal; color: #000; }
.listing_container .right_column .star-rating { list-style: none; padding: 0 0 0 2px; margin: 0; display: flex; }
.listing_container .right_column .star-rating li { display: inline-block; vertical-align: top; background: 0 0; }
@media (min-width: 992px) {
  .listing_container .right_column .rating-block .rating-holder { margin-bottom: .9375rem; }
}
@media (max-width: 991px) {
  .listing_container .right_column .rating-block .rating-status { font-size: 1.5rem; letter-spacing: .343915px; }
  .listing_container .right_column .rating-block .rating-value { font-size: 4rem; }
}

/* ── Star icons ────────────────────────────────────────────────────── */
.fa-star { font-size: 1.5rem; color: #ccc; cursor: pointer; transition: color 0.3s ease; margin-right: 5px; }
.fa-star.hovered { color: #f0ad4e; }
.fa-star.selected { color: #f0ad4e; }
.container .gradient-svg { position: absolute; opacity: 0; visibility: hidden; }

/* ── Content section ───────────────────────────────────────────────── */
.content-wrapper { margin-bottom: 40px; }
.content-section .post-meta { display: flex; justify-content: space-between; align-items: center; }
.content-section .post-meta p { color: #777777; }
.content-section .summary-box { padding: 15px !important; background: #fff0c7 !important; }
.content-section p { font-size: 18px; margin-bottom: 20px; }
.content-section p a { color: #005a8c; font-weight: 500; }
.content-section p.quote {
  background: #d2e7f5; color: #03204c; font-size: 1.5rem; font-weight: 500;
  padding: 30px 20px; margin-top: 30px; position: relative;
}
.content-section p.quote:after {
  content: "\f10e"; font: normal normal normal 14px/1 FontAwesome; font-size: 3.5rem;
  position: absolute; top: -25px; right: 20px; color: #03204c;
  text-rendering: auto; -webkit-font-smoothing: antialiased;
}
.content-section .img-container { display: block; }
.content-section .img-container img { display: block; margin: 0 auto; max-width: 100%; height: auto; }
.content-section .bold, strong, b { font-weight: 700; }
.content-section .checkbox-list { margin-bottom: 20px; }
.content-section .checkbox-list li { padding-left: 25px; margin-bottom: 10px; font-size: 1.125rem; color: #000000; line-height: 1.5; }
.content-section .checkbox-list li i { margin-right: 5px; color: #44803F; font-size: 1.375rem; vertical-align: middle; }
.content-section .checkbox-list li span { vertical-align: middle; }
.content-section .checkbox-list li:last-child { margin-bottom: 0; }
.content-section ol.small-list { padding-left: 40px; list-style: decimal; margin-bottom: 20px; }
.content-section ol.small-list li { padding: 3px 0; line-height: 1.5; }
.content-section ol.small-list li a { color: #005a8c; }
.content-section p video { display: block; width: 100%; height: auto; }
.content-section ul.small-list-unordered { padding-left: 40px; list-style: square; margin-bottom: 20px; }
.content-section ul.small-list-unordered li { padding: 3px 0; }
.content-section ul.small-list-unordered li a { color: #005a8c; }
.content-section .entry-important-information { border: 1px solid #c0a975; padding: 20px 15px; background: #f9ebb8; margin-bottom: 20px; }
.content-section .important-information-text { margin-bottom: 10px; }
.content-section .entry-important-information p a { color: #005a8c; font-weight: 700; }
.content-section h2 { font-size: 2.5rem; font-weight: 700; line-height: 1.5; }
@media screen and (max-width: 767px) { .content-section h2 { line-height: 1.3; font-size: 1.875rem; } }
.content-section h3 { font-size: 1.875rem; font-weight: 600; line-height: 1.5; }
.learnmore span a {
  width: 100%; margin: 10px auto; border-radius: 5px; background: #ED8B16;
  text-align: center; padding: 15px; font-size: 24px; color: #fff;
  font-weight: 600; text-decoration: none; display: block; transition: all .3s;
}
.learnmore span a:hover { background: #44803F; }
.savemore { max-width: 100%; }
.savemore p { font-size: 16px; margin-bottom: 10px; }
.savemore b { font-weight: 700; }

/* ── Author box ────────────────────────────────────────────────────── */
.author-container { display: flex; flex-wrap: wrap; background-color: #eee; padding: 15px; width: 100%; margin: auto; }
.author-container .fa-star { font-size: 14px; }
.author-avatar { flex: 0 0 65px; width: 65px; height: 65px; border-radius: 50%; overflow: hidden; margin-right: 20px; }
.author-avatar img { width: 100%; height: 100%; object-fit: cover; }
.author-details { flex: 1; }
.author-name { font-size: 18px; margin: 0; }
.author-name strong { font-weight: 700; }
.author-rating { margin: 10px 0; }
.author-profile { font-size: 16px; color: #333; }
@media (max-width: 600px) {
  .author-container { flex-direction: column; align-items: center; text-align: center; }
  .author-avatar { margin-right: 0; margin-bottom: 20px; }
  .author-details .author-rating .author-star,
  .author-details .author-rating .star-rating-wrap { display: flex; justify-content: center; align-items: center; }
  .author-details .author-rating .author-star { margin: 0 auto; }
}
.author-details .author-rating .author-star { list-style: none; padding: 0; margin: 0; display: flex; line-height: 2; }
.author-details .author-rating .author-star li { padding: 0 2px; display: inline-block; vertical-align: top; }
.author-details .author-rating .author-star .fa-star { color: #f0ad4e; }

/* ── Sidebar ───────────────────────────────────────────────────────── */
.sidebar {
  position: sticky; position: -webkit-sticky; top: 20px; box-sizing: border-box;
  padding: 20px; margin: 20px 0; background-color: #fff;
  border: solid 1px #fff; border-radius: 5px;
  box-shadow: 0 1px 3px rgba(158,158,158,0.7); transition: 0.2s;
}
@media (max-width: 767px) { .sidebar { display: none; } }
.sidebar:hover { box-shadow: 0 0 7px 2px #dcdcdc; }
.sidebar .rating-block { display: flex; flex-direction: column; align-items: center; }
.sidebar .rating-block .rating-holder { margin-bottom: .5rem; text-align: center; }
.sidebar .rating-block .score-text { font-size: 20px; margin: 0 0 18px 0; color: #000; font-weight: normal; width: 100%; display: block; text-align: center; }
.sidebar .rating-block .rating-value { color: #000000; font-size: 5rem; font-weight: bold; line-height: 1.2; margin: 0; }
.sidebar .rating-block .rating-status { font-size: 1.4rem; line-height: 1.4; font-weight: 600; }
.sidebar .rating-block .rating-status span { color: #44803F; }
.sidebar .rating-block .rating-status .userraings { line-height: 1.4; font-size: 16px; font-weight: normal; color: #000; }
.sidebar .rating-block .star-rating { list-style: none; padding: 0 0 0 12px; margin: 0; display: flex; flex-wrap: wrap; }
.sidebar .rating-block .star-rating li { display: inline-block; vertical-align: top; }

.sidebar-ratings-description { display: flex; flex-direction: row; justify-content: space-between; margin-bottom: 4px; }
.sidebar-ratings-text { color: #333; font-size: 14px; font-weight: 600; line-height: 14px; }
.sidebar-ratings-score { color: #333; font-size: 14px; font-weight: 700; line-height: 14px; }
.progress { position: relative; background-color: #e0e0e0; color: #fff; height: auto; border-radius: 2px; }
.progress-bar { display: flex; background-color: #44803F; width: 0; font-size: 11px; height: 18px; line-height: 18px; border-radius: 2px; transition: width 1s ease-in-out; }
.sidebar .listing_description ul { width: 100%; }
.sidebar .listing_description .fa-circle-check { color: #44803F; }
.sidebar .listing_description .fa-times-circle { color: #E1523D; }
.sidebar .cta { line-height: 35px; margin: 10px 0; width: 100%; padding: 5px; text-align: center; background: #ED8B16; border-radius: 10px; transition: 0.3s; }
.sidebar .cta a { font-weight: 700; color: #fff; text-decoration: none; text-transform: uppercase; display: block; }
.sidebar .cta:hover { background: #44803F; }
.sidebar h5 { padding: 5px 0; }

/* ── Footer ────────────────────────────────────────────────────────── */
.footer-wrapper { background-color: #1a212b; }
.container-fluid { max-width: 1170px; }
.footer-content { font-size: 14px; }
.footer-content .link { padding-top: 40px; padding-bottom: 20px; color: #fff; text-align: center; transition: opacity 200ms ease; }
.footer-content .link a { color: #fff; text-decoration: none; padding: 0 10px; }
.footer-content .link a:hover { color: #CCC; text-decoration: none; }
.footer-content .text { color: #959b98; text-align: center; }
.footer-content p { color: #404040; text-align: center; }
.footer-content a { font-weight: 400; color: #404040; display: inline-block; padding: 0 10px; }
.footer-content a:hover { text-decoration: underline; }
.ad-disclosure p { color: #959b98; padding: 20px 0; font-size: 8pt; font-style: italic; line-height: 14pt; word-wrap: break-word; }

/* ── Responsive overrides ──────────────────────────────────────────── */
@media (max-width: 767.98px) {
  select, input[type='text'], input[type='number'], textarea { font-size: 16px; }
  .listing_container { padding: 20px 0 0; margin: 15px 0; }
  .listing_title { color: #000; font-size: 14px; line-height: 1.4; }
  .listing_description ul { font-size: 16px; line-height: 1.5; width: 100%; display: inline-block; }
  .listing_description li { padding-top: 3px; }
  .middle_column { border: 0; }
  .left_column { border-right: 0; }
  .right_column { align-self: center; margin-top: 15px; margin-bottom: 15px; border-left: 0; }
  .rating-block { padding-top: 15px; border-top: #E1E1E1 1px solid; }
  .top_listing { padding-top: 50px; }
  .visible-desktop { display: none; }
}
@media (max-width: 414px) {
  .top_listing { padding-top: 80px; }
  #listings-best .listing_arrow { margin-top: 65px; }
}
@media (min-width: 768px) {
  .visible-mobile { display: none; }
}
