/* ============================================================
   VehiclePlatform Pro - Main Stylesheet
   ============================================================ */

:root {
  --primary:    #1a56db;
  --primary-dk: #1340a8;
  --accent:     #f59e0b;
  --dark:       #111827;
  --text:       #374151;
  --muted:      #6b7280;
  --border:     #e5e7eb;
  --bg-light:   #f9fafb;
  --success:    #10b981;
  --danger:     #ef4444;
  --radius:     12px;
  --shadow:     0 4px 20px rgba(0,0,0,.08);
}

* { box-sizing: border-box; }
body { font-family: 'Inter', sans-serif; color: var(--text); background: #fff; }
h1,h2,h3,h4,h5,h6 { font-family: 'Rajdhani', sans-serif; font-weight: 700; }

/* ── NAVBAR ── */
.navbar { background: var(--dark) !important; box-shadow: 0 2px 10px rgba(0,0,0,.3); }
.navbar-brand { font-family: 'Rajdhani', sans-serif; font-size: 1.6rem; font-weight: 700; color: #fff !important; }
.navbar-brand span { color: var(--accent); }
.nav-link { color: rgba(255,255,255,.85) !important; font-weight: 500; }
.nav-link:hover { color: var(--accent) !important; }

/* ── HERO ── */
.hero-section { position: relative; min-height: 540px; display: flex; align-items: center;
  background: linear-gradient(135deg, #111827 0%, #1a56db 100%); padding: 80px 0 60px; }
.hero-overlay { position: absolute; inset: 0; background: url('/assets/images/hero-bg.jpg') center/cover no-repeat; opacity: .12; }
.hero-content { position: relative; z-index: 2; color: #fff; }
.hero-title { font-size: clamp(2rem, 5vw, 3.5rem); font-weight: 700; margin-bottom: 1rem; }
.hero-sub { font-size: 1.2rem; opacity: .9; margin-bottom: 2.5rem; }

.hero-search-box { background: #fff; border-radius: var(--radius); padding: 1.5rem; max-width: 800px; margin: 0 auto; box-shadow: 0 20px 60px rgba(0,0,0,.25); }
.search-tabs .nav-link { color: var(--text); font-weight: 600; }
.search-tabs .nav-link.active { color: var(--primary); }
.search-tab-content { padding-top: 1rem; }
.reg-input { text-transform: uppercase; font-weight: 600; letter-spacing: 2px; }

/* ── STATS ── */
.stats-section { background: linear-gradient(90deg, var(--primary) 0%, var(--primary-dk) 100%); }
.stat-num { font-size: 2rem; font-weight: 700; font-family: 'Rajdhani', sans-serif; }
.stat-label { font-size: .85rem; opacity: .85; }

/* ── SECTIONS ── */
.section-title { font-size: 1.8rem; color: var(--dark); }

/* ── SERVICE CARDS ── */
.service-card { border: 1px solid var(--border); border-radius: var(--radius); transition: transform .2s, box-shadow .2s; color: var(--text) !important; }
.service-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); border-color: var(--primary); }
.service-icon { font-size: 2.5rem; }

/* ── LISTING CARD ── */
.listing-card { border-radius: var(--radius); overflow: hidden; border: 1px solid var(--border); transition: box-shadow .2s, transform .2s; }
.listing-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.listing-card .card-img-top { height: 180px; object-fit: cover; }
.listing-price { font-size: 1.2rem; font-weight: 700; color: var(--primary); font-family: 'Rajdhani', sans-serif; }
.listing-badge-featured { position: absolute; top: 10px; left: 10px; background: var(--accent); color: #fff; font-size: .7rem; font-weight: 700; padding: 3px 8px; border-radius: 20px; }
.listing-meta { font-size: .78rem; color: var(--muted); }

/* ── BRAND CARD ── */
.brand-card { border-radius: var(--radius); border: 1px solid var(--border); transition: all .2s; }
.brand-card:hover { background: var(--primary); color: #fff !important; border-color: var(--primary); }
.brand-card:hover * { color: #fff !important; }

/* ── BLOG CARD ── */
.blog-card { border-radius: var(--radius); border: 1px solid var(--border); overflow: hidden; transition: box-shadow .2s; }
.blog-card:hover { box-shadow: var(--shadow); }

/* ── REVIEW CARD ── */
.review-card { border-radius: var(--radius); border: 1px solid var(--border); }
.stars { font-size: 1rem; }

/* ── CTA ── */
.cta-section { background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dk) 100%); }

/* ── VEHICLE DETAIL PAGE ── */
.vehicle-detail-img { border-radius: var(--radius); overflow: hidden; }
.vehicle-data-table td { padding: .5rem 0; border-bottom: 1px solid var(--border); }
.vehicle-data-label { color: var(--muted); font-size: .85rem; width: 40%; }
.parivahan-badge { display: inline-flex; align-items: center; gap: 6px; background: #ecfdf5; color: #065f46; padding: 6px 14px; border-radius: 20px; font-size: .85rem; font-weight: 600; }

/* ── CHALLAN ── */
.challan-card { border-left: 4px solid var(--danger); }
.challan-paid { border-left-color: var(--success); }

/* ── FORMS ── */
.form-label { font-weight: 600; font-size: .9rem; }
.form-control, .form-select { border-radius: 8px; border-color: var(--border); }
.form-control:focus, .form-select:focus { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(26,86,219,.15); }

/* ── ADMIN SIDEBAR ── */
.admin-sidebar { width: 260px; min-height: 100vh; background: var(--dark); position: fixed; top: 0; left: 0; z-index: 1000; overflow-y: auto; }
.admin-sidebar .logo { padding: 1.5rem; font-family: 'Rajdhani'; font-size: 1.4rem; color: #fff; font-weight: 700; border-bottom: 1px solid rgba(255,255,255,.1); }
.admin-sidebar .logo span { color: var(--accent); }
.sidebar-nav .nav-link { color: rgba(255,255,255,.75); padding: .6rem 1.5rem; font-weight: 500; display: flex; align-items: center; gap: 10px; }
.sidebar-nav .nav-link:hover, .sidebar-nav .nav-link.active { color: #fff; background: rgba(255,255,255,.1); }
.admin-content { margin-left: 260px; padding: 2rem; }
.stat-card { border-radius: var(--radius); padding: 1.5rem; color: #fff; }
.stat-card .num { font-size: 2.2rem; font-weight: 700; font-family: 'Rajdhani'; }

/* ── USER DASHBOARD ── */
.user-sidebar { background: var(--bg-light); border-radius: var(--radius); padding: 1.5rem; }
.user-avatar { width: 80px; height: 80px; border-radius: 50%; object-fit: cover; }

/* ── DEALER CRM ── */
.crm-pipeline { display: flex; gap: 1rem; overflow-x: auto; padding: 1rem 0; }
.crm-column { min-width: 250px; background: var(--bg-light); border-radius: var(--radius); padding: 1rem; }
.crm-column-header { font-weight: 700; padding: .5rem; border-radius: 8px; margin-bottom: 1rem; text-align: center; }
.crm-card { background: #fff; border-radius: 8px; padding: 1rem; margin-bottom: .75rem; border: 1px solid var(--border); cursor: grab; font-size: .85rem; }

/* ── EMI CALCULATOR ── */
.emi-result-box { background: linear-gradient(135deg, var(--primary), var(--primary-dk)); color: #fff; border-radius: var(--radius); padding: 2rem; text-align: center; }
.emi-amount { font-size: 2.5rem; font-family: 'Rajdhani'; font-weight: 700; }

/* ── COMPARE ── */
.compare-table th { background: var(--primary); color: #fff; }
.compare-table td { vertical-align: middle; }
.compare-better { color: var(--success); font-weight: 600; }

/* ── ALERTS ── */
.alert-parivahan { background: #eff6ff; border: 1px solid #bfdbfe; color: #1e40af; border-radius: var(--radius); }

/* ── FOOTER ── */
.site-footer { background: var(--dark); color: rgba(255,255,255,.75); padding: 3rem 0 1rem; }
.site-footer h6 { color: #fff; font-weight: 700; margin-bottom: 1rem; }
.site-footer a { color: rgba(255,255,255,.65); text-decoration: none; }
.site-footer a:hover { color: var(--accent); }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.1); padding-top: 1rem; margin-top: 2rem; font-size: .85rem; }

/* ── RESPONSIVE ── */
@media (max-width: 768px) {
  .admin-sidebar { width: 100%; min-height: auto; position: relative; }
  .admin-content { margin-left: 0; padding: 1rem; }
  .hero-section { min-height: auto; padding: 60px 0 40px; }
  .crm-pipeline { flex-direction: column; }
}

/* ── UTILITIES ── */
.text-primary { color: var(--primary) !important; }
.bg-primary { background-color: var(--primary) !important; }
.btn-primary { background: var(--primary); border-color: var(--primary); }
.btn-primary:hover { background: var(--primary-dk); border-color: var(--primary-dk); }
.badge-verified { background: #ecfdf5; color: #065f46; font-size: .75rem; padding: 3px 8px; border-radius: 20px; }
.badge-pending { background: #fef3c7; color: #92400e; }
.badge-rejected { background: #fee2e2; color: #991b1b; }
.img-placeholder { background: var(--bg-light); display: flex; align-items: center; justify-content: center; color: var(--muted); font-size: 3rem; }
