/* ============================================================
   TITAN AUTOMOTIVE LOCKSMITHS — SHARED STYLESHEET
   titanautomotivelocksmiths.com.au
   ============================================================ */

/* ─── VARIABLES ─── */
:root {
  --charcoal:      #181818;
  --charcoal-mid:  #222222;
  --charcoal-light:#2a2a2a;
  --charcoal-card: #252525;
  --gold:          #C9A84C;
  --gold-light:    #E0BB6A;
  --gold-pale:     rgba(201,168,76,0.12);
  --gold-border:   rgba(201,168,76,0.25);
  --teal:          #06B6D4;
  --teal-light:    #22D3EE;
  --teal-pale:     rgba(6,182,212,0.1);
  --teal-border:   rgba(6,182,212,0.3);
  --white:         #FFFFFF;
  --gray1:         #CCCCCC;
  --gray2:         #999999;
  --gray3:         #555555;
  --border:        #2e2e2e;
  --max-w:         1200px;
  --max-w-narrow:  900px;
}

/* ─── RESET ─── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  font-family:'Segoe UI', Arial, sans-serif;
  background:var(--charcoal);
  color:var(--white);
  min-height:100vh;
  padding-bottom:72px; /* mobile call bar clearance */
}
svg { display:block; }
img { display:block; max-width:100%; }
a { text-decoration:none; }

/* ─── TYPOGRAPHY ─── */
.gold  { color:var(--gold); }
.teal  { color:var(--teal); }

/* ─── SECTION WRAPPER ─── */
.section-wrap  { max-width:var(--max-w); margin:0 auto; padding:80px 32px; }
.section-wrap--narrow { max-width:var(--max-w-narrow); margin:0 auto; padding:80px 32px; }
.section-bg    { background:var(--charcoal-mid); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }

/* ─── SECTION HEADER ─── */
.section-header { text-align:center; margin-bottom:52px; }
.section-eyebrow {
  display:inline-block; color:var(--gold); font-size:12px; font-weight:700;
  letter-spacing:2px; text-transform:uppercase; margin-bottom:12px;
}
.section-title  { font-size:38px; font-weight:900; letter-spacing:-1px; margin-bottom:16px; line-height:1.1; }
.section-sub    { color:var(--gray2); font-size:17px; line-height:1.6; max-width:560px; margin:0 auto; }

/* ─── ANNOUNCEMENT BAR ─── */
.ann-bar {
  background:linear-gradient(90deg,#0e0e0e 0%,#1a1a1a 50%,#0e0e0e 100%);
  border-bottom:1px solid var(--gold-border);
  padding:9px 24px;
  display:flex; align-items:center; justify-content:center; gap:32px; flex-wrap:wrap;
}
.ann-item { display:flex; align-items:center; gap:7px; color:var(--gray2); font-size:13px; }
.ann-dot  { width:5px; height:5px; border-radius:50%; background:var(--gold); flex-shrink:0; }
.ann-item strong { color:var(--gray1); font-weight:600; }
.ann-phone { color:var(--gold); font-weight:800; font-size:14px; letter-spacing:0.5px; display:flex; align-items:center; gap:6px; }
.ann-phone svg { stroke:var(--gold); }

/* ─── HEADER ─── */
header {
  background:var(--charcoal-mid);
  border-bottom:1px solid var(--border);
  position:sticky; top:0; z-index:100;
  box-shadow:0 2px 20px rgba(0,0,0,0.4);
}
.header-inner {
  max-width:var(--max-w); margin:0 auto;
  padding:0 32px; height:68px;
  display:flex; align-items:center; gap:32px;
}
.logo { display:flex; align-items:center; gap:12px; cursor:pointer; }
.logo-icon {
  width:40px; height:40px; border-radius:10px;
  background:linear-gradient(135deg,var(--gold),var(--gold-light));
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.logo-icon svg { stroke:#111; }
.logo-text { display:flex; flex-direction:column; }
.logo-name { color:var(--white); font-size:15px; font-weight:800; letter-spacing:0.3px; line-height:1.1; }
.logo-sub  { color:var(--gold); font-size:10px; font-weight:600; letter-spacing:1.5px; text-transform:uppercase; }
nav { display:flex; align-items:center; gap:4px; margin-left:auto; }
nav a {
  color:var(--gray2); font-size:14px; font-weight:500; padding:8px 12px;
  border-radius:6px; transition:all 0.2s; cursor:pointer;
}
nav a:hover { color:var(--white); background:var(--charcoal-light); }
.nav-cta {
  background:var(--gold); color:#111 !important; font-weight:800 !important;
  padding:10px 18px !important; border-radius:6px; margin-left:8px;
  font-size:14px !important; letter-spacing:0.3px; white-space:nowrap;
  display:inline-flex !important; align-items:center; gap:7px;
}
.nav-cta:hover { background:var(--gold-light) !important; transform:translateY(-1px); }
.nav-cta svg { stroke:#111; flex-shrink:0; }

/* ─── BUTTONS ─── */
.btn-gold {
  display:inline-flex; align-items:center; gap:10px;
  background:var(--gold); color:#111; padding:14px 28px;
  border-radius:8px; font-size:16px; font-weight:800;
  border:none; cursor:pointer; transition:all 0.2s;
  box-shadow:0 4px 20px rgba(201,168,76,0.3);
}
.btn-gold:hover { background:var(--gold-light); transform:translateY(-2px); box-shadow:0 8px 32px rgba(201,168,76,0.4); }
.btn-gold svg { stroke:#111; }
.btn-teal {
  display:inline-flex; align-items:center; gap:8px;
  border:1px solid var(--teal-border); color:var(--teal);
  padding:12px 22px; border-radius:8px; font-size:15px; font-weight:700;
  cursor:pointer; background:var(--teal-pale); transition:all 0.2s;
}
.btn-teal:hover { background:rgba(6,182,212,0.18); }
.btn-teal svg { stroke:var(--teal); }
.btn-outline {
  display:inline-flex; align-items:center; gap:8px;
  border:1px solid var(--border); color:var(--gray2);
  padding:12px 22px; border-radius:8px; font-size:15px; font-weight:600;
  cursor:pointer; background:transparent; transition:all 0.2s;
}
.btn-outline:hover { border-color:var(--gold-border); color:var(--gold); }

/* ─── PHONE CTA (hero size) ─── */
.phone-cta {
  display:inline-flex; align-items:center; gap:14px;
  background:var(--gold); color:#111;
  padding:16px 28px; border-radius:8px;
  font-size:20px; font-weight:900; border:none;
  letter-spacing:0.3px; margin-bottom:16px;
  box-shadow:0 4px 24px rgba(201,168,76,0.35);
  transition:all 0.2s; cursor:pointer;
}
.phone-cta:hover { background:var(--gold-light); transform:translateY(-2px); }
.phone-cta-icon { width:42px; height:42px; border-radius:8px; background:rgba(0,0,0,0.15); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.phone-cta-icon svg { stroke:#111; }
.phone-cta-label { display:flex; flex-direction:column; line-height:1.1; }
.phone-cta-label span:first-child { font-size:12px; font-weight:600; opacity:0.7; }
.phone-cta-label span:last-child  { font-size:21px; font-weight:900; }

/* ─── STATS BAR ─── */
.stats-bar { background:var(--charcoal-mid); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.stats-bar-inner {
  max-width:var(--max-w); margin:0 auto; padding:0 32px;
  display:grid; grid-template-columns:repeat(4,1fr);
}
.stat-block { padding:28px 24px; border-right:1px solid var(--border); display:flex; align-items:center; gap:18px; }
.stat-block:last-child { border-right:none; }
.stat-icon { width:52px; height:52px; border-radius:12px; flex-shrink:0; background:var(--teal-pale); border:1px solid var(--teal-border); display:flex; align-items:center; justify-content:center; }
.stat-icon svg { stroke:var(--teal); }
.stat-num  { font-size:28px; font-weight:900; color:var(--gold); line-height:1; }
.stat-num .sub { font-size:16px; color:var(--gray2); font-weight:600; }
.stat-num .accent { color:var(--teal); }
.stat-label { color:var(--gray2); font-size:13px; margin-top:3px; }

/* ─── SERVICE CARDS ─── */
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.service-card {
  background:var(--charcoal-card); border:1px solid var(--border); border-radius:12px;
  padding:28px; transition:all 0.25s; cursor:pointer;
  display:block; color:var(--white); text-decoration:none;
}
.service-card:hover { border-color:var(--gold-border); transform:translateY(-4px); box-shadow:0 12px 40px rgba(0,0,0,0.4); color:var(--white); }
.service-icon-wrap {
  width:52px; height:52px; border-radius:12px;
  background:var(--gold-pale); border:1px solid var(--gold-border);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:18px; flex-shrink:0;
}
.service-icon-wrap svg { stroke:var(--gold); }
.service-name { font-size:18px; font-weight:800; margin-bottom:10px; color:var(--white); }
.service-desc { color:var(--gray2); font-size:14px; line-height:1.6; margin-bottom:16px; }
.service-link { color:var(--gold); font-size:13px; font-weight:700; display:flex; align-items:center; gap:6px; }
.service-link::after { content:'→'; transition:transform 0.2s; }
.service-card:hover .service-link::after { transform:translateX(4px); }

/* ─── REVIEW CARDS ─── */
.reviews-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.review-card { background:var(--charcoal-card); border:1px solid var(--border); border-radius:12px; padding:26px; }
.review-stars { display:flex; gap:4px; margin-bottom:14px; }
.review-stars svg { stroke:var(--gold); fill:var(--gold); }
.review-text { color:var(--gray1); font-size:14px; line-height:1.65; margin-bottom:16px; font-style:italic; }
.review-author { display:flex; align-items:center; gap:10px; }
.review-avatar { width:38px; height:38px; border-radius:50%; background:linear-gradient(135deg,var(--gold),var(--gold-light)); display:flex; align-items:center; justify-content:center; font-size:15px; font-weight:900; color:#111; flex-shrink:0; }
.review-name strong { display:block; font-size:14px; font-weight:700; }
.review-name span { color:var(--gray3); font-size:12px; }
.reviews-cta { text-align:center; margin-top:40px; padding-top:40px; border-top:1px solid var(--border); }
.reviews-cta p { color:var(--gray2); font-size:16px; margin-bottom:16px; }
.btn-google {
  display:inline-flex; align-items:center; gap:10px;
  border:1px solid var(--border); color:var(--gray1);
  background:var(--charcoal-card); padding:12px 24px;
  border-radius:8px; font-size:15px; font-weight:700;
  cursor:pointer; transition:all 0.2s;
}
.btn-google:hover { border-color:var(--gold-border); color:var(--gold); }

/* ─── FAQ ─── */
.faq-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-top:52px; }
.faq-item { background:var(--charcoal-card); border:1px solid var(--border); border-radius:12px; overflow:hidden; transition:border-color 0.2s; }
.faq-item.open { border-color:var(--gold-border); }
.faq-question { padding:20px 24px; display:flex; align-items:center; justify-content:space-between; cursor:pointer; gap:16px; user-select:none; }
.faq-question-text { font-size:15px; font-weight:700; color:var(--white); line-height:1.4; }
.faq-chevron { width:28px; height:28px; border-radius:6px; flex-shrink:0; background:var(--gold-pale); border:1px solid var(--gold-border); display:flex; align-items:center; justify-content:center; }
.faq-chevron svg { stroke:var(--gold); transition:transform 0.25s; }
.faq-item.open .faq-chevron svg { transform:rotate(180deg); }
.faq-answer { display:none; padding:0 24px 20px; }
.faq-item.open .faq-answer { display:block; }
.faq-answer p { color:var(--gray2); font-size:14px; line-height:1.75; border-top:1px solid var(--border); padding-top:16px; }
.faq-answer strong { color:var(--gray1); }

/* ─── AREAS ─── */
.areas-grid { display:flex; flex-wrap:wrap; gap:10px; justify-content:center; }
.area-chip { background:var(--charcoal-card); border:1px solid var(--border); color:var(--gray2); padding:8px 18px; border-radius:20px; font-size:14px; transition:all 0.2s; text-decoration:none; display:inline-block; }
.area-chip:hover { border-color:var(--teal-border); color:var(--teal); background:var(--teal-pale); }
.area-chip-more { border-style:dashed; color:var(--gray3); font-style:italic; }

/* ─── MAKES STRIP ─── */
.makes-grid { display:flex; flex-wrap:wrap; gap:8px; }
.make-chip { background:var(--charcoal-card); border:1px solid var(--border); color:var(--gray2); padding:7px 16px; border-radius:6px; font-size:13px; font-weight:600; transition:all 0.2s; }
.make-chip:hover { border-color:var(--gold-border); color:var(--gold); }

/* ─── PAGE HERO (inner pages) ─── */
.page-hero {
  background:linear-gradient(135deg,#0e0e0e 0%,#1a1a1a 100%);
  border-bottom:1px solid var(--border);
  padding:64px 32px;
}
.page-hero-inner { max-width:var(--max-w); margin:0 auto; }
.breadcrumb { display:flex; align-items:center; gap:8px; color:var(--gray3); font-size:13px; margin-bottom:20px; flex-wrap:wrap; }
.breadcrumb a { color:var(--gray3); transition:color 0.2s; }
.breadcrumb a:hover { color:var(--gold); }
.breadcrumb-sep { color:var(--gray3); }
.page-hero-eyebrow { color:var(--teal); font-size:12px; font-weight:700; letter-spacing:2px; text-transform:uppercase; margin-bottom:14px; }
.page-hero-h1 { font-size:48px; font-weight:900; line-height:1.05; letter-spacing:-1.5px; margin-bottom:20px; }
.page-hero-sub { color:var(--gray2); font-size:18px; line-height:1.65; max-width:640px; margin-bottom:32px; }
.page-hero-sub strong { color:var(--gray1); }
.page-hero-actions { display:flex; gap:16px; flex-wrap:wrap; }

/* ─── TRUST BADGES (inline row) ─── */
.trust-row { display:flex; gap:24px; flex-wrap:wrap; margin-top:36px; padding-top:36px; border-top:1px solid var(--border); }
.trust-item { display:flex; align-items:center; gap:12px; }
.trust-icon { width:40px; height:40px; border-radius:10px; background:var(--gold-pale); border:1px solid var(--gold-border); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.trust-icon svg { stroke:var(--gold); }
.trust-text strong { display:block; color:var(--white); font-size:15px; font-weight:800; line-height:1.2; }
.trust-text span { color:var(--gray3); font-size:12px; }

/* ─── CTA BAND ─── */
.cta-band { background:linear-gradient(135deg,#111 0%,#1a1a1a 100%); border-top:1px solid var(--border); padding:80px 32px; }
.cta-band-inner { max-width:var(--max-w-narrow); margin:0 auto; text-align:center; }
.cta-band h2 { font-size:38px; font-weight:900; letter-spacing:-1px; margin-bottom:16px; line-height:1.1; }
.cta-band p  { color:var(--gray2); font-size:17px; line-height:1.65; margin-bottom:32px; max-width:540px; margin-left:auto; margin-right:auto; }
.cta-band-actions { display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }

/* ─── FOOTER ─── */
footer { background:#0e0e0e; border-top:1px solid var(--border); padding:40px 32px 24px; }
.footer-inner { max-width:var(--max-w); margin:0 auto; display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; margin-bottom:32px; }
.footer-logo { display:flex; align-items:center; gap:10px; margin-bottom:12px; }
.footer-logo-icon { width:32px; height:32px; border-radius:7px; background:linear-gradient(135deg,var(--gold),var(--gold-light)); display:flex; align-items:center; justify-content:center; }
.footer-logo-icon svg { stroke:#111; }
.footer-name { color:var(--white); font-size:13px; font-weight:800; }
.footer-tagline { color:var(--gray3); font-size:13px; line-height:1.6; margin-bottom:14px; }
.footer-phone { color:var(--gold); font-size:16px; font-weight:800; display:flex; align-items:center; gap:7px; }
.footer-phone svg { stroke:var(--gold); }
.footer-hours { color:var(--gray3); font-size:12px; margin-top:6px; }
.footer-col h4 { color:var(--gray2); font-size:11px; font-weight:700; letter-spacing:2px; text-transform:uppercase; margin-bottom:14px; }
.footer-col a { display:block; color:var(--gray3); font-size:14px; margin-bottom:8px; transition:color 0.2s; }
.footer-col a:hover { color:var(--gold); }
.footer-bottom { max-width:var(--max-w); margin:0 auto; padding-top:24px; border-top:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px; }
.footer-copy { color:var(--gray3); font-size:13px; }
.footer-badges { display:flex; gap:10px; flex-wrap:wrap; }
.footer-badge { background:var(--charcoal-card); border:1px solid var(--border); color:var(--gray3); padding:4px 10px; border-radius:4px; font-size:11px; }

/* ─── MOBILE CALL BAR ─── */
.mobile-call-bar { display:none; }

/* ─── SUBURB HERO CONTENT BOX ─── */
.suburb-intro { background:var(--charcoal-card); border:1px solid var(--border); border-radius:12px; padding:32px; margin-bottom:32px; }
.suburb-intro h2 { font-size:24px; font-weight:800; margin-bottom:12px; }
.suburb-intro p  { color:var(--gray2); font-size:15px; line-height:1.7; }

/* ─── WHY TITAN (2-col) ─── */
.why-inner { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
.why-title { font-size:38px; font-weight:900; letter-spacing:-1px; margin-bottom:16px; line-height:1.1; }
.why-sub   { color:var(--gray2); font-size:17px; line-height:1.65; margin-bottom:32px; }
.why-right { display:flex; flex-direction:column; gap:16px; }
.why-item  { background:var(--charcoal-card); border:1px solid var(--border); border-radius:12px; padding:22px 24px; display:flex; gap:18px; align-items:flex-start; transition:border-color 0.2s; }
.why-item:hover { border-color:var(--gold-border); }
.why-check { width:36px; height:36px; border-radius:8px; flex-shrink:0; background:var(--gold-pale); border:1px solid var(--gold-border); display:flex; align-items:center; justify-content:center; }
.why-check svg { stroke:var(--gold); }
.why-item-text strong { display:block; font-size:16px; font-weight:800; margin-bottom:5px; }
.why-item-text p { color:var(--gray2); font-size:14px; line-height:1.55; }

/* ─── HOW IT WORKS ─── */
.steps-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:0; margin-top:52px; position:relative; }
.steps-grid::before { content:''; position:absolute; top:34px; left:calc(16.66% + 16px); right:calc(16.66% + 16px); height:1px; background:linear-gradient(90deg,var(--gold-border),var(--teal-border),var(--gold-border)); z-index:0; }
.step-block { text-align:center; padding:0 28px; position:relative; z-index:1; }
.step-num-wrap { display:flex; align-items:center; justify-content:center; margin-bottom:20px; }
.step-num { width:68px; height:68px; border-radius:50%; background:var(--charcoal-card); border:2px solid var(--gold-border); display:flex; align-items:center; justify-content:center; flex-direction:column; gap:2px; }
.step-num-digit { font-size:11px; font-weight:800; color:var(--gold); letter-spacing:1px; text-transform:uppercase; line-height:1; }
.step-icon-inner svg { stroke:var(--gold); }
.step-title { font-size:18px; font-weight:800; margin-bottom:10px; }
.step-desc  { color:var(--gray2); font-size:14px; line-height:1.7; }
.step-block:nth-child(2) .step-num { border-color:var(--teal-border); }
.step-block:nth-child(2) .step-num-digit { color:var(--teal); }
.step-block:nth-child(2) .step-icon-inner svg { stroke:var(--teal); }

/* ─── CONTENT PROSE (service pages) ─── */
.prose { color:var(--gray2); font-size:16px; line-height:1.8; }
.prose h2 { font-size:26px; font-weight:800; color:var(--white); margin:36px 0 14px; letter-spacing:-0.5px; }
.prose h3 { font-size:20px; font-weight:700; color:var(--gray1); margin:28px 0 10px; }
.prose p  { margin-bottom:16px; }
.prose strong { color:var(--gray1); }
.prose ul { padding-left:20px; margin-bottom:16px; }
.prose ul li { margin-bottom:8px; }
.prose a  { color:var(--gold); text-decoration:underline; text-underline-offset:3px; }

/* ─── 2-COL CONTENT LAYOUT ─── */
.content-grid { display:grid; grid-template-columns:1fr 360px; gap:48px; align-items:start; }
.content-sidebar { position:sticky; top:86px; }
.sidebar-card { background:var(--charcoal-card); border:1px solid var(--border); border-radius:12px; padding:28px; margin-bottom:20px; }
.sidebar-card h3 { font-size:17px; font-weight:800; margin-bottom:16px; }
.sidebar-links { display:flex; flex-direction:column; gap:8px; }
.sidebar-link { display:flex; align-items:center; gap:10px; color:var(--gray2); font-size:14px; padding:10px 14px; border-radius:8px; border:1px solid var(--border); transition:all 0.2s; }
.sidebar-link:hover { border-color:var(--gold-border); color:var(--gold); background:var(--gold-pale); }
.sidebar-link svg { stroke:currentColor; flex-shrink:0; }

/* ─── FORMS ─── */
.form-group { margin-bottom:14px; }
.form-group label { display:block; color:var(--gray2); font-size:12px; font-weight:600; letter-spacing:0.5px; text-transform:uppercase; margin-bottom:6px; }
.form-group input, .form-group select {
  width:100%; background:var(--charcoal-light);
  border:1px solid var(--border); border-radius:8px;
  color:var(--white); font-size:15px; padding:12px 14px;
  outline:none; transition:border-color 0.2s; appearance:none; font-family:inherit;
}
.form-group input:focus, .form-group select:focus { border-color:var(--gold); }
.form-group input::placeholder { color:var(--gray3); }
.form-group select option { background:var(--charcoal-mid); }
.form-submit {
  width:100%; background:var(--gold); color:#111;
  border:none; border-radius:8px; padding:15px;
  font-size:16px; font-weight:900; cursor:pointer;
  transition:all 0.2s; margin-top:4px; letter-spacing:0.3px; font-family:inherit;
}
.form-submit:hover { background:var(--gold-light); transform:translateY(-1px); }
.form-divider { display:flex; align-items:center; gap:12px; margin:18px 0; }
.form-divider::before, .form-divider::after { content:''; flex:1; height:1px; background:var(--border); }
.form-divider span { color:var(--gray3); font-size:13px; }
.form-phone-btn {
  width:100%; background:transparent; border:1px solid var(--teal-border);
  color:var(--teal); border-radius:8px; padding:13px;
  font-size:15px; font-weight:700; cursor:pointer;
  display:flex; align-items:center; justify-content:center; gap:8px;
  transition:all 0.2s; text-decoration:none;
}
.form-phone-btn:hover { background:var(--teal-pale); border-color:var(--teal); }
.form-phone-btn svg { stroke:var(--teal); }
.form-trust { display:flex; gap:12px; margin-top:18px; flex-wrap:wrap; }
.form-trust-item { display:flex; align-items:center; gap:5px; color:var(--gray3); font-size:12px; }
.form-trust-item::before { content:'✓'; color:var(--gold); font-weight:800; font-size:11px; }
.form-success { text-align:center; padding:24px 0; }
.form-success-check { width:56px; height:56px; border-radius:50%; background:rgba(6,182,212,0.1); border:2px solid var(--teal); display:flex; align-items:center; justify-content:center; margin:0 auto 16px; }
.form-success-check svg { stroke:var(--teal); }
.form-success h3 { font-size:20px; font-weight:800; color:var(--gold); margin-bottom:8px; }
.form-success p { color:var(--gray2); font-size:14px; line-height:1.6; }

/* ─── HERO SPECIFIC ─── */
.hero { max-width:1200px; margin:0 auto; padding:64px 32px 72px; display:grid; grid-template-columns:1fr 420px; gap:56px; align-items:start; }
.hero-badge { display:inline-flex; align-items:center; gap:8px; background:var(--gold-pale); border:1px solid var(--gold-border); color:var(--gold); padding:6px 16px; border-radius:20px; font-size:12px; font-weight:700; letter-spacing:0.5px; text-transform:uppercase; margin-bottom:24px; }

/* ─── BOTTOM CTA GRID ─── */
.cta-bottom-grid { max-width:1100px; margin:0 auto; display:grid; grid-template-columns:1fr 400px; gap:64px; align-items:start; }

/* ══════════════════════════════════════════
   MOBILE — max-width: 768px
══════════════════════════════════════════ */
@media (max-width:768px) {

  body { padding-bottom:72px; }

  /* Mobile call bar */
  .mobile-call-bar {
    display:flex; position:fixed; bottom:0; left:0; right:0; z-index:300;
    background:var(--gold); align-items:center; justify-content:center;
    box-shadow:0 -4px 24px rgba(0,0,0,0.5);
  }
  .mobile-call-bar a {
    display:flex; align-items:center; justify-content:center; gap:12px;
    width:100%; padding:14px 16px; color:#111; font-weight:900; font-size:19px;
    overflow:hidden;
  }
  .mobile-call-bar-icon { width:36px; height:36px; border-radius:8px; background:rgba(0,0,0,0.15); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
  .mobile-call-bar-icon svg { stroke:#111; }
  .mobile-call-bar-text { display:flex; flex-direction:column; line-height:1.1; }
  .mobile-call-bar-text span:first-child { font-size:11px; font-weight:600; opacity:0.65; text-transform:uppercase; letter-spacing:0.5px; white-space:nowrap; }
  .mobile-call-bar-text span:last-child  { font-size:20px; font-weight:900; white-space:nowrap; letter-spacing:0.5px; }

  /* Announcement bar */
  .ann-bar { gap:12px; padding:8px 16px; }
  .ann-item { font-size:12px; }

  /* Header */
  .header-inner { padding:0 16px; height:60px; }
  nav a:not(.nav-cta) { display:none; }
  .nav-cta { margin-left:auto; padding:9px 12px !important; font-size:12px !important; white-space:nowrap; gap:5px !important; }

  /* Section wraps */
  .section-wrap, .section-wrap--narrow { padding:48px 16px; }
  .section-title { font-size:28px; }
  .section-sub   { font-size:15px; }

  /* Page hero */
  .page-hero { padding:40px 16px; }
  .page-hero-h1 { font-size:32px; letter-spacing:-1px; }
  .page-hero-sub { font-size:16px; }

  /* Stats */
  .stats-bar-inner { grid-template-columns:1fr 1fr; padding:16px; }
  .stat-block { padding:16px 12px; }
  .stat-num { font-size:26px; }

  /* Steps */
  .steps-grid { grid-template-columns:1fr; gap:12px; }
  .steps-grid::before { display:none; }
  .step-block { display:grid; grid-template-columns:60px 1fr; column-gap:16px; row-gap:4px; padding:20px; text-align:left; background:var(--charcoal-card); border:1px solid var(--border); border-radius:12px; }
  .step-num-wrap { grid-column:1; grid-row:1/3; flex-direction:column; justify-content:flex-start; align-items:center; margin-bottom:0; }
  .step-num { width:52px; height:52px; }
  .step-num-digit { display:none; }
  .step-title { grid-column:2; grid-row:1; font-size:16px; align-self:center; }
  .step-desc  { grid-column:2; grid-row:2; font-size:13px; text-align:left; }

  /* Services */
  .services-grid { grid-template-columns:1fr; gap:12px; }
  .service-card {
    display:grid;
    grid-template-columns:52px 1fr;
    grid-template-rows:auto auto auto;
    column-gap:16px; row-gap:4px;
    padding:18px 20px; align-items:start;
  }
  .service-icon-wrap {
    grid-column:1; grid-row:1 / span 3;
    margin-bottom:0; align-self:start;
    width:48px; height:48px;
  }
  .service-name { grid-column:2; grid-row:1; font-size:15px; align-self:center; margin-bottom:0; }
  .service-desc { grid-column:2; grid-row:2; font-size:13px; margin-bottom:2px; }
  .service-link { grid-column:2; grid-row:3; font-size:13px; }

  /* Reviews */
  .reviews-grid { grid-template-columns:1fr; gap:16px; }

  /* FAQ */
  .faq-grid { grid-template-columns:1fr; gap:8px; margin-top:32px; }

  /* Why Titan */
  .why-inner { grid-template-columns:1fr; gap:32px; }
  .why-title { font-size:28px; }

  /* Content grid */
  .content-grid { grid-template-columns:1fr; gap:32px; }
  .content-sidebar { position:static; }

  /* Hero */
  .hero { grid-template-columns:1fr; padding:36px 16px 48px; gap:36px; }

  /* Bottom CTA grid */
  .cta-bottom-grid { grid-template-columns:1fr; gap:36px; padding:0 16px; }

  /* Makes strip */
  .makes-strip, [class*="makes"] { padding:36px 16px; }

  /* Phone CTA */
  .phone-cta { width:100%; justify-content:center; padding:14px 20px; }
  .phone-cta-icon { width:36px; height:36px; }
  .phone-cta-label span:first-child { font-size:11px; white-space:nowrap; }
  .phone-cta-label span:last-child  { font-size:18px; white-space:nowrap; }

  /* CTA band */
  .cta-band { padding:48px 16px; }
  .cta-band h2 { font-size:28px; }
  .cta-band-actions { flex-direction:column; align-items:center; }

  /* Footer */
  footer { padding:36px 16px 20px; }
  .footer-inner { grid-template-columns:1fr; gap:28px; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .footer-badges { justify-content:center; }

  /* Page hero actions */
  .page-hero-actions { flex-direction:column; }
  .btn-gold, .btn-teal { width:100%; justify-content:center; }

  /* Trust row */
  .trust-row { gap:16px; }
}


/* ─── NAV DROPDOWN (desktop) ─── */
.nav-group { position:relative; }
.nav-group > a::after { content:' ▾'; font-size:10px; opacity:0.7; }
.nav-sub {
  position:absolute; top:100%; left:0;
  background:var(--charcoal-card);
  border:1px solid var(--border);
  border-radius:8px;
  padding:8px 0;
  min-width:220px;
  display:none;
  z-index:100;
  box-shadow:0 8px 24px rgba(0,0,0,0.3);
}
.nav-group:hover .nav-sub,
.nav-group:focus-within .nav-sub { display:block; }
.nav-sub a { display:block; padding:8px 16px; border-radius:0; margin:0; white-space:nowrap; background:transparent; }
.nav-sub a:hover { background:var(--charcoal-light); color:var(--white); }


/* ─── PHOTO PROOF STRIP ─── */
.proof-strip { max-width:1100px; margin:0 auto; padding:32px; display:grid; grid-template-columns:320px 1fr; gap:48px; align-items:center; }
.proof-strip picture { display:block; }
.proof-strip picture img { width:100%; height:auto; border-radius:12px; border:1px solid var(--border); display:block; }
.proof-strip .proof-copy h2 { font-size:30px; font-weight:900; line-height:1.1; margin:8px 0 14px; letter-spacing:-0.5px; color:var(--white); }
.proof-strip .proof-copy p { color:var(--gray2); font-size:16px; line-height:1.65; }
.proof-strip .proof-copy .section-eyebrow { color:var(--gold); font-size:12px; font-weight:800; letter-spacing:1.2px; text-transform:uppercase; }

/* ─── IN-PAGE PHOTO (suburb/service pages) ─── */
.page-photo { margin:24px 0; max-width:640px; }
.page-photo picture { display:block; }
.page-photo picture img { width:100%; height:auto; border-radius:12px; border:1px solid var(--border); display:block; }
.page-photo figcaption { color:var(--gray3); font-size:13px; margin-top:10px; font-style:italic; }

@media (max-width:768px) {
  .proof-strip { grid-template-columns:1fr; padding:24px 16px; gap:24px; }
  .proof-strip picture { max-width:360px; margin:0 auto; }
  .proof-strip .proof-copy h2 { font-size:24px; }
}
