/* ==========================================================================
   MingHwee SG Landing - Page-specific styles
   Apple-inspired polish. Consumes the new shared.css design system.
   ========================================================================== */

/* ==========================================================================
   HERO - Apple-style hero wrap (scoped to SG only)
   ========================================================================== */
#apple-style-hero-wrap {
  background:
    radial-gradient(ellipse 90% 70% at 18% 5%, rgba(12,124,212,.42), transparent 55%),
    radial-gradient(ellipse 70% 55% at 88% 12%, rgba(15,161,255,.32), transparent 55%),
    radial-gradient(ellipse 100% 80% at 50% 115%, rgba(255,255,255,.6), transparent 60%),
    linear-gradient(165deg, #cfe6f5 0%, #d6e9f4 40%, #e9f2f9 75%, #f8fbfd 100%) !important;
  padding: 140px 24px 0 !important;
  text-align: center !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  width: 100% !important;
  overflow: hidden !important;
  position: relative !important;
  border-bottom: 1px solid rgba(12,124,212,.08) !important;
}
#apple-style-hero-wrap::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:linear-gradient(90deg, rgba(12,40,90,.06) 1px, transparent 1px),
                   linear-gradient(0deg, rgba(12,40,90,.06) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse 75% 60% at 50% 40%, #000 35%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse 75% 60% at 50% 40%, #000 35%, transparent 75%);
  pointer-events:none;
  z-index:0 !important;
}
#apple-style-hero-wrap > *{position:relative;z-index:1 !important}

.hero-rating {
  background: rgba(255, 255, 255, 0.8) !important;
  backdrop-filter: blur(8px) !important;
  -webkit-backdrop-filter: blur(8px) !important;
  padding: 8px 16px !important;
  border-radius: 50px !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05) !important;
  border: 1px solid rgba(255, 255, 255, 0.5) !important;
  margin-bottom: 24px !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  color: #0f172a !important;
  max-width: 92% !important;
}

.hero-rating .stars {
  color: #0c7cd4;
  letter-spacing: 1px;
}

.hero-title {
  font-family: 'Inter', system-ui, -apple-system, sans-serif !important;
  font-size: 58px !important;
  font-weight: 800 !important;
  letter-spacing: -0.025em !important;
  color: #0f172a !important;
  max-width: 900px !important;
  margin: 0 0 20px !important;
  line-height: 1.05 !important;
}

.hero-subtitle {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 22px !important;
  font-weight: 500 !important;
  color: #334155 !important;
  max-width: 720px !important;
  margin: 0 0 16px !important;
  line-height: 1.45 !important;
}

.hero-stats {
  font-size: 16px !important;
  color: #475569 !important;
  margin: 0 0 36px !important;
  font-weight: 600 !important;
}

.hero-stats strong {
  color: #0c7cd4;
  font-weight: 800;
}

.hero-actions {
  display: flex !important;
  gap: 16px !important;
  justify-content: center !important;
  margin-bottom: 20px !important;
  width: 100% !important;
  max-width: 720px !important;
}

.hero-actions .btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  padding: 16px 32px !important;
  border-radius: 980px !important;
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1) !important;
  flex: 1 !important;
  white-space: nowrap !important;
  cursor: pointer !important;
  text-decoration: none !important;
  line-height: 1 !important;
}

.hero-actions .btn-primary {
  background: #0c7cd4 !important;
  color: #fff !important;
  border: 2px solid #0c7cd4 !important;
  box-shadow: 0 4px 14px 0 rgba(12, 124, 212, 0.39) !important;
}

.hero-actions .btn-primary:hover {
  background: #0fa1ff !important;
  border-color: #0fa1ff !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 20px rgba(12, 124, 212, 0.4) !important;
}

.hero-actions .btn-secondary {
  background: #fff !important;
  color: #0b0a14 !important;
  border: 2px solid #0b0a14 !important;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.1) !important;
}

.hero-actions .btn-secondary:hover {
  background: #f8fafc !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.18) !important;
}

.response-indicator {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  font-size: 14px !important;
  color: #475569 !important;
  font-weight: 600 !important;
  margin-bottom: 40px !important;
  background: rgba(255, 255, 255, 0.6) !important;
  padding: 6px 14px !important;
  border-radius: 50px !important;
  border: 1px solid rgba(255, 255, 255, 0.5) !important;
}

.pulse-dot {
  display: block !important;
  width: 10px !important;
  height: 10px !important;
  background: #0c7cd4 !important;
  border-radius: 50% !important;
  animation: pulse-green 2s infinite !important;
}

@keyframes pulse-green {
  0%   { box-shadow: 0 0 0 0 rgba(37, 211, 102, 0.7); }
  70%  { box-shadow: 0 0 0 8px rgba(37, 211, 102, 0); }
  100% { box-shadow: 0 0 0 0 rgba(37, 211, 102, 0); }
}

.hero-image-container {
  width: 100% !important;
  max-width: 1000px !important;
  margin: 0 auto !important;
  display: flex !important;
  justify-content: center !important;
  align-items: flex-end !important;
}

.hero-image-container img {
  width: 100% !important;
  height: auto !important;
  max-width: 820px !important;
  display: block !important;
  object-fit: contain !important;
  filter: drop-shadow(0 20px 40px rgba(0, 0, 0, 0.12)) !important;
  border-radius: 24px !important;
}

@media (max-width: 768px) {
  #apple-style-hero-wrap {
    padding: 100px 20px 0 !important;
  }
  .hero-title { font-size: 40px !important; }
  .hero-subtitle { font-size: 17px !important; }
  .hero-actions {
    flex-direction: column !important;
  }
  .hero-actions .btn {
    width: 100% !important;
  }
  .hero-image-container img {
    border-radius: 24px !important;
  }
}

@media (max-width: 480px) {
  .hero-title { font-size: 34px !important; }
  .hero-rating { font-size: 13px !important; }
}

/* ==========================================================================
   SECTION HEADERS (page-level helpers)
   ========================================================================== */
.sg-section-hd {
  text-align: center;
  max-width: 780px;
  margin: 0 auto 56px;
}

.sg-eyebrow {
  display: inline-block;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #0c7cd4;
  margin-bottom: 14px;
}

.sg-section-hd h2 {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: clamp(32px, 4vw, 46px);
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #0f172a;
  line-height: 1.1;
  margin: 0 0 16px;
}

.sg-section-hd p {
  font-size: 18px;
  line-height: 1.55;
  color: #475569;
  margin: 0;
}

/* ==========================================================================
   WHY CHOOSE - 4-pillar cards
   ========================================================================== */
.why-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}

.why-card {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 24px;
  padding: 32px 24px;
  text-align: left;
  transition: transform 0.3s cubic-bezier(0.25, 0.8, 0.25, 1), box-shadow 0.3s;
}

.why-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(12, 124, 212, 0.12);
  border-color: transparent;
}

.why-icon {
  width: 56px;
  height: 56px;
  border-radius: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
  color: #fff;
}

.why-icon.bg-blue  { background: linear-gradient(135deg, #0c7cd4, #0fa1ff); }
.why-icon.bg-green { background: linear-gradient(135deg, #0a5fa3, #0c7cd4); }
.why-icon.bg-amber { background: linear-gradient(135deg, #0c7cd4, #0fa1ff); }
.why-icon.bg-red   { background: linear-gradient(135deg, #b91c1c, #dc0404); }

.why-card h3 {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 19px;
  font-weight: 700;
  color: #0f172a;
  margin: 0 0 10px;
  line-height: 1.3;
}

.why-card p {
  font-size: 15px;
  color: #475569;
  line-height: 1.55;
  margin: 0;
}

/* ==========================================================================
   HELPER TYPES - 3 card grid
   ========================================================================== */
.helper-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}

.helper-card {
  background: #fff;
  border-radius: 24px;
  overflow: hidden;
  border: 1px solid #e2e8f0;
  display: flex;
  flex-direction: column;
  transition: transform 0.3s cubic-bezier(0.25, 0.8, 0.25, 1), box-shadow 0.3s;
}

.helper-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 24px 50px rgba(15, 23, 42, 0.12);
}

.helper-card-img {
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: #f1f5f9;
}

.helper-card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top; /* keep heads in frame — never crop the top */
  display: block;
  transition: transform 0.5s cubic-bezier(0.25, 0.8, 0.25, 1);
}

.helper-card:hover .helper-card-img img {
  transform: scale(1.04);
}

.helper-card-body {
  padding: 26px 24px 28px;
  display: flex;
  flex-direction: column;
  flex: 1;
}

.helper-card-body h3 {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 22px;
  font-weight: 800;
  color: #0f172a;
  margin: 0 0 6px;
}

.helper-tagline {
  font-size: 14px;
  font-weight: 600;
  color: #0c7cd4;
  margin: 0 0 18px;
  letter-spacing: 0.3px;
}

.helper-traits {
  list-style: none;
  padding: 0;
  margin: 0 0 24px;
  flex: 1;
}

.helper-traits li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 6px 0;
  font-size: 15px;
  color: #334155;
  line-height: 1.45;
}

.helper-traits svg {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  color: #0c7cd4;
  margin-top: 2px;
}

.helper-select-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 13px 22px;
  background: #fff;
  color: #0c7cd4;
  border: 2px solid #0c7cd4;
  border-radius: 980px;
  font-family: 'Inter', sans-serif;
  font-weight: 700;
  font-size: 15px;
  cursor: pointer;
  transition: all 0.25s cubic-bezier(0.25, 0.8, 0.25, 1);
  text-decoration: none;
}

.helper-select-btn:hover {
  background: #0c7cd4;
  color: #fff;
  transform: translateY(-1px);
  box-shadow: 0 6px 16px rgba(12, 124, 212, 0.3);
}

/* ==========================================================================
   HOW IT WORKS - 5-step timeline
   ========================================================================== */
.steps-wrap {
  position: relative;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 20px;
  max-width: 1100px;
  margin: 0 auto;
}

.steps-wrap::before {
  content: '';
  position: absolute;
  top: 32px;
  left: 10%;
  right: 10%;
  height: 2px;
  background-image: linear-gradient(to right, #cbd5e1 50%, transparent 50%);
  background-size: 12px 2px;
  background-repeat: repeat-x;
  z-index: 0;
}

.step {
  position: relative;
  text-align: center;
  padding: 0 8px;
  z-index: 1;
}

.step-num {
  width: 64px;
  height: 64px;
  margin: 0 auto 18px;
  border-radius: 50%;
  background: linear-gradient(135deg, #0c7cd4, #0fa1ff);
  color: #fff;
  font-family: 'Inter', sans-serif;
  font-weight: 800;
  font-size: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 8px 20px rgba(12, 124, 212, 0.3);
  border: 4px solid #fff;
}

.step h4 {
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: #0f172a;
  margin: 0 0 8px;
  line-height: 1.3;
}

.step p {
  font-size: 14px;
  color: #64748b;
  line-height: 1.5;
  margin: 0;
}

.steps-cta-wrap {
  text-align: center;
  margin-top: 48px;
}

/* ==========================================================================
   SERVICES - 5 card grid
   ========================================================================== */
.services-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 20px;
}

.service-card {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 20px;
  padding: 28px 22px;
  text-align: left;
  transition: transform 0.3s cubic-bezier(0.25, 0.8, 0.25, 1), box-shadow 0.3s, border-color 0.3s;
}

.service-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 36px rgba(15, 23, 42, 0.1);
  border-color: #bfdbfe;
}

.service-icon {
  width: 48px;
  height: 48px;
  border-radius: 16px;
  background: #e0f2fe;
  color: #0c7cd4;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
}

.service-card h4 {
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: #0f172a;
  margin: 0 0 8px;
  line-height: 1.3;
}

.service-card p {
  font-size: 14px;
  color: #64748b;
  line-height: 1.5;
  margin: 0 0 14px;
}

.service-link {
  font-size: 14px;
  font-weight: 700;
  color: #0c7cd4;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  transition: color 0.2s;
}

.service-link:hover { color: #0fa1ff; }

/* ==========================================================================
   PRICING TABLE
   ========================================================================== */
.pricing-table-wrap {
  max-width: 980px;
  margin: 0 auto;
  border-radius: 20px;
  overflow: hidden;
  border: 1px solid #e2e8f0;
  box-shadow: 0 10px 30px rgba(15, 23, 42, 0.06);
  background: #fff;
}

.pricing-table {
  width: 100%;
  border-collapse: collapse;
  font-family: 'Inter', sans-serif;
}

.pricing-table thead th {
  background: #0b0a14;
  color: #fff;
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  padding: 18px 22px;
  text-align: left;
}

.pricing-table tbody td {
  padding: 18px 22px;
  font-size: 15px;
  color: #0f172a;
  border-bottom: 1px solid #eef2f6;
  line-height: 1.45;
}

.pricing-table tbody tr:last-child td {
  border-bottom: none;
}

.pricing-table tbody tr:nth-child(even) td {
  background: #f8fafc;
}

.pricing-table tbody tr:hover td {
  background: #e0f2fe;
}

.pricing-table .amt {
  font-weight: 700;
  color: #0c7cd4;
  white-space: nowrap;
}

.pricing-note {
  max-width: 820px;
  margin: 28px auto 0;
  text-align: center;
  font-size: 15px;
  color: #64748b;
  line-height: 1.6;
}

.pricing-cta-wrap {
  text-align: center;
  margin-top: 32px;
}

@media (max-width: 700px) {
  .pricing-table-wrap {
    border: none;
    box-shadow: none;
    background: transparent;
  }
  .pricing-table, .pricing-table thead, .pricing-table tbody,
  .pricing-table tr, .pricing-table td {
    display: block;
    width: 100%;
  }
  .pricing-table thead { display: none; }
  .pricing-table tr {
    background: #fff !important;
    border: 1px solid #e2e8f0;
    border-radius: 16px;
    margin-bottom: 14px;
    padding: 18px 20px;
  }
  .pricing-table tr:hover td { background: transparent; }
  .pricing-table tbody tr:nth-child(even) td { background: transparent; }
  .pricing-table td {
    padding: 6px 0;
    border: none;
    font-size: 15px;
  }
  .pricing-table td::before {
    content: attr(data-label);
    display: block;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: #64748b;
    margin-bottom: 2px;
  }
}

/* ==========================================================================
   FINAL CTA SECTION - dark navy
   ========================================================================== */
.final-cta {
  background: linear-gradient(135deg, #0b0a14 0%, #1e293b 100%);
  padding: 88px 24px;
  text-align: center;
  color: #fff;
  position: relative;
  overflow: hidden;
}

.final-cta::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(rgba(255, 255, 255, 0.06) 1.5px, transparent 1.5px);
  background-size: 28px 28px;
  pointer-events: none;
}

.final-cta-inner {
  position: relative;
  max-width: 760px;
  margin: 0 auto;
}

.final-cta h2 {
  font-family: 'Inter', sans-serif;
  font-size: clamp(32px, 4.5vw, 48px);
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #fff;
  line-height: 1.1;
  margin: 0 0 16px;
}

.final-cta p {
  font-size: 19px;
  color: #cbd5e1;
  margin: 0 0 36px;
  line-height: 1.55;
}

.final-cta-actions {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}

.final-cta-actions .sb {
  min-width: 240px;
}

/* ==========================================================================
   MODAL EXTRAS (divider + WhatsApp alt button inside modal)
   ========================================================================== */
.modal-desc {
  color: #64748b;
  margin: 0 0 24px;
  font-size: 15px;
  line-height: 1.5;
}

.modal-divider {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 22px 0 16px;
  color: #94a3b8;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 1.5px;
}

.modal-divider::before,
.modal-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: #e2e8f0;
}

.popup-wa-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  padding: 14px 20px;
  background: #0c7cd4;
  color: #fff;
  border: none;
  border-radius: 980px;
  font-family: 'Inter', sans-serif;
  font-weight: 700;
  font-size: 16px;
  text-decoration: none;
  cursor: pointer;
  transition: all 0.25s cubic-bezier(0.25, 0.8, 0.25, 1);
}

.popup-wa-btn:hover {
  background: #1ebe5b;
  transform: translateY(-1px);
  box-shadow: 0 6px 16px rgba(37, 211, 102, 0.35);
  color: #fff;
}

.sb-block { width: 100%; }

/* ==========================================================================
   HEADER - page-specific (extends shared .site-header)
   ========================================================================== */
.site-header-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 12px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.site-logo img {
  display: block;
  height: 40px;
  width: auto;
}

.site-header-right {
  display: flex;
  align-items: center;
  gap: 14px;
}

.header-phone {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: #0f172a;
  font-weight: 700;
  font-size: 15px;
  text-decoration: none;
  transition: color 0.2s;
}

.header-phone:hover { color: #0c7cd4; }

.header-phone svg { color: #0c7cd4; }

@media (max-width: 560px) {
  .header-phone .ph-text { display: none; }
  .header-phone { padding: 6px; }
}

/* ==========================================================================
   STATS / BY-THE-NUMBERS SECTION
   ========================================================================== */
.sg-stats-section{
  background:linear-gradient(180deg, #ffffff 0%, #f7fafc 100%);
}
.stats-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:24px;
}
.stat-card{
  background:#ffffff;
  border:1px solid #e2e8f0;
  border-radius:24px;
  padding:36px 28px;
  text-align:center;
  transition:transform .3s cubic-bezier(.25,.8,.25,1), box-shadow .3s, border-color .3s;
  position:relative;
  overflow:hidden;
}
.stat-card::before{
  content:"";
  position:absolute;
  top:0;left:0;right:0;
  height:3px;
  background:linear-gradient(90deg, #0c7cd4 0%, #0fa1ff 100%);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .4s ease;
}
.stat-card:hover{
  transform:translateY(-4px);
  box-shadow:0 12px 32px rgba(12,124,212,.12);
  border-color:#0c7cd4;
}
.stat-card:hover::before{transform:scaleX(1)}
.stat-num{
  font-family:'Inter',system-ui,sans-serif;
  font-size:48px;
  font-weight:800;
  letter-spacing:-0.04em;
  color:#0c7cd4;
  line-height:1;
  margin-bottom:10px;
  background:linear-gradient(135deg, #0c7cd4 0%, #0fa1ff 100%);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
}
.stat-label{
  font-size:15px;
  font-weight:700;
  color:#0f172a;
  margin-bottom:6px;
  letter-spacing:-0.005em;
}
.stat-sub{
  font-size:13px;
  color:#64748b;
  line-height:1.5;
}
@media(max-width:900px){
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:16px}
  .stat-card{padding:28px 20px}
  .stat-num{font-size:40px}
}
@media(max-width:480px){
  .stat-num{font-size:36px}
  .stat-card{padding:24px 16px}
}

/* ==========================================================================
   FOOTER - page-specific layout
   ========================================================================== */
.footer-inner {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 48px;
  padding-top: 16px;
}

.footer-brand img {
  display: block;
  margin-bottom: 14px;
}

.footer-tagline {
  font-style: italic;
  color: #0fa1ff;
  font-weight: 600;
  margin: 0 0 14px;
}

.footer-brand p {
  color: rgba(255, 255, 255, 0.7);
  font-size: 14px;
  line-height: 1.6;
  margin: 0;
}

.footer-col h4 {
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  margin: 0 0 14px;
}

.footer-col a {
  display: block;
  color: rgba(255, 255, 255, 0.7);
  text-decoration: none;
  font-size: 14px;
  padding: 4px 0;
  transition: color 0.2s;
}

.footer-col a:hover { color: #0fa1ff; }

.footer-bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  margin-top: 40px;
  padding-top: 22px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  font-size: 13px;
  color: rgba(255, 255, 255, 0.5);
}

.footer-bottom a { color: #0fa1ff; text-decoration: none; }
.footer-bottom a:hover { color: #fff; }

@media (max-width: 820px) {
  .footer-inner {
    grid-template-columns: 1fr 1fr;
    gap: 32px;
  }
}

@media (max-width: 560px) {
  .footer-inner {
    grid-template-columns: 1fr;
    gap: 28px;
  }
  .footer-bottom {
    flex-direction: column;
    text-align: center;
  }
}

/* ==========================================================================
   RESPONSIVE - grid collapses
   ========================================================================== */
@media (max-width: 1024px) {
  .why-grid     { grid-template-columns: repeat(2, 1fr); }
  .services-grid{ grid-template-columns: repeat(2, 1fr); gap: 18px; }
  .steps-wrap   { grid-template-columns: repeat(5, 1fr); gap: 12px; }
  .steps-wrap::before { left: 8%; right: 8%; }
}

@media (max-width: 768px) {
  .why-grid,
  .helper-grid,
  .services-grid { grid-template-columns: 1fr; gap: 20px; }
  .steps-wrap {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .steps-wrap::before { display: none; }
  .step { text-align: left; display: grid; grid-template-columns: auto 1fr; gap: 18px; align-items: start; }
  .step-num { margin: 0; width: 52px; height: 52px; font-size: 20px; }
  .sg-section-hd { margin-bottom: 40px; }
}

/* ==========================================================================
   REVISION v2 ADDITIONS (May 2026)
   - Why section spotlight (warmer background to make it stand out)
   - Services grid - 3 columns to fit 6 cards cleanly
   - Featured service card
   - Google rating badge
   - Initial-based testimonial avatars
   - FAQ category pills + category blocks
   - Warm footer variant
   - Multi-section household profile form
   ========================================================================== */

/* ---- Why-spotlight ---- */
.section-why-spotlight {
  background: linear-gradient(180deg, #f0f7ff 0%, #ffffff 100%);
  position: relative;
}
.section-why-spotlight::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle at 15% 0%, rgba(12,124,212,.07), transparent 45%), radial-gradient(circle at 85% 100%, rgba(220,4,4,.04), transparent 45%);
  pointer-events: none;
}
.section-why-spotlight > .container { position: relative; z-index: 1; }
.section-why-spotlight .bento-card {
  background: #ffffff;
  box-shadow: 0 6px 24px rgba(15,23,42,.06);
  border: 1px solid rgba(12,124,212,.12);
  transition: transform .3s cubic-bezier(.25,.8,.25,1), box-shadow .3s, border-color .3s;
}
.section-why-spotlight .bento-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 18px 40px rgba(12,124,212,.16);
  border-color: rgba(12,124,212,.3);
}

/* ---- Services grid: 3 columns (6 cards) ---- */
.section-services .services-grid {
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.service-card-featured {
  background: linear-gradient(135deg, #0c7cd4 0%, #0fa1ff 100%);
  color: #ffffff;
  border-color: transparent;
}
.service-card-featured h4,
.service-card-featured p { color: #ffffff; }
.service-card-featured p { color: rgba(255,255,255,.92); }
.service-card-featured .service-icon {
  background: rgba(255,255,255,.18);
  color: #ffffff;
}
.service-card-featured .service-link {
  color: #ffffff;
  background: rgba(255,255,255,.18);
  padding: 8px 14px;
  border-radius: 999px;
  border: none;
  cursor: pointer;
  font-family: inherit;
}
.service-card-featured .service-link:hover { background: rgba(255,255,255,.28); }
.service-card .service-link {
  background: transparent;
  border: none;
  padding: 0;
  cursor: pointer;
  font-family: inherit;
}
@media (max-width: 1024px) {
  .section-services .services-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .section-services .services-grid { grid-template-columns: 1fr; gap: 18px; }
}

/* ---- Google rating badge ---- */
.google-rating-badge {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  background: #ffffff;
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  padding: 14px 22px;
  margin: 0 auto 40px;
  box-shadow: 0 6px 18px rgba(15,23,42,.06);
}
.google-rating-badge .rating-line {
  font-size: 16px;
  font-weight: 700;
  color: #0f172a;
  display: flex;
  align-items: center;
  gap: 6px;
}
.google-rating-badge .rating-line strong { color: #0c7cd4; font-size: 18px; }
.google-rating-badge .rating-line .stars { color: #f59e0b; letter-spacing: 1px; }
.google-rating-badge .rating-sub {
  font-size: 13px;
  color: #64748b;
  margin-top: 2px;
}
.google-rating-badge .rating-sub a { color: #0c7cd4; text-decoration: none; font-weight: 600; }
.google-rating-badge .rating-sub a:hover { text-decoration: underline; }
.testimonials-wrapper { display: flex; flex-direction: column; align-items: center; }
.google-rating-badge { align-self: center; }

/* ---- Testimonial initial avatars ---- */
/* Suppress legacy data-initial ::before pseudo for new testimonials */
.testimonial-person-clean::before { display: none !important; }
.testimonial-avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: 'Inter', sans-serif;
  font-size: 20px;
  font-weight: 800;
  color: #ffffff;
  flex-shrink: 0;
}
.testimonial-avatar-blue   { background: linear-gradient(135deg, #0c7cd4 0%, #0fa1ff 100%); }
.testimonial-avatar-purple { background: linear-gradient(135deg, #7c3aed 0%, #a855f7 100%); }
.testimonial-avatar-orange { background: linear-gradient(135deg, #ea580c 0%, #f97316 100%); }
.testimonial-avatar-pink   { background: linear-gradient(135deg, #db2777 0%, #ec4899 100%); }
.testimonial-avatar-green  { background: linear-gradient(135deg, #059669 0%, #10b981 100%); }

/* ---- FAQ — category nav + blocks ---- */
.section-faq .container { max-width: 980px; }
.faq-cats {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
  margin: 0 0 36px;
}
.faq-cat-pill {
  font-size: 13px;
  font-weight: 600;
  color: #0c7cd4;
  background: #e0f2fe;
  border: 1px solid rgba(12,124,212,.18);
  padding: 7px 14px;
  border-radius: 999px;
  text-decoration: none;
  transition: background .2s, color .2s, transform .2s;
}
.faq-cat-pill:hover {
  background: #0c7cd4;
  color: #ffffff;
  transform: translateY(-1px);
}
.faq-cat-block { margin-bottom: 36px; scroll-margin-top: 90px; }
.faq-cat-title {
  font-family: 'Inter', sans-serif;
  font-size: 20px;
  font-weight: 800;
  color: #0c7cd4;
  margin: 0 0 16px;
  padding-bottom: 10px;
  border-bottom: 2px solid #e0f2fe;
}

/* Override shared.css faq-list 800px cap inside the new category blocks
   so the items expand to match the H3 underline width (980px container).
   Also: pad the answer <p> so the closing divider has breathing room. */
.section-faq .faq-cat-block .faq-list {
  max-width: none;
  width: 100%;
  margin: 0;
}
.section-faq .faq-q {
  padding: 20px 4px 20px 0;
  font-size: 16px;
  line-height: 1.45;
}
.section-faq .faq-a > p {
  margin: 0;
  padding: 4px 4px 28px 0;
  font-size: 15px;
  color: #334155;
  line-height: 1.75;
}
.section-faq .faq-item {
  border-bottom: 1px solid #e2e8f0;
}
.section-faq .faq-item:last-child {
  border-bottom: none;
}
.section-faq .faq-item.open .faq-q {
  color: #0c7cd4;
}
/* Tablet — keep the wider answers, but trim category title size */
@media (max-width: 900px) {
  .section-faq .container { max-width: 100%; }
  .faq-cat-title { font-size: 18px; }
  .section-faq .faq-q { font-size: 15.5px; padding: 18px 4px 18px 0; }
  .section-faq .faq-a > p { font-size: 14.5px; padding-bottom: 24px; }
}
/* Mobile — tighten further, keep readable line height, prevent any horizontal squish */
@media (max-width: 560px) {
  .section-faq .container { padding-left: 18px; padding-right: 18px; }
  .faq-cats { gap: 6px; margin-bottom: 28px; }
  .faq-cat-pill { font-size: 12px; padding: 6px 12px; }
  .faq-cat-block { margin-bottom: 28px; }
  .faq-cat-title { font-size: 16px; padding-bottom: 8px; }
  .section-faq .faq-q {
    font-size: 14.5px;
    padding: 16px 0;
    gap: 10px;
  }
  .section-faq .faq-q span {
    /* Prevent the question text from being crushed against the chevron */
    flex: 1 1 auto;
    min-width: 0;
  }
  .section-faq .faq-a > p {
    font-size: 14px;
    padding: 2px 0 22px;
    line-height: 1.7;
  }
}

/* ---- Warm footer ---- */
.site-footer-warm {
  background: linear-gradient(180deg, #1e293b 0%, #0f1a2e 100%);
  color: rgba(255,255,255,.85);
  position: relative;
}
.site-footer-warm::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, #f59e0b 0%, #0c7cd4 50%, #dc0404 100%);
}
.site-footer-warm .footer-inner {
  grid-template-columns: 1.6fr 1fr 1.4fr 0.9fr;
  gap: 40px;
  padding-top: 28px;
}
.site-footer-warm .footer-tagline {
  color: #fbbf24;
  font-size: 16px;
  letter-spacing: .2px;
}
.site-footer-warm .footer-address,
.site-footer-warm .footer-brand p { color: rgba(255,255,255,.7); font-size: 14px; line-height: 1.6; }
.site-footer-warm .footer-licence {
  color: rgba(255,255,255,.6);
  font-size: 12px;
  margin-top: 10px;
}
.site-footer-warm .footer-licence strong { color: #fbbf24; }
.site-footer-warm .footer-col h4 { color: #fbbf24; }
.site-footer-warm .footer-col a {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: rgba(255,255,255,.78);
}
.site-footer-warm .footer-col a:hover { color: #fbbf24; }
.site-footer-warm .footer-col a svg { color: #0fa1ff; flex-shrink: 0; }
.footer-hours-line {
  color: rgba(255,255,255,.78);
  font-size: 13px;
  margin: 0 0 10px;
  line-height: 1.45;
}
.footer-hours-line strong { color: #fbbf24; display: block; font-size: 12px; letter-spacing: .5px; text-transform: uppercase; margin-bottom: 2px; }
.site-footer-warm .footer-bottom { border-top-color: rgba(255,255,255,.12); }
@media (max-width: 1024px) {
  .site-footer-warm .footer-inner { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
  .site-footer-warm .footer-inner { grid-template-columns: 1fr; }
}

/* ---- Multi-section household profile form ---- */
.form-section {
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  padding: 20px 18px;
  margin-bottom: 18px;
}
.form-section-hd {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 14px;
}
.form-section-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: linear-gradient(135deg, #0c7cd4 0%, #0fa1ff 100%);
  color: #ffffff;
  font-size: 13px;
  font-weight: 800;
  flex-shrink: 0;
}
.form-section-hd h3 {
  font-family: 'Inter', sans-serif;
  font-size: 15px;
  font-weight: 800;
  color: #0f172a;
  margin: 0;
  letter-spacing: -.005em;
}
.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 10px;
}
@media (max-width: 560px) {
  .form-row { grid-template-columns: 1fr; }
}
.req { color: #dc0404; font-weight: 700; }
.checkbox-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 6px 12px;
}
.cbox {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: #334155;
  cursor: pointer;
  padding: 4px 0;
}
.cbox input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: #0c7cd4;
  cursor: pointer;
}
.form-trust-line {
  font-size: 12px;
  color: #64748b;
  text-align: center;
  margin: 10px 0 0;
  line-height: 1.5;
}
.modal-title {
  font-family: 'Inter', sans-serif;
}

/* ==========================================================================
   REVISION v4 — DESKTOP OPTIMISATION (May 2026)
   Mobile is untouched: the base .hero-inner/.hero-copy rules keep the exact
   centered vertical stack the site already had. Every layout change that
   makes the site feel "desktop-grade" is gated behind min-width:1024px.
   ========================================================================== */

/* Base wrappers — preserve the existing centered mobile stack verbatim */
.hero-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
}
.hero-copy {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
}

/* ---- Desktop split hero + roomier rhythm (≥1024px ONLY) ---- */
@media (min-width: 1024px) {
  /* Hero becomes a 2-column split: copy left, image right */
  #apple-style-hero-wrap {
    padding: 124px 40px 84px !important;
    text-align: left !important;
    min-height: auto !important;
  }
  .hero-inner {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 56px;
    max-width: 1240px;
    margin: 0 auto;
  }
  .hero-copy {
    align-items: flex-start;
    text-align: left;
    flex: 1 1 53%;
    max-width: 640px;
  }
  .hero-copy .hero-rating { margin-bottom: 22px !important; }
  .hero-copy .hero-title {
    text-align: left !important;
    max-width: none !important;
    font-size: 60px !important;
    margin-bottom: 22px !important;
  }
  .hero-copy .hero-subtitle {
    text-align: left !important;
    max-width: 560px !important;
    margin: 0 0 28px !important;
  }
  .hero-copy .hero-actions {
    justify-content: flex-start !important;
    margin: 0 0 18px !important;
    max-width: none !important;
  }
  .hero-copy .response-indicator { margin: 0 !important; }

  /* Image column — fills its half cleanly, no letterbox */
  .hero-image-container {
    flex: 1 1 45%;
    max-width: 580px !important;
    margin: 0 !important;
    align-items: center !important;
  }
  .hero-image-container img {
    max-width: 100% !important;
    width: 100% !important;
    aspect-ratio: 4 / 3;
    object-fit: cover !important;
    object-position: center 30% !important;
    border-radius: 28px !important;
    box-shadow: 0 28px 60px rgba(12, 40, 90, 0.18) !important;
  }

  /* More generous section rhythm on big screens */
  .section { padding: 96px 0; }
  .final-cta { padding-top: 96px; padding-bottom: 96px; }

  /* Let key content sections breathe wider on desktop */
  .section-services .container,
  .sg-stats-section .container { max-width: 1200px; }

  /* Testimonial card: give it a confident max-width so it isn't a thin
     ribbon floating in whitespace on wide screens */
  .testimonials-wrapper { max-width: 860px; margin-left: auto; margin-right: auto; }
}

/* ---- Very wide screens: cap hero so it never sprawls ---- */
@media (min-width: 1440px) {
  #apple-style-hero-wrap { padding-top: 132px !important; padding-bottom: 96px !important; }
  .hero-copy .hero-title { font-size: 64px !important; }
}

/* ---- Header WhatsApp link: white text on dark header, green glyph ---- */
.header-wa { color: #ffffff !important; }
.header-wa:hover { color: #25D366 !important; }
.header-wa svg { color: #25D366 !important; }

/* ==========================================================================
   REVISION v4 POLISH (May 2026) — How It Works (desktop), review marquee,
   stats count-up. Marquee + counter work all viewports; timeline polish is
   scoped to the SG "how-title" section only so PH's shared timeline is safe.
   ========================================================================== */

/* ---- 1. Review marquee (replaces testimonial carousel) ---- */
.review-marquee { position: relative; margin-top: 8px; }
.review-row {
  overflow: hidden;
  padding: 12px 0;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 7%, #000 93%, transparent);
  mask-image: linear-gradient(90deg, transparent, #000 7%, #000 93%, transparent);
}
.review-track { display: flex; gap: 20px; width: max-content; will-change: transform; }
.review-row-left .review-track  { animation: mh-marquee-left 52s linear infinite; }
.review-row-right .review-track { animation: mh-marquee-right 52s linear infinite; }
.review-marquee:hover .review-track { animation-play-state: paused; }
@keyframes mh-marquee-left  { from { transform: translateX(0); }      to { transform: translateX(-50%); } }
@keyframes mh-marquee-right { from { transform: translateX(-50%); }   to { transform: translateX(0); } }

.review-card {
  flex: 0 0 360px; width: 360px;
  background: #ffffff;
  border: 1px solid #e8edf2;
  border-radius: 18px;
  padding: 22px 22px 18px;
  box-shadow: 0 6px 20px rgba(15,23,42,.05);
}
.review-stars { color: #f59e0b; font-size: 15px; letter-spacing: 2px; margin-bottom: 10px; }
.review-text { font-size: 14.5px; line-height: 1.6; color: #1f2937; margin: 0 0 16px; font-weight: 500; }
.review-author { display: flex; align-items: center; gap: 11px; }
.review-avatar {
  width: 40px; height: 40px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  color: #fff; font-weight: 800; font-size: 16px; flex-shrink: 0;
}
.rv-blue   { background: linear-gradient(135deg,#0c7cd4,#0fa1ff); }
.rv-purple { background: linear-gradient(135deg,#7c3aed,#a855f7); }
.rv-orange { background: linear-gradient(135deg,#ea580c,#f97316); }
.rv-pink   { background: linear-gradient(135deg,#db2777,#ec4899); }
.rv-green  { background: linear-gradient(135deg,#059669,#10b981); }
.review-who { display: flex; flex-direction: column; }
.review-name { font-size: 14px; font-weight: 700; color: #0f172a; }
.review-meta { font-size: 12px; color: #64748b; }

/* Centered Google badge sandwiched between the two marquee rows */
.review-badge-center {
  text-align: center;
  padding: 26px 16px;
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  position: relative; z-index: 2;
}
.review-badge-rating { display: flex; align-items: center; gap: 10px; }
.review-badge-rating strong {
  font-size: 38px; font-weight: 800; color: #0f172a;
  font-family: 'Inter', sans-serif; letter-spacing: -.02em; line-height: 1;
}
.review-badge-rating .stars { color: #f59e0b; font-size: 22px; letter-spacing: 2px; }
.review-badge-sub { font-size: 14px; color: #475569; }
.review-badge-sub strong { color: #0f172a; font-weight: 700; }
.review-badge-link { font-size: 13px; font-weight: 600; color: #0c7cd4; text-decoration: none; margin-top: 4px; }
.review-badge-link:hover { text-decoration: underline; }

@media (prefers-reduced-motion: reduce) {
  .review-row-left .review-track, .review-row-right .review-track { animation: none; }
  .review-row { overflow-x: auto; }
}
@media (max-width: 640px) {
  .review-card { flex: 0 0 280px; width: 280px; padding: 18px; }
  .review-text { font-size: 13.5px; }
  .review-badge-rating strong { font-size: 30px; }
  .review-row-left .review-track  { animation-duration: 36s; }
  .review-row-right .review-track { animation-duration: 36s; }
}

/* ---- 2. How It Works — sleek desktop stepper (SG-scoped, >=1024px) ---- */
@media (min-width: 1024px) {
  [aria-labelledby="how-title"] .timeline-flex {
    gap: 0;
    margin-top: 60px;
    align-items: flex-start;
  }
  [aria-labelledby="how-title"] .timeline-flex::before {
    top: 30px; left: 10%; right: 10%; height: 3px;
    background: linear-gradient(90deg, #0c7cd4, #0fa1ff);
    opacity: .22; border-radius: 2px;
  }
  [aria-labelledby="how-title"] .timeline-item {
    border: none !important;
    background: transparent !important;
    padding: 0 18px !important;
    flex: 1;
    text-align: center;
  }
  [aria-labelledby="how-title"] .timeline-item .num {
    width: 60px !important; height: 60px !important;
    font-size: 23px !important;
    margin: 0 auto 20px !important;
    background: linear-gradient(135deg, #0c7cd4, #0fa1ff) !important;
    box-shadow: 0 10px 24px rgba(12,124,212,.32) !important;
    border: 5px solid #fff !important;
  }
  [aria-labelledby="how-title"] .timeline-item h4 { font-size: 16px; margin-bottom: 8px; }
  [aria-labelledby="how-title"] .timeline-item p {
    font-size: 14px; line-height: 1.55; color: #64748b;
    max-width: 210px; margin: 0 auto;
  }
}

/* ==========================================================================
   REVISION v5 — TYPEFORM ONBOARDING MODAL (May 2026)
   One reusable multi-step ("one question per screen") flow engine, rendered
   in the EXISTING site language: brand blue #0c7cd4 / #0fa1ff, accent red
   #dc0404, Inter, white cards, 16–24px radii, 980px pill buttons. It uses its
   OWN modal (.tf-modal) so the legacy .modal + shared.js are untouched.
   Self-contained; injected into <body> by sg.js.
   ========================================================================== */

/* ---- Footer entry-point links (Partner / MOM / Helper) ---- */
.footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 28px;
  padding: 22px 0 0;
  margin-top: 28px;
  border-top: 1px solid rgba(255, 255, 255, .12);
}
.footer-link-btn {
  background: none;
  border: none;
  padding: 0;
  font-family: 'Inter', sans-serif;
  font-size: 13.5px;
  font-weight: 600;
  color: rgba(255, 255, 255, .78);
  cursor: pointer;
  text-align: left;
  transition: color .2s;
  line-height: 1.5;
}
.footer-link-btn:hover { color: #fbbf24; }
@media (max-width: 560px) {
  .footer-links { flex-direction: column; gap: 12px; }
}

/* ---- Modal shell (full-screen, mirrors the legacy .modal architecture) ---- */
/* Hide the floating WhatsApp button while the typeform is open (mirrors the
   shared.css rule that hides .fwa over the legacy .modal). */
body.tf-open .fwa { display: none !important; }

.tf-modal {
  position: fixed;
  inset: 0;
  z-index: 2200;
  background: rgba(11, 10, 20, .85);
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  display: flex;
  align-items: stretch;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity .35s ease, visibility .35s ease;
}
.tf-modal.active { opacity: 1; visibility: visible; }

.tf-shell {
  background: #ffffff;
  width: 100%;
  max-width: 100%;
  height: 100vh;
  height: 100dvh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transform: translateY(24px);
  transition: transform .4s cubic-bezier(.25, .8, .25, 1);
}
.tf-modal.active .tf-shell { transform: translateY(0); }

/* Header bar */
.tf-header {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 20px;
  background: rgba(255, 255, 255, .96);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid #e2e8f0;
}
.tf-brand { display: flex; align-items: center; gap: 10px; min-width: 0; }
.tf-brand img { height: 28px; width: auto; display: block; }
.tf-brand-label {
  font-size: 13.5px;
  font-weight: 700;
  color: #0f172a;
  letter-spacing: -.005em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.tf-header-right { display: flex; align-items: center; gap: 12px; flex-shrink: 0; }
.tf-meta { font-size: 12px; font-weight: 600; color: #64748b; white-space: nowrap; }
.tf-close {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: #f8fafc;
  color: #334155;
  border: 1px solid #e2e8f0;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: background .2s, transform .3s;
  flex-shrink: 0;
}
.tf-close:hover { background: #e2e8f0; transform: rotate(90deg); }
.tf-close svg { width: 18px; height: 18px; }

/* Progress: thin bar + step dots */
.tf-progress { flex-shrink: 0; height: 4px; background: #eef2f6; }
.tf-progress-bar {
  height: 100%;
  width: 0;
  background: linear-gradient(90deg, #0c7cd4 0%, #0fa1ff 100%);
  transition: width .35s cubic-bezier(.25, .8, .25, 1);
}
.tf-dots {
  flex-shrink: 0;
  display: flex;
  gap: 4px;
  justify-content: center;
  align-items: center;
  padding: 14px 16px 4px;
  min-height: 9px;
}
.tf-dot {
  width: 6px; height: 6px;
  border-radius: 4px;
  background: #e2e8f0;
  transition: all .3s ease;
}
.tf-dot.active { width: 22px; background: #0c7cd4; }
.tf-dot.done { background: #0fa1ff; }

/* Scroll region */
.tf-scroll {
  flex: 1;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  display: flex;
  flex-direction: column;
  padding: 16px 24px 32px;
}

/* ---- Question card ---- */
.tf-stage {
  flex: 1 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
}
.tf-card {
  width: 100%;
  max-width: 620px;
  margin: 0 auto;
  animation: tf-fade .4s cubic-bezier(.16, 1, .3, 1);
}
@keyframes tf-fade {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}
.tf-eyebrow {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #0c7cd4;
  margin-bottom: 10px;
}
.tf-eyebrow:empty { display: none; }
.tf-q {
  font-family: 'Inter', sans-serif;
  font-size: 24px;
  font-weight: 800;
  letter-spacing: -.02em;
  line-height: 1.25;
  color: #0f172a;
  margin: 0 0 6px;
}
.tf-sub {
  font-size: 15px;
  color: #64748b;
  line-height: 1.5;
  margin: 0 0 18px;
}
.tf-card .tf-sub:last-of-type { margin-bottom: 18px; }
.tf-q + .tf-input,
.tf-q + .tf-textarea,
.tf-q + .tf-opts { margin-top: 18px; }

/* Text / email / tel — underline input (typeform feel, brand-blue underline) */
.tf-input {
  width: 100%;
  padding: 14px 2px;
  font-size: 19px;
  font-family: 'Inter', sans-serif;
  color: #0f172a;
  background: transparent;
  border: none;
  border-bottom: 2px solid #0c7cd4;
  outline: none;
  border-radius: 0;
  -webkit-appearance: none;
  appearance: none;
}
.tf-input::placeholder { color: #94a3b8; font-weight: 400; }
.tf-input:focus { border-bottom-color: #0fa1ff; box-shadow: 0 2px 0 0 rgba(15, 161, 255, .25); }

/* Textarea — boxed */
.tf-textarea {
  width: 100%;
  padding: 14px 16px;
  font-size: 15px;
  font-family: 'Inter', sans-serif;
  color: #0f172a;
  background: #f8fafc;
  border: 1.5px solid #e2e8f0;
  border-radius: 12px;
  outline: none;
  resize: vertical;
  min-height: 108px;
  line-height: 1.55;
}
.tf-textarea::placeholder { color: #94a3b8; }
.tf-textarea:focus { border-color: #0c7cd4; box-shadow: 0 0 0 4px rgba(12, 124, 212, .12); background: #fff; }

/* Single / multi option buttons */
.tf-opts { display: flex; flex-direction: column; gap: 10px; }
.tf-opt {
  display: flex;
  align-items: center;
  gap: 14px;
  width: 100%;
  text-align: left;
  padding: 17px 20px;
  font-size: 16px;
  font-weight: 500;
  font-family: 'Inter', sans-serif;
  color: #1f2937;
  background: #ffffff;
  border: 2px solid #e2e8f0;
  border-radius: 14px;
  cursor: pointer;
  transition: border-color .15s, background .15s, box-shadow .15s, transform .1s;
}
.tf-opt:hover { border-color: #bfdbfe; background: #f8fbff; }
.tf-opt:active { transform: scale(.995); }
.tf-opt.selected {
  border-color: #0c7cd4;
  background: #e0f2fe;
  font-weight: 600;
  box-shadow: 0 2px 10px rgba(12, 124, 212, .14);
}
.tf-opt-marker {
  flex-shrink: 0;
  width: 24px; height: 24px;
  border-radius: 50%;
  border: 2px solid #cbd5e1;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 700;
  color: #94a3b8;
  background: transparent;
  transition: all .15s;
}
.tf-opt-marker-check { border-radius: 7px; }
.tf-opt-marker svg { width: 14px; height: 14px; opacity: 0; }
.tf-opt.selected .tf-opt-marker {
  border-color: #0c7cd4;
  background: #0c7cd4;
  color: #ffffff;
}
.tf-opt.selected .tf-opt-marker svg { opacity: 1; }
.tf-opt-text { flex: 1 1 auto; min-width: 0; line-height: 1.4; }

/* ---- Nav bar (Back / Next) ---- */
.tf-nav {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 24px;
  padding-bottom: calc(14px + env(safe-area-inset-bottom, 0px));
  border-top: 1px solid #e2e8f0;
  background: #ffffff;
}
.tf-back {
  padding: 12px 20px;
  font-size: 14px;
  font-weight: 600;
  font-family: 'Inter', sans-serif;
  color: #64748b;
  background: #ffffff;
  border: 1.5px solid #e2e8f0;
  border-radius: 980px;
  cursor: pointer;
  transition: all .2s;
}
.tf-back:hover { border-color: #cbd5e1; color: #334155; background: #f8fafc; }
.tf-next { min-width: 132px; }
/* Disabled Next — keep pill shape, muted */
.sb-disabled {
  background: #e2e8f0 !important;
  color: #94a3b8 !important;
  box-shadow: none !important;
  cursor: not-allowed !important;
}
.sb-disabled:hover { transform: none !important; box-shadow: none !important; background: #e2e8f0 !important; }

/* ---- Intro screen ---- */
.tf-intro { width: 100%; margin: auto 0; }
.tf-intro-inner {
  max-width: 480px;
  margin: 0 auto;
  text-align: center;
  padding: 12px 0;
  animation: tf-fade .4s cubic-bezier(.16, 1, .3, 1);
}
.tf-intro-eyebrow {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: #0c7cd4;
  margin-bottom: 12px;
}
.tf-intro-title {
  font-family: 'Inter', sans-serif;
  font-size: 30px;
  font-weight: 800;
  letter-spacing: -.02em;
  line-height: 1.15;
  color: #0f172a;
  margin: 0 0 12px;
}
.tf-intro-body {
  font-size: 15.5px;
  color: #475569;
  line-height: 1.6;
  margin: 0 0 24px;
}
.tf-intro-card {
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  padding: 16px 18px;
  text-align: left;
  margin-bottom: 24px;
}
.tf-intro-row {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 9px 0;
}
.tf-intro-row + .tf-intro-row { border-top: 1px solid #eef2f6; }
.tf-intro-ico {
  flex-shrink: 0;
  width: 30px; height: 30px;
  border-radius: 50%;
  background: #e0f2fe;
  color: #0c7cd4;
  display: flex;
  align-items: center;
  justify-content: center;
}
.tf-intro-ico svg { width: 16px; height: 16px; }
.tf-intro-t { font-size: 14.5px; font-weight: 700; color: #0f172a; line-height: 1.3; }
.tf-intro-s { font-size: 13px; color: #64748b; margin-top: 2px; line-height: 1.4; }
.tf-intro-trust { font-size: 12px; color: #94a3b8; margin: 14px 0 0; line-height: 1.5; }

/* ---- Success screen ---- */
.tf-success { width: 100%; margin: auto 0; }
.tf-success-inner {
  max-width: 480px;
  margin: 0 auto;
  text-align: center;
  padding: 12px 0;
  animation: tf-fade .4s cubic-bezier(.16, 1, .3, 1);
}
.tf-success-icon {
  width: 72px; height: 72px;
  border-radius: 50%;
  background: rgba(12, 124, 212, .12);
  color: #0c7cd4;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 20px;
}
.tf-success-icon svg { width: 34px; height: 34px; }
.tf-success-title {
  font-family: 'Inter', sans-serif;
  font-size: 26px;
  font-weight: 800;
  letter-spacing: -.02em;
  color: #0f172a;
  margin: 0 0 10px;
}
.tf-success-msg {
  font-size: 15px;
  color: #475569;
  line-height: 1.6;
  margin: 0 0 22px;
}
.tf-success-card {
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  padding: 8px 18px;
  text-align: left;
  margin-bottom: 22px;
}
.tf-success-step {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 11px 0;
  font-size: 14px;
  color: #334155;
  line-height: 1.45;
}
.tf-success-step + .tf-success-step { border-top: 1px solid #eef2f6; }
.tf-success-num {
  flex-shrink: 0;
  width: 26px; height: 26px;
  border-radius: 50%;
  background: linear-gradient(135deg, #0c7cd4, #0fa1ff);
  color: #ffffff;
  font-size: 12px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
}
.tf-success .popup-wa-btn { margin-bottom: 10px; }

/* ---- Responsive ---- */
@media (max-width: 560px) {
  /* Fill more of the screen on mobile + let the stage centre the card vertically.
     Tighter side padding = wider content; bigger options = fuller, more tappable. */
  .tf-scroll { padding: 12px 16px 24px; }
  .tf-card { max-width: 100%; }
  .tf-q { font-size: 22px; }
  .tf-sub { font-size: 15px; }
  .tf-input { font-size: 18px; padding: 16px 2px; }
  .tf-opts { gap: 11px; }
  .tf-opt { padding: 18px 18px; font-size: 16px; border-radius: 15px; }
  .tf-opt-marker { width: 26px; height: 26px; }
  .tf-textarea { min-height: 130px; font-size: 16px; }
  .tf-intro-title { font-size: 25px; }
  .tf-success-title { font-size: 22px; }
  .tf-nav { padding-left: 16px; padding-right: 16px; }
  .tf-next { min-width: 110px; }
  .tf-brand-label { max-width: 38vw; }
}
@media (min-width: 1024px) {
  /* Centre the working column comfortably on desktop, like a real typeform */
  .tf-scroll { padding-top: 28px; }
  .tf-q { font-size: 27px; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .tf-shell, .tf-card, .tf-intro-inner, .tf-success-inner { transition: none; animation: none; }
  .tf-progress-bar { transition: none; }
}

/* ==========================================================================
   REVISION v8 (2026-05-31) — client revision dump
   Trust strip refactor, Why section enlarge, helper reorder, steps +20%,
   bigger/bolder global type. SG-scoped (overrides shared.css; PH untouched).
   ========================================================================== */

/* ---- 1. Trust strip — desktop: centered, single-line items; mobile: marquee ---- */
.trust-bar {
  background: linear-gradient(180deg, #ffffff 0%, #f6fafe 100%);
  padding: 26px 0;
  overflow: hidden;
}
.trust-bar-inner { display: flex; justify-content: center; }
.trust-track { display: flex; align-items: center; }
.trust-item {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 16px;
  font-weight: 600;
  color: #334155;
  padding: 4px 26px;
  position: relative;
  flex-shrink: 0;
}
.trust-item .trust-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px; height: 44px;
  border-radius: 12px;
  background: #e8f3fd;
  color: #0c7cd4;
  flex-shrink: 0;
}
.trust-item .trust-icon svg { width: 24px; height: 24px; }
.trust-text { line-height: 1.3; text-align: left; }
.trust-text strong { color: #0c7cd4; font-weight: 800; }

/* DESKTOP (>=761px): static, centered, ONE LINE per item, dividers, hide marquee clones */
@media (min-width: 761px) {
  .trust-track { justify-content: center; flex-wrap: nowrap; }
  .trust-text { white-space: nowrap; }                 /* one row each, no line break */
  .trust-track > .trust-item:nth-child(n+4) { display: none; } /* hide cloned duplicates */
  .trust-track > .trust-item + .trust-item::before {
    content: ""; position: absolute; left: 0; top: 50%;
    transform: translateY(-50%); width: 1px; height: 34px; background: #e2e8f0;
  }
}

/* MOBILE (<=760px): repeating marquee */
@media (max-width: 760px) {
  .trust-bar-inner { justify-content: flex-start; width: 100%; }
  .trust-track {
    width: max-content;
    flex-wrap: nowrap;
    animation: mh-marquee-left 22s linear infinite;
    will-change: transform;
  }
  .trust-item { padding: 4px 20px; font-size: 15px; }
  .trust-text { white-space: nowrap; }
  .trust-bar:hover .trust-track { animation-play-state: paused; }
}
@media (max-width: 760px) and (prefers-reduced-motion: reduce) {
  .trust-track { animation: none; }
  .trust-bar { overflow-x: auto; }
}

/* ---- 2. Why section — 3 cards on one row, larger containers + fonts ---- */
.section-why-spotlight .bento-grid {
  grid-template-columns: repeat(3, 1fr);
  gap: 26px;
}
.section-why-spotlight .bento-card {
  padding: 40px 34px;
  border-radius: 24px;
}
.section-why-spotlight .bento-icon {
  width: 64px; height: 64px;
  border-radius: 18px;
  margin-bottom: 22px;
}
.section-why-spotlight .bento-icon svg { width: 30px; height: 30px; }
.section-why-spotlight .bento-card h3 {
  font-size: 21px;
  font-weight: 800;
  line-height: 1.3;
  margin-bottom: 12px;
  letter-spacing: -0.01em;
}
.section-why-spotlight .bento-card p {
  font-size: 16.5px;
  line-height: 1.6;
  color: #475569;
}
@media (max-width: 980px) {
  .section-why-spotlight .bento-grid { grid-template-columns: 1fr; gap: 20px; }
  .section-why-spotlight .bento-card { padding: 30px 26px; }
}

/* ---- 3. How It Works steps — +20% size, larger subtext.
   Containerize ONLY on desktop (≥768px); on mobile keep the plain stacked
   timeline (client: "don't containerize on mobile"). ---- */
@media (min-width: 768px) {
  [aria-labelledby="how-title"] .timeline-content {
    background: #ffffff;
    border: 1px solid #e8edf3;
    border-radius: 18px;
    padding: 20px 18px;
    box-shadow: 0 6px 20px rgba(15,23,42,.05);
    margin-top: 14px;
  }
}
[aria-labelledby="how-title"] .timeline-item h4 {
  font-size: 19px;       /* was ~16 → +~20% */
  font-weight: 800;
  line-height: 1.3;
  margin-bottom: 9px;
  letter-spacing: -0.01em;
}
[aria-labelledby="how-title"] .timeline-item p {
  font-size: 16px;       /* larger subtext (was 14) */
  line-height: 1.6;
  color: #475569;
  max-width: none;
}
@media (min-width: 1024px) {
  [aria-labelledby="how-title"] .timeline-item .num {
    width: 72px !important;   /* 60 → 72 = +20% */
    height: 72px !important;
    font-size: 28px !important;
    margin-bottom: 24px !important;
  }
  [aria-labelledby="how-title"] .timeline-flex::before { top: 36px; }
  [aria-labelledby="how-title"] .timeline-item p { max-width: 230px; }
}

/* ---- 4. GLOBAL TYPOGRAPHY — larger, bolder, clearer (client emphasis) ---- */
.sg-section-hd h2 {
  font-size: clamp(34px, 4.4vw, 50px);
  font-weight: 800;
  letter-spacing: -0.025em;
}
.sg-section-hd p {
  font-size: 19px;
  line-height: 1.6;
  color: #475569;
}
.sg-eyebrow { font-size: 14px; font-weight: 800; letter-spacing: 0.12em; }
.hero-subtitle { font-size: 21px !important; font-weight: 500 !important; line-height: 1.55 !important; color: #334155 !important; }
.hero-rating span { font-size: 15px; font-weight: 600; }
/* Helper cards — bigger, clearer */
.helper-card-body h3 { font-size: 23px; font-weight: 800; letter-spacing: -0.01em; }
.helper-tagline { font-size: 15px; font-weight: 700; }
.pill-tag { font-size: 14.5px; font-weight: 500; }
/* Service cards */
.service-card h4 { font-size: 19px; font-weight: 800; }
.service-card p { font-size: 15.5px; line-height: 1.55; }
/* Stats — bolder labels */
.stat-label { font-size: 16px; font-weight: 800; }
.stat-sub { font-size: 14px; }
/* Final CTA */
.final-cta h2 { font-size: clamp(30px, 4vw, 44px); font-weight: 800; }
.final-cta p { font-size: 18px; }
/* Footer — slightly larger for readability */
.site-footer-warm .footer-col a, .site-footer-warm .footer-address { font-size: 15px; }
.site-footer-warm .footer-col h4 { font-size: 14px; letter-spacing: 0.1em; }
@media (max-width: 560px) {
  .hero-subtitle { font-size: 18px !important; }
  .sg-section-hd p { font-size: 17px; }
  .helper-card-body h3 { font-size: 21px; }
}

/* ---- 3. Helper cards — Filipino centered, subtle emphasis (no invented label) ---- */
.helper-card-featured {
  position: relative;
  border: 2px solid #bfdbfe !important;
  box-shadow: 0 16px 40px rgba(12, 124, 212, 0.14) !important;
}
@media (min-width: 980px) {
  .helper-card-featured { transform: translateY(-10px); }
}

/* ---- 5. Popup form — grouped multi-field screens + larger type (v8) ---- */
.tf-group { display: flex; flex-direction: column; gap: 18px; width: 100%; }
.tf-field { display: flex; flex-direction: column; gap: 7px; text-align: left; }
.tf-field-label { font-size: 15px; font-weight: 700; color: #0f172a; }
.tf-field-label .tf-req { color: #dc0404; }
.tf-field-input {
  width: 100%;
  font-family: 'Inter', sans-serif;
  font-size: 17px;
  color: #0f172a;
  background: #f8fafc;
  border: 1.5px solid #d8e0e8;
  border-radius: 12px;
  padding: 14px 15px;
  outline: none;
  -webkit-appearance: none;
  appearance: none;
  box-sizing: border-box;
}
.tf-field-input:focus { border-color: #0c7cd4; background: #fff; box-shadow: 0 0 0 4px rgba(12,124,212,.12); }
.tf-field-input::placeholder { color: #94a3b8; }
.tf-field-select {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%230c7cd4' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 42px;
  cursor: pointer;
}
.tf-field-textarea { resize: vertical; min-height: 92px; line-height: 1.5; }

/* Bigger, clearer popup typography (client emphasis) */
.tf-q { font-size: 26px !important; font-weight: 800 !important; letter-spacing: -0.02em; }
.tf-sub { font-size: 16px !important; color: #475569 !important; line-height: 1.55 !important; }
.tf-eyebrow { font-size: 13px !important; font-weight: 800 !important; letter-spacing: 0.14em !important; }
.tf-opt { font-size: 16.5px !important; }
.tf-intro-title { font-size: 28px !important; font-weight: 800 !important; }
.tf-intro-body { font-size: 16.5px !important; line-height: 1.6 !important; }
.tf-success-title { font-size: 26px !important; font-weight: 800 !important; }
@media (min-width: 1024px) {
  .tf-q { font-size: 30px !important; }
}
@media (max-width: 560px) {
  .tf-q { font-size: 23px !important; }
  .tf-field-input { font-size: 16px; }
}

/* ---- PDPA / Privacy popup (footer-triggered) ---- */
.footer-legal-link {
  background: none; border: none; padding: 0; cursor: pointer;
  color: inherit; font: inherit; text-decoration: underline;
  text-underline-offset: 2px; opacity: .9;
}
.footer-legal-link:hover { opacity: 1; color: #0fa1ff; }
.pdpa-modal {
  position: fixed; inset: 0; z-index: 3000;
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
  background: rgba(11, 10, 20, .72);
  -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  opacity: 0; transition: opacity .28s ease;
}
.pdpa-modal[hidden] { display: none; }
.pdpa-modal.open { opacity: 1; }
.pdpa-card {
  background: #fff; width: 100%; max-width: 640px;
  max-height: 88vh; display: flex; flex-direction: column;
  border-radius: 20px; overflow: hidden;
  box-shadow: 0 30px 80px rgba(11, 10, 20, .4);
  transform: translateY(16px); transition: transform .3s cubic-bezier(.25,.8,.25,1);
}
.pdpa-modal.open .pdpa-card { transform: translateY(0); }
.pdpa-head {
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  padding: 22px 26px 16px; border-bottom: 1px solid #eef2f6; flex-shrink: 0;
}
.pdpa-head h2 { font-family: 'Inter', sans-serif; font-size: 19px; font-weight: 800; color: #0f172a; margin: 0; line-height: 1.3; letter-spacing: -.01em; }
.pdpa-close { background: #f1f5f9; border: none; width: 38px; height: 38px; border-radius: 10px; display: flex; align-items: center; justify-content: center; color: #475569; cursor: pointer; flex-shrink: 0; transition: background .15s; }
.pdpa-close:hover { background: #e2e8f0; }
.pdpa-body { padding: 20px 26px; overflow-y: auto; -webkit-overflow-scrolling: touch; }
.pdpa-body h3 { font-family: 'Inter', sans-serif; font-size: 15.5px; font-weight: 800; color: #0c7cd4; margin: 18px 0 6px; }
.pdpa-body p { font-size: 14.5px; line-height: 1.65; color: #334155; margin: 0 0 8px; }
.pdpa-body a { color: #0c7cd4; font-weight: 600; }
.pdpa-intro { font-size: 15px !important; color: #1f2937 !important; }
.pdpa-updated { font-size: 13px !important; color: #64748b !important; margin-top: 16px !important; font-style: italic; }
.pdpa-foot { padding: 16px 26px 22px; border-top: 1px solid #eef2f6; text-align: right; flex-shrink: 0; }
@media (max-width: 560px) {
  .pdpa-card { max-height: 92vh; border-radius: 16px; }
  .pdpa-head { padding: 18px 18px 14px; }
  .pdpa-head h2 { font-size: 17px; }
  .pdpa-body { padding: 16px 18px; }
  .pdpa-foot { padding: 14px 18px 18px; }
}

/* ---- 6. Dynamic opening-hours status (SG time) ---- */
.footer-hours-status {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 5px 12px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 700;
  margin-bottom: 14px;
}
.footer-hours-status .hours-dot {
  width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
}
.footer-hours-status.is-open {
  background: rgba(16, 185, 129, .16);
  color: #34d399;
}
.footer-hours-status.is-open .hours-dot {
  background: #10b981;
  box-shadow: 0 0 0 0 rgba(16,185,129,.6);
  animation: hours-pulse 2s infinite;
}
.footer-hours-status.is-closed {
  background: rgba(148, 163, 184, .16);
  color: #cbd5e1;
}
.footer-hours-status.is-closed .hours-dot { background: #94a3b8; }
@keyframes hours-pulse {
  0% { box-shadow: 0 0 0 0 rgba(16,185,129,.5); }
  70% { box-shadow: 0 0 0 6px rgba(16,185,129,0); }
  100% { box-shadow: 0 0 0 0 rgba(16,185,129,0); }
}
.footer-hours-line.hours-today {
  color: #fff;
}
.footer-hours-line.hours-today strong { color: #fbbf24; }
.footer-hours-line.hours-today::after {
  content: " · Today";
  font-size: 11px;
  color: #fbbf24;
  font-weight: 700;
}
@media (prefers-reduced-motion: reduce) {
  .footer-hours-status.is-open .hours-dot { animation: none; }
}

/* ---- 7. Stats grid now has 3 cards (Families Served removed) ---- */
.stats-grid { grid-template-columns: repeat(3, 1fr); max-width: 940px; margin-left: auto; margin-right: auto; }
@media (max-width: 900px) { .stats-grid { grid-template-columns: 1fr; } }

/* ============================================================
   Typeform — JSX form-flow port: why-hint, encouragement,
   match-detail meter, and the grouped Review screen.
   ============================================================ */
.tf-why {
  display: flex; gap: 9px; align-items: flex-start;
  background: #eef6fd; border: 1px solid #d6e9fb; border-radius: 12px;
  padding: 11px 14px; margin: 0 0 18px; line-height: 1.5;
}
.tf-why .tf-why-ico { font-size: 15px; flex-shrink: 0; line-height: 1.4; }
.tf-why span:last-child { font-size: 13.5px; color: #38566f; }

.tf-encourage {
  display: flex; gap: 9px; align-items: center;
  background: #fbf3e4; border: 1px solid #f0dfb8; border-radius: 12px;
  padding: 10px 14px; margin: 0 0 16px;
}
.tf-encourage .tf-encourage-ico { font-size: 15px; flex-shrink: 0; }
.tf-encourage span:last-child { font-size: 13.5px; font-weight: 600; color: #8a6d2f; line-height: 1.4; }

.tf-match { display: flex; align-items: center; gap: 10px; margin: 0 0 16px; }
.tf-match-label { font-size: 11px; font-weight: 700; color: #94a3b8; white-space: nowrap; letter-spacing: .3px; }
.tf-match-track { flex: 1; height: 6px; background: #eef2f6; border-radius: 4px; overflow: hidden; }
.tf-match-fill { display: block; height: 100%; border-radius: 4px; transition: width .4s ease; }
.tf-match-pct { font-size: 11px; font-weight: 800; white-space: nowrap; }

.tf-review { width: 100%; max-width: 560px; margin: 0 auto; }
.tf-review-head { text-align: center; margin-bottom: 16px; }
.tf-review-head .tf-q { margin-bottom: 6px; }
.tf-review-meter { background: #fff; border: 1px solid #e8eef4; border-radius: 14px; padding: 14px 16px; margin-bottom: 16px; box-shadow: 0 2px 10px rgba(13,33,55,.05); }
.tf-review-meter-top { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; font-size: 13.5px; font-weight: 600; color: #0d2137; }
.tf-review-meter-top strong { font-size: 16px; }
.tf-review-skip { font-size: 12.5px; color: #64748b; margin: 10px 0 0; line-height: 1.5; }
.tf-review-grp { margin-bottom: 14px; }
.tf-review-grp-h { font-size: 11px; font-weight: 800; letter-spacing: 1.4px; text-transform: uppercase; color: #c9983a; margin: 0 0 6px 4px; }
.tf-review-card { background: #fff; border: 1px solid #e8eef4; border-radius: 14px; overflow: hidden; box-shadow: 0 2px 10px rgba(13,33,55,.05); }
.tf-review-row { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; padding: 13px 16px; border-bottom: 1px solid #f1f5f9; }
.tf-review-row.last { border-bottom: none; }
.tf-review-qa { flex: 1; min-width: 0; }
.tf-review-q { font-size: 12px; color: #94a3b8; margin-bottom: 3px; line-height: 1.35; }
.tf-review-a { font-size: 14.5px; font-weight: 600; color: #1f2e3b; line-height: 1.4; word-break: break-word; }
.tf-review-a.empty { color: #b3bdc7; font-style: italic; font-weight: 500; }
.tf-review-edit { flex-shrink: 0; font-size: 12px; font-weight: 700; color: #0c7cd4; background: #eaf4fd; border: none; border-radius: 8px; padding: 6px 13px; cursor: pointer; font-family: inherit; }
.tf-review-edit.add { color: #c9983a; background: #fbf3e4; }
.tf-review-edit:hover { filter: brightness(.97); }
.tf-review-actions { margin-top: 20px; }
.tf-review-back { display: block; width: 100%; margin-top: 12px; background: none; border: none; color: #94a3b8; font-size: 13.5px; font-weight: 600; cursor: pointer; font-family: inherit; padding: 8px; }
.tf-review-back:hover { color: #0d2137; }

/* Per-question emoji in the typeform eyebrow (JSX parity) */
.tf-eyebrow { display: flex; align-items: center; gap: 7px; }
.tf-emoji { font-size: 17px; line-height: 1; letter-spacing: normal; text-transform: none; }
