/* ─── DESIGN TOKENS ─────────────────────────────────────── */
:root{
  --black:#0F0F0F;
  --cream:#ffffff;
  --gold:#1B4332;
  --gold-l:#2D6A4F;
  --gold-d:#0D2B1F;
  --white:#ffffff;
  --muted:#5a6b61;
  --border:rgba(27,67,50,0.15);
  --border-s:rgba(27,67,50,0.38);
  --surf:rgba(27,67,50,0.03);
  --surf-l:rgba(27,67,50,0.06);
  --success:#1B4332;
  --danger:#8C3A2F;
  --success-text:#1B4332;
  --danger-text:#8C3A2F;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'DM Sans',sans-serif;background:#ffffff;color:#0F0F0F;min-height:100vh;overflow-x:hidden;}html{background:#ffffff;}


/* ─── NAV ───────────────────────────────────────────────── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 24px;height:64px;
  background:rgba(255,255,255,0.98);
  border-bottom:1px solid #f0f0f0;
  backdrop-filter:blur(12px);
  transition:box-shadow 0.3s;
}
nav.scrolled{box-shadow:0 2px 20px rgba(0,0,0,0.08);}
.nav-logo{cursor:pointer;display:flex;align-items:center;height:40px;}
.nav-logo img{height:40px;width:auto;display:block;object-fit:contain;}
.nav-links{display:flex;align-items:center;gap:6px;}
.nav-btn{font-size:13px;font-weight:500;padding:8px 16px;border-radius:8px;cursor:pointer;letter-spacing:0;border:none;font-family:'DM Sans',sans-serif;transition:all 0.18s;text-decoration:none;line-height:1;}
.nav-ghost{background:transparent;color:#0F0F0F;border:1.5px solid #e0e0e0;}
.nav-ghost:hover{background:#f7f7f7;border-color:#ccc;}
.nav-solid{background:#1B4332;color:#ffffff;font-weight:600;}
.nav-solid:hover{background:#0D2B1F;transform:translateY(-1px);box-shadow:0 4px 12px rgba(27,67,50,0.25);}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;border-radius:8px;transition:background 0.18s;}
.hamburger:hover{background:#f5f5f5;}
.hamburger span{display:block;width:22px;height:1.5px;background:#0F0F0F;transition:all 0.3s;border-radius:2px;}
.mob-menu{
  display:none;position:fixed;inset:0;z-index:99;
  background:rgba(255,255,255,0.99);
  flex-direction:column;align-items:center;justify-content:center;gap:24px;
  opacity:0;pointer-events:none;
  transition:opacity 0.28s ease;
  -webkit-overflow-scrolling:touch;
}
.mob-menu.open{
  display:flex;
  opacity:1;
  pointer-events:all;
}
.mob-menu a{
  font-size:22px;font-weight:500;color:#0F0F0F;
  cursor:pointer;padding:10px 32px;border-radius:12px;
  transition:background 0.18s;width:260px;text-align:center;
}
.mob-menu a:hover{background:#f5f5f5;color:#1B4332;}
.mob-close{position:absolute;top:20px;right:20px;font-size:22px;cursor:pointer;color:#888;background:none;border:none;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background 0.18s;}
.mob-close:hover{background:#f5f5f5;}

/* ─── SECTIONS ──────────────────────────────────────────── */
.sec{display:none;}.sec.on{display:block;}

/* ─── HOME PAGE ─────────────────────────────────────────── */
.home-page{padding-top:64px;}

/* Hero */
.hero{
  padding:60px 24px 40px;
  max-width:780px;margin:0 auto;
  text-align:center;
}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12px;font-weight:500;letter-spacing:0.04em;
  color:#1B4332;background:rgba(27,67,50,0.08);
  padding:5px 14px;border-radius:20px;margin-bottom:20px;
}
.eyebrow::before{content:'';width:6px;height:6px;border-radius:50%;background:#1B4332;flex-shrink:0;}
.hero-title{
  font-family:'DM Sans',sans-serif;
  font-size:clamp(36px,5.5vw,62px);
  font-weight:700;line-height:1.1;
  color:#0F0F0F;margin-bottom:14px;
  letter-spacing:-0.02em;
}
.hero-title span{color:#1B4332;}
.hero-sub{
  font-size:17px;color:#666;max-width:520px;
  line-height:1.7;margin:0 auto 36px;font-weight:400;
}

/* Search bar — Airbnb pill style */
.search-bar{
  display:flex;align-items:stretch;
  background:#fff;
  border:1.5px solid #e0e0e0;
  border-radius:60px;
  box-shadow:0 4px 24px rgba(0,0,0,0.1);
  overflow:hidden;
  max-width:720px;margin:0 auto 20px;
  transition:box-shadow 0.2s;
}
.search-bar:focus-within{box-shadow:0 6px 32px rgba(0,0,0,0.15);border-color:#ccc;}
.sb-field{
  flex:1;display:flex;flex-direction:column;
  padding:12px 20px;border-right:1px solid #ebebeb;
  cursor:pointer;transition:background 0.15s;min-width:0;
}
.sb-field:last-of-type{border-right:none;}
.sb-field:hover{background:#f7f7f7;}
.sb-label{font-size:10px;font-weight:700;letter-spacing:0.05em;text-transform:uppercase;color:#0F0F0F;margin-bottom:3px;white-space:nowrap;}
.sb-field select,.sb-field input{
  background:transparent;border:none;outline:none;
  font-size:13px;color:#555;font-family:'DM Sans',sans-serif;
  -webkit-appearance:none;cursor:pointer;padding:0;width:100%;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.sb-field select option{background:#fff;color:#0F0F0F;}
.sb-search-btn{
  background:#1B4332;color:#fff;border:none;
  padding:0 22px;cursor:pointer;
  display:flex;align-items:center;gap:8px;
  font-size:14px;font-weight:600;font-family:'DM Sans',sans-serif;
  transition:background 0.18s;border-radius:0 60px 60px 0;
  white-space:nowrap;flex-shrink:0;
}
.sb-search-btn:hover{background:#0D2B1F;}
.sb-search-btn svg{width:16px;height:16px;flex-shrink:0;}

/* Category pills */
.cat-pills{
  display:flex;gap:8px;justify-content:center;
  flex-wrap:wrap;margin-bottom:40px;
}
.cat-pill{
  padding:8px 18px;border-radius:24px;
  border:1.5px solid #e0e0e0;
  font-size:13px;font-weight:500;color:#444;
  cursor:pointer;transition:all 0.18s;background:#fff;
  font-family:'DM Sans',sans-serif;
  display:flex;align-items:center;gap:6px;
}
.cat-pill:hover,.cat-pill.on{
  border-color:#1B4332;color:#1B4332;
  background:rgba(27,67,50,0.06);
  transform:translateY(-1px);
}

/* Stats row */
.hero-stats{
  display:flex;justify-content:center;gap:0;
  border:1px solid #f0f0f0;border-radius:16px;
  overflow:hidden;max-width:480px;margin:0 auto 48px;
}
.stat-item{
  flex:1;padding:16px 12px;text-align:center;
  border-right:1px solid #f0f0f0;
}
.stat-item:last-child{border-right:none;}
.stat-n{font-size:22px;font-weight:700;color:#1B4332;font-family:'DM Sans',sans-serif;line-height:1;}
.stat-l{font-size:11px;color:#888;margin-top:3px;font-weight:400;}

/* Section headers */
.sec-hdr{
  display:flex;align-items:baseline;justify-content:space-between;
  margin-bottom:20px;
}
.sec-hdr h2{font-size:22px;font-weight:700;color:#0F0F0F;letter-spacing:-0.01em;}
.sec-hdr a{font-size:13px;color:#1B4332;font-weight:500;cursor:pointer;text-decoration:none;}
.sec-hdr a:hover{text-decoration:underline;}

/* Top filter bar (replaces sidebar) */
.filter-bar{
  display:flex;align-items:center;gap:8px;
  margin-bottom:24px;overflow-x:auto;
  padding-bottom:4px;-webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.filter-bar::-webkit-scrollbar{display:none;}
.fb-pill{
  display:flex;align-items:center;gap:6px;
  padding:8px 16px;border:1.5px solid #e0e0e0;
  border-radius:24px;font-size:13px;font-weight:500;
  color:#444;cursor:pointer;white-space:nowrap;
  background:#fff;font-family:'DM Sans',sans-serif;
  transition:all 0.18s;flex-shrink:0;
}
.fb-pill:hover,.fb-pill.on{border-color:#1B4332;color:#1B4332;background:rgba(27,67,50,0.05);}
.fb-pill svg{width:14px;height:14px;}
.filter-btn{
  display:flex;align-items:center;gap:6px;
  padding:8px 16px;border:1.5px solid #e0e0e0;
  border-radius:24px;font-size:13px;font-weight:500;
  color:#444;cursor:pointer;background:#fff;
  font-family:'DM Sans',sans-serif;transition:all 0.18s;
  white-space:nowrap;flex-shrink:0;
}
.filter-btn:hover{border-color:#1B4332;color:#1B4332;}
.price-filter{display:flex;align-items:center;gap:8px;}
.price-filter input{width:80px;padding:4px 8px;border:1.5px solid #e0e0e0;border-radius:8px;font-size:13px;font-family:'DM Sans',sans-serif;color:#0F0F0F;outline:none;}
.price-filter input:focus{border-color:#1B4332;}

/* Car grid — Airbnb style */
.listing-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:24px;
}
.listing-card{
  cursor:pointer;border-radius:12px;overflow:hidden;
  background:#fff;
  transition:transform 0.22s cubic-bezier(0.34,1.56,0.64,1),box-shadow 0.22s;
  position:relative;
}
/* lazy-photo: absolute overlay, fades in over emoji fallback */
.lazy-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 0.35s;z-index:2;}
.lazy-photo.loaded{opacity:1;}
.listing-card:hover{
  transform:translateY(-4px);
  box-shadow:0 12px 40px rgba(0,0,0,0.12);
}
.listing-card:active{transform:translateY(-2px);}
.lc-img{
  width:100%;aspect-ratio:4/3;
  display:flex;align-items:center;justify-content:center;
  font-size:72px;position:relative;overflow:hidden;
  border-radius:12px;
  background:#f5f5f5;
}
.listing-card:hover .lc-photo{transform:scale(1.05);}
.lc-photo.loaded{opacity:1!important;}
.lc-img-inner{
  position:absolute;inset:0;display:flex;
  align-items:center;justify-content:center;font-size:72px;
}
.lc-wishlist{
  position:absolute;top:10px;right:10px;
  width:32px;height:32px;border-radius:50%;
  background:rgba(255,255,255,0.9);
  border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all 0.18s;z-index:1;
  box-shadow:0 1px 4px rgba(0,0,0,0.15);
}
.lc-wishlist:hover{background:#fff;transform:scale(1.1);}
.lc-wishlist svg{width:16px;height:16px;}
.lc-wishlist.liked svg{fill:#e00;stroke:#e00;}
.lc-drive-badge{
  position:absolute;bottom:10px;left:10px;
  background:rgba(255,255,255,0.95);
  padding:4px 10px;border-radius:20px;
  font-size:11px;font-weight:600;color:#1B4332;
  letter-spacing:0.02em;
  box-shadow:0 1px 4px rgba(0,0,0,0.12);
}
.lc-body{padding:10px 4px 0;}
.lc-top-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2px;}
.lc-name{font-size:14px;font-weight:600;color:#0F0F0F;line-height:1.3;}
.lc-rating{display:flex;align-items:center;gap:3px;font-size:12px;font-weight:500;color:#0F0F0F;flex-shrink:0;}
.lc-rating svg{width:11px;height:11px;fill:#0F0F0F;}
.lc-sub{font-size:12px;color:#777;margin-bottom:4px;}
.lc-events{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:6px;overflow:hidden;max-height:22px;}
.lc-event-tag{font-size:10px;padding:2px 6px;border-radius:12px;background:#f0f0f0;color:#555;font-weight:500;white-space:nowrap;}
.lc-price-row{display:flex;align-items:baseline;gap:3px;margin-bottom:8px;}
.lc-price{font-size:15px;font-weight:700;color:#1B4332;}
.lc-price-unit{font-size:12px;color:#777;font-weight:400;}
.lc-req-btn{
  width:100%;padding:9px;
  background:#1B4332;color:#fff;border:none;
  border-radius:8px;font-size:13px;font-weight:600;
  font-family:'DM Sans',sans-serif;cursor:pointer;
  transition:all 0.18s;
}
.lc-req-btn:hover{background:#0D2B1F;}

/* Skeleton loader */
.skeleton{
  background:linear-gradient(90deg,#f0f0f0 25%,#e8e8e8 50%,#f0f0f0 75%);
  background-size:200% 100%;
  animation:shimmer 1.4s infinite;
  border-radius:8px;
}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.skel-card{border-radius:12px;overflow:hidden;}
.skel-img{width:100%;aspect-ratio:4/3;border-radius:12px;}
.skel-line{height:14px;margin-top:12px;border-radius:6px;}
.skel-line.short{width:60%;}
.skel-line.med{width:80%;}

/* No results */
.no-results-state{
  grid-column:1/-1;text-align:center;padding:60px 24px;
}
.nr-icon{font-size:48px;margin-bottom:16px;}
.nr-title{font-size:20px;font-weight:600;color:#0F0F0F;margin-bottom:8px;}
.nr-sub{font-size:14px;color:#888;margin-bottom:20px;}
.nr-btn{
  display:inline-block;padding:10px 24px;
  background:#1B4332;color:#fff;border:none;
  border-radius:8px;font-size:14px;font-weight:600;
  cursor:pointer;font-family:'DM Sans',sans-serif;
  transition:background 0.18s;
}
.nr-btn:hover{background:#0D2B1F;}

/* How it works section */
.how-section{
  background:#f9faf9;border-radius:20px;
  padding:40px 32px;margin:48px 0;
}
.how-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:24px;}
.how-card{text-align:center;padding:8px;}
.how-icon{
  width:52px;height:52px;border-radius:14px;
  background:#1B4332;color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:22px;margin:0 auto 14px;
}
.how-title{font-size:15px;font-weight:700;color:#0F0F0F;margin-bottom:6px;}
.how-desc{font-size:13px;color:#666;line-height:1.6;}

/* CTA banner */
.cta-banner{
  background:#0F0F0F;border-radius:20px;
  padding:48px 40px;margin:0 0 48px;
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;
}
.cta-title{font-size:clamp(22px,3vw,30px);font-weight:700;color:#fff;line-height:1.2;margin-bottom:8px;}
.cta-sub{font-size:15px;color:rgba(255,255,255,0.65);}
.cta-btn{
  padding:14px 28px;background:#fff;color:#0F0F0F;
  border:none;border-radius:10px;font-size:14px;font-weight:700;
  cursor:pointer;font-family:'DM Sans',sans-serif;
  white-space:nowrap;transition:all 0.18s;flex-shrink:0;
}
.cta-btn:hover{background:#f0f0f0;transform:translateY(-1px);}

/* Home page wrapper */
.home-content{max-width:1200px;margin:0 auto;padding:0 24px 60px;}

/* ─── BROWSE PAGE ────────────────────────────────────────── */
.browse-wrap{max-width:1200px;margin:0 auto;padding:80px 20px 60px;background:#ffffff;box-sizing:border-box;}
.sec-eyebrow{font-size:11px;letter-spacing:0.3em;text-transform:uppercase;color:var(--gold);margin-bottom:10px;}
.sec-title{font-family:'DM Sans',sans-serif;font-size:clamp(24px,4vw,38px);font-weight:700;margin-bottom:24px;line-height:1.1;color:#0F0F0F;letter-spacing:-0.01em;}
.browse-layout{display:block;}
.cars-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:24px;border:none;}

/* Keep old card styles for browse page */
.car-card{background:#fff;cursor:pointer;transition:all 0.22s cubic-bezier(0.34,1.56,0.64,1);position:relative;border-radius:12px;overflow:hidden;border:none;}
.car-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,0.12);}
.car-img{height:180px;display:flex;align-items:center;justify-content:center;font-size:68px;background:#f5f5f5;position:relative;overflow:hidden;border-radius:0;}
.car-card:hover .car-photo{transform:scale(1.05);}
.car-body{padding:12px 14px;}
.ev-tags{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:10px;}
.ev-tag{font-size:11px;font-weight:500;padding:3px 8px;border-radius:12px;background:#f0f0f0;color:#555;}
.car-name{font-size:16px;font-weight:600;color:#0F0F0F;margin-bottom:2px;font-family:'DM Sans',sans-serif;}
.car-owner{font-size:13px;color:#777;margin-bottom:12px;}
.car-foot{display:flex;justify-content:space-between;align-items:center;padding-top:10px;border-top:1px solid #f0f0f0;gap:8px;flex-wrap:wrap;}
.car-price{font-size:18px;font-weight:700;color:#0F0F0F;}
.car-price-sub{font-size:12px;color:#888;}
.drive-badge{font-size:11px;font-weight:600;padding:4px 10px;background:rgba(27,67,50,0.08);border-radius:20px;color:#1B4332;}
.btn-req{
  padding:10px 18px;background:#1B4332;color:#fff;
  border:none;font-family:'DM Sans',sans-serif;font-size:13px;
  font-weight:600;cursor:pointer;transition:all 0.18s;border-radius:8px;
}
.btn-req:hover{background:#0D2B1F;}
.no-results{grid-column:1/-1;padding:48px;text-align:center;color:#888;font-size:14px;}

/* Browse filter bar */
.browse-filter-bar{
  display:flex;align-items:center;gap:8px;
  margin-bottom:24px;flex-wrap:wrap;
}
.fp-pill{
  padding:9px 18px;border:1.5px solid #e0e0e0;
  border-radius:24px;font-size:13px;font-weight:500;
  color:#444;cursor:pointer;background:#fff;
  font-family:'DM Sans',sans-serif;transition:all 0.18s;
  min-height:40px;display:inline-flex;align-items:center;
  -webkit-tap-highlight-color:transparent;
  touch-action:manipulation;user-select:none;
}
.fp-pill.on,.fp-pill:hover{border-color:#1B4332;color:#1B4332;background:rgba(27,67,50,0.06);}
.fp-pill:active{transform:scale(0.97);}
/* Filter sheet chips */
.fs-chip{
  padding:9px 16px;border:1.5px solid #e8e8e8;border-radius:24px;
  font-size:13px;font-weight:500;color:#555;cursor:pointer;background:#fff;
  font-family:'DM Sans',sans-serif;transition:all 0.15s;
  min-height:40px;touch-action:manipulation;
  -webkit-tap-highlight-color:transparent;user-select:none;
}
.fs-chip.on{background:#1B4332;color:#fff;border-color:#1B4332;}
.fs-chip:active{transform:scale(0.96);}
/* Active filter chips in filter bar */
.filter-chip{
  display:inline-flex;align-items:center;gap:5px;
  padding:6px 12px;background:rgba(27,67,50,0.08);
  border:1px solid rgba(27,67,50,0.2);border-radius:20px;
  font-size:12px;font-weight:500;color:#1B4332;
}
.filter-chip button{background:none;border:none;cursor:pointer;
  color:#1B4332;padding:0;font-size:14px;line-height:1;touch-action:manipulation;}
.fp-select{
  padding:9px 14px;border:1.5px solid #e0e0e0;
  border-radius:24px;font-size:13px;font-weight:500;
  color:#444;background:#fff;font-family:'DM Sans',sans-serif;
  outline:none;cursor:pointer;-webkit-appearance:none;
  transition:all 0.18s;min-height:40px;
  touch-action:manipulation;
}
.fp-select:hover,.fp-select:focus{border-color:#1B4332;color:#1B4332;}
.fp-reset{
  padding:8px 14px;background:transparent;
  border:1.5px dashed #e0e0e0;color:#888;
  font-size:13px;cursor:pointer;border-radius:24px;
  font-family:'DM Sans',sans-serif;transition:all 0.18s;
}
.fp-reset:hover{border-color:#1B4332;color:#1B4332;}
.range-row{display:flex;justify-content:space-between;font-size:12px;color:#888;margin-top:4px;}

/* ─── AUTH MODAL ────────────────────────────────────────── */
.overlay{display:none;position:fixed;inset:0;z-index:200;background:rgba(0,0,0,0.5);align-items:center;justify-content:center;padding:20px;-webkit-overflow-scrolling:touch;}
.overlay.on{display:flex;animation:fadeIn 0.2s ease;}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal{background:#fff;border:none;max-width:480px;width:min(480px,calc(100vw - 32px));border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,0.2);box-sizing:border-box;overflow:visible;}
.modal-hd{padding:20px 24px 16px;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;align-items:center;border-radius:16px 16px 0 0;background:#fff;}
.modal-title{font-size:18px;font-weight:700;color:#0F0F0F;font-family:'DM Sans',sans-serif;}
.modal-close{background:none;border:none;color:#888;font-size:18px;cursor:pointer;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background 0.18s;}
.modal-close:hover{background:#f5f5f5;}
.modal-body{padding:20px 20px 4px;box-sizing:border-box;}
.auth-tabs{display:flex;gap:0;margin-bottom:20px;border-bottom:1px solid #f0f0f0;}
.auth-tab{flex:1;padding:10px;text-align:center;font-size:14px;font-weight:500;color:#888;cursor:pointer;border-bottom:2px solid transparent;transition:all 0.18s;}
.auth-tab.on{color:#1B4332;border-bottom-color:#1B4332;}
/* ═══════════════════════════════════════════
   RIVRO FORM SYSTEM — single source of truth
   ═══════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;}

.form-group{margin-bottom:16px;width:100%;}
.form-group label{
  display:block;font-size:13px;font-weight:600;
  color:#0F0F0F;margin-bottom:6px;
}
.form-group input,
.form-group select,
.form-group textarea{
  display:block;
  width:100%;
  padding:13px 14px;
  border:1.5px solid #e8e8e8;
  border-radius:10px;
  font-size:16px;
  font-family:'DM Sans',sans-serif;
  color:#0F0F0F;
  background:#fff;
  outline:none;
  transition:border-color 0.18s,box-shadow 0.18s;
  -webkit-appearance:none;
  appearance:none;
  box-sizing:border-box;
  max-width:100%;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{
  border-color:#1B4332;
  box-shadow:0 0 0 3px rgba(27,67,50,0.08);
}
.form-group input::placeholder,
.form-group textarea::placeholder{color:#b0b0b0;}
.form-group textarea{resize:vertical;min-height:80px;line-height:1.6;}
.form-group select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath fill='%23888' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 14px center;
  padding-right:36px;
  cursor:pointer;
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
@media(max-width:520px){.form-row{grid-template-columns:1fr;}}
.form-row2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
@media(max-width:520px){.form-row2{grid-template-columns:1fr;}}
.form-full{grid-column:1/-1;}
/* Auth modal form */
.auth-modal-form{padding:0;}
/* Shared modal padding */
.modal-form-body{padding:20px 20px 8px;}
.auth-err{
  font-size:13px;color:#c0392b;margin-bottom:12px;
  display:none;padding:8px 12px;
  background:#fef5f5;border-radius:8px;
}
.auth-err.on{display:block;}
.bk-car-info{display:flex;align-items:center;gap:14px;margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid #f0f0f0;}
#bkBody input:focus,#bkBody select:focus,#bkBody textarea:focus{border-color:#1B4332!important;outline:none;}
.bk-car-icon{font-size:36px;}
.bk-car-name{font-size:17px;font-weight:600;color:#0F0F0F;}
.bk-car-owner{font-size:13px;color:#888;}
.form-row2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
@media(max-width:520px){.form-row2{grid-template-columns:1fr;}}
.form-full{grid-column:span 2;}
.form-group textarea{width:100%;background:#f7f7f7;border:1.5px solid #e8e8e8;border-radius:8px;padding:10px 14px;color:#0F0F0F;font-family:'DM Sans',sans-serif;font-size:14px;outline:none;resize:vertical;min-height:72px;line-height:1.5;}
.form-group select{width:100%;background:#f7f7f7;border:1.5px solid #e8e8e8;border-radius:8px;padding:10px 14px;color:#0F0F0F;font-family:'DM Sans',sans-serif;font-size:14px;outline:none;-webkit-appearance:none;}
.form-group select option{background:#fff;color:#0F0F0F;}
.modal-ft{padding:16px 24px;border-top:1px solid #f0f0f0;display:flex;gap:10px;justify-content:flex-end;}
.btn-cancel{padding:10px 18px;background:transparent;border:1.5px solid #e0e0e0;color:#666;font-family:'DM Sans',sans-serif;font-size:14px;cursor:pointer;border-radius:8px;}
.btn-cancel:hover{border-color:#ccc;background:#f7f7f7;}
.btn-submit{padding:10px 26px;background:#1B4332;color:#fff;border:none;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;cursor:pointer;border-radius:8px;transition:all 0.18s;}
.btn-submit:hover{background:#0D2B1F;}

.price-summary{background:#f9faf9;border:1px solid #efefef;border-radius:10px;padding:14px 16px;margin-bottom:16px;}
.rp-row{display:flex;justify-content:space-between;font-size:13px;padding:3px 0;color:#0F0F0F;}
.rp-row.rp-total{font-size:15px;font-weight:700;color:#1B4332;border-top:1px solid #efefef;padding-top:10px;margin-top:6px;}
.rp-row.rp-zero{font-size:15px;font-weight:700;color:#c0392b;border-top:1px solid #efefef;padding-top:10px;margin-top:6px;}
.rp-row.sub{font-size:12px;color:#888;}

/* ─── CANCELLATION MODAL ────────────────────────────────── */
.cancel-modal{max-width:460px;}
.policy-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:16px 0;}
.policy-tile{border:1.5px solid #efefef;border-radius:10px;padding:12px 14px;}
.policy-tile.highlight{border-color:#1B4332;background:rgba(27,67,50,0.05);}
.pt-days{font-size:11px;font-weight:600;text-transform:uppercase;color:#888;margin-bottom:4px;}
.pt-refund{font-size:18px;font-weight:700;color:#1B4332;font-family:'DM Sans',sans-serif;}
.pt-refund.zero{color:#c0392b;}
.pt-refund.half{color:#e67e22;}
.refund-preview{background:#f9faf9;border:1px solid #efefef;border-radius:10px;padding:14px 16px;margin:16px 0;}
.cancel-warn{background:#fef5f5;border:1px solid #fcc;border-radius:8px;padding:10px 14px;font-size:12px;color:#c0392b;line-height:1.6;margin-top:12px;}
.btn-confirm-cancel{padding:10px 26px;background:#c0392b;color:#fff;border:none;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;cursor:pointer;border-radius:8px;transition:all 0.18s;}
.btn-confirm-cancel:hover{background:#a93226;}
.btn-confirm-cancel:disabled{background:#e0a09a;cursor:default;}
.renter-booking{padding:16px 20px;border-bottom:1px solid #f5f5f5;display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:start;}
.renter-booking:last-child{border-bottom:none;}
.rb-actions{display:flex;flex-direction:column;align-items:flex-end;gap:8px;}
.btn-cancel-booking{padding:6px 12px;background:transparent;border:1.5px solid #fcc;color:#c0392b;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:500;cursor:pointer;border-radius:6px;transition:all 0.18s;white-space:nowrap;}
.btn-cancel-booking:hover{background:#fef5f5;}

/* ─── DASHBOARD ─────────────────────────────────────────── */
.dash{max-width:1100px;margin:0 auto;padding:80px 20px 60px;box-sizing:border-box;}
.dash-greeting{font-size:clamp(26px,4vw,40px);font-weight:700;margin-bottom:4px;color:#0F0F0F;font-family:'DM Sans',sans-serif;letter-spacing:-0.01em;}
.dash-sub{font-size:14px;color:#888;margin-bottom:32px;}
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:32px;}
.metric{padding:20px;background:#fff;border:1px solid #f0f0f0;border-radius:12px;}
.metric-l{font-size:12px;color:#888;margin-bottom:6px;font-weight:500;}
.metric-v{font-size:32px;font-weight:700;color:#0F0F0F;font-family:'DM Sans',sans-serif;letter-spacing:-0.02em;}
.metric-v.gold{color:#1B4332;}
.dash-grid{display:grid;grid-template-columns:1fr 340px;gap:20px;}
.d-panel{border:1px solid #f0f0f0;border-radius:12px;background:#fff;overflow:hidden;}
.d-ph{padding:16px 20px;border-bottom:1px solid #f5f5f5;display:flex;justify-content:space-between;align-items:center;}
.d-ptitle{font-size:12px;font-weight:700;letter-spacing:0.04em;text-transform:uppercase;color:#1B4332;}
.req-item{padding:16px 20px;border-bottom:1px solid #f8f8f8;display:flex;gap:12px;align-items:flex-start;}
.req-item:last-child{border-bottom:none;}
.req-ico{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;background:#f5f5f5;flex-shrink:0;}
.req-c{flex:1;}
.req-name{font-size:14px;font-weight:600;color:#0F0F0F;margin-bottom:2px;}
.req-detail{font-size:12px;color:#888;line-height:1.5;}
.badge{font-size:11px;font-weight:600;padding:3px 8px;border-radius:20px;display:inline-block;margin-top:6px;}
.badge-p{background:#fff8e6;color:#e67e22;}
.badge-a{background:#eafaf1;color:#1B4332;}
.badge-d{background:#fdf0ee;color:#c0392b;}
.badge-h{background:#eafaf1;color:#1B4332;}
.req-actions{display:flex;gap:6px;margin-top:8px;}
.btn-ok{padding:6px 14px;background:#eafaf1;border:1px solid rgba(27,67,50,0.25);color:#1B4332;font-size:12px;font-weight:600;cursor:pointer;border-radius:6px;font-family:'DM Sans',sans-serif;transition:all 0.18s;}
.btn-ok:hover{background:#1B4332;color:#fff;}
.btn-no{padding:6px 14px;background:transparent;border:1px solid #e8e8e8;color:#888;font-size:12px;font-weight:500;cursor:pointer;border-radius:6px;font-family:'DM Sans',sans-serif;transition:all 0.18s;}
.btn-no:hover{border-color:#fcc;color:#c0392b;}
.listing-row{padding:16px 20px;border-bottom:1px solid #f8f8f8;display:flex;align-items:center;gap:12px;}
.listing-row:last-child{border-bottom:none;}
.listing-ico{font-size:24px;}
.listing-info{flex:1;}
.listing-name{font-size:15px;font-weight:600;color:#0F0F0F;font-family:'DM Sans',sans-serif;}
.listing-meta{font-size:12px;color:#888;}
.toggle{width:40px;height:22px;border-radius:11px;cursor:pointer;border:none;position:relative;transition:background 0.22s;flex-shrink:0;}
.toggle.on{background:#1B4332;}
.toggle.off{background:#ddd;}
.tthumb{width:16px;height:16px;border-radius:50%;position:absolute;top:3px;transition:left 0.2s;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,0.2);}
.toggle.on .tthumb{left:21px;}
.toggle.off .tthumb{left:3px;}
.toggle-label-sm{font-size:12px;color:#888;font-weight:500;}
.add-listing-btn{width:100%;padding:16px;background:transparent;border:none;border-top:1px solid #f5f5f5;color:#1B4332;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:background 0.18s;}
.add-listing-btn:hover{background:#f9faf9;}
.stripe-banner{padding:16px 20px;background:#f0faf5;border-bottom:1px solid #d4edda;display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;border-radius:12px;}
.stripe-banner-t{font-size:14px;font-weight:600;color:#0F0F0F;}
.stripe-banner-s{font-size:12px;color:#888;margin-top:2px;}
.btn-stripe{padding:8px 18px;background:#1B4332;color:#fff;border:none;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;cursor:pointer;border-radius:8px;transition:background 0.18s;}
.btn-stripe:hover{background:#0D2B1F;}
.rb-car-name{font-size:15px;font-weight:600;color:#0F0F0F;font-family:'DM Sans',sans-serif;}
.rb-detail{font-size:13px;color:#888;line-height:1.5;}
.escrow-info{font-size:12px;color:#1B4332;margin-top:3px;font-weight:500;}

/* ─── WIZARD ────────────────────────────────────────────── */
.wiz-wrap{max-width:680px;margin:0 auto;padding:76px 20px 60px;background:#fff;box-sizing:border-box;}
.wiz-steps{display:flex;gap:0;margin-bottom:40px;position:relative;}
.wiz-steps::before{content:'';position:absolute;top:13px;left:14px;right:14px;height:2px;background:#f0f0f0;border-radius:2px;}
.ws{flex:1;display:flex;flex-direction:column;align-items:center;gap:7px;position:relative;z-index:1;}
.ws-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;border:2px solid #e0e0e0;background:#fff;color:#aaa;transition:all 0.28s;}
.ws.done .ws-dot,.ws.act .ws-dot{background:#1B4332;color:#fff;border-color:#1B4332;}
.ws-lbl{font-size:10px;color:#aaa;font-weight:600;letter-spacing:0.04em;text-transform:uppercase;text-align:center;}
.ws.act .ws-lbl{color:#1B4332;}
.ws.done .ws-lbl{color:#0F0F0F;}
.wiz-body{border:1px solid #f0f0f0;border-radius:16px;padding:28px 24px;background:#fff;min-height:280px;box-sizing:border-box;}
.wiz-step-title{font-size:24px;font-weight:700;margin-bottom:4px;color:#0F0F0F;font-family:'DM Sans',sans-serif;letter-spacing:-0.01em;}
.wiz-step-sub{font-size:14px;color:#888;margin-bottom:24px;line-height:1.55;}
.wf{margin-bottom:16px;width:100%;box-sizing:border-box;}
.wf label{display:block;font-size:12px;font-weight:600;color:#0F0F0F;margin-bottom:6px;}
.wf input,.wf select,.wf textarea{width:100%;padding:10px 14px;background:#f7f7f7;border:1.5px solid #e8e8e8;border-radius:8px;color:#0F0F0F;font-family:'DM Sans',sans-serif;font-size:14px;outline:none;transition:border-color 0.18s;}
.wf input:focus,.wf select:focus,.wf textarea:focus{border-color:#1B4332;background:#fff;}
.wf select option{background:#fff;color:#0F0F0F;}
.wf textarea{resize:vertical;min-height:76px;line-height:1.6;}
.w2{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
@media(max-width:600px){.w2{grid-template-columns:1fr;}}
.drive-opts{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.drive-opt{border:2px solid #e8e8e8;padding:16px;cursor:pointer;transition:all 0.2s;background:#fff;border-radius:10px;}
.drive-opt:hover,.drive-opt.on{border-color:#1B4332;background:rgba(27,67,50,0.04);}
.do-icon{font-size:22px;margin-bottom:8px;}
.do-title{font-size:14px;font-weight:600;color:#0F0F0F;margin-bottom:3px;}
.do-desc{font-size:12px;color:#888;line-height:1.5;}
.drive-opt.on .do-desc{color:#1B4332;}
.do-wide{grid-column:span 2;}
.ev-chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:5px;}
.ev-chip{padding:7px 14px;border:1.5px solid #e8e8e8;font-size:13px;font-weight:500;color:#666;cursor:pointer;transition:all 0.18s;background:#fff;font-family:'DM Sans',sans-serif;border-radius:20px;}
.ev-chip.on{border-color:#1B4332;color:#1B4332;background:rgba(27,67,50,0.07);}
.upload-zone{border:2px dashed #e0e0e0;padding:28px;text-align:center;color:#888;font-size:14px;cursor:pointer;transition:all 0.2s;border-radius:10px;}
.upload-zone:hover{border-color:#1B4332;color:#1B4332;background:rgba(27,67,50,0.02);}
.uploaded-photos{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px;margin-top:10px;}
.photo-thumb{width:100%;aspect-ratio:1;object-fit:cover;border-radius:8px;}
.toggle-row-wiz{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #f5f5f5;}
.toggle-row-wiz:first-of-type{border-top:1px solid #f5f5f5;}
.tr-title{font-size:14px;font-weight:500;color:#0F0F0F;}
.tr-sub{font-size:12px;color:#888;}
.wiz-nav{display:flex;justify-content:space-between;align-items:center;margin-top:20px;}
.wbtn{padding:12px 28px;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;cursor:pointer;border-radius:10px;transition:all 0.18s;}
.wbtn-back{background:transparent;border:1.5px solid #e0e0e0;color:#666;}
.wbtn-back:hover{border-color:#1B4332;color:#0F0F0F;}
.wbtn-next{background:#1B4332;color:#fff;border:none;}
.wbtn-next:hover{background:#0D2B1F;transform:translateY(-1px);}
.step-ct{font-size:12px;color:#aaa;font-weight:500;}
.success-wrap{text-align:center;padding:20px 0;}
.success-icon{font-size:44px;margin-bottom:14px;}
.success-t{font-size:28px;font-weight:700;color:#0F0F0F;margin-bottom:7px;font-family:'DM Sans',sans-serif;}
.success-s{font-size:14px;color:#888;line-height:1.6;max-width:340px;margin:0 auto;}

/* ─── TOAST ─────────────────────────────────────────────── */
.toast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%);
  padding:12px 24px;border-radius:10px;font-size:14px;font-weight:500;
  z-index:500;opacity:0;transition:opacity 0.3s,transform 0.3s;
  pointer-events:none;box-shadow:0 4px 20px rgba(0,0,0,0.15);
  transform:translateX(-50%) translateY(8px);
}
.toast.on{opacity:1;transform:translateX(-50%) translateY(0);}
.toast-ok{background:#1B4332;color:#fff;}
.toast-err{background:#c0392b;color:#fff;}

/* ─── ANIMATIONS ────────────────────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes shake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-6px)}40%,80%{transform:translateX(6px)}}
@keyframes slideUp{from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes scaleIn{from{opacity:0;transform:scale(0.95)}to{opacity:1;transform:scale(1)}}
.fade-in{animation:fadeUp 0.5s cubic-bezier(0.16,1,0.3,1) both;}
.fade-in-1{animation:fadeUp 0.5s cubic-bezier(0.16,1,0.3,1) 0.1s both;}
.fade-in-2{animation:fadeUp 0.5s cubic-bezier(0.16,1,0.3,1) 0.2s both;}
.fade-in-3{animation:fadeUp 0.5s cubic-bezier(0.16,1,0.3,1) 0.3s both;}
.fade-in-4{animation:fadeUp 0.5s cubic-bezier(0.16,1,0.3,1) 0.4s both;}

/* ─── RESPONSIVE ────────────────────────────────────────── */
/* ─── RESPONSIVE ─────────────────────────────────────────── */
@media(max-width:1100px){
  .dash{padding:84px 16px 60px;}
}
@media(max-width:900px){
  .dash-grid{grid-template-columns:1fr;}
  .metrics{grid-template-columns:repeat(2,1fr);}
  .how-grid{grid-template-columns:1fr;}
  .cta-banner{flex-direction:column;text-align:center;padding:32px 20px;}
  .listing-hero{grid-template-columns:1fr;}
}
@media(max-width:768px){
  /* ── NAV ── */
  nav{padding:0 16px;height:60px;}
  .nav-links{display:none;}
  .hamburger{display:flex;}

  /* ── HERO ── */
  .hero{padding:28px 20px 16px;}
  .hero-title{font-size:clamp(26px,6.5vw,40px);}
  .hero-sub{font-size:13px;margin-bottom:20px;}
  .home-content{padding:0 20px 40px;}

  /* Search bar */
  .search-bar{border-radius:14px;flex-direction:column;box-shadow:0 2px 16px rgba(0,0,0,0.08);}
  .sb-field{border-right:none;border-bottom:1px solid #ebebeb;padding:12px 16px;}
  .sb-field:last-of-type{border-bottom:none;}
  .sb-search-btn{border-radius:0 0 14px 14px;padding:14px;justify-content:center;width:100%;}

  /* Stats */
  .hero-stats{flex-direction:column;max-width:100%;}
  .hero-stats .stat-item{border-right:none;border-bottom:1px solid #f0f0f0;padding:12px 20px;}
  .hero-stats .stat-item:last-child{border-bottom:none;}

  /* Category pills */
  .cat-pills{flex-wrap:nowrap;overflow-x:auto;padding-bottom:8px;justify-content:flex-start;-webkit-overflow-scrolling:touch;}
  .cat-pills::-webkit-scrollbar{display:none;}
  .cat-pill{flex-shrink:0;font-size:12px;padding:7px 14px;}

  /* Listing cards */
  .listing-grid{grid-template-columns:repeat(2,1fr);gap:12px;}
  .lc-img{font-size:48px;}
  .lc-name{font-size:13px;}
  .lc-price{font-size:14px;}
  .lc-req-btn{font-size:12px;padding:8px;}

  /* ── BROWSE ── */
  .browse-wrap{padding:72px 20px 40px;}
  .cars-grid{grid-template-columns:repeat(2,1fr);gap:12px;}

  /* ── DASHBOARD ── */
  .dash{padding:72px 20px 48px;}
  .metrics{grid-template-columns:repeat(2,1fr);gap:10px;}
  .metric{padding:14px 16px;}
  .metric-v{font-size:24px;}
  .dash-greeting{font-size:clamp(20px,5vw,32px);}
  .dash-grid{grid-template-columns:1fr;gap:16px;}
  .req-item{padding:14px 16px;flex-wrap:wrap;}
  .req-actions{flex-wrap:wrap;gap:8px;margin-top:8px;}
  .btn-ok,.btn-no{flex:1;min-width:100px;text-align:center;}
  .listing-row{padding:12px 16px;gap:10px;flex-wrap:wrap;}
  .renter-booking{grid-template-columns:auto 1fr;gap:10px;}
  .rb-actions{grid-column:1/-1;display:flex;gap:8px;margin-top:6px;}

  /* ── WIZARD ── */
  .wiz-wrap{padding:72px 20px 48px;}
  .wiz-body{padding:20px 0;}
  .w2{grid-template-columns:1fr;}
  .drive-opts{grid-template-columns:1fr;}
  .do-wide{grid-column:span 1;}
  .wiz-steps{gap:0;overflow-x:auto;padding-bottom:4px;}
  .ws-lbl{font-size:9px;}
  .wiz-nav{padding:16px 0;}

  /* ── MODALS (auth, booking, etc) ── */
  /* Slide up from bottom on mobile */
  .overlay{align-items:flex-end;padding:0;}
  .modal{
    border-radius:20px 20px 0 0;
    position:fixed;bottom:0;left:0;right:0;
    max-width:100%;
    max-height:92vh;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
    margin:0;
    width:100%;
  }
  .modal-hd{padding:16px 20px 14px;}
  .modal-body{padding:4px 20px 24px;}
  .modal-ft{padding:12px 20px 16px;}

  /* Form fields inside modals */
  .form-group{margin-bottom:14px;}
  .form-group label{font-size:13px;margin-bottom:5px;}
  .form-group input,
  .form-group select,
  .form-group textarea{
    font-size:16px;   /* prevents iOS auto-zoom */
    padding:12px 14px;
    border-radius:10px;
  }
  .form-row2{grid-template-columns:1fr;}
  .form-full{grid-column:span 1;}

  /* Auth modal OTP boxes */
  

  /* Booking modal */
  .bk-modal{max-height:92vh;border-radius:20px 20px 0 0;}

  /* ── POLICY PAGES ── */
  .policy-grid{grid-template-columns:1fr;}

  /* ── FOOTER ── */
  footer #mainFooter > div > div:first-child{grid-template-columns:1fr 1fr;}
  .how-section{padding:24px 20px;}
  .footer-grid{grid-template-columns:1fr 1fr !important;gap:20px !important;}

  /* ── GALLERY ── */
  #galleryGrid{columns:2 140px;column-gap:10px;}
  .gallery-upload-btn button{padding:8px 14px;font-size:13px;}
}
@media(max-width:480px){
  /* Tighter padding on small phones — but keep 16px min side margins */
  .browse-wrap{padding:68px 16px 40px;}
  .home-content{padding:0 16px 40px;}
  .dash{padding:68px 16px 48px;}
  .hero{padding:24px 16px 14px;}
  .wiz-wrap{padding:68px 16px 40px;}

  /* Cards */
  .listing-grid{grid-template-columns:1fr 1fr;gap:10px;}
  .cars-grid{grid-template-columns:1fr 1fr;gap:10px;}
  .lc-img{font-size:40px;}
  .lc-name{font-size:12px;}
  .lc-req-btn{font-size:11px;padding:7px;}

  /* Dashboard */
  .metrics{grid-template-columns:repeat(2,1fr);gap:8px;}
  .metric{padding:12px;}
  .metric-v{font-size:20px;}
  .d-panel{border-radius:10px;}
  .req-item{gap:8px;}

  /* Misc */
  .cat-pill{padding:6px 12px;font-size:11px;}
  .hero-title{font-size:24px;}
  .wiz-steps{display:none;}
  #galleryGrid{columns:2 120px;column-gap:8px;}
  .footer-grid{grid-template-columns:1fr!important;gap:16px!important;}

  /* Modals — full width, comfortable padding */
  .modal-hd{padding:14px 16px 12px;}
  .modal-body{padding:4px 16px 20px;}
  .modal-ft{padding:12px 16px;}
  .form-group input,
  .form-group select,
  .form-group textarea{padding:11px 12px;}
  
}
@media(max-width:360px){
  /* Very small phones — single column everything */
  .listing-grid,.cars-grid{grid-template-columns:1fr;}
  .metrics{grid-template-columns:1fr 1fr;}
  .nav-logo img{height:22px;}
  .browse-wrap,.home-content,.dash,.wiz-wrap{padding-left:12px;padding-right:12px;}
  .modal-hd,.modal-body,.modal-ft{padding-left:14px;padding-right:14px;}
  .form-group input,
  .form-group select,
  .form-group textarea{padding:10px 12px;}
}


.btn-gold{width:100%;padding:14px;background:#1B4332;color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;font-family:'DM Sans',sans-serif;cursor:pointer;transition:background 0.18s;touch-action:manipulation;}
.btn-gold:hover{background:#0D2B1F;}
.btn-gold:disabled{opacity:0.45;cursor:not-allowed;}
/* Phone number row inside auth modal */
.form-group > div > input[type="tel"] {
  display:block;
  width:100%;
  padding:13px 14px;
  border:1.5px solid #e8e8e8;
  border-radius:10px;
  font-size:16px;
  font-family:'DM Sans',sans-serif;
  color:#0F0F0F;
  background:#fff;
  outline:none;
  transition:border-color 0.18s;
  -webkit-appearance:none;
  appearance:none;
  box-sizing:border-box;
  flex:1;
  min-width:0;
}
.form-group > div > input[type="tel"]:focus {
  border-color:#1B4332;
  box-shadow:0 0 0 3px rgba(27,67,50,0.08);
}
/* ── OTP BOXES — fluid, never overflow ──────────── */
#otp-boxes{
  display:flex;
  gap:8px;
  justify-content:center;
  margin-bottom:20px;
  width:100%;
}
.otp-box{
  flex:1;
  min-width:36px;
  max-width:54px;
  aspect-ratio:1;
  text-align:center;
  font-size:clamp(16px,4vw,22px);
  font-weight:700;
  border:2px solid #e0e0e0;
  border-radius:10px;
  outline:none;
  font-family:'DM Sans',sans-serif;
  color:#0F0F0F;
  background:#f9f9f9;
  transition:border-color 0.18s,background 0.18s;
  -webkit-appearance:none;
  caret-color:transparent;
  box-sizing:border-box;
  padding:0;
}
.otp-box:focus{border-color:#1B4332;background:#fff;}
.otp-box.filled{border-color:#1B4332;background:#fff;}
