/* ══════════════════════════════════════
   DESIGN TOKENS — DARK / LIGHT
══════════════════════════════════════ */
:root {
  --gold: #c9a84c;
  --gold-light: #e8c96a;
  --red: #e05a3a;
  --green: #3a7c52;
  --green-text: #6fcf97;
  --trans: 0.28s ease;
}

[data-theme="dark"] {
  --bg:       #0a0a0a;
  --surface:  #111111;
  --surface2: #1a1a1a;
  --white:    #f0ece4;
  --muted:    #666;
  --border:   #222;
  --nav-bg:   rgba(10,10,10,0.88);
  --input-bg: #0a0a0a;
  --shadow:   rgba(0,0,0,0.6);
}

[data-theme="light"] {
  --bg:       #f5f2ed;
  --surface:  #ffffff;
  --surface2: #ece8e1;
  --white:    #1a1714;
  --muted:    #888;
  --border:   #ddd8d0;
  --nav-bg:   rgba(245,242,237,0.92);
  --input-bg: #f5f2ed;
  --shadow:   rgba(0,0,0,0.12);
}

/* ══════════════════════════════════════
   BASE
══════════════════════════════════════ */
* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  background: var(--bg);
  color: var(--white);
  font-family: 'DM Sans', sans-serif;
  min-height: 100vh;
  overflow-x: hidden;
  transition: background var(--trans), color var(--trans);
}

/* ══════════════════════════════════════
   NAV
══════════════════════════════════════ */
nav {
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:1.2rem 3rem;
  background: var(--nav-bg);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--border);
  transition: background var(--trans), border-color var(--trans);
}
.logo {
  font-family:'Bebas Neue',sans-serif;
  font-size:1.8rem; letter-spacing:3px;
  color:var(--gold); cursor:pointer;
}
.logo span { color:var(--white); }
.nav-tagline {
  font-size:0.7rem; letter-spacing:4px;
  text-transform:uppercase; color:var(--muted);
}
.nav-right { display:flex; gap:0.6rem; align-items:center; }

.nav-btn {
  font-size:0.72rem; letter-spacing:2px; text-transform:uppercase;
  padding:0.45rem 1.1rem; cursor:pointer; transition:all 0.2s;
  border:1px solid var(--gold); color:var(--gold); background:none;
  font-family:'DM Sans',sans-serif;
}
.nav-btn:hover { background:var(--gold); color:var(--bg); }
.nav-btn.ghost { border-color:var(--muted); color:var(--muted); }
.nav-btn.ghost:hover { border-color:var(--white); color:var(--white); background:none; }

/* Lang Switcher */
.lang-switcher { display:flex; gap:2px; }
.lang-btn {
  font-size:0.65rem; letter-spacing:1px;
  padding:0.3rem 0.5rem; cursor:pointer;
  border:1px solid var(--border); background:none;
  color:var(--muted); transition:all 0.15s;
  font-family:'DM Sans',sans-serif;
}
.lang-btn.active { border-color:var(--gold); color:var(--gold); }
.lang-btn:hover { color:var(--white); }

/* Theme toggle */
.theme-toggle {
  width:36px; height:36px; border:1px solid var(--border);
  background:none; cursor:pointer; color:var(--muted);
  display:flex; align-items:center; justify-content:center;
  transition:all 0.15s; font-size:1rem;
}
.theme-toggle:hover { color:var(--gold); border-color:var(--gold); }

/* ══════════════════════════════════════
   PAGES
══════════════════════════════════════ */
.page { display:none; }
.page.active { display:block; }

/* ══════════════════════════════════════
   HERO
══════════════════════════════════════ */
#home { padding-top:80px; }
.hero {
  position:relative; height:65vh;
  display:flex; align-items:flex-end;
  padding:4rem 3rem; overflow:hidden;
}
[data-theme="dark"] .hero { background:linear-gradient(135deg,#0a0a0a 0%,#111 40%,#0d0d0d 100%); }
[data-theme="light"] .hero { background:linear-gradient(135deg,#ede9e2 0%,#f0ece4 40%,#e8e4dc 100%); }

.hero::before {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 80% 60% at 70% 50%, rgba(201,168,76,0.08) 0%,transparent 70%),
    radial-gradient(ellipse 40% 40% at 20% 80%, rgba(201,168,76,0.04) 0%,transparent 60%);
}
.hero-bg {
  position:absolute; inset:0; z-index:0;
  background-size:cover; background-position:center;
}
.hero-bg iframe {
  position:absolute; top:50%; left:50%;
  width:100vw; height:56.25vw;
  min-height:100%; min-width:177.78vh;
  transform:translate(-50%,-50%);
  pointer-events:none; border:none;
}
.hero-overlay {
  position:absolute; inset:0; z-index:1;
  background:rgba(0,0,0,0.55);
  display:none;
}
.hero-overlay.active { display:block; }
.hero-grid-lines {
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(201,168,76,0.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(201,168,76,0.04) 1px,transparent 1px);
  background-size:60px 60px;
}
.hero-content { position:relative; z-index:1; }
.hero-label {
  text-align:center; font-size:0.7rem; letter-spacing:5px; text-transform:uppercase;
  color:var(--gold); margin-bottom:1rem;
}
.hero-title {
  text-align:center; font-family:'Bebas Neue',sans-serif;
  font-size:clamp(4rem,10vw,9rem); line-height:0.9; letter-spacing:2px; color:var(--gold);
}
.hero-title em { color:var(--gold); font-style:normal; }
.hero-sub { 
  text-align:center; margin-top:1.5rem; font-size:0.9rem; color: #ffffff; max-width:380px; line-height:1.6; font-weight:300; }
.hero-badge {
  position:absolute; right:3rem; top:50%; transform:translateY(-50%);
  width:120px; height:120px; border:1px solid var(--gold); border-radius:50%;
  display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center;
  animation:spin-slow 20s linear infinite;
}
.hero-badge-inner { font-family:'Bebas Neue',sans-serif; font-size:2rem; color:var(--gold); line-height:1; }
.hero-badge-text { font-size:0.55rem; letter-spacing:2px; color:var(--muted); text-transform:uppercase; }
@keyframes spin-slow { to { transform:translateY(-50%) rotate(360deg); } }

/* ══════════════════════════════════════
   FLEET
══════════════════════════════════════ */
.section-header {
  display:flex; align-items:baseline; justify-content:space-between;
  padding:3rem 3rem 1.5rem;
}
.section-title { font-family:'Bebas Neue',sans-serif; font-size:2.5rem; letter-spacing:3px; color:var(--white); }
.section-line { flex:1; height:1px; background:var(--border); margin:0 1.5rem; }
.section-count { font-size:0.7rem; letter-spacing:3px; color:var(--muted); text-transform:uppercase; }

.car-grid {
  display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
  gap:1px; background:var(--border); margin:0 3rem 4rem;
  border:1px solid var(--border);
}
.car-card {
  background:var(--surface); cursor:pointer; position:relative; overflow:hidden;
  transition:background var(--trans);
}
.car-card:hover { background:var(--surface2); }
.car-card:hover .car-card-img { transform:scale(1.04); }
.car-card:hover .card-arrow { transform:translate(4px,-4px); opacity:1; }

.car-card-img-wrap { height:200px; overflow:hidden; position:relative; background:var(--surface2); }
.car-card-img { width:100%; height:100%; object-fit:cover; transition:transform 0.5s ease; filter:brightness(0.9); }
.car-card-badge {
  position:absolute; top:1rem; left:1rem;
  font-size:0.6rem; letter-spacing:2px; text-transform:uppercase;
  padding:0.3rem 0.6rem; border:1px solid var(--gold); color:var(--gold);
  background:rgba(10,10,10,0.8);
}
.car-card-body { padding:1.5rem; }
.car-card-brand { font-size:0.65rem; letter-spacing:3px; text-transform:uppercase; color:var(--gold); margin-bottom:0.4rem; }
.car-card-name { font-family:'Bebas Neue',sans-serif; font-size:1.8rem; letter-spacing:2px; color:var(--white); margin-bottom:0.8rem; }
.car-card-specs { display:flex; gap:1.2rem; margin-bottom:1.2rem; }
.spec { display:flex; flex-direction:column; gap:0.2rem; }
.spec-label { font-size:0.6rem; letter-spacing:2px; text-transform:uppercase; color:var(--muted); }
.spec-value { font-size:0.85rem; font-weight:500; color:var(--white); }
.car-card-footer {
  display:flex; align-items:center; justify-content:space-between;
  padding-top:1rem; border-top:1px solid var(--border);
}
.car-price { display:flex; align-items:baseline; gap:0.3rem; }
.price-amount { font-family:'Bebas Neue',sans-serif; font-size:1.8rem; color:var(--gold); }
.price-unit { font-size:0.65rem; color:var(--muted); letter-spacing:1px; }
.card-arrow { font-size:1.1rem; color:var(--gold); opacity:0.5; transition:all 0.3s; }

/* ══════════════════════════════════════
   CAR DETAIL
══════════════════════════════════════ */
#car-detail { padding-top:80px; min-height:100vh; }
.detail-hero { position:relative; height:55vh; overflow:hidden; background:var(--surface); }
.detail-hero-img { width:100%; height:100%; object-fit:cover; filter:brightness(0.55); }
.detail-hero-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to right,rgba(10,10,10,0.9) 0%,transparent 60%),
             linear-gradient(to top,rgba(10,10,10,0.7) 0%,transparent 50%);
}
.detail-hero-content { position:absolute; bottom:2.5rem; left:3rem; }
.back-btn {
  display:inline-flex; align-items:center; gap:0.5rem;
  font-size:0.7rem; letter-spacing:3px; text-transform:uppercase;
  color:var(--muted); cursor:pointer; margin-bottom:1.2rem;
  transition:color 0.2s; background:none; border:none;
}
.back-btn:hover { color:var(--white); }
.detail-brand { font-size:0.7rem; letter-spacing:4px; text-transform:uppercase; color:var(--gold); margin-bottom:0.4rem; }
.detail-name { font-family:'Bebas Neue',sans-serif; font-size:clamp(3rem,7vw,6rem); letter-spacing:3px; line-height:1; color:var(--white); }
.detail-price-tag { margin-top:0.8rem; display:flex; align-items:baseline; gap:0.4rem; }
.detail-price { font-family:'Bebas Neue',sans-serif; font-size:2.2rem; color:var(--gold); }
.detail-price-unit { font-size:0.75rem; color:var(--muted); letter-spacing:1px; }

.detail-body { display:grid; grid-template-columns:1fr 420px; gap:0; min-height:60vh; }
.detail-specs-panel { padding:3rem; border-right:1px solid var(--border); }
.panel-title { font-family:'Bebas Neue',sans-serif; font-size:1.2rem; letter-spacing:3px; color:var(--muted); margin-bottom:2rem; }
.specs-grid { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem 2rem; margin-bottom:2.5rem; }
.spec-item-label { font-size:0.6rem; letter-spacing:3px; text-transform:uppercase; color:var(--muted); margin-bottom:0.3rem; }
.spec-item-value { font-size:1rem; font-weight:500; color:var(--white); }
.detail-desc { font-size:0.85rem; color:var(--muted); line-height:1.8; font-weight:300; border-top:1px solid var(--border); padding-top:2rem; }

.booking-panel { background:var(--surface); padding:3rem 2.5rem; border-left:1px solid var(--border); }
.booking-title { font-family:'Bebas Neue',sans-serif; font-size:1.8rem; letter-spacing:3px; color:var(--white); margin-bottom:0.4rem; }
.booking-subtitle { font-size:0.72rem; color:var(--muted); letter-spacing:1px; margin-bottom:2rem; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.form-group { margin-bottom:1.2rem; display:flex; flex-direction:column; gap:0.4rem; }
.form-group.full { grid-column:1/-1; }
.form-label { font-size:0.6rem; letter-spacing:2px; text-transform:uppercase; color:var(--muted); }
.form-input {
  background:var(--input-bg); border:1px solid var(--border);
  color:var(--white); padding:0.75rem 1rem;
  font-family:'DM Sans',sans-serif; font-size:0.85rem;
  outline:none; transition:border-color 0.2s, background var(--trans), color var(--trans);
  width:100%;
}
.form-input:focus { border-color:var(--gold); }
.form-input::placeholder { color:var(--border); }
.form-input.error { border-color:var(--red); }
.form-select {
  appearance:none; -webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23c9a84c' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 1rem center;
  padding-right:2.5rem; cursor:pointer; color:var(--white);
}
.form-select option, .form-select optgroup { background:var(--surface2); color:var(--white); }
.form-input[type="date"]::-webkit-calendar-picker-indicator { filter:invert(0.4); cursor:pointer; }

.book-btn {
  width:100%; background:var(--gold); color:var(--bg);
  border:none; padding:1rem; cursor:pointer;
  font-family:'Bebas Neue',sans-serif; font-size:1.1rem; letter-spacing:3px;
  transition:background 0.2s; display:flex; align-items:center; justify-content:center; gap:0.6rem;
  margin-top:0.5rem;
}
.book-btn:hover { background:var(--gold-light); }
.book-btn svg { width:18px; height:18px; fill:currentColor; }
.wa-note { font-size:0.65rem; color:var(--muted); text-align:center; margin-top:0.8rem; letter-spacing:1px; }
.wa-note span { color:var(--gold); }

/* ══════════════════════════════════════
   FOOTER
══════════════════════════════════════ */
footer {
  display:flex; align-items:center; justify-content:space-between;
  padding:2rem 3rem; border-top:1px solid var(--border);
  background:var(--surface);
}
.footer-logo { font-family:'Bebas Neue',sans-serif; font-size:1.3rem; letter-spacing:3px; color:var(--gold); }
.footer-text { font-size:0.7rem; color:var(--muted); letter-spacing:1px; }
.footer-socials { display:flex; gap:0.5rem; }
.social-link {
  display:flex; align-items:center; justify-content:center;
  width:38px; height:38px; border:1px solid var(--border);
  color:var(--muted); text-decoration:none; transition:all 0.2s;
}
.social-link svg { width:16px; height:16px; fill:currentColor; }
.social-link:hover { border-color:var(--gold); color:var(--gold); transform:translateY(-2px); }
.social-link.wa:hover { border-color:#25d366; color:#25d366; }
.social-link.fb:hover { border-color:#1877f2; color:#1877f2; }
.social-link.ig:hover { border-color:#e1306c; color:#e1306c; }
.social-link.tt:hover { border-color:#fff; color:#fff; }

/* ══════════════════════════════════════
   ADMIN LOGIN
══════════════════════════════════════ */
#admin-login, #admin-dashboard { padding-top:80px; min-height:100vh; }

.login-wrap {
  display:flex; align-items:center; justify-content:center;
  min-height:calc(100vh - 80px);
  background:radial-gradient(ellipse 60% 50% at 50% 40%, rgba(201,168,76,0.06) 0%,transparent 70%);
}
.login-box {
  background:var(--surface); border:1px solid var(--border);
  padding:3rem 2.5rem; width:100%; max-width:380px;
  box-shadow:0 24px 60px var(--shadow);
}
.login-title { font-family:'Bebas Neue',sans-serif; font-size:2rem; letter-spacing:3px; color:var(--gold); margin-bottom:0.3rem; }
.login-sub { font-size:0.7rem; color:var(--muted); letter-spacing:2px; margin-bottom:2rem; }
.login-btn {
  width:100%; background:var(--gold); color:var(--bg);
  border:none; padding:0.85rem;
  font-family:'Bebas Neue',sans-serif; font-size:1rem; letter-spacing:3px;
  cursor:pointer; transition:background 0.2s; margin-top:0.5rem;
}
.login-btn:hover { background:var(--gold-light); }
.login-btn:disabled { opacity:0.6; cursor:not-allowed; }
.login-error { font-size:0.7rem; color:var(--red); margin-top:0.6rem; letter-spacing:1px; display:none; }

/* ══════════════════════════════════════
   ADMIN DASHBOARD
══════════════════════════════════════ */
.dash-wrap { display:grid; grid-template-columns:220px 1fr; min-height:calc(100vh - 80px); }
.dash-sidebar {
  background:var(--surface); border-right:1px solid var(--border);
  padding:2rem 0; position:sticky; top:80px; height:calc(100vh - 80px); overflow-y:auto;
  transition:background var(--trans);
}
.dash-sidebar-title { font-size:0.6rem; letter-spacing:3px; text-transform:uppercase; color:var(--muted); padding:0 1.5rem; margin-bottom:1rem; }
.dash-nav-item {
  display:flex; align-items:center; gap:0.7rem;
  padding:0.75rem 1.5rem; font-size:0.82rem; cursor:pointer;
  color:var(--muted); transition:all 0.15s; border-left:2px solid transparent;
}
.dash-nav-item:hover { color:var(--white); background:var(--surface2); }
.dash-nav-item.active { color:var(--gold); border-left-color:var(--gold); background:rgba(201,168,76,0.05); }
.dash-nav-item svg { width:15px; height:15px; fill:currentColor; flex-shrink:0; }
.sidebar-divider { height:1px; background:var(--border); margin:1rem 0; }
.sidebar-logout { display:flex; align-items:center; gap:0.7rem; padding:0.75rem 1.5rem; font-size:0.82rem; cursor:pointer; color:var(--muted); transition:color 0.15s; }
.sidebar-logout:hover { color:var(--red); }
.sidebar-logout svg { width:15px; height:15px; fill:currentColor; }

.dash-main { padding:2.5rem; overflow-y:auto; }
.dash-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:2rem; }
.dash-page-title { font-family:'Bebas Neue',sans-serif; font-size:2rem; letter-spacing:3px; color:var(--white); }
.dash-page-sub { font-size:0.7rem; color:var(--muted); letter-spacing:1px; margin-top:0.2rem; }

.stats-row { display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; margin-bottom:2.5rem; }
.stat-card { background:var(--surface); border:1px solid var(--border); padding:1.5rem; }
.stat-card-label { font-size:0.6rem; letter-spacing:3px; text-transform:uppercase; color:var(--muted); margin-bottom:0.5rem; }
.stat-card-value { font-family:'Bebas Neue',sans-serif; font-size:2.2rem; color:var(--gold); }
.stat-card-sub { font-size:0.65rem; color:var(--muted); margin-top:0.2rem; }

.add-car-btn {
  display:flex; align-items:center; gap:0.5rem;
  background:var(--gold); color:var(--bg); border:none; padding:0.65rem 1.3rem;
  font-family:'Bebas Neue',sans-serif; font-size:0.9rem; letter-spacing:2px;
  cursor:pointer; transition:background 0.2s;
}
.add-car-btn:hover { background:var(--gold-light); }
.add-car-btn svg { width:14px; height:14px; fill:currentColor; }

.cars-table-wrap { background:var(--surface); border:1px solid var(--border); overflow:hidden; overflow-x:auto; }
.cars-table { width:100%; border-collapse:collapse; }
.cars-table th {
  text-align:left; padding:1rem 1.2rem;
  font-size:0.6rem; letter-spacing:3px; text-transform:uppercase;
  color:var(--muted); border-bottom:1px solid var(--border); font-weight:400;
}
.cars-table td { padding:1rem 1.2rem; font-size:0.82rem; border-bottom:1px solid rgba(34,34,34,0.4); vertical-align:middle; }
.cars-table tr:last-child td { border-bottom:none; }
.cars-table tr:hover td { background:var(--surface2); }
.car-thumb { width:56px; height:40px; object-fit:cover; border:1px solid var(--border); }
.car-name-cell .cn { font-weight:500; color:var(--white); }
.car-name-cell .cb { font-size:0.7rem; color:var(--muted); }
.badge-category { font-size:0.6rem; letter-spacing:1px; text-transform:uppercase; padding:0.2rem 0.5rem; border:1px solid var(--border); color:var(--muted); }
.price-cell { font-family:'Bebas Neue',sans-serif; font-size:1.1rem; color:var(--gold); }
.action-btns { display:flex; gap:0.4rem; }
.btn-edit, .btn-del {
  padding:0.35rem 0.7rem; border:1px solid var(--border);
  font-size:0.65rem; letter-spacing:1px; text-transform:uppercase;
  cursor:pointer; transition:all 0.15s; background:none;
  display:flex; align-items:center; gap:0.3rem;
}
.btn-edit { color:var(--gold); }
.btn-edit:hover { background:var(--gold); color:var(--bg); border-color:var(--gold); }
.btn-del { color:var(--red); }
.btn-del:hover { background:var(--red); color:#fff; border-color:var(--red); }
.btn-edit svg, .btn-del svg { width:11px; height:11px; fill:currentColor; }

/* ══════════════════════════════════════
   MODAL
══════════════════════════════════════ */
.modal-overlay {
  display:none; position:fixed; inset:0; z-index:200;
  background:rgba(0,0,0,0.75); backdrop-filter:blur(4px);
  align-items:center; justify-content:center; padding:1.5rem;
}
.modal-overlay.open { display:flex; }
.modal-box {
  background:var(--surface); border:1px solid var(--border);
  width:100%; max-width:560px; max-height:90vh; overflow-y:auto;
  padding:2.5rem; animation:modal-in 0.22s ease;
}
@keyframes modal-in { from{opacity:0;transform:translateY(16px)} to{opacity:1;transform:none} }
.modal-title { font-family:'Bebas Neue',sans-serif; font-size:1.6rem; letter-spacing:3px; color:var(--white); margin-bottom:0.2rem; }
.modal-sub { font-size:0.65rem; color:var(--muted); letter-spacing:1px; margin-bottom:2rem; }
.modal-grid { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.modal-grid .form-group.span2 { grid-column:1/-1; }
.modal-actions { display:flex; gap:0.8rem; margin-top:1.5rem; justify-content:flex-end; }
.btn-cancel {
  padding:0.65rem 1.2rem; border:1px solid var(--border); background:none;
  color:var(--muted); font-size:0.8rem; cursor:pointer; transition:all 0.15s;
}
.btn-cancel:hover { color:var(--white); border-color:var(--white); }
.btn-save {
  padding:0.65rem 1.5rem; background:var(--gold); color:var(--bg);
  border:none; font-family:'Bebas Neue',sans-serif; font-size:0.95rem; letter-spacing:2px;
  cursor:pointer; transition:background 0.15s;
}
.btn-save:hover { background:var(--gold-light); }
.del-modal-text { font-size:0.85rem; color:var(--muted); line-height:1.6; margin-bottom:1.5rem; }
.del-modal-text strong { color:var(--white); }

/* ══════════════════════════════════════
   SETTINGS SECTION
══════════════════════════════════════ */
.settings-box { background:var(--surface); border:1px solid var(--border); padding:2rem; max-width:500px; }
.settings-section { margin-bottom:2rem; }
.settings-section-title { font-family:'Bebas Neue',sans-serif; font-size:1rem; letter-spacing:2px; color:var(--muted); margin-bottom:1rem; padding-bottom:0.5rem; border-bottom:1px solid var(--border); }

/* Password change fields */
.pw-requirements { font-size:0.65rem; color:var(--muted); letter-spacing:1px; margin-top:0.3rem; line-height:1.6; }

/* ══════════════════════════════════════
   TOAST
══════════════════════════════════════ */
.toast {
  position:fixed; bottom:2rem; right:2rem; z-index:300;
  background:var(--surface2); border:1px solid var(--border);
  padding:0.9rem 1.4rem; font-size:0.8rem;
  display:flex; align-items:center; gap:0.6rem;
  opacity:0; transform:translateY(8px);
  transition:all 0.3s; pointer-events:none;
}
.toast.show { opacity:1; transform:none; }
.toast.success { border-color:var(--green); color:var(--green-text); }
.toast.error   { border-color:var(--red); color:var(--red); }
.toast-dot { width:6px; height:6px; border-radius:50%; background:currentColor; flex-shrink:0; }

/* ══════════════════════════════════════
   RTL (Arabic)
══════════════════════════════════════ */
[dir="rtl"] nav { padding:1.2rem 3rem; }
[dir="rtl"] .detail-hero-content { left:auto; right:3rem; }
[dir="rtl"] .section-header { flex-direction:row-reverse; }
[dir="rtl"] .car-card-badge { left:auto; right:1rem; }
[dir="rtl"] .dash-nav-item { border-left:none; border-right:2px solid transparent; flex-direction:row-reverse; }
[dir="rtl"] .dash-nav-item.active { border-right-color:var(--gold); }
[dir="rtl"] .cars-table th, [dir="rtl"] .cars-table td { text-align:right; }
[dir="rtl"] .modal-actions { flex-direction:row-reverse; }
[dir="rtl"] .footer-socials { flex-direction:row-reverse; }
[dir="rtl"] .hero-badge { right:auto; left:3rem; }
[dir="rtl"] .hero-badge { animation:spin-slow-rtl 20s linear infinite; }
@keyframes spin-slow-rtl { to { transform:translateY(-50%) rotate(-360deg); } }
[dir="rtl"] body { font-family:'DM Sans','Segoe UI',Tahoma,sans-serif; }

/* ══════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════ */
@media(max-width:768px) {
  nav { padding:1rem 1.5rem; }
  .nav-tagline { display:none; }
  .hero { padding:3rem 1.5rem; }
  .hero-badge { display:none; }
  .section-header { padding:2rem 1.5rem 1rem; }
  .car-grid { margin:0 1.5rem 3rem; }
  .detail-body { grid-template-columns:1fr; }
  .detail-specs-panel { border-right:none; border-bottom:1px solid var(--border); padding:2rem 1.5rem; }
  .booking-panel { padding:2rem 1.5rem; border-left:none; }
  .detail-hero-content { left:1.5rem; }
  footer { flex-direction:column; gap:0.5rem; text-align:center; }
}
@media(max-width:900px) {
  .dash-wrap { grid-template-columns:1fr; }
  .dash-main { padding:1.5rem; }
  .stats-row { grid-template-columns:1fr 1fr; }
  .modal-grid { grid-template-columns:1fr; }
  .modal-grid .form-group.span2 { grid-column:1; }

  /* Hide vertical sidebar, show horizontal tab bar instead */
  .dash-sidebar { display:none; }
  .dash-mobile-nav {
    display:flex;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    border-bottom:1px solid var(--border);
    background:var(--surface);
    position:sticky;
    top:60px;
    z-index:40;
    padding:0 0.5rem;
  }
  .dash-mobile-nav::-webkit-scrollbar { display:none; }
  .dash-mobile-nav-item {
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:3px;
    padding:0.65rem 1rem;
    font-size:0.68rem;
    letter-spacing:0.8px;
    text-transform:uppercase;
    color:var(--muted);
    cursor:pointer;
    white-space:nowrap;
    border-bottom:2px solid transparent;
    transition:all 0.15s;
    flex-shrink:0;
  }
  .dash-mobile-nav-item svg { width:18px; height:18px; fill:currentColor; }
  .dash-mobile-nav-item:hover { color:var(--white); }
  .dash-mobile-nav-item.active { color:var(--gold); border-bottom-color:var(--gold); }
}

@media(min-width:901px) {
  .dash-mobile-nav { display:none; }
}

/* ══════════════════════════════════════
   AVAILABILITY TOGGLE
══════════════════════════════════════ */
.btn-avail {
  padding:4px 10px; border-radius:4px; border:none; cursor:pointer;
  font-size:0.7rem; font-weight:600; letter-spacing:0.5px;
  transition:opacity 0.2s;
}
.btn-avail.available { background:rgba(34,197,94,0.15); color:#22c55e; }
.btn-avail.unavailable { background:rgba(239,68,68,0.15); color:#ef4444; }
.btn-avail:hover { opacity:0.75; }
.car-row-unavailable { opacity:0.5; }
.car-row-unavailable .car-thumb { filter:grayscale(1); }

/* ══════════════════════════════════════
   FILTERS BAR
══════════════════════════════════════ */
.filters-bar {
  display:flex; align-items:center; gap:1rem; flex-wrap:wrap;
  padding:1rem 3rem; border-bottom:1px solid var(--border);
  background:var(--surface);
}
.search-wrap {
  position:relative; flex:1; min-width:200px;
}
.search-icon {
  position:absolute; left:0.75rem; top:50%; transform:translateY(-50%);
  width:16px; height:16px; color:var(--muted); pointer-events:none;
}
.search-input {
  width:100%; padding:0.55rem 0.75rem 0.55rem 2.2rem;
  background:var(--bg); border:1px solid var(--border); border-radius:6px;
  color:var(--text); font-size:0.85rem; outline:none;
  transition:border-color 0.2s;
}
.search-input:focus { border-color:var(--gold); }
.filter-chips { display:flex; gap:0.4rem; flex-wrap:wrap; }
.chip {
  padding:0.4rem 0.9rem; border-radius:20px; border:1px solid var(--border);
  background:transparent; color:var(--muted); font-size:0.75rem;
  cursor:pointer; letter-spacing:0.5px; transition:all 0.2s;
}
.chip:hover { border-color:var(--gold); color:var(--gold); }
.chip.active { background:var(--gold); color:#000; border-color:var(--gold); font-weight:600; }
.price-filter {
  display:flex; align-items:center; gap:0.5rem; font-size:0.78rem;
  color:var(--muted); white-space:nowrap;
}
.price-range {
  width:100px; accent-color:var(--gold); cursor:pointer;
}
.price-filter-val { color:var(--gold); font-weight:600; min-width:70px; }

/* ══════════════════════════════════════
   COMPARE TOGGLE ON CARD
══════════════════════════════════════ */
.compare-toggle {
  position:absolute; bottom:0.5rem; right:0.5rem;
  padding:4px 10px; border-radius:4px; border:1px solid rgba(255,255,255,0.3);
  background:rgba(0,0,0,0.55); color:#fff; font-size:0.7rem;
  cursor:pointer; backdrop-filter:blur(4px); transition:all 0.2s;
  letter-spacing:0.5px;
}
.compare-toggle:hover, .compare-toggle.active {
  background:var(--gold); border-color:var(--gold); color:#000; font-weight:700;
}
.car-card.in-compare { outline:2px solid var(--gold); }
.car-card-img-wrap { position:relative; }

/* ══════════════════════════════════════
   COMPARE BAR
══════════════════════════════════════ */
.compare-bar {
  position:sticky; bottom:0; z-index:50;
  display:flex; align-items:center; gap:1rem; flex-wrap:wrap;
  padding:0.75rem 2rem; background:var(--surface);
  border-top:2px solid var(--gold);
  box-shadow:0 -4px 24px rgba(0,0,0,0.3);
}
.compare-bar-cars { display:flex; gap:0.75rem; flex:1; flex-wrap:wrap; }
.compare-bar-car {
  display:flex; align-items:center; gap:0.5rem;
  background:var(--bg); border:1px solid var(--border);
  border-radius:6px; padding:0.3rem 0.6rem; font-size:0.78rem;
}
.compare-bar-car img {
  width:40px; height:28px; object-fit:cover; border-radius:3px;
}
.compare-bar-car button {
  background:none; border:none; color:var(--muted);
  cursor:pointer; font-size:0.9rem; padding:0 2px;
}
.compare-btn {
  padding:0.5rem 1.2rem; background:var(--gold); color:#000;
  border:none; border-radius:6px; font-weight:700; font-size:0.8rem;
  cursor:pointer; letter-spacing:1px; white-space:nowrap;
}
.compare-clear {
  padding:0.5rem 0.8rem; background:transparent; color:var(--muted);
  border:1px solid var(--border); border-radius:6px; font-size:0.78rem;
  cursor:pointer; white-space:nowrap;
}

/* ══════════════════════════════════════
   NO RESULTS
══════════════════════════════════════ */
.no-results {
  display:flex; flex-direction:column; align-items:center;
  justify-content:center; padding:4rem 2rem; color:var(--muted);
}
.no-results-icon { font-size:3rem; margin-bottom:0.5rem; opacity:0.4; }
.no-results-text { font-size:1rem; letter-spacing:2px; text-transform:uppercase; }

/* ══════════════════════════════════════
   COMPARE PAGE
══════════════════════════════════════ */
.compare-page-header {
  padding:2rem 3rem 1rem;
}
.compare-table-wrap {
  padding:0 2rem 3rem; overflow-x:auto;
}
.compare-table {
  width:100%; border-collapse:collapse; min-width:500px;
}
.compare-table th {
  padding:1rem; text-align:center; font-family:'Bebas Neue',sans-serif;
  font-size:1.1rem; letter-spacing:2px; border-bottom:2px solid var(--gold);
  background:var(--surface);
}
.compare-row-label {
  padding:0.75rem 1rem; font-size:0.72rem; letter-spacing:1.5px;
  text-transform:uppercase; color:var(--muted); font-weight:600;
  background:var(--surface); white-space:nowrap; width:130px;
}
.compare-row-val {
  padding:0.75rem 1rem; text-align:center; font-size:0.88rem;
  border-bottom:1px solid var(--border);
}
.compare-table tr:hover .compare-row-val { background:var(--surface); }

@media(max-width:768px) {
  .filters-bar { padding:1rem 1.5rem; }
  .compare-page-header { padding:1.5rem 1.5rem 0.5rem; }
  .compare-table-wrap { padding:0 1rem 2rem; }
}

/* ══════════════════════════════════════
   TESTIMONIALS
══════════════════════════════════════ */
.testimonials-section {
  padding:4rem 3rem;
  background:var(--surface);
  border-top:1px solid var(--border);
}
.testimonials-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));
  gap:1.5rem;
  margin-top:2rem;
}
.testimonial-card {
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:12px;
  padding:1.5rem;
  display:flex;
  flex-direction:column;
  gap:0.75rem;
  transition:border-color 0.2s, transform 0.2s;
}
.testimonial-card:hover {
  border-color:var(--gold);
  transform:translateY(-2px);
}
.testimonial-stars {
  color:var(--gold);
  font-size:1rem;
  letter-spacing:2px;
}
.testimonial-text {
  font-size:0.88rem;
  line-height:1.7;
  color:var(--text);
  flex:1;
  font-style:italic;
}
.testimonial-author {
  display:flex;
  align-items:center;
  gap:0.75rem;
  margin-top:0.25rem;
}
.testimonial-avatar {
  width:40px; height:40px;
  border-radius:50%;
  object-fit:cover;
  border:2px solid var(--gold);
}
.testimonial-initials {
  width:40px; height:40px;
  border-radius:50%;
  background:var(--gold);
  color:#000;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:700;
  font-size:1rem;
  flex-shrink:0;
}
.testimonial-name {
  font-weight:600;
  font-size:0.85rem;
}
.testimonial-car {
  font-size:0.72rem;
  color:var(--muted);
  letter-spacing:0.5px;
}

/* Testimonial admin rows */
.testimonial-admin-row {
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:8px;
  padding:1rem;
  margin-bottom:0.75rem;
}

/* WA message template code */
#cfg-wa-msg {
  font-family: 'Courier New', monospace;
  font-size:0.78rem;
  line-height:1.7;
}

@media(max-width:768px) {
  .testimonials-section { padding:2.5rem 1.5rem; }
}

/* ══════════════════════════════════════
   FEATURES / WHY US SECTION
══════════════════════════════════════ */
.features-section {
  padding:4rem 3rem;
  background:var(--bg);
  border-top:1px solid var(--border);
}
.features-grid {
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:1.25rem;
  margin-top:2rem;
}
.feature-card {
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:12px;
  padding:1.75rem 1.5rem;
  display:flex;
  flex-direction:column;
  gap:0.75rem;
  transition:border-color 0.2s, transform 0.2s;
}
.feature-card:hover {
  border-color:var(--gold);
  transform:translateY(-3px);
}
.feature-icon {
  width:48px; height:48px;
  background:rgba(201,168,76,0.1);
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}
.feature-icon svg {
  width:24px; height:24px;
  fill:var(--gold);
}
.feature-title {
  font-family:'Bebas Neue', sans-serif;
  font-size:1.15rem;
  letter-spacing:1.5px;
  color:var(--white);
  font-weight:400;
}
.feature-desc {
  font-size:0.83rem;
  line-height:1.7;
  color:var(--muted);
  flex:1;
}
.feature-tag {
  display:inline-block;
  padding:0.3rem 0.85rem;
  border:1px solid var(--gold);
  border-radius:20px;
  font-size:0.7rem;
  color:var(--gold);
  letter-spacing:0.5px;
  width:fit-content;
}

@media(max-width:900px) {
  .features-grid { grid-template-columns:repeat(2, 1fr); }
}
@media(max-width:600px) {
  .features-section { padding:2.5rem 1.5rem; }
  .features-grid { grid-template-columns:1fr; }
}

/* ══════════════════════════════════════
   BOOKINGS DASHBOARD ENHANCEMENTS
══════════════════════════════════════ */
.bookings-stats-row { grid-template-columns: repeat(4,1fr); margin-bottom:1.5rem; }
.stat-card-confirmed .stat-card-value { color: var(--green-text); }
.stat-card-pending .stat-card-value   { color: #e8c96a; }
.stat-card-earnings .stat-card-value  { color: var(--gold); }

/* Upcoming deliveries */
.upcoming-deliveries-box {
  background: var(--surface);
  border: 1px solid var(--border);
  border-left: 3px solid var(--gold);
  padding: 1rem 1.25rem;
  margin-bottom: 1.5rem;
}
.upcoming-title {
  display: flex; align-items: center; gap: 0.5rem;
  font-size: 0.6rem; letter-spacing: 3px; text-transform: uppercase;
  color: var(--muted); margin-bottom: 0.75rem; font-weight: 600;
}
.upcoming-badge {
  background: var(--gold); color: var(--bg);
  font-size: 0.6rem; font-weight: 700;
  padding: 1px 6px; border-radius: 20px; letter-spacing: 0;
}
.upcoming-list { display: flex; flex-direction: column; gap: 0.5rem; }
.upcoming-item {
  display: flex; align-items: center; gap: 1rem;
  padding: 0.6rem 0.75rem;
  background: var(--surface2); border: 1px solid var(--border);
  font-size: 0.75rem;
}
.upcoming-item-days {
  font-family: 'Bebas Neue', sans-serif; font-size: 1.4rem;
  color: var(--gold); min-width: 2.5rem; text-align: center; line-height: 1;
}
.upcoming-item-days span { display: block; font-family: inherit; font-size: 0.55rem; letter-spacing: 2px; color: var(--muted); text-transform: uppercase; }
.upcoming-item-today { color: var(--red) !important; }
.upcoming-item-info { flex: 1; }
.upcoming-item-car { font-weight: 600; color: var(--white); margin-bottom: 2px; }
.upcoming-item-customer { color: var(--muted); font-size: 0.7rem; }
.upcoming-item-city { color: var(--muted); font-size: 0.7rem; margin-left: auto; text-align:right; }

/* Filter bar */
.bookings-filter-bar {
  display: flex; gap: 0.5rem; margin-bottom: 1rem;
}
.bfilter-btn {
  background: none; border: 1px solid var(--border);
  color: var(--muted); font-size: 0.6rem; letter-spacing: 2px;
  padding: 0.4rem 1rem; cursor: pointer; font-family: inherit;
  transition: all 0.2s;
}
.bfilter-btn:hover { border-color: var(--gold); color: var(--gold); }
.bfilter-btn.active { border-color: var(--gold); color: var(--gold); background: rgba(201,168,76,0.08); }

/* Status badge in table */
.status-badge {
  font-size: 0.58rem; letter-spacing: 1.5px; text-transform: uppercase;
  padding: 3px 8px; border-radius: 2px; font-weight: 600; cursor: pointer;
  border: 1px solid transparent; transition: all 0.2s; white-space: nowrap;
}
.status-badge.pending  { background: rgba(232,201,106,0.12); color: #e8c96a; border-color: rgba(232,201,106,0.3); }
.status-badge.confirmed { background: rgba(111,207,151,0.12); color: var(--green-text); border-color: rgba(111,207,151,0.3); }

@media (max-width: 700px) {
  .bookings-stats-row { grid-template-columns: 1fr 1fr; }
  .upcoming-item-days { font-size: 1.1rem; }
}

/* Manual booking modal extras */
.modal-header { display:flex; justify-content:space-between; align-items:center; padding:1.25rem 1.5rem; border-bottom:1px solid var(--border); }
.modal-header .modal-title { font-family:'Bebas Neue',sans-serif; font-size:1.3rem; letter-spacing:3px; color:var(--white); margin:0; }
.modal-close { background:none; border:none; color:var(--muted); font-size:1rem; cursor:pointer; padding:0.25rem; line-height:1; }
.modal-close:hover { color:var(--white); }
.modal-body { padding:1.25rem 1.5rem; }
.btn-secondary { padding:0.6rem 1.2rem; border:1px solid var(--border); background:none; color:var(--muted); font-size:0.75rem; letter-spacing:1px; cursor:pointer; font-family:inherit; transition:all 0.15s; }
.btn-secondary:hover { border-color:var(--white); color:var(--white); }
