.elementor-2850 .elementor-element.elementor-element-dfb5122{--display:flex;--min-height:30px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2850 .elementor-element.elementor-element-dfb5122:not(.elementor-motion-effects-element-type-background), .elementor-2850 .elementor-element.elementor-element-dfb5122 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#2A4F7C;}.elementor-2850 .elementor-element.elementor-element-9818b2f{--display:flex;}.elementor-2850 .elementor-element.elementor-element-0e018f0{--display:flex;}.elementor-2850 .elementor-element.elementor-element-2b44bf2{--display:flex;}.elementor-2850 .elementor-element.elementor-element-74c6ade{--display:flex;--min-height:30px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2850 .elementor-element.elementor-element-74c6ade:not(.elementor-motion-effects-element-type-background), .elementor-2850 .elementor-element.elementor-element-74c6ade > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#2A4F7C;}:root{--page-title-display:none;}@media(max-width:767px){.elementor-2850 .elementor-element.elementor-element-dfb5122{--min-height:10px;--margin-top:-15px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2850 .elementor-element.elementor-element-74c6ade{--min-height:10px;--margin-top:-15px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}}/* Start custom CSS for html, class: .elementor-element-7138dc4 *//* ===============================
   PAGE HERO (Category Pages)
   Matches About page design system
   =============================== */

.ob-hero{
  background:#fff;
  padding:44px 0 28px;
  font-family:"Montserrat", sans-serif !important;
  color:#101828;
}

.ob-hero__wrap{
  width:min(1100px, calc(100% - 40px));
  margin:0 auto;
}

/* ===============================
   HEADER
   =============================== */

.ob-hero__head{
  text-align:center;
  margin:0 0 18px;
}

/* RED title */

.ob-hero__title{
  margin:0 0 12px;
  font-size:42px;
  font-weight:900;
  letter-spacing:-0.8px;
  line-height:1.05;
  color:#B3202D;
}

/* NAVY accent line */

.ob-hero__title::after{
  content:"";
  display:block;
  width:72px;
  height:3px;
  border-radius:999px;
  background:#2A4F7C;
  margin:14px auto 0;
}

/* ===============================
   INTRO TEXT
   =============================== */

.ob-hero__intro{
  margin:18px auto 0;
  max-width:880px;
}

.ob-hero__intro p{
  margin:0 0 16px;
  font-size:15.5px;
  line-height:1.9;
  color:rgba(16,24,40,0.78);
}

.ob-hero__intro p:last-child{
  margin-bottom:0;
}

/* ===============================
   RESPONSIVE
   =============================== */

@media (max-width:980px){

  .ob-hero__title{
    font-size:34px;
  }

}

@media (max-width:620px){

  .ob-hero{
    padding:36px 0 20px;
  }

  .ob-hero__title{
    font-size:30px;
  }

  .ob-hero__intro p{
    font-size:14.5px;
    line-height:1.8;
  }

}

/* ===============================
   REDUCED MOTION
   =============================== */

@media (prefers-reduced-motion: reduce){

  .ob-hero *{
    transition:none !important;
  }

}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-98baa29 *//* ===============================
   LIFESTYLE / PREMIUM TEST CARDS
   Full rebuild
=============================== */

.ob-tests{
  position:relative;
  background:#fff;
  padding:44px 0 88px;
  font-family:"Montserrat", sans-serif !important;
  overflow-x:hidden;
}

.ob-tests *{
  box-sizing:border-box;
}

.ob-tests__wrap{
  width:min(1440px, calc(100% - 40px));
  margin:0 auto;
}

/* ===============================
   SECTION HEAD
=============================== */

.ob-tests__head{
  text-align:center;
  max-width:840px;
  margin:0 auto 30px;
  padding:0 10px;
}

.ob-tests__headline{
  margin:0;
  color:#2A4F7C;
  font-size:34px;
  font-weight:850;
  line-height:1.08;
  letter-spacing:-0.04em;
}

.ob-tests__headline::after{
  content:"";
  display:block;
  width:72px;
  height:4px;
  margin:14px auto 0;
  border-radius:999px;
  background:#B3202D;
}

.ob-tests__intro{
  margin:14px auto 0;
  max-width:760px;
  color:rgba(16,24,40,0.72);
  font-size:16px;
  line-height:1.7;
  font-weight:500;
}

/* ===============================
   GRID
=============================== */

.ob-tests__grid{
  display:grid;
  gap:22px;
  padding:8px;
  align-items:stretch;
}

/* Desktop: 3 cards top, 2 wider cards below */
.ob-tests__grid--3{
  grid-template-columns:repeat(6, minmax(0, 1fr));
}

.ob-tests__grid--3 > .ob-testcard{
  grid-column:span 2;
}

/* If 5 cards total, make last 2 wider */
.ob-tests__grid--3 > .ob-testcard:nth-child(4):nth-last-child(2),
.ob-tests__grid--3 > .ob-testcard:nth-child(5):nth-last-child(1){
  grid-column:span 3;
}

/* ===============================
   CARD
=============================== */

.ob-tests--premium .ob-testcard{
  position:relative;
  display:flex;
  flex-direction:column;
  height:100%;
  min-height:100%;
  padding:14px 14px 16px;
  border-radius:24px;
  background:linear-gradient(180deg, rgba(255,255,255,0.99) 0%, rgba(251,252,255,0.98) 100%);
  border:1px solid rgba(16,24,40,0.08);
  box-shadow:
    0 10px 24px rgba(16,24,40,0.07),
    0 2px 8px rgba(16,24,40,0.04);
  overflow:hidden;
  transition:
    transform .24s ease,
    box-shadow .24s ease,
    border-color .24s ease;
}

.ob-tests--premium .ob-testcard::before{
  content:"";
  position:absolute;
  inset:0 auto 0 0;
  width:4px;
  background:linear-gradient(180deg, #B3202D 0%, #2A4F7C 100%);
  opacity:.95;
}

.ob-tests--premium .ob-testcard::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(180deg, rgba(255,255,255,0.34), transparent 38%);
}

.ob-tests--premium .ob-testcard:hover{
  transform:translateY(-5px);
  border-color:rgba(179,32,45,0.16);
  box-shadow:
    0 20px 42px rgba(16,24,40,0.12),
    0 8px 16px rgba(179,32,45,0.08);
}

.ob-tests--premium .ob-testcard--featured{
  background:linear-gradient(180deg, #fffefe 0%, #fff9fa 100%);
  border-color:rgba(179,32,45,0.16);
  box-shadow:
    0 14px 32px rgba(16,24,40,0.09),
    0 8px 16px rgba(179,32,45,0.06);
}

.ob-tests--premium .ob-testcard--featured::before{
  width:5px;
}

/* ===============================
   IMAGE
=============================== */

.ob-tests--premium .ob-testcard__media{
  position:relative;
  z-index:1;
  width:100%;
  margin:0 0 18px;
  aspect-ratio:1.55 / 1;
  border-radius:18px;
  overflow:hidden;
  background:#f4f6fa;
  box-shadow:
    inset 0 0 0 1px rgba(16,24,40,0.05),
    0 8px 18px rgba(16,24,40,0.06);
}

.ob-tests--premium .ob-testcard__image{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .45s ease;
}

.ob-tests--premium .ob-testcard:hover .ob-testcard__image{
  transform:scale(1.03);
}

/* ===============================
   TOPLINE
=============================== */

.ob-tests--premium .ob-testcard__topline{
  position:relative;
  z-index:1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  align-self:center;
  min-height:28px;
  padding:0 10px;
  margin:12px auto 10px;
  border-radius:999px;
  background:rgba(42,79,124,0.08);
  border:1px solid rgba(42,79,124,0.10);
  color:#2A4F7C;
  font-size:11px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}

/* ===============================
   TITLE
=============================== */

.ob-tests--premium .ob-testcard__title{
  position:relative;
  z-index:1;
  margin:0;
  padding:0 4px 18px;
  color:#B3202D;
  font-size:18px;
  font-weight:850;
  line-height:1.22;
  letter-spacing:-0.03em;
  text-align:center;
  text-wrap:balance;
}

.ob-tests--premium .ob-testcard__title::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:0;
  transform:translateX(-50%);
  width:32px;
  height:3px;
  border-radius:999px;
  background:#2A4F7C;
}

/* ===============================
   DESCRIPTION
=============================== */

.ob-tests--premium .ob-testcard__desc{
  position:relative;
  z-index:1;
  margin:14px 0 16px;
  color:rgba(16,24,40,0.78);
  font-size:14px;
  line-height:1.72;
}

/* ===============================
   META / BULLETS
=============================== */

.ob-tests--premium .ob-testcard__meta{
  position:relative;
  z-index:1;
  list-style:none;
  margin:0 0 14px;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:10px;
}

.ob-tests--premium .ob-testcard__meta li{
  display:flex;
  align-items:flex-start;
  gap:10px;
  color:rgba(16,24,40,0.74);
  font-size:13px;
  line-height:1.45;
  font-weight:600;
}

.ob-tests--premium .ob-testcard__meta li::before{
  content:"";
  display:block;
  width:9px;
  height:9px;
  min-width:9px;
  margin-top:4px;
  border-radius:50%;
  background:#2A4F7C;
  box-shadow:0 0 0 4px rgba(42,79,124,0.10);
  flex:0 0 9px;
}

/* ===============================
   FOOTER
=============================== */

.ob-tests--premium .ob-testcard__footer{
  position:relative;
  z-index:1;
  margin-top:auto;
  padding-top:14px;
  border-top:1px solid rgba(16,24,40,0.08);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:12px;
}

.ob-tests--premium .ob-testcard__pricewrap{
  display:flex;
  align-items:flex-end;
  justify-content:center;
  gap:6px;
}

.ob-tests--premium .ob-testcard__price-label{
  color:rgba(16,24,40,0.58);
  font-size:13px;
  font-weight:700;
  line-height:1.2;
}

.ob-tests--premium .ob-testcard__price{
  color:#B3202D;
  font-size:28px;
  font-weight:900;
  line-height:1;
  letter-spacing:-0.04em;
}

/* ===============================
   BUTTON
=============================== */

.ob-tests--premium .ob-testcard__btn{
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  min-height:46px;
  border-radius:15px;
  background:linear-gradient(180deg, #B3202D 0%, #9E1F2A 100%);
  color:#fff !important;
  text-decoration:none;
  text-align:center;
  font-size:14px;
  font-weight:800;
  letter-spacing:-0.01em;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.18),
    0 10px 20px rgba(179,32,45,0.18);
  transition:
    transform .18s ease,
    box-shadow .18s ease,
    filter .18s ease;
}

.ob-tests--premium .ob-testcard__btn:hover{
  transform:translateY(-2px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.18),
    0 14px 28px rgba(179,32,45,0.22);
  filter:saturate(1.02);
}

/* ===============================
   RESPONSIVE
=============================== */

@media (max-width:1200px){
  .ob-tests__grid--3{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }

  .ob-tests__grid--3 > .ob-testcard,
  .ob-tests__grid--3 > .ob-testcard:nth-child(4):nth-last-child(2),
  .ob-tests__grid--3 > .ob-testcard:nth-child(5):nth-last-child(1){
    grid-column:auto;
  }
}

@media (max-width:760px){
  .ob-tests{
    padding:32px 0 72px;
  }

  .ob-tests__wrap{
    width:min(1440px, calc(100% - 24px));
  }

  .ob-tests__headline{
    font-size:28px;
  }

  .ob-tests__intro{
    font-size:15px;
    line-height:1.6;
  }

  .ob-tests__grid--3{
    grid-template-columns:1fr;
    gap:16px;
    padding:4px 2px;
  }

  .ob-tests--premium .ob-testcard{
    padding:14px 14px 16px;
    border-radius:20px;
  }

  .ob-tests--premium .ob-testcard__media{
    border-radius:16px;
    aspect-ratio:1.45 / 1;
  }

  .ob-tests--premium .ob-testcard__title{
    font-size:18px;
  }

  .ob-tests--premium .ob-testcard__desc{
    font-size:14px;
    line-height:1.68;
  }
}

/* ===============================
   REDUCED MOTION
=============================== */

@media (prefers-reduced-motion: reduce){
  .ob-tests--premium .ob-testcard,
  .ob-tests--premium .ob-testcard__image,
  .ob-tests--premium .ob-testcard__btn{
    transition:none !important;
  }

  .ob-tests--premium .ob-testcard:hover,
  .ob-tests--premium .ob-testcard__btn:hover{
    transform:none !important;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-ecd5346 *//* Bottom SEO block */
.ob-seo{
  background:#fff;
  padding:34px 0 60px;
  font-family:"Montserrat",sans-serif !important;
}

.ob-seo__wrap{
  width:min(900px, calc(100% - 40px));
  margin:0 auto;
}

.ob-seo__title{
  margin:0 0 14px;
  text-align:center;

  font-size:22px;
  font-weight:850;
  color:#B3202D;
  line-height:1.2;
}

.ob-seo__title::after{
  content:"";
  display:block;
  width:64px;
  height:3px;
  border-radius:999px;
  background:#2A4F7C;
  margin:12px auto 0;
}

.ob-seo__text{
  margin:0;
  font-size:16px;
  line-height:1.8;
  color:rgba(16,24,40,0.78);
  text-align:left;
}/* End custom CSS */