/*
Theme Name: HubNetwork
Description: Shared theme for all HubNetwork sites — FuelEconomyHub, TowCapacityHub, ThePayloadHub, TrailerHitchHub, RVCenterHub
Version: 1.0
Author: HubNetwork
*/

/* ===== CSS VARIABLES (defaults; overridden per-site via PHP inline style) ===== */
:root {
  --p900:#0d2b1a; --p800:#14401f; --p700:#1a5c2a;
  --p600:#1e7a33; --p500:#25a041; --p400:#34c759;
  --p300:#6ed98a; --p100:#d4f5dd; --p50:#f0faf3;

  --gold:#c8a44a; --gold-pale:#fdf6e3; --gold-border:rgba(200,164,74,0.3);
  --amber:#f5a623; --amber-bg:#fdf3dc; --amber-border:#fce4a8;
  --danger:#e53e3e;

  --text:#1a1a1a; --text2:#4a5568; --text3:#718096;
  --border:#e2e8e4; --bg:#f8faf9; --white:#ffffff;

  --radius:12px; --radius-sm:8px;
  --shadow:0 2px 12px rgba(0,0,0,0.07);
  --shadow-hover:0 8px 28px rgba(0,0,0,0.12);
}

/* ===== RESET ===== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
img { max-width: 100%; height: auto; display: block; }
a { color: var(--p600); }

/* ===== TYPOGRAPHY ===== */
body {
  font-family: 'DM Sans', sans-serif;
  font-size: 15px;
  line-height: 1.6;
  color: var(--text);
  background: var(--bg);
}
h1,h2,h3,h4,h5,h6 {
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  line-height: 1.15;
  color: var(--text);
}
p { margin-bottom: 1em; }
p:last-child { margin-bottom: 0; }

/* ===== LAYOUT ===== */
.hn-wrap { max-width: 1200px; margin: 0 auto; padding: 0 20px; }
.hn-section { padding: 60px 0; }
.hn-section-alt { background: var(--white); }

/* ===== NAV ===== */
.hn-nav {
  background: var(--p900);
  border-bottom: 2px solid var(--p700);
  position: sticky; top: 0; z-index: 100;
}
.hn-nav-inner {
  max-width: 1200px; margin: 0 auto; padding: 0 20px;
  display: flex; align-items: center; justify-content: space-between; height: 58px;
}
.hn-nav-brand {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 22px; font-weight: 800; color: #fff;
  text-decoration: none; letter-spacing: 0.05em;
  display: flex; align-items: center; gap: 8px;
}
.hn-nav-brand .brand-accent { color: var(--p300); }
.hn-nav-links { display: flex; align-items: center; gap: 28px; }
.hn-nav-links a {
  color: rgba(255,255,255,0.8); text-decoration: none;
  font-size: 13px; letter-spacing: 0.06em; text-transform: uppercase;
  transition: color 0.2s;
}
.hn-nav-links a:hover { color: var(--p300); }

/* ===== HERO ===== */
.hn-hero {
  background:
    linear-gradient(135deg, rgba(13,43,26,0.93) 0%, rgba(20,64,31,0.87) 100%),
    url('https://images.unsplash.com/photo-1489824904134-891ab64532f1?w=1600&q=80') center/cover no-repeat;
  padding: 80px 20px 64px;
  text-align: center;
}
.hn-hero h1 { font-size: clamp(34px,6vw,72px); color: #fff; margin-bottom: 14px; }
.hn-hero .hero-sub {
  font-size: 18px; color: rgba(255,255,255,0.8);
  font-family: 'DM Sans',sans-serif; font-weight: 400;
  text-transform: none; letter-spacing: 0; margin-bottom: 36px;
}

/* Search bar */
.hn-search {
  display: flex; gap: 10px; max-width: 820px; margin: 0 auto 24px;
  background: rgba(255,255,255,0.1); border-radius: var(--radius);
  padding: 8px; backdrop-filter: blur(10px);
}
.hn-search select, .hn-search input {
  flex: 1; min-width: 0; padding: 12px 16px;
  border: 1px solid rgba(255,255,255,0.2); border-radius: var(--radius-sm);
  background: rgba(255,255,255,0.96); font-family: 'DM Sans',sans-serif;
  font-size: 14px; color: var(--text); outline: none;
}
.hn-search button {
  padding: 12px 28px; background: var(--p500); color: #fff; border: none;
  border-radius: var(--radius-sm); font-family: 'Barlow Condensed',sans-serif;
  font-size: 16px; font-weight: 700; letter-spacing: 0.05em; cursor: pointer;
  white-space: nowrap; transition: background 0.2s;
}
.hn-search button:hover { background: var(--p400); }

/* Search tags */
.hn-tags { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; margin-bottom: 36px; }
.hn-tags a {
  background: rgba(255,255,255,0.14); color: rgba(255,255,255,0.9);
  padding: 5px 14px; border-radius: 999px; font-size: 12px;
  text-decoration: none; border: 1px solid rgba(255,255,255,0.2); transition: all 0.2s;
}
.hn-tags a:hover { background: rgba(255,255,255,0.25); }

/* Hero stats */
.hn-hero-stats { display: flex; gap: 48px; justify-content: center; flex-wrap: wrap; }
.hn-hero-stat .num {
  display: block; font-family: 'Barlow Condensed',sans-serif;
  font-size: 38px; font-weight: 800; color: var(--p300);
}
.hn-hero-stat .lbl {
  font-size: 11px; color: rgba(255,255,255,0.55);
  text-transform: uppercase; letter-spacing: 0.12em;
}

/* ===== SECTION HEADERS ===== */
.hn-section-head {
  display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 28px;
}
.hn-section-head h2 { font-size: 32px; color: var(--p900); }
.hn-section-head a { font-size: 13px; color: var(--p600); text-decoration: none; font-weight: 500; }
.hn-section-head a:hover { color: var(--p500); }

/* ===== VEHICLE CARDS ===== */
.hn-grid-4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; }
.hn-grid-5 { display: grid; grid-template-columns: repeat(5,1fr); gap: 16px; }
.hn-grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }

.hn-vehicle-card {
  background: var(--white); border-radius: var(--radius); border: 1px solid var(--border);
  padding: 20px; text-decoration: none; color: inherit; display: block;
  box-shadow: var(--shadow); transition: all 0.2s;
}
.hn-vehicle-card:hover {
  transform: translateY(-3px); box-shadow: var(--shadow-hover); border-color: var(--p300);
}
.hn-card-primary {
  font-family: 'Barlow Condensed',sans-serif; font-size: 54px;
  font-weight: 800; color: var(--p600); line-height: 1;
}
.hn-card-primary-unit { font-size: 16px; color: var(--text3); font-weight: 400; margin-left: 2px; }
.hn-card-sub { display: flex; gap: 12px; margin-top: 6px; }
.hn-card-sub span { font-size: 12px; color: var(--text3); }
.hn-card-sub strong { color: var(--text2); }
.hn-card-title {
  font-family: 'Barlow Condensed',sans-serif; font-size: 18px;
  font-weight: 700; margin-top: 12px; color: var(--p900); line-height: 1.2;
}
.hn-card-class { font-size: 11px; color: var(--text3); text-transform: uppercase; letter-spacing: 0.05em; margin-top: 3px; }
.hn-eff-bar { height: 4px; background: var(--border); border-radius: 2px; margin-top: 12px; overflow: hidden; }
.hn-eff-fill { height: 100%; border-radius: 2px; background: linear-gradient(90deg, var(--p500), var(--p300)); }

/* ===== MAKE GRID ===== */
.hn-make-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(130px,1fr)); gap: 12px; }
.hn-make-card {
  background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-sm);
  padding: 16px 12px; text-align: center; text-decoration: none; color: inherit;
  transition: all 0.2s; box-shadow: var(--shadow);
}
.hn-make-card:hover { border-color: var(--p400); background: var(--p50); }
.hn-make-card .make-name { font-family: 'Barlow Condensed',sans-serif; font-weight: 700; font-size: 16px; color: var(--p900); }
.hn-make-card .make-count { font-size: 11px; color: var(--text3); margin-top: 2px; }
.hn-make-card .make-avg { font-size: 12px; color: var(--p600); font-weight: 600; margin-top: 4px; }

/* ===== GAS CARD BANNER ===== */
.hn-banner {
  background: linear-gradient(135deg, var(--gold-pale), #fffdf5);
  border: 1px solid var(--gold-border); border-radius: var(--radius);
  padding: 28px 36px; display: flex; align-items: center; gap: 24px; margin-bottom: 60px;
}
.hn-banner-icon { font-size: 42px; flex-shrink: 0; }
.hn-banner-text h3 { font-size: 22px; color: var(--p900); margin-bottom: 4px; }
.hn-banner-text p { font-size: 14px; color: var(--text2); font-family:'DM Sans',sans-serif; text-transform:none; letter-spacing:0; font-weight:400; }
.hn-banner-cta {
  margin-left: auto; background: var(--gold); color: #fff; padding: 12px 28px;
  border-radius: var(--radius-sm); text-decoration: none;
  font-family: 'Barlow Condensed',sans-serif; font-size: 15px;
  font-weight: 700; letter-spacing: 0.05em; white-space: nowrap; flex-shrink: 0; transition: background 0.2s;
}
.hn-banner-cta:hover { background: #b09038; color: #fff; }

/* ===== BLOG CARDS ===== */
.hn-blog-card {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius); overflow: hidden;
  text-decoration: none; color: inherit;
  box-shadow: var(--shadow); transition: all 0.2s; display: block;
}
.hn-blog-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-hover); }
.hn-blog-thumb {
  height: 160px; background: var(--p100);
  display: flex; align-items: center; justify-content: center; font-size: 40px;
  overflow: hidden;
}
.hn-blog-thumb img { width:100%; height:160px; object-fit:cover; }
.hn-blog-body { padding: 20px; }
.hn-blog-cat { font-size: 10px; color: var(--p600); text-transform: uppercase; letter-spacing: 0.1em; font-weight: 600; margin-bottom: 8px; }
.hn-blog-title { font-size: 18px; color: var(--p900); margin-bottom: 8px; line-height: 1.3; }
.hn-blog-excerpt { font-size: 13px; color: var(--text2); line-height: 1.6; font-family:'DM Sans',sans-serif; text-transform:none; letter-spacing:0; font-weight:400; }

/* ===== WHY SECTION ===== */
.hn-why { background: var(--p900); padding: 64px 0; }
.hn-why-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(220px,1fr)); gap: 24px; }
.hn-why-card { text-align: center; padding: 20px; }
.hn-why-icon { font-size: 36px; margin-bottom: 12px; }
.hn-why-card h3 { font-size: 18px; color: #fff; margin-bottom: 8px; }
.hn-why-card p { font-size: 13px; color: rgba(255,255,255,0.65); line-height: 1.7; font-family:'DM Sans',sans-serif; text-transform:none; letter-spacing:0; font-weight:400; }

/* ===== CALC TEASER ===== */
.hn-calc-teaser { background: linear-gradient(135deg, var(--p800), var(--p900)); padding: 64px 0; text-align: center; }
.hn-calc-teaser h2 { font-size: 38px; color: #fff; margin-bottom: 12px; }
.hn-calc-teaser p { font-size: 17px; color: rgba(255,255,255,0.75); max-width: 520px; margin: 0 auto 28px; font-family:'DM Sans',sans-serif; text-transform:none; letter-spacing:0; font-weight:400; }
.hn-cta-btn {
  display: inline-block; background: var(--p400); color: var(--p900);
  padding: 14px 36px; border-radius: var(--radius-sm); text-decoration: none;
  font-family: 'Barlow Condensed',sans-serif; font-size: 18px; font-weight: 700;
  letter-spacing: 0.05em; transition: background 0.2s;
}
.hn-cta-btn:hover { background: var(--p300); color: var(--p900); }

/* ===== FOOTER ===== */
.hn-footer { background: var(--p900); color: rgba(255,255,255,0.65); padding: 64px 0 24px; }
.hn-footer-grid { display: grid; grid-template-columns: 2fr repeat(4,1fr); gap: 40px; margin-bottom: 40px; }
.hn-footer h4 { font-size: 13px; color: #fff; letter-spacing: 0.1em; margin-bottom: 16px; }
.hn-footer ul { list-style: none; }
.hn-footer ul li { margin-bottom: 9px; }
.hn-footer ul li a { color: rgba(255,255,255,0.55); text-decoration: none; font-size: 13px; transition: color 0.2s; font-family:'DM Sans',sans-serif; font-weight:400; }
.hn-footer ul li a:hover { color: var(--p300); }
.hn-footer-brand p { font-size: 13px; line-height: 1.7; margin-top: 8px; font-family:'DM Sans',sans-serif; font-weight:400; }
.hn-footer-bottom {
  border-top: 1px solid rgba(255,255,255,0.1); padding-top: 24px;
  display: flex; justify-content: space-between; font-size: 12px; flex-wrap: wrap; gap: 8px;
}
.hn-footer-bottom a { color: rgba(255,255,255,0.4); text-decoration: none; }
.hn-footer-bottom a:hover { color: rgba(255,255,255,0.7); }

/* ===== BADGES ===== */
.hn-badge {
  display: inline-block; padding: 4px 12px; border-radius: 999px;
  font-size: 11px; font-weight: 600; font-family:'DM Sans',sans-serif;
  text-transform: none; letter-spacing: 0;
}
.hn-badge-green { background: var(--p600); color: #fff; }
.hn-badge-gold  { background: var(--gold); color: #fff; }
.hn-badge-gray  { background: rgba(255,255,255,0.15); color: rgba(255,255,255,0.9); }
.hn-badge-light { background: var(--p100); color: var(--p800); }

/* ===== VEHICLE PAGE ===== */
.hn-vehicle-page { max-width: 1200px; margin: 0 auto; padding: 24px 20px 60px; }

.hn-breadcrumb { font-size: 13px; color: var(--text3); margin-bottom: 20px; }
.hn-breadcrumb a { color: var(--p600); text-decoration: none; }
.hn-breadcrumb a:hover { color: var(--p500); }
.hn-breadcrumb span { margin: 0 6px; opacity: 0.5; }

.hn-vehicle-hero {
  background: linear-gradient(135deg, var(--p900), var(--p800));
  border-radius: var(--radius); padding: 32px 40px; color: #fff;
  margin-bottom: 24px; display: flex; align-items: center;
  justify-content: space-between; flex-wrap: wrap; gap: 20px;
}
.hn-vehicle-hero h1 { font-size: clamp(24px,4vw,44px); color: #fff; margin-bottom: 10px; }
.hn-vehicle-meta { display: flex; gap: 8px; flex-wrap: wrap; }

.hn-mpg-strip {
  display: grid; grid-template-columns: 1fr 1.5fr 1fr; gap: 1px;
  background: var(--border); border-radius: var(--radius);
  overflow: hidden; border: 1px solid var(--border); margin-bottom: 24px;
}
.hn-mpg-cell { background: var(--white); padding: 24px; text-align: center; }
.hn-mpg-cell.combined { background: var(--p50); }
.hn-mpg-label { font-size: 11px; color: var(--text3); text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 6px; }
.hn-mpg-number {
  font-family: 'Barlow Condensed',sans-serif; font-size: 64px;
  font-weight: 800; line-height: 1; color: var(--p700);
}
.hn-mpg-cell.combined .hn-mpg-number { font-size: 80px; color: var(--p600); }
.hn-mpg-unit { font-size: 16px; color: var(--text3); }

.hn-data-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 24px; }

.hn-cost-card {
  background: var(--amber-bg); border: 1px solid var(--amber-border);
  border-radius: var(--radius); padding: 24px;
}
.hn-cost-card h3 { font-size: 12px; color: var(--text3); text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 6px; }
.hn-cost-num { font-family: 'Barlow Condensed',sans-serif; font-size: 50px; font-weight: 800; color: var(--amber); line-height: 1; }
.hn-cost-savings { font-size: 13px; color: var(--p600); margin-top: 8px; font-weight: 500; }

.hn-percentile-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius); padding: 24px; }
.hn-percentile-card h3 { font-size: 12px; color: var(--text3); text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 14px; }
.hn-pct-bar { height: 12px; background: var(--border); border-radius: 6px; overflow: hidden; margin-bottom: 10px; }
.hn-pct-fill { height: 100%; border-radius: 6px; background: linear-gradient(90deg, var(--p500), var(--p300)); }
.hn-pct-label { font-family: 'Barlow Condensed',sans-serif; font-size: 22px; font-weight: 700; color: var(--p700); }
.hn-pct-sub { font-size: 12px; color: var(--text3); margin-top: 2px; }

.hn-epa-scores { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; margin-bottom: 24px; }
.hn-score-dial { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius); padding: 20px; text-align: center; }
.hn-score-dial svg { width: 80px; height: 80px; }
.hn-score-dial .dial-label { font-size: 11px; color: var(--text3); text-transform: uppercase; letter-spacing: 0.1em; margin-top: 8px; }

.hn-two-col { display: grid; grid-template-columns: minmax(0,1fr) 300px; gap: 28px; align-items: start; }

.hn-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius); padding: 24px; margin-bottom: 24px; }
.hn-card h3 { font-size: 20px; color: var(--p900); margin-bottom: 16px; }
.hn-card h4 { font-size: 16px; color: var(--p900); margin-bottom: 14px; }
.hn-card:last-child { margin-bottom: 0; }

.hn-specs-table { width: 100%; border-collapse: collapse; }
.hn-specs-table tr { border-bottom: 1px solid var(--border); }
.hn-specs-table tr:last-child { border-bottom: none; }
.hn-specs-table td { padding: 10px 0; font-size: 14px; }
.hn-specs-table td:first-child { color: var(--text3); width: 42%; }
.hn-specs-table td:last-child { font-weight: 500; color: var(--text); }

.hn-article-content { font-size: 15px; line-height: 1.8; color: var(--text2); font-family:'DM Sans',sans-serif; font-weight:400; }
.hn-article-content h2, .hn-article-content h3 { font-family:'Barlow Condensed',sans-serif; color: var(--p900); margin: 1.2em 0 0.5em; }
.hn-article-content p { margin-bottom: 1em; }

/* Sidebar */
.hn-sidebar { display: flex; flex-direction: column; gap: 20px; }
.hn-sidebar-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius); padding: 20px; }
.hn-sidebar-card h4 { font-size: 16px; color: var(--p900); margin-bottom: 14px; }

.hn-slider { width: 100%; margin: 8px 0; accent-color: var(--p500); }
.hn-calc-result { background: var(--p50); border-radius: var(--radius-sm); padding: 14px; text-align: center; margin-top: 12px; }
.hn-calc-amount { font-family: 'Barlow Condensed',sans-serif; font-size: 34px; font-weight: 800; color: var(--p600); display: block; }
.hn-calc-label { font-size: 12px; color: var(--text3); }

/* Affiliate cards */
.hn-affiliate-item {
  display: flex; align-items: center; gap: 10px; padding: 10px;
  background: var(--bg); border-radius: var(--radius-sm);
  border: 1px solid var(--border); text-decoration: none; color: inherit;
  transition: border-color 0.2s;
}
.hn-affiliate-item:hover { border-color: var(--p400); }
.hn-affiliate-badge { background: var(--p100); color: var(--p800); padding: 4px 8px; border-radius: 4px; font-size: 10px; font-weight: 700; white-space: nowrap; }
.hn-affiliate-name { font-size: 13px; font-weight: 600; color: var(--text); }
.hn-affiliate-desc { font-size: 11px; color: var(--text3); }

/* Similar vehicles */
.hn-similar-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(180px,1fr)); gap: 14px; }

/* ===== ARCHIVE PAGE ===== */
.hn-archive-header { background: var(--p900); padding: 40px 20px; }
.hn-archive-header h1 { color: #fff; font-size: 40px; margin-bottom: 6px; }
.hn-archive-header p { color: rgba(255,255,255,0.7); font-size: 15px; font-family:'DM Sans',sans-serif; font-weight:400; text-transform:none; letter-spacing:0; }

.hn-archive-body { max-width: 1200px; margin: 0 auto; padding: 40px 20px; }
.hn-archive-filters { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 28px; }
.hn-filter-btn { padding: 7px 16px; border: 1px solid var(--border); border-radius: 999px; background: var(--white); font-size: 13px; cursor: pointer; font-family:'DM Sans',sans-serif; transition: all 0.2s; text-decoration:none; color:var(--text2); }
.hn-filter-btn:hover, .hn-filter-btn.active { background: var(--p600); color: #fff; border-color: var(--p600); }

.hn-pagination { display: flex; gap: 8px; justify-content: center; margin-top: 40px; flex-wrap: wrap; }
.hn-pagination a, .hn-pagination span { padding: 8px 14px; border: 1px solid var(--border); border-radius: var(--radius-sm); text-decoration: none; color: var(--text2); font-size: 14px; }
.hn-pagination .current, .hn-pagination a:hover { background: var(--p600); color: #fff; border-color: var(--p600); }

/* ===== TEMPLATE CLASS ALIASES & ADDITIONS ===== */

/* Nav logo alias */
.hn-nav-logo { font-family:'Barlow Condensed',sans-serif; font-size:22px; font-weight:800; color:#fff; text-decoration:none; letter-spacing:0.05em; display:flex; align-items:center; gap:8px; }
.hn-nav-logo:hover { color:var(--p300); }

/* Section layout */
.hn-section-inner { max-width:1200px; margin:0 auto; padding:0 20px; }
.hn-section-header { display:flex; align-items:baseline; justify-content:space-between; margin-bottom:28px; }
.hn-section-header h2 { font-size:32px; color:var(--p900); }
.hn-section-header a { font-size:13px; color:var(--p600); text-decoration:none; font-weight:500; }
.hn-section-header a:hover { color:var(--p500); }
.hn-section { padding:60px 0; }

/* Vehicle grid aliases */
.hn-vehicle-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.hn-archive-grid { grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); }
.hn-blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.hn-similar-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); gap:14px; }

/* Efficiency bar aliases */
.hn-efficiency-bar { height:4px; background:var(--border); border-radius:2px; margin-top:12px; overflow:hidden; }
.hn-efficiency-fill { height:100%; border-radius:2px; background:linear-gradient(90deg,var(--p500),var(--p300)); }

/* Primary metric display */
.hn-card-primary { line-height:1; margin-bottom:4px; }
.primary-val { font-family:'Barlow Condensed',sans-serif; font-size:54px; font-weight:800; color:var(--p600); }
.primary-unit { font-size:16px; color:var(--text3); margin-left:2px; }

/* MPG cell aliases */
.mpg-label { font-size:11px; color:var(--text3); text-transform:uppercase; letter-spacing:0.1em; margin-bottom:6px; }
.mpg-number { font-family:'Barlow Condensed',sans-serif; font-size:64px; font-weight:800; line-height:1; color:var(--p700); }
.hn-mpg-cell.combined .mpg-number { font-size:80px; color:var(--p600); }
.mpg-unit { font-size:16px; color:var(--text3); }

/* Data grid */
.hn-data-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-bottom:24px; }

/* Cost card aliases */
.cost-amount { font-family:'Barlow Condensed',sans-serif; font-size:50px; font-weight:800; color:var(--amber); line-height:1; }
.cost-savings { font-size:13px; color:var(--p600); margin-top:8px; font-weight:500; }

/* Percentile aliases */
.hn-percentile-bar { height:12px; background:var(--border); border-radius:6px; overflow:hidden; margin-bottom:10px; }
.hn-percentile-fill { height:100%; border-radius:6px; background:linear-gradient(90deg,var(--p500),var(--p300)); }
.hn-percentile-label { font-family:'Barlow Condensed',sans-serif; font-size:22px; font-weight:700; color:var(--p700); }
.hn-percentile-sub { font-size:12px; color:var(--text3); margin-top:2px; }

/* Score dial aliases */
.score-label { font-size:11px; color:var(--text3); text-transform:uppercase; letter-spacing:0.1em; margin-top:8px; }
.score-value { font-family:'Barlow Condensed',sans-serif; font-size:24px; font-weight:800; }

/* Vehicle hero aliases */
.vehicle-title { font-size:clamp(24px,4vw,44px); color:#fff; margin-bottom:10px; }
.vehicle-meta { display:flex; gap:8px; flex-wrap:wrap; }
.hn-badge-primary { background:var(--p600); color:#fff; }
.hn-epa-link { color:rgba(255,255,255,0.6); font-size:12px; text-decoration:none; }
.hn-epa-link:hover { color:rgba(255,255,255,0.9); }

/* Blog card */
.blog-thumb { height:160px; background:var(--p100); display:flex; align-items:center; justify-content:center; font-size:40px; overflow:hidden; }
.blog-thumb img { width:100%; height:160px; object-fit:cover; }
.blog-body { padding:20px; }
.blog-cat { font-size:10px; color:var(--p600); text-transform:uppercase; letter-spacing:0.1em; font-weight:600; margin-bottom:8px; }
.blog-title { font-family:'Barlow Condensed',sans-serif; font-size:18px; color:var(--p900); margin-bottom:8px; line-height:1.3; font-weight:700; }
.blog-excerpt { font-size:13px; color:var(--text2); line-height:1.6; }

/* Why section */
.hn-why-header { text-align:center; margin-bottom:40px; }
.hn-why-header h2 { color:#fff; font-size:36px; }
.why-icon { font-size:36px; margin-bottom:12px; }

/* Footer */
.hn-footer-inner { max-width:1200px; margin:0 auto; padding:0 20px; }
.hn-footer-brand h4 { font-size:18px; }

/* Sidebar */
.hn-calc-slider { width:100%; margin:8px 0; accent-color:var(--p500); }
.hn-calc-result { background:var(--p50); border-radius:var(--radius-sm); padding:14px; text-align:center; margin-top:12px; }
.calc-amount { font-family:'Barlow Condensed',sans-serif; font-size:34px; font-weight:800; color:var(--p600); display:block; }
.calc-label { font-size:12px; color:var(--text3); }
.hn-card-item { display:flex; align-items:center; gap:10px; padding:10px; background:var(--bg); border-radius:var(--radius-sm); border:1px solid var(--border); }
.card-badge { background:var(--p100); color:var(--p800); padding:4px 8px; border-radius:4px; font-size:10px; font-weight:700; white-space:nowrap; }
.card-name { font-size:13px; font-weight:600; color:var(--text); }
.card-desc { font-size:11px; color:var(--text3); }
.hn-link-sm { display:block; text-align:center; color:var(--p600); font-size:12px; text-decoration:none; padding:4px; }
.hn-product-item { display:flex; align-items:center; gap:10px; text-decoration:none; color:inherit; padding:8px; border-radius:var(--radius-sm); border:1px solid var(--border); background:var(--bg); }
.product-name { font-size:13px; font-weight:600; color:var(--text); }
.product-desc { font-size:11px; color:var(--text3); }
.hn-epa-source { background:var(--p50); border-color:var(--p100); font-size:13px; color:var(--p800); line-height:1.6; }
.hn-epa-source a { color:var(--p600); }

/* Similar vehicles diff */
.similar-diff { font-size:11px; font-weight:600; margin-top:2px; }

/* Archive */
.hn-archive { max-width:1200px; margin:0 auto; padding:40px 20px; }
.hn-archive-header { display:flex; align-items:baseline; justify-content:space-between; margin-bottom:28px; flex-wrap:wrap; gap:8px; }
.hn-archive-header h1 { font-size:36px; color:var(--p900); }
.hn-archive-count { font-size:13px; color:var(--text3); }
.hn-archive-filters { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:28px; align-items:center; }
.hn-archive-filters select, .hn-archive-filters input { padding:8px 14px; border:1px solid var(--border); border-radius:var(--radius-sm); background:var(--white); font-family:'DM Sans',sans-serif; font-size:14px; color:var(--text); }
.hn-archive-filters button { padding:8px 20px; background:var(--p600); color:#fff; border:none; border-radius:var(--radius-sm); font-family:'Barlow Condensed',sans-serif; font-size:15px; font-weight:700; cursor:pointer; }
.hn-clear-filters { color:var(--text3); font-size:13px; text-decoration:none; padding:8px; }
.hn-clear-filters:hover { color:var(--danger); }
.hn-no-results { text-align:center; padding:60px 20px; color:var(--text3); }
.hn-no-results a { color:var(--p600); }

/* Banner aliases */
.banner-icon { font-size:42px; flex-shrink:0; }
.banner-text h3 { font-size:22px; color:var(--p900); margin-bottom:4px; }
.banner-text p { font-size:14px; color:var(--text2); font-family:'DM Sans',sans-serif; text-transform:none; letter-spacing:0; font-weight:400; }
.banner-cta { margin-left:auto; background:var(--gold); color:#fff; padding:12px 28px; border-radius:var(--radius-sm); text-decoration:none; font-family:'Barlow Condensed',sans-serif; font-size:15px; font-weight:700; letter-spacing:0.05em; white-space:nowrap; flex-shrink:0; }
.banner-cta:hover { background:#b09038; color:#fff; }

/* Make card aliases */
.make-name { font-family:'Barlow Condensed',sans-serif; font-weight:700; font-size:16px; color:var(--p900); }
.make-count { font-size:11px; color:var(--text3); margin-top:2px; }
.make-metric { font-size:12px; color:var(--p600); font-weight:600; margin-top:4px; }

/* CTA button */
.cta-btn { display:inline-block; background:var(--p400); color:var(--p900); padding:14px 36px; border-radius:var(--radius-sm); text-decoration:none; font-family:'Barlow Condensed',sans-serif; font-size:18px; font-weight:700; letter-spacing:0.05em; }
.cta-btn:hover { background:var(--p300); color:var(--p900); }

/* ===== RESPONSIVE ===== */
@media (max-width: 1024px) {
  .hn-grid-4, .hn-grid-5 { grid-template-columns: repeat(2,1fr); }
  .hn-footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 900px) {
  .hn-two-col { grid-template-columns: 1fr; }
  .hn-vehicle-hero { padding: 24px 20px; }
  .hn-mpg-number { font-size: 48px !important; }
  .hn-data-row { grid-template-columns: 1fr; }
  .hn-epa-scores { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .hn-grid-3 { grid-template-columns: 1fr; }
  .hn-grid-4, .hn-grid-5 { grid-template-columns: 1fr; }
  .hn-search { flex-direction: column; }
  .hn-banner { flex-direction: column; text-align: center; }
  .hn-banner-cta { margin-left: 0; }
  .hn-footer-grid { grid-template-columns: 1fr; }
  .hn-nav-links { display: none; }
  .hn-epa-scores { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════
   FEH HOMEPAGE — Merged Mockup CSS
   Appended to hubnetwork-theme/style.css
   Generic element selectors (nav, footer) scoped to
   body.hn-homepage to avoid affecting other pages.
════════════════════════════════════════════════════════ */

/* Extra CSS variables used by homepage */
:root {
  --g900:#0d2b1a;--g800:#14401f;--g700:#1a5c2a;--g600:#1e7a33;
  --g500:#25a041;--g400:#34c759;--g300:#6ed98a;--g100:#d4f5dd;--g50:#f0faf3;
  --gold:#c8a44a;--gold-pale:#fdf6e3;--gold-border:rgba(200,164,74,0.3);
  --amber:#f5a623;--amber-bg:#fdf3dc;--amber-border:#fce4a8;
  --red:#e53935;--blue:#1a73e8;
}

/* NAV — scoped to homepage */
nav{background:var(--g900);display:flex;align-items:center;justify-content:space-between;padding:0 48px;height:80px;position:fixed;top:0;left:0;right:0;width:100%;box-sizing:border-box;z-index:100;overflow:visible;border-bottom:1px solid rgba(255,255,255,0.07)}
body:not(.hn-homepage){padding-top:80px!important;}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.nav-logo-icon{width:34px;height:34px;background:var(--g500);border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:16px;color:white}
.nav-logo-text{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:21px;color:white;letter-spacing:0.2px}
.nav-logo-text span{color:var(--g300)}
.nav-logo-img{height:70px!important;width:auto!important;display:block!important;}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-links a{color:rgba(255,255,255,0.72);text-decoration:none;padding:6px 14px;border-radius:6px;font-size:14px;font-weight:500;transition:all 0.15s}
.nav-links a:hover{color:white;background:rgba(255,255,255,0.1)}
.nav-cta{background:var(--g600) !important;color:white !important;border-radius:6px}
.nav-cta:hover{background:var(--g500) !important}

/* HERO */
.hero{background:var(--g900);background-image:linear-gradient(to bottom,rgba(13,43,26,0.80) 0%,rgba(13,43,26,0.72) 55%,rgba(13,43,26,0.96) 100%),url('https://images.unsplash.com/photo-1449965408869-eaa3f722e40d?w=1600&q=80&auto=format&fit=crop');background-size:cover;background-position:center 40%;padding:260px 48px 78px;text-align:center;position:relative;overflow:hidden}
.hero::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:36px;background:var(--bg);clip-path:ellipse(55% 100% at 50% 100%)}
.hero-eyebrow{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,0.11);border:1px solid rgba(255,255,255,0.2);border-radius:99px;padding:4px 14px;font-size:12px;color:rgba(255,255,255,0.88);letter-spacing:0.6px;text-transform:uppercase;margin-bottom:20px}
.eyebrow-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0.3}}
.hero h1{font-family:'Barlow Condensed',sans-serif;font-size:clamp(38px,5.5vw,58px);font-weight:800;color:white;line-height:1.05;letter-spacing:-0.3px;margin-bottom:14px;max-width:700px;margin-left:auto;margin-right:auto;text-transform:none}
.hero h1 em{font-style:normal;color:var(--g300)}
.hero-sub{color:rgba(255,255,255,0.68);font-size:17px;max-width:480px;margin:0 auto 36px;line-height:1.6}

/* Search box */
.search-box{background:white;border-radius:16px;padding:20px 22px;max-width:700px;margin:0 auto;box-shadow:0 8px 36px rgba(0,0,0,0.22)}
.search-row{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:12px;align-items:end}
.sf label{display:block;font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:0.7px;margin-bottom:5px}
.sf select{width:100%;padding:10px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:'DM Sans',sans-serif;font-size:14px;color:var(--text);background:white;appearance:none;cursor:pointer}
.sf select:focus{outline:none;border-color:var(--g500)}
.search-btn{background:var(--g600);color:white;border:none;padding:10px 24px;border-radius:var(--radius-sm);font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;cursor:pointer;height:43px;transition:background 0.15s;white-space:nowrap}
.search-btn:hover{background:var(--g500)}
.search-tags{margin-top:12px;display:flex;gap:7px;flex-wrap:wrap;align-items:center}
.search-tags-label{font-size:12px;color:var(--text3)}
.stag{font-size:12px;color:var(--g600);background:var(--g50);border:1px solid rgba(30,122,51,0.2);border-radius:99px;padding:3px 10px;cursor:pointer;transition:all 0.15s;text-decoration:none}
.stag:hover{background:var(--g600);color:white}

/* Stats bar */
.stats-bar{display:flex;justify-content:center;background:rgba(255,255,255,0.08);border-radius:12px;max-width:700px;margin:28px auto 0;border:1px solid rgba(255,255,255,0.12)}
.stat-item{flex:1;padding:14px 20px;text-align:center;border-right:1px solid rgba(255,255,255,0.1)}
.stat-item:last-child{border-right:none}
.stat-num{font-family:'Barlow Condensed',sans-serif;font-size:22px;font-weight:700;color:white;display:block}
.stat-label{font-size:10px;color:rgba(255,255,255,0.55);text-transform:uppercase;letter-spacing:0.5px;margin-top:1px}

/* Wrap */
.wrap{max-width:1200px;margin:0 auto;padding:0 40px}

/* Fuel type tabs */
.fuel-tabs{display:flex;gap:7px;margin:36px 0 20px;flex-wrap:wrap}
.ftab{display:flex;align-items:center;gap:6px;padding:7px 16px;border:1.5px solid var(--border);border-radius:99px;font-size:13px;font-weight:500;color:var(--text2);cursor:pointer;background:white;transition:all 0.15s}
.ftab:hover,.ftab.active{border-color:var(--g500);color:var(--g700);background:var(--g50)}
.ftab-dot{width:7px;height:7px;border-radius:50%}

/* Section header */
.sec-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:18px}
.sec-title{font-family:'Barlow Condensed',sans-serif;font-size:26px;font-weight:700;color:var(--text);letter-spacing:0.1px;text-transform:none}
.sec-link{font-size:13px;font-weight:500;color:var(--g600);text-decoration:none}

/* Vehicle cards */
.v-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}
.vcard{background:white;border:1.5px solid var(--border);border-radius:var(--radius);padding:20px;cursor:pointer;transition:all 0.18s;position:relative;overflow:hidden;display:block}
.vcard::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--g400),var(--g600))}
.vcard:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:rgba(45,106,69,0.3)}
.vcard-make{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--g600);margin-bottom:3px}
.vcard-model{font-size:14px;font-weight:600;color:var(--text);margin-bottom:10px;line-height:1.3}
.vcard-mpg{font-family:'Barlow Condensed',sans-serif;font-size:50px;font-weight:800;color:var(--g700);line-height:1}
.vcard-mpg-lbl{font-size:11px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:0.4px;margin-bottom:8px}
.eff-bar{height:4px;background:var(--border);border-radius:2px;margin:8px 0 10px}
.eff-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--g400),var(--g600))}
.vcard-sub{display:flex;gap:6px;margin-bottom:10px}
.vcard-sub span{font-size:11px;color:var(--text3);background:var(--bg);padding:2px 7px;border-radius:4px}
.vcard-cost{font-size:13px;font-weight:700;color:var(--amber);border-top:1px solid var(--border);padding-top:10px;margin-top:2px}
.vcard-cost span{font-size:11px;font-weight:400;color:var(--text3)}
.vcard-badge{display:inline-flex;align-items:center;gap:4px;background:var(--g50);border:1px solid var(--g100);color:var(--g700);font-size:10px;font-weight:600;padding:2px 8px;border-radius:4px}

/* Make grid */
.make-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:20px}
.mcard{background:white;border:1.5px solid var(--border);border-radius:var(--radius);padding:16px 12px;text-align:center;cursor:pointer;transition:all 0.18s;text-decoration:none;display:block}
.mcard:hover{border-color:var(--g400);background:var(--g50);transform:translateY(-2px)}
.mcard-icon{width:48px;height:48px;border-radius:50%;background:var(--g50);border:1.5px solid var(--g100);display:flex;align-items:center;justify-content:center;margin:0 auto 9px;font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:17px;color:var(--g700)}
.mcard-name{font-size:13px;font-weight:600;color:var(--text);margin-bottom:1px}
.mcard-count{font-size:11px;color:var(--text3)}
.mcard-avg{font-size:11px;font-weight:600;color:var(--g600);margin-top:4px}

/* Gas card banner */
.gas-banner{background:var(--gold-pale);border:1px solid var(--gold-border);border-radius:var(--radius);padding:22px 28px;display:flex;align-items:center;gap:20px;margin-bottom:40px}
.gas-banner-icon{width:48px;height:48px;background:var(--gold);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.gas-banner-text h3{font-size:15px;font-weight:600;color:var(--text);margin-bottom:3px;text-transform:none;font-family:'DM Sans',sans-serif;letter-spacing:normal}
.gas-banner-text p{font-size:13px;color:var(--text2);max-width:440px}
.gas-banner-btn{background:var(--gold);color:white;border:none;padding:9px 20px;border-radius:var(--radius-sm);font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;margin-left:auto}

/* Calculator teaser */
.calc-teaser{background:var(--g900);border-radius:var(--radius);padding:36px 40px;display:flex;align-items:center;justify-content:space-between;gap:32px;margin-bottom:48px}
.calc-left h2{font-family:'Barlow Condensed',sans-serif;font-size:30px;font-weight:700;color:white;margin-bottom:8px;text-transform:none}
.calc-left p{font-size:14px;color:rgba(255,255,255,0.65);max-width:320px;line-height:1.6;margin-bottom:18px}
.calc-cta{display:inline-block;background:var(--g500);color:white;padding:10px 22px;border-radius:8px;font-size:14px;font-weight:600;text-decoration:none}
.calc-mini{background:rgba(255,255,255,0.1);border-radius:var(--radius-sm);padding:20px;min-width:260px}
.calc-row{display:flex;justify-content:space-between;margin-bottom:8px;font-size:13px}
.calc-row:last-child{margin-bottom:0}
.calc-lbl{color:rgba(255,255,255,0.65)}
.calc-val{font-weight:600;color:white}
.calc-result{border-top:1px solid rgba(255,255,255,0.15);padding-top:12px;margin-top:10px;text-align:center}
.calc-result-num{font-family:'Barlow Condensed',sans-serif;font-size:36px;font-weight:800;color:var(--gold)}
.calc-result-lbl{font-size:12px;color:rgba(255,255,255,0.55)}

/* MPG Scale section */
.scale-section{background:var(--g900);border-radius:var(--radius);padding:38px 44px;margin-bottom:48px;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.scale-left h2{font-family:'Barlow Condensed',sans-serif;font-size:30px;font-weight:700;color:white;line-height:1.1;margin-bottom:10px;text-transform:none}
.scale-left p{font-size:14px;color:rgba(255,255,255,0.6);line-height:1.6;margin-bottom:18px}
.scale-cta{display:inline-flex;align-items:center;gap:6px;background:var(--g500);color:white;padding:9px 20px;border-radius:8px;font-size:14px;font-weight:600;text-decoration:none}
.spectrum{display:flex;flex-direction:column;gap:9px}
.srow{display:flex;align-items:center;gap:10px}
.slbl{font-size:12px;font-weight:600;color:rgba(255,255,255,0.6);width:80px;text-align:right;flex-shrink:0}
.strack{flex:1;background:rgba(255,255,255,0.1);border-radius:4px;height:26px;overflow:hidden;display:flex;align-items:center}
.sbar{height:100%;border-radius:4px;display:flex;align-items:center;padding:0 10px}
.sbar span{font-size:11px;font-weight:700;color:white}
.sbar-red{background:linear-gradient(90deg,#e53935,#ef5350);width:28%}
.sbar-ylw{background:linear-gradient(90deg,#f5a623,#ffb83f);width:50%}
.sbar-grn{background:linear-gradient(90deg,#43a047,#66bb6a);width:72%}
.sbar-best{background:linear-gradient(90deg,#1a7a33,#25a041);width:100%}

/* Blog cards */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:48px}
.bcard{background:white;border:1.5px solid var(--border);border-radius:var(--radius);padding:20px;cursor:pointer;transition:all 0.18s;text-decoration:none;display:block}
.bcard:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.bcard-tag{font-size:10px;font-weight:700;color:var(--g600);text-transform:uppercase;letter-spacing:0.6px;margin-bottom:7px}
.bcard-title{font-size:15px;font-weight:600;color:var(--text);line-height:1.4;margin-bottom:7px;font-family:'DM Sans',sans-serif;text-transform:none;letter-spacing:normal}
.bcard-meta{font-size:12px;color:var(--text3)}

/* Why cards */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.why-card{background:white;border:1.5px solid var(--border);border-radius:var(--radius);padding:22px}
.why-icon{width:40px;height:40px;background:var(--g50);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:12px;font-size:20px}
.why-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:5px;font-family:'DM Sans',sans-serif;text-transform:none;letter-spacing:normal}
.why-text{font-size:13px;color:var(--text2);line-height:1.6}

/* FOOTER — scoped to homepage */
body.hn-homepage footer{background:var(--g900);padding:44px 48px 24px}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:32px;max-width:1200px;margin:0 auto 32px;padding-bottom:32px;border-bottom:1px solid rgba(255,255,255,0.1)}
.footer-brand-name{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:20px;color:white;margin-bottom:6px}
.footer-brand-name span{color:var(--g300)}
.footer-brand-sub{font-size:13px;color:rgba(255,255,255,0.5);max-width:220px;line-height:1.6}
.footer-col h4{font-size:11px;font-weight:600;color:rgba(255,255,255,0.4);text-transform:uppercase;letter-spacing:0.6px;margin-bottom:12px}
.footer-col a{display:block;font-size:13px;color:rgba(255,255,255,0.7);text-decoration:none;margin-bottom:8px}
.footer-col a:hover{color:white}
.footer-bottom{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;font-size:12px;color:rgba(255,255,255,0.35)}

/* ═══════════════════════════════════════════════════════
   FEH VEHICLE PAGE CSS — Merged Mockup
   Appended to style.css
════════════════════════════════════════════════════════ */

/* Breadcrumb */
.breadcrumb{background:var(--g900);padding:9px 48px 13px;display:flex;gap:6px;align-items:center;font-size:12px}
.breadcrumb a{color:rgba(255,255,255,0.5);text-decoration:none}
.breadcrumb a:hover{color:rgba(255,255,255,0.8)}
.bc-sep{color:rgba(255,255,255,0.2)}
.breadcrumb span{color:rgba(255,255,255,0.88);font-weight:500}

/* Vehicle hero */
.vhero-wrap{background:var(--g900);background-image:radial-gradient(ellipse 80% 100% at 50% 60%,rgba(30,122,51,0.3) 0%,transparent 70%)}
.vhero{max-width:860px;margin:0 auto;padding:38px 40px 0;display:flex;flex-direction:column;align-items:center;text-align:center}
.vhero-make{font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--g300);margin-bottom:6px}
.vhero-title{font-family:'Barlow Condensed',sans-serif;font-size:46px;font-weight:800;color:white;line-height:1.05;margin-bottom:14px;letter-spacing:-0.3px;text-transform:none}
.vhero-badges{display:flex;gap:8px;margin-bottom:26px;justify-content:center;flex-wrap:wrap}
.vbadge{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:99px;font-size:12px;font-weight:600}
.vbadge-epa{background:rgba(52,199,89,0.15);border:1px solid rgba(52,199,89,0.3);color:var(--g300)}
.vbadge-ev{background:rgba(26,115,232,0.15);border:1px solid rgba(26,115,232,0.3);color:#82b4f5}
.vbadge-class{background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.2);color:rgba(255,255,255,0.75)}

/* MPG strip */
.mpg-strip{display:flex;margin-top:28px;background:rgba(255,255,255,0.06);border-radius:12px 12px 0 0;border:1px solid rgba(255,255,255,0.1);border-bottom:none;width:fit-content}
.mpg-block{padding:20px 44px;text-align:center;position:relative}
.mpg-block+.mpg-block::before{content:'';position:absolute;left:0;top:16px;bottom:16px;width:1px;background:rgba(255,255,255,0.1)}
.mpg-block.combined{background:rgba(52,199,89,0.12);border:1px solid rgba(52,199,89,0.2);border-bottom:none;border-radius:12px 12px 0 0;margin:-1px}
.mpg-type{font-size:10px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:rgba(255,255,255,0.45);margin-bottom:4px}
.mpg-num{font-family:'Barlow Condensed',sans-serif;font-size:64px;font-weight:800;color:white;line-height:1}
.mpg-block.combined .mpg-num{color:var(--g300);font-size:72px}
.mpg-unit{font-size:12px;font-weight:600;color:rgba(255,255,255,0.38);text-transform:uppercase;letter-spacing:0.5px}

/* Page body grid */
.vbody{max-width:1200px;margin:0 auto;padding:28px 40px;display:grid;grid-template-columns:1fr 320px;gap:24px}
.main-col{display:flex;flex-direction:column;gap:20px}
.sidebar{display:flex;flex-direction:column;gap:18px}

/* Annual fuel cost card */
.cost-card{background:var(--amber-bg);border:1.5px solid var(--amber-border);border-radius:var(--radius);padding:22px 26px;display:flex;align-items:center;gap:24px}
.cost-icon{width:52px;height:52px;background:var(--amber);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}
.cost-main-lbl{font-size:11px;font-weight:700;letter-spacing:0.8px;text-transform:uppercase;color:#9a6400;margin-bottom:3px}
.cost-amount{font-family:'Barlow Condensed',sans-serif;font-size:48px;font-weight:800;color:#7a4f00;line-height:1;margin-bottom:3px}
.cost-sub{font-size:12px;color:#9a6400}
.cost-compare{text-align:right;margin-left:auto}
.cost-vs{font-size:12px;color:#9a6400;margin-bottom:4px}
.cost-saving{font-family:'Barlow Condensed',sans-serif;font-size:26px;font-weight:700;color:var(--g700)}
.cost-saving-lbl{font-size:11px;color:var(--g600);font-weight:600}

/* Class rank card */
.rank-card{background:white;border:1.5px solid var(--border);border-radius:var(--radius);padding:22px 26px}
.card-lbl{font-size:11px;font-weight:700;letter-spacing:0.6px;text-transform:uppercase;color:var(--text3);margin-bottom:14px;display:flex;align-items:center;gap:7px}
.card-lbl::before{content:'';display:inline-block;width:3px;height:12px;background:var(--g500);border-radius:2px}
.rank-row{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.rank-pct{font-family:'Barlow Condensed',sans-serif;font-size:52px;font-weight:800;color:var(--g600);line-height:1;flex-shrink:0}
.rank-text{font-size:14px;color:var(--text2);line-height:1.5}
.rank-bar-wrap{background:var(--bg);border-radius:8px;height:30px;overflow:hidden;border:1px solid var(--border);position:relative}
.rank-bar-fill{height:100%;border-radius:8px;background:linear-gradient(90deg,var(--g400),var(--g600));display:flex;align-items:center;justify-content:flex-end;padding-right:12px}
.rank-bar-lbl{font-size:11px;font-weight:700;color:white}
.rank-compare{display:flex;gap:10px;margin-top:14px}
.rank-cmp-item{flex:1;background:var(--bg);border-radius:8px;padding:10px 12px}
.rank-cmp-lbl{font-size:11px;color:var(--text3);margin-bottom:2px}
.rank-cmp-val{font-family:'Barlow Condensed',sans-serif;font-size:24px;font-weight:700}
.rank-cmp-val.good{color:var(--g600)}.rank-cmp-val.avg{color:var(--text3)}.rank-cmp-val.bad{color:var(--red)}

/* EPA scores card */
.scores-card{background:white;border:1.5px solid var(--border);border-radius:var(--radius);padding:22px 26px}
.scores-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.score-item{background:var(--bg);border-radius:10px;padding:16px;text-align:center}
.score-dial{position:relative;width:80px;height:80px;margin:0 auto 9px}
.score-dial svg{transform:rotate(-90deg)}
.dial-num{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:'Barlow Condensed',sans-serif;font-size:28px;font-weight:800;color:var(--g600)}
.score-lbl{font-size:12px;font-weight:600;color:var(--text2);margin-bottom:2px;font-family:'DM Sans',sans-serif;text-transform:none;letter-spacing:normal}
.score-sub{font-size:11px;color:var(--text3)}
.score-stat{display:flex;align-items:center;gap:14px;grid-column:span 2}
.score-stat-block{flex:1;background:var(--bg);border-radius:10px;padding:14px}
.score-stat-num{font-family:'Barlow Condensed',sans-serif;font-size:30px;font-weight:800;color:var(--g600)}
.score-stat-lbl{font-size:11px;color:var(--text3);margin-top:2px}

/* Specs card */
.specs-card{background:white;border:1.5px solid var(--border);border-radius:var(--radius);padding:22px 26px}
.specs-table{width:100%;border-collapse:collapse}
.specs-table tr{border-bottom:1px solid var(--bg)}
.specs-table tr:last-child{border-bottom:none}
.specs-table td{padding:9px 0;vertical-align:top}
.specs-table td:first-child{font-size:13px;font-weight:600;color:var(--text3);width:42%}
.specs-table td:last-child{font-size:14px;color:var(--text);font-weight:500}

/* Article card */
.article-card{background:white;border:1.5px solid var(--border);border-radius:var(--radius);padding:26px}
.article-card h2{font-family:'Barlow Condensed',sans-serif;font-size:24px;font-weight:700;color:var(--text);margin:0 0 12px;text-transform:none}
.article-card h3{font-size:15px;font-weight:600;color:var(--text);margin:16px 0 8px;text-transform:none;font-family:'DM Sans',sans-serif;letter-spacing:normal}
.article-card p{font-size:14px;color:var(--text2);line-height:1.75;margin-bottom:13px}
.article-card ul{font-size:14px;color:var(--text2);line-height:1.8;padding-left:20px;margin-bottom:13px}

/* Sidebar cards */
.sc{background:white;border:1.5px solid var(--border);border-radius:var(--radius);padding:18px}
.sc-title{font-size:11px;font-weight:700;letter-spacing:0.7px;text-transform:uppercase;color:var(--text3);margin-bottom:13px;display:flex;align-items:center;gap:7px}
.sc-title::before{content:'';display:inline-block;width:3px;height:12px;background:var(--g500);border-radius:2px}

/* Fuel calculator result */
.calc-result-box{background:var(--g50);border-radius:8px;padding:14px;text-align:center;margin-top:6px}
.calc-result-big{font-family:'Barlow Condensed',sans-serif;font-size:32px;font-weight:800;color:var(--g700)}
.calc-result-sub{font-size:11px;color:var(--text3)}

/* Gas card affiliate */
.gas-card-affiliate{background:var(--gold-pale);border:1px solid var(--gold-border);border-radius:var(--radius);padding:18px}
.gca-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:4px}
.gca-sub{font-size:12px;color:var(--text2);margin-bottom:12px}
.gca-item{background:white;border-radius:6px;padding:9px 10px;font-size:12px;display:flex;justify-content:space-between;align-items:center;margin-bottom:7px}
.gca-item:last-of-type{margin-bottom:0}
.gca-item strong{font-weight:600}
.gca-pct{color:var(--g600);font-weight:700}
.gca-btn{width:100%;background:var(--gold);color:white;border:none;padding:9px;border-radius:6px;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;cursor:pointer;margin-top:12px}
.gca-disc{font-size:10px;color:var(--text3);text-align:center;margin-top:6px}

/* Similar vehicles */
.sim-card{display:flex;align-items:center;gap:11px;padding:9px 0;border-bottom:1px solid var(--border);text-decoration:none}
.sim-card:last-child{border-bottom:none;padding-bottom:0}
.sim-mpg{width:50px;height:50px;background:var(--g50);border:1.5px solid var(--g100);border-radius:9px;display:flex;flex-direction:column;align-items:center;justify-content:center;flex-shrink:0}
.sim-mpg-num{font-family:'Barlow Condensed',sans-serif;font-size:22px;font-weight:800;color:var(--g700);line-height:1}
.sim-mpg-unit{font-size:9px;font-weight:600;color:var(--g600);text-transform:uppercase}
.sim-name{font-size:13px;font-weight:600;color:var(--text);margin-bottom:2px}
.sim-cost{font-size:12px;color:var(--amber);font-weight:600}

/* Amazon affiliate */
.amz-item{display:flex;align-items:center;gap:10px;padding:9px;background:var(--bg);border-radius:7px;cursor:pointer;margin-bottom:7px;text-decoration:none}
.amz-img{width:36px;height:36px;background:var(--border);border-radius:4px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:18px}
.amz-name{font-size:12px;font-weight:600;color:var(--text)}
.amz-stars{font-size:11px;color:var(--g600)}
.amz-disc{font-size:10px;color:var(--text3);margin-top:8px}

/* Compare CTA */
.cmp-cta{background:var(--g50);border:1.5px solid var(--g100);border-radius:var(--radius);padding:18px}
.cmp-cta p{font-size:13px;color:var(--g700);line-height:1.5;margin-bottom:13px}
.cmp-btn{display:block;background:var(--g600);color:white;text-align:center;padding:10px;border-radius:8px;font-size:13px;font-weight:600;text-decoration:none}

/* Ad zone */
.ad-zone{background:var(--bg);border:1.5px dashed var(--border);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--text3);font-size:12px;font-weight:500}

/* ═══════════════════════════════════════
   RESPONSIVE / MOBILE FIXES v2
   Paste at very end of style.css
═══════════════════════════════════════ */

/* Tablet — 1024px and below */
@media (max-width: 1024px) {
  .v-grid { grid-template-columns: repeat(2, 1fr); }
  .make-grid { grid-template-columns: repeat(4, 1fr); }
  .why-grid { grid-template-columns: repeat(2, 1fr); }
  .blog-grid { grid-template-columns: repeat(2, 1fr); }
  .footer-top { grid-template-columns: 1fr 1fr 1fr; gap: 24px; }
  .scale-section { grid-template-columns: 1fr; gap: 28px; }
  .calc-teaser { flex-direction: column; align-items: flex-start; }
  .calc-mini { min-width: unset; width: 100%; }
}

/* Mobile — 768px and below */
@media (max-width: 768px) {

  /* NAV */
  nav { padding: 0 16px; height: 60px; }
  body:not(.hn-homepage) { padding-top: 60px!important; }
  .nav-links a:not(.nav-cta) { display: none; }
  .nav-logo-text { font-size: 17px; }
  .nav-logo-img { height:50px!important; width:auto!important; }

  /* HERO */
  .hero { padding: 160px 16px 56px; }
  .hero h1 { font-size: 34px; margin-bottom: 12px; }
  .hero-sub { font-size: 15px; margin-bottom: 22px; }
  .hero-eyebrow { font-size: 11px; padding: 4px 12px; margin-bottom: 16px; }

  /* SEARCH BOX */
  .search-box { padding: 16px; border-radius: 14px; margin: 0 4px; }
  .search-row {
    grid-template-columns: 1fr !important;
    gap: 10px;
  }
  .sf select { padding: 12px 14px; font-size: 15px; }
  .search-btn {
    width: 100% !important;
    height: 48px;
    font-size: 15px;
  }
  .search-tags { gap: 6px; margin-top: 10px; flex-wrap: wrap; }
  .stag { font-size: 12px; padding: 4px 10px; }

  /* STATS BAR — fix overflow */
  .stats-bar {
    max-width: 100% !important;
    flex-wrap: wrap;
    margin: 20px 4px 0;
    border-radius: 10px;
  }
  .stat-item {
    flex: 1 1 33% !important;
    padding: 10px 6px;
    min-width: 0;
    border-right: 1px solid rgba(255,255,255,0.1);
  }
  /* 3+2 layout: row 1 has 3 items, row 2 has 2 */
  .stat-item:nth-child(3) { border-right: none; }
  .stat-item:nth-child(4),
  .stat-item:nth-child(5) {
    flex: 1 1 50% !important;
    border-top: 1px solid rgba(255,255,255,0.1);
  }
  .stat-item:nth-child(5) { border-right: none; }
  .stat-num { font-size: 17px; }
  .stat-label { font-size: 9px; letter-spacing: 0.3px; }

  /* MAIN WRAP */
  .wrap { padding: 0 16px; }

  /* FUEL TYPE TABS */
  .fuel-tabs {
    gap: 6px;
    margin: 22px 0 16px;
    overflow-x: auto;
    flex-wrap: nowrap !important;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 6px;
    scrollbar-width: none;
  }
  .fuel-tabs::-webkit-scrollbar { display: none; }
  .ftab { font-size: 12px; padding: 6px 12px; flex-shrink: 0; }

  /* SECTION HEADERS */
  .sec-title { font-size: 22px; }
  .sec-head { flex-wrap: wrap; gap: 4px; }
  .sec-link { font-size: 12px; }

  /* VEHICLE CARDS — most critical fix */
  .v-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 10px;
  }
  .vcard { padding: 14px; }
  .vcard-make { font-size: 9px; letter-spacing: 0.6px; }
  .vcard-model {
    font-size: 12px;
    margin-bottom: 8px;
    /* prevent long names breaking layout */
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
  }
  .vcard-mpg { font-size: 40px; }
  .vcard-mpg-lbl { font-size: 10px; margin-bottom: 6px; }
  .vcard-sub span { font-size: 10px; padding: 2px 5px; }
  .vcard-cost { font-size: 12px; }
  .vcard-badge { font-size: 9px; padding: 2px 6px; }

  /* MAKE GRID */
  .make-grid {
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 10px;
  }
  .mcard { padding: 12px 8px; }
  .mcard-icon { width: 40px; height: 40px; font-size: 14px; margin-bottom: 7px; }
  .mcard-name { font-size: 12px; }
  .mcard-count { font-size: 10px; }
  .mcard-avg { font-size: 10px; margin-top: 3px; }

  /* GAS BANNER — fix overflow */
  .gas-banner {
    flex-direction: column !important;
    align-items: flex-start;
    padding: 18px;
    gap: 12px;
  }
  .gas-banner-text h3 { font-size: 14px; }
  .gas-banner-text p { font-size: 13px; max-width: 100%; }
  .gas-banner-btn {
    width: 100%;
    text-align: center;
    margin-left: 0 !important;
    padding: 11px 16px;
  }

  /* MPG SCALE SECTION — fix two-column on mobile */
  .scale-section {
    grid-template-columns: 1fr !important;
    padding: 24px 18px;
    gap: 22px;
    border-radius: 12px;
    margin-bottom: 28px;
  }
  .scale-left h2 { font-size: 24px; line-height: 1.15; }
  .scale-left p { font-size: 13px; }
  .scale-cta { font-size: 13px; padding: 9px 16px; }
  /* Fix spectrum bars — they were showing as tiny boxes */
  .spectrum { gap: 8px; }
  .srow { gap: 8px; }
  .slbl {
    width: 72px !important;
    font-size: 11px;
    text-align: right;
    flex-shrink: 0;
  }
  .strack { height: 28px; }
  .sbar span { font-size: 11px; }
  .sbar-red { width: 35% !important; }
  .sbar-ylw { width: 58% !important; }
  .sbar-grn { width: 78% !important; }
  .sbar-best { width: 100% !important; }

  /* CALCULATOR TEASER */
  .calc-teaser {
    flex-direction: column !important;
    padding: 24px 18px;
    gap: 18px;
    border-radius: 12px;
    margin-bottom: 28px;
  }
  .calc-left h2 { font-size: 24px; }
  .calc-left p { font-size: 13px; max-width: 100%; }
  .calc-mini { min-width: unset !important; width: 100%; }
  .calc-result-num { font-size: 30px; }

  /* BLOG GRID */
  .blog-grid { grid-template-columns: 1fr; gap: 10px; margin-bottom: 28px; }
  .bcard { padding: 16px; }
  .bcard-title { font-size: 14px; }

  /* WHY GRID */
  .why-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; margin-bottom: 36px; }
  .why-card { padding: 16px; }
  .why-title { font-size: 13px; }
  .why-text { font-size: 12px; line-height: 1.55; }

  /* FOOTER */
  footer { padding: 28px 16px 18px; }
  .footer-top {
    grid-template-columns: 1fr 1fr !important;
    gap: 20px;
  }
  .footer-top > div:first-child { grid-column: span 2; }
  .footer-brand-sub { max-width: 100%; }
  .footer-bottom {
    flex-direction: column;
    gap: 6px;
    text-align: center;
  }
  .footer-bottom p { font-size: 11px; }
}

/* Small mobile — 480px and below */
@media (max-width: 480px) {
  .hero h1 { font-size: 28px; }
  .v-grid { grid-template-columns: 1fr !important; }
  .make-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .why-grid { grid-template-columns: 1fr; }
  .footer-top { grid-template-columns: 1fr !important; }
  .footer-top > div:first-child { grid-column: span 1; }
  .scale-section { padding: 20px 14px; }
  .slbl { width: 60px !important; font-size: 10px; }
}
/* Vehicle page — mobile responsive */
@media (max-width: 768px) {
  .vbody { grid-template-columns: 1fr !important; padding: 16px; }
  .vhero { padding: 28px 16px 0; }
  .mpg-strip { width: 100%; }
  .mpg-block { padding: 16px 20px; }
  .mpg-num { font-size: 48px; }
  .mpg-block.combined .mpg-num { font-size: 54px; }
  .cost-card { flex-direction: column; gap: 14px; }
  .cost-compare { text-align: left; margin-left: 0; }
  .scores-grid { grid-template-columns: 1fr 1fr; }
}

