.logo-img {
  height: 80px;   /* increase size */
  margin-right: 10px; /* add spacing from text */
}/* ===== BioTech Mockup Match - NAV & HERO ===== */
:root{
  --bi-black:#0B0B0B;
  --bi-surface:#0F0F0F;
  --bi-gold:#D9C3A3;      /* champagne gold */
  --bi-gold-2:#C9B28E;    /* deeper gold */
  --bi-red:#E53935;
}

body{background:var(--bi-black); color:#fff;}

/* NAV */
.site-header{background:linear-gradient(180deg, rgba(11,11,11,.95), rgba(11,11,11,.75)); border-bottom:1px solid rgba(217,195,163,.14)}
.nav{padding:20px 0;}
.nav ul li a{
  color:#d8d5cf; font-weight:500; letter-spacing:.2px;
  padding:10px 12px; border-radius:999px;
}
.nav ul li a:hover{color:#fff; background:rgba(217,195,163,.10);}

/* “Get a Quote” pill */
.nav .nav-cta{
  display:inline-block;
  border-radius:999px; padding:10px 18px;
  border:1px solid rgba(217,195,163,.45);
  background:transparent; color:var(--bi-gold);
  box-shadow: 0 0 0 1px rgba(217,195,163,.05) inset;
}
.nav .nav-cta:hover{
  background:linear-gradient(135deg, var(--bi-gold), var(--bi-gold-2));
  color:#111; border-color:transparent;
}

/* HERO layout like mockup: device left, copy right */
.hero{
  padding:110px 0 80px;
  background:
    radial-gradient(65% 50% at 35% 20%, rgba(217,195,163,.14), transparent 60%),
    linear-gradient(180deg, rgba(217,195,163,.06), rgba(0,0,0,0));
}
.hero-wrap{display:grid; grid-template-columns: 1.05fr .95fr; gap:48px; align-items:center;}
@media (max-width:900px){ .hero-wrap{grid-template-columns:1fr; gap:26px;} }

/* Device image with subtle spotlight like mockup */
.hero-wrap img{
  width:100%; height:auto; border-radius:20px;
  border:1px solid rgba(217,195,163,.25);
  box-shadow:
    0 28px 60px rgba(0,0,0,.55),
    0 0 140px rgba(201,178,142,.20);
  background:#0f0f0f;
}

/* BADGE */
.badge{
  border-color:rgba(217,195,163,.35);
  color:var(--bi-gold); background:rgba(217,195,163,.06);
  padding:7px 12px; font-weight:500;
}

/* Headline & sub like mockup */
.hero h1{
  color:var(--bi-gold);
  font-size: clamp(40px, 6vw, 64px);
  line-height:1.05; margin:10px 0 10px;
}
.hero .eyebrow{color:var(--bi-gold); font-size:22px; margin:8px 0 18px; font-weight:600;}
.hero .lede{color:#dedad5; font-size:18px;}

/* Buttons: gold pill + dark pill */
.btns{display:flex; gap:14px; flex-wrap:wrap; margin-top:22px;}
.btn{
  padding:12px 22px; border-radius:999px;
  border:1px solid rgba(217,195,163,.35); background:#121212; color:#fff;
}
.btn.primary{
  border:none;
  background:linear-gradient(135deg, var(--bi-gold), var(--bi-gold-2));
  color:#111; font-weight:600;
}
.btn.ghost{
  background:transparent; color:#eae6df;
  border:1px solid rgba(217,195,163,.45);
}
.btn.ghost:hover{background:rgba(217,195,163,.10);}

/* KPI cards (row under hero image in mockup) */
.kpis{gap:16px; margin-top:26px;}
.kpis .card{
  background:#111; border:1px solid rgba(217,195,163,.18);
  border-radius:14px; padding:16px;
}
.kpis .card strong{font-size:22px; color:#fff;}
.tag{border-color:rgba(229,57,53,.35); color:var(--bi-gold); background:rgba(229,57,53,.10);}
/* --- Global resets for images & text scaling --- */
img { max-width: 100%; height: auto; }
html { -webkit-text-size-adjust: 100%; }

/* --- Header: hide the extra site title text next to the logo --- */
/* Keep custom logo, hide only any text title link */
.logo a:not(.custom-logo-link) { display:none !important; }
.custom-logo { height:60px; width:auto; }

/* --- Nav tweaks for smaller screens --- */
.nav { padding: 18px 0; }
.nav ul { display:flex; gap:22px; flex-wrap:wrap; }
@media (max-width: 900px) {
  .nav ul { gap: 12px; }
  .nav .nav-cta { display: none; } /* optional: hide pill button on small screens */
}

/* --- HERO layout & image sizing --- */
.hero { padding: 96px 0 64px; }
.hero-wrap { 
  display: grid; 
  grid-template-columns: minmax(0,560px) 1fr;  /* keep device from growing too large */
  gap: 40px; 
  align-items: center;
}
.hero-wrap img { 
  width: 100%; 
  height: auto; 
  object-fit: contain;             /* prevent “zoomed-in” look */
  border-radius: 20px;
  border: 1px solid rgba(217,195,163,.25);
  box-shadow: 0 28px 60px rgba(0,0,0,.55), 0 0 140px rgba(201,178,142,.20);
}

/* Headline & text size tuning */
.hero h1 { font-size: clamp(36px, 5.5vw, 60px); line-height: 1.06; }
.hero .lede { font-size: 18px; color: #dedad5; }

/* KPI cards */
.kpis { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 16px; margin-top: 24px; }
.kpis .card { background:#111; border:1px solid rgba(217,195,163,.18); border-radius:14px; padding:16px; }
.kpis .card strong { font-size: 22px; }

/* --- Mobile adaptations --- */
@media (max-width: 900px) {
  .hero { padding: 72px 0 44px; }
  .hero-wrap { grid-template-columns: 1fr; gap: 22px; }
  .hero h1 { font-size: clamp(28px, 8vw, 44px); }
  .hero .lede { font-size: 16px; }
  .kpis { grid-template-columns: repeat(2, minmax(0,1fr)); }
}

@media (max-width: 520px) {
  .kpis { grid-template-columns: 1fr; }
}/* Make the header menu look like the mockup */
.site-header .nav ul {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  gap: 24px !important;
  align-items: center;
}
.site-header .nav li { margin: 0; }
.site-header .nav li a {
  color: #d8d5cf; font-weight: 500; letter-spacing: .2px;
  padding: 10px 12px; border-radius: 999px;
}
.site-header .nav li a:hover { color:#fff; background: rgba(217,195,163,.10); }

/* Pill CTA on the right */
.nav .nav-cta {
  display:inline-block; padding:10px 18px; border-radius:999px;
  border:1px solid rgba(217,195,163,.45); color:#D9C3A3; background:transparent;
}
.nav .nav-cta:hover {
  background:linear-gradient(135deg,#D9C3A3,#C9B28E); color:#111; border-color:transparent;
/* Hero layout & image scaling */
.hero-wrap{display:grid;grid-template-columns:minmax(0,560px) 1fr;gap:40px;align-items:center;}
.hero-wrap img{width:100%;height:auto;object-fit:contain;border-radius:20px;border:1px solid rgba(217,195,163,.25);
  box-shadow:0 28px 60px rgba(0,0,0,.55), 0 0 140px rgba(201,178,142,.20);}

@media (max-width:900px){
  .hero-wrap{grid-template-columns:1fr;gap:22px;}
  .hero h1{font-size:clamp(28px,8vw,44px);}
.hero-wrap{
  display:grid;
  grid-template-columns:minmax(0,560px) 1fr;
  gap:40px; align-items:center;
}
.hero-wrap img{ width:100%; height:auto; object-fit:contain; }
@media (max-width:900px){
  .hero-wrap{ grid-template-columns:1fr; gap:22px; }
  .hero h1{ font-size:clamp(28px,8vw,44px); }
.hero-wrap{
  display:grid;
  grid-template-columns:minmax(0,560px) 1fr;
  gap:40px; align-items:center;
}
.hero-wrap img{ width:100%; height:auto; object-fit:contain; }
@media (max-width:900px){
  .hero-wrap{ grid-template-columns:1fr; gap:22px; }
  .hero h1{ font-size:clamp(28px,8vw,44px); }
.hero-wrap{
  display:grid;
  grid-template-columns:minmax(0,560px) 1fr;
  gap:40px; align-items:center;
}
.hero-wrap img{ width:100%; height:auto; object-fit:contain; }
@media (max-width:900px){
  .hero-wrap{ grid-template-columns:1fr; gap:22px; }
  .hero h1{ font-size:clamp(28px,8vw,44px); }
.hero-wrap{
  display:grid;
  grid-template-columns:minmax(0,560px) 1fr;
  gap:40px; align-items:center;
}
.hero-wrap img{ width:100%; height:auto; object-fit:contain; }
@media (max-width:900px){
  .hero-wrap{ grid-template-columns:1fr; gap:22px; }
  .hero h1{ font-size:clamp(28px,8vw,44px); }
.hero-wrap{
  display:grid;
  grid-template-columns:minmax(0,560px) 1fr;
  gap:40px; align-items:center;
}
.hero-wrap img{ width:100%; height:auto; object-fit:contain; }
@media (max-width:900px){
  .hero-wrap{ grid-template-columns:1fr; gap:22px; }
  .hero h1{ font-size:clamp(28px,8vw,44px); }
/* --- Make hero image blend into the dark background --- */
.hero {
  /* keep subtle gold glow behind image */
  background:
    radial-gradient(65% 50% at 35% 20%, rgba(217,195,163,.14), transparent 60%),
    linear-gradient(180deg, rgba(217,195,163,.06), rgba(0,0,0,0));
}

/* Layout */
.hero-wrap{
  display:grid;
  grid-template-columns:minmax(0,560px) 1fr;
  gap:40px; align-items:center;
}
@media (max-width:900px){
  .hero-wrap{ grid-template-columns:1fr; gap:22px; }
}

/* Image container + blending */
.hero-media { position: relative; }
.hero-media img{
  display:block;
  width:100%;
  height:auto;
  border-radius:20px;
  border:1px solid rgba(217,195,163,.18);
  box-shadow:0 28px 60px rgba(0,0,0,.55), 0 0 140px rgba(201,178,142,.20);
  /* Smooth fade to transparent edges (works on iPad Safari) */
  -webkit-mask-image: radial-gradient(120% 120% at 50% 15%, rgba(0,0,0,1) 60%, rgba(0,0,0,0) 100%);
          mask-image: radial-gradient(120% 120% at 50% 15%, rgba(0,0,0,1) 50%, rgba(0,0,0,0) 100%);
mask-image: radial-gradient(120% 120% at 50% 15%, rgba(0,0,0,1) 50%, rgba(0,0,0,0) 100%);
}

/* Optional: add a subtle bottom vignette if you want a deeper melt */
.hero-media::after{
  content:"";
  position:absolute; inset:0;
  pointer-events:none;
  background: radial-gradient(80% 60% at 50% 80%, rgba(0,0,0,.35), transparent 70%);
  border-radius:20px;
}

/* Text sizing (keeps the mockup feel) */
.hero h1{ color:#D9C3A3; font-size:clamp(36px,5.5vw,60px); line-height:1.06; }
.hero .eyebrow{ color:#D9C3A3; font-weight:600; margin:10px 0 12px; }
.hero .lede{ color:#dedad5; font-size:18px; }
	.devices-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 2rem;
  margin: 2rem 0;
}
.device-card {
  background:#fff;
  border:1px solid #eee;
  border-radius:12px;
  text-align:center;
  padding:1.5rem;
  transition:all .3s ease;
}
.device-card:hover {
  transform:translateY(-6px);
  box-shadow:0 10px 20px rgba(0,0,0,.08);
}
.device-card .thumb img {
  max-height:220px;
  margin-bottom:1rem;
  object-fit:contain;
  width: 100%;
}
.device-card .meta {
  font-size: .9rem;
  opacity: .8;
}
.device-card .cta {
  display:inline-block;
  margin-top:.5rem;
  font-weight:600;
  text-decoration: underline;
.about-bio {
  padding: 4rem 2rem;
  background: #f8f9fb;
  text-align: center;
}
.about-bio h2 {
  font-size: 2rem;
  margin-bottom: 1rem;
}
.about-bio .subhead {
  font-size: 1.2rem;
  font-weight: 500;
  margin-bottom: 1.5rem;
  color: #004466;
}
.about-bio p {
  max-width: 700px;
  margin: 0 auto 1rem;
  line-height: 1.6;
}
.about-bio ul {
  list-style: none;
  padding: 0;
  margin: 2rem auto;
  max-width: 600px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1rem;
}
.about-bio ul li {
  background: #fff;
  border: 1px solid #eee;
  border-radius: 8px;
  padding: 1rem;
}
.about-bio .btn.primary {
  display: inline-block;
  padding: 0.8rem 1.5rem;
  background: #0077aa;
  color: #fff;
  border-radius: 6px;
  text-decoration: none;
  font-weight: 600;
  transition: background .3s ease;
}
.about-bio .btn.primary:hover {
  background: #005577;
/* Add spacing below the Learn More button section */
.learn-more {
  margin-bottom: 60px;   /* default for desktop */
}

/* For tablets */
@media (max-width: 1024px) {
  .learn-more {
    margin-bottom: 40px;
  }
}

/* For mobile phones */
@media (max-width: 600px) {
  .learn-more {
    margin-bottom: 25px;
  .about-section {
  margin-bottom: 60px; /* adjust px value as needed */
.flagship-devices {
  padding-top: 150px; /* adjust as needed */
/* ===== ABOUT / LEADERSHIP ===== */
.about {
  padding: clamp(56px, 6vw, 96px) 20px;
  background: #f9fafb;
}

.about-wrap {
  max-width: 1200px;
  margin: 0 auto;
}

.about-header h2 {
  font-size: clamp(1.9rem, 3vw, 2.4rem);
  line-height: 1.15;
  color: #0b2545; /* navy */
  margin: 0 0 12px 0;
}

.about-intro {
  font-size: clamp(1.05rem, 1.4vw, 1.15rem);
  margin: 0 0 6px 0;
}

.about-support {
  margin: 0 0 28px 0;
  color: #243b53;
}

/* Leadership grid */
.leaders {
  display: grid;
  gap: 28px;
  grid-template-columns: 1fr;
  margin-top: 10px;
}

/* Side-by-side on desktop */
@media (min-width: 900px) {
  .leaders {
    grid-template-columns: 1fr 1fr;
    gap: 36px;
  }
}

.leader-card {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 18px;
  padding: 20px;
  background: #ffffff;
  border: 1px solid rgba(11,37,69,0.08);
  border-radius: 12px;
  box-shadow: 0 10px 24px rgba(0,0,0,0.04);
}

@media (min-width: 560px) {
  .leader-card {
    grid-template-columns: 140px 1fr;
    padding: 24px;
  }
}

.leader-media img {
  width: 100%;
  height: auto;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 10px;
}

.leader-name {
  font-size: 1.15rem;
  margin: 2px 0 2px 0;
  color: #0b2545;
}

.leader-title {
  margin: 0 0 8px 0;
  font-weight: 600;
  color: #3a506b;
}

.leader-bio {
  margin: 0 0 10px 0;
  line-height: 1.55;
}

.leader-quals {
  list-style: none;
  padding: 0;
  margin: 0;
}

.leader-quals li {
  position: relative;
  padding-left: 18px;
  margin: 6px 0 0 0;
}

.leader-quals li::before {
  content: "•";
  position: absolute;
  left: 0;
  top: 0;
  line-height: 1;
  color: #0b2545;
}

/* Highlights row under leaders */
.about-highlights {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px 16px;
  list-style: none;
  padding: 22px 0 0 0;
  margin: 22px 0 0 0;
  border-top: 1px solid rgba(11,37,69,0.08);
}

@media (min-width: 820px) {
  .about-highlights {
    grid-template-columns: repeat(4, 1fr);
  }
}

.about-highlights li {
  font-weight: 600;
  color: #0b2545;
/* Add spacing before Flagship Devices section */
h2:contains("Flagship Devices") {
  margin-top: 30px !important;
/* === Dropdown Menu Styling for Flagship Devices === */

/* Style the dropdown container */
.main-navigation ul ul,
#site-navigation ul ul {
  background: #111; /* dark background */
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 6px;
  padding: 8px 0;
  min-width: 220px; /* width of dropdown */
  z-index: 9999;
}

/* Remove bullets/spacing */
.main-navigation ul ul li,
#site-navigation ul ul li {
  list-style: none;
  margin: 0;
  padding: 0;
}

/* Style links inside dropdown */
.main-navigation ul ul li a,
#site-navigation ul ul li a {
  display: block;
  padding: 10px 16px;
  color: #f5f5f5; /* light text */
  text-decoration: none;
  font-weight: 500;
  font-size: 0.95rem;
}

/* Hover effect */
.main-navigation ul ul li a:hover,
#site-navigation ul ul li a:hover {
  background: #e7c79d; /* gold highlight */
  color: #111; /* dark text on hover */
  border-radius: 4px;
  transition: all 0.2s ease;
}

/* Show dropdown on hover (desktop) */
.main-navigation li:hover > ul,
#site-navigation li:hover > ul {
  display: block;
}

/* Ensure dropdowns don’t overlap badly on mobile */
/* Base: hide submenus */
.site-nav .menu .sub-menu,
.main-navigation .sub-menu,
#site-navigation .sub-menu {
  display: none;
  position: absolute;
  left: 0;
  top: 100%;
  background: #111;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 6px;
  min-width: 220px;
  padding: 8px 0;
  z-index: 9999;
}

/* Show on hover (desktop) */
.site-nav .menu li:hover > .sub-menu,
.main-navigation li:hover > .sub-menu,
#site-navigation li:hover > .sub-menu {
  display: block;
}

/* Mobile: keep them hidden, reveal on focus-within (tap) */
@media (max-width: 900px) {
  .site-nav .menu { flex-direction: column; gap: 12px; }
  .site-nav .menu > li { position: relative; }
  .site-nav .menu .sub-menu {
    position: static;      /* stack under parent */
    background: #111;
    border: 0;
    margin-top: 6px;
  }
  /* reveal submenu when parent gets focus (first tap) */
  .site-nav .menu li:focus-within > .sub-menu {
    display: block;
  }
  .site-nav .menu .sub-menu a { padding-left: 24px; }
}
}/* Basic horizontal menu */
.site-nav .menu { display: flex; gap: 24px; list-style: none; margin: 0; padding: 0; }
.site-nav .menu > li { position: relative; } /* needed for absolute submenu */

/* Hide submenu by default */
.site-nav .menu .sub-menu {
  display: none;
  position: absolute;
  left: 0;
  top: 100%;
  background: #111;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 6px;
  min-width: 220px;
  padding: 8px 0;
  z-index: 9999;
}

/* Show on hover (desktop) */
.site-nav .menu li:hover > .sub-menu { display: block; }

/* Submenu items */
.site-nav .menu .sub-menu li { list-style: none; }
.site-nav .menu .sub-menu a {
  display: block; padding: 10px 16px;
  color: #f5f5f5; text-decoration: none; font-weight: 500;
}
.site-nav .menu .sub-menu a:hover { background: #e7c79d; color: #111; border-radius: 4px; }

/* Optional: top-level link styling */
.site-nav .menu > li > a { text-decoration: none; color: #f5f5f5; font-weight: 600; }

/* Mobile: stack items and indent sub-items */
@media (max-width: 768px) {
  .site-nav .menu { flex-direction: column; gap: 12px; }
  .site-nav .menu .sub-menu { position: static; display: block; background: transparent; border: 0; padding: 0; }
  .site-nav .menu .sub-menu a { padding-left: 24px; }
}/* Basic horizontal menu */
.site-nav .menu { display: flex; gap: 24px; list-style: none; margin: 0; padding: 0; }
.site-nav .menu > li { position: relative; } /* needed for absolute submenu */

/* Hide submenu by default */
.site-nav .menu .sub-menu {
  display: none;
  position: absolute;
  left: 0;
  top: 100%;
  background: #111;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 6px;
  min-width: 220px;
  padding: 8px 0;
  z-index: 9999;
}

/* Show on hover (desktop) */
.site-nav .menu li:hover > .sub-menu { display: block; }

/* Submenu items */
.site-nav .menu .sub-menu li { list-style: none; }
.site-nav .menu .sub-menu a {
  display: block; padding: 10px 16px;
  color: #f5f5f5; text-decoration: none; font-weight: 500;
}
.site-nav .menu .sub-menu a:hover { background: #e7c79d; color: #111; border-radius: 4px; }

/* Optional: top-level link styling */
.site-nav .menu > li > a { text-decoration: none; color: #f5f5f5; font-weight: 600; }

/* Mobile: stack items and indent sub-items */
@media (max-width: 768px) {
  .site-nav .menu { flex-direction: column; gap: 12px; }
  .site-nav .menu .sub-menu { position: static; display: block; background: transparent; border: 0; padding: 0; }
  .site-nav .menu .sub-menu a { padding-left: 24px; }
}/* Basic horizontal menu */
.site-nav .menu { display: flex; gap: 24px; list-style: none; margin: 0; padding: 0; }
.site-nav .menu > li { position: relative; } /* needed for absolute submenu */

/* Hide submenu by default */
.site-nav .menu .sub-menu {
  display: none;
  position: absolute;
  left: 0;
  top: 100%;
  background: #111;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 6px;
  min-width: 220px;
  padding: 8px 0;
  z-index: 9999;
}

/* Show on hover (desktop) */
.site-nav .menu li:hover > .sub-menu { display: block; }

/* Submenu items */
.site-nav .menu .sub-menu li { list-style: none; }
.site-nav .menu .sub-menu a {
  display: block; padding: 10px 16px;
  color: #f5f5f5; text-decoration: none; font-weight: 500;
}
.site-nav .menu .sub-menu a:hover { background: #e7c79d; color: #111; border-radius: 4px; }

/* Optional: top-level link styling */
.site-nav .menu > li > a { text-decoration: none; color: #f5f5f5; font-weight: 600; }

/* Mobile: stack items and indent sub-items */
@media (max-width: 768px) {
  .site-nav .menu { flex-direction: column; gap: 12px; }
  .site-nav .menu .sub-menu { position: static; display: block; background: transparent; border: 0; padding: 0; }
  .site-nav .menu .sub-menu a { padding-left: 24px; }
}/* Force dropdown behavior for "Flagship Devices" submenu */
.site-header .site-nav .menu { 
  display: flex; 
  gap: 24px; 
  list-style: none; 
  margin: 0; 
  padding: 0;
  flex-wrap: nowrap;
}

.site-header .site-nav .menu > li {
  position: relative; /* anchor for absolute submenu */
}

/* Hide submenus by default, no matter what the theme set */
.site-header .site-nav .menu > li > ul.sub-menu {
  display: none !important;
  position: absolute;
  left: 0;
  top: calc(100% + 8px);
  background: #111;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 6px;
  min-width: 220px;
  padding: 8px 0;
  z-index: 9999;
  white-space: nowrap;
}

/* Make sure submenu items are not laid out like top-level items */
.site-header .site-nav .menu > li > ul.sub-menu > li {
  display: block !important;
  margin: 0;
}

/* Show submenu on hover/focus (desktop + keyboard) */
.site-header .site-nav .menu > li:hover > ul.sub-menu,
.site-header .site-nav .menu > li:focus-within > ul.sub-menu {
  display: block !important;
}

/* Links */
.site-header .site-nav .menu > li > ul.sub-menu a {
  display: block;
  padding: 10px 16px;
  color: #f5f5f5;
  text-decoration: none;
  font-weight: 500;
}
.site-header .site-nav .menu > li > ul.sub-menu a:hover {
  background: #e7c79d;
  color: #111;
  border-radius: 4px;
}

/* Mobile: stack menu; reveal submenu on first tap (focus) */
@media (max-width: 900px) {
  .site-header .site-nav .menu { flex-direction: column; gap: 12px; }
  .site-header .site-nav .menu > li > ul.sub-menu {
    position: static; 
    display: none !important;
    background: #111;
    border: 0;
    margin-top: 6px;
  }
  .site-header .site-nav .menu > li:focus-within > ul.sub-menu {
    display: block !important;
  }
  .site-header .site-nav .menu > li > ul.sub-menu a { padding-left: 24px; }
}.site-nav .menu { display:flex; gap:24px; list-style:none; margin:0; padding:0; }
.site-nav .menu > li { position:relative; }
.site-nav .menu > li > ul.sub-menu {
  display:none; position:absolute; left:0; top:100%;
  background:#111; border:1px solid rgba(255,255,255,.1);
  border-radius:6px; min-width:220px; padding:8px 0; z-index:9999;
}
.site-nav .menu > li:hover > ul.sub-menu,
.site-nav .menu > li:focus-within > ul.sub-menu { display:block; }
.site-nav .menu > li > ul.sub-menu a { display:block; padding:10px 16px; text-decoration:none; color:#f5f5f5; }
.site-nav .menu > li > ul.sub-menu a:hover { background:#e7c79d; color:#111; border-radius:4px; }
@media (max-width:900px){
  .site-nav .menu { flex-direction:column; gap:12px; }
  .site-nav .menu > li > ul.sub-menu { position:static; display:none; border:0; margin-top:6px; }
  .site-nav .menu > li:focus-within > ul.sub-menu { display:block; }
  .site-nav .menu > li > ul.sub-menu a { padding-left:24px; }
}/* ======== HARD OVERRIDES FOR HEADER DROPDOWN ======== */
.site-header .site-nav .menu {
  display: flex !important;
  gap: 24px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.site-header .site-nav .menu > li {
  position: relative;           /* anchor for absolute submenu */
  flex: 0 0 auto;               /* prevent theme flex rules from stretching items */
}

/* Hide submenus by default, and make sure they are NOT laid out by flex */
.site-header .site-nav .menu > li > ul.sub-menu {
  display: none !important;     /* override any theme display rules */
  position: absolute !important;
  left: 0;
  top: calc(100% + 8px);
  background: #111;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 6px;
  min-width: 220px;
  padding: 8px 0;
  z-index: 9999;
  white-space: nowrap;
}

.site-header .site-nav .menu > li > ul.sub-menu > li {
  display: block !important;    /* sub items are blocks inside dropdown */
  margin: 0;
}

.site-header .site-nav .menu > li > ul.sub-menu a {
  display: block;
  padding: 10px 16px;
  color: #f5f5f5;
  text-decoration: none;
  font-weight: 500;
}
.site-header .site-nav .menu > li > ul.sub-menu a:hover {
  background: #e7c79d;
  color: #111;
  border-radius: 4px;
}

/* Show submenu on hover & keyboard focus (desktop) */
@media (min-width: 900px) {
  .site-header .site-nav .menu > li:hover > ul.sub-menu,
  .site-header .site-nav .menu > li:focus-within > ul.sub-menu {
    display: block !important;
  }
}

/* Mobile/tablet: stack menu; reveal submenu when parent has .open */
@media (max-width: 899.98px) {
  .site-header .site-nav .menu { flex-direction: column; gap: 12px; }
  .site-header .site-nav .menu > li > ul.sub-menu {
    position: static !important;
    display: none !important;
    background: #111;
    border: 0;
    margin-top: 6px;
  }
  .site-header .site-nav .menu > li.open > ul.sub-menu {
    display: block !important;
  }
  .site-header .site-nav .menu > li > ul.sub-menu a { padding-left: 24px; }
}/* Reset menu layout */
.site-nav .menu {
  display: flex;
  gap: 24px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.site-nav .menu > li {
  position: relative;
}

/* Hide submenus by default */
.site-nav .menu > li > .sub-menu {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  background: #111;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 6px;
  padding: 8px 0;
  min-width: 220px;
  z-index: 9999;
}

.site-nav .menu > li > .sub-menu li {
  display: block;
  margin: 0;
}

.site-nav .menu > li > .sub-menu a {
  display: block;
  padding: 10px 16px;
  color: #f5f5f5;
  text-decoration: none;
  font-weight: 500;
}
.site-nav .menu > li > .sub-menu a:hover {
  background: #e7c79d;
  color: #111;
  border-radius: 4px;
}

/* Show submenu on hover / keyboard focus (desktop) */
.site-nav .menu > li:hover > .sub-menu,
.site-nav .menu > li:focus-within > .sub-menu {
  display: block;
}

/* Mobile stacking */
@media (max-width: 900px) {
  .site-nav .menu {
    flex-direction: column;
    gap: 12px;
  }
  .site-nav .menu > li > .sub-menu {
    position: static;
    display: none;
    border: 0;
    margin-top: 6px;
  }
  .site-nav .menu > li.open > .sub-menu {
    display: block;
  }
  .site-nav .menu > li > .sub-menu a {
    padding-left: 24px;
  }
}/* ===== Clinic Locator Styles ===== */

/* Base container */
.container { 
  max-width: 1200px; 
  margin: 0 auto; 
  padding: 0 20px; 
}

.locator { 
  padding: clamp(44px, 5vw, 72px) 0; 
}
.locator-header h1 { margin: 0 0 6px; }
.locator-header p { margin: 0 0 16px; opacity: .85; }

/* Filters */
.locator-filters { 
  display: grid; 
  grid-template-columns: 1fr 220px 200px auto; 
  gap: 10px; 
  align-items: center; 
}
.locator-filters input,
.locator-filters select { 
  width: 100%; 
  padding: 10px 12px; 
  border-radius: 10px; 
  border: 1px solid rgba(255,255,255,.12); 
  background: rgba(255,255,255,.04); 
  color: inherit; 
}
.locator-filters button { 
  padding: 10px 14px; 
  border-radius: 10px; 
  border: 1px solid rgba(255,255,255,.15); 
  background: transparent; 
  color: inherit; 
  cursor: pointer; 
}
@media (max-width: 780px){ 
  .locator-filters { grid-template-columns: 1fr; } 
}

/* Clinic grid */
.clinic-grid { 
  display: grid; 
  gap: 16px; 
  grid-template-columns: 1fr; 
  margin-top: 18px; 
}
@media (min-width: 760px){ 
  .clinic-grid { grid-template-columns: 1fr 1fr; } 
}
@media (min-width: 1100px){ 
  .clinic-grid { grid-template-columns: 1fr 1fr 1fr; } 
}

/* Clinic card */
.clinic-card { 
  display: grid; 
  grid-template-columns: 96px 1fr; 
  gap: 14px; 
  padding: 16px; 
  border: 1px solid rgba(255,255,255,.10); 
  border-radius: 14px; 
  background: rgba(255,255,255,.03); 
}
.clinic-media img { 
  width: 96px; 
  height: 96px; 
  object-fit: cover; 
  border-radius: 10px; 
}
.clinic-name { margin: 0 0 4px; }
.machine-tags { 
  display: flex; 
  flex-wrap: wrap; 
  gap: 6px; 
  list-style: none; 
  padding: 0; 
  margin: 4px 0 8px; 
}
.machine-tags li { 
  padding: 4px 8px; 
  border-radius: 999px; 
  border: 1px solid rgba(255,255,255,.15); 
  font-size: .85rem; 
}
.clinic-address { 
  margin: 0 0 4px; 
  font-style: normal; 
  opacity: .9; 
}
.clinic-city { 
  margin: 0 0 10px; 
  opacity: .75; 
}
.clinic-actions { 
  display: flex; 
  flex-wrap: wrap; 
  gap: 8px; 
}

/* Buttons */
.btn-primary { 
  display: inline-block; 
  padding: 10px 14px; 
  border-radius: 999px; 
  background: #e7c79d; 
  color: #111; 
  text-decoration: none; 
  font-weight: 600; 
}
.btn-outline { 
  display: inline-block; 
  padding: 10px 14px; 
  border-radius: 999px; 
  border: 1px solid rgba(255,255,255,.25); 
  text-decoration: none; 
  color: inherit; 
}
.btn-link { 
  display: inline-block; 
  padding: 8px 2px; 
  text-decoration: none; 
  opacity: .9; 
}.locator {
  scroll-margin-top: 90px;
}

html {
  scroll-behavior: smooth;
}/* ===== Clinic Locator Styles ===== */
.locator {
  padding: clamp(44px, 6vw, 72px) 0;
  max-width: 1200px;
  margin: 0 auto;
}

.locator-header {
  text-align: center;
  margin-bottom: 32px;
}

.locator-header h2 {
  font-size: 2rem;
  margin: 0 0 8px;
}

.locator-header p {
  font-size: 1rem;
  opacity: 0.8;
  margin: 0;
}

/* Grid layout */
.clinic-grid {
  display: grid;
  gap: 20px;
  grid-template-columns: 1fr;
}

@media (min-width: 768px) {
  .clinic-grid { grid-template-columns: 1fr 1fr; }
}

@media (min-width: 1100px) {
  .clinic-grid { grid-template-columns: 1fr 1fr 1fr; }
}

/* Clinic card */
.clinic-card {
  display: grid;
  grid-template-columns: 96px 1fr;
  gap: 16px;
  padding: 20px;
  border: 1px solid rgba(0,0,0,.1);
  border-radius: 12px;
  background: #fff;
  color: #111;
}

body.dark .clinic-card {
  background: rgba(255,255,255,.05);
  border-color: rgba(255,255,255,.1);
  color: #fff;
}

.clinic-media img {
  width: 96px;
  height: 96px;
  border-radius: 8px;
  object-fit: cover;
}

.clinic-name {
  margin: 0 0 6px;
  font-size: 1.1rem;
  font-weight: 600;
}

.machine-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 0 0 10px;
  padding: 0;
  list-style: none;
}

.machine-tags li {
  padding: 3px 8px;
  border: 1px solid rgba(0,0,0,.15);
  border-radius: 999px;
  font-size: .85rem;
}

.clinic-address {
  margin: 0 0 4px;
  font-style: normal;
  opacity: 0.9;
}

.clinic-city {
  margin: 0 0 12px;
  opacity: 0.7;
}

/* Buttons */
.clinic-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.clinic-actions a {
  text-decoration: none;
  font-size: .9rem;
  font-weight: 500;
}

.btn-outline {
  padding: 8px 14px;
  border-radius: 999px;
  border: 1px solid #333;
  background: transparent;
  color: #333;
}

.btn-primary {
  padding: 8px 14px;
  border-radius: 999px;
  background: #e7c79d;
  color: #111;
  font-weight: 600;
}

.btn-link {
  padding: 6px 2px;
  color: #0066cc;
}/* ===== Clinic Locator (dark theme safe) ===== */
#locator.locator {
  padding: clamp(44px, 6vw, 72px) 0;
  max-width: 1200px;
  margin: 0 auto;
}

#locator .locator-header {
  text-align: center;
  margin-bottom: 32px;
}
#locator .locator-header h2 { margin: 0 0 8px; font-size: 2rem; }
#locator .locator-header p  { margin: 0; opacity: .85; }

/* Grid */
#locator .clinic-grid {
  display: grid;
  gap: 20px;
  grid-template-columns: 1fr;
}
@media (min-width: 768px){ #locator .clinic-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1100px){ #locator .clinic-grid { grid-template-columns: 1fr 1fr 1fr; } }

/* Card */
#locator .clinic-card{
  display: grid;
  grid-template-columns: 96px 1fr;
  gap: 16px;
  padding: 18px;
  border-radius: 12px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.12);
  color: inherit;
}
#locator .clinic-media img{
  width:96px;height:96px;object-fit:cover;border-radius:8px;
}

#locator .clinic-name{ margin:0 0 6px; font-size:1.05rem; font-weight:600; }
#locator .machine-tags{ display:flex; flex-wrap:wrap; gap:6px; margin:0 0 10px; padding:0; list-style:none; }
#locator .machine-tags li{
  padding:3px 8px; border:1px solid rgba(255,255,255,.2); border-radius:999px; font-size:.85rem;
}
#locator .clinic-address{ margin:0 0 4px; font-style:normal; opacity:.9; }
#locator .clinic-city{ margin:0 0 12px; opacity:.7; }

/* Buttons + links */
#locator .clinic-actions{ display:flex; flex-wrap:wrap; gap:8px; }
#locator .clinic-actions a{ text-decoration:none; font-size:.9rem; }
#locator .btn-outline{
  padding:8px 14px; border-radius:999px; border:1px solid rgba(255,255,255,.3); color:inherit;
}
#locator .btn-primary{
  padding:8px 14px; border-radius:999px; background:#e7c79d; color:#111; font-weight:600;
}
#locator .btn-link{ padding:6px 0; color:#e7c79d; }
	/* Locator block only (won’t affect the rest of the site) */
#locator.locator { padding: clamp(44px, 6vw, 72px) 0; max-width: 1200px; margin: 0 auto; }
#locator .locator-header { text-align: center; margin-bottom: 32px; }
#locator .locator-header h2 { margin: 0 0 8px; font-size: 2rem; }
#locator .locator-header p { margin: 0; opacity: .85; }

/* Grid */
#locator .clinic-grid { display: grid; gap: 20px; grid-template-columns: 1fr; }
@media (min-width: 768px){ #locator .clinic-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1100px){ #locator .clinic-grid { grid-template-columns: 1fr 1fr 1fr; } }

/* Card */
#locator .clinic-card { display: grid; grid-template-columns: 96px 1fr; gap: 16px; padding: 18px;
  border-radius: 12px; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.12); color: inherit; }
#locator .clinic-media img { width: 96px; height: 96px; object-fit: cover; border-radius: 8px; }

/* Text + tags */
#locator .clinic-name { margin: 0 0 6px; font-size: 1.05rem; font-weight: 600; }
#locator .machine-tags { display: flex; flex-wrap: wrap; gap: 6px; margin: 0 0 10px; padding: 0; list-style: none; }
#locator .machine-tags li { padding: 3px 8px; border: 1px solid rgba(255,255,255,.2); border-radius: 999px; font-size: .85rem; }
#locator .clinic-address { margin: 0 0 4px; font-style: normal; opacity: .9; }
#locator .clinic-city { margin: 0 0 12px; opacity: .7; }

/* Links/buttons inside locator — stop the blue links */
#locator a { color: inherit; text-decoration: none; }
#locator .clinic-actions { display: flex; flex-wrap: wrap; gap: 8px; }
#locator .btn-outline { padding: 8px 14px; border-radius: 999px; border: 1px solid rgba(255,255,255,.3); color: inherit; }
#locator .btn-primary { padding: 8px 14px; border-radius: 999px; background: #e7c79d; color: #111; font-weight: 600; }
#locator .btn-link { padding: 6px 0; color: #e7c79d; }

/* Smooth anchor jump */
#locator { scroll-margin-top: 90px; }
html { scroll-behavior: smooth; }
	/* === Clinic Locator: hide the old filter UI if present === */
#locator .locator-filters,
#locator input[type="search"],
#locator select,
#locator button,
#locator .no-results {
  display: none !important;
}

/* === Locator layout & card styling (scoped) === */
#locator.locator { padding: clamp(44px, 6vw, 72px) 0; max-width: 1200px; margin: 0 auto; }
#locator .locator-header { text-align: center; margin-bottom: 32px; }
#locator .locator-header h2 { margin: 0 0 8px; font-size: 2rem; }
#locator .locator-header p { margin: 0; opacity: .85; }

#locator .clinic-grid { display: grid; gap: 20px; grid-template-columns: 1fr; }
@media (min-width: 768px){ #locator .clinic-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1100px){ #locator .clinic-grid { grid-template-columns: 1fr 1fr 1fr; } }

#locator .clinic-card { display: grid; grid-template-columns: 96px 1fr; gap: 16px; padding: 18px;
  border-radius: 12px; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.12); color: inherit; }
#locator .clinic-media img { width:96px; height:96px; object-fit:cover; border-radius:8px; }

#locator .clinic-name { margin:0 0 6px; font-size:1.05rem; font-weight:600; }
#locator .machine-tags { display:flex; flex-wrap:wrap; gap:6px; margin:0 0 10px; padding:0; list-style:none; }
#locator .machine-tags li { padding:3px 8px; border:1px solid rgba(255,255,255,.2); border-radius:999px; font-size:.85rem; }
#locator .clinic-address { margin:0 0 4px; font-style:normal; opacity:.9; }
#locator .clinic-city { margin:0 0 12px; opacity:.7; }

#locator .clinic-actions { display:flex; flex-wrap:wrap; gap:8px; }
#locator .clinic-actions a { text-decoration:none; font-size:.9rem; }
#locator .btn-outline { padding:8px 14px; border-radius:999px; border:1px solid rgba(255,255,255,.3); color:inherit; }
#locator .btn-primary { padding:8px 14px; border-radius:999px; background:#e7c79d; color:#111; font-weight:600; }
#locator .btn-link { padding:6px 0; color:#e7c79d; }

/* Keep anchor scroll nice */
#locator { scroll-margin-top: 90px; }
html { scroll-behavior: smooth; }

/* === Flagship Devices: stop blue links === */
.device-card a { color: inherit; text-decoration: none; }
.device-card a:hover .cta { text-decoration: underline; }
.device-card .cta { color: #e7c79d; }
	/* Global font reset */
body, html, p, a, li, button, input, select, textarea {
  font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI",
               Roboto, "Helvetica Neue", Arial, sans-serif !important;
  color: #f5f5f5;
  line-height: 1.6;
}

/* Headings */
h1, h2, h3, h4, h5, h6 {
  font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI",
               Roboto, "Helvetica Neue", Arial, sans-serif !important;
  font-weight: 700;
  color: #f5f5f5;
}

/* Remove ugly blue links */
a { color: inherit !important; text-decoration: none; }
a:hover { text-decoration: underline; }
	/* ==== Clinic Locator: responsive grid ==== */
/* 1 col on small screens, 2 cols on tablet, 3 on large desktop */
#locator .clinic-grid{
  display:grid;
  gap:20px;
  grid-template-columns: 1fr;                /* phones */
}
@media (min-width: 600px){
  #locator .clinic-grid{ grid-template-columns: repeat(2, 1fr); }  /* tablet */
}
@media (min-width: 1100px){
  #locator .clinic-grid{ grid-template-columns: repeat(3, 1fr); }  /* wide */
}

/* Card layout tidy-up */
#locator .clinic-card{
  display:grid;
  grid-template-columns: 96px 1fr;
  align-items:start;
  gap:16px;
  padding:18px;
  border-radius:12px;
  background: rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.12);
}
#locator .clinic-media img{ width:96px; height:96px; object-fit:cover; border-radius:8px; }

/* Spacing + links */
#locator .clinic-name{ margin:0 0 6px; font-weight:600; }
#locator .clinic-address{ margin:0 0 4px; font-style:normal; opacity:.9; }
#locator .clinic-city{ margin:0 0 10px; opacity:.75; }
#locator .clinic-actions{ display:flex; flex-wrap:wrap; gap:8px; }
#locator a{ color:inherit; text-decoration:none; }
#locator .btn-outline{ padding:8px 14px; border-radius:999px; border:1px solid rgba(255,255,255,.3); }
#locator .btn-primary{ padding:8px 14px; border-radius:999px; background:#e7c79d; color:#111; font-weight:600; }
#locator .btn-link{ padding:6px 0; color:#e7c79d; }
	/* Force the Clinic Locator into a responsive grid */
#locator .clinic-grid{
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
  gap: 24px !important;
  align-items: start !important;
}

/* Make each card fill its grid cell nicely */
#locator .clinic-card{ height: 100%; display: grid; grid-template-columns: 96px 1fr; gap: 16px; }

/* (If you still see bullets anywhere) */
#locator .machine-tags{ list-style: none; margin: 0 0 10px; padding: 0; display: flex; flex-wrap: wrap; gap: 6px; }
	.clinic-logo {
  width: 150px;      /* adjust as needed */
  height: 150px;     /* makes all boxes square */
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #222; /* optional: gives neat uniform frame */
  background: #fff;  /* keeps white background behind logos */
  margin-bottom: 15px;
}

.clinic-logo img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain; /* ensures logo fits without distortion */
}/* Grid layout */
.clinics-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 32px;
}
@media (max-width: 900px) { .clinics-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .clinics-grid { grid-template-columns: 1fr; } }

.clinic-card { display: flex; flex-direction: column; gap: 6px; }

/* Uniform logo box */
.clinic-logo {
  width: 150px;
  height: 150px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #222;
  background: #fff;
  border-radius: 6px;
  overflow: hidden;
  margin-bottom: 8px;
}
.clinic-logo img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;  /* scales without distortion */
}
.clinic-logo .logo-fallback {
  font-size: 12px;
  text-align: center;
  padding: 10px;
  color: #888;
}

/* Minor typography */
.clinic-name { margin: 0 0 2px; font-weight: 600; }
.clinic-address, .clinic-city, .clinic-phone { margin: 0; }
	/* Grid layout */
.clinics-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 32px;
}
@media (max-width: 900px) { .clinics-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .clinics-grid { grid-template-columns: 1fr; } }

.clinic-card { display: flex; flex-direction: column; gap: 6px; }

/* Uniform logo wrapper */
.clinic-logo {
  width: 150px;           /* make all boxes same size */
  height: 150px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #222; /* optional frame */
  background: #fff;
  border-radius: 6px;
  overflow: hidden;
  margin-bottom: 8px;
}
.clinic-logo img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;     /* preserve proportions */
}
.clinic-logo .logo-fallback {
  font-size: 12px;
  text-align: center;
  padding: 8px;
  color: #888;
}

/* Minor typography spacing */
.clinic-name { margin: 0 0 2px; font-weight: 600; }
.clinic-address, .clinic-city, .clinic-machines { margin: 0; }
	/* Grid layout */
.clinics-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 32px;
}
@media (max-width: 900px) { .clinics-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .clinics-grid { grid-template-columns: 1fr; } }

.clinic-card { display: flex; flex-direction: column; gap: 6px; }

/* Uniform logo wrapper */
.clinic-logo {
  width: 150px;
  height: 150px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #222;
  background: #fff;
  border-radius: 6px;
  overflow: hidden;
  margin-bottom: 8px;
}
.clinic-logo img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}
.clinic-logo .logo-fallback {
  font-size: 12px;
  text-align: center;
  padding: 8px;
  color: #888;
}

.clinic-name { margin: 0 0 2px; font-weight: 600; }
.clinic-address, .clinic-city, .clinic-machines { margin: 0; }
	/* Container */
.container { max-width: 1200px; margin: 0 auto; padding: 0 20px; }
.locator { padding: clamp(44px, 5vw, 72px) 0; }
.locator-header h1 { margin: 0 0 6px; }
.locator-header p { margin: 0 0 16px; opacity: .85; }

/* Grid */
.clinic-grid { display: grid; gap: 16px; grid-template-columns: 1fr; margin-top: 18px; }
@media (min-width: 760px){ .clinic-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1100px){ .clinic-grid { grid-template-columns: 1fr 1fr 1fr; } }

/* Card */
.clinic-card { display: grid; grid-template-columns: 96px 1fr; gap: 14px; padding: 16px; border: 1px solid rgba(255,255,255,.10); border-radius: 14px; background: rgba(255,255,255,.03); }
.clinic-media img { width: 96px; height: 96px; object-fit: cover; border-radius: 10px; }
.clinic-name { margin: 0 0 4px; }
.machine-tags { display: flex; flex-wrap: wrap; gap: 6px; list-style: none; padding: 0; margin: 4px 0 8px; }
.machine-tags li { padding: 4px 8px; border-radius: 999px; border: 1px solid rgba(255,255,255,.15); font-size: .85rem; }
.clinic-address { margin: 0 0 4px; font-style: normal; opacity: .9; }
.clinic-city { margin: 0 0 10px; opacity: .75; }
.clinic-actions { display: flex; flex-wrap: wrap; gap: 8px; }

/* Buttons */
.btn-primary { display: inline-block; padding: 10px 14px; border-radius: 999px; background: #e7c79d; color: #111; text-decoration: none; font-weight: 600; }
.btn-outline { display: inline-block; padding: 10px 14px; border-radius: 999px; border: 1px solid rgba(255,255,255,.25); text-decoration: none; color: inherit; }
.btn-link { display: inline-block; padding: 8px 2px; text-decoration: none; opacity: .9; }
	/* global fallback if your theme font isn’t loading */
body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
               Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji", sans-serif;
  line-height: 1.5;
/* Force clean, modern system font across the site */
html, body, #page, .site {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
               Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji", sans-serif !important;
  line-height: 1.5;
}/* Force Inter everywhere */
html, body, #page, .site {
  font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
               Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji", sans-serif !important;
  line-height: 1.5;
}/* Nudge WP block theme variables so body/headings inherit our choice */
:root{
  --wp--preset--font-family--system-font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji", sans-serif;
  --wp--preset--font-family--body: "Inter", var(--wp--preset--font-family--system-font);
  --wp--preset--font-family--heading: "Inter", var(--wp--preset--font-family--system-font);
}
body{ font-family: var(--wp--preset--font-family--body) !important; }
h1,h2,h3,h4,h5,h6{ font-family: var(--wp--preset--font-family--heading) !important; }
	/* ========== Flagship Devices ========== */
.section.flagship { 
  /* moves the whole block lower from the previous content */
  margin-top: 32px;
  margin-bottom: 56px; /* creates gap above Clinic Locator */
}

.flagship-head h2 {
  /* lowers the heading itself a touch */
  margin-top: 10px;
  margin-bottom: 14px;
}

.flagship-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}
@media (min-width: 760px){ .flagship-grid { grid-template-columns: 1fr 1fr 1fr; } }

/* Card */
.device-card {
  background: #121212;
  border: 1px solid rgba(217,195,163,.18);
  border-radius: var(--radius, 12px);
  padding: 16px;
}
.device-title { 
  margin: 0 0 10px; 
  font-size: 1.05rem; 
  font-weight: 600; 
}

/* Image directly under heading; fixed, consistent size */
.device-media {
  width: 100%;
  aspect-ratio: 16 / 9;        /* consistent landscape */
  background: #0f0f0f;
  border: 1px solid rgba(217,195,163,.16);
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: 10px;          /* space before "View device" link */
}
.device-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;            /* fills without distortion */
  display: block;
}

/* Link below the image */
.device-link {
  display: inline-block;
  margin-top: 4px;
  color: var(--biotech-champagne);
  text-decoration: none;
  font-weight: 600;
}
.device-link:hover { color: var(--biotech-red); }

/* Extra spacing between sections:
   adds more gap before Clinic Locator specifically */
#flagship-devices + .biotech-locator,
.section.flagship + .biotech-locator {
  margin-top: 40px;
}/* nudge heading down and add gap before Clinic Locator */
#flagship-devices { margin-top: 24px !important; margin-bottom: 72px !important; }
	.wp-block-embed-youtube,
.wp-block-embed__wrapper iframe {
  display: block;
  margin-left: auto;
  margin-right: auto;
  max-width: 100% !important;
  width: 100% !important;
  height: auto !important;
}
	/* Make hero images responsive & prevent distortion */
.hero-img img{
  width: 100%;
  height: auto;      /* keep natural proportions */
  display: block;
}

/* If you prefer a consistent, modern ratio on small screens */
@media (max-width: 640px){
  .hero-img img{
    aspect-ratio: 16 / 9;  /* keeps a nice shape on phones */
    object-fit: cover;     /* crops a bit instead of stretching */
    max-height: 70vh;      /* avoid overly tall heroes */
  }
	/* Stack button groups on small screens */
@media (max-width: 640px){
  .wp-block-buttons{display:flex;flex-wrap:wrap;gap:10px}
  .wp-block-buttons .wp-block-button{flex:1 1 100%}
  .wp-block-buttons .wp-block-button__link{display:block;width:100%;text-align:center}
}

/* Optional: tighten giant spacers on phones */
@media (max-width: 640px){
  .wp-block-spacer[style*="height:100px"],
  .wp-block-spacer[style*="height:85px"],
  .wp-block-spacer[style*="height:72px"]{height:32px !important}
/* Force top RF/Patrix-R button row to stack on mobile */
@media (max-width: 640px){
  .wp-block-buttons .wp-block-button a[href="#rf-serum"],
  .wp-block-buttons .wp-block-button a[href="#patrix-r"] {
    display:block;
    width:100%;
    text-align:center;
    margin-bottom:10px;
  }
}.container { max-width:1200px; margin:0 auto; padding:0 20px; }
.section-head .muted { opacity:.75; }
.devices-grid .grid { display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:20px; }
.device-card { border:1px solid rgba(0,0,0,.08); border-radius:12px; padding:16px; background:#fff; }
.device-card .image-wrap { display:block; border-radius:10px; overflow:hidden; margin:-16px -16px 12px; }
.device-card img { display:block; width:100%; height:auto; }
.device-card .btn { margin-top:8px; }
@media (max-width: 1024px){ .devices-grid .grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 640px){ .devices-grid .grid { grid-template-columns: 1fr; } }
	/* Add breathing space below the Custom Devices section */
.home-custom-devices .section-cta {
  margin-bottom: 48px; /* adjust 48px → 64px if you want more space */
}
	.home-custom-devices {
  padding-bottom: 64px;
/* Section spacing so it doesn't crash into the form below */
.home-custom-devices { padding: clamp(36px, 5vw, 64px) 0; margin-bottom: 56px; }
.section-head .muted { opacity: .75; }

/* 4-up grid */
.cd-grid { 
  display: grid; 
  grid-template-columns: repeat(4, minmax(0,1fr)); 
  gap: 20px; 
}

/* Card + image behaviour */
.cd-card { background: transparent; }
.cd-card .img-wrap { 
  display: block; 
  border-radius: 12px; 
  overflow: hidden; 
  aspect-ratio: 16 / 10;     /* keeps all thumbs the same shape */
  background: #111; 
}
.cd-card img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Link below each image */
.cd-card .view-link { 
  display: block; 
  text-align: center; 
  margin-top: 10px; 
}

/* Responsive */
@media (max-width: 1024px){
  .cd-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px){
  .cd-grid { grid-template-columns: 1fr; }
/* Flagship Devices grid layout */
.flagship-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr); /* 2 per row */
  gap: 40px 30px; /* vertical & horizontal spacing */
  margin-top: 40px;
  margin-bottom: 60px;
}

/* Device cards inside */
.flagship-grid article {
  background: #111;          /* optional: match your theme */
  padding: 20px;
  border-radius: 10px;
  text-align: center;
}

.flagship-grid h2,
.flagship-grid h3 {
  margin-top: 15px;
  margin-bottom: 10px;
}

/* Buttons */
.flagship-grid .btn,
.flagship-grid .learn-more,
.flagship-grid a {
  display: inline-block;
  margin-top: 15px;
}

/* Mobile responsive */
@media (max-width: 768px) {
  .flagship-grid {
    grid-template-columns: 1fr; /* stack on mobile */
  }
}/* Turn child devices into a clean grid */
.flagship-grid {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr); /* 2 per row */
  gap: 40px; /* space between cards */
  margin-top: 40px;
  margin-bottom: 60px;
}

/* Each device card */
.flagship-grid > * {
  background: #111;      /* optional, matches your dark theme */
  padding: 20px;
  border-radius: 10px;
}/* Add spacing between any child devices output by the shortcode */
.page-id-### .entry-content > * {
  margin-bottom: 40px;
/* Flagship Devices page grid setup */
.page-slug-flagship-devices .entry-content {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px 30px;
  margin-top: 40px;
  margin-bottom: 60px;
}

/* Force each device section to behave like a card */
.page-slug-flagship-devices .entry-content > * {
  background: #111; /* or match your device card background */
  padding: 20px;
  border-radius: 10px;
}

/* Title spacing */
.page-slug-flagship-devices .entry-content > * h2,
.page-slug-flagship-devices .entry-content > * h3 {
  margin-top: 1;
  margin-bottom: 15px;
}

/* Responsive: stack on smaller screens */
@media (max-width: 768px) {
  .page-slug-flagship-devices .entry-content {
    grid-template-columns: 1fr;
  /* Add space under any heading */
.wp-block-heading,
h2, h3 { 
  margin-bottom: 10px !important;
}

/* If a button group comes right after a heading, add extra gap */
.wp-block-heading + .wp-block-buttons,
h2 + .wp-block-buttons,
h3 + .wp-block-buttons {
  margin-top: 16px !important;
}

/* Also nudge single buttons if they aren't wrapped in .wp-block-buttons */
.wp-block-heading + .wp-block-button,
h2 + .wp-block-button,
h3 + .wp-block-button {
  margin-top: 16px !important;
/* Only affects the Flagship Devices page */
.flagship-page .wp-block-heading,
.flagship-page h2,
.flagship-page h3 { 
  margin-bottom: 10px !important;
}

.flagship-page .wp-block-heading + .wp-block-buttons,
.flagship-page h2 + .wp-block-buttons,
.flagship-page h3 + .wp-block-buttons,
.flagship-page .wp-block-heading + .wp-block-button,
.flagship-page h2 + .wp-block-button,
.flagship-page h3 + .wp-block-button {
  margin-top: 16px !important;
}/* --- Flagship page: add breathing room --- */

/* 1) Space under headings in page content */
.entry-content h2,
.entry-content h3 { 
  margin-bottom: 12px !important;
}

/* 2) Space above & below any “button” inside page content */
.entry-content .wp-block-buttons,
.entry-content .wp-block-button,
.entry-content a.wp-block-button__link,
.entry-content a.wp-element-button,
.entry-content a.btn,
.entry-content .btn,
.entry-content .button,
.entry-content button {
  display: inline-block;
  margin-top: 16px !important;   /* pushes button away from text above */
  margin-bottom: 16px !important;/* adds room before next heading */
}

/* 3) If your theme wraps each device in a Group block, give each block separation */
.entry-content > .wp-block-group {
  margin-bottom: 32px !important;
/* == Universal styles for our device_children_grid shortcode == */
.device-grid {
  --cols: 4;
  display: grid;
  grid-template-columns: repeat(var(--cols), minmax(0,1fr));
  gap: 24px;                      /* spacing between cards */
  margin-top: 32px;
  margin-bottom: 64px;
}
.device-grid[data-cols="1"] { --cols: 1; }
.device-grid[data-cols="2"] { --cols: 2; }
.device-grid[data-cols="3"] { --cols: 3; }
.device-grid[data-cols="4"] { --cols: 4; }

.device-card { 
  display: flex; 
  flex-direction: column;
}

.device-card .img-wrap {
  display: block;
  aspect-ratio: 16 / 10;          /* consistent hero shape */
  border-radius: 12px;
  overflow: hidden;
  background: #111;
}
.device-card .img-wrap img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}

/* Optional title (only if show_titles="true") */
.device-card .title {
  margin: 12px 0 2px;
  text-align: center;
}

/* Button spacing */
.device-card .view-link {
  display: block;
  text-align: center;
  margin-top: 10px;               /* space from image/title */
}

/* Responsive */
@media (max-width: 1024px){ .device-grid { --cols: 2; } }
@media (max-width: 640px){  .device-grid { --cols: 1; } }
	/* ===== Flagship Devices grid: keep equal card sizes, center images ===== */
.device-grid .dg-img {
  aspect-ratio: 16 / 10;           /* consistent card shape */
  display: flex;
  align-items: center;
  justify-content: center;
  background: #111;                /* background behind images */
}

.device-grid .dg-img img {
  object-fit: contain !important;  /* fit full image, no crop */
  max-height: 100%;
  max-width: 100%;
}.flagship-media img { transition: transform .25s ease; }
.flagship-card:hover .flagship-media img { transform: scale(1.02); }
	/* --- Custom Devices section --- */
.custom-devices { 
  margin: 36px 0 56px; 
}

.custom-devices .lead {
  color: var(--text-300, #cfcfcf);
  margin: 8px 0 20px;
  line-height: 1.5;
}

/* turn the broken stacked "View device" pills into a neat responsive grid */
.custom-devices .link-list {
  list-style: none;
  padding: 0;
  margin: 0 0 18px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
}

/* each item is a full-width chip button */
.custom-devices .link-list li { margin: 0; }

.custom-devices .link-list a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  text-decoration: none;
  border: 1px solid var(--border-700, #2a2a2a);
  background: rgba(255,255,255,0.04);        /* subtle on dark bg */
  border-radius: 999px;
  padding: 12px 14px;
  font-weight: 500;
  color: var(--text-100, #f5f5f5);
  transition: transform .15s ease, background .15s ease, border-color .15s ease;
}

.custom-devices .link-list a:hover,
.custom-devices .link-list a:focus-visible {
  background: rgba(255,255,255,0.08);
  border-color: var(--border-600, #3a3a3a);
  transform: translateY(-1px);
}

/* arrow always aligned to the right */
.custom-devices .link-list a .arrow {
  opacity: .85;
  font-size: 16px;
  line-height: 1;
}

/* the “View all Custom Devices” button */
.custom-devices .view-all {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  border: 1px solid var(--border-700, #2a2a2a);
  border-radius: 999px;
  padding: 10px 14px;
  color: var(--text-100, #f5f5f5);
  background: transparent;
  transition: background .15s ease, border-color .15s ease, transform .15s ease;
}

.custom-devices .view-all:hover,
.custom-devices .view-all:focus-visible {
  background: rgba(255,255,255,0.06);
  border-color: var(--border-600, #3a3a3a);
  transform: translateY(-1px);
}

/* ensure nothing overlaps the form below on small screens */
.custom-devices,
.custom-devices * { z-index: 0; }
	/* ===== Custom Devices list on Home ===== */
.home .home-custom-devices {
  margin: 40px 0 56px;
}

.home .home-custom-devices .cd-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
  margin-bottom: 28px; /* space below EMS + RF */
}

.home .home-custom-devices .cd-card {
  margin: 0;
  list-style: none;
}

.home .home-custom-devices .cd-link {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  text-decoration: none;
  border: 1px solid #2a2a2a;
  background: rgba(255,255,255,.04);
  border-radius: 999px;
  padding: 10px 14px;
  font-weight: 500;
  color: #f5f5f5;
  transition: transform .15s ease, background .15s ease, border-color .15s ease;
}

.home .home-custom-devices .cd-link:hover,
.home .home-custom-devices .cd-link:focus-visible {
  background: rgba(255,255,255,.08);
  border-color: #3a3a3a;
  transform: translateY(-1px);
}.home-flagship-devices .device-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
  list-style: none;
  padding: 0;
  margin: 0;
}
@media (max-width: 768px) {
  .home-flagship-devices .device-list {
    grid-template-columns: 1fr;
  }
}
.home-flagship-devices .device-list li h3 {
  margin: 0 0 8px;
}
.home-flagship-devices .device-list li a {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  text-decoration: none;
}.flagship .device-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
}
@media (max-width: 768px) {
  .flagship .device-grid { grid-template-columns: 1fr; }
}
	/* Hide the image only for the Facial Analysis card on the home grid */
.device-card a[href*="facial-analysis"] .thumb { display: none !important; }
	/* Hide the thumbnail block for Facial Analysis card on the home grid */
.flagship .device-card a[href*="facial-analysis"] .thumb { display: none !important; }
	.flagship .device-card a[href*="facial-analysis"] .thumb { display: none !important; }
	/* Hide hero/thumb images for ALL device cards on homepage */
.flagship .device-card .thumb {
  display: none !important;
}
	/* Brand tokens */
:root {
  --champagne: #D9C3A3;         /* primary champagne */
  --champagne-30: rgba(217,195,163,.30);
  --champagne-45: rgba(217,195,163,.45);
  --ink: #0F0F0F;               /* page bg */
  --card: #0B0B0B;              /* card bg */
}

/* Card wrapper spacing + look */
.custom-devices-list { 
  display: grid;
  gap: 16px;                     /* space between rows */
  margin: 8px 0 0;
}
.custom-devices-list .cd-item{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:14px 16px;
  border-radius:14px;
  background: var(--card);
  border:1px solid var(--champagne-30);
}

/* Title */
.custom-devices-list .cd-title{
  margin:0;
  line-height:1.2;
  font-size: clamp(18px, 2.4vw, 28px);
  color:#fff;
}

/* Button (champagne pill) */
.custom-devices-list .btn,
.custom-devices-list .btn.ghost{
  appearance:none;
  display:inline-block;
  padding:8px 16px;
  border-radius:999px;
  text-decoration:none;
  border:1px solid var(--champagne-45);
  background: transparent;
  color: var(--champagne);
  line-height:1;                 /* prevents tall buttons */
  white-space: nowrap;           /* no wrap */
}

/* Prevent overlap on narrow screens – stack title above button */
@media (max-width: 640px){
  .custom-devices-list .cd-item{
    flex-direction: column;
    align-items:flex-start;
    gap:10px;
  }
}

/* Optional: headline & box styling like your screenshot */
.section .section-head h2,
h2.entry-title, .page .entry-title {
  color:#fff;
} 
/* =========================
   Custom Devices section polish
   ========================= */
:root{
  --champagne:#E8D9B5;           /* your champagne gold */
  --ink:#0d0d0f;                  /* page bg */
  --ink-2:#151517;                /* card bg */
  --muted:#a9a9ad;                /* helper text */
}

/* Section shell */
.home-custom-devices.container,
section.home-custom-devices {
  padding: 48px 0 28px;
  margin-bottom: 64px;            /* <-- creates the gap before the next section */
  border-top: 1px solid rgba(232,217,181,.12);
  border-bottom: 1px solid rgba(232,217,181,.08);
}

/* Headline & tagline */
.home-custom-devices .section-head h2{
  margin:0 0 8px;
  line-height:1.15;
  color:#fff;
}
.home-custom-devices .section-head p{
  margin:0 0 18px;
  color: var(--muted);
}

/* Grid of items */
.home-custom-devices .cd-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
@media (min-width: 768px){
  .home-custom-devices .cd-grid{ grid-template-columns:repeat(4,1fr); gap:16px; }
}

/* Individual item card */
.home-custom-devices .cd-item{
  background: linear-gradient(180deg, rgba(232,217,181,.06), rgba(255,255,255,0));
  border:1px solid rgba(232,217,181,.25);
  border-radius:12px;
  padding:16px 14px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  min-height:64px;
}

/* Device title */
.home-custom-devices .cd-item .cd-title{
  margin:0;
  font-weight:600;
  color: var(--champagne);
  letter-spacing:.2px;
}

/* Ghost button (prevents overlap & keeps on one line) */
.home-custom-devices .cd-item .btn.ghost{
  border:1px solid var(--champagne);
  color: var(--champagne);
  padding:6px 12px;
  border-radius:999px;
  text-decoration:none;
  white-space:nowrap;         /* no wrapping / overlapping */
  font-size:14px;
  line-height:1;
  flex-shrink:0;              /* don't let the button squish */
}
.home-custom-devices .cd-item .btn.ghost:hover{
  background: var(--champagne);
  color: var(--ink);
}

/* Make sure long titles don’t collide with the button */
.home-custom-devices .cd-item .cd-title{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  max-width:75%;
}

/* Add a faint divider after the section for visual separation */
.home-custom-devices.container::after,
section.home-custom-devices::after{
  content:"";
  display:block;
  height:1px;
  background: rgba(232,217,181,.08);
  margin-top:28px;
}

/* If you’re showing the text-only list (with arrows), make it neat */
.home-custom-devices .custom-devices-list{
  display:grid;
  gap:10px;
  margin-top:10px;
}
.home-custom-devices .custom-devices-list .cd-item{
  background:transparent;
  border:1px solid rgba(232,217,181,.18);
}

/* Optional: champagne links inside the list */
.home-custom-devices a{
  color: var(--champagne);
}
.home-custom-devices a:hover{
  text-decoration:underline;
}

/* =========================
   Gap before the contact form
   ========================= */
/* Generic: push common form wrappers down a bit */
.home-custom-devices + .wpforms-container,
.home-custom-devices + .wpcf7,
.home-custom-devices + .gform_wrapper,
.home-custom-devices + section,
.home-custom-devices + .contact-card{
  margin-top: 40px;
}

/* If your request form wrapper has a known ID/class, keep this too */
#request-pricing, .request-pricing, .pricing-demo, .contact-card{
  scroll-margin-top: 80px; /* nicer anchor jump */
}	
	#custom-devices + * { margin-top: 40px !important; }