:root {
  --bg: #0d1117;
  --card: #151b23;
  --text: #e6edf3;
  --muted: #9da7b3;
  --accent: #8b5cf6;
  --accent2: #06b6d4;
}
* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: 'Cairo', 'Segoe UI', Tahoma, sans-serif;
  color: var(--text);
  background: radial-gradient(circle at top right, #202938 0%, var(--bg) 45%), linear-gradient(120deg, #0d1117, #111827 60%, #1f2937);
}
.page-loader { position: fixed; inset: 0; display: grid; place-content: center; gap: 1rem; background: #04070d; z-index: 9999; transition: opacity .5s ease, visibility .5s ease; }
.page-loader.hidden { opacity: 0; visibility: hidden; }
.loader-road { width: 220px; height: 70px; position: relative; overflow: hidden; }
.loader-trail { position: absolute; top: 34px; left: 0; right: 0; height: 2px; background: repeating-linear-gradient(90deg, rgba(99,102,241,.95) 0 16px, transparent 16px 30px); animation: trailMove .7s linear infinite; }
.loader-car { position: absolute; top: 6px; left: 50%; transform: translateX(-50%); font-size: 2.3rem; filter: drop-shadow(0 0 14px rgba(99,102,241,.65)); animation: carBounce .45s ease-in-out infinite alternate; }
.loader-text { margin: 0; color: #8b5cf6; text-align: center; font-weight: 700; font-size: 1.15rem; letter-spacing: .5px; }
@keyframes trailMove { from { background-position-x: 0; } to { background-position-x: 46px; } }
@keyframes carBounce { from { transform: translateX(-50%) translateY(0); } to { transform: translateX(-50%) translateY(-5px); } }

.navbar { position: sticky; top: 0; display: flex; justify-content: space-between; align-items: center; padding: .9rem 6vw; z-index: 50; gap: 1rem; }
.glass { background: rgba(20,28,39,.75); backdrop-filter: blur(12px); border: 1px solid rgba(255,255,255,.08); border-radius: 16px; }
.brand { font-size: 1.4rem; font-weight: 700; color: var(--text); text-decoration: none; }

.nav-menu { display: flex; align-items: center; gap: 1rem; margin-inline-start: auto; }
.navbar nav { display: flex; align-items: center; gap: .6rem; }
.navbar nav a {
  color: var(--text);
  text-decoration: none;
  padding: .45rem .75rem;
  border-radius: 10px;
  transition: background .2s ease, color .2s ease;
}
.navbar nav a:hover { background: rgba(139,92,246,.2); color: #fff; }

.nav-toggle {
  display: none;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(15,23,34,.85);
  padding: .6rem;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 5px;
}

.nav-toggle span {
  width: 100%;
  height: 2px;
  border-radius: 99px;
  background: #fff;
  transition: transform .25s ease, opacity .25s ease;
}

.nav-toggle.active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle.active span:nth-child(2) { opacity: 0; }
.nav-toggle.active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.chip { display: inline-block; padding: .35rem .8rem; border-radius: 999px; border: 1px solid rgba(255,255,255,.2); color: var(--text); text-decoration: none; }
.chip.active { background: var(--accent); border-color: var(--accent); }

.container { width: min(1200px, 92vw); margin: 2rem auto; }
.section { margin-top: 2rem; }
.hero { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; align-items: center; }
.hero h1 { font-size: clamp(1.7rem, 4vw, 3rem); }
.hero-gallery { display: grid; grid-template-columns: 1fr 1fr; gap: .7rem; }
.hero-gallery img { width: 100%; border-radius: 18px; height: 240px; object-fit: cover; animation: float 4s ease-in-out infinite; }
.hero-gallery img:nth-child(2) { animation-delay: .5s; }
@keyframes float { 50% { transform: translateY(-10px); } }
.hero-mini { color: var(--muted); }

.btn-primary, .btn-secondary, .danger-btn { padding: .8rem 1.2rem; border-radius: 12px; text-decoration: none; border: none; cursor: pointer; color: #fff; font-weight: 600; }
.btn-primary { background: linear-gradient(130deg, var(--accent), #6d28d9); }
.btn-secondary { background: linear-gradient(130deg, var(--accent2), #0ea5e9); display:inline-block; text-align:center; }
.danger-btn { background: linear-gradient(130deg, #ef4444, #dc2626); padding: .45rem .7rem; font-size: .85rem; }
.hero-actions { display: flex; gap: .8rem; }

.categories-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px,1fr)); gap: .8rem; margin-top: 1rem; }
.category-card { background: var(--card); color: var(--text); padding: 1rem; border-radius: 14px; text-decoration: none; display: flex; justify-content: space-between; }
.categories-hero-grid { grid-template-columns: repeat(auto-fit, minmax(240px,1fr)); }
.category-large { padding: 0; overflow: hidden; min-height: 240px; display: grid; grid-template-rows: 170px 1fr; border: 1px solid rgba(255,255,255,.1); }
.category-large img { width: 100%; height: 170px; object-fit: cover; }
.category-large div { padding: 1rem; display: grid; gap: .25rem; }
.category-large strong { font-size: 1.2rem; }
.category-large span { color: var(--muted); }
.car-list { display: grid; gap: 1rem; margin-top: 1rem; }
.compact { grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
.car-card { background: var(--card); border: 1px solid rgba(255,255,255,.08); border-radius: 18px; overflow: hidden; }
.car-card img { width: 100%; height: 210px; object-fit: cover; }
.car-info { padding: 1rem; }

.showcase { display: grid; grid-template-columns: 1.1fr 1fr; }
.showcase-body { padding: 1rem; }
.specs-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: .5rem; margin: .8rem 0; }

.car-description-card {
  margin: .8rem 0;
  padding: .8rem .9rem;
  background: rgba(139,92,246,.14);
  border: 1px solid rgba(139,92,246,.3);
  border-radius: 12px;
}

.car-description-text {
  margin: 0;
  line-height: 1.8;
  color: #e5e7eb;
  white-space: normal;
  word-break: break-word;
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.car-description-card.expanded .car-description-text {
  display: block;
  overflow: visible;
}

.desc-toggle-btn {
  margin-top: .55rem;
  border: none;
  background: transparent;
  color: var(--accent2);
  font-weight: 700;
  cursor: pointer;
  padding: 0;
}
.showcase-footer { display: flex; gap: .7rem; align-items: center; flex-wrap: wrap; }
.status.available { color: #4ade80; }
.status.reserved { color: #f97316; }
.map { width: 100%; min-height: 360px; border-radius: 16px; border: 0; }
.terms-block ul, .terms-block ol { line-height: 2; color: var(--muted); }
.footer { text-align: center; padding: 2rem 1rem; color: var(--muted); }

.showcase-media { position: relative; min-height: 260px; }
.carousel-track { position: relative; height: 100%; }
.carousel-image { display: none; width: 100%; height: 100%; min-height: 300px; object-fit: cover; }
.carousel-image.active { display: block; }
.carousel-btn { position: absolute; top: 50%; transform: translateY(-50%); border: none; width: 40px; height: 40px; border-radius: 50%; background: rgba(13,17,23,.65); color: #fff; cursor: pointer; z-index: 2; }
.carousel-btn.prev { left: 12px; }
.carousel-btn.next { right: 12px; }
.carousel-dots { position: absolute; bottom: 12px; left: 50%; transform: translateX(-50%); display: flex; gap: 8px; }
.carousel-dots span { width: 10px; height: 10px; border-radius: 50%; background: rgba(255,255,255,.4); cursor: pointer; }
.carousel-dots span.active { background: var(--accent); }


body.modal-open { overflow: hidden; }

.carousel-image { cursor: zoom-in; }

.car-modal {
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .25s ease, visibility .25s ease;
  z-index: 110;
  padding: 1rem;
}

.car-modal.open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.car-modal-overlay {
  position: absolute;
  inset: 0;
  background: rgba(1, 4, 9, 0.78);
}

.car-modal-content {
  width: min(920px, 100%);
  max-height: min(88vh, 760px);
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 60px 1fr 60px;
  grid-template-rows: 1fr auto;
  gap: .75rem;
  padding: 1rem;
  align-items: center;
}

#car-modal-image {
  width: 100%;
  max-height: 68vh;
  border-radius: 12px;
  object-fit: contain;
  background: #030712;
  grid-column: 2;
}

.car-modal-close {
  position: absolute;
  top: .6rem;
  right: .6rem;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.3);
  background: rgba(7,11,18,.8);
  color: #fff;
  cursor: pointer;
}

.car-modal-nav {
  border: none;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: rgba(7,11,18,.8);
  color: #fff;
  font-size: 1.15rem;
  cursor: pointer;
}

.car-modal-nav.prev { grid-column: 1; }
.car-modal-nav.next { grid-column: 3; }

.car-modal-footer {
  grid-column: 1 / -1;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: .8rem;
  flex-wrap: wrap;
}

.car-modal-footer h3 { margin: 0; font-size: 1.05rem; }
.car-modal-footer p { margin: 0; color: var(--muted); }

.admin-layout { width: min(1300px, 94vw); margin: 2rem auto; display: grid; grid-template-columns: 300px 1fr; gap: 1rem; font-size: 1.08rem; }
.admin-sidebar { padding: 1rem; display: grid; gap: .5rem; height: fit-content; }
.admin-sidebar a { color: var(--text); text-decoration: none; padding: .85rem; background: #121821; border-radius: 10px; font-size: 1.08rem; }
.admin-main { background: var(--card); border-radius: 16px; padding: 1.25rem; }
.admin-main h1 { font-size: 2rem; margin-top: 0; }
.admin-form { display: grid; grid-template-columns: repeat(auto-fit,minmax(220px,1fr)); gap: .7rem; }
.admin-form input, .admin-form select, .admin-form textarea { padding: .9rem; font-size: 1.05rem; border-radius: 10px; border: 1px solid #2d3748; background: #0f1722; color: #fff; }
.admin-form textarea { min-height: 90px; grid-column: 1/-1; }
.image-upload-box { grid-column: 1/-1; border: 1px dashed #4b5563; border-radius: 14px; padding: 1rem; display:grid; gap:.5rem; }
.hidden-input { display:none; }
.preview-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(200px,1fr)); gap: .8rem; grid-column: 1/-1; }
.preview-item { background:#0f1722; padding:.5rem; border-radius:10px; display:grid; gap:.5rem; }
.preview-grid img { width: 100%; height: 180px; object-fit: contain; background:#030712; border-radius: 8px; }
.status-row { display:flex; justify-content: space-between; align-items:center; padding: .8rem; margin-bottom: .7rem; }
.admin-login { min-height: 100vh; display: grid; place-content: center; }
.login-form { width: min(420px, 92vw); display: grid; gap: .9rem; padding: 1.7rem; font-size: 1.08rem; }
.error { color: #ef4444; }
.stats-grid { display:grid; grid-template-columns: repeat(auto-fit,minmax(170px,1fr)); gap: .7rem; }
.stat-card { padding: 1rem; }

.edit-cars-grid { display:grid; gap: 1rem; }
.car-edit-card { padding: 1rem; border:1px solid rgba(255,255,255,.1); }
.existing-images-grid { display:grid; grid-template-columns: repeat(auto-fit,minmax(170px,1fr)); gap:.7rem; margin: .8rem 0 1rem; }
.existing-image-item { background:#0f1722; padding:.5rem; border-radius:10px; display:grid; gap:.5rem; }
.existing-image-item img { width:100%; height:120px; object-fit:cover; border-radius:8px; }
.file-label { grid-column: 1/-1; display:grid; gap:.4rem; padding:.7rem; border:1px dashed #4b5563; border-radius:10px; }

.form-actions { grid-column: 1/-1; display:flex; justify-content:flex-start; }
.delete-car-form { margin-top: .8rem; display:flex; justify-content:flex-end; }

.reveal { opacity: 0; transform: translateY(24px); transition: all .6s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }
@media (max-width: 900px) {
  .hero, .showcase, .admin-layout, .hero-modern, .latest-grid { grid-template-columns: 1fr; }

  .navbar { padding: .8rem 4vw; }
  .nav-toggle { display: inline-flex; }

  .nav-menu {
    position: absolute;
    top: calc(100% + .6rem);
    inset-inline: 4vw;
    margin: 0;
    padding: .9rem;
    border-radius: 14px;
    border: 1px solid rgba(255,255,255,.12);
    background: linear-gradient(165deg, rgba(17,24,39,.96), rgba(8,13,22,.96));
    box-shadow: 0 14px 32px rgba(1, 5, 12, .5);
    display: grid;
    gap: .8rem;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-8px);
    pointer-events: none;
    transition: opacity .22s ease, transform .22s ease, visibility .22s ease;
  }

  .nav-menu.open {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: auto;
  }

  .navbar nav { display: grid; gap: .35rem; }
  .navbar nav a { background: rgba(255,255,255,.04); }
  .lang-switcher { display: flex; gap: .5rem; }
  .car-description-text { -webkit-line-clamp: 5; }

  /* Hero mobile fixes */
  .hero-modern { min-height: auto; border-radius: 0; padding-bottom: 1rem; }
  .hero-modern-visual { display: none !important; }
  .hero-modern-content { order: 1; width: 100%; }
  .hero-modern .container { width: min(92vw, 92vw); margin: 1.2rem auto; }
  .hero-modern h1 { font-size: clamp(1.8rem, 7vw, 2.5rem); }
  .hero-modern p { font-size: 1rem; }

  /* Home latest cards should show image clearly */
  .latest-grid { grid-template-columns: 1fr; }
  .latest-card img { height: 260px; object-fit: cover; }

  /* Category pills should not overlap */
  .category-pill-bar {
    display: block !important;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x proximity;
  }
  .category-pill {
    flex: 0 0 180px;
    min-width: 180px;
    white-space: nowrap;
    border: 2px solid #20293C;
    border-inline-end: 1px solid rgba(255,255,255,.08);
    border-bottom:none;
    font-size:.95rem;
    scroll-snap-align: start;
  }

  .car-modal-content {
    grid-template-columns: 44px 1fr 44px;
    padding: .8rem;
  }

  #car-modal-image { max-height: 62vh; }
}

.hero-modern {
  width: 100%;
  margin: 0;
  min-height: 560px;
  border-radius: 0;
  overflow: hidden;
  position: relative;
  background: linear-gradient(120deg, #0b1220 0%, #111827 45%, #1f2937 100%);
  color: #e5e7eb;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  border: 1px solid rgba(255,255,255,.08);
}
.hero-modern::before {
  content: '';
  position: absolute;
  width: 65%;
  height: 160%;
  inset-inline-end: -12%;
  top: -26%;
  background: radial-gradient(circle, rgba(139,92,246,.28), rgba(6,182,212,.06) 55%, transparent 68%);
  transform: rotate(-12deg);
}
.hero-modern-content { z-index: 2; }
.hero-modern h1 { font-size: clamp(2rem, 4.4vw, 4rem); line-height: 1.12; margin: .4rem 0 1rem; color: #f8fafc; }
.hero-modern p { color: #cbd5e1; max-width: 580px; font-size: 1.18rem; }
.hero-kicker { color: #38bdf8 !important; font-weight: 700; margin: 0; }
.hero-modern-visual { height: 100%; display:grid; place-items:center; position: relative; z-index:2; }
.hero-modern-visual::before {
  content:'';
  position:absolute;
  width: 420px;
  height: 420px;
  border-radius: 34% 66% 70% 30% / 30% 43% 57% 70%;
  background: linear-gradient(145deg, rgba(99,102,241,.24), rgba(6,182,212,.18));
  filter: blur(1px);
}
.hero-modern-visual img { width: min(96%, 700px); object-fit: contain; z-index: 2; filter: drop-shadow(0 22px 30px rgba(0,0,0,.55)); }

.hero-modern.hero-ar .hero-modern-content { order: 2; }
.hero-modern.hero-ar .hero-modern-visual { order: 1; }

.category-pill-bar {
  background: linear-gradient(135deg, #111827, #0f172a);
  border-radius: 18px;
  display: flex;
  border: 1px solid rgba(255,255,255,.1);
  overflow: hidden;
}
.category-pill { display:flex; align-items:center; justify-content:center; gap:.65rem; padding: .85rem 1rem; flex: 1 1 0; min-width: 0; text-decoration:none; color:#e5e7eb; border-inline-end:1px solid rgba(255,255,255,.08); font-weight:700; transition: background .2s ease, color .2s ease; }
.category-pill:last-child { border-inline-end: none; }
.category-pill img { width:58px; height:32px; object-fit:contain; filter: drop-shadow(0 5px 8px rgba(0,0,0,.35)); }
.category-pill:hover { background:rgba(99,102,241,.16); color:#c4b5fd; }

.latest-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
.latest-card { border:1px solid rgba(255,255,255,.12); }
.latest-meta { display:flex; justify-content:space-between; align-items:center; margin-top:.6rem; }
.all-cars-cta { display:flex; justify-content:center; margin-top:1.2rem; }
.all-cars-btn { min-width: 220px; text-align:center; box-shadow: 0 12px 24px rgba(79,70,229,.35); }

.status-select {
  background: linear-gradient(145deg, #101827, #111b2a);
  color: #fff;
  border: 1px solid #374151;
  border-radius: 12px;
  padding: .65rem 2.1rem .65rem .9rem;
  font-size: 1rem;
  appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, #cbd5e1 50%), linear-gradient(135deg, #cbd5e1 50%, transparent 50%);
  background-position: calc(100% - 18px) calc(50% - 3px), calc(100% - 12px) calc(50% - 3px);
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
}
.status-select:focus { outline:none; border-color: var(--accent2); box-shadow: 0 0 0 3px rgba(6,182,212,.18); }

.admin-submit-loading {
  position: fixed;
  inset: 0;
  background: rgba(2,6,13,.76);
  backdrop-filter: blur(3px);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 300;
}
.admin-submit-loading.show { display:flex; }
.admin-submit-card { padding: 1.2rem 1.4rem; display:grid; gap:.7rem; justify-items:center; }
.admin-submit-card .mini-loader { width:44px; height:44px; border: 4px solid rgba(255,255,255,.2); border-top-color:#6366f1; border-radius:50%; animation: spin 1s linear infinite; }
.admin-submit-card p { margin:0; font-weight:700; }

@keyframes spin { to { transform: rotate(360deg); } }


.admin-sidebar a.active {
  background: linear-gradient(135deg, rgba(139,92,246,.85), rgba(6,182,212,.75));
  border: 1px solid rgba(255,255,255,.2);
}

.admin-login {
  background: radial-gradient(circle at 15% 12%, rgba(139,92,246,.28) 0, transparent 34%), radial-gradient(circle at 80% 80%, rgba(6,182,212,.24) 0, transparent 28%);
}

.login-form {
  border: 1px solid rgba(255,255,255,.15);
  box-shadow: 0 24px 45px rgba(2,6,12,.5);
}

.login-form h1 { margin: 0; }

.input-group { display: grid; gap: .4rem; }

.input-group input {
  width: 100%;
  padding: .95rem 1rem;
  border-radius: 12px;
  border: 1px solid #364152;
  background: linear-gradient(180deg, #101827, #0f1722);
  color: #fff;
  font-size: 1rem;
  outline: none;
  transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}

.input-group input:focus {
  border-color: var(--accent2);
  box-shadow: 0 0 0 3px rgba(6,182,212,.22);
  transform: translateY(-1px);
}