:root {
  --red: #c8202c;
  --red-hover: #a01622;
  --red-glow: rgba(200, 32, 44, 0.18);
  --black: #0a0a0a;
  --black-2: #141414;
  --black-3: #1c1c1c;
  --black-4: #2a2a2a;
  --white: #ffffff;
  --off-white: #fafafa;
  --gray-100: #f4f4f5;
  --gray-300: #d4d4d8;
  --gray-500: #71717a;
  --gray-600: #52525b;
  --gray-700: #3f3f46;
  --gray-800: #27272a;
  --border-dark: #2e2e2e;
  --radius: 8px;
  --radius-lg: 14px;
  --shadow: 0 4px 24px rgba(0,0,0,.18);
  --shadow-red: 0 8px 28px var(--red-glow);
}
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  font-size:16px; line-height:1.65; color:var(--black);
  background:var(--white); -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4 { font-family:'Plus Jakarta Sans',sans-serif; color:var(--black); line-height:1.18; font-weight:800; letter-spacing:-.015em; }
h1 { font-size:clamp(34px,5vw,58px); margin-bottom:.4em; }
h2 { font-size:clamp(26px,3vw,40px); margin:1.2em 0 .4em; }
h3 { font-size:clamp(18px,1.6vw,22px); margin:1em 0 .4em; }
p { margin-bottom:14px; max-width:68ch; }
a { color:var(--red); text-decoration:none; transition:color .2s; }
a:hover { color:var(--red-hover); text-decoration:underline; }
strong { color:var(--black); font-weight:700; }
img { max-width:100%; height:auto; display:block; }
ul,ol { margin:12px 0 18px; padding-left:22px; }
li { margin-bottom:6px; }

.section { padding:80px 24px; }
.section-dark { background:var(--black); color:var(--off-white); }
.section-dark h2,.section-dark h3 { color:var(--off-white); }
.section-dark p { color:var(--gray-300); }
.section-dark a { color:#ff6b75; }
.section-tinted { background:var(--off-white); }
.wrap { max-width:1180px; margin:0 auto; }
.wrap-narrow { max-width:820px; margin:0 auto; }
.eyebrow { font-size:12px; font-weight:800; text-transform:uppercase; letter-spacing:.14em; color:var(--red); margin-bottom:16px; display:block; }
.section-dark .eyebrow { color:#ff6b75; }
/* TLDR aside (canonical AIO target - Speakable-targetable) */
.tldr-wrap { max-width:820px; margin:40px auto 32px; padding:0 24px; }
.tldr { background:#fff8f8; border-left:5px solid var(--red); padding:24px 28px; border-radius:0 var(--radius) var(--radius) 0; box-shadow:0 2px 12px rgba(200,32,44,.08); }
.tldr-label { display:block; font-size:11px; text-transform:uppercase; letter-spacing:.16em; color:var(--red); font-weight:800; margin-bottom:10px; }
.tldr p { font-size:17px; color:var(--gray-800); line-height:1.65; max-width:none; margin:0; }
.tldr p strong { color:var(--black); }

/* Stat row (canonical 4 cards after TLDR) */
.stat-row-wrap { max-width:1180px; margin:0 auto 40px; padding:0 24px; }
.stat-row { display:grid; grid-template-columns:repeat(4, 1fr); gap:16px; }
.stat-card { background:var(--white); border:1px solid var(--gray-100); border-top:3px solid var(--red); border-radius:var(--radius); padding:24px 18px; text-align:center; box-shadow:0 1px 4px rgba(0,0,0,.04); }
.stat-card-num { display:block; font-family:'Plus Jakarta Sans',sans-serif; font-size:30px; font-weight:800; color:var(--black); line-height:1.1; }
.stat-card-label { display:block; font-size:11.5px; text-transform:uppercase; letter-spacing:.08em; color:var(--gray-600); margin-top:8px; font-weight:700; }
@media (max-width:700px) { .stat-row { grid-template-columns:repeat(2, 1fr); } }

/* Pricing table (canonical for cost-related pages) */
.pricing-wrap { max-width:820px; margin:32px auto; padding:0 24px; }
.pricing-table { width:100%; border-collapse:collapse; background:var(--white); border:1px solid var(--gray-100); border-radius:var(--radius); overflow:hidden; box-shadow:0 1px 4px rgba(0,0,0,.04); }
.pricing-table caption { caption-side:top; text-align:left; padding:14px 18px; background:var(--black); color:var(--white); font-weight:700; font-size:14px; letter-spacing:.04em; text-transform:uppercase; }
.pricing-table th, .pricing-table td { padding:14px 18px; text-align:left; border-bottom:1px solid var(--gray-100); font-size:15px; }
.pricing-table th { background:var(--gray-100); font-weight:700; color:var(--black); font-size:13px; text-transform:uppercase; letter-spacing:.04em; }
.pricing-table tr:last-child td { border-bottom:0; }
.pricing-table tbody tr:hover { background:#fff8f8; }
.pricing-table .price { color:var(--red); font-weight:700; white-space:nowrap; }

/* Benefits grid */
.benefits-grid { display:grid; grid-template-columns:repeat(2, 1fr); gap:16px; margin:24px 0 32px; padding:0; list-style:none; }
.benefits-grid li { background:var(--white); border:1px solid var(--gray-100); border-left:3px solid var(--red); border-radius:var(--radius); padding:18px 22px; font-size:15px; color:var(--gray-700); }
.benefits-grid li strong { display:block; color:var(--black); font-size:15.5px; margin-bottom:4px; font-weight:700; }
@media (max-width:700px) { .benefits-grid { grid-template-columns:1fr; } }

/* Inline image at H2 boundary (3 per long-form page) */
.inline-image { margin:36px 0; border-radius:var(--radius); overflow:hidden; border:1px solid var(--gray-100); box-shadow:0 4px 20px rgba(0,0,0,.06); }
.inline-image img { width:100%; aspect-ratio:16/9; object-fit:cover; display:block; }
.inline-image figcaption { padding:14px 20px; background:var(--gray-100); font-size:13.5px; color:var(--gray-600); border-top:1px solid var(--gray-100); text-align:center; font-style:italic; }

/* Related services (every long-form page) */
.related-services-section { background:var(--off-white); padding:48px 24px; border-top:1px solid var(--gray-100); }
.related-services-inner { max-width:1180px; margin:0 auto; }
.related-services-section h2 { margin-bottom:8px; }
.related-services-section .lede { color:var(--gray-600); margin-bottom:24px; font-size:15px; }
.related-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(220px, 1fr)); gap:14px; }
.related-card { display:block; background:var(--white); border:1px solid var(--gray-100); border-radius:var(--radius); padding:20px; transition:all .2s; text-decoration:none; }
.related-card:hover { transform:translateY(-2px); box-shadow:0 6px 20px rgba(0,0,0,.08); border-color:var(--red); text-decoration:none; }
.related-card .eyebrow-mini { font-size:11px; text-transform:uppercase; letter-spacing:.05em; color:var(--red); font-weight:700; margin-bottom:6px; display:block; }
.related-card h3 { font-size:16px; color:var(--black); margin:0 0 6px; font-family:'Inter',sans-serif; font-weight:700; }
.related-card p { font-size:13.5px; color:var(--gray-600); margin:0; }

/* PAA section (People Also Ask - bottom of every long-form page) */
.paa-section { background:var(--white); padding:64px 24px; border-top:1px solid var(--gray-100); }
.paa-inner { max-width:820px; margin:0 auto; }
.paa-grid { display:grid; gap:14px; margin-top:28px; }
.paa-item { background:var(--off-white); border:1px solid var(--gray-100); border-left:3px solid var(--red); border-radius:6px; padding:22px 26px; }
.paa-item h3 { font-size:17px; color:var(--black); margin:0 0 10px; font-family:'Inter',sans-serif; font-weight:700; }
.paa-item p { font-size:15px; color:var(--gray-700); margin:0; line-height:1.65; max-width:none; }

/* announce */
.announce { background:var(--red); color:var(--white); text-align:center; padding:10px 16px; font-size:13.5px; font-weight:600; }
.announce a { color:var(--white); text-decoration:underline; font-weight:700; }

/* nav - elite standard, larger logo */
nav.site-nav { position:sticky; top:0; z-index:100; background:var(--white); border-bottom:1px solid var(--gray-100); backdrop-filter:saturate(140%) blur(8px); }
.nav-inner { max-width:1320px; margin:0 auto; display:flex; align-items:center; justify-content:space-between; padding:18px 28px; gap:24px; }
.nav-brand { display:flex; align-items:center; gap:14px; }
.nav-brand img { width:auto; height:74px; display:block; }
@media (max-width:900px) { .nav-brand img { height:58px; } .nav-inner { padding:14px 20px; } }
.nav-links { display:flex; gap:28px; list-style:none; align-items:center; padding:0; margin:0; }
.nav-links a { color:var(--gray-700); font-weight:600; font-size:14.5px; }
.nav-links a:hover { color:var(--red); text-decoration:none; }
.nav-right { display:flex; align-items:center; gap:14px; }
.nav-cta { background:var(--red); color:var(--white); padding:11px 22px; border-radius:6px; font-weight:700; font-size:14.5px; transition:all .2s; white-space:nowrap; }
.nav-cta:hover { background:var(--red-hover); color:var(--white); transform:translateY(-1px); text-decoration:none; }
.hamburger { display:none; background:none; border:none; cursor:pointer; padding:8px; width:44px; height:44px; }
.hamburger span { display:block; width:24px; height:2.5px; background:var(--black); margin:5px 0; transition:all .25s; border-radius:2px; }
.hamburger.active span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.hamburger.active span:nth-child(2) { opacity:0; }
.hamburger.active span:nth-child(3) { transform:rotate(-45deg) translate(7px,-7px); }
.mobile-menu { display:none; position:fixed; top:0; right:0; bottom:0; width:280px; background:var(--white); box-shadow:-4px 0 24px rgba(0,0,0,.15); z-index:99; padding:80px 24px 24px; transform:translateX(100%); transition:transform .3s ease; }
.mobile-menu.open { transform:translateX(0); }
.mobile-menu a { display:block; padding:16px 0; font-size:17px; color:var(--gray-700); font-weight:600; border-bottom:1px solid var(--gray-100); }
.mobile-menu a:last-child { border:0; }
.mobile-menu a:hover { color:var(--red); }
.mobile-menu .nav-cta { display:block; text-align:center; margin-top:18px; padding:14px; }
.mobile-menu-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.45); z-index:98; }
.mobile-menu-overlay.open { display:block; }
@media (max-width:900px) { .nav-links { display:none; } .hamburger { display:block; } .mobile-menu { display:block; } .nav-cta { display:none; } }

/* hero */
.hero { position:relative; min-height:480px; display:flex; align-items:center; padding:96px 24px 80px; background:#000; background-size:cover; background-position:center; overflow:hidden; }
.hero-home { background-image:linear-gradient(135deg,rgba(10,10,10,.82) 0%,rgba(10,10,10,.55) 60%,rgba(200,32,44,.42) 100%),url('/images/hero.webp'); min-height:560px; padding:120px 24px 96px; }
.hero-page { background-image:linear-gradient(135deg,rgba(10,10,10,.86) 0%,rgba(10,10,10,.7) 100%),url('/images/hero.webp'); min-height:380px; padding:96px 24px 64px; }
.hero::before { content:""; position:absolute; bottom:0; left:0; right:0; height:60px; background:linear-gradient(to bottom, transparent, var(--black) 95%); pointer-events:none; }
.hero-inner { max-width:1180px; margin:0 auto; position:relative; z-index:2; width:100%; }
.hero h1 { color:var(--off-white); margin-bottom:20px; max-width:22ch; text-shadow:0 2px 16px rgba(0,0,0,.5); }
.hero h1 em { font-style:normal; color:var(--red); }
.hero .lede { font-size:19px; color:var(--off-white); max-width:60ch; margin-bottom:28px; line-height:1.55; opacity:.92; text-shadow:0 1px 8px rgba(0,0,0,.4); }
.cta-row { display:flex; gap:14px; flex-wrap:wrap; }
.btn-primary { display:inline-flex; align-items:center; gap:10px; background:var(--red); color:var(--white); padding:16px 30px; border-radius:6px; font-weight:700; font-size:16px; transition:all .25s; box-shadow:var(--shadow-red); }
.btn-primary:hover { background:var(--red-hover); color:var(--white); transform:translateY(-2px); text-decoration:none; box-shadow:0 12px 36px rgba(200,32,44,.35); }
.btn-outline { display:inline-flex; align-items:center; gap:10px; background:rgba(255,255,255,.06); color:var(--off-white); padding:14px 28px; border-radius:6px; font-weight:600; font-size:15px; border:2px solid rgba(255,255,255,.35); transition:all .25s; backdrop-filter:blur(4px); }
.btn-outline:hover { border-color:var(--white); color:var(--white); background:rgba(255,255,255,.12); text-decoration:none; }
.hero-trust { display:flex; gap:24px; margin-top:32px; flex-wrap:wrap; font-size:13px; color:var(--off-white); opacity:.85; }
.hero-trust span::before { content:"●"; color:var(--red); margin-right:6px; }

/* breadcrumb */
.breadcrumb { background:var(--gray-100); padding:14px 24px; font-size:13.5px; color:var(--gray-500); }
.breadcrumb-inner { max-width:1180px; margin:0 auto; }
.breadcrumb a { color:var(--gray-700); font-weight:600; }
.breadcrumb a:hover { color:var(--red); text-decoration:none; }
.breadcrumb span { margin:0 8px; color:var(--gray-300); }

/* stats */
.stats { background:var(--black-2); color:var(--off-white); padding:36px 24px; border-top:1px solid var(--border-dark); border-bottom:1px solid var(--border-dark); }
.stats-grid { max-width:1180px; margin:0 auto; display:grid; grid-template-columns:repeat(4, 1fr); gap:24px; text-align:center; }
.stat-num { font-family:'Plus Jakarta Sans',sans-serif; font-size:36px; font-weight:800; color:var(--red); line-height:1; display:block; }
.stat-label { font-size:12.5px; text-transform:uppercase; letter-spacing:.08em; color:var(--gray-300); margin-top:8px; font-weight:600; display:block; }
@media (max-width:600px) { .stats-grid { grid-template-columns:repeat(2, 1fr); } }

/* svc cards */
.svc-grid { display:grid; grid-template-columns:repeat(3, 1fr); gap:22px; margin-top:36px; }
.svc-card { background:var(--white); border:1px solid var(--gray-100); border-radius:var(--radius); overflow:hidden; transition:all .25s; display:flex; flex-direction:column; }
.svc-card:hover { transform:translateY(-3px); box-shadow:var(--shadow); border-color:var(--red); }
.svc-card-photo { width:100%; aspect-ratio:16/10; object-fit:cover; display:block; background:var(--gray-100); }
.svc-card-body { padding:22px 24px; display:flex; flex-direction:column; flex:1; }
.svc-card-body h3 { font-size:17px; color:var(--black); margin:0 0 8px; font-family:'Inter',sans-serif; font-weight:700; }
.svc-card-body p { font-size:14.5px; color:var(--gray-600); margin:0 0 12px; flex:1; }
.svc-card-link { font-size:13.5px; font-weight:700; color:var(--red); display:inline-flex; align-items:center; gap:6px; }
.svc-card-link:hover { color:var(--red-hover); }
.svc-card-link::after { content:"→"; transition:transform .2s; }
.svc-card-link:hover::after { transform:translateX(3px); }
@media (max-width:900px) { .svc-grid { grid-template-columns:repeat(2, 1fr); } }
@media (max-width:600px) { .svc-grid { grid-template-columns:1fr; } }

/* steps */
.steps { display:grid; grid-template-columns:repeat(4, 1fr); gap:24px; margin-top:40px; counter-reset:step; }
.step { background:var(--black-2); padding:32px 24px 28px; border-radius:var(--radius); border:1px solid var(--border-dark); position:relative; counter-increment:step; }
.step::before { content:counter(step,decimal-leading-zero); position:absolute; top:-14px; left:24px; background:var(--red); color:var(--white); padding:6px 12px; border-radius:6px; font-family:'Plus Jakarta Sans',sans-serif; font-weight:800; font-size:14px; letter-spacing:.04em; }
.step h3 { font-size:18px; margin-top:8px; margin-bottom:8px; color:var(--off-white); }
.step p { font-size:14.5px; color:var(--gray-300); margin:0; }
@media (max-width:900px) { .steps { grid-template-columns:repeat(2, 1fr); } }
@media (max-width:600px) { .steps { grid-template-columns:1fr; } }

/* why grid */
.why-grid { display:grid; grid-template-columns:repeat(4, 1fr); gap:28px; margin-top:36px; }
.why-cell { padding:24px; border-left:3px solid var(--red); background:var(--white); border-radius:0 var(--radius) var(--radius) 0; box-shadow:0 1px 4px rgba(0,0,0,.04); }
.why-cell h3 { font-size:17px; margin-bottom:10px; font-family:'Inter',sans-serif; font-weight:700; }
.why-cell p { font-size:14.5px; color:var(--gray-600); margin:0; }
@media (max-width:900px) { .why-grid { grid-template-columns:repeat(2, 1fr); } }
@media (max-width:600px) { .why-grid { grid-template-columns:1fr; } }

/* US map - mobile responsive */
.map-wrap { background:var(--black-2); padding:32px 16px; border-radius:var(--radius); margin-top:32px; border:1px solid var(--border-dark); }
@media (max-width:600px) { .map-wrap { padding:20px 8px; margin:24px -8px 0; border-radius:0; } }
.us-map { width:100%; height:auto; display:block; margin:0 auto; aspect-ratio:960/600; max-width:1100px; }
.us-map svg { width:100%; height:auto; }
@media (max-width:600px) {
  .us-map { aspect-ratio:960/600; }
}
.us-map .state { fill:#2a2a2a; stroke:#0a0a0a; stroke-width:.6; transition:fill .15s; }
.us-map .state.active { fill:#c8202c; cursor:pointer; }
.us-map a:hover .state.active, .us-map a:focus .state.active { fill:#a01622; }
.us-map .state.coming { fill:#3a3a3a; cursor:not-allowed; }
.us-map .state.coming:hover { fill:#4a4a4a; }
.us-map a { outline:none; }
.us-map a:focus { outline:2px solid var(--red); outline-offset:2px; }
.map-legend { display:flex; gap:24px; justify-content:center; margin-top:20px; flex-wrap:wrap; font-size:13px; color:var(--gray-300); }
.map-legend span { display:inline-flex; align-items:center; gap:8px; }
.map-legend i { display:inline-block; width:14px; height:14px; border-radius:3px; }
.map-legend i.active { background:var(--red); }
.map-legend i.coming { background:#3a3a3a; }

/* reviews */
.reviews-grid { display:grid; grid-template-columns:repeat(3, 1fr); gap:24px; margin-top:36px; }
.review { background:var(--white); border:1px solid var(--gray-100); border-radius:var(--radius); padding:26px; }
.review .stars { color:var(--red); font-size:18px; letter-spacing:2px; margin-bottom:10px; }
.review p { font-size:15px; color:var(--gray-700); font-style:italic; margin-bottom:14px; }
.review .author { font-size:13.5px; font-weight:700; color:var(--black); }
.review .author span { font-weight:500; color:var(--gray-500); }
@media (max-width:900px) { .reviews-grid { grid-template-columns:1fr; } }

/* problems */
.problems-grid { display:grid; grid-template-columns:repeat(3, 1fr); gap:14px; margin-top:28px; }
.problem-link { display:block; padding:16px 20px; background:var(--white); border:1px solid var(--gray-100); border-radius:6px; color:var(--black); font-size:14.5px; font-weight:600; transition:all .2s; }
.problem-link:hover { border-color:var(--red); color:var(--red); text-decoration:none; transform:translateX(3px); }
.problem-link::after { content:" →"; color:var(--red); }
@media (max-width:900px) { .problems-grid { grid-template-columns:repeat(2, 1fr); } }
@media (max-width:600px) { .problems-grid { grid-template-columns:1fr; } }

/* faq */
.faq-list { margin-top:28px; }
.faq-item { background:var(--white); border:1px solid var(--gray-100); border-left:3px solid var(--red); border-radius:6px; padding:20px 24px; margin-bottom:12px; }
.faq-item h3 { font-size:17px; color:var(--black); margin:0 0 8px; font-family:'Inter',sans-serif; font-weight:700; }
.faq-item p { font-size:15px; color:var(--gray-700); margin:0; max-width:none; }

/* === Triton-style editorial chrome (cloned for A1 inner pages) === */

/* Subhero - WHITE theme with subtle photo bg + breadcrumbs (matches homepage palette but light) */
.subhero { background:var(--off-white); color:var(--gray-700); padding:96px 32px 64px; position:relative; overflow:hidden; border-bottom:1px solid var(--gray-100); }
.subhero-bg { position:absolute; inset:0; background-size:cover; background-position:center; opacity:.10; z-index:0; }
.subhero::before { content:""; position:absolute; inset:0; background:linear-gradient(135deg, rgba(255,255,255,.85) 0%, rgba(255,255,255,.92) 60%, rgba(200,32,44,.06) 110%); z-index:1; }
.subhero-inner { max-width:1180px; margin:0 auto; position:relative; z-index:2; }
.breadcrumbs { font-family:'Inter',sans-serif; font-size:11.5px; font-weight:700; color:var(--gray-500); margin-bottom:22px; text-transform:uppercase; letter-spacing:.12em; }
.breadcrumbs a { color:var(--gray-700); transition:color .15s; }
.breadcrumbs a:hover { color:var(--red); text-decoration:none; }
.breadcrumbs .sep { margin:0 8px; color:var(--gray-300); }
.subhero h1 { color:var(--black); margin-bottom:18px; max-width:24ch; }
.subhero-lead { font-size:18px; line-height:1.7; color:var(--gray-700); max-width:760px; margin-bottom:28px; }
.subhero-actions { display:flex; gap:12px; flex-wrap:wrap; }
.subhero-actions .btn-outline { color:var(--black); border-color:var(--gray-300); background:var(--white); }
.subhero-actions .btn-outline:hover { border-color:var(--red); color:var(--red); background:var(--white); }

/* Prose wrapper (Triton's main content style) */
.prose { max-width:780px; margin:0 auto; font-size:17px; line-height:1.8; color:var(--gray-700); padding:0 24px; }
.prose h2 { margin:64px 0 18px; color:var(--black); font-size:clamp(24px,2.6vw,34px); }
.prose h2:first-child { margin-top:24px; }
.prose h3 { font-size:21px; font-weight:700; color:var(--gray-800); margin:40px 0 14px; letter-spacing:-.01em; }
.prose p { margin-bottom:16px; max-width:none; }
.prose ul, .prose ol { padding-left:22px; margin:14px 0 22px; }
.prose ul li, .prose ol li { font-size:17px; margin-bottom:10px; line-height:1.7; }
.prose strong { color:var(--black); font-weight:700; }
.prose a { color:var(--red); text-decoration:underline; text-decoration-thickness:1.5px; text-underline-offset:3px; }
.prose a:hover { color:var(--red-hover); }

/* Triton-style TLDR (Who/What/Where/How structure) */
.prose .tldr-box { background:var(--white); border:1px solid var(--gray-100); border-left:3px solid var(--red); padding:24px 28px; margin:0 0 36px; box-shadow:var(--shadow-sm); border-radius:0 6px 6px 0; }
.prose .tldr-box .tldr-label { font-family:'Inter',monospace; font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:.16em; color:var(--red); margin-bottom:12px; display:block; }
.prose .tldr-box p { font-size:15.5px; line-height:1.7; color:var(--gray-800); margin-bottom:8px; }
.prose .tldr-box p:last-child { margin-bottom:0; }
.prose .tldr-box p strong { color:var(--black); font-weight:700; min-width:70px; display:inline-block; }

/* Gallery grid (Triton signature - 3-col captioned photos) */
.gallery-grid { display:grid; grid-template-columns:repeat(3, 1fr); gap:18px; margin:36px 0; }
.gallery-grid figure { margin:0; background:var(--white); border:1px solid var(--gray-100); border-radius:8px; overflow:hidden; }
.gallery-grid figure img { width:100%; aspect-ratio:4/3; object-fit:cover; display:block; filter:grayscale(.25) contrast(1.05) brightness(.94); transition:filter .3s, transform .3s; }
.gallery-grid figure:hover img { filter:none; transform:scale(1.02); }
.gallery-grid figcaption { padding:12px 14px; font-size:13px; color:var(--gray-600); border-top:1px solid var(--gray-100); }
@media (max-width:900px) { .gallery-grid { grid-template-columns:repeat(2, 1fr); } }
@media (max-width:600px) { .gallery-grid { grid-template-columns:1fr; } }

/* Section variants matching Triton: section-bg (white), section-bone (off-white) */
.section-bg { background:var(--white); padding:64px 0; }
.section-bone { background:var(--off-white); padding:64px 0; }
.section-dark-block { background:var(--black); color:var(--off-white); padding:64px 24px; }
.section-dark-block h2, .section-dark-block h3 { color:var(--off-white); }
.section-dark-block p { color:var(--gray-300); }

/* Pricing table inside .prose for cost-related H2s */
.prose .pricing-table { width:100%; border-collapse:collapse; background:var(--white); border:1px solid var(--gray-100); border-radius:8px; overflow:hidden; margin:24px 0 32px; }
.prose .pricing-table caption { caption-side:top; text-align:left; padding:12px 16px; background:var(--black); color:var(--white); font-weight:700; font-size:13px; letter-spacing:.04em; text-transform:uppercase; }
.prose .pricing-table th, .prose .pricing-table td { padding:14px 18px; text-align:left; border-bottom:1px solid var(--gray-100); font-size:15px; }
.prose .pricing-table th { background:var(--gray-100); font-weight:700; color:var(--black); font-size:12.5px; text-transform:uppercase; letter-spacing:.04em; }

/* Service area inline strip with city interlinks */
.city-interlink { padding:64px 24px; background:var(--off-white); }
.city-interlink-inner { max-width:1180px; margin:0 auto; }
.city-interlink h2 { margin-bottom:8px; }
.city-interlink .lede { color:var(--gray-600); font-size:16px; margin-bottom:24px; }
.city-chips { display:flex; flex-wrap:wrap; gap:10px; }
.city-chip { background:var(--white); border:1px solid var(--gray-100); color:var(--gray-700); padding:10px 18px; border-radius:24px; font-size:14px; font-weight:600; transition:all .2s; }
.city-chip:hover { background:var(--red); border-color:var(--red); color:var(--white); text-decoration:none; transform:translateY(-1px); }

/* Persona card (about page) */
.persona-card { display:grid; grid-template-columns:280px 1fr; gap:36px; max-width:980px; margin:24px auto 0; background:var(--white); border:1px solid var(--gray-100); border-radius:var(--radius-lg); padding:36px; box-shadow:var(--shadow-sm); }
.persona-photo { background:var(--off-white); border-radius:var(--radius); padding:32px; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; min-height:240px; border:1px solid var(--gray-100); }
.persona-photo .role { margin-top:14px; font-size:11px; text-transform:uppercase; letter-spacing:.12em; color:var(--red); font-weight:800; }
.persona-photo svg { color:var(--red); width:64px; height:64px; }
.persona-body h3 { font-size:24px; margin:0 0 4px; color:var(--black); }
.persona-body .title { font-size:13px; text-transform:uppercase; letter-spacing:.08em; color:var(--gray-600); font-weight:700; margin-bottom:18px; }
.persona-body p { font-size:15.5px; line-height:1.7; color:var(--gray-700); margin-bottom:14px; }
.founder-creds { display:flex; flex-wrap:wrap; gap:8px; margin-top:18px; }
.founder-cred { display:inline-flex; align-items:center; gap:6px; background:var(--off-white); border:1px solid var(--gray-100); padding:6px 12px; border-radius:24px; font-size:12px; font-weight:700; color:var(--gray-700); }
.founder-cred::before { content:"✓"; color:var(--red); font-weight:900; }
@media (max-width:800px) { .persona-card { grid-template-columns:1fr; padding:24px; } }

/* Blog hub post grid */
.blog-grid { display:grid; grid-template-columns:repeat(3, 1fr); gap:22px; max-width:1180px; margin:32px auto 0; padding:0 24px; }
.blog-card { background:var(--white); border:1px solid var(--gray-100); border-radius:var(--radius); overflow:hidden; transition:all .25s; display:flex; flex-direction:column; }
.blog-card:hover { transform:translateY(-3px); box-shadow:var(--shadow); border-color:var(--red); text-decoration:none; }
.blog-card-photo { width:100%; aspect-ratio:16/10; object-fit:cover; display:block; background:var(--gray-100); filter:grayscale(.2); transition:filter .3s; }
.blog-card:hover .blog-card-photo { filter:none; }
.blog-card-body { padding:22px 24px; display:flex; flex-direction:column; flex:1; }
.blog-card-cat { font-size:11px; text-transform:uppercase; letter-spacing:.08em; color:var(--red); font-weight:800; margin-bottom:8px; }
.blog-card h3 { font-size:18px; color:var(--black); margin:0 0 8px; font-family:'Inter',sans-serif; font-weight:700; line-height:1.3; }
.blog-card p { font-size:14.5px; color:var(--gray-600); margin:0 0 14px; flex:1; line-height:1.55; }
.blog-card-meta { font-size:12.5px; color:var(--gray-500); }
@media (max-width:900px) { .blog-grid { grid-template-columns:repeat(2, 1fr); } }
@media (max-width:600px) { .blog-grid { grid-template-columns:1fr; } }

/* Shop product grid */
.shop-grid { display:grid; grid-template-columns:repeat(3, 1fr); gap:22px; max-width:1180px; margin:32px auto 0; padding:0 24px; }
.shop-card { background:var(--white); border:1px solid var(--gray-100); border-radius:var(--radius); overflow:hidden; display:flex; flex-direction:column; }
.shop-card-photo { width:100%; aspect-ratio:1/1; object-fit:cover; background:var(--gray-100); }
.shop-card-body { padding:22px 24px; display:flex; flex-direction:column; flex:1; }
.shop-card-cat { font-size:11px; text-transform:uppercase; letter-spacing:.08em; color:var(--red); font-weight:800; margin-bottom:6px; }
.shop-card h3 { font-size:17px; color:var(--black); margin:0 0 8px; font-family:'Inter',sans-serif; font-weight:700; }
.shop-card p { font-size:14px; color:var(--gray-600); margin:0 0 14px; flex:1; line-height:1.55; }
.shop-card-cta { background:var(--red); color:var(--white); text-align:center; padding:12px 18px; border-radius:6px; font-weight:700; font-size:14px; margin-top:auto; transition:background .2s; }
.shop-card-cta:hover { background:var(--red-hover); color:var(--white); text-decoration:none; }
@media (max-width:900px) { .shop-grid { grid-template-columns:repeat(2, 1fr); } }
@media (max-width:600px) { .shop-grid { grid-template-columns:1fr; } }

/* Contact 3-column */
.contact-grid { display:grid; grid-template-columns:repeat(3, 1fr); gap:22px; max-width:1180px; margin:32px auto 0; padding:0 24px; }
.contact-card { background:var(--white); border:1px solid var(--gray-100); border-top:3px solid var(--red); border-radius:var(--radius); padding:32px 28px; text-align:center; }
.contact-card-icon { width:64px; height:64px; background:var(--off-white); border-radius:50%; display:flex; align-items:center; justify-content:center; margin:0 auto 16px; color:var(--red); font-family:'Plus Jakarta Sans',sans-serif; font-weight:800; font-size:26px; }
.contact-card h3 { font-size:19px; color:var(--black); margin:0 0 10px; font-family:'Inter',sans-serif; font-weight:700; }
.contact-card p { font-size:14.5px; color:var(--gray-600); margin:0 0 18px; min-height:64px; }
.contact-card .btn-primary, .contact-card .btn-outline { width:100%; justify-content:center; }
@media (max-width:900px) { .contact-grid { grid-template-columns:1fr; } }

/* Locations metro/state grid */
.metro-grid { display:grid; grid-template-columns:repeat(3, 1fr); gap:18px; max-width:1180px; margin:32px auto 0; padding:0 24px; }
.metro-card { background:var(--white); border:1px solid var(--gray-100); border-left:4px solid var(--red); border-radius:var(--radius); padding:24px; transition:all .2s; }
.metro-card:hover { box-shadow:var(--shadow); transform:translateY(-2px); border-color:var(--red); border-left-color:var(--red); text-decoration:none; }
.metro-card.coming { border-left-color:var(--gray-300); opacity:.7; }
.metro-card h3 { color:var(--black); font-size:17px; margin:0 0 4px; font-family:'Inter',sans-serif; font-weight:700; }
.metro-card .meta { font-size:11px; text-transform:uppercase; letter-spacing:.08em; color:var(--red); font-weight:800; margin-bottom:8px; }
.metro-card.coming .meta { color:var(--gray-500); }
.metro-card p { font-size:14px; color:var(--gray-600); margin:0; }
@media (max-width:800px) { .metro-grid { grid-template-columns:repeat(2, 1fr); } }
@media (max-width:500px) { .metro-grid { grid-template-columns:1fr; } }

/* Final CTA banner (Triton-style) */
.cta-banner { background:linear-gradient(135deg, var(--red) 0%, var(--red-hover) 100%); color:var(--white); padding:72px 24px; text-align:center; }
.cta-banner h2 { color:var(--white); font-size:clamp(28px,3.4vw,40px); margin-bottom:14px; }
.cta-banner p { color:rgba(255,255,255,.92); font-size:18px; max-width:60ch; margin:0 auto 28px; }
.cta-banner .btn-fill { background:var(--black); color:var(--white); display:inline-flex; align-items:center; gap:10px; padding:16px 32px; border-radius:6px; font-weight:700; font-size:16px; text-decoration:none; transition:all .25s; }
.cta-banner .btn-fill:hover { background:var(--white); color:var(--red); transform:translateY(-2px); text-decoration:none; }

/* === legacy rich chrome (kept but no longer primary) === */

/* Inner hero with bg photo */
.hero-rich { position:relative; min-height:520px; display:flex; align-items:center; padding:120px 24px 100px; background:#000; background-size:cover; background-position:center; overflow:hidden; }
.hero-rich::before { content:""; position:absolute; bottom:0; left:0; right:0; height:80px; background:linear-gradient(to bottom, transparent, var(--black) 95%); pointer-events:none; }
.hero-rich-inner { max-width:1180px; margin:0 auto; position:relative; z-index:2; width:100%; }
.hero-rich h1 { color:var(--off-white); margin-bottom:18px; max-width:22ch; text-shadow:0 2px 16px rgba(0,0,0,.55); }
.hero-rich h1 em { font-style:normal; color:var(--red); }
.hero-rich .lede { font-size:18px; color:var(--off-white); max-width:60ch; margin-bottom:24px; line-height:1.55; opacity:.92; text-shadow:0 1px 8px rgba(0,0,0,.4); }

/* Img+text alternating block (TCSDR pattern) */
.img-text-block { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; max-width:1180px; margin:0 auto; padding:0 24px; }
.img-text-block.flip .img-text-photo { order:2; }
.img-text-photo { border-radius:var(--radius-lg); overflow:hidden; box-shadow:0 12px 40px rgba(0,0,0,.12); }
.img-text-photo img { width:100%; height:auto; aspect-ratio:4/3; object-fit:cover; display:block; }
.img-text-copy h2 { margin-bottom:.6em; }
.img-text-copy p { font-size:17px; line-height:1.7; color:var(--gray-700); margin-bottom:14px; }
.img-text-copy ul { padding-left:0; list-style:none; margin:18px 0; }
.img-text-copy ul li { padding:10px 0 10px 32px; position:relative; font-size:15.5px; color:var(--gray-800); border-bottom:1px solid var(--gray-100); }
.img-text-copy ul li:last-child { border-bottom:0; }
.img-text-copy ul li::before { content:""; position:absolute; left:0; top:14px; width:18px; height:18px; background:var(--red); border-radius:50%; }
.img-text-copy ul li::after { content:""; position:absolute; left:5px; top:19px; width:8px; height:4px; border-left:2px solid var(--white); border-bottom:2px solid var(--white); transform:rotate(-45deg); }
@media (max-width:900px) { .img-text-block { grid-template-columns:1fr; gap:32px; } .img-text-block.flip .img-text-photo { order:0; } }

/* Symptom grid (TCSDR-style 6 symptom cards) */
.symptom-grid { display:grid; grid-template-columns:repeat(3, 1fr); gap:20px; margin-top:36px; max-width:1180px; margin-left:auto; margin-right:auto; }
.symptom { background:var(--white); border:1px solid var(--gray-100); border-top:3px solid var(--red); border-radius:var(--radius); padding:24px; display:flex; gap:16px; align-items:flex-start; }
.symptom-icon { flex-shrink:0; width:44px; height:44px; background:var(--red); color:var(--white); border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:'Plus Jakarta Sans',sans-serif; font-weight:800; font-size:18px; }
.symptom-text { flex:1; }
.symptom-text h3 { font-size:16px; margin:0 0 6px; font-family:'Inter',sans-serif; font-weight:700; color:var(--black); }
.symptom-text p { font-size:14px; color:var(--gray-600); margin:0; line-height:1.55; }
@media (max-width:900px) { .symptom-grid { grid-template-columns:repeat(2, 1fr); } }
@media (max-width:600px) { .symptom-grid { grid-template-columns:1fr; } }

/* Brand grid (4-col logos/names) */
.brand-grid { display:grid; grid-template-columns:repeat(4, 1fr); gap:14px; margin-top:36px; max-width:1180px; margin-left:auto; margin-right:auto; padding:0 24px; }
.brand-cell { background:var(--white); border:1px solid var(--gray-100); border-radius:var(--radius); padding:18px; text-align:center; transition:all .2s; }
.brand-cell:hover { border-color:var(--red); transform:translateY(-2px); }
.brand-cell strong { display:block; font-size:15px; color:var(--black); font-weight:700; margin-bottom:4px; }
.brand-cell small { display:block; font-size:13px; color:var(--gray-500); }
@media (max-width:700px) { .brand-grid { grid-template-columns:repeat(2, 1fr); } }

/* Process steps (numbered, TCL-style) */
.process-list { counter-reset:step; max-width:980px; margin:36px auto 0; padding:0 24px; }
.process-step { background:var(--white); border:1px solid var(--gray-100); border-radius:var(--radius); padding:26px 28px 26px 90px; margin-bottom:14px; position:relative; counter-increment:step; transition:all .2s; }
.process-step:hover { box-shadow:var(--shadow); border-color:var(--red); }
.process-step::before { content:counter(step,decimal-leading-zero); position:absolute; left:24px; top:24px; width:50px; height:50px; background:var(--red); color:var(--white); border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:'Plus Jakarta Sans',sans-serif; font-weight:800; font-size:20px; }
.process-step h3 { margin:0 0 8px; font-size:18px; color:var(--black); font-family:'Inter',sans-serif; font-weight:700; }
.process-step p { margin:0; font-size:15px; color:var(--gray-700); line-height:1.65; max-width:none; }

/* Service area card (with mini-state-pill list) */
.area-strip { background:var(--black); color:var(--off-white); padding:64px 24px; }
.area-strip-inner { max-width:1180px; margin:0 auto; }
.area-strip h2 { color:var(--off-white); }
.area-strip p { color:var(--gray-300); }
.area-pills { display:flex; flex-wrap:wrap; gap:10px; margin-top:24px; }
.area-pill { background:var(--black-2); border:1px solid var(--border-dark); color:var(--off-white); padding:10px 18px; border-radius:24px; font-size:14px; font-weight:600; transition:all .2s; }
.area-pill:hover { background:var(--red); border-color:var(--red); color:var(--white); text-decoration:none; }

/* Reviews row (3 cards) */
.review-row-section { background:var(--off-white); padding:80px 24px; }
.review-row-inner { max-width:1180px; margin:0 auto; text-align:center; }
.review-row-inner h2 { margin-bottom:36px; }
.review-row { display:grid; grid-template-columns:repeat(3, 1fr); gap:24px; text-align:left; }
@media (max-width:900px) { .review-row { grid-template-columns:1fr; } }

/* FAQ accordion (visible) */
.faq-accordion { max-width:820px; margin:36px auto 0; padding:0 24px; }
.faq-accordion details { background:var(--white); border:1px solid var(--gray-100); border-left:3px solid var(--red); border-radius:6px; padding:0; margin-bottom:10px; transition:all .2s; }
.faq-accordion details[open] { box-shadow:var(--shadow); }
.faq-accordion summary { padding:18px 24px; cursor:pointer; font-size:16.5px; font-weight:700; color:var(--black); list-style:none; position:relative; padding-right:48px; }
.faq-accordion summary::-webkit-details-marker { display:none; }
.faq-accordion summary::after { content:"+"; position:absolute; right:22px; top:50%; transform:translateY(-50%); color:var(--red); font-size:24px; font-weight:300; transition:transform .2s; }
.faq-accordion details[open] summary::after { transform:translateY(-50%) rotate(45deg); }
.faq-accordion .faq-a { padding:0 24px 22px; font-size:15px; color:var(--gray-700); line-height:1.7; }

/* Section header centered */
.section-head { text-align:center; max-width:760px; margin:0 auto 8px; padding:0 24px; }
.section-head .eyebrow { display:inline-block; }
.section-head h2 { margin:0 0 14px; }
.section-head p { color:var(--gray-600); font-size:17px; max-width:62ch; margin:0 auto; }
.section-dark .section-head h2 { color:var(--off-white); }
.section-dark .section-head p { color:var(--gray-300); }

/* article (blog post - kept for compatibility but inner pages use rich sections now) */
.article-body { max-width:760px; margin:48px auto; padding:0 24px; }
.article-body h2 { font-size:clamp(22px,2.4vw,30px); margin:1.4em 0 .4em; }
.article-body h3 { font-size:clamp(18px,1.6vw,22px); margin:1.2em 0 .3em; color:var(--gray-800); }
.article-body p { font-size:17px; color:var(--gray-700); line-height:1.75; max-width:none; }
.article-body ul { padding-left:24px; }
.article-body li { font-size:17px; color:var(--gray-700); }
.article-body img { border-radius:var(--radius); margin:24px 0; }
.article-body a { color:var(--red); text-decoration:underline; }
.article-meta { color:var(--gray-500); font-size:14px; margin-bottom:20px; padding-bottom:16px; border-bottom:1px solid var(--gray-100); }

/* areas/locations */
.location-cards { display:grid; grid-template-columns:repeat(auto-fit, minmax(260px, 1fr)); gap:16px; margin-top:24px; }
.location-card { background:var(--white); border:1px solid var(--gray-100); border-left:4px solid var(--red); border-radius:var(--radius); padding:24px; transition:all .2s; }
.location-card:hover { box-shadow:var(--shadow); transform:translateY(-2px); }
.location-card h3 { color:var(--black); margin:0 0 8px; font-family:'Inter',sans-serif; font-weight:700; font-size:18px; }
.location-card a { color:var(--black); }
.location-card .city-meta { font-size:13.5px; color:var(--gray-500); }

/* ai share */
.aishare { background:var(--black); color:var(--off-white); padding:60px 24px; border-top:1px solid var(--border-dark); text-align:center; }
.aishare-label { font-size:11px; color:var(--gray-300); letter-spacing:.18em; text-transform:uppercase; margin-bottom:18px; font-weight:700; }
.aishare-row { display:flex; justify-content:center; gap:12px; flex-wrap:wrap; }
.aishare-row a { padding:10px 22px; border:1px solid var(--border-dark); color:var(--off-white); font-family:'Inter',sans-serif; font-size:13px; font-weight:600; letter-spacing:.04em; transition:all .2s; border-radius:4px; background:var(--black-2); }
.aishare-row a:hover { border-color:var(--red); color:var(--red); text-decoration:none; }

/* final cta */
.cta-final { background:var(--red); color:var(--white); padding:64px 24px; text-align:center; }
.cta-final h2 { color:var(--white); font-size:clamp(28px,3.4vw,42px); margin-bottom:14px; }
.cta-final p { color:rgba(255,255,255,.9); font-size:18px; max-width:60ch; margin:0 auto 28px; }
.cta-final .btn-primary { background:var(--black); border:1px solid var(--black); }
.cta-final .btn-primary:hover { background:var(--white); color:var(--red); border-color:var(--white); }

/* footer */
footer { background:var(--black); color:var(--gray-300); padding:48px 24px 24px; }
.footer-inner { max-width:1180px; margin:0 auto; display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:32px; }
.footer-col h4 { color:var(--white); font-size:14px; text-transform:uppercase; letter-spacing:.08em; margin-bottom:14px; font-family:'Inter',sans-serif; font-weight:700; }
.footer-col ul { list-style:none; padding:0; margin:0; }
.footer-col li { margin-bottom:8px; }
.footer-col a { color:var(--gray-300); font-size:14px; }
.footer-col a:hover { color:var(--white); text-decoration:none; }
.footer-brand img { height:60px; margin-bottom:14px; }
.footer-brand p { color:var(--gray-300); font-size:14px; max-width:30ch; margin-bottom:18px; }
.footer-social { display:flex; gap:8px; flex-wrap:wrap; margin-top:8px; }
.footer-social a { width:40px; height:40px; border:1px solid var(--border-dark); display:flex; align-items:center; justify-content:center; color:var(--gray-300); transition:all .2s; border-radius:6px; background:var(--black-2); }
.footer-social a:hover { border-color:var(--red); color:var(--red); text-decoration:none; }
.footer-social svg { width:16px; height:16px; fill:currentColor; }
.footer-bottom { max-width:1180px; margin:32px auto 0; padding-top:24px; border-top:1px solid var(--border-dark); display:flex; justify-content:space-between; gap:24px; flex-wrap:wrap; font-size:13px; color:var(--gray-500); }
@media (max-width:800px) { .footer-inner { grid-template-columns:1fr 1fr; } }
@media (max-width:500px) { .footer-inner { grid-template-columns:1fr; } }

/* floating call */
.float-call { position:fixed; bottom:20px; right:20px; background:var(--red); color:var(--white); width:60px; height:60px; border-radius:50%; display:flex; align-items:center; justify-content:center; box-shadow:0 8px 24px rgba(200,32,44,.4); z-index:97; transition:transform .2s; }
.float-call:hover { transform:scale(1.08); color:var(--white); }
.float-call svg { width:28px; height:28px; fill:currentColor; }
