/* ================================================
   PET EMERGENCY CENTER — Homepage styles
   Brand: #C41E2A red, #1A1A1A near-black, warm cream.
   Type: Montserrat ExtraBold headlines / DM Sans body
   ================================================ */

:root {
  /* Pulled from petemergencycenters.com: navy + sky blue primary, red for urgent CTAs */
  --pec-navy: #0E3A5F;       /* deep brand blue */
  --pec-navy-2: #0A2C48;     /* darker navy for hero/footer */
  --pec-navy-3: #07213A;     /* deepest */
  --pec-sky: #7FB8D6;        /* light brand blue */
  --pec-sky-2: #B8DAEB;      /* pale tint */
  --pec-sky-bg: #E8F2F8;     /* washed-sky background */

  --pec-accent: #C41E2A;     /* urgent red — CTAs only */
  --pec-accent-dark: #9E1822;

  --pec-ink: #0A2C48;        /* headings use navy, not black */
  --pec-ink-2: #2B4A66;
  --pec-muted: #5B7187;
  --pec-line: #D9E3EC;
  --pec-cream: #F5F8FB;      /* was warm cream → now cool off-white */
  --pec-cream-2: #EDF3F8;

  --pec-coal: var(--pec-navy-2);
  --pec-coal-2: var(--pec-navy-3);

  --pec-wrap: 1240px;
  --pec-pad: 24px;
  --pec-r: 8px;
  --pec-r-lg: 16px;
  --pec-r-xl: 24px;

  --pec-sec-pad-y: 112px;

  --pec-shadow-sm: 0 2px 8px -2px rgba(10,44,72,0.08);
  --pec-shadow: 0 12px 32px -12px rgba(10,44,72,0.18);
  --pec-shadow-lg: 0 30px 60px -25px rgba(10,44,72,0.35);

  --pec-ease: cubic-bezier(0.22, 1, 0.36, 1);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: 'DM Sans', system-ui, -apple-system, sans-serif;
  color: var(--pec-ink);
  background: #fff;
  line-height: 1.6;
  font-size: 17px;
  font-feature-settings: "ss01", "ss02";
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
body { padding-bottom: 80px; } /* for mobile sticky bar */

a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

/* Typography */
.pec-h1, .pec-h2, .pec-h3 {
  font-family: 'Montserrat', system-ui, sans-serif;
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.02;
  margin: 0;
  color: var(--pec-ink);
  text-wrap: balance;
}
[data-heads="serif"] .pec-h1,
[data-heads="serif"] .pec-h2,
[data-heads="serif"] .pec-h3 {
  font-family: 'Fraunces', 'Playfair Display', Georgia, serif;
  font-weight: 700;
  letter-spacing: -0.015em;
}

.pec-h1 { font-size: clamp(34px, 3.4vw, 46px); line-height: 1.1; font-weight: 900; letter-spacing: -0.025em; margin-bottom: 0; max-width: 720px; text-wrap: balance; overflow-wrap: break-word; }
.pec-h1__accent {
  color: var(--pec-navy); font-style: italic; font-weight: 900;
  background-image: linear-gradient(transparent 62%, rgba(127,184,214,0.55) 62%);
  background-repeat: no-repeat;
  background-size: 0% 100%;
  background-position: 0 0;
  animation: pec-underline-grow 0.9s 0.4s var(--pec-ease) forwards;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}
@keyframes pec-underline-grow {
  to { background-size: 100% 100%; }
}

/* ================================================
   Instagram follow section
================================================ */
.pec-insta {
  padding: 80px 0;
  background: #fff;
  text-align: center;
}
.pec-insta__inner { max-width: 1100px; margin: 0 auto; padding: 0 var(--pec-pad); }
.pec-insta .pec-h2 { margin-top: 20px; }
.pec-insta__icon {
  display: flex; align-items: center; justify-content: center;
  width: 64px; height: 64px;
  border-radius: 18px;
  margin: 20px auto 0;
  color: #fff;
  background: linear-gradient(45deg, #FEDA77 0%, #F58529 25%, #DD2A7B 50%, #8134AF 75%, #515BD4 100%);
  box-shadow: 0 8px 24px -8px rgba(221,42,123,0.45);
}
.pec-insta__handle {
  font-family: 'Montserrat', sans-serif;
  font-size: 15px; font-weight: 700;
  color: #DD2A7B;
  margin: 6px 0 0;
  letter-spacing: -0.01em;
}
.pec-insta__handle a { color: inherit; text-decoration: none; }
.pec-insta__handle a:hover { text-decoration: underline; }
.pec-insta__sub {
  max-width: 580px; margin: 16px auto 0;
  color: var(--pec-ink-2); font-size: 17px; line-height: 1.6;
}
.pec-insta__cta { margin-top: 28px; }

/* Instagram feed grid (placeholders ready for a feed widget) */
.pec-insta__grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 8px;
  margin: 40px auto 32px;
  max-width: 980px;
}
.pec-insta__tile {
  position: relative;
  aspect-ratio: 1/1;
  border-radius: 12px;
  overflow: hidden;
  background: linear-gradient(135deg, #FEDA77 0%, #F58529 30%, #DD2A7B 60%, #8134AF 90%);
  display: block;
  text-decoration: none;
  transition: transform .2s, box-shadow .2s;
}
.pec-insta__tile::after {
  content: ""; position: absolute; inset: 0;
  background: rgba(0,0,0,0.35);
  transition: background .2s;
}
.pec-insta__tile:hover { transform: translateY(-2px); box-shadow: var(--pec-shadow); }
.pec-insta__tile:hover::after { background: rgba(0,0,0,0.15); }
.pec-insta__tile-icon {
  position: absolute; inset: 0; z-index: 1;
  display: flex; align-items: center; justify-content: center;
  color: #fff; opacity: 0.9;
}

@media (max-width: 720px) {
  .pec-insta__grid { grid-template-columns: repeat(3, 1fr); }
  .pec-insta { padding: 56px 0; }
}

.pec-h2 { font-size: clamp(30px, 3.4vw, 48px); line-height: 1.08; letter-spacing: -0.02em; }
.pec-h2--light { color: #fff; }

.pec-h3 { font-size: 22px; line-height: 1.25; letter-spacing: -0.01em; }
.pec-h3--light { color: #fff; }

.pec-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: 'Montserrat', sans-serif;
  font-weight: 700; font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--pec-accent);
  margin-bottom: 20px;
}
.pec-eyebrow--light { color: var(--pec-sky); }
.pec-eyebrow::before {
  content: ""; display: inline-block; width: 28px; height: 1px; background: currentColor;
}

.pec-link { color: var(--pec-accent); text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 1px; }
.pec-link:hover { text-decoration-thickness: 2px; }
.pec-link--arrow { display: inline-flex; align-items: center; gap: 6px; font-weight: 600; }

.pec-wrap {
  max-width: var(--pec-wrap);
  margin: 0 auto;
  padding: 0 var(--pec-pad);
}

.pec-section-head { margin-bottom: 64px; max-width: 820px; }
.pec-section-head--light .pec-eyebrow { color: var(--pec-sky); }
.pec-section-head__sub { font-size: 18px; line-height: 1.55; color: var(--pec-muted); margin-top: 20px; max-width: 640px; }

.pec-sep { color: var(--pec-muted); margin: 0 6px; }

/* ================================================
   BUTTONS
================================================ */
.pec-btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: 'Montserrat', sans-serif;
  font-weight: 700; font-size: 15px; letter-spacing: 0.01em;
  padding: 13px 22px;
  border-radius: var(--pec-r);
  border: 2px solid transparent;
  cursor: pointer;
  transition: transform .25s var(--pec-ease), background .25s ease, color .25s ease, border-color .25s ease, box-shadow .25s ease;
  white-space: nowrap;
  position: relative;
  will-change: transform;
}
.pec-btn:hover { transform: translateY(-2px); }
.pec-btn:active { transform: translateY(0); transition-duration: .08s; }
.pec-btn--lg { padding: 17px 28px; font-size: 16px; }
.pec-btn--sm { padding: 10px 16px; font-size: 14px; }

.pec-btn--primary {
  background: var(--pec-accent); color: #fff; border-color: var(--pec-accent);
  box-shadow: 0 6px 20px -6px rgba(196,30,42,0.5);
}
.pec-btn--primary:hover { background: var(--pec-accent-dark); border-color: var(--pec-accent-dark); box-shadow: 0 12px 28px -6px rgba(196,30,42,0.55); }

.pec-btn--outline {
  background: transparent; color: var(--pec-navy); border-color: var(--pec-navy);
}
.pec-btn--outline:hover { background: var(--pec-navy); color: #fff; }

.pec-btn--outline-white { color: #fff; border-color: #fff; }
.pec-btn--outline-white:hover { background: #fff; color: var(--pec-ink); }

.pec-btn--ghost { background: transparent; color: var(--pec-ink); border-color: transparent; padding: 8px 12px; }
.pec-btn--ghost:hover { color: var(--pec-accent); }

.pec-btn--white { background: #fff; color: var(--pec-ink); border-color: #fff; box-shadow: 0 10px 30px -12px rgba(0,0,0,0.3); }
.pec-btn--white:hover { background: var(--pec-cream); box-shadow: 0 16px 36px -12px rgba(0,0,0,0.35); }

.pec-btn--phone { font-weight: 800; font-size: 17px; }

/* Nav address pill — opens Google Maps */
.pec-btn--address {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: 700;
  color: var(--pec-ink-2);
  background: var(--pec-cream);
  border: 1px solid var(--pec-line);
  padding: 8px 14px;
  border-radius: 100px;
  line-height: 1.2;
  transition: color .15s, background .15s, border-color .15s;
  text-align: left;
}
.pec-btn--address:hover {
  color: var(--pec-accent);
  background: #fff;
  border-color: var(--pec-accent);
}
.pec-btn--address svg { color: var(--pec-accent); flex: 0 0 auto; }
.pec-btn--address__lines { display: flex; flex-direction: column; gap: 2px; line-height: 1.15; }
.pec-btn--address__top { font-weight: 800; color: var(--pec-ink); letter-spacing: -0.005em; }
.pec-btn--address__bot { font-weight: 600; font-size: 11px; color: var(--pec-muted); letter-spacing: 0.04em; text-transform: uppercase; }

/* ================================================
   TOP NAV
================================================ */
.pec-nav {
  position: sticky; top: 0; z-index: 50;
  background: #fff;
  border-bottom: 1px solid var(--pec-line);
  transition: box-shadow .2s ease;
}
.pec-nav--scrolled { box-shadow: 0 2px 0 0 rgba(0,0,0,0.04), 0 10px 30px -20px rgba(0,0,0,0.2); }

.pec-nav__inner {
  max-width: 1440px; margin: 0 auto;
  padding: 14px 32px;
  display: flex; align-items: center; gap: 28px;
}

.pec-logo { display: flex; flex-direction: column; align-items: flex-start; gap: 4px; flex: 0 0 auto; line-height: 1; }
.pec-logo__img { display: block; height: 38px; width: auto; max-width: 100%; }
.pec-logo__img--dark { filter: brightness(0) invert(1); opacity: 0.95; }
.pec-logo__tag { font-size: 11px; color: var(--pec-muted); letter-spacing: 0.05em; padding-left: 2px; }
.pec-logo--footer { gap: 10px; }
.pec-logo--footer .pec-logo__img { height: 40px; }
.pec-logo--footer .pec-logo__tag { color: #6A85A0; }

.pec-nav__links { display: flex; gap: 22px; flex: 1 1 auto; justify-content: center; align-items: center; white-space: nowrap; }
.pec-nav__links > a,
.pec-nav__toggle {
  font-family: 'Montserrat', sans-serif;
  font-weight: 600; font-size: 14px; letter-spacing: 0.01em;
  white-space: nowrap;
  color: var(--pec-ink);
  position: relative; padding: 6px 0;
  background: none; border: none; cursor: pointer;
  display: inline-flex; align-items: center; gap: 6px;
}
.pec-nav__toggle svg { transition: transform .25s var(--pec-ease); }
.pec-nav__links > a:hover,
.pec-nav__toggle:hover { color: var(--pec-accent); }
.pec-nav__links > a::after,
.pec-nav__toggle::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -2px; height: 2px;
  background: var(--pec-accent); transform: scaleX(0); transform-origin: left; transition: transform .25s var(--pec-ease);
}
.pec-nav__links > a:hover::after,
.pec-nav__toggle:hover::after { transform: scaleX(1); }

/* Dropdowns */
.pec-nav__drop { position: relative; }
.pec-nav__menu {
  position: absolute; top: calc(100% + 14px); left: 50%;
  transform: translate(-50%, 6px);
  min-width: 240px;
  background: #fff;
  border: 1px solid var(--pec-line);
  border-radius: var(--pec-r-lg);
  box-shadow: var(--pec-shadow-lg);
  padding: 10px;
  display: flex; flex-direction: column;
  opacity: 0; visibility: hidden;
  transition: opacity .25s ease, transform .25s var(--pec-ease), visibility .25s;
  z-index: 60;
}
.pec-nav__menu::before {
  content: ""; position: absolute; top: -6px; left: 50%; width: 12px; height: 12px;
  background: #fff; border-left: 1px solid var(--pec-line); border-top: 1px solid var(--pec-line);
  transform: translateX(-50%) rotate(45deg);
}
.pec-nav__drop:hover .pec-nav__menu,
.pec-nav__drop:focus-within .pec-nav__menu {
  opacity: 1; visibility: visible;
  transform: translate(-50%, 0);
}
.pec-nav__drop:hover .pec-nav__toggle svg,
.pec-nav__drop:focus-within .pec-nav__toggle svg { transform: rotate(180deg); }
.pec-nav__menu a {
  font-family: 'DM Sans', sans-serif;
  font-weight: 500; font-size: 14px;
  color: var(--pec-ink);
  padding: 10px 12px;
  border-radius: var(--pec-r);
  transition: background .2s ease, color .2s ease;
  white-space: nowrap;
}
.pec-nav__menu a:hover { background: var(--pec-sky-bg); color: var(--pec-navy); }

.pec-nav__cta { display: flex; align-items: center; gap: 10px; flex: 0 0 auto; }

.pec-openstrip {
  background: var(--pec-navy-2);
  color: #D9E7F2;
  padding: 8px var(--pec-pad);
  text-align: center;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.01em;
  display: flex; align-items: center; justify-content: center; gap: 6px;
}
.pec-openstrip strong { color: #fff; font-weight: 700; }
.pec-pulse {
  display: inline-block; width: 8px; height: 8px; border-radius: 50%;
  background: #5ACB70;
  box-shadow: 0 0 0 0 rgba(90, 203, 112, 0.6);
  animation: pec-pulse 2.2s ease-out infinite;
  margin-right: 4px;
}
@keyframes pec-pulse {
  0% { box-shadow: 0 0 0 0 rgba(90,203,112,0.7); }
  100% { box-shadow: 0 0 0 12px rgba(90,203,112,0); }
}

/* ================================================
   HERO
================================================ */
.pec-hero {
  background: var(--pec-sky-bg);
  padding: 72px 0 0;
  position: relative;
  overflow: hidden;
}
.pec-hero::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 85% 15%, rgba(127,184,214,0.38), transparent 50%),
    radial-gradient(ellipse at 10% 90%, rgba(14,58,95,0.08), transparent 45%);
  pointer-events: none;
  animation: pec-drift 22s ease-in-out infinite alternate;
}
@keyframes pec-drift {
  0%   { transform: translate3d(0,0,0) scale(1); }
  100% { transform: translate3d(-2%, 1%, 0) scale(1.05); }
}
.pec-hero__grid { position: relative; z-index: 1; }
.pec-trustbar { position: relative; z-index: 1; }
.pec-hero__grid {
  max-width: var(--pec-wrap); margin: 0 auto;
  padding: 0 var(--pec-pad);
  display: grid; grid-template-columns: 1.3fr 1fr; gap: 56px;
  align-items: center;
}
.pec-hero--stacked .pec-hero__grid { grid-template-columns: 1fr; text-align: center; }
.pec-hero--stacked .pec-hero__cta { justify-content: center; }
.pec-hero--stacked .pec-hero__foot { justify-content: center; }
.pec-hero--center .pec-hero__grid { grid-template-columns: 1fr; max-width: 960px; text-align: center; }
.pec-hero--center .pec-hero__media { display: none; }
.pec-hero--center .pec-hero__cta { justify-content: center; }
.pec-hero--center .pec-hero__foot { justify-content: center; }

.pec-hero__eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: 'Montserrat', sans-serif; font-weight: 700;
  font-size: 13px; letter-spacing: 0.06em;
  color: var(--pec-ink-2);
  padding: 8px 16px;
  border: 1px solid var(--pec-line);
  background: #fff;
  border-radius: 100px;
  margin-bottom: 32px;
  box-shadow: var(--pec-shadow-sm);
}
.pec-dot {
  width: 8px; height: 8px; background: var(--pec-accent); border-radius: 50%;
  box-shadow: 0 0 0 4px rgba(196,30,42,0.15);
  animation: pec-dot-pulse 2.4s ease-in-out infinite;
}
@keyframes pec-dot-pulse {
  0%,100% { box-shadow: 0 0 0 4px rgba(196,30,42,0.15); }
  50%     { box-shadow: 0 0 0 7px rgba(196,30,42,0.08); }
}

.pec-hero__sub {
  font-size: clamp(16px, 1.15vw, 19px);
  line-height: 1.6;
  color: var(--pec-ink-2);
  margin: 24px 0 36px;
  max-width: 560px;
}
.pec-h1 + .pec-hero__sub { margin-top: 24px; }
.pec-hero__cta { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 36px; }
.pec-hero__foot {
  display: flex; gap: 8px; align-items: center; flex-wrap: wrap;
  color: var(--pec-muted); font-size: 14px;
}
.pec-hero__foot span { display: inline-flex; align-items: center; gap: 6px; }

/* Hero media */
.pec-hero__media { position: relative; }
.pec-hero__frame {
  position: relative;
  aspect-ratio: 4/5;
  width: 100%;
  border-radius: var(--pec-r-xl);
  overflow: hidden;
  background: var(--pec-sky-2);
  box-shadow: var(--pec-shadow-lg), 0 2px 0 rgba(0,0,0,0.04);
  transform: translateY(0);
  animation: pec-float 6s ease-in-out infinite;
}
@keyframes pec-float {
  0%,100% { transform: translateY(0); }
  50%     { transform: translateY(-8px); }
}
.pec-hero__badge {
  position: absolute; left: 24px; bottom: 24px;
  background: #fff;
  padding: 20px 24px;
  border-radius: var(--pec-r-lg);
  box-shadow: 0 24px 48px -16px rgba(0,0,0,0.35);
  max-width: 280px;
  animation: pec-fade-in 0.7s 0.6s var(--pec-ease) both;
}
@keyframes pec-fade-in {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}
.pec-hero__badge-top {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: 'Montserrat', sans-serif;
  font-size: 11px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--pec-navy);
}
.pec-hero__badge-top svg { color: var(--pec-accent); }
.pec-hero__badge-big {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 22px; font-weight: 800; color: var(--pec-ink);
  margin: 6px 0 4px; line-height: 1.1;
}
.pec-hero__badge-sub {
  display: block; font-size: 13px; color: var(--pec-muted);
}

/* Trust bar */
.pec-trustbar {
  margin-top: 96px;
  border-top: 1px solid var(--pec-line);
  background: #fff;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
}
.pec-trustbar__item {
  display: flex; align-items: center; gap: 16px;
  padding: 30px 28px;
  border-right: 1px solid var(--pec-line);
  transition: background .3s ease;
}
.pec-trustbar__item:hover { background: var(--pec-sky-bg); }
.pec-trustbar__item:hover svg { transform: scale(1.1) rotate(-4deg); }
.pec-trustbar__item svg { transition: transform .3s var(--pec-ease); flex: 0 0 auto; }
.pec-trustbar__item:last-child { border-right: none; }
.pec-trustbar__item strong { display: block; font-family: 'Montserrat', sans-serif; font-weight: 700; font-size: 14px; line-height: 1.3; letter-spacing: 0.01em; color: var(--pec-navy); }
.pec-trustbar__item span { display: block; font-size: 13px; color: var(--pec-muted); margin-top: 4px; }

/* ================================================
   EMPATHY
================================================ */
.pec-empathy {
  padding: var(--pec-sec-pad-y) 0;
  background: #fff;
  position: relative;
}
.pec-empathy .pec-wrap { max-width: var(--pec-wrap); }
.pec-empathy__grid { display: grid; grid-template-columns: 1.3fr 1fr; gap: 64px; align-items: center; }
.pec-empathy__copy { max-width: 680px; }
.pec-empathy__media img { border-radius: var(--pec-r-xl); }
.pec-empathy__eyebrow {
  font-family: 'Montserrat', sans-serif; font-weight: 600;
  font-size: 13px; color: var(--pec-muted); letter-spacing: 0.1em;
  margin-bottom: 24px;
  display: inline-flex; align-items: center; gap: 12px;
}
.pec-empathy__eyebrow::before {
  content: ""; width: 32px; height: 1px; background: var(--pec-accent);
}
.pec-empathy__body {
  margin-top: 40px;
  font-size: 19px;
  line-height: 1.7;
  color: var(--pec-ink-2);
}
.pec-empathy__body p { margin: 0 0 24px; }
.pec-empathy__body p:last-child { margin-bottom: 0; }
.pec-empathy__body strong { color: var(--pec-ink); }

/* ================================================
   HOW IT WORKS
================================================ */
.pec-how {
  padding: var(--pec-sec-pad-y) 0;
  background: var(--pec-sky-bg);
  border-top: 1px solid var(--pec-line);
  border-bottom: 1px solid var(--pec-line);
}
.pec-how__grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
}
.pec-step {
  background: #fff;
  border: 1px solid var(--pec-line);
  border-radius: var(--pec-r-lg);
  padding: 36px;
  position: relative;
  transition: transform .4s var(--pec-ease), box-shadow .4s ease, border-color .4s ease;
  overflow: hidden;
}
.pec-step::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--pec-accent), var(--pec-sky));
  transform: scaleX(0); transform-origin: left;
  transition: transform .5s var(--pec-ease);
}
.pec-step:hover { transform: translateY(-6px); box-shadow: var(--pec-shadow); border-color: var(--pec-sky-2); }
.pec-step:hover::before { transform: scaleX(1); }
.pec-step:hover .pec-step__icon { transform: scale(1.08) rotate(-4deg); }
.pec-step__top {
  display: flex; justify-content: space-between; align-items: flex-start;
  margin-bottom: 28px;
}
.pec-step__n {
  font-family: 'Montserrat', sans-serif;
  font-size: 13px; font-weight: 700; letter-spacing: 0.16em;
  color: var(--pec-navy);
  padding: 6px 12px;
  background: var(--pec-sky-bg);
  border-radius: 100px;
}
.pec-step__icon {
  color: var(--pec-navy);
  transition: transform .5s var(--pec-ease);
  display: inline-flex;
}
.pec-step h3 { margin-bottom: 14px; font-size: 22px; line-height: 1.3; }
.pec-step p { color: var(--pec-muted); margin: 0; font-size: 16px; line-height: 1.6; }

/* ================================================
   WHY CHOOSE (DARK)
================================================ */
.pec-why {
  padding: var(--pec-sec-pad-y) 0;
  background: var(--pec-navy-2);
  color: #C9DCEA;
}
.pec-why .pec-h2--light { color: #fff; }
.pec-why__grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 2px;
  background: #14416B;
  border-radius: var(--pec-r-xl);
  overflow: hidden;
  border: 1px solid #14416B;
  box-shadow: var(--pec-shadow-lg);
}
.pec-whycard {
  grid-column: span 2;
  background: var(--pec-navy-3);
  padding: 40px 36px;
  color: #B8CDDE;
  position: relative;
  transition: background .4s ease, transform .4s var(--pec-ease);
  overflow: hidden;
}
.pec-whycard::after {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(circle at 80% 0%, rgba(127,184,214,0.15), transparent 60%);
  opacity: 0; transition: opacity .4s ease;
  pointer-events: none;
}
.pec-whycard:hover { background: #0D2E4F; }
.pec-whycard:hover::after { opacity: 1; }
.pec-whycard--lead { grid-column: span 6; background: #0F3458; padding-bottom: 44px; }
.pec-whycard--lead h3 { font-size: clamp(28px, 2.8vw, 36px); max-width: 700px; margin-bottom: 18px; line-height: 1.15; }
.pec-whycard__num {
  font-family: 'Montserrat', sans-serif;
  font-size: 12px; font-weight: 700; letter-spacing: 0.18em;
  color: var(--pec-sky);
  display: block; margin-bottom: 20px;
}
.pec-whycard h3 { color: #fff; font-size: 20px; margin-bottom: 14px; line-height: 1.3; }
.pec-whycard p { font-size: 15px; line-height: 1.65; color: #99B3C9; margin: 0; }

.pec-whycard--cta {
  grid-column: span 4;
  background: var(--pec-accent);
  color: #fff;
  padding: 44px;
  display: flex; flex-direction: column; justify-content: space-between;
  gap: 20px;
}
.pec-whycard--cta::after { display: none; }
.pec-whycard--cta:hover { background: var(--pec-accent-dark); }
.pec-whycard__cta-eyebrow {
  font-family: 'Montserrat', sans-serif;
  font-size: 12px; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase;
  opacity: 0.9;
}
.pec-whycard__cta-big {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(28px, 2.6vw, 38px); font-weight: 900; line-height: 1.08;
  letter-spacing: -0.02em;
  margin: 14px 0 4px;
}
.pec-whycard__cta-foot { font-size: 13px; opacity: 0.85; margin: 0; color: #fff; line-height: 1.5; }
.pec-whycard--cta .pec-btn { align-self: flex-start; }

/* ================================================
   SERVICES
================================================ */
.pec-services { padding: var(--pec-sec-pad-y) 0; background: #fff; }
.pec-services__grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
  border-top: 1px solid var(--pec-line);
  border-left: 1px solid var(--pec-line);
  border-radius: var(--pec-r-lg);
  overflow: hidden;
  border-right: 1px solid var(--pec-line);
  border-bottom: 1px solid var(--pec-line);
}
.pec-svc {
  padding: 40px 36px 44px;
  border-right: 1px solid var(--pec-line);
  border-bottom: 1px solid var(--pec-line);
  display: block;
  position: relative;
  transition: background .35s ease;
  overflow: hidden;
}
.pec-svc:nth-child(3n) { border-right: none; }
.pec-svc:nth-last-child(-n+3) { border-bottom: none; }
.pec-svc::after {
  content: ""; position: absolute; bottom: 0; left: 0; width: 100%; height: 3px;
  background: var(--pec-accent);
  transform: scaleX(0); transform-origin: left;
  transition: transform .45s var(--pec-ease);
}
.pec-svc:hover { background: var(--pec-sky-bg); }
.pec-svc:hover::after { transform: scaleX(1); }
.pec-svc:hover .pec-svc__num { color: var(--pec-accent); }
.pec-svc:hover .pec-svc__more { color: var(--pec-accent); gap: 12px; }
.pec-svc__num {
  font-family: 'Montserrat', sans-serif;
  font-size: 12px; font-weight: 700; letter-spacing: 0.18em;
  color: var(--pec-navy);
  margin-bottom: 18px;
  transition: color .3s ease;
}
.pec-svc h3 { margin-bottom: 14px; font-size: 22px; line-height: 1.3; }
.pec-svc p { color: var(--pec-muted); font-size: 15px; line-height: 1.6; margin: 0 0 24px; }
.pec-svc__more {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: 'Montserrat', sans-serif; font-weight: 700; font-size: 14px;
  color: var(--pec-ink);
  transition: gap .35s var(--pec-ease), color .25s ease;
}

/* ================================================
   TELEHEALTH
================================================ */
.pec-tele {
  padding: var(--pec-sec-pad-y) 0;
  background: var(--pec-navy);
  color: #fff;
  background-image:
    radial-gradient(ellipse at 0% 0%, rgba(127,184,214,0.25), transparent 50%),
    radial-gradient(ellipse at 100% 100%, rgba(196,30,42,0.18), transparent 45%);
}
.pec-tele__grid {
  display: grid; grid-template-columns: 1.2fr 1fr; gap: 72px; align-items: start;
}
.pec-tele__lead { font-size: 20px; font-weight: 500; margin: 32px 0 18px; line-height: 1.55; }
.pec-tele p { color: #D9E7F2; font-size: 16px; line-height: 1.7; }
.pec-tele__credit {
  display: flex; gap: 18px;
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: var(--pec-r-lg);
  padding: 24px 26px;
  margin: 32px 0 36px;
  color: #fff; font-size: 16px; line-height: 1.6;
  backdrop-filter: blur(4px);
}
.pec-tele__credit-star {
  font-size: 28px; color: var(--pec-sky); font-weight: 900; line-height: 1;
  animation: pec-twinkle 2.8s ease-in-out infinite;
}
@keyframes pec-twinkle {
  0%,100% { transform: scale(1) rotate(0); opacity: 1; }
  50%     { transform: scale(1.15) rotate(12deg); opacity: 0.85; }
}
.pec-tele__credit strong { color: #fff; }
.pec-tele__side {
  background: rgba(0,0,0,0.18);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--pec-r-lg);
  padding: 0;
  overflow: hidden;
  position: relative;
}
.pec-tele__turtle {
  position: absolute; right: -28px; bottom: -22px;
  width: 160px; height: auto;
  pointer-events: none;
  filter: drop-shadow(0 16px 18px rgba(0,0,0,0.45));
  transform: rotate(-6deg);
  z-index: 2;
  animation: pec-turtle-amble 8s ease-in-out infinite;
}
@keyframes pec-turtle-amble {
  0%, 100% { transform: rotate(-6deg) translateY(0); }
  50%      { transform: rotate(-4deg) translateY(-4px); }
}
.pec-tele__side-img {
  display: block;
  width: 100%;
  aspect-ratio: 3/2;
  object-fit: cover;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.pec-tele__side-head { margin: 28px 28px 22px; font-size: 20px; }
.pec-tele__side .pec-tele__list { padding: 0 28px 28px; }
.pec-tele__list { list-style: none; padding: 0; margin: 0; }
.pec-tele__list li {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 14px 0;
  border-bottom: 1px solid rgba(255,255,255,0.15);
  color: #D9E7F2;
  font-size: 15px; line-height: 1.5;
}
.pec-tele__list li:last-child { border-bottom: none; }
.pec-tele__list li svg { flex: 0 0 auto; margin-top: 3px; }

/* ================================================
   ANIMALS
================================================ */
.pec-animals { padding: var(--pec-sec-pad-y) 0; background: var(--pec-sky-bg); }

/* Featured group cutout — the iconic recognition image */
.pec-animals__feature {
  display: grid; grid-template-columns: 1fr 1.15fr;
  gap: 56px; align-items: center;
  margin-bottom: 56px;
}
.pec-animals__feature .pec-section-head { margin-bottom: 0; max-width: none; }
.pec-animals__hero {
  position: relative;
  background: linear-gradient(140deg, #B8DAEB 0%, #7FB8D6 55%, #0E3A5F 100%);
  border-radius: var(--pec-r-xl);
  padding: 36px 32px 0;
  aspect-ratio: 4/3;
  overflow: hidden;
  display: flex; align-items: flex-end; justify-content: center;
  box-shadow: var(--pec-shadow-lg);
}
.pec-animals__hero::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(255,255,255,0.18), transparent 60%),
    radial-gradient(ellipse at 50% 100%, rgba(10,44,72,0.4), transparent 65%);
  pointer-events: none;
}
.pec-animals__hero img {
  position: relative;
  width: 92%; height: auto;
  display: block;
  filter: drop-shadow(0 24px 32px rgba(7,33,58,0.45));
  animation: pec-float 7s ease-in-out infinite;
}
.pec-animals__chip {
  position: absolute; top: 20px; left: 20px;
  display: inline-flex; align-items: center; gap: 8px;
  font-family: 'Montserrat', sans-serif;
  font-size: 11px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase;
  color: #fff;
  background: rgba(0,0,0,0.25);
  backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,0.18);
  padding: 8px 14px; border-radius: 100px;
  z-index: 2;
}

.pec-animals__grid {
  display: flex; flex-wrap: wrap; justify-content: center; gap: 16px;
}
.pec-animal {
  flex: 1 1 calc(20% - 16px);
  min-width: 168px;
  max-width: 220px;
}
.pec-animal {
  background: #fff;
  border: 1px solid var(--pec-line);
  border-radius: var(--pec-r-lg);
  padding: 12px 12px 16px;
  text-align: center;
  color: var(--pec-ink-2);
  transition: transform .35s var(--pec-ease), border-color .3s ease, color .3s ease, box-shadow .3s ease;
  cursor: default;
  overflow: hidden;
}
.pec-animal:hover {
  transform: translateY(-6px);
  border-color: var(--pec-navy);
  color: var(--pec-navy);
  box-shadow: var(--pec-shadow);
}
.pec-animal:hover .pec-animal__photo img { transform: scale(1.08); }
.pec-animal:hover .pec-animal__art { transform: scale(1.12) rotate(-6deg); }
.pec-animal__art {
  margin: 12px 0 14px; display: flex; justify-content: center;
  transition: transform .5s var(--pec-ease);
}
.pec-animal__photo {
  width: 100%;
  aspect-ratio: 1/1;
  border-radius: var(--pec-r);
  overflow: hidden;
  margin-bottom: 14px;
  background: linear-gradient(135deg, #E8F2F8 0%, #B8DAEB 100%);
  position: relative;
}
.pec-animal__photo img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .6s var(--pec-ease);
}
.pec-animal__photo::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(7,33,58,0.08));
  pointer-events: none;
}
.pec-animal__name {
  font-family: 'Montserrat', sans-serif;
  font-weight: 700; font-size: 14px; letter-spacing: 0.01em;
  color: var(--pec-ink);
  padding: 0 4px;
}

/* ================================================
   REVIEWS
================================================ */
.pec-reviews { padding: var(--pec-sec-pad-y) 0; background: #fff; }
.pec-reviews__grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px;
}
.pec-review {
  padding: 32px;
  background: var(--pec-sky-bg);
  border: 1px solid var(--pec-line);
  border-radius: var(--pec-r-lg);
  display: flex; flex-direction: column;
  transition: transform .35s var(--pec-ease), box-shadow .35s ease, border-color .3s ease;
  position: relative;
}
.pec-review::before {
  content: "\201C"; position: absolute; top: 12px; right: 22px;
  font-family: 'Fraunces', Georgia, serif; font-size: 72px; line-height: 1;
  color: var(--pec-sky); opacity: 0.5;
  font-weight: 800;
}
.pec-review:hover { transform: translateY(-6px); box-shadow: var(--pec-shadow); border-color: var(--pec-sky); }
.pec-review__stars { display: flex; gap: 3px; margin-bottom: 18px; position: relative; }
.pec-review__text { font-size: 15px; line-height: 1.65; color: var(--pec-ink-2); margin: 0 0 auto; padding-bottom: 22px; position: relative; }
.pec-review__meta { display: flex; justify-content: space-between; font-size: 13px; color: var(--pec-muted); padding-top: 16px; border-top: 1px solid var(--pec-line); }
.pec-review__meta strong { color: var(--pec-ink); font-weight: 700; font-family: 'Montserrat', sans-serif; font-size: 14px; }
.pec-reviews__more { text-align: center; margin-top: 48px; }

/* ================================================
   SERVICE AREA
================================================ */
.pec-area {
  padding: var(--pec-sec-pad-y) 0;
  background: var(--pec-sky-bg);
  border-top: 1px solid var(--pec-line);
}
.pec-area__grid {
  display: grid; grid-template-columns: 1fr 1.2fr; gap: 72px;
  align-items: start;
}
.pec-area__copy p { color: var(--pec-ink-2); font-size: 17px; margin-top: 20px; }
.pec-area__note { font-size: 15px !important; color: var(--pec-muted) !important; }
.pec-area__cities { display: flex; flex-wrap: wrap; gap: 8px; padding-top: 44px; }
.pec-pill {
  font-family: 'Montserrat', sans-serif;
  padding: 9px 16px;
  background: #fff;
  border: 1px solid var(--pec-line);
  border-radius: 100px;
  font-size: 13px; font-weight: 600;
  color: var(--pec-ink);
  transition: transform .25s var(--pec-ease), border-color .25s ease, color .25s ease, background .25s ease;
  cursor: default;
}
.pec-pill:hover { transform: translateY(-2px); border-color: var(--pec-navy); color: #fff; background: var(--pec-navy); }
.pec-pill--ghost { background: transparent; color: var(--pec-muted); font-style: italic; font-weight: 500; }

/* ================================================
   FAQ
================================================ */
.pec-faq { padding: var(--pec-sec-pad-y) 0; background: #fff; }
.pec-faq__grid {
  display: grid; grid-template-columns: 1fr 1.6fr; gap: 72px;
}
.pec-faq__head { position: sticky; top: 120px; }
.pec-faq__intro { color: var(--pec-muted); font-size: 16px; margin-top: 16px; }
.pec-faq__list { display: flex; flex-direction: column; }
.pec-faq__item {
  display: flex; flex-direction: column;
  text-align: left;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--pec-line);
  padding: 24px 0;
  cursor: pointer;
  font-family: inherit;
  color: var(--pec-ink);
}
.pec-faq__item:first-child { border-top: 1px solid var(--pec-line); }
.pec-faq__q {
  display: grid; grid-template-columns: auto 1fr auto; gap: 20px;
  align-items: center;
  font-family: 'Montserrat', sans-serif;
  font-weight: 700; font-size: 18px;
  line-height: 1.35;
  transition: color .25s ease;
}
.pec-faq__item:hover .pec-faq__q { color: var(--pec-accent); }
.pec-faq__item--open .pec-faq__q { color: var(--pec-navy); }
.pec-faq__n { font-size: 12px; color: var(--pec-navy); letter-spacing: 0.14em; font-weight: 700; }
.pec-faq__chev { transition: transform .3s var(--pec-ease), color .25s ease; color: var(--pec-muted); display: flex; }
.pec-faq__item:hover .pec-faq__chev { color: var(--pec-accent); }
.pec-faq__item--open .pec-faq__chev { transform: rotate(180deg); color: var(--pec-navy); }
.pec-faq__a {
  max-height: 0; overflow: hidden; opacity: 0;
  color: var(--pec-ink-2);
  font-size: 16px; line-height: 1.7;
  transition: max-height .4s var(--pec-ease), padding .3s ease, opacity .3s ease;
}
.pec-faq__item--open .pec-faq__a {
  max-height: 420px;
  opacity: 1;
  padding: 18px 0 8px 0;
  padding-left: 36px;
}

/* ================================================
   FINAL CTA
================================================ */
.pec-final {
  padding: var(--pec-sec-pad-y) 0;
  background: var(--pec-navy-3);
  color: #fff;
  position: relative;
  overflow: hidden;
}
.pec-final::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 100% 0%, rgba(127,184,214,0.22), transparent 50%),
    radial-gradient(ellipse at 0% 100%, rgba(196,30,42,0.12), transparent 40%);
  pointer-events: none;
}
.pec-final__grid {
  display: grid; grid-template-columns: 1.2fr 1fr; gap: 72px; align-items: start;
  position: relative;
}
.pec-final__h { font-size: clamp(28px, 2.9vw, 44px); line-height: 1.15; margin-bottom: 22px; letter-spacing: -0.02em; }
.pec-final__p { color: #A9C1D4; font-size: 17px; line-height: 1.6; margin-bottom: 36px; }
.pec-final__cta { display: flex; gap: 14px; flex-wrap: wrap; }

.pec-contact-card {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--pec-r-xl);
  padding: 36px;
  backdrop-filter: blur(8px);
}
.pec-contact-card h3 { margin-bottom: 20px; font-size: 22px; }
.pec-contact-card__row {
  display: flex; gap: 14px; align-items: flex-start;
  padding: 12px 0;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  color: #B8CDDE;
  font-size: 15px;
}
.pec-contact-card__row:last-of-type { border-bottom: none; }
.pec-contact-card__row svg { color: var(--pec-sky); margin-top: 3px; flex: 0 0 auto; }
.pec-contact-card__row a { color: #fff; font-weight: 700; font-family: 'Montserrat', sans-serif; font-size: 17px; }
.pec-contact-card__row strong { color: #fff; font-weight: 700; }

.pec-minimap {
  margin-top: 20px; border-radius: var(--pec-r-lg); overflow: hidden;
  aspect-ratio: 16/10; position: relative; background: var(--pec-sky-bg);
}
.pec-minimap iframe { display: block; width: 100%; height: 100%; }
.pec-minimap__link {
  position: absolute; bottom: 12px; right: 12px;
  display: inline-flex; align-items: center; gap: 6px;
  background: #fff; color: var(--pec-ink);
  padding: 8px 14px; border-radius: 100px;
  font-family: 'Montserrat', sans-serif; font-weight: 700; font-size: 13px;
}

/* ================================================
   FOOTER
================================================ */
.pec-footer { background: #061628; color: #99B3C9; padding: 72px 0 28px; }
.pec-footer__top {
  padding-bottom: 40px;
  margin-bottom: 40px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.pec-footer__brand { max-width: 480px; }
.pec-footer__grid {
  display: grid; grid-template-columns: 1fr 1fr 1.4fr; gap: 48px;
  padding-bottom: 40px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.pec-footer__h {
  font-family: 'Montserrat', sans-serif;
  color: #fff; font-size: 13px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase;
  margin: 0 0 20px;
}
.pec-footer__grid a, .pec-footer__grid p {
  display: block; color: #99B3C9; font-size: 14px; padding: 6px 0; margin: 0; line-height: 1.55;
}
.pec-footer__grid a { transition: color .25s ease; }
.pec-footer__grid a:hover { color: #fff; }
.pec-footer__blurb { max-width: 420px; font-size: 14px; line-height: 1.65; margin-top: 24px; color: #99B3C9; }
.pec-footer__phone { color: #fff !important; font-family: 'Montserrat', sans-serif; font-weight: 700; font-size: 18px !important; letter-spacing: 0.01em; }
.pec-footer__nap { padding: 6px 0 !important; }
.pec-footer__nap strong, .pec-footer__hours strong { color: #fff; font-weight: 700; }
.pec-footer__map { color: var(--pec-sky) !important; font-weight: 600; padding: 10px 0 !important; }

.pec-social { display: flex; gap: 10px; margin-top: 18px; }
.pec-social a {
  width: 38px; height: 38px; padding: 0 !important;
  display: inline-flex !important; align-items: center; justify-content: center;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 50%;
  color: #99B3C9 !important;
  transition: background .25s ease, color .25s ease, transform .25s var(--pec-ease), border-color .25s ease;
}
.pec-social a:hover { background: var(--pec-accent); color: #fff !important; transform: translateY(-2px); border-color: transparent; }

.pec-footer__bottom {
  max-width: var(--pec-wrap); margin: 0 auto;
  padding: 28px var(--pec-pad) 0;
  display: flex; justify-content: space-between; font-size: 13px; color: #5B7187;
}
.pec-footer__bottom a { color: #99B3C9; transition: color .25s ease; }
.pec-footer__bottom a:hover { color: #fff; }

/* Skip link */
.pec-skip {
  position: absolute; top: -100px; left: 16px; z-index: 200;
  background: var(--pec-accent); color: #fff;
  padding: 12px 20px; border-radius: var(--pec-r);
  font-family: 'Montserrat', sans-serif; font-weight: 700; font-size: 14px;
  transition: top .2s ease;
}
.pec-skip:focus { top: 16px; outline: 3px solid #fff; outline-offset: 2px; }

/* ================================================
   STICKY BARS
================================================ */
.pec-tele-float {
  position: fixed; right: 24px; bottom: 24px; z-index: 40;
  display: none; /* shown on desktop when scrolled */
  align-items: center; gap: 14px;
  background: var(--pec-accent);
  color: #fff;
  padding: 14px 20px 14px 16px;
  border-radius: var(--pec-r-lg);
  box-shadow: 0 20px 40px -10px rgba(196,30,42,0.5), 0 10px 20px -10px rgba(0,0,0,0.3);
  transform: translateY(20px); opacity: 0;
  transition: transform .3s ease, opacity .3s ease, background .2s ease;
  font-family: 'Montserrat', sans-serif;
  font-size: 14px; font-weight: 700; line-height: 1.25;
  max-width: 260px;
}
.pec-tele-float--shown { transform: translateY(0); opacity: 1; }
.pec-tele-float:hover { background: var(--pec-accent-dark); }
.pec-tele-float__icon {
  width: 40px; height: 40px; border-radius: 50%;
  background: rgba(0,0,0,0.15);
  display: flex; align-items: center; justify-content: center;
}
.pec-tele-float__label em { font-style: normal; font-weight: 500; opacity: 0.85; font-size: 12px; }

@media (min-width: 900px) {
  .pec-tele-float { display: flex; }
}

.pec-sticky-mobile {
  display: flex;
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 50;
  background: #fff;
  border-top: 1px solid var(--pec-line);
  box-shadow: 0 -10px 30px -15px rgba(0,0,0,0.2);
  /* Extend the white background through the iOS home-indicator area
     so there is no visible gap when the address bar collapses on scroll. */
  padding-bottom: env(safe-area-inset-bottom);
  /* GPU compositing layer + smooth transform updates while iOS Safari
     animates the URL bar. Without these the bar can "hover" mid-screen
     during the collapse transition. */
  will-change: transform;
  transform: translate3d(0, 0, 0);
  -webkit-backface-visibility: hidden;
}
.pec-sticky-mobile__btn {
  flex: 1; display: flex; align-items: center; justify-content: center; gap: 8px;
  padding: 14px 10px;
  font-family: 'Montserrat', sans-serif; font-weight: 700; font-size: 14px;
  letter-spacing: 0.01em;
}
.pec-sticky-mobile__btn--call { background: var(--pec-accent); color: #fff; }
.pec-sticky-mobile__btn--tele { background: var(--pec-sky-bg); color: var(--pec-navy); }
.pec-sticky-mobile__btn--tele svg { color: var(--pec-navy); }

/* Reserve space at the bottom of every page on mobile so content does
   not sit underneath the sticky bar. ~52px button + ~12px breathing
   room + the device safe-area inset. */
@media (max-width: 899px) {
  body { padding-bottom: calc(64px + env(safe-area-inset-bottom)); }
}

@media (min-width: 900px) {
  .pec-sticky-mobile { display: none; }
  body { padding-bottom: 0; }
}

/* ================================================
   MOBILE NAV — hamburger + full-screen overlay menu
================================================ */
.pec-nav__burger {
  display: none;
  width: 44px; height: 44px;
  padding: 0;
  background: transparent;
  border: 1px solid var(--pec-line);
  border-radius: var(--pec-r);
  cursor: pointer;
  align-items: center; justify-content: center;
  color: var(--pec-ink);
  flex: 0 0 auto;
  transition: border-color .2s ease, color .2s ease;
}
.pec-nav__burger:hover { border-color: var(--pec-ink); color: var(--pec-accent); }

.pec-mobile-menu {
  position: fixed; inset: 0; z-index: 200;
  background: radial-gradient(ellipse at 50% 20%, #0E3A5F 0%, #07213A 70%, #061628 100%);
  color: #fff;
  display: flex; flex-direction: column;
  padding: 24px 24px 32px;
  transform: translateX(100%);
  transition: transform .35s var(--pec-ease);
  overflow-y: auto;
}
.pec-mobile-menu--open { transform: translateX(0); }
.pec-mobile-menu__top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 32px; }
.pec-mobile-menu__logo img { height: 34px; filter: brightness(0) invert(1); }
.pec-mobile-menu__close {
  width: 44px; height: 44px; padding: 0;
  background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--pec-r);
  color: #fff; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
}
.pec-mobile-menu__nav { display: flex; flex-direction: column; flex: 1; margin-bottom: 32px; }
.pec-mobile-menu__nav > a,
.pec-mobile-menu__drop > summary {
  font-family: 'Montserrat', sans-serif;
  font-weight: 700; font-size: 20px;
  color: #fff;
  padding: 18px 4px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  cursor: pointer;
  list-style: none;
  display: flex; align-items: center; justify-content: space-between;
  letter-spacing: -0.01em;
}
.pec-mobile-menu__nav > a:hover,
.pec-mobile-menu__drop > summary:hover { color: var(--pec-sky); }
.pec-mobile-menu__drop > summary::-webkit-details-marker { display: none; }
.pec-mobile-menu__drop > summary::after {
  content: ""; width: 10px; height: 10px;
  border-right: 2px solid currentColor; border-bottom: 2px solid currentColor;
  transform: rotate(45deg);
  transition: transform .3s var(--pec-ease);
  flex: 0 0 auto;
}
.pec-mobile-menu__drop[open] > summary::after { transform: rotate(-135deg); }
.pec-mobile-menu__drop[open] > summary { color: var(--pec-sky); }
.pec-mobile-menu__sub { padding: 8px 0 12px 12px; display: flex; flex-direction: column; }
.pec-mobile-menu__sub a {
  font-family: 'DM Sans', sans-serif;
  font-size: 16px; font-weight: 500;
  color: #B8CDDE;
  padding: 12px 0;
  border-left: 2px solid rgba(127,184,214,0.25);
  padding-left: 16px;
}
.pec-mobile-menu__sub a:hover { color: #fff; border-left-color: var(--pec-accent); }
.pec-mobile-menu__cta { display: flex; flex-direction: column; gap: 12px; }
.pec-mobile-menu__cta .pec-btn { width: 100%; justify-content: center; }

body.pec-menu-open { overflow: hidden; }

/* ================================================
   RESPONSIVE BREAKPOINTS
================================================ */

/* Tablet landscape and down */
@media (max-width: 1100px) {
  .pec-hero__grid { grid-template-columns: 1fr; gap: 48px; }
  .pec-hero__media { max-width: 560px; margin: 0 auto; width: 100%; }
  .pec-trustbar { grid-template-columns: repeat(2, 1fr); }
  .pec-trustbar__item:nth-child(2) { border-right: none; }
  .pec-trustbar__item:nth-child(1), .pec-trustbar__item:nth-child(2) { border-bottom: 1px solid var(--pec-line); }
  .pec-how__grid { grid-template-columns: 1fr; }
  .pec-why__grid { grid-template-columns: repeat(2, 1fr); }
  .pec-whycard { grid-column: span 1; }
  .pec-whycard--lead { grid-column: span 2; }
  .pec-whycard--cta { grid-column: span 2; }
  .pec-services__grid { grid-template-columns: repeat(2, 1fr); border-radius: var(--pec-r-lg); }
  .pec-svc:nth-child(3n) { border-right: 1px solid var(--pec-line); }
  .pec-svc:nth-child(2n) { border-right: none; }
  .pec-svc:nth-last-child(-n+3) { border-bottom: 1px solid var(--pec-line); }
  .pec-svc:nth-last-child(-n+2) { border-bottom: none; }
  .pec-tele__grid { grid-template-columns: 1fr; gap: 36px; }
  .pec-animal { flex: 1 1 calc(33.333% - 16px); min-width: 150px; }
  .pec-reviews__grid { grid-template-columns: repeat(2, 1fr); }
  .pec-area__grid { grid-template-columns: 1fr; gap: 36px; }
  .pec-area__cities { padding-top: 0; }
  .pec-faq__grid { grid-template-columns: 1fr; gap: 36px; }
  .pec-faq__head { position: static; }
  .pec-final__grid { grid-template-columns: 1fr; gap: 48px; }
  .pec-footer__grid { grid-template-columns: repeat(2, 1fr); }
  .pec-nav__links { display: none; }
  .pec-nav__burger { display: inline-flex; }
  .pec-empathy__grid { grid-template-columns: 1fr; gap: 36px; }
  .pec-empathy__media { max-width: 560px; margin: 0 auto; width: 100%; }
  .pec-animals__feature { grid-template-columns: 1fr; gap: 32px; }
  .pec-animals__hero { aspect-ratio: 4/3; max-width: 600px; margin: 0 auto; }
}

/* Narrower desktop: condense the address pill so the nav doesn't overflow */
@media (max-width: 1500px) {
  .pec-btn--address__lines { display: none; }
  .pec-btn--address::after {
    content: "Directions";
    font-weight: 800; color: var(--pec-ink); font-size: 13px;
    letter-spacing: -0.005em;
  }
  .pec-btn--address { padding: 8px 14px 8px 12px; }
  .pec-nav__inner { gap: 20px; }
}
@media (max-width: 1080px) {
  .pec-btn--address { display: none; }
}

/* Small tablet / large phone */
@media (max-width: 900px) {
  :root {
    --pec-sec-pad-y: 72px;
    --pec-pad: 20px;
  }
  .pec-nav__inner { padding: 12px 16px; gap: 16px; }
  .pec-nav__cta .pec-btn--phone span { display: none; }
  .pec-nav__cta .pec-btn--phone { padding: 8px 10px; }
  .pec-logo__img { height: 32px; }
  .pec-logo__tag { display: none; }
  .pec-openstrip { font-size: 12px; padding: 7px 14px; }
  .pec-section-head { margin-bottom: 40px; }
  .pec-hero__cta .pec-btn,
  .pec-final__cta .pec-btn { flex: 1 1 auto; }
  .pec-why__grid { border-radius: var(--pec-r-lg); }
  .pec-contact-card { padding: 28px; }
  .pec-footer { padding: 48px 0 20px; }
}

/* Mobile */
@media (max-width: 640px) {
  :root {
    --pec-sec-pad-y: 56px;
  }
  body { font-size: 16px; }
  .pec-logo__tag { display: none; }
  .pec-openstrip { font-size: 11px; padding: 6px 12px; }
  .pec-nav__cta { gap: 8px; }
  .pec-nav__cta .pec-btn--sm { display: none; }
  .pec-hero { padding-top: 40px; }
  .pec-hero__cta { flex-direction: column; width: 100%; gap: 10px; margin-bottom: 28px; }
  .pec-hero__cta .pec-btn { width: 100%; justify-content: center; }
  .pec-hero__eyebrow { font-size: 12px; padding: 6px 12px; }
  .pec-hero__badge { left: 16px; right: 16px; bottom: 16px; max-width: none; padding: 14px 16px; }
  .pec-hero__badge-big { font-size: 18px; }
  .pec-trustbar { grid-template-columns: 1fr; }
  .pec-trustbar__item { border-right: none !important; border-bottom: 1px solid var(--pec-line); padding: 20px 18px; }
  .pec-trustbar__item:last-child { border-bottom: none; }
  .pec-empathy__body { font-size: 16px; }
  .pec-empathy__body p { margin-bottom: 20px; }
  .pec-step { padding: 28px 24px; }
  .pec-step h3 { font-size: 20px; }
  .pec-why__grid { grid-template-columns: 1fr; }
  .pec-whycard, .pec-whycard--lead, .pec-whycard--cta { grid-column: span 1; padding: 28px 24px; }
  .pec-whycard--lead h3 { font-size: 26px; }
  .pec-whycard__cta-big { font-size: 28px; }
  .pec-services__grid { grid-template-columns: 1fr; }
  .pec-svc { padding: 28px 24px; border-right: none !important; }
  .pec-svc h3 { font-size: 20px; }
  .pec-tele__credit { padding: 18px 20px; font-size: 15px; }
  .pec-tele__side-head { margin: 22px 22px 18px; }
  .pec-tele__side .pec-tele__list { padding: 0 22px 22px; }
  .pec-animals__grid { gap: 12px; }
  .pec-animal { flex: 1 1 calc(50% - 12px); min-width: 0; padding: 10px 10px 14px; }
  .pec-reviews__grid { grid-template-columns: 1fr; }
  .pec-review { padding: 24px; }
  .pec-faq__q { font-size: 16px; gap: 12px; }
  .pec-faq__item { padding: 20px 0; }
  .pec-faq__item--open .pec-faq__a { padding-left: 28px; font-size: 15px; }
  .pec-final__h { font-size: clamp(24px, 6.5vw, 34px); }
  .pec-final__cta { flex-direction: column; width: 100%; gap: 10px; }
  .pec-final__cta .pec-btn { width: 100%; justify-content: center; }
  .pec-contact-card { padding: 24px; }
  .pec-footer__grid { grid-template-columns: 1fr; gap: 32px; }
  .pec-footer__bottom { flex-direction: column; gap: 8px; text-align: center; }
  .pec-bleed__img { border-radius: var(--pec-r-lg); }
  .pec-preloader__logo { height: 36px; }
  .pec-preloader__ecg { width: 200px; height: 40px; }
  .pec-preloader__label { font-size: 10px; letter-spacing: 0.18em; }
  .pec-mobile-menu__nav > a,
  .pec-mobile-menu__drop > summary { font-size: 18px; padding: 16px 4px; }
  .pec-section-head { margin-bottom: 32px; }
  .pec-section-head__sub { font-size: 16px; }
}

/* ================================================
   SCROLL REVEAL + MICRO-INTERACTIONS
================================================ */
.pec-reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .8s var(--pec-ease), transform .8s var(--pec-ease);
  will-change: opacity, transform;
}
.pec-reveal.is-in {
  opacity: 1;
  transform: translateY(0);
}
.pec-reveal[data-delay="1"] { transition-delay: 0.08s; }
.pec-reveal[data-delay="2"] { transition-delay: 0.16s; }
.pec-reveal[data-delay="3"] { transition-delay: 0.24s; }
.pec-reveal[data-delay="4"] { transition-delay: 0.32s; }
.pec-reveal[data-delay="5"] { transition-delay: 0.4s; }
.pec-reveal[data-delay="6"] { transition-delay: 0.48s; }

/* Intro animation for hero copy */
.pec-hero__copy > * { animation: pec-hero-in 0.9s var(--pec-ease) both; }
.pec-hero__copy > *:nth-child(1) { animation-delay: .05s; }
.pec-hero__copy > *:nth-child(2) { animation-delay: .15s; }
.pec-hero__copy > *:nth-child(3) { animation-delay: .25s; }
.pec-hero__copy > *:nth-child(4) { animation-delay: .35s; }
.pec-hero__copy > *:nth-child(5) { animation-delay: .45s; }
@keyframes pec-hero-in {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Animated underline for nav links — replaces the earlier scaleX */
.pec-nav__links a::after { transition: transform .35s var(--pec-ease); }

/* Reduce motion for users who prefer it */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  .pec-reveal { opacity: 1; transform: none; }
}

/* Smooth anchor scroll */
html { scroll-behavior: smooth; scroll-padding-top: 120px; }

/* ================================================
   PRELOADER — branded, heartbeat ECG trace
================================================ */
.pec-preloader {
  position: fixed; inset: 0; z-index: 9999;
  background: radial-gradient(ellipse at 50% 40%, #0E3A5F 0%, #07213A 70%, #061628 100%);
  display: flex; align-items: center; justify-content: center;
  transition: opacity .45s var(--pec-ease), visibility .45s;
}
.pec-preloader--hidden { opacity: 0; visibility: hidden; pointer-events: none; }
.pec-preloader__inner {
  display: flex; flex-direction: column; align-items: center; gap: 24px;
  animation: pec-preloader-in .6s var(--pec-ease) both;
}
@keyframes pec-preloader-in {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}
.pec-preloader__logo {
  height: 44px; width: auto;
  filter: brightness(0) invert(1);
  animation: pec-preloader-breathe 1.8s ease-in-out infinite;
}
@keyframes pec-preloader-breathe {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: 0.75; transform: scale(0.97); }
}
.pec-preloader__ecg {
  width: 260px; height: 48px;
  overflow: visible;
}
.pec-preloader__ecg path.track {
  stroke: rgba(127,184,214,0.18);
  stroke-width: 2;
  fill: none;
}
.pec-preloader__ecg path.trace {
  stroke: var(--pec-accent);
  stroke-width: 2.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  fill: none;
  stroke-dasharray: 70 300;
  animation: pec-ecg-sweep 1.6s linear infinite;
  filter: drop-shadow(0 0 6px rgba(196,30,42,0.6));
}
@keyframes pec-ecg-sweep {
  from { stroke-dashoffset: 370; }
  to   { stroke-dashoffset: 0; }
}
.pec-preloader__label {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px; font-weight: 700; letter-spacing: 0.22em; text-transform: uppercase;
  color: rgba(217,231,242,0.55);
}
@media (prefers-reduced-motion: reduce) {
  .pec-preloader__logo { animation: none; }
  .pec-preloader__ecg path.trace { animation: none; stroke-dasharray: none; }
}

/* ================================================
   PATIENTS MARQUEE — continuous photo strip
================================================ */
.pec-marquee {
  padding: 72px 0 80px;
  background: #fff;
  overflow: hidden;
  position: relative;
}
.pec-marquee__head {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 40px;
  padding: 0 var(--pec-pad);
}
.pec-marquee__head .pec-eyebrow { justify-content: center; }
.pec-marquee__head h2 {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(24px, 2.4vw, 32px); font-weight: 800;
  letter-spacing: -0.02em; line-height: 1.2;
  color: var(--pec-ink); margin: 0;
}
.pec-marquee__viewport {
  position: relative;
  overflow: hidden;
  -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 6%, #000 94%, transparent 100%);
          mask-image: linear-gradient(90deg, transparent 0, #000 6%, #000 94%, transparent 100%);
}
.pec-marquee__strip {
  display: flex;
  width: max-content;
  gap: 20px;
  animation: pec-marquee-scroll 50s linear infinite;
  will-change: transform;
}
.pec-marquee__viewport:hover .pec-marquee__strip { animation-play-state: paused; }
.pec-marquee__item {
  flex: 0 0 auto;
  width: 220px; height: 220px;
  border-radius: var(--pec-r-lg);
  overflow: hidden;
  background: var(--pec-sky-bg);
  box-shadow: var(--pec-shadow-sm);
  position: relative;
  transition: transform .4s var(--pec-ease);
}
.pec-marquee__item:hover { transform: translateY(-4px); }
.pec-marquee__item img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.pec-marquee__caption {
  position: absolute; left: 12px; bottom: 12px;
  font-family: 'Montserrat', sans-serif;
  font-size: 11px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase;
  color: #fff;
  background: rgba(7,33,58,0.6);
  backdrop-filter: blur(4px);
  padding: 5px 10px; border-radius: 100px;
}
@keyframes pec-marquee-scroll {
  from { transform: translate3d(0, 0, 0); }
  to   { transform: translate3d(-50%, 0, 0); }
}
@media (max-width: 900px) {
  .pec-marquee { padding: 56px 0 64px; }
  .pec-marquee__item { width: 180px; height: 180px; }
  .pec-marquee__strip { animation-duration: 38s; gap: 16px; }
  .pec-marquee__head { margin-bottom: 28px; }
}
@media (max-width: 640px) {
  .pec-marquee { padding: 48px 0 56px; }
  .pec-marquee__item { width: 144px; height: 144px; border-radius: var(--pec-r); }
  .pec-marquee__strip { animation-duration: 30s; gap: 12px; }
  .pec-marquee__caption { font-size: 9px; padding: 4px 8px; left: 8px; bottom: 8px; }
}
@media (prefers-reduced-motion: reduce) {
  .pec-marquee__strip { animation: none; }
  .pec-marquee__viewport {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
  }
  .pec-marquee__item { scroll-snap-align: start; }
}

/* ================================================
   EDITORIAL IMAGERY
================================================ */
.pec-frame-img { width: 100%; height: 100%; display: block; object-fit: cover; position: absolute; inset: 0; }

.pec-bleed {
  position: relative;
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 var(--pec-pad);
}
.pec-bleed__img {
  display: block;
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
  border-radius: var(--pec-r-xl);
  box-shadow: var(--pec-shadow);
}
.pec-bleed--tall .pec-bleed__img { aspect-ratio: 3/2; }

/* Section-side imagery for two-column layouts */
.pec-side-img {
  width: 100%;
  aspect-ratio: 4/5;
  object-fit: cover;
  border-radius: var(--pec-r-xl);
  box-shadow: var(--pec-shadow);
  display: block;
}
.pec-side-img--wide { aspect-ratio: 3/2; }
