/* ==========================================================================
   PainTEQ Design System — Custom CSS
   painteq-child/assets/css/painteq-custom.css
   ========================================================================== */

/* --------------------------------------------------------------------------
   01 · CSS CUSTOM PROPERTIES (Design Tokens)
   -------------------------------------------------------------------------- */
:root {
  --pt-deep:             #002539;
  --pt-deep-2:           #0A3650;
  --pt-corporate-blue:   #16ACE3;
  --pt-mint:             #85FABC;
  --pt-ivory:            #F4F2EE;
  --pt-bone:             #E8E4DC;
  --pt-bone-white:       #F4ECDC;
  --pt-surface-white:    #FFFFFF;
  --pt-ink:              #002539;
  --pt-ink-2:            #3B5260;
  --pt-ink-3:            #6F8390;
  --pt-line:             #D6DDE2;
  --pt-line-soft:        #ECEFF2;
  --pt-info:             #16ACE3;
  --pt-success:          #15B36B;
  --pt-warning:          #F19820;
  --pt-danger:           #C8203C;
  --pt-font-display:     "Saira", "Helvetica Neue", Arial, sans-serif;
  --pt-font-body:        "Saira", "Helvetica Neue", Arial, sans-serif;
  --pt-font-serif:       "Cormorant Garamond", Georgia, serif;
  --pt-font-mono:        "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
  --pt-max-width:        1440px;
  --pt-site-pad-x:       clamp(20px, 4.4vw, 72px);
  --pt-section-pad-y:    clamp(80px, 12vw, 200px);
  --pt-radius-pill:      999px;
  --pt-shadow-sm:        0 1px 2px rgba(0,37,57,.06);
  --pt-shadow-md:        0 6px 14px -4px rgba(0,37,57,.10);
  --pt-shadow-lg:        0 18px 40px -12px rgba(0,37,57,.18);
  /* Display type scale */
  --pt-display-1: clamp(48px, 7.8vw, 144px);
  --pt-display-2: clamp(44px, 6vw, 104px);
  --pt-display-3: clamp(32px, 4vw, 68px);
  --pt-stat:      clamp(64px, 8.6vw, 140px);
  --site-pad-x:   clamp(20px, 4.4vw, 72px);
  --site-max:     1440px;
}

/* --------------------------------------------------------------------------
   02 · BASE RESETS
   -------------------------------------------------------------------------- */
html { scroll-behavior: smooth; }
body {
  margin: 0;
  padding: 0;
  font-family: var(--pt-font-body);
  font-weight: 300;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* --------------------------------------------------------------------------
   03 · LAYOUT UTILITY
   -------------------------------------------------------------------------- */
.pt-wrap {
  width: 100%;
  max-width: var(--pt-max-width);
  margin-inline: auto;
  padding-inline: var(--pt-site-pad-x);
}
.wrap {
  width: 100%;
  max-width: var(--site-max);
  margin: 0 auto;
  padding-inline: var(--site-pad-x);
}

/* --------------------------------------------------------------------------
   04 · SURFACE UTILITIES
   -------------------------------------------------------------------------- */
.surface-dark  { background-color: var(--pt-deep);          color: #fff; }
.surface-deep  { background-color: var(--pt-deep-2);        color: #fff; }
.surface-ivory { background-color: var(--pt-ivory);         color: var(--pt-ink); }
.surface-bone  { background-color: var(--pt-bone);          color: var(--pt-ink); }
.surface-white { background-color: var(--pt-surface-white); color: var(--pt-ink); }

/* --------------------------------------------------------------------------
   05 · AUDIENCE BAR
   -------------------------------------------------------------------------- */
.pt-audience-bar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 101;
  height: 38px;
  display: flex;
  align-items: center;
  background: rgba(5, 12, 18, 0.92);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.85);
  transition: transform 280ms cubic-bezier(.2,.7,.2,1), opacity 200ms;
}
.pt-audience-bar__row {
  display: flex;
  align-items: center;
  min-height: 28px;
}
.pt-audience-bar__switch {
  display: inline-flex;
  align-items: stretch;
  gap: 6px;
}
.pt-audience-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 11px 4px;
  font-family: var(--pt-font-display);
  font-size: 11.5px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: inherit;
  text-decoration: none;
  border-radius: var(--pt-radius-pill);
  border: 1px solid transparent;
  transition: background 200ms, color 200ms, border-color 200ms;
}
.pt-audience-pill__arrow {
  width: 11px;
  height: 11px;
  opacity: 0.85;
  transition: transform 240ms;
}
.pt-audience-pill--active {
  background: var(--pt-corporate-blue);
  color: var(--pt-deep);
  cursor: default;
}
.pt-audience-pill--link {
  border-color: rgba(255,255,255,0.18);
  opacity: 0.9;
}
.pt-audience-pill--link:hover {
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.32);
  opacity: 1;
}
.pt-audience-pill--link:hover .pt-audience-pill__arrow { transform: translateX(3px); }
.pt-audience-bar--hidden {
  transform: translateY(-100%);
  opacity: 0;
  pointer-events: none;
}

/* --------------------------------------------------------------------------
   06 · MAIN NAV
   -------------------------------------------------------------------------- */
.pt-nav {
  position: fixed;
  top: 38px;
  left: 0;
  right: 0;
  z-index: 100;
  padding: 22px 0;
  color: #ffffff;
  border-bottom: 1px solid transparent;
  transition: background 280ms, border-color 280ms, padding 280ms, top 280ms;
}
.pt-nav--scrolled {
  background: rgba(6, 20, 28, 0.85);
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  border-bottom-color: rgba(255,255,255,0.08);
  padding: 14px 0;
}
.pt-nav--on-light { color: var(--pt-ink); }
.pt-nav--on-light.pt-nav--scrolled {
  background: rgba(244, 242, 238, 0.88);
  border-bottom-color: rgba(0,37,57,0.08);
}
.pt-nav__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 40px;
}
.pt-nav__logo {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  color: inherit;
  text-decoration: none;
}
.pt-nav__logo-img {
  height: 26px;
  width: auto;
  max-width: none;
  flex-shrink: 0;
  display: block;
  transition: filter 280ms;
}
.pt-nav--on-light .pt-nav__logo-img {
  filter: brightness(0) saturate(100%);
}
.pt-nav__links {
  display: flex;
  align-items: center;
  gap: 36px;
  font-family: var(--pt-font-display);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.pt-nav__link {
  color: inherit;
  text-decoration: none;
  opacity: 0.85;
  transition: opacity 220ms;
}
.pt-nav__link:hover { opacity: 1; }
.pt-nav__cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--pt-font-display);
  font-size: 12.5px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: inherit;
  text-decoration: none;
  background: transparent;
  border: 1px solid currentColor;
  padding: 8px 18px 7px;
  border-radius: var(--pt-radius-pill);
  white-space: nowrap;
  transition: background 220ms, color 220ms, border-color 220ms;
}
.pt-nav__cta::after {
  content: "\2192";
  font-size: 14px;
  transition: transform 220ms;
}
.pt-nav__cta:hover {
  background: var(--pt-corporate-blue);
  border-color: var(--pt-corporate-blue);
  color: var(--pt-deep);
}
.pt-nav__cta:hover::after { transform: translateX(3px); }

/* --------------------------------------------------------------------------
   07 · MOBILE HAMBURGER
   -------------------------------------------------------------------------- */
.pt-nav__toggle {
  display: none;
  width: 44px;
  height: 44px;
  background: transparent;
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 6px;
  padding: 0;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 5px;
  color: inherit;
  transition: background 220ms, border-color 220ms;
}
.pt-nav--on-light .pt-nav__toggle { border-color: rgba(0,37,57,0.18); }
.pt-nav__toggle-bar {
  display: block;
  width: 18px;
  height: 1.5px;
  background: currentColor;
  transition: transform 240ms cubic-bezier(.5,.1,.25,1), opacity 200ms;
  transform-origin: center;
}
.pt-nav--open .pt-nav__toggle { background: rgba(255,255,255,0.06); }
.pt-nav--on-light.pt-nav--open .pt-nav__toggle { background: rgba(0,37,57,0.06); }
.pt-nav--open .pt-nav__toggle-bar:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.pt-nav--open .pt-nav__toggle-bar:nth-child(2) { opacity: 0; }
.pt-nav--open .pt-nav__toggle-bar:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* --------------------------------------------------------------------------
   08 · MOBILE DRAWER
   -------------------------------------------------------------------------- */
.pt-nav__mobile {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: rgba(0,37,57,0.97);
  backdrop-filter: blur(20px) saturate(140%);
  border-bottom: 1px solid rgba(255,255,255,0.10);
  max-height: 0;
  overflow: hidden;
  transition: max-height 320ms cubic-bezier(.5,.1,.25,1);
  color: #fff;
}
.pt-nav--on-light .pt-nav__mobile {
  background: rgba(244,242,238,0.97);
  border-bottom-color: rgba(0,37,57,0.10);
  color: var(--pt-ink);
}
.pt-nav--open .pt-nav__mobile { max-height: 80vh; }
.pt-nav__mobile-inner {
  display: flex;
  flex-direction: column;
  padding: 8px 0 20px;
}
.pt-nav__mobile-link {
  display: flex;
  align-items: baseline;
  gap: 16px;
  padding: 18px 4px;
  font-family: var(--pt-font-display);
  font-size: 22px;
  font-weight: 400;
  letter-spacing: -0.01em;
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  transition: opacity 200ms, padding-left 220ms;
}
.pt-nav--on-light .pt-nav__mobile-link { border-bottom-color: rgba(0,37,57,0.08); }
.pt-nav__mobile-link:hover { opacity: 0.75; padding-left: 8px; }
.pt-nav__mobile-num {
  font-family: var(--pt-font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.08em;
  opacity: 0.5;
  min-width: 24px;
}
.pt-nav__mobile-cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  align-self: flex-start;
  margin-top: 20px;
  padding: 12px 20px;
  background: var(--pt-corporate-blue);
  color: var(--pt-deep);
  border-radius: var(--pt-radius-pill);
  font-family: var(--pt-font-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 600;
  text-decoration: none;
}

/* --------------------------------------------------------------------------
   09 · RESPONSIVE
   -------------------------------------------------------------------------- */
@media (max-width: 880px) {
  .pt-nav__links  { display: none; }
  .pt-nav__cta    { display: none; }
  .pt-nav__toggle { display: inline-flex; }
  .pt-nav__mobile { display: block; }
}
@media (max-width: 600px) {
  .pt-audience-bar__row { justify-content: flex-end; }
  .pt-audience-pill { padding: 4px 9px 3px; font-size: 10.5px; }
}

/* --------------------------------------------------------------------------
   10 · EYEBROW
   -------------------------------------------------------------------------- */
.eyebrow {
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: var(--pt-font-body);
  font-size: 11.5px;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  line-height: 1.2;
}
.eyebrow::before {
  content: "";
  display: block;
  width: 28px;
  height: 1px;
  background-color: currentColor;
  flex-shrink: 0;
}

/* --------------------------------------------------------------------------
   11 · BUTTONS
   -------------------------------------------------------------------------- */
.btn-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 28px;
  border: 1px solid currentColor;
  border-radius: var(--pt-radius-pill);
  font-family: var(--pt-font-body);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  transition: all 0.3s ease;
  background: transparent;
  color: inherit;
}
.btn-pill:hover {
  background-color: var(--pt-corporate-blue);
  border-color: var(--pt-corporate-blue);
  color: var(--pt-deep);
}

/* --------------------------------------------------------------------------
   12 · SCROLL REVEAL
   -------------------------------------------------------------------------- */
.pt-reveal {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 720ms ease, transform 720ms ease;
  transition-delay: var(--pt-reveal-delay, 0ms);
}
.pt-reveal.pt-in {
  opacity: 1;
  transform: translateY(0);
}
@media (prefers-reduced-motion: reduce) {
  .pt-reveal { opacity: 1; transform: none; transition: none; }
}

/* --------------------------------------------------------------------------
   13 · GRAVITY FORMS RESTYLE (placeholder - Phase 2)
   -------------------------------------------------------------------------- */

/* ==========================================================================
   PAGE WRAPPER RESETS
   ========================================================================== */
html, body {
  margin: 0 !important;
  padding: 0 !important;
  overflow-x: hidden;
}
.site {
  padding: 0 !important;
  margin: 0 !important;
}
.site-main,
#content,
.page-content {
  margin: 0 !important;
  padding: 0 !important;
}
.elementor-section-wrap > .elementor-section:first-child,
.elementor-top-section:first-child {
  margin-top: 0 !important;
}
main#content {
  display: block;
  margin: 0;
  padding: 0;
}
.elementor-location-header,
.elementor-location-footer {
  position: relative;
  z-index: auto;
}
main#content {
  padding-top: 96px;
}

/* ==========================================================================
   H2 CLINICIAN NAV — always visible (dark bg from top)
   ========================================================================== */
body.page-id-3628 #pt-nav {
  background: rgba(6,20,28,0.72) !important;
}
body.page-id-3628 #pt-nav.pt-nav--scrolled {
  background: rgba(6,20,28,0.92) !important;
}
body.page-id-3624 #pt-nav {
  background: rgba(6,20,28,0.72) !important;
}
body.page-id-3624 #pt-nav.pt-nav--scrolled {
  background: rgba(6,20,28,0.92) !important;
}

/* ==========================================================================
   CLINICIAN HERO — Section #top
   ========================================================================== */

/* Hero must fill from very top — override 96px push */
body.page-id-3628 main#content {
  padding-top: 0 !important;
}

/* serif-italic accent */
.serif-italic {
  font-family: "Cormorant Garamond", "Times New Roman", serif;
  font-style: italic;
  font-weight: 400;
  letter-spacing: -0.01em;
}

/* Hero shell */
.pt-hero-cln {
  position: relative;
  min-height: 100vh;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  background: var(--pt-deep);
}
.pt-hero-cln__canvas {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}
.pt-hero-cln__tint {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(120% 80% at 80% 30%, rgba(133,250,188,0.05) 0%, transparent 55%),
    radial-gradient(80% 60% at 20% 90%, rgba(22,172,227,0.06) 0%, transparent 60%),
    linear-gradient(180deg, #002539 0%, #001A29 100%);
}
.pt-hero-cln__grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size: 96px 96px;
  -webkit-mask-image: radial-gradient(60% 80% at 80% 50%, black, transparent 75%);
  mask-image: radial-gradient(60% 80% at 80% 50%, black, transparent 75%);
}
.pt-hero-cln__grain {
  position: absolute;
  inset: 0;
  opacity: 0.35;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns%3D%27http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%27 width%3D%27180%27 height%3D%27180%27%3E%3Cfilter id%3D%27n%27%3E%3CfeTurbulence type%3D%27fractalNoise%27 baseFrequency%3D%270.9%27 numOctaves%3D%272%27 stitchTiles%3D%27stitch%27%2F%3E%3CfeColorMatrix values%3D%270 0 0 0 0.6 0 0 0 0 0.7 0 0 0 0 0.8 0 0 0 0.55 0%27%2F%3E%3C%2Ffilter%3E%3Crect width%3D%27180%27 height%3D%27180%27 filter%3D%27url(%23n)%27%2F%3E%3C%2Fsvg%3E");
}
.pt-hero-cln__anatomy {
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.pt-hero-cln__anatomy-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: right center;
  opacity: 0.72;
  display: block;
  -webkit-mask-image:
    linear-gradient(to right, transparent 0%, transparent 30%, rgba(0,0,0,0.15) 44%, rgba(0,0,0,0.55) 56%, rgba(0,0,0,0.85) 66%, black 78%),
    linear-gradient(to bottom, transparent 0%, transparent 4%, rgba(0,0,0,0.35) 20%, rgba(0,0,0,0.75) 30%, black 42%);
  -webkit-mask-composite: destination-in;
  mask-image:
    linear-gradient(to right, transparent 0%, transparent 30%, rgba(0,0,0,0.15) 44%, rgba(0,0,0,0.55) 56%, rgba(0,0,0,0.85) 66%, black 78%),
    linear-gradient(to bottom, transparent 0%, transparent 4%, rgba(0,0,0,0.35) 20%, rgba(0,0,0,0.75) 30%, black 42%);
  mask-composite: intersect;
}
@media (max-width: 900px) {
  .pt-hero-cln__anatomy-img {
    opacity: 0.42;
    object-position: center;
    -webkit-mask-image: linear-gradient(to bottom, transparent 0%, rgba(0,0,0,0.4) 30%, black 60%);
    mask-image: linear-gradient(to bottom, transparent 0%, rgba(0,0,0,0.4) 30%, black 60%);
  }
}
.pt-hero-cln__traq-hex {
  position: absolute;
  transform: translate(-50%, -50%) scale(0.55);
  opacity: 0;
  pointer-events: none;
  display: block;
}
.pt-hero-cln__traq-hex.is-on {
  animation:
    ptClinicianTraqHexIn 900ms cubic-bezier(0.2,0.7,0.3,1) 700ms forwards,
    ptClinicianTraqHexPulse 4.5s ease-in-out 1800ms infinite;
}
@keyframes ptClinicianTraqHexIn {
  to { opacity: 1; transform: translate(-50%,-50%) scale(1); }
}
@keyframes ptClinicianTraqHexPulse {
  0%,100% { filter: drop-shadow(0 0 6px rgba(64,196,255,0.25)); transform: translate(-50%,-50%) scale(1); }
  50% { filter: drop-shadow(0 0 22px rgba(64,196,255,0.95)) drop-shadow(0 0 44px rgba(64,196,255,0.45)); transform: translate(-50%,-50%) scale(1.05); }
}
.pt-hero-cln__hex-ring {
  position: absolute;
  transform: translate(-50%,-50%);
  opacity: 0;
  pointer-events: none;
  overflow: visible;
}
.pt-hero-cln__hex-ring.is-on {
  animation: ptClinicianHexRipple 4.5s cubic-bezier(0.25,0.55,0.35,1) 2050ms infinite;
}
.pt-hero-cln__hex-ring--2.is-on { animation-delay: 4300ms; }
@keyframes ptClinicianHexRipple {
  0%   { opacity: 0; transform: translate(-50%,-50%) scale(0.92); }
  10%  { opacity: 0.5; }
  100% { opacity: 0; transform: translate(-50%,-50%) scale(2.5); }
}
@media (prefers-reduced-motion: reduce) {
  .pt-hero-cln__traq-hex { opacity: 1; transform: translate(-50%,-50%) scale(1); }
  .pt-hero-cln__traq-hex.is-on { animation: none; }
  .pt-hero-cln__hex-ring, .pt-hero-cln__hex-ring.is-on { animation: none; opacity: 0; }
}
.pt-hero-cln__content {
  position: relative;
  z-index: 2;
  width: 100%;
  padding-block: 20vh 7vh;
  color: #ffffff;
}
.pt-hero-cln__scroll-wrap {
  display: flex;
  margin-top: clamp(80px,12vh,160px);
}
.pt-hero-cln__scroll {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  font-family: var(--pt-font-display);
  font-size: 10.5px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  opacity: 0.55;
  color: #ffffff;
}
.pt-hero-cln__scroll-line {
  width: 1px;
  height: 56px;
  background: linear-gradient(to bottom, transparent, currentColor, transparent);
  position: relative;
  overflow: hidden;
}
.pt-hero-cln__scroll-line::after {
  content: "";
  position: absolute;
  inset: 0;
  background: currentColor;
  animation: ptScrollPulse 2.6s cubic-bezier(.4,.7,.4,1) infinite;
}
@keyframes ptScrollPulse {
  0%   { transform: translateY(-100%); }
  60%  { transform: translateY(100%); }
  100% { transform: translateY(100%); }
}

/* Elementor widget style overrides inside #top */
body.page-id-3628 #top .elementor-widget-heading .elementor-heading-title {
  font-family: Bahnschrift, "Saira", "Helvetica Neue", Arial, sans-serif !important;
  font-weight: 400 !important;
  letter-spacing: -0.04em !important;
  line-height: 0.92 !important;
  color: #ffffff !important;
  max-width: 14ch;
  text-wrap: balance;
}
body.page-id-3628 #top .elementor-widget-text-editor p {
  font-family: Bahnschrift, "Saira", "Helvetica Neue", Arial, sans-serif !important;
  font-size: clamp(18px,1.55vw,24px) !important;
  line-height: 1.45 !important;
  font-weight: 300 !important;
  opacity: 0.78;
  color: #ffffff;
  max-width: 44ch;
  margin: 0;
}
body.page-id-3628 #top .elementor-button-wrapper { margin-top: 48px; }
body.page-id-3628 #top .elementor-button {
  font-family: var(--pt-font-display) !important;
  font-size: 13.5px !important;
  font-weight: 500 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  border-radius: 999px !important;
  border: 1px solid rgba(255,255,255,0.9) !important;
  background: transparent !important;
  color: #ffffff !important;
  padding: 16px 30px !important;
  transition: background 220ms, border-color 220ms, color 220ms !important;
}
body.page-id-3628 #top .elementor-button:hover {
  background: var(--pt-corporate-blue) !important;
  border-color: var(--pt-corporate-blue) !important;
  color: var(--pt-deep) !important;
}

/* --------------------------------------------------------------------------
   LEGAL PAGES (Privacy Policy + Terms of Use)
   -------------------------------------------------------------------------- */
.pt-legal h2 {
  font-family: Bahnschrift,'Saira','Helvetica Neue',Arial,sans-serif;
  font-size: clamp(1.1rem, 2vw, 1.4rem);
  font-weight: 600;
  color: #002539;
  margin: 40px 0 12px;
  letter-spacing: -0.01em;
}
.pt-legal h3 {
  font-family: Bahnschrift,'Saira','Helvetica Neue',Arial,sans-serif;
  font-size: 1rem;
  font-weight: 600;
  color: #002539;
  margin: 32px 0 10px;
}
.pt-legal p {
  font-family: 'Saira', sans-serif;
  font-size: 15px;
  line-height: 1.75;
  color: #3B5260;
  margin: 0 0 20px;
}
.pt-legal ul {
  font-family: 'Saira', sans-serif;
  font-size: 15px;
  line-height: 1.75;
  color: #3B5260;
  margin: 0 0 20px;
  padding-left: 24px;
}
.pt-legal ul li { margin-bottom: 8px; }
.pt-legal a { color: #16ACE3; text-decoration: none; }
.pt-legal a:hover { text-decoration: underline; }
.pt-legal hr {
  border: none;
  border-top: 1px solid rgba(0,37,57,0.10);
  margin: 40px 0;
}



/* Apply section reasons */
.car-apply-reasons{margin-top:36px;border-top:1px solid rgba(255,255,255,.12);padding-top:8px}
.car-apply-reason{padding:20px 0;border-bottom:1px solid rgba(255,255,255,.10)}
.car-apply-reason:last-child{border-bottom:none}
.car-apply-reason-num{font-family:"JetBrains Mono",monospace;font-size:11px;font-weight:500;letter-spacing:.14em;color:#16ACE3;margin:0 0 8px}
.car-apply-reason-title{font-family:Bahnschrift,"Saira","Helvetica Neue",Arial,sans-serif;font-size:16px;font-weight:700;color:#fff;margin:0 0 6px}
.car-apply-reason-body{font-family:"Saira","Helvetica Neue",Arial,sans-serif;font-size:13px;font-weight:300;line-height:1.6;color:rgba(255,255,255,.65);margin:0}
/* Reduce textarea height */
.car-form-card .gform_wrapper.gravity-theme textarea{min-height:72px !important;max-height:96px !important;height:96px !important;resize:vertical}

/* ============================================================
   CAREERS PAGE - Form S4 Styles (page 4271)
   ============================================================ */
.car-apply-wrap{max-width:1440px;margin:0 auto;padding:clamp(72px,9vw,140px) clamp(20px,4.4vw,72px);display:grid;grid-template-columns:1fr 1fr;gap:clamp(48px,6vw,96px);align-items:start}
.car-apply-eyebrow{font-family:"JetBrains Mono",monospace;font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:#16ACE3;margin:0 0 20px}
.car-apply-h2{font-family:Bahnschrift,"Saira","Helvetica Neue",Arial,sans-serif;font-size:clamp(28px,3.2vw,46px);font-weight:700;line-height:1.1;color:#fff;margin:0 0 20px}
.car-apply-h2 em{font-family:"Cormorant Garamond",Georgia,serif;font-style:italic;font-weight:500;color:#16ACE3}
.car-apply-body{font-family:"Saira","Helvetica Neue",Arial,sans-serif;font-size:clamp(14px,1.1vw,16px);font-weight:300;line-height:1.75;color:rgba(255,255,255,.72);margin:0 0 16px}
.car-apply-body a{color:#16ACE3;text-decoration:none;border-bottom:1px solid rgba(22,172,227,.4)}
.car-apply-body a:hover{border-color:#16ACE3}
.car-apply-body:last-of-type{margin-bottom:0}
.car-form-card{background:#fff;border-radius:6px;padding:clamp(28px,3vw,44px)}
.car-form-card-title{font-family:Bahnschrift,"Saira","Helvetica Neue",Arial,sans-serif;font-size:22px;font-weight:700;color:#002539;margin:0 0 6px}
.car-form-card-sub{font-family:"Saira","Helvetica Neue",Arial,sans-serif;font-size:14px;font-weight:300;color:#3B5260;margin:0 0 24px}
.car-form-card-sub span{color:#16ACE3}
.car-form-card .gform_required_legend{display:none}
/* GF native 12-col grid — fields use layoutGridColumnSpan */
.car-form-card .gform_wrapper.gravity-theme .gform_fields{display:grid;grid-template-columns:repeat(12,1fr);gap:14px 20px}
.car-form-card .gform_wrapper.gravity-theme .gfield{grid-column:span 12}
.car-form-card .gform_wrapper.gravity-theme .gfield--width-half{grid-column:span 6}
.car-form-card .gform_wrapper.gravity-theme .gfield--width-third{grid-column:span 4}
.car-form-card .gform_wrapper.gravity-theme .gfield--width-full{grid-column:span 12}
/* Fallback by column span attribute */
.car-form-card .gform_wrapper.gravity-theme [class*="gfield--width"]{}

.car-form-card .gform_wrapper.gravity-theme .gfield label.gfield_label{font-family:"JetBrains Mono",monospace;font-size:10px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:#3B5260;margin-bottom:6px;display:block}
.car-form-card .gform_wrapper.gravity-theme .gfield_required{color:#16ACE3;margin-left:2px}
.car-form-card .gform_wrapper.gravity-theme input:not([type=radio]):not([type=checkbox]):not([type=submit]):not([type=file]),
.car-form-card .gform_wrapper.gravity-theme select,
.car-form-card .gform_wrapper.gravity-theme textarea{font-family:"Saira","Helvetica Neue",Arial,sans-serif;font-size:14px;font-weight:300;border:1px solid #E8E4DC;border-radius:6px;padding:11px 14px;color:#002539;background:#fff;width:100%;box-sizing:border-box;transition:border-color .2s,box-shadow .2s;-webkit-appearance:none;appearance:none}
.car-form-card .gform_wrapper.gravity-theme input:focus,
.car-form-card .gform_wrapper.gravity-theme select:focus,
.car-form-card .gform_wrapper.gravity-theme textarea:focus{outline:none;border-color:#16ACE3;box-shadow:0 0 0 3px rgba(22,172,227,.15)}
.car-form-card .gform_wrapper.gravity-theme textarea{min-height:120px;resize:vertical}
.car-form-card .gform_wrapper.gravity-theme #field_13_10 .gfield_consent_label{font-family:"Saira","Helvetica Neue",Arial,sans-serif;font-size:13px;font-weight:300;color:#3B5260;line-height:1.5}
.car-form-card .gform_wrapper.gravity-theme #field_13_10 .gfield_consent_label a{color:#16ACE3;text-decoration:none;border-bottom:1px solid rgba(22,172,227,.3)}
.car-form-card .gform_wrapper.gravity-theme #field_13_10 .gfield_consent_label a:hover{border-color:#16ACE3}
.car-form-card .gform_wrapper.gravity-theme #field_13_10 input[type=checkbox]{width:16px;height:16px;accent-color:#16ACE3;flex-shrink:0;margin-top:0;vertical-align:middle;position:relative;top:0}
.car-form-card .gform_wrapper.gravity-theme #field_13_10 .ginput_container_consent{display:flex;align-items:center;gap:10px}
.car-form-card .gform_wrapper.gravity-theme #field_13_10 .gfield_consent_label{margin:0;line-height:1.4}
.car-form-card .gform_wrapper.gravity-theme .gfield_description{font-family:"Saira","Helvetica Neue",Arial,sans-serif;font-size:12px;color:#6F8390;margin-top:4px}
.car-form-card .gform_wrapper.gravity-theme .gform_footer{margin-top:28px;padding-top:0}
.car-form-card .gform_wrapper.gravity-theme input[type=submit]{font-family:Bahnschrift,"Saira","Helvetica Neue",Arial,sans-serif;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:#002539;color:#fff;border:none;border-radius:999px;padding:14px 40px;cursor:pointer;transition:background .25s}
.car-form-card .gform_wrapper.gravity-theme input[type=submit]:hover{background:#16ACE3}
.car-form-card .gform_confirmation_message{font-family:"Saira","Helvetica Neue",Arial,sans-serif;font-size:15px;color:#002539;padding:24px 0;text-align:center}
@media(max-width:960px){.car-apply-wrap{grid-template-columns:1fr}}
@media(max-width:600px){.car-form-card .gform_wrapper.gravity-theme .gform_fields{grid-template-columns:1fr}}

/* ---- Careers photo grid (S3) native image widgets ---- */
#car-photos-right.e-con { display:grid !important; grid-template-columns:repeat(2,1fr); gap:10px; }
#car-photos-right.e-con > .e-con-inner { display:contents; }
.car-photo-img-widget .elementor-image { margin:0; }
.car-photo-img-widget img { width:100% !important; height:210px !important; object-fit:cover !important; border-radius:6px !important; display:block !important; transition:transform .5s ease; }
.car-photo-img-widget img:hover { transform:scale(1.03); }
@media(max-width:768px){
  #car-photos-sec.e-con { flex-direction:column !important; }
  #car-photos-right.e-con { grid-template-columns:repeat(2,1fr); }
}


/* ============================================================
   CONTACT MODAL - Light white-card theme override
   ============================================================ */
.pt-modal__box{background:#ffffff !important;box-shadow:0 24px 64px rgba(0,0,0,0.35) !important;max-width:510px !important;padding:36px 36px 40px !important;}
.pt-modal__close{background:rgba(0,37,57,0.06) !important;border:1px solid rgba(0,37,57,0.12) !important;color:#002539 !important;}
.pt-modal__close:hover{background:rgba(0,37,57,0.14) !important;}
.pt-modal__title{color:#002539 !important;}
.pt-modal__sub{color:#6F8390 !important;}
#pt-contact-modal .gform_required_legend{display:none !important;}
#pt-contact-modal .gform_wrapper.gravity-theme .gform_fields{display:grid !important;grid-template-columns:repeat(12,1fr) !important;gap:14px 20px !important;}
#pt-contact-modal .gform_wrapper.gravity-theme .gfield{grid-column:span 12;}
#pt-contact-modal .gform_wrapper.gravity-theme .gfield--width-half{grid-column:span 6 !important;}
#pt-contact-modal .gform_wrapper.gravity-theme .gfield--width-full{grid-column:span 12 !important;}
#pt-contact-modal .gform_wrapper.gravity-theme .gfield label.gfield_label{font-family:JetBrains Mono,monospace !important;font-size:10px !important;font-weight:500 !important;letter-spacing:0.14em !important;text-transform:uppercase !important;color:#3B5260 !important;margin-bottom:6px !important;}
#pt-contact-modal .gform_wrapper.gravity-theme .gfield_required{color:#16ACE3 !important;}
#pt-contact-modal .gform_wrapper.gravity-theme input:not([type=radio]):not([type=checkbox]):not([type=submit]):not([type=file]),
#pt-contact-modal .gform_wrapper.gravity-theme select,
#pt-contact-modal .gform_wrapper.gravity-theme textarea{background:#ffffff !important;border:1px solid #E8E4DC !important;border-radius:6px !important;color:#002539 !important;font-weight:300 !important;}
#pt-contact-modal .gform_wrapper.gravity-theme input:focus,
#pt-contact-modal .gform_wrapper.gravity-theme select:focus,
#pt-contact-modal .gform_wrapper.gravity-theme textarea:focus{border-color:#16ACE3 !important;box-shadow:0 0 0 3px rgba(22,172,227,.15) !important;background:#ffffff !important;}
#pt-contact-modal .gform_wrapper.gravity-theme textarea{min-height:80px !important;}
#pt-contact-modal .gform_wrapper.gravity-theme .gfield_consent_label{color:#3B5260 !important;}
#pt-contact-modal .gform_wrapper.gravity-theme .gfield_consent_label a{color:#16ACE3 !important;}
#pt-contact-modal .ginput_container_consent{display:flex !important;align-items:center !important;gap:10px !important;}
#pt-contact-modal .ginput_container_consent input[type=checkbox]{margin:0 !important;accent-color:#16ACE3;}
#pt-contact-modal .gform_wrapper.gravity-theme .gform_footer{margin-top:20px !important;}
#pt-contact-modal .gform_wrapper input[type=submit],
#pt-contact-modal .gform_wrapper button[type=submit]{background:#002539 !important;color:#ffffff !important;border-radius:999px !important;font-size:12px !important;font-weight:700 !important;letter-spacing:.1em !important;text-transform:uppercase !important;padding:14px 40px !important;border:none !important;}
#pt-contact-modal .gform_wrapper input[type=submit]:hover,
#pt-contact-modal .gform_wrapper button[type=submit]:hover{background:#16ACE3 !important;color:#002539 !important;}
#pt-contact-modal .gform_confirmation_message{color:#002539 !important;text-align:center !important;}
@media(max-width:600px){.pt-modal__box{padding:28px 20px 32px !important;} #pt-contact-modal .gform_wrapper.gravity-theme .gfield--width-half{grid-column:span 12 !important;}}
#pt-contact-modal .gform_wrapper.gravity-theme textarea{min-height:70px !important;max-height:90px !important;height:90px !important;}
#pt-contact-modal .gform_wrapper input[type=submit]:hover,
#pt-contact-modal .gform_wrapper button[type=submit]:hover{background:#16ACE3 !important;color:#002539 !important;}
/* MODAL CHECKBOX ALIGN - consent + marketing opt-in */
#pt-contact-modal .gform_wrapper.gravity-theme .ginput_container_consent,
#pt-contact-modal .gform_wrapper.gravity-theme .gfield_checkbox .gchoice{display:flex !important;align-items:flex-start !important;gap:10px !important;}
#pt-contact-modal .gform_wrapper.gravity-theme .ginput_container_consent input[type=checkbox],
#pt-contact-modal .gform_wrapper.gravity-theme .gfield_checkbox input[type=checkbox]{width:16px !important;height:16px !important;margin:2px 0 0 0 !important;accent-color:#16ACE3;flex-shrink:0;}
#pt-contact-modal .gform_wrapper.gravity-theme .ginput_container_consent label,
#pt-contact-modal .gform_wrapper.gravity-theme .gfield_checkbox label{font-family:"Saira",sans-serif !important;font-size:13px !important;font-weight:300 !important;text-transform:none !important;letter-spacing:0 !important;color:#3B5260 !important;line-height:1.5 !important;margin:0 !important;text-align:left !important;}
#pt-contact-modal .gform_wrapper.gravity-theme .gfield_checkbox .gchoice label a,
#pt-contact-modal .gform_wrapper.gravity-theme .ginput_container_consent label a{color:#16ACE3 !important;text-decoration:none;}
/* Consent/marketing field labels (the bold heading) - keep small mono */
#pt-contact-modal .gform_wrapper.gravity-theme .gfield--type-consent > .gfield_label,
#pt-contact-modal .gform_wrapper.gravity-theme .gfield--type-checkbox > .gfield_label{font-family:"JetBrains Mono",monospace !important;font-size:10px !important;font-weight:500 !important;letter-spacing:0.14em !important;text-transform:uppercase !important;color:#3B5260 !important;margin-bottom:10px !important;}
/* CAREERS FORM WIDTH - narrower card */
.car-form-card{max-width:100%;width:100%;}
@media(max-width:960px){.car-form-card{max-width:100%;}}
/* MODAL FIELDSET RESET - remove border box around consent/marketing + tighten gap */
#pt-contact-modal .gform_wrapper.gravity-theme fieldset.gfield,
#pt-contact-modal .gform_wrapper.gravity-theme .gfield--type-consent,
#pt-contact-modal .gform_wrapper.gravity-theme .gfield--type-checkbox{border:none !important;padding:0 !important;margin:0 !important;}
#pt-contact-modal .gform_wrapper.gravity-theme .gfield--type-consent legend.gfield_label,
#pt-contact-modal .gform_wrapper.gravity-theme .gfield--type-checkbox legend.gfield_label{padding:0 !important;}
/* Tighten checkbox-to-label gap */
#pt-contact-modal .gform_wrapper.gravity-theme .ginput_container_consent,
#pt-contact-modal .gform_wrapper.gravity-theme .gfield_checkbox .gchoice{gap:8px !important;}
#pt-contact-modal .gform_wrapper.gravity-theme .gfield_checkbox .gchoice input[type=checkbox]{margin:2px 0 0 0 !important;}
/* MODAL CHECKBOX SPACING - remove gap between marketing + consent */
#pt-contact-modal .gform_wrapper.gravity-theme .gfield--type-checkbox{margin-bottom:0 !important;}
#pt-contact-modal .gform_wrapper.gravity-theme .gfield--type-consent{margin-top:0 !important;}
#pt-contact-modal .gform_wrapper.gravity-theme .gform_fields{row-gap:14px !important;}
/* HIDDEN FIELD GRID FIX - stop hidden fields occupying grid rows */
#pt-contact-modal .gform_wrapper.gravity-theme .gfield--type-hidden,
#pt-contact-modal .gform_wrapper.gravity-theme .gform_hidden,
#pt-contact-modal .gform_wrapper.gravity-theme input[type=hidden]{display:none !important;grid-column:1 !important;height:0 !important;margin:0 !important;padding:0 !important;}
.car-form-card .gform_wrapper.gravity-theme .gfield--type-hidden{display:none !important;}
/* MODAL COMPACT - reduce field heights so form fits without scroll */
#pt-contact-modal .gform_wrapper.gravity-theme .gform_fields{row-gap:10px !important;}
#pt-contact-modal .gform_wrapper.gravity-theme input:not([type=radio]):not([type=checkbox]):not([type=submit]):not([type=file]),
#pt-contact-modal .gform_wrapper.gravity-theme select{padding:8px 12px !important;font-size:13px !important;}
#pt-contact-modal .gform_wrapper.gravity-theme .gfield label.gfield_label{margin-bottom:3px !important;font-size:9px !important;}
#pt-contact-modal .gform_wrapper.gravity-theme textarea{min-height:56px !important;height:56px !important;padding:8px 12px !important;font-size:13px !important;}
#pt-contact-modal .gform_wrapper.gravity-theme .gform_footer{margin-top:14px !important;}
#pt-contact-modal .gform_wrapper.gravity-theme input[type=submit]{padding:12px 36px !important;}
.pt-modal__box{padding:32px 36px 36px !important;}
.pt-modal__title{font-size:22px !important;margin-bottom:18px !important;}
/* ============================================================
   CLINICIAN TOOL FLOAT ANIMATION (procedure section)
   Tools bob gently by default, pause on hover
   ============================================================ */
@keyframes ptToolFloat {
  0%   { transform: translateY(0); }
  50%  { transform: translateY(-12px); }
  100% { transform: translateY(0); }
}
.tool-step .ts-photo img {
  animation: ptToolFloat 4s ease-in-out infinite;
  will-change: transform;
}
/* Stagger each tool so they do not bob in unison */
.tool-step:nth-child(1) .ts-photo img { animation-delay: 0s; }
.tool-step:nth-child(2) .ts-photo img { animation-delay: 0.6s; }
.tool-step:nth-child(3) .ts-photo img { animation-delay: 1.2s; }
.tool-step:nth-child(4) .ts-photo img { animation-delay: 1.8s; }
.tool-step:nth-child(5) .ts-photo img { animation-delay: 2.4s; }
/* Pause the float when hovering that tool card */
.tool-step:hover .ts-photo img {
  animation-play-state: paused;
}
@media (prefers-reduced-motion: reduce) {
  .tool-step .ts-photo img { animation: none; }
}
/* ============================================================
   HERO HEX FLASH FIX - hide hex/rings until JS positions them
   ============================================================ */
.hero-traq-hex, .hero-hex-ring {
  opacity: 0 !important;
  transition: opacity 0.4s ease 0.1s;
}
.hero-anatomy.pt-hex-ready .hero-traq-hex,
.hero-anatomy.pt-hex-ready .hero-hex-ring {
  opacity: 1 !important;
}

/* ============================================================
   PATIENT FORM GRID (Form 12 - .ns-gf-wrap)
   ============================================================ */
.ns-gf-wrap .gform_wrapper.gravity-theme .gform_required_legend{display:none !important;}
.ns-gf-wrap .gform_wrapper.gravity-theme .gform_fields{display:grid !important;grid-template-columns:repeat(12,1fr) !important;gap:8px 12px !important;}
.ns-gf-wrap .gform_wrapper.gravity-theme .gfield{grid-column:span 12;}
.ns-gf-wrap .gform_wrapper.gravity-theme .gfield--width-half{grid-column:span 6 !important;}
.ns-gf-wrap .gform_wrapper.gravity-theme .gfield--width-full{grid-column:span 12 !important;}
/* Hide hidden fields so they don't create grid gaps */
.ns-gf-wrap .gform_wrapper.gravity-theme .gfield--type-hidden{display:none !important;}
/* Labels */
.ns-gf-wrap .gform_wrapper.gravity-theme .gfield label.gfield_label{font-family:"JetBrains Mono",monospace !important;font-size:10px !important;font-weight:500 !important;letter-spacing:.14em !important;text-transform:uppercase !important;color:#3B5260 !important;margin-bottom:3px !important;display:block;}
.ns-gf-wrap .gform_wrapper.gravity-theme .gfield_required{color:#16ACE3 !important;margin-left:2px;}
/* Inputs */
.ns-gf-wrap .gform_wrapper.gravity-theme input:not([type=radio]):not([type=checkbox]):not([type=submit]):not([type=file]),
.ns-gf-wrap .gform_wrapper.gravity-theme select,
.ns-gf-wrap .gform_wrapper.gravity-theme textarea{font-family:"Saira",sans-serif !important;font-size:13px !important;font-weight:300 !important;border:1px solid #E8E4DC !important;border-radius:6px !important;padding:7px 12px !important;color:#002539 !important;background:#fff !important;width:100% !important;box-sizing:border-box !important;transition:border-color .2s,box-shadow .2s !important;}
.ns-gf-wrap .gform_wrapper.gravity-theme input:focus,
.ns-gf-wrap .gform_wrapper.gravity-theme select:focus,
.ns-gf-wrap .gform_wrapper.gravity-theme textarea:focus{border-color:#16ACE3 !important;box-shadow:0 0 0 3px rgba(22,172,227,.15) !important;outline:none !important;}
.ns-gf-wrap .gform_wrapper.gravity-theme textarea{min-height:52px !important;height:52px !important;resize:none !important;}
/* Consent + checkbox alignment */
.ns-gf-wrap .gform_wrapper.gravity-theme .ginput_container_consent,
.ns-gf-wrap .gform_wrapper.gravity-theme .gfield_checkbox .gchoice{display:flex !important;align-items:flex-start !important;gap:8px !important;}
.ns-gf-wrap .gform_wrapper.gravity-theme .ginput_container_consent input[type=checkbox],
.ns-gf-wrap .gform_wrapper.gravity-theme .gfield_checkbox input[type=checkbox]{width:16px !important;height:16px !important;margin:2px 0 0 0 !important;accent-color:#16ACE3;flex-shrink:0;}
.ns-gf-wrap .gform_wrapper.gravity-theme fieldset.gfield{border:none !important;padding:0 !important;margin:0 !important;}
/* Submit */
.ns-gf-wrap .gform_wrapper.gravity-theme .gform_footer{margin-top:12px !important;padding-top:0 !important;}
.ns-gf-wrap .gform_wrapper input[type=submit],
.ns-gf-wrap .gform_wrapper button[type=submit]{font-family:Bahnschrift,"Saira","Helvetica Neue",Arial,sans-serif !important;font-size:12px !important;font-weight:700 !important;letter-spacing:.1em !important;text-transform:uppercase !important;background:#002539 !important;color:#fff !important;border:none !important;border-radius:999px !important;padding:14px 40px !important;cursor:pointer !important;transition:background .25s !important;}
.ns-gf-wrap .gform_wrapper input[type=submit]:hover,
.ns-gf-wrap .gform_wrapper button[type=submit]:hover{background:#16ACE3 !important;color:#002539 !important;}
@media(max-width:640px){.ns-gf-wrap .gform_wrapper.gravity-theme .gfield--width-half,.ns-gf-wrap .gform_wrapper.gravity-theme .gfield--width-third{grid-column:span 12 !important;}}
/* =========================================================
   COOKIE CONSENT — Bar + Preferences Modal
   painteq-cookie-consent.php mu-plugin
   ========================================================= */

/* --- Bar --- */
#pt-consent-bar {
    position: fixed;
    bottom: 0; left: 0; right: 0;
    z-index: 999999;
    background: #002539;
    border-top: 1px solid rgba(22,172,227,0.3);
    padding: 16px clamp(20px,4.4vw,72px);
    display: none;
    transform: translateY(100%);
    opacity: 0;
    transition: transform 0.4s ease, opacity 0.4s ease;
    box-shadow: 0 -4px 24px rgba(0,0,0,0.2);
}
.pt-consent-inner {
    max-width: 1440px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    flex-wrap: wrap;
}
.pt-consent-text p {
    margin: 0;
    font-family: 'Saira','Helvetica Neue',Arial,sans-serif;
    font-size: 14px;
    color: rgba(255,255,255,0.78);
    line-height: 1.55;
    max-width: 640px;
}
.pt-consent-text p a {
    color: #16ACE3;
    text-decoration: underline;
    text-underline-offset: 2px;
}
.pt-consent-text p a:hover { opacity: 0.75; }
.pt-consent-actions {
    display: flex;
    gap: 10px;
    flex-shrink: 0;
    align-items: center;
    flex-wrap: wrap;
}

/* --- Shared button styles --- */
.pt-consent-btn {
    font-family: 'Saira','Helvetica Neue',Arial,sans-serif;
    font-size: 12.5px;
    font-weight: 500;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 10px 22px;
    border-radius: 999px;
    border: none;
    cursor: pointer;
    transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, opacity 0.2s ease;
    white-space: nowrap;
    line-height: 1;
}
.pt-consent-btn--primary  { background: #16ACE3; color: #fff; }
.pt-consent-btn--primary:hover { background: #0d8fc0; }
.pt-consent-btn--secondary {
    background: transparent;
    color: rgba(255,255,255,0.65);
    border: 1px solid rgba(255,255,255,0.22);
}
.pt-consent-btn--secondary:hover { border-color: rgba(255,255,255,0.5); color: #fff; }
.pt-consent-btn--ghost {
    background: transparent;
    color: rgba(255,255,255,0.45);
    border: none;
    padding-left: 4px;
    padding-right: 4px;
    text-decoration: underline;
    text-underline-offset: 2px;
    letter-spacing: 0.04em;
}
.pt-consent-btn--ghost:hover { color: rgba(255,255,255,0.8); }

/* --- Modal overlay --- */
#pt-prefs-overlay {
    position: fixed;
    inset: 0;
    z-index: 1000000;
    background: rgba(0,37,57,0.75);
    backdrop-filter: blur(4px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
}
#pt-prefs-overlay[hidden] { display: none; }

/* --- Modal card --- */
#pt-prefs-modal {
    background: #F4F2EE;
    border-radius: 12px;
    width: 100%;
    max-width: 560px;
    max-height: 90vh;
    overflow-y: auto;
    position: relative;
    box-shadow: 0 24px 64px rgba(0,0,0,0.28);
    outline: none;
}

/* --- Modal header --- */
.pt-prefs-header {
    background: #002539;
    padding: 32px 32px 28px;
    border-radius: 12px 12px 0 0;
    position: relative;
}
.pt-prefs-eyebrow {
    font-family: Bahnschrift,'Saira','Helvetica Neue',Arial,sans-serif;
    font-size: 11px;
    letter-spacing: 0.14em;
    color: #16ACE3;
    display: block;
    margin-bottom: 10px;
}
.pt-prefs-title {
    font-family: 'Saira','Helvetica Neue',Arial,sans-serif;
    font-size: 26px;
    font-weight: 600;
    color: #fff;
    margin: 0 0 10px;
    line-height: 1.2;
}
.pt-prefs-sub {
    font-family: 'Saira','Helvetica Neue',Arial,sans-serif;
    font-size: 13.5px;
    color: rgba(255,255,255,0.65);
    margin: 0;
    line-height: 1.5;
    max-width: 42ch;
}
.pt-prefs-close {
    position: absolute;
    top: 20px; right: 20px;
    width: 32px; height: 32px;
    border-radius: 50%;
    background: rgba(255,255,255,0.1);
    border: none;
    color: rgba(255,255,255,0.7);
    font-size: 20px;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s ease;
}
.pt-prefs-close:hover { background: rgba(255,255,255,0.2); color: #fff; }

/* --- Modal body rows --- */
.pt-prefs-body { padding: 8px 0; }
.pt-prefs-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    padding: 20px 32px;
    border-bottom: 1px solid rgba(0,37,57,0.08);
}
.pt-prefs-row:last-child { border-bottom: none; }
.pt-prefs-row-info { flex: 1; }
.pt-prefs-row-info h3 {
    font-family: 'Saira','Helvetica Neue',Arial,sans-serif;
    font-size: 15px;
    font-weight: 600;
    color: #002539;
    margin: 0 0 5px;
}
.pt-prefs-row-info p {
    font-family: 'Saira','Helvetica Neue',Arial,sans-serif;
    font-size: 13px;
    color: #6F8390;
    margin: 0 0 6px;
    line-height: 1.5;
}
.pt-prefs-example {
    font-family: 'JetBrains Mono','Courier New',monospace;
    font-size: 11px;
    color: #3B5260;
    background: rgba(0,37,57,0.06);
    padding: 2px 8px;
    border-radius: 4px;
    display: inline-block;
}
.pt-prefs-always-label {
    font-family: 'Saira','Helvetica Neue',Arial,sans-serif;
    font-size: 12px;
    font-weight: 600;
    color: #16ACE3;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    white-space: nowrap;
}

/* --- Toggle switch --- */
.pt-toggle { display: inline-flex; cursor: pointer; flex-shrink: 0; }
.pt-toggle input { position: absolute; opacity: 0; width: 0; height: 0; }
.pt-toggle-track {
    width: 48px; height: 26px;
    background: #C8C4BC;
    border-radius: 999px;
    position: relative;
    transition: background 0.25s ease;
    display: flex;
    align-items: center;
}
.pt-toggle input:checked ~ .pt-toggle-track { background: #16ACE3; }
.pt-toggle-thumb {
    width: 20px; height: 20px;
    background: #fff;
    border-radius: 50%;
    position: absolute;
    left: 3px;
    box-shadow: 0 1px 4px rgba(0,0,0,0.2);
    transition: transform 0.25s ease;
}
.pt-toggle input:checked ~ .pt-toggle-track .pt-toggle-thumb { transform: translateX(22px); }

/* --- Modal footer --- */
.pt-prefs-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 20px 32px;
    border-top: 1px solid rgba(0,37,57,0.1);
    background: #EDE9E1;
    border-radius: 0 0 12px 12px;
    flex-wrap: wrap;
}
.pt-prefs-policy-link {
    font-family: 'Saira','Helvetica Neue',Arial,sans-serif;
    font-size: 12.5px;
    color: #3B5260;
    text-decoration: underline;
    text-underline-offset: 2px;
}
.pt-prefs-policy-link:hover { color: #002539; }
.pt-prefs-footer-btns { display: flex; gap: 10px; }
.pt-prefs-footer .pt-consent-btn--secondary {
    color: #3B5260;
    border-color: rgba(0,37,57,0.22);
}
.pt-prefs-footer .pt-consent-btn--secondary:hover {
    border-color: #002539;
    color: #002539;
}

/* --- Responsive --- */
@media (max-width: 640px) {
    .pt-consent-inner { flex-direction: column; align-items: flex-start; gap: 14px; }
    .pt-consent-actions { width: 100%; justify-content: flex-end; }
    .pt-consent-text p { font-size: 13px; }
    .pt-prefs-header { padding: 24px 20px 20px; }
    .pt-prefs-row { padding: 18px 20px; flex-direction: column; align-items: flex-start; }
    .pt-prefs-footer { padding: 16px 20px; }
    .pt-prefs-toggle-wrap { align-self: flex-end; }
}
/* =========================================================
   CLINICIAN PAGE — Implant logo sizing
   ========================================================= */
.implant-logo {
    width: 40% !important;
    max-width: 40% !important;
    height: auto !important;
    display: block !important;
}
/* LINQ + TRAQ implant logo size — Clinician page alloteq section */
.implant-logo {
    width: 40% !important;
    max-width: 40% !important;
    height: auto !important;
    display: block;
}

/* Reimbursement card — remove gap between descriptor and attr rows */
.pt-reimb-card-head {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
}
.pt-reimb-attrs {
    margin-top: 0 !important;
    padding-top: 0 !important;
}

/* Remove hero grid overlays — About + Careers */
.pt-abt-hero__grid,
.car-hero__grid {
    display: none !important;
}

/* Sonar position override — updated for new cropped anatomy image (ID 4286)
   Higher specificity to beat Elementor generated CSS */
.elementor-3627 .pt-hex-glow--pelvis,
#intro-figure-col .pt-hex-glow--pelvis { --hx: 40.5%; --hy: 40%; }

/* More Evidence Here button — rotated arrow + corporate blue border */
.pt-ev-publications-btn .e-font-icon-svg,
.pt-ev-publications-btn .elementor-button-icon svg {
    transform: rotate(-45deg) !important;
    display: inline-block !important;
}
.pt-ev-publications-btn .elementor-button {
    color: #16ACE3 !important;
    border-color: #16ACE3 !important;
}
.pt-ev-publications-btn .elementor-button:hover {
    color: #ffffff !important;
    background: #16ACE3 !important;
}

/* Evidence CTA row — vertically centre text with buttons */
.elementor-element-cln-ev-cta {
    align-items: center !important;
}

/* Evidence CTA — tighten gap between the two buttons */
.elementor-element-cln-ev-cta .elementor-element-cln-ev-cta-btn,
.elementor-element-cln-ev-cta .elementor-element-cln-ev-pub-btn {
    flex: 0 0 auto !important;
}
.elementor-element-cln-ev-cta {
    gap: 16px !important;
    justify-content: flex-end !important;
}
.elementor-element-cln-ev-cta .elementor-element-cln-ev-cta-text {
    flex: 1 1 auto !important;
}


/* ============================================================
   Waffle Menu button -- pre-rendered in header HTML so it
   appears at first paint. Styles here prevent unstyled flash
   before site-menu.js runs and injects its own <style> block.
   These rules mirror what site-menu.js generates exactly.
============================================================ */
.site-menu-btn {
    display: inline-flex;
    align-items: center;
    align-self: center;
    gap: 8px;
    background: transparent;
    border: 1px solid rgba(255,255,255,0.32);
    color: inherit;
    font-family: "Saira", "Helvetica Neue", Arial, sans-serif;
    font-size: 12.5px;
    font-weight: 500;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    padding: 5px 13px;
    border-radius: 999px;
    cursor: pointer;
    white-space: nowrap;
    transition: background 220ms, border-color 220ms, color 220ms;
    line-height: inherit;
}
.site-menu-btn svg {
    width: 13px;
    height: 13px;
    display: block;
    flex-shrink: 0;
}
.site-menu-btn:hover {
    background: #16ACE3;
    border-color: #16ACE3;
    color: #002539;
}
/* Dark pages (Clinician, About) -- white button */
body.pt-theme-dark #pt-nav .site-menu-btn {
    color: #ffffff !important;
    border-color: rgba(255,255,255,0.32) !important;
}
/* Light pages (Patient, Patents, Accessibility etc) -- dark button */
body.pt-theme-light #pt-nav .site-menu-btn {
    color: #002539 !important;
    border-color: rgba(0,37,57,0.30) !important;
}


/* More Evidence Here button -- clear persistent blue :focus state after click */
.pt-ev-publications-btn .elementor-button:focus:not(:focus-visible) {
    background: transparent !important;
    color: #16ACE3 !important;
    border-color: #16ACE3 !important;
}
.pt-ev-publications-btn .elementor-button:active {
    background: #16ACE3 !important;
    color: #ffffff !important;
    border-color: #16ACE3 !important;
    transition: none !important;
}


/* Clinician page — foundation stat figure (1″ incision card)
   Position the double-prime mark as a true superscript at the top of the numeral */
.fstat-figure {
    position: relative;
    display: inline-block;
}
.fstat-unit {
    position: relative;
    top: -0.55em;
    font-size: 0.45em;
    vertical-align: top;
    margin-left: 2px;
}


/* Patient hero — mobile crop fix: subject (woman) is positioned right-of-center
   in the source image. Desktop background-position is "center left" which works
   on wide viewports, but on mobile (narrower + cover crop zooms in) this cuts
   her out of frame. Shift crop right on mobile only. */
@media (max-width: 767px) {
    #top {
        background-position: 30% center !important;
    }
}


/* Patient page — Safe / Proven / Doesn't close doors bullets row.
   Centre everything on mobile: icon circle, heading, body text.
   Correct selectors confirmed from rendered HTML: #trt-bullets-row container,
   .elementor-element-trt-bullet-1/2/3 children. */
@media (max-width: 767px) {
    #trt-bullets-row {
        justify-content: center !important;
        align-items: center !important;
        flex-direction: column !important;
    }
    #trt-bullets-row > div {
        align-items: center !important;
        text-align: center !important;
        width: 100% !important;
    }
    #trt-bullets-row .tbullet-icon {
        margin-left: auto !important;
        margin-right: auto !important;
    }
    #trt-bullets-row .tbullet-title,
    #trt-bullets-row .tbullet-desc,
    #trt-bullets-row .elementor-heading-title {
        text-align: center !important;
    }
}


/* Patient page — "PainTEQ comes in two options..." line.
   Elementor generates a fixed-width rule at .elementor-3627 .elementor-element.elementor-element-trt-options-line
   (47.917% width) which beats a plain #id selector since elementor-post-3627.css loads after this file.
   Match Elementor's exact selector pattern + !important to win the cascade on mobile. */
@media (max-width: 767px) {
    .elementor-3627 .elementor-element.elementor-element-trt-options-line {
        width: 100% !important;
        max-width: 100% !important;
        --container-widget-width: 100% !important;
        margin-left: auto !important;
        margin-right: auto !important;
        text-align: center !important;
    }
    .elementor-3627 .elementor-element.elementor-element-trt-options-line p {
        text-align: center !important;
    }
}


/* Patient page inline form (Form 12) — checkbox + consent label layout fix.
   ROOT CAUSE: Gravity Forms theme.min.css hard-locks .gchoice to inline-size/
   max-inline-size/min-inline-size: 200px (CSS logical properties, not "width").
   That 200px cap was forcing the label text to wrap inside a narrow column
   regardless of any width/flex rules targeting the physical "width" property.
   Must override the logical-property versions directly. */
.ns-gf-wrap .gform_wrapper.gravity-theme .gchoice,
.ns-gf-wrap .gform_wrapper.gravity-theme .ginput_container_consent {
    inline-size: 100% !important;
    max-inline-size: 100% !important;
    min-inline-size: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    display: flex !important;
    align-items: flex-start !important;
    gap: 10px !important;
}
.ns-gf-wrap .gform_wrapper.gravity-theme .gchoice input[type=checkbox],
.ns-gf-wrap .gform_wrapper.gravity-theme .ginput_container_consent input[type=checkbox] {
    width: 18px !important;
    height: 18px !important;
    margin: 2px 0 0 0 !important;
    accent-color: #16ACE3;
    flex-shrink: 0;
}
.ns-gf-wrap .gform_wrapper.gravity-theme .gchoice label,
.ns-gf-wrap .gform_wrapper.gravity-theme .ginput_container_consent label {
    flex: 1 1 auto !important;
    inline-size: auto !important;
    max-inline-size: none !important;
    width: auto !important;
    margin: 0 !important;
    line-height: 1.4 !important;
}
@media (max-width: 480px) {
    .ns-gf-wrap .gform_wrapper.gravity-theme .gchoice label,
    .ns-gf-wrap .gform_wrapper.gravity-theme .ginput_container_consent label {
        font-size: 14.5px !important;
    }
}


/* Careers page form (Form 13) — mobile field width fix.
   Gravity Forms uses a 12-column CSS grid; gfield--width-half/third/quarter etc.
   span fewer columns with no built-in mobile stacking override. On narrow phones
   this crams First Name/Last Name and other paired fields into half-width boxes.
   Force every field to full width (span all 12 columns) below 600px. */
@media (max-width: 600px) {
    .car-form-card .gform_wrapper.gravity-theme .gfield {
        grid-column: 1 / -1 !important;
    }
}


/* Form 14 (General Contact) confirmation message — force black/dark text.
   Was inheriting a mint-green colour from an unidentified default source. */
.pt-gf-confirm__title,
.pt-gf-confirm__p,
.pt-gf-confirm__p a {
    color: #002539 !important;
}
.pt-gf-confirm__p a {
    text-decoration: underline;
}
