/*
  mobile.css — OnPoint Pro Doors
  COMPETITOR-MATCHED MOBILE REDESIGN
  Based on: Precision Door, GarageDoorRepair.com, Doors Done Right
  All rules inside @media max-width: 768px
  styles.css NOT touched. Desktop unchanged.
*/

@media (max-width: 768px) {

/* ─── RESET ──────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box !important; }
html, body {
  margin: 0 !important;
  padding: 0 !important;
  overflow-x: hidden !important;
  width: 100% !important;
}

/* ─── CONTAINER ──────────────────────────────────────── */
.container, .opx-wrap {
  width: 100% !important;
  max-width: 100% !important;
  padding-left: 16px !important;
  padding-right: 16px !important;
  margin: 0 auto !important;
}

/* ─── TOP NOTICE — hide, use header instead ─────────── */
.opx-topNotice { display: none !important; }

/* ─── HEADER ─────────────────────────────────────────── */
/* Dark header like Precision Door / Doors Done Right */
.topbar {
  position: sticky !important;
  top: 0 !important;
  z-index: 999 !important;
  background: #111 !important;
  border-bottom: none !important;
  box-shadow: 0 2px 12px rgba(0,0,0,0.4) !important;
  padding: 0 !important;
}

.nav {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 10px 16px !important;
  gap: 10px !important;
}

/* Brand — white text on dark */
.brand {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  text-decoration: none !important;
  flex: 1 !important;
  min-width: 0 !important;
}

.brand img {
  width: 34px !important;
  height: 34px !important;
  border-radius: 4px !important;
  flex-shrink: 0 !important;
}

.brand .title {
  display: flex !important;
  flex-direction: column !important;
  gap: 1px !important;
}

.brand strong {
  font-size: 11px !important;
  font-weight: 900 !important;
  color: #fff !important;
  line-height: 1.2 !important;
  white-space: nowrap !important;
}

.brand span {
  font-size: 8px !important;
  color: #aaa !important;
  white-space: nowrap !important;
}

/* Hide desktop nav pieces — keep .actions visible for call button */
.topbar .badge, .navlinks { display: none !important; }

/* Show call button + hamburger in mobile header */
.actions {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  flex-shrink: 0 !important;
}

.actions .btn-primary {
  background: #CC2222 !important;
  color: #fff !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  padding: 7px 10px !important;
  border-radius: 6px !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  letter-spacing: 0.3px !important;
  text-transform: uppercase !important;
  box-shadow: 0 2px 6px rgba(204,34,34,0.4) !important;
  animation: callPulse 2s ease-in-out infinite !important;
  font-size: 0 !important;
}

.actions .btn-primary::before {
  content: '\1F4DE  CALL' !important;
  font-size: 11px !important;
  letter-spacing: 0.5px !important;
}

@keyframes callPulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.04); box-shadow: 0 3px 10px rgba(204,34,34,0.55) !important; }
}

/* Hamburger — white icon on dark header */
.iconbtn {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: none !important;
  border: none !important;
  padding: 6px !important;
  cursor: pointer !important;
  color: #fff !important;
  text-decoration: none !important;
  flex-shrink: 0 !important;
}

.iconbtn svg { width: 24px !important; height: 24px !important; }

/* CTA row directly below nav — like Precision Door */
/* We inject this visually by styling the mobilepanel wrapper */

/* ─── MOBILE MENU ────────────────────────────────────── */
.mobilepanel {
  display: block !important;
  background: #1a1a1a !important;
  max-height: 0 !important;
  overflow: hidden !important;
  transition: max-height 0.35s ease !important;
  border-top: 1px solid rgba(255,255,255,0.08) !important;
}

.mobilepanel.open { max-height: 500px !important; }

.mobilepanel .inner {
  padding: 8px 0 !important;
  display: flex !important;
  flex-direction: column !important;
}

.mobilepanel a {
  display: block !important;
  padding: 13px 20px !important;
  color: #eee !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  border-bottom: 1px solid rgba(255,255,255,0.06) !important;
}

.mobilepanel .opx-btnPrimary {
  background: #CC2222 !important;
  color: #fff !important;
  font-weight: 800 !important;
  text-align: center !important;
}

.mobilepanel .row {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 10px !important;
  padding: 12px 16px !important;
}

.mobilepanel .row a {
  border: none !important;
  text-align: center !important;
  border-radius: 8px !important;
  padding: 12px 8px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
}

.mobilepanel .btn-primary {
  background: #CC2222 !important;
  color: #fff !important;
}

/* ─── HERO — Image top, dark content below (Doors Done Right pattern) ── */
.hero {
  padding: 0 !important;
  background: #0d0d0d !important;
}

.hero .container {
  padding: 0 !important;
  max-width: 100% !important;
  width: 100% !important;
}

/* Flex column, reorder children visually */
.heroGrid {
  display: flex !important;
  flex-direction: column !important;
  width: 100% !important;
  background: #0d0d0d !important;
  gap: 0 !important;
}

/* Image + stats: first visually (heroStats is INSIDE heroMedia in DOM) */
.heroMedia {
  order: 0 !important;
  position: relative !important;
  width: 100% !important;
  height: auto !important;
  overflow: visible !important;
  flex-shrink: 0 !important;
}

.heroMedia img {
  width: 100% !important;
  height: 200px !important;
  object-fit: cover !important;
  object-position: center 35% !important;
  display: block !important;
}

/* Red stats bar: inside heroMedia, flows below image */
.heroStats {
  order: 0 !important;
  position: relative !important;
  bottom: auto !important;
  left: auto !important;
  right: auto !important;
  z-index: auto !important;
  display: flex !important;
  background: #CC2222 !important;
  width: 100% !important;
}

.heroStats .stat {
  flex: 1 !important;
  padding: 9px 6px !important;
  text-align: center !important;
  background: none !important;
  border-right: 1px solid rgba(255,255,255,0.2) !important;
  border-bottom: none !important;
  min-height: unset !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
}

.heroStats .stat:last-child { border-right: none !important; }

.heroStats .stat strong {
  display: block !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  color: #fff !important;
  line-height: 1.2 !important;
}

.heroStats .stat span {
  display: block !important;
  font-size: 9px !important;
  color: rgba(255,255,255,0.85) !important;
  line-height: 1.3 !important;
  margin-top: 1px !important;
}

/* Text card: third visually, dark background */
.heroCard {
  order: 2 !important;
  position: relative !important;
  z-index: auto !important;
  padding: 24px 16px 28px !important;
  background: #0d0d0d !important;
  color: #fff !important;
}

.heroCard .kicker {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  color: rgba(255,255,255,0.8) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  margin-bottom: 12px !important;
}

.heroCard .kicker .dot {
  width: 7px !important;
  height: 7px !important;
  background: #4ade80 !important;
  border-radius: 50% !important;
  flex-shrink: 0 !important;
  animation: pulse-dot 2s ease-in-out infinite !important;
}

@keyframes pulse-dot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.7; transform: scale(0.8); }
}

.heroCard h1, .heroCard .h1 {
  font-size: 28px !important;
  font-weight: 900 !important;
  color: #fff !important;
  margin: 0 0 10px !important;
  line-height: 1.15 !important;
  letter-spacing: -0.3px !important;
}

.heroCard .sub {
  font-size: 13px !important;
  color: rgba(255,255,255,0.75) !important;
  line-height: 1.5 !important;
  margin: 0 0 20px !important;
}

.heroBtns {
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  margin: 0 !important;
}

.heroBtns .btn:nth-child(1) {
  background: #CC2222 !important;
  color: #fff !important;
  font-size: 16px !important;
  font-weight: 800 !important;
  padding: 16px !important;
  border-radius: 8px !important;
  text-align: center !important;
  border: none !important;
}

.heroBtns .btn:nth-child(2) {
  background: rgba(255,255,255,0.08) !important;
  color: #fff !important;
  border: 1.5px solid rgba(255,255,255,0.3) !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  padding: 13px !important;
  border-radius: 8px !important;
  text-align: center !important;
}

.heroBtns .btn:nth-child(3) {
  display: none !important;
}

/* Mobile heroTrust — clean grid */
.heroTrust {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 12px !important;
  margin-top: 22px !important;
  padding-top: 18px !important;
  border-top: 1px solid rgba(255,255,255,0.1) !important;
}
.heroTrust .ts {
  display: flex !important;
  flex-direction: column !important;
  gap: 2px !important;
}
.heroTrust .ts .stars {
  color: #FFA000 !important;
  font-size: 13px !important;
  letter-spacing: 1px !important;
  margin-bottom: 2px !important;
}
.heroTrust .ts strong {
  font-size: 16px !important;
  font-weight: 900 !important;
  color: #fff !important;
  line-height: 1 !important;
}
.heroTrust .ts span {
  font-size: 10px !important;
  color: rgba(255,255,255,0.6) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.4px !important;
}

.opx-badgesRow { display: none !important; }

/* ─── BUTTONS ────────────────────────────────────────── */
.btn {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  min-height: 50px !important;
  padding: 13px 16px !important;
  border-radius: 10px !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  text-decoration: none !important;
  cursor: pointer !important;
  border: none !important;
  transition: transform 0.15s ease !important;
  text-align: center !important;
  line-height: 1.1 !important;
  width: 100% !important;
}

.btn:active { transform: scale(0.96) !important; }

.btn-accent {
  background: #CC2222 !important;
  color: #fff !important;
  box-shadow: 0 4px 14px rgba(0,0,0,0.3) !important;
}

.btn-primary {
  background: rgba(255,255,255,0.95) !important;
  color: #1a1a1a !important;
  box-shadow: 0 4px 14px rgba(0,0,0,0.2) !important;
}

/* ─── QUICK BOOK BAR ─────────────────────────────────── */
.quickBook {
  background: #1a1a1a !important;
  padding: 14px 16px !important;
  border: none !important;
}

.qbBar {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 10px !important;
  align-items: center !important;
}

.qbLeft { display: none !important; } /* Hidden — clean 2-button layout */

.qbRight {
  grid-column: 1 / -1 !important;
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 10px !important;
}

.qbRight .btn {
  min-height: 48px !important;
  font-size: 13px !important;
  border-radius: 8px !important;
}

.qbRight .btn-primary {
  background: #CC2222 !important;
  color: #fff !important;
}

.qbRight .btn:not(.btn-primary) {
  background: rgba(255,255,255,0.1) !important;
  color: #fff !important;
  border: 1px solid rgba(255,255,255,0.25) !important;
}

/* ─── SECTIONS ───────────────────────────────────────── */
.section, .opx-section {
  padding: 24px 0 !important;
  border-bottom: 1px solid #eee !important;
}

.sectionHead {
  padding: 0 16px !important;
  margin-bottom: 18px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
}

.sectionHead h2 {
  font-size: 22px !important;
  font-weight: 900 !important;
  color: #1a1a1a !important;
  margin: 0 0 4px !important;
  line-height: 1.2 !important;
}

.sectionHead p {
  font-size: 13px !important;
  color: #666 !important;
  margin: 0 !important;
}

.sectionHead .btn {
  min-height: 44px !important;
  font-size: 13px !important;
  background: #CC2222 !important;
  color: #fff !important;
  border-radius: 8px !important;
  padding: 11px 16px !important;
}

/* ─── SERVICE CARDS ──────────────────────────────────── */
.cards {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 10px !important;
  padding: 0 16px !important;
}

.card {
  display: flex !important;
  flex-direction: column !important;
  border-radius: 10px !important;
  overflow: hidden !important;
  background: #fff !important;
  border: 1px solid #e8e8e8 !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06) !important;
}

.card .media {
  width: 100% !important;
  height: 90px !important;
  overflow: hidden !important;
  background: #f0f0f0 !important;
  flex-shrink: 0 !important;
}

.card .media img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}

.card .body {
  padding: 10px !important;
  flex: 1 !important;
}

.card h3 {
  font-size: 12px !important;
  font-weight: 800 !important;
  color: #1a1a1a !important;
  margin: 0 0 4px !important;
  line-height: 1.3 !important;
}

.card h3 a {
  color: #1a1a1a !important;
  text-decoration: none !important;
}

.card p {
  font-size: 10px !important;
  color: #888 !important;
  margin: 0 !important;
  line-height: 1.4 !important;
}

.card ul { display: none !important; }

.card .foot {
  padding: 0 10px 10px !important;
  display: flex !important;
  align-items: center !important;
  gap: 4px !important;
}

.pill {
  font-size: 9px !important;
  background: #fef0f0 !important;
  color: #CC2222 !important;
  padding: 3px 7px !important;
  border-radius: 20px !important;
  font-weight: 700 !important;
}

.card .link {
  font-size: 10px !important;
  font-weight: 700 !important;
  color: #CC2222 !important;
  text-decoration: none !important;
  margin-left: auto !important;
}

/* ─── SAFETY BOX ─────────────────────────────────────── */
.opx-safety {
  background: #fffbf0 !important;
  border-top: none !important;
}

.opx-safetyCard {
  margin: 0 16px !important;
  padding: 16px !important;
  background: #fff !important;
  border: 2px solid #f59e0b !important;
  border-radius: 10px !important;
  box-shadow: 0 2px 8px rgba(245,158,11,0.15) !important;
}

.opx-safetyIcon { font-size: 26px !important; margin-bottom: 6px !important; }

.opx-safetyBody h2 {
  font-size: 16px !important;
  font-weight: 900 !important;
  margin: 0 0 8px !important;
}

.opx-safetyBody p {
  font-size: 12px !important;
  line-height: 1.55 !important;
  margin: 0 0 12px !important;
  color: #444 !important;
}

.opx-safetyActions {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 8px !important;
}

.opx-safetyActions a {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 44px !important;
  border-radius: 8px !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  text-decoration: none !important;
}

.opx-safetyActions .opx-btnPrimary {
  background: #CC2222 !important;
  color: #fff !important;
}

.opx-safetyActions .opx-btn-secondary {
  background: #fff !important;
  color: #CC2222 !important;
  border: 2px solid #CC2222 !important;
}

.opx-muted { font-size: 10px !important; color: #999 !important; margin-top: 8px !important; }

/* ─── RESERVE FORM ───────────────────────────────────── */
.reserve {
  background: #f4f4f4 !important;
  padding: 24px 0 !important;
}

.opx {
  display: block !important;
  padding: 0 16px !important;
}

.opx-left { display: none !important; }

.opx-right { width: 100% !important; }

.opx-card {
  border-radius: 14px !important;
  overflow: hidden !important;
  background: #fff !important;
  box-shadow: 0 8px 30px rgba(0,0,0,0.12) !important;
  border: none !important;
}

.opx-card-top {
  background: linear-gradient(135deg, #CC2222 0%, #900f0f 100%) !important;
  padding: 20px 20px 18px !important;
  border: none !important;
}

.opx-openNow {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  color: rgba(255,255,255,0.9) !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  margin-bottom: 8px !important;
}

.opx-openDot {
  width: 7px !important;
  height: 7px !important;
  background: #4ade80 !important;
  border-radius: 50% !important;
  flex-shrink: 0 !important;
  display: inline-block !important;
}

.opx-card-title {
  font-size: 22px !important;
  font-weight: 900 !important;
  color: #fff !important;
  margin: 0 0 4px !important;
  letter-spacing: -0.3px !important;
}

.opx-card-sub {
  font-size: 12px !important;
  color: rgba(255,255,255,0.85) !important;
  margin: 0 !important;
}

.opx-formWrap { padding: 18px !important; }

.opx-grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 12px !important;
}

.opx-field { display: block !important; }

.opx-field label {
  display: block !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  color: #333 !important;
  margin-bottom: 5px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.3px !important;
}

.opx-req { color: #CC2222 !important; }

.opx-field input,
.opx-field select,
.opx-field textarea {
  display: block !important;
  width: 100% !important;
  font-size: 16px !important;
  font-family: inherit !important;
  padding: 11px 12px !important;
  border: 1.5px solid #e0e0e0 !important;
  border-radius: 8px !important;
  background: #fafafa !important;
  color: #1a1a1a !important;
  outline: none !important;
  transition: border-color 0.2s, box-shadow 0.2s !important;
  -webkit-appearance: none !important;
  appearance: none !important;
}

.opx-field select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23666' stroke-width='1.5' stroke-linecap='round' fill='none'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 12px center !important;
  padding-right: 32px !important;
}

.opx-field input:focus,
.opx-field select:focus,
.opx-field textarea:focus {
  border-color: #CC2222 !important;
  background: #fff !important;
  box-shadow: 0 0 0 3px rgba(204,34,34,0.1) !important;
}

.opx-full { grid-column: 1 / -1 !important; }

.opx-field[style*="background"] {
  grid-column: 1 / -1 !important;
  background: #fff8f8 !important;
  border: 1.5px solid #f8d0d0 !important;
  border-radius: 8px !important;
  padding: 12px !important;
}

.opx-field label[style] {
  font-size: 11px !important;
  font-weight: 400 !important;
  color: #555 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  cursor: pointer !important;
  line-height: 1.5 !important;
}

.opx-field input[type="checkbox"] {
  width: 18px !important;
  height: 18px !important;
  accent-color: #CC2222 !important;
  flex-shrink: 0 !important;
  -webkit-appearance: auto !important;
  appearance: auto !important;
}

#opxBtn {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  width: 100% !important;
  padding: 15px 18px !important;
  margin-top: 16px !important;
  font-size: 15px !important;
  font-weight: 900 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  background: linear-gradient(135deg, #CC2222, #900f0f) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 10px !important;
  cursor: pointer !important;
  min-height: 54px !important;
  box-shadow: 0 6px 20px rgba(204,34,34,0.4) !important;
  transition: transform 0.15s !important;
}

#opxBtn:active { transform: scale(0.97) !important; }

.opx-btnDot {
  width: 7px !important; height: 7px !important;
  background: rgba(255,255,255,0.5) !important;
  border-radius: 50% !important; display: inline-block !important;
}

.opx-note {
  font-size: 11px !important;
  color: #999 !important;
  text-align: center !important;
  margin-top: 8px !important;
}

/* ─── HIGHLIGHTS / BADGES ────────────────────────────── */
.badgeRow {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 10px !important;
  padding: 0 16px !important;
}

.badge {
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  padding: 14px 12px !important;
  background: #fff !important;
  border-radius: 10px !important;
  border: 1px solid #eee !important;
  box-shadow: 0 2px 6px rgba(0,0,0,0.04) !important;
}

.badge .ico { font-size: 22px !important; }

.badgeTxt strong {
  font-size: 12px !important;
  font-weight: 800 !important;
  color: #1a1a1a !important;
  display: block !important;
}

.badgeTxt span {
  font-size: 10px !important;
  color: #888 !important;
  display: block !important;
  line-height: 1.4 !important;
}

/* ─── BRANDS ─────────────────────────────────────────── */
.brandStrip {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 8px !important;
  padding: 0 16px !important;
}

.brandLogo {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 54px !important;
  padding: 8px !important;
  background: #f8f8f8 !important;
  border-radius: 8px !important;
  border: 1px solid #eee !important;
}

.brandLogo img {
  max-width: 52px !important;
  max-height: 34px !important;
  width: auto !important;
  height: auto !important;
}

.brandLogo a {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* ─── FAQ ────────────────────────────────────────────── */
.faqGrid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 8px !important;
  padding: 0 16px !important;
}

.faqItem {
  border: 1px solid #e4e4e4 !important;
  border-radius: 10px !important;
  background: #fff !important;
  overflow: hidden !important;
}

.faqItem summary {
  padding: 14px 16px !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  color: #1a1a1a !important;
  cursor: pointer !important;
  list-style: none !important;
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
}

.faqItem summary::-webkit-details-marker { display: none !important; }
.faqItem summary::after {
  content: '+' !important;
  font-size: 20px !important;
  font-weight: 300 !important;
  color: #CC2222 !important;
  flex-shrink: 0 !important;
  margin-left: 8px !important;
}
.faqItem[open] summary::after { content: '−' !important; }

.faqItem p {
  font-size: 13px !important;
  color: #555 !important;
  padding: 0 16px 14px !important;
  margin: 0 !important;
  line-height: 1.6 !important;
  border-top: 1px solid #f0f0f0 !important;
  padding-top: 10px !important;
}

/* ─── REVIEWS ────────────────────────────────────────── */
.reviewGrid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 10px !important;
  padding: 0 16px !important;
}

.review {
  background: #fff !important;
  border: 1px solid #e4e4e4 !important;
  border-radius: 10px !important;
  padding: 14px !important;
}

.review .stars {
  font-size: 15px !important;
  color: #f59e0b !important;
  margin-bottom: 8px !important;
  display: block !important;
}

.review p {
  font-size: 13px !important;
  color: #555 !important;
  line-height: 1.6 !important;
  margin: 0 0 10px !important;
  font-style: italic !important;
}

.review .who {
  font-size: 11px !important;
  display: flex !important;
  gap: 6px !important;
  color: #999 !important;
}

.review .who strong { color: #1a1a1a !important; }

/* ─── AREAS ──────────────────────────────────────────── */
.areaGrid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 10px !important;
  padding: 0 16px !important;
}

.areaCard {
  background: #fff !important;
  border: 1px solid #e4e4e4 !important;
  border-radius: 10px !important;
  padding: 14px !important;
}

.areaCard h3 {
  font-size: 13px !important;
  font-weight: 800 !important;
  color: #1a1a1a !important;
  margin: 0 0 10px !important;
}

.chips { display: flex !important; flex-wrap: wrap !important; gap: 6px !important; }

.chip {
  font-size: 12px !important;
  padding: 5px 10px !important;
  background: #f5f5f5 !important;
  color: #444 !important;
  border-radius: 20px !important;
  border: 1px solid #ddd !important;
  text-decoration: none !important;
}

/* ─── CONTACT / SPLIT ────────────────────────────────── */
.split {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 10px !important;
  padding: 0 16px !important;
}

.panel {
  background: #fff !important;
  border: 1px solid #e4e4e4 !important;
  border-radius: 10px !important;
  padding: 16px !important;
  text-align: center !important;
}

.panel h3 {
  font-size: 15px !important;
  font-weight: 800 !important;
  margin: 0 0 10px !important;
  color: #1a1a1a !important;
}

.panel p {
  font-size: 13px !important;
  color: #666 !important;
  margin: 0 0 10px !important;
  line-height: 1.5 !important;
}

.panel .btn { margin-top: 4px !important; }

/* ─── BEFORE/AFTER/RESOURCES ─────────────────────────── */
.opx-grid3 {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 10px !important;
  padding: 0 16px !important;
}

.opx-cardSoft, .opx-card {
  background: #fff !important;
  border: 1px solid #e4e4e4 !important;
  border-radius: 10px !important;
  padding: 14px !important;
}

.opx-cardSoft h3, .opx-card h3 {
  font-size: 13px !important;
  font-weight: 800 !important;
  color: #1a1a1a !important;
  margin: 0 0 6px !important;
}

.opx-cardSoft p, .opx-card p {
  font-size: 12px !important;
  color: #666 !important;
  margin: 0 !important;
  line-height: 1.5 !important;
}

.opx-sectionHead {
  padding: 0 16px !important;
  margin-bottom: 16px !important;
}

.opx-sectionHead h2 {
  font-size: 21px !important;
  font-weight: 900 !important;
  color: #1a1a1a !important;
  margin: 0 0 6px !important;
}

.opx-sectionHead p {
  font-size: 13px !important;
  color: #666 !important;
  margin: 0 !important;
}

.opx-linksGrid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 6px !important;
  padding: 0 16px !important;
  margin-bottom: 12px !important;
}

.opx-linkCard {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 12px 14px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  color: #1a1a1a !important;
  background: #fff !important;
  border: 1px solid #e4e4e4 !important;
  border-radius: 8px !important;
}

.opx-linkCardStatic {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 11px 14px !important;
  font-size: 13px !important;
  background: #f8f8f8 !important;
  border-radius: 8px !important;
  color: #1a1a1a !important;
}

.opx-linkArrow { color: #CC2222 !important; font-weight: 800 !important; }

.opx-resourceBlock {
  padding: 0 16px !important;
  margin-bottom: 18px !important;
}

.opx-resourceBlock h3 {
  font-size: 13px !important;
  font-weight: 800 !important;
  color: #1a1a1a !important;
  margin: 0 0 10px !important;
}

.opx-ctaRow {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 10px !important;
  padding: 0 16px !important;
}

.opx-ctaRow a {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 46px !important;
  border-radius: 8px !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  text-decoration: none !important;
}

.opx-ctaRow .opx-btnPrimary { background: #CC2222 !important; color: #fff !important; }
.opx-ctaRow .opx-btn-secondary {
  background: #fff !important;
  color: #CC2222 !important;
  border: 2px solid #CC2222 !important;
}

/* ─── FOOTER ─────────────────────────────────────────── */
.footer {
  background: #111 !important;
  color: #fff !important;
  padding: 22px 0 !important;
  border-top: 3px solid #CC2222 !important;
}

.footerGrid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 16px !important;
  padding: 0 16px 16px !important;
  border-bottom: 1px solid rgba(255,255,255,0.08) !important;
  margin-bottom: 14px !important;
}

.footer h4 {
  font-size: 10px !important;
  font-weight: 900 !important;
  color: #fff !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  margin: 0 0 8px !important;
}

.footer p {
  font-size: 11px !important;
  color: #aaa !important;
  margin: 0 0 5px !important;
  line-height: 1.5 !important;
}

.footer a { color: #ff8888 !important; text-decoration: none !important; }
.footer .small { font-size: 10px !important; color: #777 !important; }

.opx-footer-links {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 16px !important;
  padding: 0 16px 14px !important;
  border-bottom: 1px solid rgba(255,255,255,0.08) !important;
  margin-bottom: 14px !important;
}

.opx-footer-col h4 {
  font-size: 10px !important;
  font-weight: 900 !important;
  color: #fff !important;
  text-transform: uppercase !important;
  margin: 0 0 8px !important;
}

.opx-footer-col a {
  display: block !important;
  font-size: 10px !important;
  color: #ff8888 !important;
  margin-bottom: 5px !important;
  text-decoration: none !important;
}

.opx-footerLinks { display: none !important; }

.line {
  padding: 0 16px !important;
  border: none !important;
}

.line p {
  font-size: 10px !important;
  color: #666 !important;
  margin: 0 0 4px !important;
  text-align: center !important;
}

.line a { color: #ff8888 !important; }

/* ─── STICKY CALL ────────────────────────────────────── */
.stickyCall {
  position: fixed !important;
  bottom: 20px !important;
  right: 16px !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 13px 20px !important;
  background: #CC2222 !important;
  color: #fff !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  border-radius: 50px !important;
  box-shadow: 0 6px 24px rgba(204,34,34,0.55) !important;
  text-decoration: none !important;
  z-index: 200 !important;
  min-height: 50px !important;
  border: none !important;
  cursor: pointer !important;
  animation: pulse 2.5s infinite !important;
}

@keyframes pulse {
  0%, 100% { box-shadow: 0 6px 24px rgba(204,34,34,0.55); }
  50% { box-shadow: 0 6px 32px rgba(204,34,34,0.75); }
}

.stickyCall .stickyIcon { font-size: 16px !important; }

.opx-urgentBar { display: none !important; }

/* ─── GLOBAL FORM INPUT FONT SIZE (prevents iOS zoom) ── */
input:not([type="checkbox"]):not([type="radio"]),
select, textarea { font-size: 16px !important; }

/* ─── REMOVE DUPLICATE CTA BAR ────────────────────────── */
.quickBook { display: none !important; }

/* ─── REMOVE SAFETY FIRST SECTION ─────────────────────── */
.opx-safety { display: none !important; }

/* ─── BROKEN SPRING IMAGE FIX — springs_optimized-768w.webp missing ─ */
/* Hide the broken srcset img, replace .media with CSS background */
#services .cards .card:nth-child(1) .media img {
  display: none !important;
}
#services .cards .card:nth-child(1) .media {
  background-image: url('/assets/img/springs_optimized.jpg') !important;
  background-size: cover !important;
  background-position: center !important;
}

/* ─── HIDE SPECIFIC SERVICE CARDS (mobile only) ────────── */
/* 3=Rollers/Cables 4=New Door 6=Remote/Keypad 7=Cable Repair */
#services .cards .card:nth-child(3),
#services .cards .card:nth-child(4),
#services .cards .card:nth-child(6),
#services .cards .card:nth-child(7) {
  display: none !important;
}

/* ─── CARD IMAGE HEIGHT — make Broken Spring clearly visible ─ */
.card .media {
  height: 130px !important;
}

} /* end @media (max-width: 768px) */

/* ─── 480px and below ────────────────────────────────── */
@media (max-width: 480px) {

  .heroCard h1, .heroCard .h1 {
    font-size: 25px !important;
  }

  .heroGrid { min-height: 400px !important; }

  .heroCard {
    padding: 28px 16px 70px !important;
  }

  .heroBtns {
    grid-template-columns: 1fr !important;
  }

  .heroBtns .btn:nth-child(3) {
    grid-column: 1 !important;
  }

  .cards {
    grid-template-columns: 1fr !important;
  }

  .card .media { height: 140px !important; }

  .opx-grid {
    grid-template-columns: 1fr !important;
  }

  .badgeRow {
    grid-template-columns: 1fr !important;
  }

  .badge {
    flex-direction: row !important;
    align-items: flex-start !important;
  }

  .qbRight {
    grid-template-columns: 1fr !important;
  }

  .opx-safetyActions {
    grid-template-columns: 1fr !important;
  }

  .opx-ctaRow {
    grid-template-columns: 1fr !important;
  }

  .opx-footer-links {
    grid-template-columns: 1fr !important;
  }

  .container, .opx-wrap {
    padding-left: 14px !important;
    padding-right: 14px !important;
  }

  .stickyCall {
    bottom: 14px !important;
    right: 14px !important;
    padding: 11px 16px !important;
    font-size: 12px !important;
  }
}
