/* ============================================================
   CHINA EV SOURCE — Global Stylesheet  v2
   Accent: #00A3FF | Nav/Footer: #0f0f0f | Light sections: #fff / #f8fafc
   ============================================================ */

/* Google Translate 激活时会将 body.top 设为负值导致内容上移，强制归零 */
body.translated-ltr, body.translated-rtl { top: 0 !important; }

@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&display=swap');

/* ---- Variables ---- */
:root {
  --accent:        #00A3FF;
  --accent-dark:   #0082cc;
  --accent-glow:   rgba(0,163,255,0.22);

  --dark:          #0f0f0f;
  --dark-2:        #161616;
  --dark-border:   rgba(255,255,255,0.1);
  --dark-text:     #9ca3af;

  --light:         #ffffff;
  --light-2:       #f8fafc;
  --light-3:       #f1f5f9;
  --light-border:  #e2e8f0;
  --text-heading:  #0f172a;
  --text-body:     #374151;
  --text-muted:    #6b7280;

  --font:          'Outfit', sans-serif;
  --nav-h:         72px;
  --radius:        14px;
  --radius-sm:     8px;
  --transition:    0.22s ease;
}

/* ---- Reset ---- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body { font-family: var(--font); background: var(--light); color: var(--text-body); line-height: 1.6; overflow-x: hidden; }
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
button { cursor: pointer; font-family: var(--font); }
::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: var(--dark); }
::-webkit-scrollbar-thumb { background: #333; border-radius: 3px; }

/* ============================================================
   NAVBAR  — always dark, no scroll change
   ============================================================ */
.navbar {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--nav-h);
  z-index: 1000;
  display: flex;
  align-items: center;
  padding: 0 48px;
  background: var(--dark);
  border-bottom: 1px solid var(--dark-border);
}

.nav-logo {
  display: flex; align-items: center;
  flex-shrink: 0;
}
.nav-logo-img {
  height: 48px;
  width: auto;
  display: block;
  mix-blend-mode: screen;
}

.nav-links {
  display: flex; align-items: center; gap: 2px;
  margin: 0 auto;
}
.nav-links a {
  padding: 8px 14px; border-radius: var(--radius-sm);
  font-size: 0.88rem; font-weight: 500; color: #9ca3af;
  transition: color var(--transition), background var(--transition);
  white-space: nowrap;
}
.nav-links a:hover,
.nav-links a.active { color: #fff; background: rgba(255,255,255,0.07); }

.nav-cta {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 22px;
  background: var(--accent); color: #fff;
  border-radius: var(--radius-sm); border: none;
  font-size: 0.88rem; font-weight: 600; font-family: var(--font);
  flex-shrink: 0;
  transition: background var(--transition), box-shadow var(--transition), transform var(--transition);
}
.nav-cta:hover {
  background: var(--accent-dark);
  box-shadow: 0 4px 18px var(--accent-glow);
  transform: translateY(-1px);
}

.nav-burger {
  display: none; flex-direction: column; gap: 5px;
  background: none; border: none; padding: 8px; margin-left: auto;
}
.nav-burger span {
  width: 24px; height: 2px; background: #fff; border-radius: 2px; display: block;
  transition: transform 0.3s, opacity 0.3s;
}

.nav-mobile {
  display: none; position: fixed;
  top: var(--nav-h); left: 0; right: 0;
  background: var(--dark);
  border-bottom: 1px solid var(--dark-border);
  padding: 16px 20px; z-index: 999;
  flex-direction: column; gap: 4px;
}
.nav-mobile.open { display: flex; }
.nav-mobile a {
  padding: 11px 14px; border-radius: var(--radius-sm);
  font-size: 0.95rem; font-weight: 500; color: #9ca3af;
  transition: background var(--transition), color var(--transition);
}
.nav-mobile a:hover { background: rgba(255,255,255,0.07); color: #fff; }
.nav-mobile .nav-cta { margin-top: 8px; justify-content: center; }

/* ============================================================
   FLOATING WHATSAPP
   ============================================================ */
.float-wa {
  position: fixed; bottom: 28px; right: 28px;
  width: 56px; height: 56px;
  background: #25d366; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  z-index: 990;
  box-shadow: 0 4px 20px rgba(37,211,102,0.4);
  transition: transform var(--transition), box-shadow var(--transition);
}
.float-wa:hover {
  transform: scale(1.1) translateY(-2px);
  box-shadow: 0 8px 28px rgba(37,211,102,0.55);
}
.float-wa svg { width: 28px; height: 28px; fill: #fff; }

/* ============================================================
   HERO — full-screen background image with overlay
   ============================================================ */
.hero {
  min-height: 100vh;
  position: relative;
  overflow: hidden;
  display: flex; align-items: center;
  padding-top: var(--nav-h);
  background: var(--dark) center center / cover no-repeat;
}
/* overlay: dark left fade to transparent right */
.hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(
    100deg,
    rgba(0,0,0,0.88) 0%,
    rgba(0,0,0,0.65) 45%,
    rgba(0,0,0,0.25) 75%,
    rgba(0,0,0,0.05) 100%
  );
  z-index: 1;
}
/* subtle top & bottom vignette */
.hero::before {
  content: '';
  position: absolute; inset: 0; z-index: 2;
  background: linear-gradient(to bottom, rgba(15,15,15,0.55) 0%, transparent 18%, transparent 82%, rgba(15,15,15,0.6) 100%);
  pointer-events: none;
}

.hero-inner {
  position: relative; z-index: 3;
  max-width: 1200px; width: 100%;
  margin: 0 auto; padding: 0 48px;
}

.hero-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(0,163,255,0.15);
  border: 1px solid rgba(0,163,255,0.35);
  border-radius: 999px; padding: 5px 16px;
  font-size: 0.75rem; font-weight: 700;
  color: var(--accent); letter-spacing: 0.08em; text-transform: uppercase;
  margin-bottom: 24px;
}
.hero-badge::before {
  content: ''; width: 6px; height: 6px; background: var(--accent); border-radius: 50%;
  animation: pulse 2s ease-in-out infinite;
}
@keyframes pulse {
  0%,100% { opacity:1; transform:scale(1); }
  50% { opacity:0.4; transform:scale(1.4); }
}

.hero-title {
  font-size: clamp(3.2rem, 6vw, 5.2rem);
  font-weight: 800; line-height: 1.05; letter-spacing: -0.03em;
  color: #ffffff; margin-bottom: 6px;
}
.hero-title .brand { color: var(--accent); }

.hero-tagline {
  font-size: clamp(1rem, 1.8vw, 1.15rem);
  color: rgba(255,255,255,0.75);
  line-height: 1.65; margin-bottom: 36px;
  max-width: 500px;
}
.hero-tagline strong { color: #ffffff; font-weight: 600; }

.hero-btns { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 52px; }

.hero-stats {
  display: flex; gap: 36px; flex-wrap: wrap;
  padding-top: 28px;
  border-top: 1px solid rgba(255,255,255,0.15);
}
.hero-stat-num {
  font-size: 1.8rem; font-weight: 800; color: var(--accent);
  line-height: 1; letter-spacing: -0.03em;
}
.hero-stat-label {
  font-size: 0.72rem; color: rgba(255,255,255,0.55);
  margin-top: 4px; letter-spacing: 0.04em;
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn-primary {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 13px 26px; background: var(--accent); color: #fff;
  border-radius: var(--radius-sm); font-size: 0.92rem; font-weight: 600; border: none;
  transition: background var(--transition), transform var(--transition), box-shadow var(--transition);
}
.btn-primary:hover {
  background: var(--accent-dark); transform: translateY(-2px);
  box-shadow: 0 8px 22px var(--accent-glow);
}
.btn-outline {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 13px 26px; background: rgba(255,255,255,0.1); color: #fff;
  border-radius: var(--radius-sm); font-size: 0.92rem; font-weight: 600;
  border: 1px solid rgba(255,255,255,0.3);
  transition: background var(--transition), border-color var(--transition), transform var(--transition);
  backdrop-filter: blur(4px);
}
.btn-outline:hover {
  background: rgba(255,255,255,0.18); border-color: rgba(255,255,255,0.5);
  transform: translateY(-2px);
}
.btn-wa {
  display: inline-flex; align-items: center; gap: 9px;
  padding: 13px 26px; background: #25d366; color: #fff;
  border-radius: var(--radius-sm); font-size: 0.92rem; font-weight: 600; border: none;
  transition: background var(--transition), transform var(--transition), box-shadow var(--transition);
}
.btn-wa:hover {
  background: #1cb956; transform: translateY(-2px);
  box-shadow: 0 8px 22px rgba(37,211,102,0.35);
}
.btn-email {
  display: inline-flex; align-items: center; gap: 9px;
  padding: 13px 26px; background: transparent; color: var(--text-heading);
  border-radius: var(--radius-sm); font-size: 0.92rem; font-weight: 600;
  border: 1.5px solid var(--light-border);
  transition: background var(--transition), border-color var(--transition), transform var(--transition);
}
.btn-email:hover {
  background: var(--light-3); border-color: #c0ccd8; transform: translateY(-2px);
}
.btn-primary svg, .btn-outline svg, .btn-wa svg, .btn-email svg { width: 18px; height: 18px; flex-shrink: 0; }

/* ============================================================
   SECTION UTILITIES
   ============================================================ */
.section { padding: 96px 48px; }
.section-sm { padding: 64px 48px; }
.container { max-width: 1200px; margin: 0 auto; }

.sec-tag {
  display: inline-block; font-size: 0.72rem; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent);
  margin-bottom: 10px;
}
.sec-title {
  font-size: clamp(1.9rem, 3.5vw, 2.6rem);
  font-weight: 800; letter-spacing: -0.025em;
  color: var(--text-heading); line-height: 1.15; margin-bottom: 14px;
}
.sec-sub {
  font-size: 1rem; color: var(--text-muted);
  max-width: 540px; line-height: 1.72;
}
.divider { width: 44px; height: 3px; background: var(--accent); border-radius: 2px; margin-bottom: 20px; }
.divider.center { margin-left: auto; margin-right: auto; }
.text-center { text-align: center; }
.text-center .sec-sub { margin: 0 auto; }

/* ============================================================
   BRANDS SECTION — white bg, real logos
   ============================================================ */
.brands-section {
  background: var(--light);
  padding: 64px 48px;
  border-top: 1px solid var(--light-border);
  border-bottom: 1px solid var(--light-border);
}
.brands-header {
  text-align: center; margin-bottom: 40px;
}
.brands-header p {
  font-size: 0.72rem; font-weight: 700; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--text-muted);
}

.brands-grid {
  max-width: 1100px; margin: 0 auto;
  display: flex; flex-wrap: wrap;
  align-items: center; justify-content: center;
  gap: 16px;
}
.brand-card {
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  padding: 20px 24px; min-width: 110px;
  background: var(--light); border: 1.5px solid var(--light-border);
  border-radius: 12px;
  transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
  cursor: default;
}
.brand-card:hover {
  border-color: var(--accent);
  box-shadow: 0 4px 20px rgba(0,163,255,0.1);
  transform: translateY(-3px);
}
.brand-logo-img {
  height: 36px; width: auto; max-width: 90px;
  object-fit: contain;
  filter: none;
  transition: filter var(--transition);
}
.brand-logo-badge {
  height: 36px; display: flex; align-items: center; justify-content: center;
  padding: 4px 12px; border-radius: 6px;
  font-size: 0.8rem; font-weight: 800; letter-spacing: 0.04em;
  white-space: nowrap;
}
.brand-name {
  font-size: 0.72rem; font-weight: 600; color: var(--text-muted);
  letter-spacing: 0.04em; text-align: center;
}

/* ============================================================
   STATS SECTION — light gray
   ============================================================ */
.stats-section {
  background: var(--light-2);
  padding: 80px 48px;
  border-bottom: 1px solid var(--light-border);
}
.stats-grid {
  max-width: 900px; margin: 0 auto;
  display: grid; grid-template-columns: repeat(4,1fr);
}
.stat-item {
  text-align: center; padding: 40px 20px;
  border-right: 1px solid var(--light-border);
}
.stat-item:last-child { border-right: none; }
.stat-num {
  font-size: clamp(2.4rem,5vw,3.4rem); font-weight: 800;
  color: var(--text-heading); line-height: 1; letter-spacing: -0.03em;
}
.stat-num .accent { color: var(--accent); }
.stat-label {
  font-size: 0.82rem; color: var(--text-muted); margin-top: 10px;
}

/* ============================================================
   SERVICES SECTION — white
   ============================================================ */
.services-section {
  background: var(--light); padding: 96px 48px;
  border-bottom: 1px solid var(--light-border);
}
.services-grid {
  display: grid; grid-template-columns: repeat(4,1fr);
  gap: 20px; margin-top: 52px;
}
.service-card {
  background: var(--light); border: 1.5px solid var(--light-border);
  border-radius: var(--radius); padding: 32px 26px;
  transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
}
.service-card:hover {
  border-color: var(--accent);
  box-shadow: 0 6px 28px rgba(0,163,255,0.1);
  transform: translateY(-4px);
}
.service-icon {
  width: 50px; height: 50px;
  background: rgba(0,163,255,0.08); border: 1.5px solid rgba(0,163,255,0.18);
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center; margin-bottom: 20px;
}
.service-icon svg { width: 22px; height: 22px; stroke: var(--accent); fill: none; stroke-width: 1.8; }
.service-card h3 { font-size: 1rem; font-weight: 700; color: var(--text-heading); margin-bottom: 9px; }
.service-card p { font-size: 0.87rem; color: var(--text-muted); line-height: 1.68; }

/* ============================================================
   HOW IT WORKS SECTION — light gray
   ============================================================ */
.how-section { background: var(--light-2); padding: 96px 48px; }
.steps-row {
  display: grid; grid-template-columns: repeat(5,1fr);
  gap: 0; margin-top: 52px; position: relative;
}
.steps-row::before {
  content: ''; position: absolute;
  top: 32px; left: calc(10% + 16px); right: calc(10% + 16px); height: 1px;
  background: linear-gradient(90deg, transparent, var(--light-border), var(--light-border), transparent);
}
.step-item {
  display: flex; flex-direction: column; align-items: center;
  text-align: center; padding: 0 12px; position: relative; z-index: 1;
}
.step-num {
  width: 64px; height: 64px;
  background: var(--light); border: 2px solid var(--light-border);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.15rem; font-weight: 800; color: var(--accent);
  margin-bottom: 20px;
  transition: border-color var(--transition), box-shadow var(--transition), background var(--transition);
}
.step-item:hover .step-num {
  border-color: var(--accent);
  background: rgba(0,163,255,0.06);
  box-shadow: 0 0 0 6px rgba(0,163,255,0.08);
}
.step-item h4 { font-size: 0.88rem; font-weight: 700; color: var(--text-heading); margin-bottom: 7px; }
.step-item p { font-size: 0.78rem; color: var(--text-muted); line-height: 1.6; }

.steps-cta { text-align: center; margin-top: 44px; }
.link-arrow {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--accent); font-size: 0.9rem; font-weight: 600;
  transition: gap var(--transition);
}
.link-arrow:hover { gap: 10px; }

/* ============================================================
   CTA BANNER — dark (matches nav/footer)
   ============================================================ */
.cta-banner {
  background: var(--dark);
  border-top: 1px solid var(--dark-border);
  padding: 88px 48px; text-align: center;
  position: relative; overflow: hidden;
}
.cta-banner::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse at 50% 100%, rgba(0,163,255,0.12) 0%, transparent 65%);
  pointer-events: none;
}
.cta-banner h2 {
  font-size: clamp(1.8rem,3.5vw,2.5rem); font-weight: 800;
  letter-spacing: -0.02em; color: #fff; margin-bottom: 14px;
  position: relative; z-index: 1;
}
.cta-banner p {
  font-size: 1rem; color: #9ca3af; margin-bottom: 36px;
  position: relative; z-index: 1;
}
.cta-btns {
  display: flex; gap: 14px; justify-content: center; flex-wrap: wrap;
  position: relative; z-index: 1;
}
/* override btn-email for dark bg */
.cta-banner .btn-email {
  color: #fff; border-color: rgba(255,255,255,0.2);
}
.cta-banner .btn-email:hover {
  background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.35);
  color: #fff;
}

/* ============================================================
   FOOTER — same dark as navbar
   ============================================================ */
.footer {
  background: var(--dark);
  border-top: 1px solid var(--dark-border);
  padding: 64px 48px 32px;
}
.footer-grid {
  max-width: 1200px; margin: 0 auto;
  display: grid; grid-template-columns: 2fr 1fr 1fr;
  gap: 48px; padding-bottom: 48px;
  border-bottom: 1px solid var(--dark-border);
}
.footer-brand .nav-logo { margin-bottom: 16px; }
.footer-brand p { font-size: 0.86rem; color: var(--dark-text); line-height: 1.72; max-width: 300px; }
.footer-title {
  font-size: 0.7rem; font-weight: 700; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--dark-text); margin-bottom: 18px;
}
.footer-links { display: flex; flex-direction: column; gap: 10px; }
.footer-links a { font-size: 0.86rem; color: var(--dark-text); transition: color var(--transition); }
.footer-links a:hover { color: #fff; }
.footer-contacts { display: flex; flex-direction: column; gap: 11px; }
.contact-item {
  display: flex; align-items: center; gap: 10px;
  font-size: 0.84rem; color: var(--dark-text); transition: color var(--transition);
}
.contact-item:hover { color: #fff; }

.footer-bottom {
  max-width: 1200px; margin: 0 auto;
  padding-top: 26px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; flex-wrap: wrap;
}
.footer-copy { font-size: 0.78rem; color: var(--dark-text); }
.footer-socials { display: flex; gap: 10px; }
.social-icon {
  width: 36px; height: 36px;
  background: rgba(255,255,255,0.05); border: 1px solid var(--dark-border);
  border-radius: 8px; display: flex; align-items: center; justify-content: center;
  color: var(--dark-text); font-size: 1rem;
  transition: background var(--transition), border-color var(--transition), color var(--transition);
}
.social-icon:hover {
  background: rgba(0,163,255,0.12); border-color: rgba(0,163,255,0.35); color: var(--accent);
}

/* ============================================================
   PAGE BANNER (inner pages)
   ============================================================ */
.page-banner {
  padding: calc(var(--nav-h) + 56px) 48px 56px;
  background: var(--dark); border-bottom: 1px solid var(--dark-border);
  position: relative; overflow: hidden;
}
.page-banner::after {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse at 30% 50%, rgba(0,163,255,0.07) 0%, transparent 65%);
  pointer-events: none;
}
.page-banner-inner { max-width: 1200px; margin: 0 auto; position: relative; z-index: 1; }
.page-banner h1 {
  font-size: clamp(2rem,5vw,3rem); font-weight: 800;
  letter-spacing: -0.02em; color: #fff; margin-bottom: 12px;
}
.page-banner p { font-size: 1rem; color: var(--dark-text); max-width: 520px; }

/* ============================================================
   CARS PAGE — Filter & Grid
   ============================================================ */
.filter-bar {
  background: var(--light); border-bottom: 1.5px solid var(--light-border);
  padding: 16px 48px; position: sticky; top: var(--nav-h); z-index: 100;
  box-shadow: 0 2px 12px rgba(0,0,0,0.05);
}
.filter-inner {
  max-width: 1200px; margin: 0 auto;
  display: flex; gap: 16px; flex-wrap: wrap; align-items: flex-end;
}
.filter-group { display: flex; flex-direction: column; gap: 4px; }
.filter-label {
  font-size: 0.68rem; font-weight: 700; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--text-muted);
}
.filter-select {
  background: var(--light); border: 1.5px solid var(--light-border);
  border-radius: var(--radius-sm); color: var(--text-heading);
  font-family: var(--font); font-size: 0.87rem;
  padding: 8px 32px 8px 12px; appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 10px center;
  cursor: pointer; transition: border-color var(--transition);
}
.filter-select:focus { outline: none; border-color: var(--accent); }

.cars-section { padding: 48px 48px 96px; background: var(--light-2); }
.cars-grid {
  max-width: 1200px; margin: 0 auto;
  display: grid; grid-template-columns: repeat(4,1fr); gap: 20px;
}
.car-card {
  background: var(--light); border: 1.5px solid var(--light-border);
  border-radius: var(--radius); overflow: hidden;
  transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
}
.car-card:hover {
  border-color: var(--accent);
  box-shadow: 0 8px 28px rgba(0,0,0,0.1);
  transform: translateY(-4px);
}
.car-img {
  width: 100%; aspect-ratio: 16/9;
  background: var(--light-3); display: flex; align-items: center; justify-content: center;
  border-bottom: 1.5px solid var(--light-border); overflow: hidden; position: relative;
}
.car-img img { width: 100%; height: 100%; object-fit: cover; }
.car-img-placeholder { display: flex; flex-direction: column; align-items: center; gap: 8px; }
.car-img-placeholder svg { width: 48px; height: 24px; stroke: #cdd5df; fill: none; stroke-width: 1.5; }
.car-img-placeholder span { font-size: 0.68rem; color: #cdd5df; letter-spacing: 0.06em; text-transform: uppercase; }

.car-badges { position: absolute; top: 10px; left: 10px; display: flex; gap: 6px; }
.badge {
  font-size: 0.63rem; font-weight: 700; letter-spacing: 0.06em;
  text-transform: uppercase; padding: 3px 8px; border-radius: 4px;
}
.badge-ev    { background: rgba(0,163,255,0.12); color: #0082cc; border: 1px solid rgba(0,163,255,0.25); }
.badge-phev  { background: rgba(0,180,100,0.1); color: #00803c; border: 1px solid rgba(0,180,100,0.2); }
.badge-fuel  { background: rgba(220,120,0,0.1); color: #b35a00; border: 1px solid rgba(220,120,0,0.2); }
.badge-lhd   { background: rgba(0,0,0,0.06); color: var(--text-muted); border: 1px solid var(--light-border); }
.badge-rhd   { background: rgba(220,50,50,0.08); color: #b91c1c; border: 1px solid rgba(220,50,50,0.15); }

.car-info { padding: 16px; }
.car-brand { font-size: 0.68rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--accent); margin-bottom: 4px; }
.car-name { font-size: 1rem; font-weight: 700; color: var(--text-heading); margin-bottom: 8px; }
.car-specs { display: flex; gap: 12px; font-size: 0.74rem; color: var(--text-muted); margin-bottom: 12px; flex-wrap: wrap; }
.btn-inquire {
  width: 100%; padding: 10px;
  background: transparent; border: 1.5px solid var(--light-border);
  border-radius: var(--radius-sm); color: var(--text-heading);
  font-size: 0.84rem; font-weight: 600; font-family: var(--font);
  display: flex; align-items: center; justify-content: center; gap: 7px;
  transition: background var(--transition), border-color var(--transition), color var(--transition);
}
.btn-inquire:hover {
  background: rgba(0,163,255,0.06); border-color: var(--accent); color: var(--accent);
}

/* ============================================================
   INQUIRY MODAL
   ============================================================ */
.modal-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,0.55);
  backdrop-filter: blur(6px); z-index: 2000;
  display: flex; align-items: center; justify-content: center; padding: 20px;
  opacity: 0; pointer-events: none; transition: opacity 0.22s;
}
.modal-overlay.open { opacity: 1; pointer-events: all; }
.modal {
  background: var(--light); border: 1.5px solid var(--light-border);
  border-radius: 18px; padding: 36px; max-width: 460px; width: 100%;
  transform: translateY(16px); transition: transform 0.22s;
}
.modal-overlay.open .modal { transform: translateY(0); }
.modal-header { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 24px; }
.modal-header h3 { font-size: 1.25rem; font-weight: 800; color: var(--text-heading); }
.modal-close { background: none; border: none; color: var(--text-muted); font-size: 1.3rem; padding: 2px; cursor: pointer; }
.modal-close:hover { color: var(--text-heading); }
.form-group { margin-bottom: 14px; }
.form-group label { display: block; font-size: 0.78rem; font-weight: 600; color: var(--text-muted); margin-bottom: 5px; letter-spacing: 0.04em; }
.form-input, .form-textarea {
  width: 100%; background: var(--light-2); border: 1.5px solid var(--light-border);
  border-radius: var(--radius-sm); color: var(--text-heading);
  font-family: var(--font); font-size: 0.9rem; padding: 10px 13px;
  transition: border-color var(--transition);
}
.form-input:focus, .form-textarea:focus { outline: none; border-color: var(--accent); }
.form-textarea { resize: vertical; min-height: 80px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.form-submit {
  width: 100%; padding: 12px; background: var(--accent); color: #fff;
  border: none; border-radius: var(--radius-sm);
  font-size: 0.94rem; font-weight: 600; font-family: var(--font); margin-top: 6px;
  transition: background var(--transition), transform var(--transition);
}
.form-submit:hover { background: var(--accent-dark); transform: translateY(-1px); }

/* ============================================================
   FAQ PAGE
   ============================================================ */
.faq-category { margin-bottom: 40px; }
.faq-cat-title {
  font-size: 0.75rem; font-weight: 700; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--accent); margin-bottom: 16px;
  padding-bottom: 10px; border-bottom: 1.5px solid var(--light-border);
}
.faq-item { border-bottom: 1px solid var(--light-border); }
.faq-question {
  width: 100%; display: flex; justify-content: space-between; align-items: center;
  padding: 18px 0; background: none; border: none;
  font-family: var(--font); font-size: 0.95rem; font-weight: 600;
  color: var(--text-heading); text-align: left; cursor: pointer;
  gap: 16px; transition: color var(--transition);
}
.faq-question:hover { color: var(--accent); }
.faq-icon { flex-shrink: 0; width: 20px; height: 20px; position: relative; }
.faq-icon::before, .faq-icon::after {
  content: ''; position: absolute; background: var(--text-muted);
  border-radius: 2px; transition: transform 0.25s, opacity 0.25s;
}
.faq-icon::before { width: 12px; height: 2px; top: 50%; left: 50%; transform: translate(-50%,-50%); }
.faq-icon::after { width: 2px; height: 12px; top: 50%; left: 50%; transform: translate(-50%,-50%); }
.faq-item.open .faq-icon::after { transform: translate(-50%,-50%) rotate(90deg); opacity: 0; }
.faq-answer { max-height: 0; overflow: hidden; transition: max-height 0.3s ease, padding 0.3s; }
.faq-item.open .faq-answer { max-height: 600px; padding-bottom: 18px; }
.faq-answer p { font-size: 0.9rem; color: var(--text-muted); line-height: 1.72; }

/* ============================================================
   CARS PAGE — HERO
   ============================================================ */
.cars-hero {
  min-height: 500px;
  background: #07101e center center / cover no-repeat;
  position: relative; overflow: hidden;
  display: flex; align-items: center;
  margin-top: var(--nav-h);
}
.cars-hero-overlay {
  position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(
    105deg,
    rgba(0,0,0,0.88) 0%,
    rgba(0,0,0,0.62) 42%,
    rgba(0,0,0,0.28) 68%,
    rgba(0,0,0,0.08) 100%
  );
}
/* top & bottom vignette */
.cars-hero::before {
  content: ''; position: absolute; inset: 0; z-index: 2;
  background: linear-gradient(
    to bottom,
    rgba(7,16,30,0.5) 0%, transparent 20%,
    transparent 78%, rgba(7,16,30,0.55) 100%
  );
  pointer-events: none;
}
.cars-hero-deco {
  position: absolute; right: -3%; top: 50%;
  transform: translateY(-50%);
  font-size: clamp(8rem, 20vw, 18rem);
  font-weight: 900; letter-spacing: -0.05em;
  color: rgba(255,255,255,0.04);
  line-height: 1; pointer-events: none; user-select: none;
  z-index: 3;
}
.cars-hero-inner {
  position: relative; z-index: 4;
  max-width: 1200px; width: 100%;
  margin: 0 auto; padding: 72px 48px;
}
.cars-hero-inner h1 {
  font-size: clamp(2.4rem, 5vw, 3.8rem);
  font-weight: 800; letter-spacing: -0.03em;
  color: #fff; margin: 16px 0 18px; line-height: 1.08;
}
.ch-accent { color: var(--accent); }
.cars-hero-inner > p {
  font-size: 1.05rem; color: rgba(255,255,255,0.62);
  max-width: 520px; line-height: 1.7; margin-bottom: 36px;
}
.ch-stats {
  display: flex; gap: 40px; flex-wrap: wrap;
  padding-top: 28px; border-top: 1px solid rgba(255,255,255,0.1);
}
.ch-stats > div { display: flex; flex-direction: column; gap: 4px; }
.ch-stats strong {
  font-size: 1.35rem; font-weight: 800; color: var(--accent);
  letter-spacing: -0.02em; line-height: 1;
}
.ch-stats span { font-size: 0.7rem; color: rgba(255,255,255,0.42); letter-spacing: 0.04em; }

/* ============================================================
   FILTER BAR ENHANCEMENTS
   ============================================================ */
.btn-filter-reset {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 16px;
  background: transparent; border: 1.5px solid var(--light-border);
  border-radius: var(--radius-sm); color: var(--text-muted);
  font-size: 0.84rem; font-weight: 600; font-family: var(--font);
  cursor: pointer; transition: all var(--transition);
  white-space: nowrap;
}
.btn-filter-reset:hover { border-color: var(--accent); color: var(--accent); background: rgba(0,163,255,0.05); }
.filter-results-bar { max-width: 1200px; margin: 8px auto 0; }
#results-count { font-size: 0.76rem; color: var(--text-muted); font-weight: 500; }

/* ============================================================
   CAR IMAGE — gradient placeholder with SVG silhouette
   ============================================================ */
.car-img-shine {
  position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(ellipse at 50% 0%, rgba(255,255,255,0.1) 0%, transparent 65%);
}
.car-silhouette {
  width: 76%; max-width: 185px; height: auto;
  position: absolute; bottom: 10px;
  left: 50%; transform: translateX(-50%);
  pointer-events: none;
}

/* ============================================================
   NO RESULTS STATE
   ============================================================ */
.no-results {
  max-width: 1200px; margin: 0 auto;
  display: none; flex-direction: column; align-items: center;
  gap: 16px; padding: 80px 20px; text-align: center;
}
.no-results.show { display: flex; }
.no-results i { font-size: 3rem; color: var(--text-muted); opacity: 0.4; }
.no-results p { font-size: 1rem; color: var(--text-muted); }

/* ============================================================
   CAR CARD — two-button action row
   ============================================================ */
.car-actions { display: flex; gap: 8px; }
.btn-view-detail {
  flex: 1;
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  padding: 9px 8px; font-size: 0.8rem; font-weight: 600; font-family: var(--font);
  background: var(--accent); color: #fff; border-radius: var(--radius-sm); border: none;
  text-decoration: none;
  transition: background var(--transition), transform var(--transition);
}
.btn-view-detail:hover { background: var(--accent-dark); transform: translateY(-1px); }
.car-actions .btn-inquire {
  flex: 1; width: auto; padding: 9px 8px; font-size: 0.8rem;
}

/* ============================================================
   PAGINATION
   ============================================================ */
.pagination {
  display: flex; align-items: center; justify-content: center;
  gap: 6px; padding: 40px 20px 0; flex-wrap: wrap;
}
.page-btn {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 38px; height: 38px; padding: 0 12px;
  background: var(--light); border: 1.5px solid var(--light-border);
  border-radius: var(--radius-sm); font-size: 0.86rem; font-weight: 600;
  color: var(--text-heading); font-family: var(--font); cursor: pointer;
  transition: all var(--transition);
}
.page-btn:hover:not(.disabled) { border-color: var(--accent); color: var(--accent); background: rgba(0,163,255,0.05); }
.page-btn.active { background: var(--accent); border-color: var(--accent); color: #fff; }
.page-btn.disabled { opacity: 0.35; cursor: not-allowed; }
.page-ellipsis { color: var(--text-muted); font-size: 0.86rem; padding: 0 4px; line-height: 38px; }

/* ============================================================
   CAR DETAIL PAGE v2 — gzdcars / ddongauto style
   All classes prefixed .cd- to avoid conflicts
   ============================================================ */

/* Breadcrumb */
.cd-breadcrumb {
  background: var(--light-2); border-bottom: 1px solid var(--light-border);
  padding: calc(var(--nav-h) + 10px) 48px 10px;
}
.cd-breadcrumb-inner {
  max-width: 1280px; margin: 0 auto;
  display: flex; align-items: center; gap: 7px;
  font-size: 0.76rem; color: var(--text-muted);
}
.cd-breadcrumb a { color: var(--text-muted); transition: color var(--transition); }
.cd-breadcrumb a:hover { color: var(--accent); }
.cd-breadcrumb i { font-size: 0.68rem; }

/* ---- TOP: Two-column gallery + sidebar ---- */
.cd-top {
  max-width: 1280px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 390px; gap: 0;
  padding: 32px 48px 40px;
  align-items: start;
}
.cd-gallery { }

.cd-main-img {
  width: 100%; aspect-ratio: 16/9;
  border-radius: var(--radius); overflow: hidden;
  position: relative; display: flex; align-items: center; justify-content: center;
  border: 1.5px solid var(--light-border); margin-bottom: 10px;
  transition: background 0.35s ease; cursor: zoom-in;
}
.cd-main-label {
  position: absolute; top: 12px; left: 12px;
  background: rgba(0,0,0,0.45); color: rgba(255,255,255,0.9);
  font-size: 0.62rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
  padding: 4px 10px; border-radius: 4px; backdrop-filter: blur(4px); z-index: 2;
}
.cd-main-svg {
  width: 72%; max-width: 400px; height: auto;
  position: absolute; bottom: 16px; left: 50%; transform: translateX(-50%);
  pointer-events: none; z-index: 1; transition: opacity 0.25s;
}
.cd-thumbs {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 3px;
  background: #111; padding: 3px;
  border-radius: var(--radius) var(--radius) 0 0;
}
.cd-thumb {
  aspect-ratio: 4/3; overflow: hidden;
  border: 2px solid transparent; cursor: pointer;
  position: relative; display: flex; align-items: center; justify-content: center;
  transition: border-color var(--transition);
}
.cd-thumb.active, .cd-thumb:hover { border-color: var(--accent); }
.cd-thumb i { color: rgba(255,255,255,0.38); font-size: 1rem; position: relative; z-index: 1; }
.cd-thumb-lbl {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: rgba(0,0,0,0.55); color: rgba(255,255,255,0.9);
  font-size: 0.52rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase;
  text-align: center; padding: 3px 4px; backdrop-filter: blur(3px);
}

/* ---- Sidebar ---- */
.cd-sidebar {
  display: flex; flex-direction: column;
}
.cd-sidebar-content {
  padding: 20px 0 0 28px;
  display: flex; flex-direction: column;
  border-top: 1px solid var(--light-border);
}
.cd-brand { font-size: 0.68rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent); margin-bottom: 5px; }
.cd-model { font-size: clamp(1.7rem, 2.8vw, 2.3rem); font-weight: 800; color: var(--text-heading); letter-spacing: -0.02em; line-height: 1.1; margin-bottom: 8px; }
.cd-tagline { font-size: 0.86rem; color: var(--text-muted); line-height: 1.6; margin-bottom: 18px; }
.cd-badges { display: flex; gap: 7px; flex-wrap: wrap; margin-bottom: 18px; }

.cd-spec-row {
  display: grid; grid-template-columns: repeat(4,1fr);
  border: 1.5px solid var(--light-border); border-radius: var(--radius); overflow: hidden;
  margin-bottom: 18px;
}
.cd-spec-cell {
  padding: 12px 8px; text-align: center;
  border-right: 1px solid var(--light-border);
}
.cd-spec-cell:last-child { border-right: none; }
.cd-spec-cell strong { display: block; font-size: 0.95rem; font-weight: 800; color: var(--text-heading); line-height: 1; white-space: nowrap; }
.cd-spec-cell span { display: block; font-size: 0.56rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.05em; margin-top: 4px; }

.cd-delivery {
  display: flex; align-items: center; gap: 8px; font-size: 0.82rem;
  color: var(--text-muted); margin-bottom: 14px;
}
.cd-delivery i { color: var(--accent); }
.cd-delivery strong { color: var(--text-heading); }

.cd-price {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px; background: var(--light-2); border-radius: var(--radius-sm);
  border: 1.5px solid var(--light-border); margin-bottom: 14px;
}
.cd-price-lbl { font-size: 0.68rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.08em; font-weight: 700; }
.cd-price-val { font-size: 0.92rem; font-weight: 800; color: var(--text-heading); }

.cd-ctas { display: flex; flex-direction: column; gap: 10px; margin-bottom: 18px; }
.cd-wa {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  padding: 13px 20px; background: #25d366; color: #fff;
  border-radius: var(--radius-sm); font-size: 0.9rem; font-weight: 700;
  border: none; font-family: var(--font); cursor: pointer; text-decoration: none;
  transition: background var(--transition), transform var(--transition);
}
.cd-wa:hover { background: #1cb956; transform: translateY(-1px); }
.cd-wa svg { width: 18px; height: 18px; fill: #fff; flex-shrink: 0; }
.cd-quote {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  padding: 12px 20px; background: transparent; color: var(--text-heading);
  border-radius: var(--radius-sm); font-size: 0.9rem; font-weight: 600;
  border: 1.5px solid var(--light-border); font-family: var(--font); cursor: pointer;
  transition: all var(--transition);
}
.cd-quote:hover { border-color: var(--accent); color: var(--accent); background: rgba(0,163,255,0.04); }

.cd-mini-feats { border-top: 1px solid var(--light-border); padding-top: 16px; }
.cd-mini-feats-title { font-size: 0.62rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-muted); margin-bottom: 10px; }
.cd-mini-feat { display: flex; align-items: flex-start; gap: 8px; margin-bottom: 8px; }
.cd-mini-feat i { color: var(--accent); font-size: 0.85rem; flex-shrink: 0; margin-top: 2px; }
.cd-mini-feat span { font-size: 0.78rem; color: var(--text-body); line-height: 1.45; }

/* ---- Full-width content sections ---- */
.cd-section { padding: 60px 48px; border-top: 1px solid var(--light-border); }
.cd-section.alt { background: var(--light-2); }
.cd-section-inner { max-width: 1280px; margin: 0 auto; }
.cd-section-hd { margin-bottom: 32px; }

/* Parameters table */
.cd-params-tbl { width: 100%; border-collapse: collapse; }
.cd-params-tbl tr { border-bottom: 1px solid var(--light-border); }
.cd-params-tbl tr:nth-child(odd) { background: var(--light-3); }
.cd-params-tbl td { padding: 12px 18px; font-size: 0.86rem; }
.cd-params-tbl td:first-child { color: var(--text-muted); font-weight: 600; width: 35%; }
.cd-params-tbl td:last-child { color: var(--text-heading); font-weight: 600; }

/* Video placeholder */
.cd-video-box {
  max-width: 900px; margin: 28px auto 0;
  aspect-ratio: 16/9; background: linear-gradient(135deg, #08101e 0%, #14202e 100%);
  border-radius: var(--radius); border: 1.5px solid var(--light-border);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 14px; position: relative; overflow: hidden; cursor: pointer;
}
.cd-video-box::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse at 50% 65%, rgba(0,163,255,0.1) 0%, transparent 60%);
  pointer-events: none;
}
.cd-play { width: 68px; height: 68px; border-radius: 50%; position: relative; z-index: 1;
  background: rgba(255,255,255,0.12); border: 2px solid rgba(255,255,255,0.35);
  display: flex; align-items: center; justify-content: center;
  backdrop-filter: blur(4px); transition: background var(--transition), transform var(--transition);
}
.cd-video-box:hover .cd-play { background: rgba(0,163,255,0.45); transform: scale(1.08); }
.cd-play i { color: #fff; font-size: 1.5rem; margin-left: 5px; }
.cd-video-hint { color: rgba(255,255,255,0.5); font-size: 0.82rem; position: relative; z-index: 1; }

/* Article grid */
.cd-article-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; margin-top: 28px; }
.cd-art-col h3 { font-size: 1.05rem; font-weight: 700; color: var(--text-heading); margin-bottom: 12px; padding-left: 12px; border-left: 3px solid var(--accent); }
.cd-art-col p { font-size: 0.88rem; color: var(--text-body); line-height: 1.8; }

/* Highlights list */
.cd-highlights { display: flex; flex-direction: column; gap: 10px; margin-top: 28px; }
.cd-hl-item {
  display: flex; align-items: flex-start; gap: 14px;
  padding: 16px 18px; background: var(--light); border: 1.5px solid var(--light-border);
  border-radius: var(--radius-sm); border-left: 3px solid var(--accent);
}
.cd-hl-num { font-size: 1rem; font-weight: 900; color: var(--accent); line-height: 1; flex-shrink: 0; min-width: 20px; }
.cd-hl-txt { font-size: 0.85rem; color: var(--text-body); line-height: 1.55; }
.cd-hl-txt strong { display: block; color: var(--text-heading); font-weight: 700; margin-bottom: 2px; }

/* Color section */
.cd-color-preview {
  width: 100%; height: 200px; border-radius: var(--radius);
  position: relative; overflow: hidden; margin-bottom: 20px;
  display: flex; align-items: center; justify-content: center;
  border: 1.5px solid var(--light-border); transition: background 0.35s ease;
}
.cd-color-preview svg { width: 55%; max-width: 480px; height: auto; position: absolute; bottom: 12px; left: 50%; transform: translateX(-50%); }
.cd-color-swatches { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; margin-bottom: 8px; }
.cd-sw {
  width: 34px; height: 34px; border-radius: 50%; cursor: pointer;
  border: 2.5px solid transparent; outline: 2px solid transparent; outline-offset: 2px;
  transition: all var(--transition); box-shadow: inset 0 0 0 1px rgba(0,0,0,0.14);
}
.cd-sw.active { outline-color: var(--accent); transform: scale(1.2); }
.cd-sw:hover { transform: scale(1.1); }
.cd-color-name { font-size: 0.84rem; font-weight: 600; color: var(--text-body); margin-top: 4px; }

/* Trims table */
.cd-trims-tbl { width: 100%; border-collapse: collapse; margin-top: 28px; border-radius: var(--radius); overflow: hidden; border: 1.5px solid var(--light-border); }
.cd-trims-tbl th { background: var(--dark); color: rgba(255,255,255,0.8); padding: 13px 16px; font-size: 0.68rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; text-align: left; }
.cd-trims-tbl td { padding: 13px 16px; font-size: 0.84rem; color: var(--text-body); border-bottom: 1px solid var(--light-border); }
.cd-trims-tbl tr:last-child td { border-bottom: none; }
.cd-trims-tbl tbody tr:hover td { background: rgba(0,163,255,0.04); }
.cd-trim-name { font-weight: 700; color: var(--text-heading); }
.cd-trim-quote { color: var(--accent); font-weight: 600; font-size: 0.78rem; cursor: pointer; white-space: nowrap; }
.cd-trim-quote:hover { text-decoration: underline; }

/* Ordering Process */
.cd-process { display: grid; grid-template-columns: repeat(5,1fr); gap: 0; margin-top: 40px; position: relative; }
.cd-process::before {
  content: ''; position: absolute; top: 32px;
  left: calc(10% + 20px); right: calc(10% + 20px); height: 2px;
  background: linear-gradient(90deg, var(--accent), rgba(0,163,255,0.25));
}
.cd-ps { display: flex; flex-direction: column; align-items: center; text-align: center; padding: 0 10px; position: relative; z-index: 1; }
.cd-ps-num { width: 64px; height: 64px; border-radius: 50%; background: var(--accent); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 1rem; font-weight: 800; margin-bottom: 16px; box-shadow: 0 4px 18px rgba(0,163,255,0.35); }
.cd-ps h4 { font-size: 0.84rem; font-weight: 700; color: var(--text-heading); margin-bottom: 6px; }
.cd-ps p { font-size: 0.74rem; color: var(--text-muted); line-height: 1.5; }

/* FAQ (reuse existing .faq-* classes) */
.cd-faq { margin-top: 28px; }

/* Contact section */
.cd-contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; margin-top: 32px; }
.cd-contact-method {
  display: flex; align-items: center; gap: 14px; padding: 16px 18px;
  border: 1.5px solid var(--light-border); border-radius: var(--radius-sm);
  margin-bottom: 12px; transition: all var(--transition); text-decoration: none;
  color: inherit;
}
.cd-contact-method:hover { border-color: var(--accent); background: rgba(0,163,255,0.03); }
.cd-contact-method i { font-size: 1.2rem; color: var(--accent); flex-shrink: 0; }
.cd-contact-method strong { display: block; font-size: 0.84rem; color: var(--text-heading); }
.cd-contact-method span { font-size: 0.78rem; color: var(--text-muted); }

/* Related */
.cd-related-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; margin-top: 28px; }

/* ---- MAIN WRAPPER — ddongauto-style 63/32 grid ----
   No align-items (default = stretch) so the right column
   automatically matches the left column's full height,
   giving position:sticky the room it needs.              */
.cd-main-wrapper {
  max-width: 1280px; margin: 0 auto;
  padding: 32px 48px 0;
  display: grid; grid-template-columns: 1fr 380px;
}
.cd-left-area  { min-width: 0; padding-right: 48px; }
.cd-right-col  { }   /* stretches to left-area height by default */

/* Sidebar — pure CSS sticky, no JS needed */
.cd-sidebar {
  position: sticky;
  top: calc(var(--nav-h) + 16px);
  display: flex; flex-direction: column;
}

/* Inner blocks (inside cd-left-area) */
.cd-inner-block {
  padding: 40px 0; border-top: 1px solid var(--light-border);
}
.cd-inner-block.alt {
  padding: 40px 24px; margin: 0 -24px;
  background: var(--light-2); border-top: 1px solid var(--light-border);
}
.cd-inner-hd { margin-bottom: 24px; }
.cd-inner-title { font-size: clamp(1.25rem,2.2vw,1.7rem); font-weight: 800; color: var(--text-heading); letter-spacing: -0.02em; line-height: 1.15; }
.cd-inner-sub { font-size: 0.84rem; color: var(--text-muted); margin-top: 6px; line-height: 1.65; }

/* Color card grid (replaces cd-color-preview / cd-color-swatches) */
.cd-color-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(150px,1fr));
  gap: 12px;
}
.cd-color-card {
  border-radius: var(--radius); overflow: hidden; cursor: pointer;
  border: 2.5px solid var(--light-border);
  transition: border-color var(--transition), transform var(--transition), box-shadow var(--transition);
}
.cd-color-card:hover { border-color: rgba(0,163,255,0.5); transform: translateY(-2px); box-shadow: 0 6px 20px rgba(0,0,0,0.08); }
.cd-color-card.active { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(0,163,255,0.12); }
.cd-color-card-img {
  aspect-ratio: 16/9; position: relative;
  display: flex; align-items: flex-end; justify-content: center;
  overflow: hidden; transition: background 0.3s ease;
}
.cd-color-card-img svg { width: 92%; max-width: 180px; height: auto; position: absolute; bottom: 7px; left: 50%; transform: translateX(-50%); pointer-events: none; }
.cd-color-card-foot {
  display: flex; align-items: center; gap: 8px; padding: 8px 10px;
  background: var(--light); border-top: 1px solid var(--light-border);
}
.cd-color-dot { width: 14px; height: 14px; border-radius: 50%; flex-shrink: 0; box-shadow: inset 0 0 0 1px rgba(0,0,0,0.14); }
.cd-color-card-name { font-size: 0.75rem; font-weight: 600; color: var(--text-heading); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ---- Responsive ---- */
@media (max-width: 1100px) {
  .cd-main-wrapper { grid-template-columns: 1fr 340px; }
  .cd-related-grid { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 900px) {
  .cd-main-wrapper { grid-template-columns: 1fr; padding: 20px 20px 0; }
  .cd-left-area { padding-right: 0; }
  .cd-right-col { order: -1; }   /* sidebar above content on mobile */
  .cd-sidebar { position: static; padding-top: 0; }
  .cd-spec-row { grid-template-columns: repeat(2,1fr); }
  .cd-spec-cell:nth-child(2) { border-right: none; }
  .cd-article-grid, .cd-contact-grid { grid-template-columns: 1fr; gap: 28px; }
  .cd-section { padding: 40px 20px; }
  .cd-breadcrumb { padding-left: 20px; padding-right: 20px; }

  .cd-related-grid { grid-template-columns: repeat(2,1fr); }
  .cd-inner-block.alt { margin: 0 -20px; padding-left: 20px; padding-right: 20px; }
}
@media (max-width: 600px) {
  .cd-related-grid { grid-template-columns: 1fr; }
  .cd-color-grid { grid-template-columns: repeat(2,1fr); }
}

/* ============================================================
   CAR DETAIL PAGE
   ============================================================ */
.detail-breadcrumb {
  background: var(--light-2); border-bottom: 1px solid var(--light-border);
  padding: calc(var(--nav-h) + 12px) 48px 12px;
}
.detail-breadcrumb-inner {
  max-width: 1200px; margin: 0 auto;
  display: flex; align-items: center; gap: 8px;
  font-size: 0.78rem; color: var(--text-muted);
}
.detail-breadcrumb a { color: var(--text-muted); transition: color var(--transition); }
.detail-breadcrumb a:hover { color: var(--accent); }
.detail-breadcrumb i { font-size: 0.7rem; }

.detail-main {
  max-width: 1200px; margin: 0 auto;
  padding: 36px 48px 72px;
  display: grid; grid-template-columns: 1fr 420px; gap: 48px;
  align-items: start;
}

/* Left: gallery */
.detail-gallery { position: sticky; top: calc(var(--nav-h) + 24px); }
.detail-main-img {
  width: 100%; aspect-ratio: 16/9; border-radius: var(--radius);
  overflow: hidden; position: relative;
  border: 1.5px solid var(--light-border);
  display: flex; align-items: center; justify-content: center;
  transition: background 0.35s ease;
}
.detail-main-img .car-img-shine { border-radius: var(--radius); }
.detail-main-svg {
  width: 70%; max-width: 380px; height: auto;
  position: absolute; bottom: 18px;
  left: 50%; transform: translateX(-50%);
  pointer-events: none; transition: opacity 0.3s;
}
.detail-view-label {
  position: absolute; top: 14px; left: 14px;
  background: rgba(0,0,0,0.45); color: rgba(255,255,255,0.85);
  font-size: 0.7rem; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase;
  padding: 4px 10px; border-radius: 4px; backdrop-filter: blur(4px);
}
.detail-thumbs {
  display: grid; grid-template-columns: repeat(4,1fr); gap: 10px; margin-top: 12px;
}
.detail-thumb {
  aspect-ratio: 4/3; border-radius: var(--radius-sm);
  border: 2px solid var(--light-border); overflow: hidden;
  cursor: pointer; position: relative;
  display: flex; align-items: center; justify-content: center;
  transition: border-color var(--transition);
}
.detail-thumb.active { border-color: var(--accent); }
.detail-thumb:hover { border-color: var(--accent); }
.detail-thumb-label {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: rgba(0,0,0,0.55); color: rgba(255,255,255,0.9);
  font-size: 0.6rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
  padding: 5px; text-align: center; backdrop-filter: blur(3px);
}
.detail-thumb svg { width: 70%; max-width: 80px; height: auto; pointer-events: none; }

/* Right: info panel */
.detail-info { display: flex; flex-direction: column; gap: 0; }
.detail-badges { display: flex; gap: 8px; margin-bottom: 14px; flex-wrap: wrap; }
.detail-brand-name {
  font-size: 0.72rem; font-weight: 700; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--accent); margin-bottom: 6px;
}
.detail-model-name {
  font-size: clamp(1.8rem, 3vw, 2.6rem); font-weight: 800;
  color: var(--text-heading); letter-spacing: -0.025em; line-height: 1.1;
  margin-bottom: 8px;
}
.detail-tagline { font-size: 0.9rem; color: var(--text-muted); margin-bottom: 24px; line-height: 1.6; }

.key-stats {
  display: grid; grid-template-columns: repeat(3,1fr);
  gap: 0; margin-bottom: 24px;
  border: 1.5px solid var(--light-border); border-radius: var(--radius);
  overflow: hidden;
}
.key-stat {
  padding: 16px 12px; text-align: center;
  border-right: 1px solid var(--light-border);
}
.key-stat:last-child { border-right: none; }
.key-stat strong { display: block; font-size: 1.1rem; font-weight: 800; color: var(--text-heading); line-height: 1; }
.key-stat span { font-size: 0.66rem; color: var(--text-muted); margin-top: 4px; display: block; letter-spacing: 0.04em; }

.detail-section-title {
  font-size: 0.68rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--text-muted); margin-bottom: 12px; margin-top: 20px;
}
.color-swatches { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 4px; }
.color-swatch {
  width: 28px; height: 28px; border-radius: 50%;
  border: 2.5px solid transparent; cursor: pointer;
  outline: 2px solid transparent; outline-offset: 2px;
  transition: outline-color var(--transition), transform var(--transition);
  box-shadow: inset 0 0 0 1px rgba(0,0,0,0.12);
}
.color-swatch.active { outline-color: var(--accent); transform: scale(1.15); }
.color-swatch:hover { transform: scale(1.1); }
.selected-color-name { font-size: 0.82rem; color: var(--text-body); margin-top: 6px; margin-bottom: 20px; }

.price-box {
  background: var(--light-2); border: 1.5px solid var(--light-border);
  border-radius: var(--radius); padding: 18px 20px; margin-bottom: 16px;
  display: flex; align-items: center; justify-content: space-between;
}
.price-box-label { font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-muted); }
.price-box-value { font-size: 1.15rem; font-weight: 800; color: var(--text-heading); }

.detail-cta { display: flex; flex-direction: column; gap: 10px; margin-bottom: 20px; }
.btn-detail-wa {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  padding: 14px 24px; background: #25d366; color: #fff;
  border-radius: var(--radius-sm); font-size: 0.92rem; font-weight: 700; border: none;
  font-family: var(--font); cursor: pointer;
  transition: background var(--transition), transform var(--transition);
}
.btn-detail-wa:hover { background: #1cb956; transform: translateY(-1px); }
.btn-detail-wa svg { width: 20px; height: 20px; fill: #fff; flex-shrink: 0; }
.btn-detail-quote {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  padding: 13px 24px; background: transparent; color: var(--text-heading);
  border-radius: var(--radius-sm); font-size: 0.92rem; font-weight: 600;
  border: 1.5px solid var(--light-border); font-family: var(--font); cursor: pointer;
  transition: all var(--transition);
}
.btn-detail-quote:hover { border-color: var(--accent); color: var(--accent); background: rgba(0,163,255,0.04); }

.trust-row {
  display: flex; gap: 16px; flex-wrap: wrap; padding-top: 16px;
  border-top: 1px solid var(--light-border);
}
.trust-item { display: flex; align-items: center; gap: 6px; font-size: 0.74rem; color: var(--text-muted); }
.trust-item i { color: var(--accent); }

/* Specs Section */
.specs-section {
  background: var(--light-2); border-top: 1px solid var(--light-border);
  padding: 64px 48px;
}
.specs-inner { max-width: 1200px; margin: 0 auto; }
.specs-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 24px; margin-top: 36px; }
.spec-group {
  background: var(--light); border: 1.5px solid var(--light-border);
  border-radius: var(--radius); overflow: hidden;
}
.spec-group-title {
  padding: 14px 20px; font-size: 0.72rem; font-weight: 700; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--text-heading);
  background: var(--light-3); border-bottom: 1px solid var(--light-border);
  display: flex; align-items: center; gap: 8px;
}
.spec-group-title i { color: var(--accent); }
.spec-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 11px 20px; border-bottom: 1px solid var(--light-border); gap: 16px;
}
.spec-row:last-child { border-bottom: none; }
.spec-key { font-size: 0.82rem; color: var(--text-muted); flex-shrink: 0; }
.spec-val { font-size: 0.85rem; font-weight: 600; color: var(--text-heading); text-align: right; }

/* Features */
.features-list {
  display: grid; grid-template-columns: repeat(2,1fr); gap: 10px; margin-top: 36px;
}
.feature-item {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 14px 16px; background: var(--light);
  border: 1.5px solid var(--light-border); border-radius: var(--radius-sm);
}
.feature-item i { color: var(--accent); font-size: 1rem; flex-shrink: 0; margin-top: 1px; }
.feature-item span { font-size: 0.84rem; color: var(--text-body); line-height: 1.55; }

/* Related Cars */
.related-section { padding: 64px 48px; background: var(--light); border-top: 1px solid var(--light-border); }
.related-inner { max-width: 1200px; margin: 0 auto; }
.related-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; margin-top: 28px; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1100px) {
  .services-grid { grid-template-columns: repeat(2,1fr); }
  .cars-grid { grid-template-columns: repeat(3,1fr); }
}
@media (max-width: 1024px) {
  .detail-main { grid-template-columns: 1fr; }
  .detail-gallery { position: static; }
  .specs-grid { grid-template-columns: 1fr; }
  .features-list { grid-template-columns: 1fr; }
  .related-grid { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 900px) {
  :root { --nav-h: 64px; }
  .navbar { padding: 0 20px; }
  .nav-links, .nav-cta, .lang-select { display: none; }
  .nav-burger { display: flex; }
  .nav-logo-img { height: auto; max-height: 36px; max-width: 58vw; }

  /* 子页 Hero 高度移动端缩小，减少背景图裁剪 */
  .cars-hero, .about-hero, .htb-hero, .news-hero, .faq-hero, .ct-hero {
    min-height: 220px;
  }

  .hero-inner { padding: 0 24px; }
  .cars-hero-inner { padding: 48px 24px; }
  .cars-hero-deco { font-size: clamp(6rem,22vw,10rem); }
  .ch-stats { gap: 24px; }
  .detail-breadcrumb { padding-left: 20px; padding-right: 20px; }
  .detail-main { padding: 24px 20px 48px; }
  .specs-section, .related-section { padding: 40px 20px; }
  .section, .section-sm { padding: 64px 24px; }
  .brands-section, .stats-section { padding: 48px 24px; }
  .services-section, .how-section { padding: 64px 24px; }
  .cta-banner, .footer { padding-left: 24px; padding-right: 24px; }

  .stats-grid { grid-template-columns: repeat(2,1fr); }
  .stat-item { border-right: none; border-bottom: 1px solid var(--light-border); }
  .stat-item:nth-child(odd) { border-right: 1px solid var(--light-border); }
  .stat-item:nth-child(3), .stat-item:nth-child(4) { border-bottom: none; }

  .steps-row { grid-template-columns: 1fr; gap: 24px; }
  .steps-row::before { display: none; }
  .step-item { flex-direction: row; text-align: left; align-items: flex-start; gap: 18px; }
  .step-num { flex-shrink: 0; }

  .footer-grid { grid-template-columns: 1fr; gap: 32px; }
  .filter-bar { padding: 14px 20px; }
  .cars-grid { grid-template-columns: repeat(2,1fr); }
  .cars-section { padding: 28px 20px 64px; }
}
@media (max-width: 600px) {
  .hero-title { font-size: 2.6rem; }
  .hero-btns { flex-direction: column; }
  .btn-primary, .btn-outline, .btn-wa, .btn-email { width: 100%; justify-content: center; }
  .services-grid { grid-template-columns: 1fr; }
  .cars-grid { grid-template-columns: 1fr; }
  .footer-bottom { flex-direction: column; text-align: center; }
  .form-row { grid-template-columns: 1fr; }
  /* 品牌区：3列网格，卡片缩小 */
  .brands-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
  }
  .brand-card { min-width: unset; width: 100%; padding: 10px 6px; gap: 6px; }
  .brand-logo-img { height: 24px; max-width: 56px; }
  .brand-logo-badge { height: 24px; font-size: 0.7rem; padding: 2px 6px; }
  .brand-name { font-size: 0.62rem; }
}

/* ============================================================
   ABOUT PAGE
   ============================================================ */

/* Hero */
.about-hero {
  min-height: 500px; background: var(--dark) center center / cover no-repeat;
  display: flex; align-items: center;
  position: relative; overflow: hidden; margin-top: var(--nav-h);
}
.about-hero-bg {
  position: absolute; inset: 0;
  background: linear-gradient(
    100deg,
    rgba(0,0,0,0.88) 0%,
    rgba(0,0,0,0.65) 50%,
    rgba(0,0,0,0.35) 80%,
    rgba(0,0,0,0.15) 100%
  );
}
.about-hero-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size: 64px 64px;
}
.about-hero-inner {
  max-width: 1200px; margin: 0 auto; padding: 64px 48px;
  display: grid; grid-template-columns: 1fr 400px; gap: 64px; align-items: center;
  position: relative; z-index: 1; width: 100%;
}
.about-hero-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(0,163,255,0.14); border: 1px solid rgba(0,163,255,0.3);
  color: var(--accent); font-size: 0.72rem; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase;
  padding: 6px 16px; border-radius: 100px; margin-bottom: 22px;
}
.about-hero-title {
  font-size: clamp(2.4rem, 5vw, 3.8rem); font-weight: 800;
  color: #fff; line-height: 1.1; letter-spacing: -0.03em; margin-bottom: 20px;
}
.about-hero-title span { color: var(--accent); }
.about-hero-sub {
  font-size: 1rem; color: rgba(255,255,255,0.62); line-height: 1.75; margin-bottom: 36px;
}
.about-hero-pills { display: flex; gap: 10px; flex-wrap: wrap; }
.about-hero-pill {
  display: inline-flex; align-items: center; gap: 7px;
  background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.12);
  color: rgba(255,255,255,0.8); font-size: 0.78rem; font-weight: 600;
  padding: 7px 14px; border-radius: 100px;
}
.about-hero-pill i { font-size: 0.9rem; color: var(--accent); }
.about-hero-visual {
  aspect-ratio: 5/4; border-radius: 20px; overflow: hidden;
  border: 1px solid rgba(0,163,255,0.18);
  position: relative;
}
.about-hero-visual-photo {
  width: 100%; height: 100%; object-fit: cover;
  position: absolute; inset: 0; display: block;
}
.about-hero-visual-badge {
  position: absolute; top: 20px; left: 20px; z-index: 2;
  background: rgba(0,163,255,0.18); border: 1px solid rgba(0,163,255,0.3);
  color: var(--accent); font-size: 0.65rem; font-weight: 700;
  letter-spacing: 0.08em; text-transform: uppercase;
  padding: 5px 12px; border-radius: 6px; backdrop-filter: blur(4px);
}

/* Company Intro */
.about-intro-wrap {
  padding: 88px 48px; max-width: 1200px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 400px; gap: 80px; align-items: center;
}
.about-intro-title {
  font-size: clamp(1.8rem, 3vw, 2.6rem); font-weight: 800;
  color: var(--text-heading); line-height: 1.2; letter-spacing: -0.02em; margin-bottom: 24px;
}
.about-intro-body { color: var(--text-body); line-height: 1.82; font-size: 0.95rem; }
.about-intro-body p + p { margin-top: 16px; }
.about-intro-body strong { color: var(--text-heading); font-weight: 700; }
.about-intro-highlights { display: flex; gap: 28px; margin-top: 32px; flex-wrap: wrap; }
.about-intro-hi {
  display: flex; align-items: center; gap: 8px;
  font-size: 0.84rem; font-weight: 600; color: var(--text-heading);
}
.about-intro-hi i { color: var(--accent); font-size: 1rem; }
.about-building {
  border-radius: var(--radius); overflow: hidden;
  border: 1.5px solid var(--light-border);
  aspect-ratio: 3/4; position: relative;
}
.about-building-photo {
  width: 100%; height: 100%; object-fit: cover;
  position: absolute; inset: 0; display: block;
}
.about-building-caption {
  position: absolute; bottom: 0; left: 0; right: 0; z-index: 2;
  background: rgba(0,0,0,0.7); backdrop-filter: blur(8px);
  padding: 14px 20px; text-align: center;
}
.about-building-caption strong {
  display: block; font-size: 0.78rem; font-weight: 700;
  letter-spacing: 0.08em; text-transform: uppercase; color: #fff; margin-bottom: 2px;
}
.about-building-caption span { font-size: 0.68rem; color: rgba(255,255,255,0.5); }

/* Dark stats strip */
.about-stats-strip { background: var(--dark); padding: 56px 48px; }
.about-stats-inner {
  max-width: 1200px; margin: 0 auto;
  display: grid; grid-template-columns: repeat(4,1fr);
}
.astat {
  text-align: center; padding: 16px 24px;
  border-right: 1px solid rgba(255,255,255,0.08);
}
.astat:last-child { border-right: none; }
.astat-num {
  font-size: clamp(2.2rem, 4vw, 3rem); font-weight: 800; color: #fff;
  letter-spacing: -0.03em; line-height: 1; margin-bottom: 8px;
}
.astat-num em { color: var(--accent); font-style: normal; }
.astat-lbl { font-size: 0.82rem; color: var(--dark-text); font-weight: 500; line-height: 1.4; }

/* Services */
.about-services { padding: 88px 48px; background: var(--light-2); }
.about-services-inner { max-width: 1200px; margin: 0 auto; }
.service-grid {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; margin-top: 52px;
}
.service-card {
  background: var(--light); border-radius: var(--radius);
  padding: 34px 28px; border: 1.5px solid var(--light-border);
  transition: border-color var(--transition), transform var(--transition), box-shadow var(--transition);
  position: relative; overflow: hidden;
}
.service-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--accent), var(--accent-dark));
  transform: scaleX(0); transform-origin: left; transition: transform var(--transition);
}
.service-card:hover { border-color: var(--accent); transform: translateY(-5px); box-shadow: 0 16px 40px rgba(0,163,255,0.1); }
.service-card:hover::before { transform: scaleX(1); }
.service-icon {
  width: 54px; height: 54px; border-radius: 14px;
  background: rgba(0,163,255,0.1); display: flex; align-items: center; justify-content: center;
  margin-bottom: 22px; transition: background var(--transition);
}
.service-card:hover .service-icon { background: rgba(0,163,255,0.18); }
.service-icon i { font-size: 1.5rem; color: var(--accent); }
.service-card h3 { font-size: 1rem; font-weight: 700; color: var(--text-heading); margin-bottom: 10px; }
.service-card p { font-size: 0.85rem; color: var(--text-muted); line-height: 1.72; }

/* Why Choose Us */
.about-why { padding: 88px 48px; background: var(--dark); }
.about-why-inner { max-width: 1200px; margin: 0 auto; }
.about-why-hd { text-align: center; margin-bottom: 60px; }
.about-why-hd .sec-title { color: #fff; }
.about-why-hd .sec-sub { color: var(--dark-text); }
.why-grid {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 2px;
  border-radius: var(--radius); overflow: hidden;
}
.why-card {
  background: rgba(255,255,255,0.03);
  padding: 40px 32px; border: 1px solid rgba(255,255,255,0.06);
  transition: background var(--transition), border-color var(--transition);
  position: relative;
}
.why-card:hover { background: rgba(0,163,255,0.07); border-color: rgba(0,163,255,0.22); }
.why-idx {
  font-size: 0.6rem; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--accent); margin-bottom: 18px;
  display: flex; align-items: center; gap: 10px;
}
.why-idx::after { content: ''; flex: 1; height: 1px; background: rgba(0,163,255,0.25); }
.why-card i { font-size: 1.8rem; color: rgba(0,163,255,0.4); margin-bottom: 16px; display: block; }
.why-card h3 { font-size: 1.02rem; font-weight: 700; color: #fff; margin-bottom: 12px; line-height: 1.3; }
.why-card p { font-size: 0.83rem; color: var(--dark-text); line-height: 1.75; }

/* Certifications */
.about-certs { padding: 80px 48px; background: var(--light); }
.about-certs-inner { max-width: 1200px; margin: 0 auto; }
.cert-strip {
  display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; margin-top: 52px;
}
.cert-card {
  border: 1.5px solid var(--light-border); border-radius: var(--radius);
  padding: 32px 24px; text-align: center;
  transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
}
.cert-card:hover {
  border-color: var(--accent);
  box-shadow: 0 8px 28px rgba(0,163,255,0.1);
  transform: translateY(-3px);
}
.cert-icon {
  width: 60px; height: 60px; border-radius: 50%;
  background: linear-gradient(135deg, rgba(0,163,255,0.15), rgba(0,163,255,0.04));
  border: 1px solid rgba(0,163,255,0.15);
  display: flex; align-items: center; justify-content: center; margin: 0 auto 18px;
}
.cert-icon i { font-size: 1.65rem; color: var(--accent); }
.cert-card h4 { font-size: 0.84rem; font-weight: 700; color: var(--text-heading); margin-bottom: 8px; }
.cert-card p { font-size: 0.76rem; color: var(--text-muted); line-height: 1.65; }
.cert-badge {
  display: inline-block; margin-top: 12px;
  background: rgba(0,163,255,0.08); color: var(--accent);
  font-size: 0.65rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
  padding: 4px 10px; border-radius: 4px;
}

/* Distribution Centers */
.about-depots { padding: 88px 48px; background: var(--light-2); }
.about-depots-inner { max-width: 1200px; margin: 0 auto; }
.depot-grid {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; margin-top: 52px;
}
.depot-item {
  border-radius: var(--radius); overflow: hidden;
  border: 1.5px solid var(--light-border);
  transition: transform var(--transition), box-shadow var(--transition);
}
.depot-item:hover { transform: translateY(-5px); box-shadow: 0 20px 48px rgba(0,0,0,0.12); }
.depot-photo {
  width: 100%;
  height: 220px;
  position: relative;
  overflow: hidden;
  background: #f0f4f8;
}
.depot-photo-img {
  position: absolute; inset: 0;
  width: 100%; height: 100%; object-fit: contain;
  display: block;
}
.depot-photo-num {
  position: absolute; top: 14px; right: 14px; z-index: 2;
  background: rgba(0,163,255,0.18); border: 1px solid rgba(0,163,255,0.3);
  color: var(--accent); font-size: 0.62rem; font-weight: 700;
  padding: 3px 9px; border-radius: 4px;
}
.depot-info { background: var(--light); padding: 20px 22px; }
.depot-info h4 { font-size: 0.9rem; font-weight: 700; color: var(--text-heading); margin-bottom: 5px; }
.depot-info p { font-size: 0.78rem; color: var(--text-muted); line-height: 1.6; }

/* About responsive */
@media (max-width: 1100px) {
  .about-hero-inner { grid-template-columns: 1fr; }
  .about-hero-visual { display: none; }
  .about-intro-wrap { grid-template-columns: 1fr; }
  .about-building { aspect-ratio: 16/9; }
  .about-stats-inner { grid-template-columns: repeat(2,1fr); }
  .astat:nth-child(2) { border-right: none; }
  .astat:nth-child(3) { border-top: 1px solid rgba(255,255,255,0.08); }
  .astat:nth-child(4) { border-top: 1px solid rgba(255,255,255,0.08); border-right: none; }
  .service-grid { grid-template-columns: repeat(2,1fr); }
  .why-grid { grid-template-columns: repeat(2,1fr); }
  .cert-strip { grid-template-columns: repeat(2,1fr); }
  .depot-grid { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 768px) {
  .about-hero-inner, .about-intro-wrap { padding: 44px 20px; }
  .about-services, .about-why, .about-certs, .about-depots, .about-stats-strip { padding: 56px 20px; }
  .service-grid, .cert-strip { grid-template-columns: 1fr; }
  .why-grid { grid-template-columns: 1fr; }
  .depot-grid { grid-template-columns: 1fr; }
  .about-stats-inner { grid-template-columns: repeat(2,1fr); }
}

/* ============================================================
   HOW TO BUY PAGE
   ============================================================ */

/* Hero */
.htb-hero {
  min-height: 500px; background: var(--dark) center center / cover no-repeat;
  display: flex; align-items: center;
  position: relative; overflow: hidden; margin-top: var(--nav-h);
}
.htb-hero-bg {
  position: absolute; inset: 0;
  background: linear-gradient(
    100deg,
    rgba(0,0,0,0.90) 0%,
    rgba(0,0,0,0.68) 50%,
    rgba(0,0,0,0.38) 80%,
    rgba(0,0,0,0.18) 100%
  );
}
.htb-hero-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size: 64px 64px;
}
.htb-hero-inner {
  max-width: 1200px; margin: 0 auto; padding: 64px 48px;
  position: relative; z-index: 1; width: 100%;
  display: grid; grid-template-columns: 1fr 360px; gap: 60px; align-items: center;
}
.htb-hero-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(0,163,255,0.14); border: 1px solid rgba(0,163,255,0.3);
  color: var(--accent); font-size: 0.72rem; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase;
  padding: 6px 16px; border-radius: 100px; margin-bottom: 22px;
}
.htb-hero-title {
  font-size: clamp(2.2rem, 4.5vw, 3.6rem); font-weight: 800;
  color: #fff; line-height: 1.1; letter-spacing: -0.03em; margin-bottom: 18px;
}
.htb-hero-title span { color: var(--accent); }
.htb-hero-sub {
  font-size: 1rem; color: rgba(255,255,255,0.6); line-height: 1.72; margin-bottom: 32px;
}
.htb-hero-quick {
  display: flex; flex-direction: column; gap: 10px;
}
.htb-hero-q {
  display: flex; align-items: center; gap: 12px;
  background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.1);
  border-radius: 10px; padding: 12px 16px;
}
.htb-hero-q i { font-size: 1.2rem; color: var(--accent); flex-shrink: 0; }
.htb-hero-q span { font-size: 0.84rem; color: rgba(255,255,255,0.8); font-weight: 500; }

/* 5-Step Process */
.htb-process { padding: 88px 48px; background: var(--light); }
.htb-process-inner { max-width: 1200px; margin: 0 auto; }
.process-steps {
  margin-top: 64px;
  display: flex; flex-direction: column; gap: 0;
}
.process-step {
  display: grid; grid-template-columns: 80px 1fr; gap: 0;
  position: relative;
}
.process-step:not(:last-child)::after {
  content: '';
  position: absolute; left: 39px; top: 80px; bottom: 0;
  width: 2px;
  background: linear-gradient(to bottom, var(--accent) 0%, var(--light-border) 100%);
}
.step-left {
  display: flex; flex-direction: column; align-items: center;
  padding-top: 4px;
}
.step-circle {
  width: 56px; height: 56px; border-radius: 50%;
  background: var(--accent); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.15rem; font-weight: 800; flex-shrink: 0;
  box-shadow: 0 0 0 6px rgba(0,163,255,0.12);
  position: relative; z-index: 1;
}
.step-body { padding: 0 0 56px 32px; }
.step-tag {
  font-size: 0.65rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--accent); margin-bottom: 8px;
}
.step-body h3 {
  font-size: 1.2rem; font-weight: 800; color: var(--text-heading);
  margin-bottom: 12px; line-height: 1.25;
}
.step-body p { font-size: 0.9rem; color: var(--text-body); line-height: 1.78; max-width: 680px; }
.step-meta {
  display: flex; gap: 16px; flex-wrap: wrap; margin-top: 16px;
}
.step-chip {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--light-2); border: 1px solid var(--light-border);
  border-radius: 100px; padding: 5px 13px;
  font-size: 0.78rem; font-weight: 600; color: var(--text-muted);
}
.step-chip i { font-size: 0.85rem; color: var(--accent); }
.step-chip.highlight {
  background: rgba(0,163,255,0.08); border-color: rgba(0,163,255,0.25);
  color: var(--accent);
}

/* Payment Methods */
.htb-payment { padding: 88px 48px; background: var(--dark); }
.htb-payment-inner { max-width: 1200px; margin: 0 auto; }
.htb-payment-hd { text-align: center; margin-bottom: 56px; }
.htb-payment-hd .sec-title { color: #fff; }
.htb-payment-hd .sec-sub { color: var(--dark-text); }
.payment-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; }
.payment-card {
  background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.09);
  border-radius: var(--radius); padding: 36px 28px;
  transition: background var(--transition), border-color var(--transition), transform var(--transition);
  display: flex; flex-direction: column;
}
.payment-card:hover {
  background: rgba(0,163,255,0.07); border-color: rgba(0,163,255,0.25);
  transform: translateY(-4px);
}
.payment-card-icon {
  width: 56px; height: 56px; border-radius: 14px;
  background: rgba(0,163,255,0.14); border: 1px solid rgba(0,163,255,0.2);
  display: flex; align-items: center; justify-content: center; margin-bottom: 22px;
}
.payment-card-icon i { font-size: 1.6rem; color: var(--accent); }
.payment-card h3 { font-size: 1rem; font-weight: 700; color: #fff; margin-bottom: 10px; }
.payment-card p { font-size: 0.84rem; color: var(--dark-text); line-height: 1.72; flex: 1; }
.payment-card-tag {
  display: inline-block; margin-top: 20px;
  background: rgba(0,163,255,0.14); color: var(--accent);
  font-size: 0.65rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
  padding: 4px 10px; border-radius: 4px; align-self: flex-start;
}
.payment-split {
  margin-top: 48px; padding: 32px 36px;
  background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.09);
  border-radius: var(--radius);
  display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center;
}
.payment-split h4 { font-size: 0.92rem; font-weight: 700; color: #fff; margin-bottom: 16px; }
.split-bars { display: flex; flex-direction: column; gap: 12px; }
.split-bar-row { display: flex; align-items: center; gap: 14px; }
.split-bar-lbl { font-size: 0.78rem; color: var(--dark-text); width: 100px; flex-shrink: 0; }
.split-bar-track {
  flex: 1; height: 8px; background: rgba(255,255,255,0.08); border-radius: 4px; overflow: hidden;
}
.split-bar-fill { height: 100%; border-radius: 4px; background: var(--accent); }
.split-bar-pct { font-size: 0.78rem; font-weight: 700; color: #fff; width: 36px; text-align: right; flex-shrink: 0; }
.payment-note { font-size: 0.82rem; color: var(--dark-text); line-height: 1.7; }
.payment-note strong { color: rgba(255,255,255,0.8); }

/* Shipping & Logistics */
.htb-shipping { padding: 88px 48px; background: var(--light-2); }
.htb-shipping-inner { max-width: 1200px; margin: 0 auto; }
.shipping-compare {
  display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-top: 52px;
}
.ship-card {
  background: var(--light); border-radius: var(--radius);
  border: 1.5px solid var(--light-border); overflow: hidden;
  transition: border-color var(--transition), box-shadow var(--transition);
}
.ship-card:hover { border-color: var(--accent); box-shadow: 0 12px 32px rgba(0,163,255,0.08); }
.ship-card-head {
  background: linear-gradient(135deg, #0c1e36 0%, #091528 100%);
  padding: 28px 28px 24px;
  display: flex; align-items: center; gap: 16px;
}
.ship-card-head i { font-size: 2rem; color: var(--accent); flex-shrink: 0; }
.ship-card-head h3 { font-size: 1.05rem; font-weight: 800; color: #fff; margin-bottom: 4px; }
.ship-card-head p { font-size: 0.78rem; color: rgba(255,255,255,0.5); }
.ship-card-body { padding: 24px 28px; }
.ship-pros { display: flex; flex-direction: column; gap: 10px; margin-bottom: 20px; }
.ship-pro {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 0.85rem; color: var(--text-body); line-height: 1.55;
}
.ship-pro i { font-size: 0.9rem; color: var(--accent); flex-shrink: 0; margin-top: 2px; }
.ship-note {
  font-size: 0.78rem; color: var(--text-muted);
  background: var(--light-2); padding: 10px 14px; border-radius: 8px;
}
.terms-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 24px;
}
.term-card {
  background: var(--light); border: 1.5px solid var(--light-border);
  border-radius: var(--radius); padding: 24px 22px;
  transition: border-color var(--transition);
}
.term-card:hover { border-color: var(--accent); }
.term-card h4 {
  display: flex; align-items: center; gap: 8px;
  font-size: 0.92rem; font-weight: 700; color: var(--text-heading); margin-bottom: 10px;
}
.term-card h4 i { color: var(--accent); }
.term-card p { font-size: 0.82rem; color: var(--text-muted); line-height: 1.68; }
.transit-table-wrap { margin-top: 48px; overflow-x: auto; }
.transit-table {
  width: 100%; border-collapse: collapse;
  font-size: 0.86rem;
}
.transit-table th {
  background: var(--dark); color: rgba(255,255,255,0.8);
  padding: 14px 20px; text-align: left;
  font-size: 0.72rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase;
}
.transit-table th:first-child { border-radius: 10px 0 0 10px; }
.transit-table th:last-child { border-radius: 0 10px 10px 0; }
.transit-table td { padding: 14px 20px; border-bottom: 1px solid var(--light-border); }
.transit-table tr:last-child td { border-bottom: none; }
.transit-table tr:hover td { background: rgba(0,163,255,0.04); }
.transit-table td:first-child { font-weight: 600; color: var(--text-heading); }
.transit-badge {
  display: inline-block; background: rgba(0,163,255,0.1); color: var(--accent);
  font-size: 0.72rem; font-weight: 700; padding: 3px 9px; border-radius: 4px;
}

/* Documents Included */
.htb-docs { padding: 88px 48px; background: var(--light); }
.htb-docs-inner { max-width: 1200px; margin: 0 auto; }
.docs-grid {
  display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; margin-top: 52px;
}
.doc-item {
  background: var(--light-2); border: 1.5px solid var(--light-border);
  border-radius: var(--radius); padding: 24px 20px; text-align: center;
  transition: border-color var(--transition), transform var(--transition), box-shadow var(--transition);
}
.doc-item:hover {
  border-color: var(--accent); transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0,163,255,0.09);
}
.doc-item i { font-size: 1.8rem; color: var(--accent); display: block; margin-bottom: 12px; }
.doc-item h4 { font-size: 0.84rem; font-weight: 700; color: var(--text-heading); margin-bottom: 6px; }
.doc-item p { font-size: 0.74rem; color: var(--text-muted); line-height: 1.55; }

/* Order Journey Timeline */
.htb-timeline { padding: 88px 48px; background: var(--dark); }
.htb-timeline-inner { max-width: 1000px; margin: 0 auto; }
.htb-timeline-hd { text-align: center; margin-bottom: 60px; }
.htb-timeline-hd .sec-title { color: #fff; }
.htb-timeline-hd .sec-sub { color: var(--dark-text); }
.ot-track { position: relative; display: flex; flex-direction: column; gap: 0; }
.ot-track::before {
  content: '';
  position: absolute; left: 23px; top: 24px; bottom: 24px; width: 2px;
  background: linear-gradient(to bottom, var(--accent) 0%, rgba(0,163,255,0.15) 100%);
}
.ot-item {
  display: grid; grid-template-columns: 48px 1fr; gap: 24px;
  padding-bottom: 40px; position: relative;
}
.ot-item:last-child { padding-bottom: 0; }
.ot-dot {
  width: 48px; height: 48px; border-radius: 50%;
  background: var(--dark-2); border: 2px solid var(--accent);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; position: relative; z-index: 1;
}
.ot-dot i { font-size: 1.1rem; color: var(--accent); }
.ot-content { padding-top: 10px; }
.ot-day {
  font-size: 0.65rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--accent); margin-bottom: 6px;
}
.ot-content h4 { font-size: 0.96rem; font-weight: 700; color: #fff; margin-bottom: 6px; }
.ot-content p { font-size: 0.83rem; color: var(--dark-text); line-height: 1.68; }

/* How to Buy responsive */
@media (max-width: 1100px) {
  .htb-hero-inner { grid-template-columns: 1fr; }
  .htb-hero-quick { display: none; }
  .payment-grid { grid-template-columns: 1fr; }
  .payment-split { grid-template-columns: 1fr; gap: 28px; }
  .shipping-compare { grid-template-columns: 1fr; }
  .terms-row { grid-template-columns: 1fr; }
  .docs-grid { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 768px) {
  .htb-hero-inner, .htb-process-inner,
  .htb-payment-inner, .htb-shipping-inner,
  .htb-docs-inner, .htb-timeline-inner { padding-left: 20px; padding-right: 20px; }
  .htb-process, .htb-payment, .htb-shipping, .htb-docs, .htb-timeline { padding: 56px 20px; }
  .docs-grid { grid-template-columns: repeat(2,1fr); }
  .process-step { grid-template-columns: 56px 1fr; }
}
@media (max-width: 480px) {
  .docs-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   NEWS DETAIL PAGE
   ============================================================ */

/* Header */
.nd-header {
  background: var(--dark); padding-top: var(--nav-h);
  position: relative; overflow: hidden;
}
.nd-header-bg {
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 60% 80% at 70% 60%, rgba(0,163,255,0.1) 0%, transparent 65%);
}
.nd-header-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.022) 1px, transparent 1px);
  background-size: 60px 60px;
}
.nd-header-inner {
  max-width: 1200px; margin: 0 auto; padding: 40px 48px 52px;
  position: relative; z-index: 1;
}
.nd-breadcrumb {
  display: flex; align-items: center; gap: 8px; margin-bottom: 24px;
  font-size: 0.76rem; color: rgba(255,255,255,0.4);
}
.nd-breadcrumb a { color: rgba(255,255,255,0.4); transition: color var(--transition); }
.nd-breadcrumb a:hover { color: var(--accent); }
.nd-breadcrumb i { font-size: 0.7rem; }
.nd-cat-badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 0.68rem; font-weight: 700; letter-spacing: 0.09em; text-transform: uppercase;
  padding: 5px 13px; border-radius: 5px; margin-bottom: 18px;
}
.nd-title {
  font-size: clamp(1.5rem, 3.5vw, 2.6rem); font-weight: 800;
  color: #fff; line-height: 1.18; letter-spacing: -0.025em;
  max-width: 820px; margin-bottom: 22px;
}
.nd-meta {
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
  font-size: 0.8rem; color: rgba(255,255,255,0.45);
}
.nd-meta i { font-size: 0.85rem; }
.nd-meta span { display: flex; align-items: center; gap: 6px; }

/* Body */
.nd-body {
  max-width: 1200px; margin: 0 auto; padding: 52px 48px 80px;
  display: grid; grid-template-columns: 1fr 320px; gap: 56px; align-items: start;
}

/* Article */
.nd-article-img {
  width: 100%; aspect-ratio: 16/9; border-radius: var(--radius);
  overflow: hidden; border: 1.5px solid var(--light-border);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  margin-bottom: 36px; position: relative;
}
.nd-article-img i { font-size: 5rem; opacity: 0.22; position: relative; z-index: 1; }
.nd-article-img .img-label {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: rgba(0,0,0,0.6); backdrop-filter: blur(6px);
  padding: 10px 16px; text-align: center;
  font-size: 0.65rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase;
  color: rgba(255,255,255,0.4);
}

/* Prose */
.nd-prose { font-size: 0.96rem; color: var(--text-body); line-height: 1.82; }
.nd-prose p { margin-bottom: 20px; }
.nd-prose p:last-child { margin-bottom: 0; }
.nd-prose h2 {
  font-size: 1.25rem; font-weight: 800; color: var(--text-heading);
  letter-spacing: -0.01em; margin: 36px 0 14px; line-height: 1.25;
}
.nd-prose h3 {
  font-size: 1.05rem; font-weight: 700; color: var(--text-heading);
  margin: 28px 0 10px;
}
.nd-prose strong { color: var(--text-heading); font-weight: 700; }
.nd-prose a { color: var(--accent); text-decoration: underline; text-underline-offset: 3px; }
.nd-blockquote {
  border-left: 3px solid var(--accent); margin: 28px 0;
  padding: 18px 24px; background: rgba(0,163,255,0.05);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}
.nd-blockquote p { font-size: 1rem; font-style: italic; color: var(--text-heading); margin: 0; line-height: 1.7; }
.nd-blockquote cite { font-size: 0.76rem; color: var(--text-muted); font-style: normal; margin-top: 8px; display: block; }
.nd-stat-row {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(140px,1fr)); gap: 16px; margin: 28px 0;
}
.nd-stat-box {
  background: var(--light-2); border: 1.5px solid var(--light-border);
  border-radius: var(--radius-sm); padding: 20px 16px; text-align: center;
}
.nd-stat-box strong { display: block; font-size: 1.7rem; font-weight: 800; color: var(--accent); letter-spacing: -0.02em; }
.nd-stat-box span { font-size: 0.75rem; color: var(--text-muted); font-weight: 500; }
.nd-tag-row { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 32px; padding-top: 24px; border-top: 1px solid var(--light-border); }
.nd-tag {
  background: var(--light-2); border: 1px solid var(--light-border);
  border-radius: 100px; padding: 4px 12px;
  font-size: 0.75rem; color: var(--text-muted); font-weight: 600;
}

/* Sidebar */
.nd-sidebar {
  position: sticky; top: calc(var(--nav-h) + 20px);
  display: flex; flex-direction: column; gap: 20px;
}
.nd-side-card {
  border: 1.5px solid var(--light-border); border-radius: var(--radius);
  overflow: hidden;
}
.nd-side-card-head {
  background: var(--dark); padding: 16px 20px;
  font-size: 0.72rem; font-weight: 700; letter-spacing: 0.09em; text-transform: uppercase;
  color: rgba(255,255,255,0.6); display: flex; align-items: center; gap: 8px;
}
.nd-side-card-head i { color: var(--accent); }
.nd-side-card-body { padding: 16px 20px; }
.nd-related-item {
  display: flex; gap: 12px; align-items: flex-start;
  padding: 12px 0; border-bottom: 1px solid var(--light-border);
  transition: opacity var(--transition);
}
.nd-related-item:last-child { border-bottom: none; padding-bottom: 0; }
.nd-related-item:hover { opacity: 0.75; }
.nd-related-thumb {
  width: 52px; height: 40px; border-radius: 6px; overflow: hidden;
  flex-shrink: 0; display: flex; align-items: center; justify-content: center;
}
.nd-related-thumb i { font-size: 1rem; opacity: 0.5; }
.nd-related-txt h4 {
  font-size: 0.78rem; font-weight: 700; color: var(--text-heading);
  line-height: 1.35; margin-bottom: 3px;
}
.nd-related-txt span { font-size: 0.68rem; color: var(--text-muted); }
.nd-cta-side {
  background: linear-gradient(145deg, #041624 0%, #07233a 100%);
  border: 1px solid rgba(0,163,255,0.2); border-radius: var(--radius);
  padding: 24px 20px; text-align: center;
}
.nd-cta-side i { font-size: 2rem; color: var(--accent); display: block; margin-bottom: 12px; }
.nd-cta-side h4 { font-size: 0.9rem; font-weight: 700; color: #fff; margin-bottom: 8px; }
.nd-cta-side p { font-size: 0.78rem; color: rgba(255,255,255,0.5); line-height: 1.6; margin-bottom: 18px; }
.nd-cta-side a {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  background: #25d366; color: #fff; font-size: 0.84rem; font-weight: 700;
  padding: 11px 20px; border-radius: 100px;
  transition: background var(--transition);
}
.nd-cta-side a:hover { background: #20b858; }
.nd-cta-side a svg { width: 17px; height: 17px; fill: currentColor; }

/* News detail responsive */
@media (max-width: 1000px) {
  .nd-body { grid-template-columns: 1fr; }
  .nd-sidebar { position: static; }
  .nd-stat-row { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 768px) {
  .nd-header-inner, .nd-body { padding-left: 20px; padding-right: 20px; }
  .nd-body { padding-top: 36px; }
  .nd-stat-row { grid-template-columns: 1fr; }
}

/* ============================================================
   NEWS PAGE
   ============================================================ */

/* Hero */
.news-hero {
  min-height: 500px; background: var(--dark) center center / cover no-repeat;
  display: flex; align-items: center;
  position: relative; overflow: hidden; margin-top: var(--nav-h);
}
.news-hero-bg {
  position: absolute; inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,0.72) 0%,
    rgba(0,0,0,0.55) 50%,
    rgba(0,0,0,0.72) 100%
  );
}
.news-hero-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size: 64px 64px;
}
.news-hero-inner {
  max-width: 1200px; margin: 0 auto; padding: 56px 48px;
  position: relative; z-index: 1; width: 100%;
}
.news-hero-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(0,163,255,0.14); border: 1px solid rgba(0,163,255,0.3);
  color: var(--accent); font-size: 0.72rem; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase;
  padding: 6px 16px; border-radius: 100px; margin-bottom: 20px;
}
.news-hero-title {
  font-size: clamp(2rem, 4.5vw, 3.4rem); font-weight: 800;
  color: #fff; line-height: 1.1; letter-spacing: -0.03em; margin-bottom: 16px;
}
.news-hero-title span { color: var(--accent); }
.news-hero-sub { font-size: 0.96rem; color: rgba(255,255,255,0.58); line-height: 1.7; max-width: 600px; }

/* Filter bar */
.news-filters-wrap { background: var(--light); border-bottom: 1px solid var(--light-border); }
.news-filters {
  max-width: 1200px; margin: 0 auto; padding: 0 48px;
  display: flex; align-items: center; gap: 8px; overflow-x: auto;
  scrollbar-width: none;
}
.news-filters::-webkit-scrollbar { display: none; }
.news-filter-btn {
  flex-shrink: 0; padding: 16px 18px;
  font-size: 0.82rem; font-weight: 600; color: var(--text-muted);
  background: none; border: none; border-bottom: 2px solid transparent;
  cursor: pointer; transition: color var(--transition), border-color var(--transition);
  white-space: nowrap;
}
.news-filter-btn:hover { color: var(--text-heading); }
.news-filter-btn.active { color: var(--accent); border-bottom-color: var(--accent); }

/* Body wrap */
.news-body { max-width: 1200px; margin: 0 auto; padding: 56px 48px 80px; }

/* Featured article */
.news-featured {
  display: grid; grid-template-columns: 1fr 420px; gap: 0;
  border-radius: var(--radius); overflow: hidden;
  border: 1.5px solid var(--light-border); margin-bottom: 52px;
  transition: box-shadow var(--transition);
}
.news-featured:hover { box-shadow: 0 16px 48px rgba(0,0,0,0.1); }
.news-featured-img {
  position: relative; min-height: 380px;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  overflow: hidden;
}
.news-featured-img .news-img-inner { position: relative; z-index: 1; text-align: center; }
.news-featured-img .news-img-inner i { font-size: 5rem; opacity: 0.28; display: block; margin-bottom: 10px; }
.news-featured-img .news-img-inner span {
  font-size: 0.6rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; opacity: 0.35;
}
.news-feat-cat {
  position: absolute; top: 20px; left: 20px; z-index: 2;
  font-size: 0.65rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
  padding: 5px 12px; border-radius: 5px;
}
.news-feat-label {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: rgba(0,0,0,0.6); backdrop-filter: blur(6px);
  padding: 10px 20px;
  font-size: 0.65rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
  color: rgba(255,255,255,0.5); z-index: 2;
}
.news-featured-content { background: var(--light); padding: 40px 36px; display: flex; flex-direction: column; }
.news-featured-content .news-feat-cat { position: static; align-self: flex-start; margin-bottom: 16px; }
.news-featured-content h2 {
  font-size: clamp(1.15rem, 2vw, 1.5rem); font-weight: 800; color: var(--text-heading);
  line-height: 1.3; margin-bottom: 14px; letter-spacing: -0.01em;
}
.news-featured-content .news-meta {
  display: flex; align-items: center; gap: 12px;
  font-size: 0.76rem; color: var(--text-muted); margin-bottom: 16px; flex-wrap: wrap;
}
.news-featured-content .news-meta i { font-size: 0.85rem; }
.news-featured-content p { font-size: 0.88rem; color: var(--text-body); line-height: 1.78; flex: 1; }
.news-read-more {
  display: inline-flex; align-items: center; gap: 6px; margin-top: 24px;
  font-size: 0.84rem; font-weight: 700; color: var(--accent);
  transition: gap var(--transition);
}
.news-read-more:hover { gap: 10px; }
.news-read-more i { font-size: 0.9rem; }

/* Section heading row */
.news-section-hd {
  display: flex; align-items: center; justify-content: space-between; margin-bottom: 28px;
}
.news-section-hd h3 { font-size: 1rem; font-weight: 700; color: var(--text-heading); }
.news-count { font-size: 0.78rem; color: var(--text-muted); }

/* Grid */
.news-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }

/* Card */
.news-card {
  border-radius: var(--radius); overflow: hidden;
  border: 1.5px solid var(--light-border); background: var(--light);
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
  display: flex; flex-direction: column;
}
.news-card:hover { transform: translateY(-5px); box-shadow: 0 16px 40px rgba(0,0,0,0.1); border-color: rgba(0,163,255,0.3); }
.news-card-img {
  aspect-ratio: 16/9; position: relative;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  overflow: hidden; flex-shrink: 0;
}
.news-card-img .news-img-inner { position: relative; z-index: 1; text-align: center; }
.news-card-img .news-img-inner i { font-size: 2.8rem; opacity: 0.28; display: block; margin-bottom: 6px; }
.news-card-img .news-img-inner span { font-size: 0.55rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; opacity: 0.3; }
.news-card-img .news-feat-cat { top: 14px; left: 14px; }
.news-card-body { padding: 22px 22px 24px; display: flex; flex-direction: column; flex: 1; }
.news-card-meta {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  font-size: 0.72rem; color: var(--text-muted); margin-bottom: 10px;
}
.news-card-meta i { font-size: 0.78rem; }
.news-card-title {
  font-size: 0.96rem; font-weight: 700; color: var(--text-heading);
  line-height: 1.4; margin-bottom: 10px; letter-spacing: -0.005em;
}
.news-card-excerpt { font-size: 0.82rem; color: var(--text-muted); line-height: 1.68; flex: 1; }
.news-card-footer {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: 18px; padding-top: 14px; border-top: 1px solid var(--light-border);
}
.news-card-footer .news-read-more { margin-top: 0; font-size: 0.8rem; }
.news-read-time { font-size: 0.72rem; color: var(--text-muted); display: flex; align-items: center; gap: 5px; }

/* Category badge colours */
.cat-market   { background: rgba(0,163,255,0.1);  color: #0082cc; }
.cat-brand    { background: rgba(139,92,246,0.1);  color: #7c3aed; }
.cat-logistics{ background: rgba(245,158,11,0.1);  color: #d97706; }
.cat-reg      { background: rgba(16,185,129,0.1);  color: #059669; }
.cat-industry { background: rgba(239,68,68,0.1);   color: #dc2626; }
.cat-company  { background: rgba(0,163,255,0.15);  color: var(--accent); }

/* Load more */
.news-load-more-wrap { text-align: center; margin-top: 48px; }
.news-load-more {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 13px 32px; border-radius: 100px;
  border: 1.5px solid var(--light-border); background: var(--light);
  font-size: 0.88rem; font-weight: 600; color: var(--text-heading);
  cursor: pointer; transition: border-color var(--transition), color var(--transition), background var(--transition);
}
.news-load-more:hover { border-color: var(--accent); color: var(--accent); background: rgba(0,163,255,0.04); }
.news-load-more i { font-size: 1rem; }

/* CMS hint banner */
.news-cms-note {
  background: rgba(0,163,255,0.06); border: 1px solid rgba(0,163,255,0.2);
  border-radius: var(--radius-sm); padding: 12px 18px;
  display: flex; align-items: center; gap: 10px;
  font-size: 0.78rem; color: var(--text-muted); margin-bottom: 32px;
}
.news-cms-note i { color: var(--accent); flex-shrink: 0; }

/* News responsive */
@media (max-width: 1100px) {
  .news-featured { grid-template-columns: 1fr; }
  .news-featured-img { min-height: 260px; }
  .news-grid { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 768px) {
  .news-hero-inner, .news-body { padding-left: 20px; padding-right: 20px; }
  .news-body { padding-top: 36px; padding-bottom: 56px; }
  .news-filters { padding: 0 20px; }
  .news-grid { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .news-section-hd { flex-direction: column; align-items: flex-start; gap: 6px; }
}

/* ============================================================
   FAQ PAGE
   ============================================================ */

/* Hero */
.faq-hero {
  min-height: 500px; background: var(--dark) center center / cover no-repeat;
  display: flex; align-items: center;
  position: relative; overflow: hidden; margin-top: var(--nav-h);
}
.faq-hero-bg {
  position: absolute; inset: 0;
  background: linear-gradient(
    100deg,
    rgba(0,0,0,0.88) 0%,
    rgba(0,0,0,0.65) 55%,
    rgba(0,0,0,0.35) 85%,
    rgba(0,0,0,0.15) 100%
  );
}
.faq-hero-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.022) 1px, transparent 1px);
  background-size: 64px 64px;
}
.faq-hero-inner {
  max-width: 1200px; margin: 0 auto; padding: 56px 48px;
  position: relative; z-index: 1; width: 100%;
  display: grid; grid-template-columns: 1fr auto; gap: 48px; align-items: center;
}
.faq-hero-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(0,163,255,0.14); border: 1px solid rgba(0,163,255,0.3);
  color: var(--accent); font-size: 0.72rem; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase;
  padding: 6px 16px; border-radius: 100px; margin-bottom: 20px;
}
.faq-hero-title {
  font-size: clamp(2rem, 4vw, 3.2rem); font-weight: 800;
  color: #fff; line-height: 1.1; letter-spacing: -0.03em; margin-bottom: 14px;
}
.faq-hero-title span { color: var(--accent); }
.faq-hero-sub { font-size: 0.96rem; color: rgba(255,255,255,0.58); line-height: 1.7; max-width: 560px; }
.faq-hero-count {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  background: rgba(0,163,255,0.1); border: 1px solid rgba(0,163,255,0.2);
  border-radius: 16px; padding: 24px 32px; flex-shrink: 0;
}
.faq-hero-count strong { font-size: 3rem; font-weight: 800; color: var(--accent); line-height: 1; }
.faq-hero-count span { font-size: 0.72rem; color: rgba(255,255,255,0.5); font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; }

/* Category tabs */
.faq-tabs-wrap {
  background: var(--light); border-bottom: 1px solid var(--light-border);
  position: sticky; top: var(--nav-h); z-index: 90;
}
.faq-tabs {
  max-width: 1200px; margin: 0 auto; padding: 0 48px;
  display: flex; align-items: center; gap: 4px; overflow-x: auto; scrollbar-width: none;
}
.faq-tabs::-webkit-scrollbar { display: none; }
.faq-tab-btn {
  flex-shrink: 0; padding: 15px 18px;
  font-size: 0.82rem; font-weight: 600; color: var(--text-muted);
  background: none; border: none; border-bottom: 2px solid transparent;
  cursor: pointer; transition: color var(--transition), border-color var(--transition);
  white-space: nowrap; display: flex; align-items: center; gap: 7px;
}
.faq-tab-btn i { font-size: 0.9rem; }
.faq-tab-btn:hover { color: var(--text-heading); }
.faq-tab-btn.active { color: var(--accent); border-bottom-color: var(--accent); }
.faq-tab-count {
  background: var(--light-2); border: 1px solid var(--light-border);
  border-radius: 100px; padding: 1px 7px; font-size: 0.68rem; font-weight: 700;
  color: var(--text-muted);
}
.faq-tab-btn.active .faq-tab-count { background: rgba(0,163,255,0.1); border-color: rgba(0,163,255,0.2); color: var(--accent); }

/* Body */
.faq-body { max-width: 1200px; margin: 0 auto; padding: 0 48px 80px; }

/* Section */
.faq-section { padding: 52px 0; border-bottom: 1px solid var(--light-border); }
.faq-section:last-child { border-bottom: none; }
.faq-section-hd {
  display: grid; grid-template-columns: 56px 1fr; gap: 0; align-items: start; margin-bottom: 32px;
}
.faq-section-icon {
  width: 44px; height: 44px; border-radius: 12px;
  background: rgba(0,163,255,0.1); border: 1px solid rgba(0,163,255,0.15);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 2px;
}
.faq-section-icon i { font-size: 1.25rem; color: var(--accent); }
.faq-section-txt h2 {
  font-size: 1.15rem; font-weight: 800; color: var(--text-heading);
  letter-spacing: -0.01em; margin-bottom: 6px;
}
.faq-section-txt p { font-size: 0.84rem; color: var(--text-muted); line-height: 1.6; }

/* Override accordion for longer answers */
.faq-page .faq-item.open .faq-answer { max-height: 800px; }
.faq-page .faq-question { font-size: 0.95rem; font-weight: 700; text-align: left; }
.faq-page .faq-answer p { font-size: 0.88rem; line-height: 1.78; margin-bottom: 10px; }
.faq-page .faq-answer p:last-child { margin-bottom: 0; }
.faq-page .faq-answer strong { color: var(--text-heading); font-weight: 700; }
.faq-answer-note {
  display: flex; align-items: flex-start; gap: 9px; margin-top: 12px;
  background: rgba(0,163,255,0.07); border-left: 3px solid var(--accent);
  border-radius: 0 6px 6px 0; padding: 10px 14px;
  font-size: 0.8rem; color: var(--text-body); line-height: 1.6;
}
.faq-answer-note i { color: var(--accent); flex-shrink: 0; font-size: 0.95rem; margin-top: 1px; }

/* Still have questions block */
.faq-contact-strip {
  background: var(--dark); border-radius: var(--radius);
  padding: 40px 48px; margin: 48px 0 0;
  display: grid; grid-template-columns: 1fr auto; gap: 32px; align-items: center;
}
.faq-contact-strip h3 { font-size: 1.1rem; font-weight: 800; color: #fff; margin-bottom: 8px; }
.faq-contact-strip p { font-size: 0.86rem; color: var(--dark-text); line-height: 1.65; }
.faq-contact-btns { display: flex; flex-direction: column; gap: 10px; flex-shrink: 0; }
.faq-wa-btn {
  display: inline-flex; align-items: center; gap: 8px;
  background: #25d366; color: #fff; font-size: 0.84rem; font-weight: 700;
  padding: 11px 22px; border-radius: 100px; white-space: nowrap;
  transition: background var(--transition);
}
.faq-wa-btn:hover { background: #1fb657; }
.faq-wa-btn svg { width: 17px; height: 17px; fill: currentColor; }
.faq-email-btn {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.15);
  color: rgba(255,255,255,0.8); font-size: 0.84rem; font-weight: 600;
  padding: 11px 22px; border-radius: 100px; white-space: nowrap;
  transition: background var(--transition), border-color var(--transition);
}
.faq-email-btn:hover { background: rgba(255,255,255,0.12); border-color: rgba(255,255,255,0.25); }

/* FAQ responsive */
@media (max-width: 1000px) {
  .faq-hero-inner { grid-template-columns: 1fr; }
  .faq-hero-count { display: none; }
}
@media (max-width: 768px) {
  .faq-hero-inner, .faq-body { padding-left: 20px; padding-right: 20px; }
  .faq-tabs { padding: 0 20px; }
  .faq-contact-strip { grid-template-columns: 1fr; padding: 28px 24px; }
  .faq-contact-btns { flex-direction: row; flex-wrap: wrap; }
}

/* ============================================================
   CONTACT PAGE
   ============================================================ */

/* Hero */
.ct-hero {
  min-height: 500px; background: var(--dark) center center / cover no-repeat;
  display: flex; align-items: center;
  position: relative; overflow: hidden; margin-top: var(--nav-h);
}
.ct-hero-bg {
  position: absolute; inset: 0;
  background: linear-gradient(
    100deg,
    rgba(0,0,0,0.88) 0%,
    rgba(0,0,0,0.65) 55%,
    rgba(0,0,0,0.35) 85%,
    rgba(0,0,0,0.15) 100%
  );
}
.ct-hero-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.022) 1px, transparent 1px);
  background-size: 64px 64px;
}
.ct-hero-inner {
  max-width: 1200px; margin: 0 auto; padding: 52px 48px;
  position: relative; z-index: 1; width: 100%;
  display: grid; grid-template-columns: 1fr auto; gap: 48px; align-items: center;
}
.ct-hero-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(0,163,255,0.14); border: 1px solid rgba(0,163,255,0.3);
  color: var(--accent); font-size: 0.72rem; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase;
  padding: 6px 16px; border-radius: 100px; margin-bottom: 18px;
}
.ct-hero-title {
  font-size: clamp(2rem, 4vw, 3rem); font-weight: 800;
  color: #fff; line-height: 1.1; letter-spacing: -0.03em; margin-bottom: 14px;
}
.ct-hero-title span { color: var(--accent); }
.ct-hero-sub { font-size: 0.95rem; color: rgba(255,255,255,0.57); line-height: 1.7; max-width: 540px; }
.ct-hero-pills {
  display: flex; flex-direction: column; gap: 10px; flex-shrink: 0;
}
.ct-hero-pill {
  display: flex; align-items: center; gap: 12px;
  background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.1);
  border-radius: 12px; padding: 13px 18px; min-width: 220px;
}
.ct-hero-pill i { font-size: 1.2rem; color: var(--accent); flex-shrink: 0; }
.ct-hero-pill-txt strong { display: block; font-size: 0.82rem; font-weight: 700; color: #fff; }
.ct-hero-pill-txt span { font-size: 0.72rem; color: rgba(255,255,255,0.45); }

/* Main grid */
.ct-body { max-width: 1200px; margin: 0 auto; padding: 64px 48px 80px; }
.ct-grid { display: grid; grid-template-columns: 1fr 380px; gap: 56px; align-items: start; }

/* Form column */
.ct-form-wrap { }
.ct-form-title { font-size: 1.35rem; font-weight: 800; color: var(--text-heading); letter-spacing: -0.01em; margin-bottom: 6px; }
.ct-form-sub { font-size: 0.86rem; color: var(--text-muted); margin-bottom: 28px; }

.ct-form { display: flex; flex-direction: column; gap: 16px; }
.ct-form .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.ct-form .form-group { display: flex; flex-direction: column; gap: 6px; }
.ct-form label { font-size: 0.78rem; font-weight: 700; color: var(--text-heading); }
.ct-form label .req { color: var(--accent); margin-left: 2px; }
.ct-form .form-input, .ct-form .form-select, .ct-form .form-textarea {
  width: 100%; padding: 12px 16px;
  font-family: var(--font); font-size: 0.9rem; color: var(--text-heading);
  background: var(--light); border: 1.5px solid var(--light-border); border-radius: 10px;
  transition: border-color var(--transition), box-shadow var(--transition);
  outline: none;
}
.ct-form .form-input:focus, .ct-form .form-select:focus, .ct-form .form-textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(0,163,255,0.1);
}
.ct-form .form-select { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24'%3E%3Cpath fill='%236b7280' d='M7 10l5 5 5-5z'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 36px; cursor: pointer; }
.ct-form .form-textarea { min-height: 130px; resize: vertical; line-height: 1.6; }
.ct-form-hint { font-size: 0.74rem; color: var(--text-muted); margin-top: 2px; }

.ct-submit {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  width: 100%; padding: 15px 28px; margin-top: 4px;
  background: var(--accent); color: #fff;
  font-family: var(--font); font-size: 0.96rem; font-weight: 700;
  border: none; border-radius: 100px; cursor: pointer;
  transition: background var(--transition), transform var(--transition), box-shadow var(--transition);
}
.ct-submit:hover:not(:disabled) { background: var(--accent-dark); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,163,255,0.3); }
.ct-submit:disabled { opacity: 0.7; cursor: not-allowed; }
@keyframes spin { to { transform: rotate(360deg); } }

/* Right column */
.ct-right { display: flex; flex-direction: column; gap: 20px; }

/* Response time bar */
.ct-response-bar {
  background: linear-gradient(135deg, #041624 0%, #071e36 100%);
  border: 1px solid rgba(0,163,255,0.2); border-radius: var(--radius);
  padding: 22px 22px;
}
.ct-response-bar h4 { font-size: 0.82rem; font-weight: 700; color: rgba(255,255,255,0.6); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 16px; }
.ct-resp-row { display: flex; align-items: center; gap: 12px; margin-bottom: 10px; }
.ct-resp-row:last-child { margin-bottom: 0; }
.ct-resp-icon { width: 34px; height: 34px; border-radius: 8px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.ct-resp-icon i { font-size: 1rem; }
.ct-resp-txt { flex: 1; }
.ct-resp-txt strong { display: block; font-size: 0.82rem; font-weight: 700; color: #fff; }
.ct-resp-txt span { font-size: 0.72rem; color: rgba(255,255,255,0.4); }
.ct-resp-badge { font-size: 0.65rem; font-weight: 800; letter-spacing: 0.06em; text-transform: uppercase; padding: 3px 9px; border-radius: 4px; flex-shrink: 0; }
.badge-fast { background: rgba(37,211,102,0.15); color: #25d366; }
.badge-std  { background: rgba(0,163,255,0.12); color: var(--accent); }
.badge-slow { background: rgba(255,255,255,0.06); color: rgba(255,255,255,0.35); }

/* Channel cards */
.ct-channels { display: flex; flex-direction: column; gap: 10px; }
.ct-channel {
  display: flex; align-items: center; gap: 14px;
  padding: 16px 18px; border-radius: var(--radius-sm);
  border: 1.5px solid var(--light-border); background: var(--light);
  text-decoration: none; transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
}
.ct-channel:hover { border-color: var(--accent); box-shadow: 0 4px 16px rgba(0,163,255,0.08); transform: translateX(3px); }
.ct-channel-icon { width: 42px; height: 42px; border-radius: 10px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.ct-channel-icon i { font-size: 1.25rem; }
.ct-channel-txt strong { display: block; font-size: 0.88rem; font-weight: 700; color: var(--text-heading); margin-bottom: 2px; }
.ct-channel-txt span { font-size: 0.76rem; color: var(--text-muted); }
.ct-channel-arrow { margin-left: auto; color: var(--text-muted); font-size: 0.9rem; flex-shrink: 0; transition: color var(--transition); }
.ct-channel:hover .ct-channel-arrow { color: var(--accent); }

/* Office card */
.ct-office {
  border: 1.5px solid var(--light-border); border-radius: var(--radius);
  overflow: hidden;
}
.ct-office-head {
  background: var(--dark); padding: 14px 20px;
  display: flex; align-items: center; gap: 8px;
  font-size: 0.72rem; font-weight: 700; letter-spacing: 0.09em; text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}
.ct-office-head i { color: var(--accent); }
.ct-office-body { padding: 18px 20px; display: flex; flex-direction: column; gap: 12px; }
.ct-office-row { display: flex; align-items: flex-start; gap: 10px; }
.ct-office-row i { font-size: 0.95rem; color: var(--accent); flex-shrink: 0; margin-top: 2px; }
.ct-office-row span { font-size: 0.82rem; color: var(--text-body); line-height: 1.5; }
.ct-office-row strong { color: var(--text-heading); }

/* What happens next */
.ct-next {
  background: var(--light-2); border: 1.5px solid var(--light-border);
  border-radius: var(--radius); padding: 22px 20px;
}
.ct-next h4 { font-size: 0.82rem; font-weight: 700; color: var(--text-heading); margin-bottom: 14px; display: flex; align-items: center; gap: 8px; }
.ct-next h4 i { color: var(--accent); }
.ct-next-steps { display: flex; flex-direction: column; gap: 10px; }
.ct-next-step { display: flex; align-items: flex-start; gap: 10px; font-size: 0.8rem; color: var(--text-body); line-height: 1.55; }
.ct-next-num {
  width: 22px; height: 22px; border-radius: 50%; background: var(--accent); color: #fff;
  font-size: 0.65rem; font-weight: 800; display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}

/* Success state */
.ct-success {
  display: none; text-align: center; padding: 48px 24px;
  border: 1.5px solid rgba(37,211,102,0.3); border-radius: var(--radius);
  background: rgba(37,211,102,0.05);
}
.ct-success i { font-size: 3rem; color: #25d366; display: block; margin-bottom: 16px; }
.ct-success h3 { font-size: 1.2rem; font-weight: 800; color: var(--text-heading); margin-bottom: 8px; }
.ct-success p { font-size: 0.88rem; color: var(--text-muted); line-height: 1.7; }

/* Responsive */
@media (max-width: 1000px) {
  .ct-hero-inner { grid-template-columns: 1fr; }
  .ct-hero-pills { display: none; }
  .ct-grid { grid-template-columns: 1fr; }
  .ct-right { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
  .ct-response-bar, .ct-next { grid-column: 1 / -1; }
}
@media (max-width: 768px) {
  .ct-hero-inner, .ct-body { padding-left: 20px; padding-right: 20px; }
  .ct-body { padding-top: 40px; padding-bottom: 56px; }
  .ct-right { grid-template-columns: 1fr; }
  .ct-form .form-row { grid-template-columns: 1fr; }
}

/* ============================================================
   HERO SLIDER  (index.html)
   ============================================================ */
.hero-slider {
  position: relative; width: 100%; height: 100vh; min-height: 600px; overflow: hidden;
}
.slide {
  position: absolute; inset: 0;
  display: flex; align-items: center; padding-top: var(--nav-h);
  opacity: 0; transition: opacity 0.85s ease;
  pointer-events: none; background: var(--dark); z-index: 1;
}
.slide.active { opacity: 1; pointer-events: auto; z-index: 2; }

.slide .hero-overlay {
  position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(100deg,rgba(0,0,0,0.88) 0%,rgba(0,0,0,0.65) 45%,rgba(0,0,0,0.25) 75%,rgba(0,0,0,0.05) 100%);
}
.slide::before {
  content:''; position:absolute; inset:0; z-index:2; pointer-events:none;
  background: linear-gradient(to bottom,rgba(15,15,15,0.55) 0%,transparent 18%,transparent 82%,rgba(15,15,15,0.6) 100%);
}
.slide .hero-inner { position:relative; z-index:3; max-width:1200px; width:100%; margin:0 auto; padding:0 48px; }

/* Slide 1 — video */
.slide-video-bg {
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0;
}
/* Slide image background */
.slide-img-bg {
  position:absolute; inset:0; z-index:0;
  background: var(--dark) center center / cover no-repeat;
}

/* Checklist (video slide) */
.hero-checklist { list-style:none; display:flex; flex-direction:column; gap:8px; margin-bottom:36px; }
.hero-checklist li { display:flex; align-items:center; gap:10px; color:rgba(255,255,255,0.85); font-size:0.92rem; font-weight:500; }
.hero-checklist li i { color:var(--accent); font-size:1.05rem; flex-shrink:0; }

/* Slider arrows */
.slider-arrow {
  position:absolute; top:50%; transform:translateY(-50%); z-index:10;
  background:rgba(255,255,255,0.1); border:1.5px solid rgba(255,255,255,0.2);
  color:#fff; width:52px; height:52px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:1.3rem; cursor:pointer;
  transition: background 0.22s, border-color 0.22s, transform 0.22s;
  backdrop-filter:blur(4px);
}
.slider-prev { left:28px; }
.slider-next { right:28px; }
.slider-arrow:hover { background:rgba(0,163,255,0.3); border-color:var(--accent); transform:translateY(-50%) scale(1.1); }

/* Slider dots */
.slider-dots {
  position:absolute; bottom:28px; left:50%; transform:translateX(-50%);
  z-index:10; display:flex; gap:10px; align-items:center;
}
.dot { width:9px; height:9px; border-radius:50%; background:rgba(255,255,255,0.4); border:none; cursor:pointer; padding:0; transition: background 0.22s, width 0.28s, border-radius 0.28s; }
.dot.active { background:var(--accent); width:26px; border-radius:5px; }

/* Slide progress bar at bottom */
.slider-progress {
  position:absolute; bottom:0; left:0; height:3px; z-index:10;
  background:var(--accent); width:0%; transition:width linear;
  opacity:0.7;
}

/* Mute/unmute button on video slide */
.slider-mute-btn {
  position:absolute; top:calc(var(--nav-h) + 18px); right:20px; z-index:10;
  background:rgba(0,0,0,0.45); border:1px solid rgba(255,255,255,0.18);
  color:#fff; width:40px; height:40px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; font-size:1rem;
  transition:background 0.2s, opacity 0.3s;
  backdrop-filter:blur(4px); -webkit-backdrop-filter:blur(4px);
}
.slider-mute-btn:hover { background:rgba(0,163,255,0.5); }
.slider-mute-btn.hidden { opacity:0; pointer-events:none; }

/* ============================================================
   LANGUAGE SELECT
   ============================================================ */
.lang-select {
  background: transparent;
  border: none;
  color: #9ca3af;
  font-size: 0.88rem;
  font-weight: 500;
  font-family: var(--font);
  cursor: pointer;
  outline: none;
  flex-shrink: 0;
  margin-right: 10px;
  padding: 6px 22px 6px 8px;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%239ca3af' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 4px center;
  transition: color 0.2s;
}
.lang-select:hover { color: #fff; }
.lang-select option { background: #1a1a1a; color: #fff; }

/* Mobile nav lang select */
.nav-mobile .lang-select {
  width: 100%; margin: 4px 14px 10px;
  padding: 10px 30px 10px 12px;
  font-size: 0.9rem;
  background-color: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 7px;
  color: #d1d5db;
  background-position: right 12px center;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23d1d5db' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}
.nav-mobile .lang-select:hover { color: #fff; }

/* Suppress all Google Translate UI notifications */
.goog-te-banner-frame, .goog-te-banner-frame.skiptranslate { display:none !important; }
.goog-te-balloon-frame { display:none !important; }
#goog-gt-tt { display:none !important; }
.goog-tooltip, .goog-tooltip-opened { display:none !important; }
.VIpgJd-ZVi9od-aZ2wEe-wOHMyf { display:none !important; }
.VIpgJd-ZVi9od-ORHb-OEVmcd { display:none !important; }
.goog-te-menu-frame { display:none !important; }
body { top:0 !important; }

/* ============================================================
   MOBILE RESPONSIVE — global fixes
   ============================================================ */
@media (max-width: 900px) {
  /* hide desktop lang select (shown in mobile nav instead) */
  .navbar .lang-select { display:none; }
  /* slider on tablet */
  .slider-arrow { width:42px; height:42px; font-size:1.05rem; }
  .slider-prev { left:12px; }
  .slider-next { right:12px; }
  /* navbar on small tablets */
  .navbar { padding:0 16px; }
  /* footer */
  .footer { padding:48px 20px 24px; }
}
@media (max-width: 600px) {
  /* hide arrows on phone — swipe dots only */
  .slider-arrow { display:none; }
  /* hero checklist can be too long on small screens */
  .hero-checklist { display:none; }
  .hero-stats { gap:18px; flex-wrap:wrap; }
  .hero-stat-num { font-size:1.4rem; }
  /* nav mobile padding */
  .nav-mobile { padding:12px 14px; }
  /* page banners */
  .page-banner { padding: calc(var(--nav-h) + 36px) 20px 36px; }
  /* how to buy hero */
  .htb-hero-inner { padding:44px 20px; }
  .htb-hero-inner { grid-template-columns:1fr; }
  /* filter bar */
  .filter-bar { padding:12px 14px; }
  .filter-inner { gap:10px; }
  .filter-select { font-size:0.82rem; padding:7px 28px 7px 10px; }
  /* cars grid on small phones */
  .cars-grid { gap:12px; }
  /* news */
  .news-body { padding:28px 14px 48px; }
  /* faq */
  .faq-body { padding:0 14px 56px; }
  /* contact */
  .ct-body { padding:32px 14px 48px; }
}
/* Touch swipe hint on mobile (only for slider) */
@media (max-width: 600px) {
  .slider-dots { bottom:20px; }
}

/* ============================================================
   POPULAR MODELS — Homepage
   ============================================================ */
.popular-section { background: var(--light-2); }
.popular-top {
  display: flex; align-items: flex-end; justify-content: space-between; gap: 24px;
  margin-bottom: 40px; flex-wrap: wrap;
}
.popular-controls { display: flex; flex-direction: column; align-items: flex-end; gap: 14px; }
.popular-tabs {
  display: flex; gap: 4px;
  background: var(--light); border: 1.5px solid var(--light-border);
  border-radius: 12px; padding: 4px;
}
.pop-tab {
  padding: 10px 32px; border: none; border-radius: 9px; background: transparent;
  cursor: pointer; font-family: var(--font); transition: all 0.22s;
  display: flex; flex-direction: column; align-items: center; gap: 2px;
}
.pop-tab > span { font-size: 0.95rem; font-weight: 700; color: var(--text-muted); }
.pop-tab small { font-size: 0.68rem; color: var(--text-muted); font-weight: 500; }
.pop-tab.active { background: var(--accent); }
.pop-tab.active > span, .pop-tab.active small { color: #fff; }
.pop-tab:hover:not(.active) { background: var(--light-3); }
.popular-more-link {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 0.88rem; font-weight: 600; color: var(--accent);
  transition: gap 0.2s;
}
.popular-more-link:hover { gap: 10px; }
.popular-grid {
  display: none; grid-template-columns: repeat(4, 1fr); gap: 20px;
}
.popular-grid.active { display: grid; }
.pop-car-card {
  background: #fff; border-radius: var(--radius);
  border: 1.5px solid var(--light-border);
  overflow: hidden; text-decoration: none;
  transition: transform 0.22s, box-shadow 0.22s, border-color 0.22s;
  display: block;
}
.pop-car-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 40px rgba(0,0,0,0.1);
  border-color: var(--accent);
}
.pop-car-img {
  height: 160px; position: relative; overflow: hidden;
  display: flex; align-items: center; justify-content: center;
}
.pop-car-svg { width: 82%; max-height: 88px; position: relative; z-index: 1; }
.pop-img-shine {
  position: absolute; inset: 0; pointer-events: none; z-index: 2;
  background: linear-gradient(160deg, rgba(255,255,255,0.06) 0%, transparent 60%);
}
.pop-badges {
  position: absolute; top: 10px; left: 10px; display: flex; gap: 5px; z-index: 3;
}
.pop-badge {
  font-size: 0.62rem; font-weight: 700; padding: 3px 8px; border-radius: 5px;
  backdrop-filter: blur(4px); letter-spacing: 0.05em; color: #fff;
}
.pop-badge-ev  { background: rgba(22,163,74,0.85); }
.pop-badge-phev{ background: rgba(217,119,6,0.85); }
.pop-badge-lhd { background: rgba(29,78,216,0.8); }
.pop-badge-rhd { background: rgba(15,118,110,0.85); }
.pop-car-info { padding: 16px 18px; }
.pop-car-brand {
  font-size: 0.72rem; font-weight: 700; color: var(--accent);
  text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 4px;
}
.pop-car-model { font-size: 1rem; font-weight: 700; color: var(--text-heading); margin-bottom: 8px; line-height: 1.3; }
.pop-car-range { font-size: 0.76rem; color: var(--text-muted); margin-bottom: 10px; display: flex; align-items: center; gap: 4px; }
.pop-car-range i { color: var(--accent); font-size: 0.8rem; }
.pop-car-tags { display: flex; gap: 5px; flex-wrap: wrap; }
.pop-car-tag {
  font-size: 0.62rem; font-weight: 700; padding: 2px 8px; border-radius: 4px;
  text-transform: uppercase; letter-spacing: 0.04em;
}
.pop-car-tag.ev { background: #dcfce7; color: #166534; }
.pop-car-tag.phev { background: #fef3c7; color: #92400e; }
.pop-car-tag.suv { background: #ede9fe; color: #5b21b6; }
.pop-car-tag.sedan { background: #dbeafe; color: #1e40af; }
.pop-car-tag.hatchback { background: #fce7f3; color: #9d174d; }
.pop-car-tag.mpv { background: #ffedd5; color: #9a3412; }
.pop-car-tag.rhd { background: #f0fdf4; color: #15803d; border: 1px solid #bbf7d0; }
.pop-car-tag.lhd { background: #eff6ff; color: #1d4ed8; border: 1px solid #bfdbfe; }

/* ============================================================
   DISTRIBUTION CENTERS — Homepage (moved from about)
   ============================================================ */
.home-depots { background: var(--light-2); }
.home-depots .about-depots-inner { max-width: 1200px; margin: 0 auto; padding: 80px 48px; }
@media (max-width: 900px) {
  .home-depots .about-depots-inner { padding: 56px 20px; }
}

/* ============================================================
   CUSTOMER REVIEWS — Homepage Slider
   ============================================================ */
.reviews-section {
  background: var(--light);
  padding: 88px 0 80px;
  position: relative; overflow: hidden;
}
.reviews-deco {
  display: flex; align-items: center; justify-content: center;
  gap: 20px; margin-bottom: 40px;
}
.reviews-deco-line {
  height: 2px; width: 72px; border-radius: 2px;
  background: linear-gradient(90deg, transparent, var(--accent));
}
.reviews-deco-line.rev-line-r { background: linear-gradient(90deg, var(--accent), transparent); }
.reviews-deco-quote {
  font-size: 2.6rem; line-height: 1; color: var(--accent); font-weight: 900;
  font-family: Georgia, serif; opacity: 0.8;
}
.reviews-slider-wrap { position: relative; max-width: 1100px; margin: 0 auto; padding: 0 40px; }
.reviews-overflow { overflow: hidden; border-radius: var(--radius); }
.reviews-track {
  display: flex;
  transition: transform 0.52s cubic-bezier(0.25, 0.8, 0.25, 1);
}
.review-slide {
  min-width: 100%; display: flex; gap: 0;
  background: #fff; border-radius: var(--radius);
  border: 1.5px solid var(--light-border);
  min-height: 340px; overflow: hidden;
}
.review-photo-col {
  width: 38%; flex-shrink: 0;
  background: var(--light-3);
  display: flex; align-items: center; justify-content: center;
  position: relative; overflow: hidden;
  min-height: 340px;
}
.review-photo-img { width: 100%; height: 100%; object-fit: cover; display: block; }
.review-photo-placeholder {
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  color: var(--text-muted); padding: 20px; text-align: center;
}
.review-photo-placeholder i { font-size: 3.2rem; color: var(--light-border); }
.review-photo-placeholder span { font-size: 0.78rem; }
.review-content-col {
  flex: 1; padding: 44px 52px;
  display: flex; flex-direction: column; justify-content: center;
  position: relative;
}
.review-bg-quote {
  position: absolute; top: 16px; left: 44px;
  font-size: 7rem; line-height: 1; font-family: Georgia, serif;
  color: rgba(0,163,255,0.07); font-weight: 900; pointer-events: none;
  user-select: none;
}
.review-stars { color: #f59e0b; font-size: 1.1rem; letter-spacing: 0.12em; margin-bottom: 18px; }
.review-text {
  font-size: 0.96rem; line-height: 1.82; color: var(--text-body);
  font-style: italic; margin-bottom: 26px; position: relative; z-index: 1;
  max-width: 560px;
}
.review-divider { width: 36px; height: 2px; background: var(--accent); border-radius: 2px; margin-bottom: 18px; }
.review-car {
  font-size: 0.78rem; color: var(--text-muted);
  display: flex; align-items: center; gap: 6px; margin-bottom: 8px;
}
.review-car i { color: var(--accent); font-size: 0.82rem; }
.review-customer-name { font-size: 1rem; font-weight: 700; color: var(--text-heading); }
.review-customer-country { font-size: 0.86rem; color: var(--text-muted); margin-top: 2px; }
.rev-arrow {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 44px; height: 44px; border-radius: 50%;
  background: #fff; border: 1.5px solid var(--light-border);
  box-shadow: 0 4px 14px rgba(0,0,0,0.1);
  display: flex; align-items: center; justify-content: center;
  z-index: 10; font-size: 1.05rem; color: var(--text-heading);
  transition: all 0.2s; cursor: pointer;
}
.rev-arrow:hover { background: var(--accent); color: #fff; border-color: var(--accent); box-shadow: 0 6px 20px rgba(0,163,255,0.3); }
.rev-prev { left: -4px; }
.rev-next { right: -4px; }
.reviews-dots { display: flex; justify-content: center; gap: 8px; margin-top: 24px; }
.rev-dot {
  width: 8px; height: 8px; border-radius: 50%; background: var(--light-border);
  border: none; cursor: pointer; padding: 0; transition: all 0.25s;
}
.rev-dot.active { background: var(--accent); width: 24px; border-radius: 4px; }
@media (max-width: 900px) {
  .review-slide { flex-direction: column; }
  .review-photo-col { width: 100%; min-height: 200px; }
  .review-content-col { padding: 28px 24px; }
  .reviews-slider-wrap { padding: 0 16px; }
  .popular-grid { grid-template-columns: repeat(2, 1fr); }
  .popular-top { flex-direction: column; align-items: flex-start; }
  .popular-controls { align-items: flex-start; }
}
@media (max-width: 600px) {
  .popular-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .pop-car-img { height: 110px; }
  .review-content-col { padding: 20px 16px; }
  .review-text { font-size: 0.88rem; }
  .rev-arrow { display: none; }
}

/* ── 所有子页 Hero + 首页 Slider 手机端高度（放在最后确保层叠优先级） ── */
@media (max-width: 900px) {
  .about-hero, .htb-hero, .news-hero, .faq-hero, .ct-hero {
    min-height: 220px;
  }
  .hero-slider {
    height: 56vw;
    min-height: 200px;
    max-height: 420px;
    margin-top: var(--nav-h);
  }
}
