/* =====================================================
   NIGERIACARMARKET PLUGIN — FRONTEND STYLES
   v1.0.0
===================================================== */

/* ---------- DESIGN TOKENS ---------- */
:root {
  --ncm-black:   #0a0a0a;
  --ncm-dark:    #111318;
  --ncm-card:    #16191f;
  --ncm-border:  #222630;
  --ncm-green:   #00c853;
  --ncm-green2:  #00e676;
  --ncm-amber:   #ffab00;
  --ncm-white:   #f4f5f7;
  --ncm-muted:   #8a9099;
  --ncm-font-d:  'Bebas Neue', sans-serif;
  --ncm-font-b:  'DM Sans', sans-serif;
  --ncm-font-m:  'Space Mono', monospace;
  --ncm-radius:  12px;
  --ncm-trans:   0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ---------- BASE ---------- */
.ncm-container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
.ncm-section   { padding: 88px 0; background: var(--ncm-black); }
.ncm-section-label {
  font-family: var(--ncm-font-m); font-size: 11px;
  letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--ncm-green); margin-bottom: 14px;
}
.ncm-section-title {
  font-family: var(--ncm-font-d);
  font-size: clamp(32px, 4.5vw, 58px);
  line-height: 1.05; color: var(--ncm-white); margin-bottom: 18px;
}
.ncm-section-body {
  color: var(--ncm-muted); font-size: 16px; line-height: 1.7;
  max-width: 560px;
}
.ncm-section-center { text-align: center; max-width: 580px; margin: 0 auto 52px; }
.ncm-section-center .ncm-section-body { margin: 0 auto; }
.ncm-tag {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(0,200,83,0.12); color: var(--ncm-green2);
  font-family: var(--ncm-font-m); font-size: 11px; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase;
  padding: 5px 12px; border-radius: 100px;
  border: 1px solid rgba(0,200,83,0.25);
}

/* ---------- BUTTONS ---------- */
.ncm-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 13px 26px; border-radius: 8px;
  font-family: var(--ncm-font-b); font-weight: 600; font-size: 14px;
  text-decoration: none; transition: all var(--ncm-trans);
  white-space: nowrap; cursor: pointer; border: none;
}
.ncm-btn-primary  { background: var(--ncm-green); color: var(--ncm-black); }
.ncm-btn-primary:hover  { background: var(--ncm-green2); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,200,83,0.35); color: var(--ncm-black); text-decoration: none; }
.ncm-btn-outline  { border: 1.5px solid var(--ncm-border); color: var(--ncm-white); background: none; }
.ncm-btn-outline:hover  { border-color: var(--ncm-green); color: var(--ncm-green); transform: translateY(-2px); text-decoration: none; }
.ncm-btn-amber    { background: var(--ncm-amber); color: var(--ncm-black); }
.ncm-btn-amber:hover { background: #ffc107; transform: translateY(-2px); box-shadow: 0 8px 24px rgba(255,171,0,0.35); text-decoration: none; }
.ncm-btn-lg { font-size: 15px; padding: 15px 32px; }

/* =====================================================
   HERO
===================================================== */
.ncm-hero {
  min-height: 88vh; position: relative; overflow: hidden;
  display: flex; align-items: center;
  background: var(--ncm-black); font-family: var(--ncm-font-b);
}
.ncm-hero-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 80% 60% at 60% 50%, rgba(0,200,83,0.08) 0%, transparent 60%),
    radial-gradient(ellipse 40% 40% at 85% 20%, rgba(255,171,0,0.06) 0%, transparent 50%),
    linear-gradient(180deg, #0a0a0a 0%, #111318 100%);
  pointer-events: none;
}
.ncm-hero-grid-bg {
  position: absolute; inset: 0; opacity: 0.04; pointer-events: none;
  background-image: linear-gradient(var(--ncm-border) 1px, transparent 1px),
                    linear-gradient(90deg, var(--ncm-border) 1px, transparent 1px);
  background-size: 60px 60px;
}
.ncm-hero-content {
  position: relative; z-index: 2;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 60px; align-items: center; padding: 80px 0;
}
.ncm-hero-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(0,200,83,0.1); border: 1px solid rgba(0,200,83,0.3);
  border-radius: 100px; padding: 6px 16px;
  font-family: var(--ncm-font-m); font-size: 11px; color: var(--ncm-green2);
  letter-spacing: 0.1em; text-transform: uppercase;
  margin-bottom: 26px; width: fit-content;
}
.ncm-hero-badge-dot {
  width: 7px; height: 7px; background: var(--ncm-green);
  border-radius: 50%; animation: ncm-pulse 2s infinite;
}
@keyframes ncm-pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(1.3)} }
.ncm-hero-h1 {
  font-family: var(--ncm-font-d);
  font-size: clamp(44px, 6vw, 80px);
  line-height: 1.0; color: var(--ncm-white); margin-bottom: 22px;
}
.ncm-line-green { color: var(--ncm-green); }
.ncm-line-amber { color: var(--ncm-amber); }
.ncm-hero-intro {
  color: var(--ncm-muted); font-size: 16px; line-height: 1.75;
  margin-bottom: 32px; max-width: 500px;
}
.ncm-hero-intro strong { color: var(--ncm-white); }
.ncm-hero-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 44px; }
.ncm-hero-stats {
  display: flex; gap: 32px; padding-top: 28px;
  border-top: 1px solid var(--ncm-border);
}
.ncm-stat-num { font-family: var(--ncm-font-d); font-size: 30px; color: var(--ncm-white); line-height: 1; }
.ncm-stat-lbl { font-size: 12px; color: var(--ncm-muted); margin-top: 3px; }

/* Hero Visual */
.ncm-hero-visual { display: flex; align-items: center; justify-content: center; }
.ncm-hero-car-frame {
  width: 100%; aspect-ratio: 4/3; background: var(--ncm-card);
  border-radius: 24px; border: 1px solid var(--ncm-border);
  overflow: hidden; position: relative;
  display: flex; align-items: center; justify-content: center;
}
.ncm-hero-car-emoji { font-size: 110px; animation: ncm-carfloat 4s ease-in-out infinite; }
@keyframes ncm-carfloat { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-12px)} }
.ncm-hero-car-glow {
  position: absolute; width: 200px; height: 60px;
  background: rgba(0,200,83,0.2); filter: blur(40px);
  bottom: 20%; left: 50%; transform: translateX(-50%); border-radius: 50%;
}
.ncm-badge-floating {
  position: absolute; background: var(--ncm-dark);
  border: 1px solid var(--ncm-border); border-radius: 12px; padding: 10px 14px;
  font-family: var(--ncm-font-b); font-size: 12px; font-weight: 600; color: var(--ncm-white);
}
.ncm-badge-tl { top: 16px; left: -16px; }
.ncm-badge-br { bottom: 16px; right: -16px; }
.ncm-bf-icon { font-size: 18px; margin-bottom: 3px; }
.ncm-bf-val  { color: var(--ncm-green); font-size: 14px; }
.ncm-bf-sub  { color: var(--ncm-muted); font-size: 10px; }

/* =====================================================
   BRANDS TICKER
===================================================== */
.ncm-brands-section {
  padding: 36px 0; border-bottom: 1px solid var(--ncm-border);
  background: var(--ncm-dark); overflow: hidden;
}
.ncm-brands-label {
  text-align: center; font-family: var(--ncm-font-m); font-size: 11px;
  color: var(--ncm-muted); letter-spacing: 0.15em; text-transform: uppercase;
  margin-bottom: 24px;
}
.ncm-brands-overflow { overflow: hidden; }
.ncm-brands-track {
  display: flex; gap: 48px; animation: ncm-scroll 22s linear infinite;
  width: max-content;
}
@keyframes ncm-scroll { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }
.ncm-brand-item {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--ncm-font-d); font-size: 19px; letter-spacing: 1px;
  color: var(--ncm-muted); white-space: nowrap;
}

/* =====================================================
   ABOUT
===================================================== */
.ncm-about-section { background: var(--ncm-black); }
.ncm-about-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 72px; align-items: start;
}
.ncm-about-visual { position: relative; }
.ncm-about-card {
  background: var(--ncm-card); border: 1px solid var(--ncm-border);
  border-radius: 20px; padding: 32px; position: relative; overflow: hidden;
}
.ncm-about-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--ncm-green), var(--ncm-amber));
}
.ncm-about-body { color: var(--ncm-muted); font-size: 15px; line-height: 1.7; margin-top: 14px; }
.ncm-stats-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 22px;
}
.ncm-stat-box {
  background: var(--ncm-dark); border: 1px solid var(--ncm-border);
  border-radius: 12px; padding: 18px; text-align: center;
}
.ncm-stat-box-num { font-family: var(--ncm-font-d); font-size: 34px; color: var(--ncm-green); }
.ncm-stat-box-lbl { font-size: 12px; color: var(--ncm-muted); margin-top: 3px; }
.ncm-side-badge {
  position: absolute; right: -20px; top: 36px;
  background: var(--ncm-amber); color: var(--ncm-black);
  border-radius: 10px; padding: 12px 16px;
  font-weight: 700; font-size: 13px; text-align: center;
  box-shadow: 0 8px 28px rgba(255,171,0,0.4); line-height: 1.4;
}

/* WHY LIST (inside about) */
.ncm-why-wrapper { font-family: var(--ncm-font-b); }
.ncm-why-list { display: flex; flex-direction: column; gap: 16px; margin-top: 28px; }
.ncm-why-item {
  display: flex; gap: 14px; align-items: flex-start; padding: 18px;
  background: var(--ncm-card); border-radius: 12px; border: 1px solid var(--ncm-border);
  transition: border-color var(--ncm-trans);
}
.ncm-why-item:hover { border-color: var(--ncm-green); }
.ncm-why-icon {
  width: 42px; height: 42px; border-radius: 10px;
  background: rgba(0,200,83,0.1); border: 1px solid rgba(0,200,83,0.2);
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; flex-shrink: 0;
}
.ncm-why-title { font-weight: 600; font-size: 15px; color: var(--ncm-white); margin-bottom: 3px; }
.ncm-why-desc  { font-size: 13px; color: var(--ncm-muted); line-height: 1.5; }

/* =====================================================
   ELECTRIC CARS
===================================================== */
.ncm-ev-band {
  background: linear-gradient(135deg, #0a1f10 0%, #111318 50%, #0d1a0f 100%);
  border-top: 1px solid rgba(0,200,83,0.2);
  border-bottom: 1px solid rgba(0,200,83,0.2);
}
.ncm-ev-grid {
  display: grid; grid-template-columns: 1fr 1.2fr; gap: 72px; align-items: center;
}
.ncm-ev-badges { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 28px; }
.ncm-ev-badge {
  padding: 7px 14px; border-radius: 8px;
  background: rgba(0,200,83,0.1); border: 1px solid rgba(0,200,83,0.25);
  font-family: var(--ncm-font-b); font-size: 13px; font-weight: 600; color: var(--ncm-green2);
}
.ncm-ev-btns { display: flex; gap: 12px; margin-top: 28px; flex-wrap: wrap; }
.ncm-ev-models-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.ncm-ev-model-card {
  background: rgba(0,0,0,0.4); border: 1px solid rgba(0,200,83,0.15);
  border-radius: 14px; padding: 20px; transition: all var(--ncm-trans);
  font-family: var(--ncm-font-b);
}
.ncm-ev-model-card:hover { border-color: var(--ncm-green); background: rgba(0,200,83,0.05); }
.ncm-ev-model-icon  { font-size: 34px; margin-bottom: 10px; }
.ncm-ev-model-name  { font-size: 15px; font-weight: 700; color: var(--ncm-white); margin-bottom: 4px; }
.ncm-ev-model-range { font-size: 12px; color: var(--ncm-green); font-family: var(--ncm-font-m); }
.ncm-ev-model-price { font-size: 13px; color: var(--ncm-muted); margin-top: 5px; }

/* =====================================================
   LATEST DEALS
===================================================== */
.ncm-deals-section { background: var(--ncm-black); }
.ncm-deals-header {
  display: flex; justify-content: space-between; align-items: flex-end;
  margin-bottom: 36px; flex-wrap: wrap; gap: 16px;
}
.ncm-deals-listings { font-family: var(--ncm-font-b); }

/* =====================================================
   HOW IT WORKS
===================================================== */
.ncm-how-section { background: var(--ncm-dark); border-top: 1px solid var(--ncm-border); border-bottom: 1px solid var(--ncm-border); }
.ncm-features-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; }
.ncm-feature-card {
  padding: 30px; background: var(--ncm-card); border: 1px solid var(--ncm-border);
  border-radius: 16px; position: relative; overflow: hidden;
  transition: border-color var(--ncm-trans);
}
.ncm-feature-card:hover { border-color: var(--ncm-green); }
.ncm-feature-num {
  font-family: var(--ncm-font-d); font-size: 76px;
  color: rgba(0,200,83,0.06); position: absolute;
  top: -10px; right: 16px; line-height: 1;
}
.ncm-feature-icon {
  width: 52px; height: 52px; border-radius: 12px;
  background: rgba(0,200,83,0.1); border: 1px solid rgba(0,200,83,0.2);
  display: flex; align-items: center; justify-content: center;
  font-size: 24px; margin-bottom: 18px;
}
.ncm-feature-title { font-size: 17px; font-weight: 700; color: var(--ncm-white); margin-bottom: 10px; }
.ncm-feature-desc  { font-size: 13px; color: var(--ncm-muted); line-height: 1.6; }

/* =====================================================
   LOCATIONS
===================================================== */
.ncm-locations-section { background: var(--ncm-black); }
.ncm-cities-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; }
.ncm-city-card {
  background: var(--ncm-card); border: 1px solid var(--ncm-border);
  border-radius: 16px; padding: 28px; text-align: center;
  transition: all var(--ncm-trans); display: block; text-decoration: none;
}
.ncm-city-card:hover { border-color: var(--ncm-green); transform: translateY(-4px); text-decoration: none; }
.ncm-city-flag  { font-size: 38px; margin-bottom: 10px; }
.ncm-city-name  { font-size: 18px; font-weight: 700; color: var(--ncm-white); margin-bottom: 4px; font-family: var(--ncm-font-b); }
.ncm-city-count { color: var(--ncm-green); font-family: var(--ncm-font-m); font-size: 12px; }
.ncm-city-desc  { color: var(--ncm-muted); font-size: 12px; margin-top: 8px; line-height: 1.5; }

/* =====================================================
   TESTIMONIALS
===================================================== */
.ncm-testimonials-section { background: var(--ncm-dark); border-top: 1px solid var(--ncm-border); }
.ncm-testimonials-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; }
.ncm-testimonial-card {
  background: var(--ncm-card); border: 1px solid var(--ncm-border);
  border-radius: 16px; padding: 26px; font-family: var(--ncm-font-b);
}
.ncm-stars            { color: var(--ncm-amber); font-size: 14px; margin-bottom: 12px; }
.ncm-testimonial-text { color: var(--ncm-muted); font-size: 14px; line-height: 1.7; margin-bottom: 18px; }
.ncm-testimonial-author { display: flex; align-items: center; gap: 12px; }
.ncm-author-avatar {
  width: 40px; height: 40px; border-radius: 50%;
  background: linear-gradient(135deg, var(--ncm-green), var(--ncm-amber));
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 14px; color: var(--ncm-black); flex-shrink: 0;
}
.ncm-author-name { font-size: 14px; font-weight: 600; color: var(--ncm-white); }
.ncm-author-city { font-size: 12px; color: var(--ncm-muted); }

/* =====================================================
   CTA BAND
===================================================== */
.ncm-cta-band {
  background: linear-gradient(135deg, rgba(0,200,83,0.14) 0%, rgba(0,200,83,0.04) 100%);
  border-top: 1px solid rgba(0,200,83,0.2);
  border-bottom: 1px solid rgba(0,200,83,0.2);
}
.ncm-cta-inner    { text-align: center; position: relative; z-index: 2; }
.ncm-cta-inner .ncm-tag { margin: 0 auto 18px; display: inline-flex; }
.ncm-cta-title    { font-family: var(--ncm-font-d); font-size: clamp(34px,5vw,60px); color: var(--ncm-white); margin-bottom: 14px; }
.ncm-cta-desc     { color: var(--ncm-muted); font-size: 16px; max-width: 480px; margin: 0 auto 32px; font-family: var(--ncm-font-b); }
.ncm-cta-actions  { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

/* =====================================================
   RESPONSIVE
===================================================== */
@media (max-width: 1024px) {
  .ncm-hero-content  { grid-template-columns: 1fr; gap: 40px; }
  .ncm-hero-visual   { display: none; }
  .ncm-about-grid    { grid-template-columns: 1fr; gap: 40px; }
  .ncm-ev-grid       { grid-template-columns: 1fr; gap: 40px; }
}
@media (max-width: 768px) {
  .ncm-section       { padding: 60px 0; }
  .ncm-features-grid { grid-template-columns: 1fr; }
  .ncm-testimonials-grid { grid-template-columns: 1fr; }
  .ncm-cities-grid   { grid-template-columns: 1fr; }
  .ncm-ev-models-grid{ grid-template-columns: 1fr 1fr; }
  .ncm-hero-stats    { gap: 20px; flex-wrap: wrap; }
  .ncm-deals-header  { flex-direction: column; align-items: flex-start; }
  .ncm-side-badge    { display: none; }
}
@media (max-width: 480px) {
  .ncm-ev-models-grid{ grid-template-columns: 1fr; }
  .ncm-hero-actions  { flex-direction: column; }
}
