/* ============================================================
   Jeanette's Pet Grooming — Homepage sections
   ============================================================ */

/* ---------- Hero ---------- */
.hero {
  position: relative; overflow: hidden;
  padding: calc(var(--header-h) + clamp(40px, 7vw, 80px)) 0 clamp(56px, 8vw, 100px);
  background:
    radial-gradient(1000px 500px at 90% -15%, var(--coral-tint) 0%, transparent 55%),
    radial-gradient(800px 480px at -10% 105%, var(--teal-tint) 0%, transparent 55%),
    var(--cream);
}
.hero-grid {
  display: grid; grid-template-columns: 1.05fr 1fr; gap: clamp(32px, 5vw, 64px);
  align-items: center; position: relative; z-index: 1;
}
.hero-badge {
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--white); border-radius: 999px; padding: 9px 18px 9px 12px;
  font-family: var(--font-display); font-weight: 500; font-size: .92rem;
  box-shadow: var(--shadow-sm); margin-bottom: 22px;
}
.hero-badge .stars svg { width: 15px; height: 15px; }
.hero h1 .accent { color: var(--coral); }
.hero .lede { font-size: clamp(1.1rem, 1.6vw, 1.3rem); max-width: 50ch; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin: 30px 0 26px; }
.hero-trust { display: flex; align-items: center; gap: 14px; color: var(--ink-soft); font-size: .95rem; }
.hero-trust strong { color: var(--ink); font-family: var(--font-display); font-weight: 500; }

.hero-photo { position: relative; }
.hero-photo > img {
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  aspect-ratio: 5/4; object-fit: cover; width: 100%;
}
.hero-card {
  position: absolute; left: -26px; bottom: 30px;
  background: var(--white); border-radius: var(--radius);
  box-shadow: var(--shadow); padding: 16px 22px;
  display: flex; align-items: center; gap: 14px;
}
.hero-card .ico {
  width: 46px; height: 46px; border-radius: 50%; flex: none;
  background: var(--teal-tint); display: grid; place-items: center;
}
.hero-card .ico svg { width: 24px; height: 24px; fill: var(--teal-deep); }
.hero-card strong { font-family: var(--font-display); font-weight: 600; display: block; line-height: 1.2; }
.hero-card span { font-size: .85rem; color: var(--ink-soft); }
.hero-paw {
  position: absolute; width: clamp(160px, 22vw, 280px); height: auto;
  fill: var(--coral); opacity: .08; pointer-events: none;
}
.hero-paw--1 { top: 6%; left: 42%; transform: rotate(-20deg); }

/* ---------- Trust band ---------- */
.trust-band { background: var(--white); box-shadow: var(--shadow-sm); position: relative; z-index: 2; }
.trust-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; padding: 34px 0; }
.trust-item { display: flex; align-items: center; gap: 14px; }
.trust-item .ico { width: 50px; height: 50px; border-radius: 16px; flex: none; background: var(--coral-tint); display: grid; place-items: center; }
.trust-item .ico svg { width: 26px; height: 26px; fill: var(--coral-deep); }
.trust-item strong { font-family: var(--font-display); font-weight: 600; font-size: 1.25rem; display: block; line-height: 1.15; }
.trust-item span { font-size: .9rem; color: var(--ink-soft); }

/* ---------- Services preview ---------- */
.service-card { display: flex; flex-direction: column; }
.service-card .card-body { display: flex; flex-direction: column; flex: 1; }
.service-card .card-link { margin-top: auto; }
.price-from { font-family: var(--font-display); font-weight: 600; color: var(--teal-deep); font-size: .95rem; }

/* ---------- About / Jeanette split ---------- */
.about-split { display: grid; grid-template-columns: 1fr 1.1fr; gap: clamp(36px, 6vw, 70px); align-items: center; }
.about-photo { position: relative; }
.about-photo img { border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); aspect-ratio: 3/4; object-fit: cover; width: 100%; }
.about-photo .hand-note {
  position: absolute; right: -10px; bottom: -16px; transform: rotate(-4deg);
  background: var(--white); border-radius: var(--radius-sm); box-shadow: var(--shadow);
  padding: 12px 20px; font-family: var(--font-hand); font-size: 1.35rem; color: var(--coral-deep);
}
.about-checks { list-style: none; padding: 0; margin: 22px 0 28px; display: flex; flex-direction: column; gap: 13px; }
.about-checks li { display: flex; gap: 12px; align-items: flex-start; }
.about-checks svg { width: 24px; height: 24px; flex: none; fill: var(--teal); margin-top: 2px; }

/* ---------- Process ---------- */
.process-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.process-step { background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow-sm); padding: 30px 26px; position: relative; }
.process-num {
  width: 52px; height: 52px; border-radius: 50%; background: var(--coral);
  color: #fff; font-family: var(--font-display); font-weight: 600; font-size: 1.3rem;
  display: grid; place-items: center; margin-bottom: 18px; box-shadow: 0 6px 16px rgba(232,96,76,.3);
}
.process-step:nth-child(even) .process-num { background: var(--teal); box-shadow: 0 6px 16px rgba(31,122,112,.3); }
.process-step h3 { font-size: 1.18rem; }
.process-step p { color: var(--ink-soft); font-size: .97rem; margin: 0; }

/* ---------- Reviews preview ---------- */
.google-pill {
  display: inline-flex; align-items: center; gap: 10px; background: var(--white);
  border-radius: 999px; padding: 10px 20px; box-shadow: var(--shadow-sm);
  font-family: var(--font-display); font-weight: 500;
}

/* ---------- Gallery strip ---------- */
.gallery-strip { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.gallery-strip a { border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-sm); display: block; }
.gallery-strip img { aspect-ratio: 1/1; object-fit: cover; width: 100%; transition: transform .4s ease; }
.gallery-strip a:hover img { transform: scale(1.06); }

/* ---------- Visit / map ---------- */
.visit-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px, 5vw, 56px); align-items: start; }
.visit-info { display: flex; flex-direction: column; gap: 20px; }
.visit-row { display: flex; gap: 16px; align-items: flex-start; background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow-sm); padding: 22px 24px; }
.visit-row .ico { width: 48px; height: 48px; border-radius: 14px; flex: none; background: var(--teal-tint); display: grid; place-items: center; }
.visit-row .ico svg { width: 24px; height: 24px; fill: var(--teal-deep); }
.visit-row strong { font-family: var(--font-display); font-weight: 600; display: block; margin-bottom: 3px; }
.visit-row a { color: var(--teal-deep); }
.visit-map iframe, .visit-map img { width: 100%; border: 0; border-radius: var(--radius-lg); box-shadow: var(--shadow); min-height: 420px; object-fit: cover; }

/* ---------- Responsive ---------- */
@media (max-width: 1020px) {
  .hero-grid { grid-template-columns: 1fr; }
  .hero-photo { max-width: 620px; }
  .hero-card { left: 12px; }
  .trust-grid { grid-template-columns: repeat(2, 1fr); }
  .process-grid { grid-template-columns: repeat(2, 1fr); }
  .about-split { grid-template-columns: 1fr; }
  .about-photo { max-width: 460px; }
  .gallery-strip { grid-template-columns: repeat(2, 1fr); }
  .visit-grid { grid-template-columns: 1fr; }
}
@media (max-width: 680px) {
  .trust-grid { grid-template-columns: 1fr 1fr; gap: 18px; }
  .trust-item { flex-direction: column; align-items: flex-start; gap: 10px; }
  .process-grid { grid-template-columns: 1fr; }
  .hero-card { padding: 12px 16px; }
}
