/* ============================================================
   Sri Laxmi Auto Consulting Udumalai — Public Site CSS
   ============================================================ */

/* ── Variables ─────────────────────────────────────────────── */
:root {
  --color-primary:    #1e3a5f;
  --color-primary-dk: #162d4a;
  --color-accent:     #e8a21a;
  --color-accent-dk:  #c98c15;
  --color-wa:         #25d366;
  --color-wa-dk:      #128c7e;
  --color-text:       #1a202c;
  --color-text-muted: #6b7280;
  --color-bg:         #ffffff;
  --color-bg-light:   #f7f9fc;
  --color-border:     #e5e7eb;
  --color-success:    #10b981;
  --color-danger:     #ef4444;
  --radius-sm:   6px;
  --radius:      10px;
  --radius-lg:   16px;
  --shadow-sm:   0 1px 4px rgba(0,0,0,0.07);
  --shadow:      0 4px 16px rgba(0,0,0,0.1);
  --shadow-lg:   0 8px 32px rgba(0,0,0,0.14);
  --transition:  all 0.2s ease;
  --font-body:   'Inter', 'Segoe UI', system-ui, -apple-system, sans-serif;
}

/* ── Reset & Base ──────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: var(--font-body); font-size: 1rem; color: var(--color-text); background: var(--color-bg); line-height: 1.6; -webkit-font-smoothing: antialiased; }
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
a:hover { color: var(--color-accent); }
ul { list-style: none; }
button { cursor: pointer; }

/* ── Container ──────────────────────────────────────────────── */
.container { max-width: 1200px; margin: 0 auto; padding: 0 1.25rem; }

/* ── Announcement Bar ──────────────────────────────────────── */
.announcement-bar {
  background: var(--color-primary-dk); color: #c8d6e5;
  font-size: 0.82rem; padding: 0.4rem 0; text-align: center;
}
.announcement-bar a { color: var(--color-accent); }
.announcement-bar .container { display: flex; justify-content: center; align-items: center; flex-wrap: wrap; gap: 0.25rem; }
.d-none { display: none; }
@media (min-width: 768px) { .d-none.d-md-inline { display: inline !important; } }

/* ── Site Header ────────────────────────────────────────────── */
.site-header {
  background: var(--color-bg); border-bottom: 2px solid var(--color-border);
  position: sticky; top: 0; z-index: 500; box-shadow: var(--shadow-sm);
  transition: box-shadow 0.3s;
}
.site-header.scrolled { box-shadow: var(--shadow); }

.header-inner {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0.75rem 0;
}

/* Logo */
.site-logo { display: flex; align-items: center; gap: 0.6rem; }
.site-logo .logo-icon { width: 36px; height: 36px; background: var(--color-primary); color: var(--color-accent); display: flex; align-items: center; justify-content: center; border-radius: 8px; font-size: 1.2rem; flex-shrink: 0; }
.site-logo .logo-name { display: block; font-weight: 700; font-size: 1rem; color: var(--color-primary); line-height: 1.2; }
.site-logo .logo-sub  { display: block; font-size: 0.7rem; color: var(--color-text-muted); }

/* Desktop Nav */
.site-nav { display: flex; align-items: center; gap: 0.25rem; }
.site-nav .nav-item {
  padding: 0.45rem 0.85rem; border-radius: var(--radius-sm);
  font-size: 0.9rem; font-weight: 500; color: var(--color-text);
  transition: var(--transition);
}
.site-nav .nav-item:hover, .site-nav .nav-item.active { background: var(--color-bg-light); color: var(--color-primary); }
.site-nav .btn-admin-login {
  display: inline-flex; align-items: center; gap: 0.3rem;
  background: transparent; color: var(--color-primary);
  border: 1.5px solid var(--color-primary); padding: 0.38rem 0.85rem;
  border-radius: 20px; font-size: 0.82rem; font-weight: 600;
  transition: var(--transition);
}
.site-nav .btn-admin-login:hover { background: var(--color-primary); color: #fff; }

.site-nav .btn-wa {
  display: inline-flex; align-items: center; gap: 0.35rem;
  background: var(--color-wa); color: #fff; padding: 0.4rem 0.9rem;
  border-radius: 20px; font-size: 0.85rem; font-weight: 600;
  transition: var(--transition);
}
.site-nav .btn-wa:hover { background: var(--color-wa-dk); color: #fff; }
.site-nav .btn-wa svg { flex-shrink: 0; }

/* Mobile Menu Button */
.mobile-menu-btn { display: none; background: none; border: none; padding: 0.4rem; cursor: pointer; }
.mobile-menu-btn span { display: block; width: 22px; height: 2px; background: var(--color-primary); margin: 4px 0; border-radius: 2px; transition: var(--transition); }

/* Mobile Nav */
.mobile-nav { display: none; border-top: 1px solid var(--color-border); }
.mobile-nav nav { padding: 0.75rem 1.25rem 1rem; display: flex; flex-direction: column; gap: 0.25rem; }
.mobile-nav a { padding: 0.6rem 0.5rem; font-size: 0.95rem; font-weight: 500; border-radius: var(--radius-sm); }
.mobile-nav a:hover, .mobile-nav a.active { background: var(--color-bg-light); color: var(--color-primary); }
.mobile-nav .mobile-cta { background: var(--color-primary); color: #fff !important; text-align: center; margin-top: 0.5rem; padding: 0.6rem; border-radius: var(--radius); font-weight: 600; }

@media (max-width: 767px) {
  .site-nav { display: none; }
  .mobile-menu-btn { display: block; }
  .mobile-nav.open { display: block; }
}

/* ── Buttons ────────────────────────────────────────────────── */
.btn-primary {
  display: inline-block; background: var(--color-primary); color: #fff;
  padding: 0.65rem 1.5rem; border-radius: var(--radius); font-weight: 600;
  font-size: 0.9rem; border: none; transition: var(--transition); cursor: pointer;
}
.btn-primary:hover { background: var(--color-primary-dk); color: #fff; transform: translateY(-1px); }

.btn-secondary {
  display: inline-block; background: transparent; color: var(--color-primary);
  padding: 0.6rem 1.4rem; border-radius: var(--radius); font-weight: 600;
  font-size: 0.9rem; border: 2px solid var(--color-primary); transition: var(--transition);
}
.btn-secondary:hover { background: var(--color-primary); color: #fff; }

.btn-full { width: 100%; text-align: center; }

/* WhatsApp buttons */
.btn-outline-wa {
  display: inline-flex; align-items: center; gap: 0.4rem;
  background: transparent; color: var(--color-wa); border: 2px solid var(--color-wa);
  padding: 0.6rem 1.4rem; border-radius: var(--radius); font-weight: 600; font-size: 0.9rem;
  transition: var(--transition);
}
.btn-outline-wa:hover { background: var(--color-wa); color: #fff; }

.btn-wa-solid {
  display: inline-block; background: var(--color-wa); color: #fff;
  padding: 0.65rem 1.5rem; border-radius: var(--radius); font-weight: 600; font-size: 0.9rem;
  transition: var(--transition);
}
.btn-wa-solid:hover { background: var(--color-wa-dk); color: #fff; }

/* ── Flash Messages ─────────────────────────────────────────── */
.flash-message {
  padding: 0.85rem 1.25rem; border-radius: var(--radius); margin: 1rem 0;
  font-weight: 500; font-size: 0.9rem;
}
.flash-success { background: #d1fae5; color: #065f46; border-left: 4px solid #10b981; }
.flash-error   { background: #fee2e2; color: #991b1b; border-left: 4px solid #ef4444; }
.flash-warning { background: #fef3c7; color: #92400e; border-left: 4px solid #f59e0b; }
.flash-info    { background: #e0f2fe; color: #0c4a6e; border-left: 4px solid #0ea5e9; }

/* ── Hero Section ───────────────────────────────────────────── */
.hero-section {
  position: relative; background: var(--color-primary);
  min-height: 520px; display: flex; align-items: center;
  overflow: hidden;
}
.hero-overlay { position: absolute; inset: 0; background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><circle cx="20" cy="80" r="50" fill="rgba(232,162,26,0.06)"/><circle cx="80" cy="20" r="40" fill="rgba(232,162,26,0.04)"/></svg>') no-repeat center/cover; }
.hero-content { position: relative; width: 100%; display: flex; align-items: flex-start; gap: 2rem; flex-wrap: wrap; padding: 3rem 1.25rem; justify-content: center; }
.hero-text { flex: 1; min-width: 280px; max-width: 580px; color: #fff; }
.hero-text h1 { font-size: clamp(1.6rem, 4vw, 2.4rem); font-weight: 800; line-height: 1.2; margin-bottom: 1rem; }
.text-accent { color: var(--color-accent); }
.hero-text > p { font-size: 1rem; color: rgba(255,255,255,0.85); margin-bottom: 1.5rem; line-height: 1.7; }
.hero-stats { display: flex; gap: 1.5rem; margin-bottom: 1.5rem; flex-wrap: wrap; }
.hero-stat { text-align: center; }
.stat-value { display: block; font-size: 1.6rem; font-weight: 800; color: var(--color-accent); line-height: 1; }
.stat-label { font-size: 0.78rem; color: rgba(255,255,255,0.7); text-transform: uppercase; letter-spacing: 0.5px; }
.hero-actions { display: flex; gap: 0.75rem; flex-wrap: wrap; }

/* Hero Search Card */
.hero-search-card {
  background: #fff; border-radius: var(--radius-lg); padding: 1.5rem;
  width: 100%; max-width: 340px; box-shadow: var(--shadow-lg);
  flex-shrink: 0;
}
.hero-search-card h3 { font-size: 1rem; font-weight: 700; color: var(--color-primary); margin-bottom: 1rem; }
.hero-search-form { display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem; }
.form-group { display: flex; flex-direction: column; gap: 0.25rem; }
.form-group label { font-size: 0.75rem; font-weight: 600; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.5px; }
.form-group select,
.form-group input,
.form-group textarea { border: 1.5px solid var(--color-border); border-radius: var(--radius-sm); padding: 0.5rem 0.75rem; font-size: 0.88rem; font-family: var(--font-body); background: #fff; color: var(--color-text); transition: border-color 0.2s; width: 100%; }
.form-group select:focus,
.form-group input:focus,
.form-group textarea:focus { outline: none; border-color: var(--color-primary); box-shadow: 0 0 0 3px rgba(30,58,95,0.1); }
.form-group.has-error select,
.form-group.has-error input,
.form-group.has-error textarea { border-color: var(--color-danger); }
.field-error { font-size: 0.78rem; color: var(--color-danger); }
.required { color: var(--color-danger); }
.form-group-full { grid-column: 1 / -1; }
.btn-search-full { width: 100%; background: var(--color-accent); color: var(--color-primary); border: none; padding: 0.65rem; border-radius: var(--radius-sm); font-weight: 700; font-size: 0.9rem; cursor: pointer; transition: var(--transition); }
.btn-search-full:hover { background: var(--color-accent-dk); }

/* ── Page Banner ────────────────────────────────────────────── */
.page-banner { background: var(--color-primary); color: #fff; padding: 2.5rem 0; }
.page-banner h1 { font-size: clamp(1.4rem, 3vw, 2rem); font-weight: 800; margin: 0.5rem 0 0.25rem; }
.page-banner p { color: rgba(255,255,255,0.8); font-size: 0.95rem; }
.page-banner .breadcrumb { display: flex; gap: 0.5rem; font-size: 0.82rem; color: rgba(255,255,255,0.6); margin-bottom: 0.5rem; }
.page-banner .breadcrumb a { color: var(--color-accent); }
.page-banner .breadcrumb li::after { content: ' /'; }
.page-banner .breadcrumb li:last-child::after { content: ''; }
.page-banner-sm { padding: 1.5rem 0; }
.page-banner-note { margin-top: 0.5rem !important; font-style: italic; }

/* ── Sections ───────────────────────────────────────────────── */
.section-vehicles { padding: 4rem 0; }
.bg-light-section { background: var(--color-bg-light); }
.section-header { text-align: center; margin-bottom: 2.5rem; }
.section-header h2 { font-size: clamp(1.4rem, 3vw, 1.9rem); font-weight: 700; color: var(--color-primary); }
.section-header p { color: var(--color-text-muted); margin-top: 0.5rem; }
.section-cta { text-align: center; margin-top: 2rem; }
.empty-state { text-align: center; padding: 4rem 1rem; color: var(--color-text-muted); }
.empty-state .empty-icon { font-size: 3rem; margin-bottom: 1rem; }
.empty-state h3 { font-size: 1.2rem; font-weight: 600; margin-bottom: 0.5rem; }
.empty-state p { margin-bottom: 1rem; }

/* ── Vehicle Cards Grid ─────────────────────────────────────── */
.vehicles-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 1.25rem; }

.vehicle-card {
  background: #fff; border-radius: var(--radius-lg); overflow: hidden;
  box-shadow: var(--shadow-sm); transition: var(--transition); position: relative;
  border: 1px solid var(--color-border);
}
.vehicle-card:hover { box-shadow: var(--shadow); transform: translateY(-3px); }

.card-img-link { display: block; overflow: hidden; }
.card-img { width: 100%; height: 190px; object-fit: cover; transition: transform 0.3s; }
.card-img-link:hover .card-img { transform: scale(1.04); }
.card-img-wrap { position: relative; }

.badge-featured {
  position: absolute; top: 0.6rem; left: 0.6rem;
  background: var(--color-accent); color: var(--color-primary);
  font-size: 0.7rem; font-weight: 700; padding: 0.2rem 0.6rem; border-radius: 20px;
  text-transform: uppercase; letter-spacing: 0.5px;
}

.card-body { padding: 1rem; }
.card-meta { display: flex; gap: 0.5rem; margin-bottom: 0.4rem; }
.card-year, .card-make { font-size: 0.75rem; font-weight: 600; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.4px; }
.card-title { font-size: 0.97rem; font-weight: 700; margin-bottom: 0.3rem; line-height: 1.3; }
.card-title a:hover { color: var(--color-primary); }
.card-reg { font-size: 0.78rem; color: var(--color-text-muted); margin-bottom: 0.3rem; font-family: monospace; }
.card-desc { font-size: 0.8rem; color: var(--color-text-muted); margin-bottom: 0.5rem; line-height: 1.5; }
.card-price { font-size: 1.1rem; font-weight: 800; color: var(--color-primary); margin-bottom: 0.75rem; }
.card-actions { display: flex; gap: 0.5rem; }
.btn-card-view {
  flex: 1; text-align: center; padding: 0.45rem; border-radius: var(--radius-sm);
  font-size: 0.82rem; font-weight: 600; background: var(--color-primary); color: #fff;
  transition: var(--transition);
}
.btn-card-view:hover { background: var(--color-primary-dk); color: #fff; }
.btn-card-wa {
  padding: 0.45rem 0.75rem; border-radius: var(--radius-sm); border: 1.5px solid var(--color-wa);
  color: var(--color-wa); font-size: 0.82rem; font-weight: 600; transition: var(--transition);
}
.btn-card-wa:hover { background: var(--color-wa); color: #fff; }

/* Sold Cards */
.vehicle-card-sold { opacity: 0.85; }
.badge-sold-overlay { position: absolute; top: 0.5rem; right: 0.5rem; background: var(--color-danger); color: #fff; font-size: 0.72rem; font-weight: 700; padding: 0.2rem 0.6rem; border-radius: 20px; text-transform: uppercase; }
.sold-label { font-size: 0.8rem; color: var(--color-danger); font-weight: 600; margin-top: 0.5rem; }
.sold-notice { background: #fef3c7; border-left: 4px solid #f59e0b; padding: 0.75rem 1rem; border-radius: var(--radius-sm); font-size: 0.85rem; color: #92400e; margin-bottom: 1rem; }

/* ── Listing Layout (sidebar + grid) ──────────────────────────── */
.vehicles-listing-section { padding: 3rem 0; }
.listing-layout { display: grid; grid-template-columns: 240px 1fr; gap: 1.5rem; align-items: start; }

/* Filter Sidebar */
.filter-sidebar { position: sticky; top: 80px; }
.filter-card { background: #fff; border-radius: var(--radius-lg); border: 1px solid var(--color-border); padding: 1.25rem; }
.filter-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 1rem; }
.filter-header h2 { font-size: 0.95rem; font-weight: 700; color: var(--color-primary); }
.filter-reset { font-size: 0.78rem; color: var(--color-accent); font-weight: 600; }
.filter-group { margin-bottom: 0.9rem; }
.filter-group label { display: block; font-size: 0.75rem; font-weight: 600; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.4px; margin-bottom: 0.3rem; }
.filter-group select,
.filter-group input { width: 100%; border: 1.5px solid var(--color-border); border-radius: var(--radius-sm); padding: 0.45rem 0.7rem; font-size: 0.85rem; }
.filter-group select:focus,
.filter-group input:focus { outline: none; border-color: var(--color-primary); }
.btn-apply-filter { width: 100%; background: var(--color-primary); color: #fff; border: none; padding: 0.6rem; border-radius: var(--radius-sm); font-weight: 600; font-size: 0.9rem; cursor: pointer; transition: var(--transition); }
.btn-apply-filter:hover { background: var(--color-primary-dk); }
.btn-filter-toggle { display: none; position: fixed; bottom: 1.5rem; right: 1.5rem; background: var(--color-primary); color: #fff; border: none; border-radius: 50px; padding: 0.7rem 1.2rem; font-size: 0.9rem; font-weight: 600; box-shadow: var(--shadow); gap: 0.4rem; align-items: center; z-index: 200; }

.listing-info { font-size: 0.82rem; color: var(--color-text-muted); margin-bottom: 1rem; }

@media (max-width: 767px) {
  /* Hero */
  .hero-content { padding: 2rem 1.25rem; gap: 1.5rem; }
  .hero-search-card { max-width: 100%; }
  .hero-search-form { grid-template-columns: 1fr; }
  /* Vehicles grid: 2 cols on phones ≥ 480px, 1 col below */
  .vehicles-grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); }
}

@media (max-width: 479px) {
  .vehicles-grid { grid-template-columns: 1fr; }
}

@media (max-width: 767px) {
  .listing-layout { grid-template-columns: 1fr; }
  .filter-sidebar { position: static; }
  .filter-card { display: none; }
  .filter-card.open { display: block; margin-bottom: 1rem; }
  .btn-filter-toggle { display: flex; position: static; width: 100%; justify-content: center; border-radius: var(--radius); margin-bottom: 1rem; bottom: auto; right: auto; }
}

/* ── Why Choose Us ──────────────────────────────────────────── */
.section-why { padding: 4rem 0; }
.why-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 1.5rem; }
.why-card { background: #fff; border-radius: var(--radius-lg); padding: 1.5rem; border: 1px solid var(--color-border); text-align: center; }
.why-icon { font-size: 2rem; margin-bottom: 0.75rem; color: var(--color-accent); }
.why-card h3 { font-size: 1rem; font-weight: 700; color: var(--color-primary); margin-bottom: 0.4rem; }
.why-card p { font-size: 0.85rem; color: var(--color-text-muted); }

/* ── CTA Banner ─────────────────────────────────────────────── */
.section-cta-banner { background: var(--color-primary); padding: 3.5rem 0; }
.cta-banner-content { text-align: center; color: #fff; }
.cta-banner-content h2 { font-size: clamp(1.3rem, 3vw, 1.8rem); font-weight: 800; margin-bottom: 0.75rem; }
.cta-banner-content p { color: rgba(255,255,255,0.8); margin-bottom: 1.5rem; }
.cta-banner-actions { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }
.btn-white { background: #fff; color: var(--color-primary); padding: 0.65rem 1.5rem; border-radius: var(--radius); font-weight: 700; font-size: 0.9rem; transition: var(--transition); }
.btn-white:hover { background: var(--color-accent); color: var(--color-primary); }

/* ── Vehicle Detail ─────────────────────────────────────────── */
.vehicle-detail-section { padding: 3rem 0; }
.detail-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }
.gallery-main { position: relative; border-radius: var(--radius-lg); overflow: hidden; background: var(--color-bg-light); margin-bottom: 0.75rem; }
.gallery-main-img { width: 100%; height: 320px; object-fit: cover; }
.gallery-status { position: absolute; top: 0.75rem; left: 0.75rem; background: var(--color-success); color: #fff; font-size: 0.78rem; font-weight: 700; padding: 0.25rem 0.7rem; border-radius: 20px; text-transform: uppercase; }
.gallery-thumbs { display: flex; gap: 0.5rem; }
.gallery-thumb { width: 70px; height: 55px; object-fit: cover; border-radius: var(--radius-sm); cursor: pointer; border: 2px solid transparent; transition: var(--transition); }
.gallery-thumb:hover, .gallery-thumb.active { border-color: var(--color-accent); }

.detail-badge-row { display: flex; gap: 0.5rem; margin-bottom: 0.75rem; flex-wrap: wrap; }
.badge-available-lg { background: #d1fae5; color: #065f46; padding: 0.3rem 0.9rem; border-radius: 20px; font-size: 0.82rem; font-weight: 700; }
.badge-available-sm { background: #d1fae5; color: #065f46; padding: 0.15rem 0.6rem; border-radius: 20px; font-size: 0.78rem; font-weight: 600; }

.detail-info h1 { font-size: clamp(1.2rem, 3vw, 1.6rem); font-weight: 800; color: var(--color-primary); margin-bottom: 0.5rem; }
.detail-price { font-size: 1.8rem; font-weight: 800; color: var(--color-accent); margin-bottom: 1.25rem; }
.detail-specs { border: 1px solid var(--color-border); border-radius: var(--radius); overflow: hidden; margin-bottom: 1.25rem; }
.spec-row { display: flex; border-bottom: 1px solid var(--color-border); }
.spec-row:last-child { border-bottom: none; }
.spec-label { width: 130px; padding: 0.6rem 0.9rem; font-size: 0.82rem; font-weight: 600; color: var(--color-text-muted); background: var(--color-bg-light); flex-shrink: 0; }
.spec-value { padding: 0.6rem 0.9rem; font-size: 0.88rem; color: var(--color-text); flex: 1; }
.detail-price-row { font-weight: 700; color: var(--color-accent); font-size: 1rem; }

.detail-description { margin-bottom: 1.25rem; }
.detail-description h2 { font-size: 1rem; font-weight: 700; margin-bottom: 0.4rem; }
.detail-description p { font-size: 0.9rem; color: var(--color-text-muted); line-height: 1.7; }

.detail-cta { display: flex; gap: 0.75rem; flex-wrap: wrap; margin-bottom: 1.25rem; }
.btn-call-lg {
  display: inline-flex; align-items: center; gap: 0.5rem;
  background: var(--color-primary); color: #fff; padding: 0.75rem 1.5rem;
  border-radius: var(--radius); font-weight: 600; font-size: 0.9rem; transition: var(--transition);
}
.btn-call-lg:hover { background: var(--color-primary-dk); color: #fff; }
.btn-wa-lg {
  display: inline-flex; align-items: center; gap: 0.5rem;
  background: var(--color-wa); color: #fff; padding: 0.75rem 1.5rem;
  border-radius: var(--radius); font-weight: 600; font-size: 0.9rem; transition: var(--transition);
}
.btn-wa-lg:hover { background: var(--color-wa-dk); color: #fff; }

.detail-seller { background: var(--color-bg-light); border-radius: var(--radius); padding: 1rem; font-size: 0.85rem; color: var(--color-text-muted); }
.detail-seller h3 { font-size: 0.88rem; font-weight: 700; color: var(--color-primary); margin-bottom: 0.4rem; }
.detail-seller a { color: var(--color-accent); }

.detail-back { margin-top: 2rem; }

@media (max-width: 767px) {
  .detail-layout { grid-template-columns: 1fr; }
  .gallery-main-img { height: 240px; }
}

/* ── About Page ─────────────────────────────────────────────── */
.about-section { padding: 3.5rem 0; }
.about-layout { display: grid; grid-template-columns: 1fr 340px; gap: 2.5rem; align-items: start; }
.about-content h2 { font-size: 1.3rem; font-weight: 700; color: var(--color-primary); margin: 1.5rem 0 0.5rem; }
.about-content h2:first-child { margin-top: 0; }
.about-content p { color: var(--color-text-muted); line-height: 1.8; margin-bottom: 0.75rem; font-size: 0.95rem; }
.about-list { padding-left: 1.5rem; list-style: disc; margin-bottom: 0.75rem; }
.about-list li { color: var(--color-text-muted); font-size: 0.9rem; line-height: 1.8; }
.about-quote { border-left: 4px solid var(--color-accent); padding: 0.75rem 1.25rem; background: var(--color-bg-light); border-radius: 0 var(--radius-sm) var(--radius-sm) 0; font-style: italic; color: var(--color-primary); margin: 1.5rem 0; }
.about-contact-box { border: 1px solid var(--color-border); border-radius: var(--radius); padding: 1.25rem; margin: 1rem 0 1.5rem; }
.about-contact-item { font-size: 0.9rem; margin-bottom: 0.6rem; color: var(--color-text-muted); }
.about-contact-item strong { color: var(--color-text); margin-right: 0.5rem; }
.about-contact-item a { color: var(--color-accent); }
.about-cta { display: flex; gap: 1rem; flex-wrap: wrap; }

.about-highlights { background: var(--color-primary); color: #fff; border-radius: var(--radius-lg); padding: 1.5rem; margin-bottom: 1rem; }
.about-highlights h3 { font-size: 1rem; font-weight: 700; margin-bottom: 1rem; color: var(--color-accent); }
.highlight-item { display: flex; gap: 0.75rem; margin-bottom: 1rem; align-items: flex-start; }
.highlight-item:last-child { margin-bottom: 0; }
.highlight-icon { font-size: 1.2rem; color: var(--color-accent); flex-shrink: 0; margin-top: 0.1rem; }
.highlight-item strong { display: block; font-size: 0.9rem; margin-bottom: 0.1rem; }
.highlight-item p { font-size: 0.8rem; color: rgba(255,255,255,0.7); margin: 0; }

.about-cta-card { background: var(--color-bg-light); border-radius: var(--radius-lg); padding: 1.25rem; border: 1px solid var(--color-border); }
.about-cta-card h3 { font-size: 0.95rem; font-weight: 700; margin-bottom: 0.4rem; }
.about-cta-card p { font-size: 0.85rem; color: var(--color-text-muted); margin-bottom: 0.75rem; }
.btn-call-block, .btn-wa-block { display: block; text-align: center; padding: 0.6rem; border-radius: var(--radius-sm); font-weight: 600; font-size: 0.88rem; margin-bottom: 0.5rem; transition: var(--transition); }
.btn-call-block { background: var(--color-primary); color: #fff; }
.btn-call-block:hover { background: var(--color-primary-dk); color: #fff; }
.btn-wa-block { background: var(--color-wa); color: #fff; }
.btn-wa-block:hover { background: var(--color-wa-dk); color: #fff; }

@media (max-width: 900px) {
  .about-layout { grid-template-columns: 1fr; }
  .about-sidebar { order: -1; }
  .about-highlights { display: grid; grid-template-columns: 1fr 1fr; gap: 0.5rem; }
  .about-highlights h3 { grid-column: 1 / -1; }
}

/* ── Contact Page ───────────────────────────────────────────── */
.contact-section { padding: 3.5rem 0; }
.contact-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 2.5rem; align-items: start; }
.contact-info h2 { font-size: 1.3rem; font-weight: 700; color: var(--color-primary); margin-bottom: 1.5rem; }
.contact-card { display: flex; gap: 1rem; background: var(--color-bg-light); border-radius: var(--radius); padding: 1rem; margin-bottom: 0.75rem; border: 1px solid var(--color-border); }
.contact-icon { font-size: 1.5rem; color: var(--color-accent); flex-shrink: 0; }
.contact-card h3 { font-size: 0.9rem; font-weight: 700; color: var(--color-primary); margin-bottom: 0.2rem; }
.contact-card p { font-size: 0.85rem; color: var(--color-text-muted); }
.contact-link { color: var(--color-accent); font-weight: 600; }
.btn-wa-contact { display: inline-block; background: var(--color-wa); color: #fff; padding: 0.4rem 1rem; border-radius: 20px; font-size: 0.82rem; font-weight: 600; margin-top: 0.5rem; transition: var(--transition); }
.btn-wa-contact:hover { background: var(--color-wa-dk); color: #fff; }
.map-placeholder { background: var(--color-bg-light); border-radius: var(--radius); padding: 1.5rem; text-align: center; border: 1px dashed var(--color-border); margin-top: 1rem; color: var(--color-text-muted); font-size: 0.9rem; }

.contact-form-wrap h2 { font-size: 1.3rem; font-weight: 700; color: var(--color-primary); margin-bottom: 1.5rem; }
.enquiry-form .form-group { margin-bottom: 1rem; }

@media (max-width: 767px) {
  .contact-layout { grid-template-columns: 1fr; }
}

/* ── Pagination ─────────────────────────────────────────────── */
.pagination-wrap { text-align: center; padding: 2rem 0 1rem; }
.pagination { display: inline-flex; gap: 0.35rem; flex-wrap: wrap; justify-content: center; margin-bottom: 0.5rem; }
.page-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px; border-radius: var(--radius-sm);
  border: 1.5px solid var(--color-border); font-size: 0.85rem; font-weight: 500;
  color: var(--color-text); background: #fff; transition: var(--transition);
}
.page-btn:hover { border-color: var(--color-primary); color: var(--color-primary); }
.page-btn.active { background: var(--color-primary); border-color: var(--color-primary); color: #fff; }
.page-ellipsis { display: inline-flex; align-items: center; justify-content: center; width: 36px; height: 36px; color: var(--color-text-muted); }
.pagination-info { font-size: 0.8rem; color: var(--color-text-muted); }

/* ── Site Footer ────────────────────────────────────────────── */
.site-footer { background: var(--color-primary); color: rgba(255,255,255,0.85); padding: 3rem 0 0; }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1.5fr; gap: 2.5rem; padding-bottom: 2.5rem; }
.footer-logo { display: flex; align-items: center; gap: 0.6rem; margin-bottom: 1rem; }
.footer-logo .logo-icon { width: 36px; height: 36px; background: var(--color-accent); color: var(--color-primary); display: flex; align-items: center; justify-content: center; border-radius: 8px; font-size: 1.2rem; flex-shrink: 0; }
.footer-logo .logo-name { color: #fff; font-size: 0.95rem; }
.footer-logo .logo-sub  { color: rgba(255,255,255,0.6); font-size: 0.7rem; }
.footer-brand p { font-size: 0.85rem; line-height: 1.7; margin-bottom: 1rem; color: rgba(255,255,255,0.7); }
.btn-footer-wa { display: inline-block; background: var(--color-wa); color: #fff; padding: 0.5rem 1.2rem; border-radius: 20px; font-size: 0.85rem; font-weight: 600; transition: var(--transition); }
.btn-footer-wa:hover { background: var(--color-wa-dk); color: #fff; }

.footer-links h4, .footer-contact h4 { font-size: 0.9rem; font-weight: 700; color: #fff; margin-bottom: 1rem; text-transform: uppercase; letter-spacing: 0.5px; }
.footer-links ul li { margin-bottom: 0.5rem; }
.footer-links a, .footer-contact a { font-size: 0.85rem; color: rgba(255,255,255,0.7); transition: color 0.2s; }
.footer-links a:hover, .footer-contact a:hover { color: var(--color-accent); }
.footer-contact ul li { display: flex; gap: 0.5rem; align-items: flex-start; font-size: 0.85rem; color: rgba(255,255,255,0.75); margin-bottom: 0.6rem; }
.footer-contact svg { flex-shrink: 0; margin-top: 0.15rem; color: var(--color-accent); }

.footer-bottom { border-top: 1px solid rgba(255,255,255,0.1); padding: 1.25rem 0; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 0.5rem; }
.footer-bottom p { font-size: 0.8rem; color: rgba(255,255,255,0.5); margin: 0; }
.footer-disclaimer { font-style: italic; }

@media (max-width: 767px) {
  .footer-grid { grid-template-columns: 1fr; gap: 1.5rem; }
  .footer-bottom { flex-direction: column; text-align: center; }
}

/* ── PWA Install Banner ─────────────────────────────────────── */
.pwa-install-banner {
  position: fixed; bottom: 0; left: 0; right: 0; background: var(--color-primary);
  color: #fff; padding: 0.85rem 1.25rem; display: flex;
  justify-content: space-between; align-items: center; z-index: 1000;
  box-shadow: 0 -4px 16px rgba(0,0,0,0.15); gap: 1rem; flex-wrap: wrap;
}
.pwa-install-content { display: flex; align-items: center; gap: 0.75rem; }
.pwa-install-icon { width: 40px; height: 40px; background: var(--color-accent); border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 1.3rem; color: var(--color-primary); flex-shrink: 0; }
.pwa-install-content strong { display: block; font-size: 0.9rem; }
.pwa-install-content small { font-size: 0.78rem; color: rgba(255,255,255,0.7); }
.pwa-install-actions { display: flex; gap: 0.5rem; align-items: center; }
.btn-pwa-install { background: var(--color-accent); color: var(--color-primary); border: none; padding: 0.5rem 1.2rem; border-radius: 20px; font-weight: 700; font-size: 0.85rem; cursor: pointer; transition: var(--transition); }
.btn-pwa-install:hover { background: var(--color-accent-dk); }
.btn-pwa-dismiss { background: transparent; border: none; color: rgba(255,255,255,0.7); font-size: 1.2rem; cursor: pointer; padding: 0.25rem; line-height: 1; }
.btn-pwa-dismiss:hover { color: #fff; }

/* ── Misc / Utility ─────────────────────────────────────────── */
.mx-3 { margin: 0 0.75rem; }
.no-image-svg { opacity: 0.4; }
