/* ============================================================
   Rutherford Rescue Roadside — Stylesheet
   Friendly & approachable · Mobile-first · Central Coast CA
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --navy:       #1a2744;
  --navy-mid:   #243459;
  --navy-soft:  #2e4270;
  --blue:       #2563eb;
  --blue-dk:    #1d4ed8;
  --blue-lt:    #dbeafe;
  --orange:     #ea580c;
  --orange-dk:  #c2410c;
  --orange-lt:  #fff7ed;
  --green:      #16a34a;
  --green-lt:   #dcfce7;
  --gray-50:    #f8fafc;
  --gray-100:   #f1f5f9;
  --gray-200:   #e2e8f0;
  --gray-400:   #94a3b8;
  --gray-600:   #475569;
  --gray-800:   #1e293b;
  --ink:        #0f172a;
  --white:      #ffffff;
  --border:     rgba(15,23,42,0.09);
  --shadow-sm:  0 1px 3px rgba(0,0,0,.08);
  --shadow-md:  0 4px 16px rgba(0,0,0,.10);
  --shadow-lg:  0 12px 40px rgba(0,0,0,.14);
  --radius:     10px;
  --radius-lg:  16px;
  --radius-xl:  24px;
  --font-head:  'Poppins', system-ui, sans-serif;
  --font-body:  'Poppins', system-ui, sans-serif;
  --max:        1080px;
  --nav-h:      68px;
}

html { scroll-behavior: smooth; font-size: 16px; }
body { font-family: var(--font-body); background: var(--white); color: var(--ink); line-height: 1.65; -webkit-font-smoothing: antialiased; }
img  { display: block; max-width: 100%; }
a    { color: inherit; }

/* ── LAYOUT ── */
.container  { max-width: var(--max); margin: 0 auto; padding: 0 20px; }
.section    { padding: 72px 0; }
.section-sm { padding: 48px 0; }
@media (min-width: 768px) { .container { padding: 0 32px; } .section { padding: 96px 0; } }

/* ── TYPOGRAPHY ── */
h1 { font-size: clamp(32px, 6vw, 58px); font-weight: 700; line-height: 1.12; color: var(--ink); }
h2 { font-size: clamp(24px, 4vw, 40px); font-weight: 700; line-height: 1.2;  color: var(--ink); }
h3 { font-size: clamp(17px, 2.5vw, 22px); font-weight: 600; line-height: 1.3; color: var(--ink); }
h4 { font-size: 16px; font-weight: 600; color: var(--ink); }
p  { font-size: 16px; color: var(--gray-600); line-height: 1.75; }
em { font-style: normal; color: var(--orange); }

.eyebrow { display:inline-flex; align-items:center; gap:8px; font-size:12px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--blue); margin-bottom:12px; }
.eyebrow::before { content:''; width:20px; height:2px; background:var(--blue); flex-shrink:0; }

/* ── BUTTONS ── */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; font-family:var(--font-body); font-weight:700; border:none; border-radius:var(--radius); cursor:pointer; text-decoration:none; transition:all .2s; white-space:nowrap; min-height:48px; }
.btn-sm  { font-size:14px; padding:10px 20px; min-height:40px; }
.btn-md  { font-size:15px; padding:12px 24px; }
.btn-lg  { font-size:16px; padding:15px 32px; border-radius:12px; }
.btn-xl  { font-size:18px; padding:18px 36px; border-radius:14px; }
.btn-call    { background:var(--orange); color:#fff; }
.btn-call:hover  { background:var(--orange-dk); transform:translateY(-1px); box-shadow:0 6px 20px rgba(234,88,12,.35); }
.btn-primary { background:var(--blue); color:#fff; }
.btn-primary:hover { background:var(--blue-dk); transform:translateY(-1px); box-shadow:0 6px 20px rgba(37,99,235,.3); }
.btn-outline  { background:transparent; border:2px solid var(--navy); color:var(--navy); }
.btn-outline:hover { background:var(--navy); color:#fff; }
.btn-white    { background:#fff; color:var(--navy); }
.btn-white:hover { background:var(--gray-100); }
.btn-ghost-white { background:transparent; border:2px solid rgba(255,255,255,.5); color:#fff; }
.btn-ghost-white:hover { background:rgba(255,255,255,.12); border-color:#fff; }

/* ── CLICK-TO-CALL pulse ── */
.btn-call-pulse { position:relative; }
.btn-call-pulse::before { content:''; position:absolute; inset:-4px; border-radius:16px; background:var(--orange); opacity:.25; animation:callpulse 2s ease-out infinite; }
@keyframes callpulse { 0%{transform:scale(1);opacity:.25} 70%{transform:scale(1.12);opacity:0} 100%{transform:scale(1.12);opacity:0} }

/* ── NAV ── */
.site-nav { position:sticky; top:0; z-index:200; height:var(--nav-h); background:rgba(255,255,255,.97); backdrop-filter:blur(12px); border-bottom:1px solid var(--border); box-shadow:var(--shadow-sm); }
.nav-inner { display:flex; align-items:center; justify-content:space-between; height:100%; gap:16px; }
.nav-logo  { font-weight:800; font-size:17px; color:var(--navy); text-decoration:none; line-height:1.1; flex-shrink:0; }
.nav-logo span { color:var(--orange); }
.nav-logo small { display:block; font-size:10px; font-weight:600; color:var(--gray-400); letter-spacing:.06em; text-transform:uppercase; }
.nav-phone { display:none; align-items:center; gap:8px; font-weight:700; font-size:15px; color:var(--navy); text-decoration:none; }
.nav-phone svg { color:var(--orange); }
.nav-links { display:none; list-style:none; gap:28px; }
.nav-links a { font-size:14px; font-weight:600; color:var(--gray-600); text-decoration:none; transition:color .15s; }
.nav-links a:hover { color:var(--orange); }
.nav-call-btn { display:none; }
.nav-toggle { display:flex; background:none; border:1px solid var(--border); border-radius:var(--radius); cursor:pointer; padding:8px 10px; flex-direction:column; gap:4px; min-width:44px; min-height:44px; align-items:center; justify-content:center; }
.nav-toggle span { display:block; width:20px; height:2px; background:var(--ink); border-radius:2px; transition:all .2s; }
@media (min-width:640px)  { .nav-phone { display:flex; } }
@media (min-width:900px)  { .nav-links { display:flex; } .nav-call-btn { display:inline-flex; } .nav-toggle { display:none; } }
.nav-mobile { display:none; position:fixed; inset:var(--nav-h) 0 0 0; background:#fff; z-index:199; padding:28px 20px; flex-direction:column; gap:4px; overflow-y:auto; }
.nav-mobile.open { display:flex; }
.nav-mobile a { font-size:20px; font-weight:700; color:var(--ink); text-decoration:none; padding:16px 0; border-bottom:1px solid var(--border); display:block; }
.nav-mobile .btn { margin-top:20px; width:100%; justify-content:center; }

/* ── FOOTER ── */
.site-footer { background:var(--navy); color:rgba(255,255,255,.6); padding:56px 0 32px; }
.footer-grid { display:grid; grid-template-columns:1fr; gap:36px; margin-bottom:40px; }
@media (min-width:600px) { .footer-grid { grid-template-columns:1.5fr 1fr 1fr; gap:48px; } }
.footer-logo { font-weight:800; font-size:20px; color:#fff; text-decoration:none; }
.footer-logo span { color:var(--orange); }
.footer-brand p { font-size:14px; margin-top:12px; line-height:1.7; max-width:260px; }
.footer-col h5 { font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.3); margin-bottom:14px; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-col ul a { font-size:14px; color:rgba(255,255,255,.6); text-decoration:none; transition:color .15s; }
.footer-col ul a:hover { color:#fff; }
.footer-bottom { border-top:1px solid rgba(255,255,255,.08); padding-top:24px; display:flex; flex-direction:column; gap:8px; font-size:13px; }
@media (min-width:600px) { .footer-bottom { flex-direction:row; justify-content:space-between; align-items:center; } }

/* ── BADGES ── */
.badge { display:inline-flex; align-items:center; gap:5px; font-size:12px; font-weight:700; padding:4px 10px; border-radius:20px; }
.badge-green  { background:var(--green-lt);  color:var(--green); }
.badge-blue   { background:var(--blue-lt);   color:var(--blue); }
.badge-orange { background:var(--orange-lt); color:var(--orange); }
.badge-navy   { background:rgba(26,39,68,.08); color:var(--navy); }
.live-dot { width:7px; height:7px; border-radius:50%; background:var(--green); animation:livepulse 2s infinite; display:inline-block; }
@keyframes livepulse { 0%,100%{opacity:1} 50%{opacity:.3} }

/* ── SERVICE CARDS ── */
.service-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
@media (min-width:600px) { .service-grid { grid-template-columns:repeat(2,1fr); gap:20px; } }
@media (min-width:900px) { .service-grid { grid-template-columns:repeat(4,1fr); } }
.service-card { background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg); padding:24px 20px; text-align:center; transition:all .2s; text-decoration:none; display:block; }
.service-card:hover { box-shadow:var(--shadow-md); transform:translateY(-3px); border-color:var(--blue); }
.service-icon { width:56px; height:56px; border-radius:14px; display:flex; align-items:center; justify-content:center; font-size:26px; margin:0 auto 14px; }
.service-card h3 { font-size:16px; margin-bottom:8px; }
.service-card p  { font-size:13px; }

/* ── AREA CARDS ── */
.area-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:12px; }
@media (min-width:600px) { .area-grid { grid-template-columns:repeat(4,1fr); } }
.area-card { background:var(--gray-50); border:1px solid var(--border); border-radius:var(--radius-lg); padding:20px 16px; text-align:center; }
.area-card .icon { font-size:28px; margin-bottom:8px; }
.area-card h3 { font-size:15px; margin-bottom:4px; }
.area-card p  { font-size:12px; }

/* ── FAQ ── */
.faq-item { border-bottom:1px solid var(--border); }
.faq-btn  { width:100%; display:flex; justify-content:space-between; align-items:center; padding:20px 0; background:none; border:none; cursor:pointer; text-align:left; gap:16px; }
.faq-btn h3 { font-size:16px; color:var(--ink); margin:0; }
.faq-icon { width:28px; height:28px; border-radius:50%; background:var(--blue-lt); display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:transform .2s; color:var(--blue); font-size:18px; font-weight:700; }
.faq-btn.open .faq-icon { transform:rotate(45deg); background:var(--blue); color:#fff; }
.faq-answer { display:none; padding-bottom:20px; }
.faq-answer.open { display:block; }
.faq-answer p { font-size:15px; }

/* ── REVIEW CARDS ── */
.review-grid { display:grid; grid-template-columns:1fr; gap:16px; }
@media (min-width:600px) { .review-grid { grid-template-columns:repeat(3,1fr); } }
.review-card { background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg); padding:24px; }
.stars { color:#f59e0b; font-size:16px; margin-bottom:12px; letter-spacing:2px; }
.review-card p  { font-size:14px; font-style:italic; margin-bottom:14px; }
.reviewer { font-size:13px; font-weight:700; color:var(--gray-600); }

/* ── TRUST STRIP ── */
.trust-strip { background:var(--navy); padding:36px 0; }
.trust-grid  { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
@media (min-width:768px) { .trust-grid { grid-template-columns:repeat(4,1fr); } }
.trust-cell  { text-align:center; }
.trust-cell .icon { font-size:28px; margin-bottom:8px; }
.trust-cell h4 { font-size:14px; font-weight:700; color:#fff; margin-bottom:3px; }
.trust-cell p  { font-size:12px; color:rgba(255,255,255,.5); }

/* ── RESPONSIVE HELPERS ── */
.flex-col  { display:flex; flex-direction:column; gap:12px; }
.flex-row  { display:flex; flex-wrap:wrap; gap:12px; }
@media (min-width:560px) { .mobile-only { display:none; } }
